• Skip to content
  • Skip to link menu
KDE API Reference
  • KDE API Reference
  • kdepimlibs API Reference
  • KDE Home
  • Contact Us
 

akonadi

  • sources
  • kde-4.14
  • kdepimlibs
  • akonadi
recursivecollectionfilterproxymodel.cpp
1 /*
2  Copyright (c) 2009 Stephen Kelly <steveire@gmail.com>
3  Copyright (c) 2012 Laurent Montel <montel@kde.org>
4 
5  This library is free software; you can redistribute it and/or modify it
6  under the terms of the GNU Library General Public License as published by
7  the Free Software Foundation; either version 2 of the License, or (at your
8  option) any later version.
9 
10  This library is distributed in the hope that it will be useful, but WITHOUT
11  ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
12  FITNESS FOR A PARTICULAR PURPOSE. See the GNU Library General Public
13  License for more details.
14 
15  You should have received a copy of the GNU Library General Public License
16  along with this library; see the file COPYING.LIB. If not, write to the
17  Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
18  02110-1301, USA.
19 */
20 
21 #include "recursivecollectionfilterproxymodel.h"
22 
23 #include "entitytreemodel.h"
24 #include "mimetypechecker.h"
25 
26 #include <kdebug.h>
27 
28 using namespace Akonadi;
29 
30 namespace Akonadi
31 {
32 
33 class RecursiveCollectionFilterProxyModelPrivate
34 {
35  Q_DECLARE_PUBLIC(RecursiveCollectionFilterProxyModel)
36  RecursiveCollectionFilterProxyModel *q_ptr;
37 public:
38  RecursiveCollectionFilterProxyModelPrivate(RecursiveCollectionFilterProxyModel *model)
39  : q_ptr(model)
40  , checkOnlyChecked(false)
41  {
42 
43  }
44 
45  QSet<QString> includedMimeTypes;
46  Akonadi::MimeTypeChecker checker;
47  QString pattern;
48  bool checkOnlyChecked;
49 };
50 
51 }
52 
53 RecursiveCollectionFilterProxyModel::RecursiveCollectionFilterProxyModel(QObject *parent)
54  : KRecursiveFilterProxyModel(parent)
55  , d_ptr(new RecursiveCollectionFilterProxyModelPrivate(this))
56 {
57 
58 }
59 
60 RecursiveCollectionFilterProxyModel::~RecursiveCollectionFilterProxyModel()
61 {
62  delete d_ptr;
63 }
64 
65 bool RecursiveCollectionFilterProxyModel::acceptRow(int sourceRow, const QModelIndex &sourceParent) const
66 {
67  Q_D(const RecursiveCollectionFilterProxyModel);
68 
69  const QModelIndex rowIndex = sourceModel()->index(sourceRow, 0, sourceParent);
70  const Akonadi::Collection collection = rowIndex.data(Akonadi::EntityTreeModel::CollectionRole).value<Akonadi::Collection>();
71  if (!collection.isValid()) {
72  return false;
73  }
74  const bool checked = (rowIndex.data(Qt::CheckStateRole).toInt() == Qt::Checked);
75  const bool isCheckable = sourceModel()->flags(rowIndex) & Qt::ItemIsUserCheckable;
76  if (isCheckable && (d->checkOnlyChecked && !checked)) {
77  return false;
78  }
79 
80  const bool collectionWanted = d->checker.isWantedCollection(collection);
81  if (collectionWanted) {
82  if (!d->pattern.isEmpty()) {
83  const QString text = rowIndex.data(Qt::DisplayRole).toString();
84  return text.contains(d->pattern, Qt::CaseInsensitive);
85  }
86  }
87  return collectionWanted;
88 }
89 
90 void RecursiveCollectionFilterProxyModel::addContentMimeTypeInclusionFilter(const QString &mimeType)
91 {
92  Q_D(RecursiveCollectionFilterProxyModel);
93  d->includedMimeTypes << mimeType;
94  d->checker.setWantedMimeTypes(d->includedMimeTypes.toList());
95  invalidateFilter();
96 }
97 
98 void RecursiveCollectionFilterProxyModel::addContentMimeTypeInclusionFilters(const QStringList &mimeTypes)
99 {
100  Q_D(RecursiveCollectionFilterProxyModel);
101  d->includedMimeTypes.unite(mimeTypes.toSet());
102  d->checker.setWantedMimeTypes(d->includedMimeTypes.toList());
103  invalidateFilter();
104 }
105 
106 void RecursiveCollectionFilterProxyModel::clearFilters()
107 {
108  Q_D(RecursiveCollectionFilterProxyModel);
109  d->includedMimeTypes.clear();
110  d->checker.setWantedMimeTypes(QStringList());
111  invalidateFilter();
112 }
113 
114 void RecursiveCollectionFilterProxyModel::setContentMimeTypeInclusionFilters(const QStringList &mimeTypes)
115 {
116  Q_D(RecursiveCollectionFilterProxyModel);
117  d->includedMimeTypes = mimeTypes.toSet();
118  d->checker.setWantedMimeTypes(d->includedMimeTypes.toList());
119  invalidateFilter();
120 }
121 
122 QStringList RecursiveCollectionFilterProxyModel::contentMimeTypeInclusionFilters() const
123 {
124  Q_D(const RecursiveCollectionFilterProxyModel);
125  return d->includedMimeTypes.toList();
126 }
127 
128 int Akonadi::RecursiveCollectionFilterProxyModel::columnCount(const QModelIndex &index) const
129 {
130  // Optimization: we know that we're not changing the number of columns, so skip QSortFilterProxyModel
131  return sourceModel()->columnCount(mapToSource(index));
132 }
133 
134 void Akonadi::RecursiveCollectionFilterProxyModel::setSearchPattern(const QString &pattern)
135 {
136  Q_D(RecursiveCollectionFilterProxyModel);
137  d->pattern = pattern;
138  invalidate();
139 }
140 
141 void Akonadi::RecursiveCollectionFilterProxyModel::setIncludeCheckedOnly(bool checked)
142 {
143  Q_D(RecursiveCollectionFilterProxyModel);
144  d->checkOnlyChecked = checked;
145  invalidate();
146 }
QModelIndex
Akonadi::RecursiveCollectionFilterProxyModel::clearFilters
void clearFilters()
Clears the current filters.
Definition: recursivecollectionfilterproxymodel.cpp:106
Akonadi::Collection
Represents a collection of PIM items.
Definition: collection.h:75
Akonadi::RecursiveCollectionFilterProxyModel::setSearchPattern
void setSearchPattern(const QString &pattern)
Add search pattern.
Definition: recursivecollectionfilterproxymodel.cpp:134
QVariant::value
T value() const
QList::toSet
QSet< T > toSet() const
Akonadi::MimeTypeChecker
Helper for checking MIME types of Collections and Items.
Definition: mimetypechecker.h:109
Akonadi::RecursiveCollectionFilterProxyModel::RecursiveCollectionFilterProxyModel
RecursiveCollectionFilterProxyModel(QObject *parent=0)
Creates a new recursive collection filter proxy model.
Definition: recursivecollectionfilterproxymodel.cpp:53
Akonadi::RecursiveCollectionFilterProxyModel::addContentMimeTypeInclusionFilters
void addContentMimeTypeInclusionFilters(const QStringList &mimeTypes)
Add content mime types to be shown by the filter.
Definition: recursivecollectionfilterproxymodel.cpp:98
QVariant::toInt
int toInt(bool *ok) const
QObject
QSet< QString >
Akonadi::EntityTreeModel::CollectionRole
The collection.
Definition: entitytreemodel.h:336
QString
Akonadi::RecursiveCollectionFilterProxyModel
A model to filter out collections of non-matching content types.
Definition: recursivecollectionfilterproxymodel.h:39
QStringList
Akonadi::RecursiveCollectionFilterProxyModel::setIncludeCheckedOnly
void setIncludeCheckedOnly(bool checked)
Show only checked item.
Definition: recursivecollectionfilterproxymodel.cpp:141
QString::contains
bool contains(QChar ch, Qt::CaseSensitivity cs) const
Akonadi::RecursiveCollectionFilterProxyModel::setContentMimeTypeInclusionFilters
void setContentMimeTypeInclusionFilters(const QStringList &mimeTypes)
Replace the content mime types to be shown by the filter.
Definition: recursivecollectionfilterproxymodel.cpp:114
QModelIndex::data
QVariant data(int role) const
Akonadi::RecursiveCollectionFilterProxyModel::addContentMimeTypeInclusionFilter
void addContentMimeTypeInclusionFilter(const QString &mimeType)
Add content mime type to be shown by the filter.
Definition: recursivecollectionfilterproxymodel.cpp:90
Akonadi::RecursiveCollectionFilterProxyModel::contentMimeTypeInclusionFilters
QStringList contentMimeTypeInclusionFilters() const
Returns the currently included mimetypes in the filter.
Definition: recursivecollectionfilterproxymodel.cpp:122
Akonadi::Entity::isValid
bool isValid() const
Returns whether the entity is valid.
Definition: entity.cpp:97
QVariant::toString
QString toString() const
Akonadi::RecursiveCollectionFilterProxyModel::~RecursiveCollectionFilterProxyModel
virtual ~RecursiveCollectionFilterProxyModel()
Destroys the recursive collection filter proxy model.
Definition: recursivecollectionfilterproxymodel.cpp:60
This file is part of the KDE documentation.
Documentation copyright © 1996-2020 The KDE developers.
Generated on Mon Jun 22 2020 13:38:03 by doxygen 1.8.7 written by Dimitri van Heesch, © 1997-2006

KDE's Doxygen guidelines are available online.

akonadi

Skip menu "akonadi"
  • Main Page
  • Namespace List
  • Namespace Members
  • Alphabetical List
  • Class List
  • Class Hierarchy
  • Class Members
  • File List
  • Modules
  • Related Pages

kdepimlibs API Reference

Skip menu "kdepimlibs API Reference"
  • akonadi
  •   contact
  •   kmime
  •   socialutils
  • kabc
  • kalarmcal
  • kblog
  • kcal
  • kcalcore
  • kcalutils
  • kholidays
  • kimap
  • kioslave
  •   imap4
  •   mbox
  •   nntp
  • kldap
  • kmbox
  • kmime
  • kontactinterface
  • kpimidentities
  • kpimtextedit
  • kpimutils
  • kresources
  • ktnef
  • kxmlrpcclient
  • mailtransport
  • microblog
  • qgpgme
  • syndication
  •   atom
  •   rdf
  •   rss2

Search



Report problems with this website to our bug tracking system.
Contact the specific authors with questions and comments about the page contents.

KDE® and the K Desktop Environment® logo are registered trademarks of KDE e.V. | Legal