X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fuisupport%2Fnickviewfilter.cpp;h=907034d74d5ca6874fd4d38e06bcde759abae124;hp=993bac08a1d88a6e250388d915ddbcf84c8c7fcb;hb=da28b86876edea39e97ffdd4cc5602072c001f93;hpb=68efe6df6d72f1ac498d0594866455418552665d diff --git a/src/uisupport/nickviewfilter.cpp b/src/uisupport/nickviewfilter.cpp index 993bac08..907034d7 100644 --- a/src/uisupport/nickviewfilter.cpp +++ b/src/uisupport/nickviewfilter.cpp @@ -29,12 +29,14 @@ /****************************************************************************************** * NickViewFilter ******************************************************************************************/ -NickViewFilter::NickViewFilter(NetworkModel *parent) - : QSortFilterProxyModel(parent) +NickViewFilter::NickViewFilter(const BufferId &bufferId, NetworkModel *parent) + : QSortFilterProxyModel(parent), + _bufferId(bufferId) { setSourceModel(parent); setDynamicSortFilter(true); setSortCaseSensitivity(Qt::CaseInsensitive); + setSortRole(TreeModel::SortRole); } QVariant NickViewFilter::data(const QModelIndex &index, int role) const { @@ -42,6 +44,12 @@ QVariant NickViewFilter::data(const QModelIndex &index, int role) const { return foreground(index); else return QSortFilterProxyModel::data(index, role); +// else { +// QVariant d = +// if(role == 0) +// qDebug() << index << role << d; +// return d; +// } } QVariant NickViewFilter::foreground(const QModelIndex &index) const { @@ -57,3 +65,13 @@ QVariant NickViewFilter::foreground(const QModelIndex &index) const { // FIXME:: make colors configurable; // FIXME: use the style interface instead of qsettings } + + +bool NickViewFilter::filterAcceptsRow(int source_row, const QModelIndex &source_parent) const { + // root node, networkindexes, the bufferindex of the buffer this filter is active for and it's childs are accepted + if(!source_parent.isValid()) + return true; + + QModelIndex source_child = source_parent.child(source_row, 0); + return (sourceModel()->data(source_child, NetworkModel::BufferIdRole).value() == _bufferId); +}