X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fuisupport%2Fbufferhotlistfilter.cpp;h=0df4203374b1cd44ffb5dabcd913329c459be9ac;hp=1c262271d5ac0eeda86162fab41df006856c47e7;hb=695758015a80eb8c158a9ac4c0f1c0b547e70df3;hpb=754a784dda6fe5235c59a7ce3829599ccf62eeda diff --git a/src/uisupport/bufferhotlistfilter.cpp b/src/uisupport/bufferhotlistfilter.cpp index 1c262271..0df42033 100644 --- a/src/uisupport/bufferhotlistfilter.cpp +++ b/src/uisupport/bufferhotlistfilter.cpp @@ -1,5 +1,5 @@ /*************************************************************************** - * Copyright (C) 2005-08 by the Quassel Project * + * Copyright (C) 2005-2015 by the Quassel Project * * devel@quassel-irc.org * * * * This program is free software; you can redistribute it and/or modify * @@ -15,55 +15,68 @@ * You should have received a copy of the GNU General Public License * * along with this program; if not, write to the * * Free Software Foundation, Inc., * - * 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * + * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. * ***************************************************************************/ #include "bufferhotlistfilter.h" #include "networkmodel.h" + BufferHotListFilter::BufferHotListFilter(QAbstractItemModel *source, QObject *parent) - : QSortFilterProxyModel(parent) + : QSortFilterProxyModel(parent) +{ + setSourceModel(source); + setDynamicSortFilter(true); + sort(0, Qt::DescendingOrder); // enable sorting... this is "usually" triggered by a enabling setSortingEnabled(true) on a view; +} + +BufferId BufferHotListFilter::hottestBuffer() { - setSourceModel(source); - setDynamicSortFilter(true); - sort(0, Qt::DescendingOrder); // enable sorting... this is "usually" triggered by a enabling setSortingEnabled(true) on a view; + invalidate(); + sort(0, Qt::DescendingOrder); + QModelIndex topIndex = index(0,0); + return data(topIndex, NetworkModel::BufferIdRole).value(); } -bool BufferHotListFilter::filterAcceptsRow(int source_row, const QModelIndex &source_parent) const { - Q_ASSERT(sourceModel()); - QModelIndex source_index = sourceModel()->index(source_row, 0, source_parent); +bool BufferHotListFilter::filterAcceptsRow(int source_row, const QModelIndex &source_parent) const +{ + Q_ASSERT(sourceModel()); + QModelIndex source_index = sourceModel()->index(source_row, 0, source_parent); - MsgId firstUnreadMsgId = sourceModel()->data(source_index, NetworkModel::BufferFirstUnreadMsgIdRole).value(); - if(!firstUnreadMsgId.isValid()) - return false; + MsgId firstUnreadMsgId = sourceModel()->data(source_index, NetworkModel::BufferFirstUnreadMsgIdRole).value(); + if (!firstUnreadMsgId.isValid()) + return false; - // filter out statusbuffers (it's accessable as networkitem) - BufferInfo::Type bufferType = (BufferInfo::Type)sourceModel()->data(source_index, NetworkModel::BufferTypeRole).toInt(); - if(bufferType == BufferInfo::StatusBuffer) { - NetworkModel::ItemType itemType = (NetworkModel::ItemType)sourceModel()->data(source_index, NetworkModel::ItemTypeRole).toInt(); - return itemType == NetworkModel::NetworkItemType; - } + // filter out statusbuffers (it's accessable as networkitem) + BufferInfo::Type bufferType = (BufferInfo::Type)sourceModel()->data(source_index, NetworkModel::BufferTypeRole).toInt(); + if (bufferType == BufferInfo::StatusBuffer) { + NetworkModel::ItemType itemType = (NetworkModel::ItemType)sourceModel()->data(source_index, NetworkModel::ItemTypeRole).toInt(); + return itemType == NetworkModel::NetworkItemType; + } - return true; + return true; } -bool BufferHotListFilter::lessThan(const QModelIndex &source_left, const QModelIndex &source_right) const { - int leftActivity = sourceModel()->data(source_left, NetworkModel::BufferActivityRole).toInt(); - int rightActivity = sourceModel()->data(source_right, NetworkModel::BufferActivityRole).toInt(); - if(leftActivity != rightActivity) - return leftActivity < rightActivity; - MsgId leftUnreadMsgId = sourceModel()->data(source_left, NetworkModel::BufferFirstUnreadMsgIdRole).value(); - MsgId rightUnreadMsgId = sourceModel()->data(source_right, NetworkModel::BufferFirstUnreadMsgIdRole).value(); - return leftUnreadMsgId > rightUnreadMsgId; // newer messages are treated to be "less" +bool BufferHotListFilter::lessThan(const QModelIndex &source_left, const QModelIndex &source_right) const +{ + int leftActivity = sourceModel()->data(source_left, NetworkModel::BufferActivityRole).toInt(); + int rightActivity = sourceModel()->data(source_right, NetworkModel::BufferActivityRole).toInt(); + if (leftActivity != rightActivity) + return leftActivity < rightActivity; + + MsgId leftUnreadMsgId = sourceModel()->data(source_left, NetworkModel::BufferFirstUnreadMsgIdRole).value(); + MsgId rightUnreadMsgId = sourceModel()->data(source_right, NetworkModel::BufferFirstUnreadMsgIdRole).value(); + return leftUnreadMsgId > rightUnreadMsgId; // newer messages are treated to be "less" } + // QVariant BufferHotListFilter::data(const QModelIndex &index, int role) const { // QVariant d = QSortFilterProxyModel::data(index, role); // if(role == Qt::DisplayRole) { -// int activity = QSortFilterProxyModel::data(index, NetworkModel::BufferActivityRole).toInt(); +// int activity = QSortFilterProxyModel::data(index, NetworkModel::BufferActivityRole).toInt(); // MsgId unreadMsgId = QSortFilterProxyModel::data(index, NetworkModel::BufferFirstUnreadMsgIdRole).value(); // return QString("%1 %2 %3").arg(d.toString()).arg(activity).arg(unreadMsgId.toInt()); // }