annotate examples/itemviews/customsortfiltermodel/mysortfilterproxymodel_d1.d @ 374:681af90e1d53

Removed debug writelns. Fixed build script.
author Max Samukha <maxter@spambox.com>
date Thu, 08 Jul 2010 22:21:56 +0300
parents 06e7d3219464
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
216
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
1 /****************************************************************************
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
2 **
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
3 ** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies).
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
4 ** Contact: Qt Software Information (qt-info@nokia.com)
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
5 **
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
6 ** This file is part of the examples of the Qt Toolkit.
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
7 **
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
8 ** $QT_BEGIN_LICENSE:LGPL$
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
9 ** Commercial Usage
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
10 ** Licensees holding valid Qt Commercial licenses may use this file in
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
11 ** accordance with the Qt Commercial License Agreement provided with the
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
12 ** Software or, alternatively, in accordance with the terms contained in
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
13 ** a written agreement between you and Nokia.
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
14 **
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
15 ** GNU Lesser General Public License Usage
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
16 ** Alternatively, this file may be used under the terms of the GNU Lesser
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
17 ** General Public License version 2.1 as published by the Free Software
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
18 ** Foundation and appearing in the file LICENSE.LGPL included in the
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
19 ** packaging of this file. Please review the following information to
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
20 ** ensure the GNU Lesser General Public License version 2.1 requirements
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
21 ** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
22 **
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
23 ** In addition, as a special exception, Nokia gives you certain
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
24 ** additional rights. These rights are described in the Nokia Qt LGPL
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
25 ** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
26 ** package.
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
27 **
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
28 ** GNU General Public License Usage
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
29 ** Alternatively, this file may be used under the terms of the GNU
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
30 ** General Public License version 3.0 as published by the Free Software
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
31 ** Foundation and appearing in the file LICENSE.GPL included in the
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
32 ** packaging of this file. Please review the following information to
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
33 ** ensure the GNU General Public License version 3.0 requirements will be
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
34 ** met: http://www.gnu.org/copyleft/gpl.html.
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
35 **
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
36 ** If you are unsure which license is appropriate for your use, please
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
37 ** contact the sales department at qt-sales@nokia.com.
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
38 ** $QT_END_LICENSE$
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
39 **
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
40 ****************************************************************************/
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
41 module mysortfilterproxymodel_d1;
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
42
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
43 import qt.core.QDate;
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
44 import qt.core.QVariant;
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
45 import qt.core.QDateTime;
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
46 import qt.gui.QSortFilterProxyModel;
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
47
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
48
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
49 class MySortFilterProxyModel : public QSortFilterProxyModel
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
50 {
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
51 public:
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
52
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
53 this(QObject parent = null)
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
54 {
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
55 super(parent);
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
56 minDate = new QDate();
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
57 maxDate = new QDate();
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
58 }
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
59
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
60 QDate filterMinimumDate()
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
61 {
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
62 return minDate;
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
63 }
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
64
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
65 void setFilterMinimumDate(QDate date)
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
66 {
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
67 minDate = date;
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
68 invalidateFilter();
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
69 }
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
70
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
71 QDate filterMaximumDate()
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
72 {
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
73 return maxDate;
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
74 }
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
75
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
76 void setFilterMaximumDate(QDate date)
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
77 {
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
78 maxDate = date;
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
79 invalidateFilter();
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
80 }
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
81
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
82 protected:
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
83
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
84 override bool filterAcceptsRow(int sourceRow, QModelIndex sourceParent)
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
85 {
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
86 QModelIndex index0 = sourceModel().index(sourceRow, 0, sourceParent);
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
87 QModelIndex index1 = sourceModel().index(sourceRow, 1, sourceParent);
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
88 QModelIndex index2 = sourceModel().index(sourceRow, 2, sourceParent);
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
89
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
90 static bool contains(string str, QRegExp rx1)
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
91 {
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
92 auto rx2 = new QRegExp(rx1);
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
93 return (rx2.indexIn(str, 0) != -1);
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
94 }
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
95
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
96 return (contains(sourceModel().data(index0).toString(), filterRegExp())
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
97 || contains(sourceModel().data(index1).toString(), filterRegExp()))
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
98 && dateInRange(sourceModel().data(index2).toDate());
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
99 }
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
100
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
101 override bool lessThan(QModelIndex left, QModelIndex right)
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
102 {
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
103 QVariant leftData = sourceModel().data(left);
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
104 QVariant rightData = sourceModel().data(right);
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
105
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
106 if (leftData.type() == QVariant.Type.DateTime) {
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
107 return leftData.toDateTime() < rightData.toDateTime();
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
108 } else {
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
109 QRegExp emailPattern = new QRegExp("([\\w\\.]*@[\\w\\.]*)");
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
110
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
111 string leftString = leftData.toString();
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
112 if(left.column() == 1 && emailPattern.indexIn(leftString) != -1)
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
113 leftString = emailPattern.cap(1);
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
114
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
115 string rightString = rightData.toString();
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
116 if(right.column() == 1 && emailPattern.indexIn(rightString) != -1)
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
117 rightString = emailPattern.cap(1);
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
118
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
119 return leftString < rightString;
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
120 }
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
121 }
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
122
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
123 private:
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
124
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
125 bool dateInRange(QDate date)
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
126 {
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
127 return (!minDate.isValid() || date > minDate) && (!maxDate.isValid() || date < maxDate);
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
128 }
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
129
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
130 QDate minDate;
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
131 QDate maxDate;
06e7d3219464 ups....
SokoL_SD
parents:
diff changeset
132 }