/***************************************************************************
- * Copyright (C) 2005-07 by The Quassel Team *
+ * Copyright (C) 2005-08 by the Quassel Project *
* devel@quassel-irc.org *
* *
* This program is free software; you can redistribute it and/or modify *
* it under the terms of the GNU General Public License as published by *
* the Free Software Foundation; either version 2 of the License, or *
- * (at your option) any later version. *
+ * (at your option) version 3. *
* *
* This program is distributed in the hope that it will be useful, *
* but WITHOUT ANY WARRANTY; without even the implied warranty of *
#include "bufferviewfilter.h"
+#include <QColor>
+
+#include "networkmodel.h"
+
+#include "uisettings.h"
+
/*****************************************
* The Filter for the Tree View
*****************************************/
-BufferViewFilter::BufferViewFilter(QAbstractItemModel *model, const Modes &filtermode, const QList<uint> &nets)
+BufferViewFilter::BufferViewFilter(QAbstractItemModel *model, const Modes &filtermode, const QList<NetworkId> &nets)
: QSortFilterProxyModel(model),
mode(filtermode),
- networks(QSet<uint>::fromList(nets))
+ networks(QSet<NetworkId>::fromList(nets))
{
setSourceModel(model);
setSortCaseSensitivity(Qt::CaseInsensitive);
-
- // I have this feeling that this resulted in a fuckup once... no clue though right now and invalidateFilter isn't a slot -.-
- //connect(model, SIGNAL(invalidateFilter()), this, SLOT(invalidate()));
- connect(model, SIGNAL(invalidateFilter()), this, SLOT(invalidateFilter_()));
-}
-
-void BufferViewFilter::invalidateFilter_() {
- QSortFilterProxyModel::invalidateFilter();
}
Qt::ItemFlags BufferViewFilter::flags(const QModelIndex &index) const {
if(parent != QModelIndex())
return QSortFilterProxyModel::dropMimeData(data, action, row, column, parent);
- if(!BufferTreeModel::mimeContainsBufferList(data))
+ if(!NetworkModel::mimeContainsBufferList(data))
return false;
- QList< QPair<uint, uint> > bufferList = BufferTreeModel::mimeDataToBufferList(data);
+ QList< QPair<NetworkId, BufferId> > bufferList = NetworkModel::mimeDataToBufferList(data);
- uint netId, bufferId;
+ NetworkId netId;
+ BufferId bufferId;
for(int i = 0; i < bufferList.count(); i++) {
netId = bufferList[i].first;
bufferId = bufferList[i].second;
- networks << netId;
+ if(!networks.contains(netId)) {
+ networks << netId;
+ }
addBuffer(bufferId);
}
return true;
}
-void BufferViewFilter::addBuffer(const uint &bufferuid) {
+void BufferViewFilter::addBuffer(const BufferId &bufferuid) {
if(!buffers.contains(bufferuid)) {
buffers << bufferuid;
invalidateFilter();
return; // only child elements can be deleted
bool lastBuffer = (rowCount(index.parent()) == 1);
- uint netId = index.data(BufferTreeModel::NetworkIdRole).toUInt();
- uint bufferuid = index.data(BufferTreeModel::BufferUidRole).toUInt();
+ NetworkId netId = index.data(NetworkModel::NetworkIdRole).value<NetworkId>();
+ BufferId bufferuid = index.data(NetworkModel::BufferIdRole).value<BufferId>();
+
if(buffers.contains(bufferuid)) {
buffers.remove(bufferuid);
- if(lastBuffer)
+
+ if(lastBuffer) {
networks.remove(netId);
+ Q_ASSERT(!networks.contains(netId));
+ }
+
invalidateFilter();
}
bool BufferViewFilter::filterAcceptBuffer(const QModelIndex &source_bufferIndex) const {
- Buffer::Type bufferType = (Buffer::Type) source_bufferIndex.data(BufferTreeModel::BufferTypeRole).toInt();
+ BufferInfo::Type bufferType = (BufferInfo::Type) source_bufferIndex.data(NetworkModel::BufferTypeRole).toInt();
- if((mode & NoChannels) && bufferType == Buffer::ChannelType)
+ if((mode & NoChannels) && bufferType == BufferInfo::ChannelBuffer)
return false;
- if((mode & NoQueries) && bufferType == Buffer::QueryType)
+ if((mode & NoQueries) && bufferType == BufferInfo::QueryBuffer)
return false;
- if((mode & NoServers) && bufferType == Buffer::StatusType)
+ if((mode & NoServers) && bufferType == BufferInfo::StatusBuffer)
return false;
-// bool isActive = source_bufferIndex.data(BufferTreeModel::BufferActiveRole).toBool();
+// bool isActive = source_bufferIndex.data(NetworkModel::BufferActiveRole).toBool();
// if((mode & NoActive) && isActive)
// return false;
// if((mode & NoInactive) && !isActive)
// return false;
-// if((mode & FullCustom)) {
-// uint bufferuid = source_bufferIndex.data(BufferTreeModel::BufferUidRole).toUInt();
-// if(!buffers.contains(bufferuid))
-// return false;
-// }
+ if((mode & FullCustom)) {
+ BufferId bufferuid = source_bufferIndex.data(NetworkModel::BufferIdRole).value<BufferId>();
+ return buffers.contains(bufferuid);
+ }
return true;
}
bool BufferViewFilter::filterAcceptNetwork(const QModelIndex &source_index) const {
- uint net = source_index.data(BufferTreeModel::NetworkIdRole).toUInt();
+ NetworkId net = source_index.data(NetworkModel::NetworkIdRole).value<NetworkId>();
return !((mode & (SomeNets | FullCustom)) && !networks.contains(net));
}
}
bool BufferViewFilter::lessThan(const QModelIndex &left, const QModelIndex &right) const {
- int lefttype = left.data(BufferTreeModel::BufferTypeRole).toInt();
- int righttype = right.data(BufferTreeModel::BufferTypeRole).toInt();
+ int lefttype = left.data(NetworkModel::BufferTypeRole).toInt();
+ int righttype = right.data(NetworkModel::BufferTypeRole).toInt();
if(lefttype != righttype)
return lefttype < righttype;
return QSortFilterProxyModel::lessThan(left, right);
}
+QVariant BufferViewFilter::data(const QModelIndex &index, int role) const {
+ if(role == Qt::ForegroundRole)
+ return foreground(index);
+ else
+ return QSortFilterProxyModel::data(index, role);
+}
+
+QVariant BufferViewFilter::foreground(const QModelIndex &index) const {
+ UiSettings s("QtUi/Colors");
+ QVariant inactiveActivity = s.value("inactiveActivityFG", QVariant(QColor(Qt::gray)));
+ QVariant noActivity = s.value("noActivityFG", QVariant(QColor(Qt::black)));
+ QVariant highlightActivity = s.value("highlightActivityFG", QVariant(QColor(Qt::magenta)));
+ QVariant newMessageActivity = s.value("newMessageActivityFG", QVariant(QColor(Qt::green)));
+ QVariant otherActivity = s.value("otherActivityFG", QVariant(QColor(Qt::darkGreen)));
+
+ if(!index.data(NetworkModel::ItemActiveRole).toBool())
+ return inactiveActivity.value<QColor>();
+
+ Buffer::ActivityLevel activity = (Buffer::ActivityLevel)index.data(NetworkModel::BufferActivityRole).toInt();
+
+ if(activity & Buffer::Highlight)
+ return highlightActivity.value<QColor>();
+ if(activity & Buffer::NewMessage)
+ return newMessageActivity.value<QColor>();
+ if(activity & Buffer::OtherActivity)
+ return otherActivity.value<QColor>();
+
+ return noActivity.value<QColor>();
+
+ // FIXME:: make colors configurable;
+
+}