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

mailcommon

  • sources
  • kde-4.12
  • kdepim
  • mailcommon
  • folderdialog
selectmulticollectionwidget.cpp
Go to the documentation of this file.
1 /*
2  Copyright (c) 2013 Montel Laurent <montel@kde.org>
3 
4  This program is free software; you can redistribute it and/or modify it
5  under the terms of the GNU General Public License, version 2, as
6  published by the Free Software Foundation.
7 
8  This program is distributed in the hope that it will be useful, but
9  WITHOUT ANY WARRANTY; without even the implied warranty of
10  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
11  General Public License for more details.
12 
13  You should have received a copy of the GNU General Public License along
14  with this program; if not, write to the Free Software Foundation, Inc.,
15  51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
16 */
17 
18 #include "selectmulticollectionwidget.h"
19 #include "checkedcollectionwidget.h"
20 
21 #include <Akonadi/RecursiveCollectionFilterProxyModel>
22 #include <Akonadi/CollectionFilterProxyModel>
23 
24 #include <Akonadi/ChangeRecorder>
25 #include <Akonadi/EntityTreeModel>
26 #include <Akonadi/EntityRightsFilterModel>
27 #include <KMime/Message>
28 #include <KRecursiveFilterProxyModel>
29 
30 #include <KCheckableProxyModel>
31 #include <KLineEdit>
32 #include <KLocale>
33 
34 #include <QVBoxLayout>
35 #include <QTreeView>
36 
37 using namespace MailCommon;
38 SelectMultiCollectionWidget::SelectMultiCollectionWidget(QWidget *parent)
39  : QWidget(parent)
40 {
41  initialize();
42 }
43 
44 
45 SelectMultiCollectionWidget::SelectMultiCollectionWidget(const QList<Akonadi::Collection::Id> &selectedCollection, QWidget *parent)
46  : QWidget(parent),
47  mListCollection(selectedCollection)
48 {
49  initialize();
50 }
51 
52 SelectMultiCollectionWidget::~SelectMultiCollectionWidget()
53 {
54 }
55 
56 void SelectMultiCollectionWidget::initialize()
57 {
58  QVBoxLayout *vbox = new QVBoxLayout;
59  setLayout(vbox);
60 
61  mCheckedCollectionWidget = new MailCommon::CheckedCollectionWidget;
62  connect(mCheckedCollectionWidget->entityTreeModel(), SIGNAL(rowsInserted(QModelIndex,int,int)),
63  this, SLOT(slotCollectionsInserted(QModelIndex,int,int)));
64 
65  vbox->addWidget(mCheckedCollectionWidget);
66 }
67 
68 void SelectMultiCollectionWidget::updateStatus(const QModelIndex &parent)
69 {
70  const int nbCol = mCheckedCollectionWidget->checkableProxy()->rowCount( parent );
71  for ( int i = 0; i < nbCol; ++i ) {
72  const QModelIndex child = mCheckedCollectionWidget->checkableProxy()->index( i, 0, parent );
73 
74  const Akonadi::Collection col =
75  mCheckedCollectionWidget->checkableProxy()->data( child, Akonadi::EntityTreeModel::CollectionRole ).value<Akonadi::Collection>();
76 
77  if (mListCollection.contains(col.id())) {
78  mCheckedCollectionWidget->checkableProxy()->setData( child, Qt::Checked, Qt::CheckStateRole );
79  }
80  updateStatus( child );
81  }
82 }
83 
84 void SelectMultiCollectionWidget::slotCollectionsInserted(const QModelIndex &, int, int)
85 {
86  if (!mListCollection.isEmpty()) {
87  updateStatus(QModelIndex());
88  }
89  mCheckedCollectionWidget->folderTreeView()->expandAll();
90 }
91 
92 QList<Akonadi::Collection> SelectMultiCollectionWidget::selectedCollection(const QModelIndex &parent) const
93 {
94  QList<Akonadi::Collection> lst;
95 
96  const int nbCol = mCheckedCollectionWidget->checkableProxy()->rowCount( parent );
97  for ( int i = 0; i < nbCol; ++i ) {
98  const QModelIndex child = mCheckedCollectionWidget->checkableProxy()->index( i, 0, parent );
99 
100  const Akonadi::Collection col =
101  mCheckedCollectionWidget->checkableProxy()->data( child, Akonadi::EntityTreeModel::CollectionRole ).value<Akonadi::Collection>();
102 
103  if (mCheckedCollectionWidget->checkableProxy()->data( child, Qt::CheckStateRole ).value<int>())
104  lst << col;
105  lst << selectedCollection( child );
106  }
107  return lst;
108 }
109 
110 
111 #include "selectmulticollectionwidget.moc"
MailCommon::CheckedCollectionWidget
Definition: checkedcollectionwidget.h:35
MailCommon::SelectMultiCollectionWidget::~SelectMultiCollectionWidget
~SelectMultiCollectionWidget()
Definition: selectmulticollectionwidget.cpp:52
QWidget
MailCommon::SelectMultiCollectionWidget::SelectMultiCollectionWidget
SelectMultiCollectionWidget(const QList< Akonadi::Collection::Id > &selectedCollection, QWidget *parent=0)
Definition: selectmulticollectionwidget.cpp:45
MailCommon::CheckedCollectionWidget::folderTreeView
QTreeView * folderTreeView() const
Definition: checkedcollectionwidget.cpp:94
selectmulticollectionwidget.h
checkedcollectionwidget.h
MailCommon::CheckedCollectionWidget::entityTreeModel
Akonadi::EntityTreeModel * entityTreeModel() const
Definition: checkedcollectionwidget.cpp:89
MailCommon::CheckedCollectionWidget::checkableProxy
KCheckableProxyModel * checkableProxy() const
Definition: checkedcollectionwidget.cpp:104
QList
MailCommon::SelectMultiCollectionWidget::selectedCollection
QList< Akonadi::Collection > selectedCollection(const QModelIndex &parent=QModelIndex()) const
Definition: selectmulticollectionwidget.cpp:92
This file is part of the KDE documentation.
Documentation copyright © 1996-2014 The KDE developers.
Generated on Tue Oct 14 2014 22:55:15 by doxygen 1.8.7 written by Dimitri van Heesch, © 1997-2006

KDE's Doxygen guidelines are available online.

mailcommon

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

kdepim API Reference

Skip menu "kdepim API Reference"
  • akonadi_next
  • akregator
  • blogilo
  • calendarsupport
  • console
  •   kabcclient
  •   konsolekalendar
  • kaddressbook
  • kalarm
  •   lib
  • kdgantt2
  • kjots
  • kleopatra
  • kmail
  • knode
  • knotes
  • kontact
  • korgac
  • korganizer
  • ktimetracker
  • libkdepim
  • libkleo
  • libkpgp
  • mailcommon
  • messagelist
  • messageviewer

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