forked from KDE/okular
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathannotationproxymodels.h
147 lines (119 loc) · 4.54 KB
/
annotationproxymodels.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
/***************************************************************************
* Copyright (C) 2007 by Tobias Koenig <[email protected]> *
* *
* This program is free software; you can redistribute it and/or modify *
* it under the terms of the GNU General Public License as published by *
* the Free Software Foundation; either version 2 of the License, or *
* (at your option) any later version. *
***************************************************************************/
#ifndef ANNOTATIONPROXYMODEL_H
#define ANNOTATIONPROXYMODEL_H
#include <QSortFilterProxyModel>
#include <QPair>
/**
* A proxy model, which filters out all pages except the
* current one.
*/
class PageFilterProxyModel : public QSortFilterProxyModel
{
Q_OBJECT
public:
/**
* Creates a new page filter proxy model.
*
* @param parent The parent object.
*/
explicit PageFilterProxyModel( QObject *parent = nullptr );
/**
* Reimplemented from QSortFilterProxy.
*/
bool filterAcceptsRow( int, const QModelIndex& ) const override;
public Q_SLOTS:
/**
* Sets whether the proxy model shall filter
* by current page.
*/
void groupByCurrentPage( bool value );
/**
* Sets the current page.
*/
void setCurrentPage( int page );
private:
bool mGroupByCurrentPage;
int mCurrentPage;
};
/**
* A proxy model which either groups the annotations by
* pages or shows them all as list.
*/
class PageGroupProxyModel : public QAbstractProxyModel
{
Q_OBJECT
public:
/**
* Creates a new page group proxy model.
*
* @param parent The parent object.
*/
explicit PageGroupProxyModel( QObject *parent = nullptr );
int columnCount( const QModelIndex &parentIndex ) const override;
int rowCount( const QModelIndex &parentIndex ) const override;
QModelIndex index( int row, int column, const QModelIndex &parentIndex = QModelIndex() ) const override;
QModelIndex parent( const QModelIndex &index ) const override;
QModelIndex mapFromSource( const QModelIndex &sourceIndex ) const override;
QModelIndex mapToSource( const QModelIndex &proxyIndex ) const override;
void setSourceModel( QAbstractItemModel *model ) override;
public Q_SLOTS:
/**
* Sets whether the proxy model shall group
* the annotations by page.
*/
void groupByPage( bool value );
private Q_SLOTS:
void rebuildIndexes();
void sourceDataChanged(const QModelIndex &topLeft, const QModelIndex &bottomRight, const QVector<int> &roles);
private:
bool mGroupByPage;
QList<QModelIndex> mIndexes;
QList<QPair< QModelIndex, QList<QModelIndex> > > mTreeIndexes;
};
/**
* A proxy model which groups the annotations by author.
*/
class AuthorGroupProxyModel : public QAbstractProxyModel
{
Q_OBJECT
public:
/**
* Creates a new author group proxy model.
*
* @param parent The parent object.
*/
explicit AuthorGroupProxyModel( QObject *parent = nullptr );
~AuthorGroupProxyModel();
int columnCount( const QModelIndex &parentIndex ) const override;
int rowCount( const QModelIndex &parentIndex ) const override;
QModelIndex index( int row, int column, const QModelIndex &parentIndex = QModelIndex() ) const override;
QModelIndex parent( const QModelIndex &index ) const override;
QModelIndex mapFromSource( const QModelIndex &sourceIndex ) const override;
QModelIndex mapToSource( const QModelIndex &proxyIndex ) const override;
void setSourceModel( QAbstractItemModel *model ) override;
QItemSelection mapSelectionToSource(const QItemSelection &selection) const override;
QItemSelection mapSelectionFromSource(const QItemSelection &selection) const override;
QVariant data(const QModelIndex &proxyIndex, int role = Qt::DisplayRole) const override;
QMap<int, QVariant> itemData(const QModelIndex &index) const override;
Qt::ItemFlags flags(const QModelIndex &index) const override;
public Q_SLOTS:
/**
* Sets whether the proxy model shall group
* the annotations by author.
*/
void groupByAuthor( bool value );
private Q_SLOTS:
void rebuildIndexes();
void sourceDataChanged(const QModelIndex &topLeft, const QModelIndex &bottomRight, const QVector<int> &roles);
private:
class Private;
Private* const d;
};
#endif