/* Copyright (c) 2009 Kevin Ottens 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_STATISTICSPROXYMODEL_H #define AKONADI_STATISTICSPROXYMODEL_H #include "akonadi_export.h" #include namespace Akonadi { /** * @short A proxy model that exposes collection statistics through extra columns. * * This class can be used on top of an EntityTreeModel to display extra columns * summarizing statistics of collections. * * @code * * Akonadi::EntityTreeModel *model = new Akonadi::EntityTreeModel( ... ); * * Akonadi::StatisticsProxyModel *proxy = new Akonadi::StatisticsProxyModel(); * proxy->setSourceModel( model ); * * Akonadi::EntityTreeView *view = new Akonadi::EntityTreeView( this ); * view->setModel( proxy ); * * @endcode * * @author Kevin Ottens * @since 4.4 * @deprecated use the one in kdepim, which is much faster */ class AKONADI_EXPORT_DEPRECATED StatisticsProxyModel : public QSortFilterProxyModel { Q_OBJECT public: /** * Creates a new statistics proxy model. * * @param parent The parent object. */ explicit StatisticsProxyModel( QObject *parent = 0 ); /** * Destroys the statistics proxy model. */ virtual ~StatisticsProxyModel(); /** * @param enable Display tooltips */ void setToolTipEnabled( bool enable); /** * Return true if we display tooltips, otherwise false */ bool isToolTipEnabled() const; /** * @param enable Display extra statistics columns */ void setExtraColumnsEnabled( bool enable); /** * Return true if we display extra statistics columns, otherwise false */ bool isExtraColumnsEnabled() const; virtual QModelIndex index ( int row, int column, const QModelIndex & parent = QModelIndex() ) const; virtual QVariant data( const QModelIndex & index, int role = Qt::DisplayRole ) const; virtual QVariant headerData( int section, Qt::Orientation orientation, int role = Qt::DisplayRole ) const; virtual Qt::ItemFlags flags ( const QModelIndex & index ) const; virtual int columnCount( const QModelIndex & parent = QModelIndex() ) const; virtual QModelIndexList match( const QModelIndex& start, int role, const QVariant& value, int hits = 1, Qt::MatchFlags flags = Qt::MatchFlags( Qt::MatchStartsWith | Qt::MatchWrap ) ) const; virtual void setSourceModel(QAbstractItemModel* sourceModel); virtual void connectNotify(const char* signal); private: //@cond PRIVATE class Private; Private* const d; Q_PRIVATE_SLOT( d, void proxyDataChanged( QModelIndex, QModelIndex ) ) Q_PRIVATE_SLOT( d, void sourceLayoutAboutToBeChanged() ) Q_PRIVATE_SLOT( d, void sourceLayoutChanged() ) //@endcond }; } #endif