/* Copyright (c) 2009 Stephen Kelly This library is free software; you can redistribute it and/or modify it under the terms of the GNU Library General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version. This library is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Library General Public License for more details. You should have received a copy of the GNU Library General Public License along with this library; see the file COPYING.LIB. If not, write to the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. */ #ifndef AKONADI_SELECTIONPROXYMODEL_H #define AKONADI_SELECTIONPROXYMODEL_H #include #include "akonadi_export.h" namespace Akonadi { class SelectionProxyModelPrivate; /** * @short A proxy model used to reference count selected Akonadi::Collection in a view * * Only selected Collections will be populated and monitored for changes. Unselected * Collections will be ignored. * * This model extends KSelectionProxyModel to implement reference counting on the Collections * in an EntityTreeModel. The EntityTreeModel must use LazyPopulation to enable * SelectionProxyModel to work. * * By selecting a Collection, its reference count will be increased. A Collection in the * EntityTreeModel which has a reference count of zero will ignore all signals from Monitor * about items changed, inserted, removed etc, which can be expensive operations. * * Example: * * @code * * using namespace Akonadi; * * // itemView * // ^ * // | * // itemModel * // | * // flatModel * // | * // collectionView --> selectionModel * // ^ ^ * // | | * // collectionFilter | * // \______________model * * EntityTreeModel *model = new EntityTreeModel( ... ); * * // setup collection model * EntityMimeTypeFilterModel *collectionFilter = new EntityMimeTypeFilterModel( this ); * collectionFilter->setSourceModel( model ); * collectionFilter->addMimeTypeInclusionFilter( Collection::mimeType() ); * collectionFilter->setHeaderGroup( EntityTreeModel::CollectionTreeHeaders ); * * // setup collection view * EntityTreeView *collectionView = new EntityTreeView( this ); * collectionView->setModel( collectionFilter ); * * // setup selection model * SelectionProxyModel *selectionModel = new SelectionProxyModel( collectionView->selectionModel(), this ); * selectionModel->setSourceModel( model ); * * // setup item model * KDescendantsProxyModel *flatModel = new KDescendantsProxyModel( this ); * flatModel->setSourceModel( selectionModel ); * * EntityMimeTypeFilterModel *itemModel = new EntityMimeTypeFilterModel( this ); * itemModel->setSourceModel( flatModel ); * itemModel->setHeaderGroup( EntityTreeModel::ItemListHeaders ); * itemModel->addMimeTypeExclusionFilter( Collection::mimeType() ); * * EntityListView *itemView = new EntityListView( this ); * itemView->setModel( itemModel ); * @endcode * * See \ref libakonadi_integration "Integration in your Application" for further guidance on the use of this class. * @author Stephen Kelly * @since 4.4 */ class AKONADI_EXPORT SelectionProxyModel : public KSelectionProxyModel { Q_OBJECT public: /** * Creates a new selection proxy model. * * @param selectionModel The selection model of the source view. * @param parent The parent object. */ explicit SelectionProxyModel( QItemSelectionModel *selectionModel, QObject *parent = 0 ); ~SelectionProxyModel(); private: //@cond PRIVATE Q_DECLARE_PRIVATE( SelectionProxyModel ) SelectionProxyModelPrivate *const d_ptr; Q_PRIVATE_SLOT( d_func(), void rootIndexAdded( const QModelIndex & ) ) Q_PRIVATE_SLOT( d_func(), void rootIndexAboutToBeRemoved( const QModelIndex & ) ) //@endcond }; } #endif