2
* Copyright (C) 2012 Canonical, Ltd.
4
* This program is free software; you can redistribute it and/or modify
5
* it under the terms of the GNU General Public License as published by
6
* the Free Software Foundation; version 3.
8
* This program is distributed in the hope that it will be useful,
9
* but WITHOUT ANY WARRANTY; without even the implied warranty of
10
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
11
* GNU General Public License for more details.
13
* You should have received a copy of the GNU General Public License
14
* along with this program. If not, see <http://www.gnu.org/licenses/>.
17
#ifndef QSORTFILTERPROXYMODELQML_H
18
#define QSORTFILTERPROXYMODELQML_H
20
#include <QSortFilterProxyModel>
22
class QSortFilterProxyModelQML : public QSortFilterProxyModel
26
Q_PROPERTY(QAbstractItemModel* model READ sourceModel WRITE setModel NOTIFY modelChanged)
27
Q_PROPERTY(int totalCount READ totalCount NOTIFY totalCountChanged)
28
Q_PROPERTY(int count READ count NOTIFY countChanged)
29
Q_PROPERTY(bool invertMatch READ invertMatch WRITE setInvertMatch NOTIFY invertMatchChanged)
32
explicit QSortFilterProxyModelQML(QObject *parent = 0);
34
Q_INVOKABLE QVariant data(int row, int role);
35
Q_INVOKABLE int count();
36
Q_INVOKABLE int findFirst(int role, const QVariant& value) const;
37
virtual bool filterAcceptsRow(int sourceRow, const QModelIndex &sourceParent) const;
40
int totalCount() const;
41
bool invertMatch() const;
42
QHash<int, QByteArray> roleNames() const;
45
void setModel(QAbstractItemModel *model);
46
void setInvertMatch(bool invertMatch);
49
void totalCountChanged();
51
void invertMatchChanged(bool);
58
#endif // QSORTFILTERPROXYMODELQML_H