X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fqtui%2Fchatmonitorfilter.cpp;h=bbf391892f0f036674f06c20866c1e5e07bd7b96;hp=3654867fa9c00302e2ea9504611bcd7cb0553510;hb=38880d99a159fd670915d910bcb2c4280b3efc51;hpb=32eadb49053bb3d68fe60a1773a79abd9e86c5f4 diff --git a/src/qtui/chatmonitorfilter.cpp b/src/qtui/chatmonitorfilter.cpp index 3654867f..bbf39189 100644 --- a/src/qtui/chatmonitorfilter.cpp +++ b/src/qtui/chatmonitorfilter.cpp @@ -20,39 +20,139 @@ #include "chatmonitorfilter.h" +#include "client.h" #include "chatlinemodel.h" +#include "networkmodel.h" +#include "chatviewsettings.h" ChatMonitorFilter::ChatMonitorFilter(MessageModel *model, QObject *parent) -: MessageFilter(model, QList(), parent) + : MessageFilter(model, parent) { - _initTime = QDateTime::currentDateTime(); + ChatViewSettings viewSettings(idString()); + _showFields = viewSettings.value("ShowFields", AllFields).toInt(); + _showOwnMessages = viewSettings.value("ShowOwnMsgs", true).toBool(); + viewSettings.notify("ShowFields", this, SLOT(showFieldsSettingChanged(const QVariant &))); + viewSettings.notify("ShowOwnMsgs", this, SLOT(showOwnMessagesSettingChanged(const QVariant &))); + // ChatMonitorSettingsPage + QString showHighlightsSettingsId = "ShowHighlights"; + QString operationModeSettingsId = "OperationMode"; + QString buffersSettingsId = "Buffers"; + + _showHighlights = viewSettings.value(showHighlightsSettingsId, false).toBool(); + _operationMode = viewSettings.value(operationModeSettingsId, 0).toInt(); + // read configured list of buffers to monitor/ignore + foreach(QVariant v, viewSettings.value(buffersSettingsId, QVariant()).toList()) + _bufferIds << v.value(); + + viewSettings.notify(showHighlightsSettingsId, this, SLOT(showHighlightsSettingChanged(const QVariant &))); + viewSettings.notify(operationModeSettingsId, this, SLOT(operationModeSettingChanged(const QVariant &))); + viewSettings.notify(buffersSettingsId, this, SLOT(buffersSettingChanged(const QVariant &))); } bool ChatMonitorFilter::filterAcceptsRow(int sourceRow, const QModelIndex &sourceParent) const { - QDateTime msgTime = sourceModel()->data(sourceModel()->index(sourceRow, 0), MessageModel::TimestampRole).toDateTime(); - return msgTime > _initTime; -} + Q_UNUSED(sourceParent) + + Message::Flags flags = (Message::Flags)sourceModel()->data(sourceModel()->index(sourceRow, 0), MessageModel::FlagsRole).toInt(); + if(flags & Message::Backlog || (!_showOwnMessages && flags & Message::Self)) + return false; + + Message::Type type = (Message::Type)sourceModel()->data(sourceModel()->index(sourceRow, 0), MessageModel::TypeRole).toInt(); + if(!(type & (Message::Plain | Message::Notice | Message::Action))) + return false; -QString ChatMonitorFilter::idString() const { - return "ChatMonitor"; + // ChatMonitorSettingsPage + if(_operationMode == ChatViewSettings::OptOut + && !(_showHighlights && flags & Message::Highlight) + && _bufferIds.contains(sourceModel()->data(sourceModel()->index(sourceRow, 0), MessageModel::BufferIdRole).value())) + return false; + if(_operationMode == ChatViewSettings::OptIn + && !(_showHighlights && flags & Message::Highlight) + && !_bufferIds.contains(sourceModel()->data(sourceModel()->index(sourceRow, 0), MessageModel::BufferIdRole).value())) + return false; + + return true; } // override this to inject display of network and channel QVariant ChatMonitorFilter::data(const QModelIndex &index, int role) const { - if(index.column() != ChatLineModel::SenderColumn) return MessageFilter::data(index, role); - if(role == ChatLineModel::DisplayRole) { - /* - BufferId bufid = data(index, ChatLineModel::BufferIdRole); - if(bufid.isValid) { - const Network *net = Client::networkModel()->networkByIndex(Client::networkModel()->bufferIndex(bufid)); - if(!net) { - qDebug() << "invalid net!"; - return QVariant(); - } - - */ + if(index.column() != ChatLineModel::SenderColumn || role != ChatLineModel::DisplayRole) + return MessageFilter::data(index, role); + + BufferId bufid = data(index, ChatLineModel::BufferIdRole).value(); + if(!bufid.isValid()) { + qDebug() << "ChatMonitorFilter::data(): chatline belongs to an invalid buffer!"; + return QVariant(); + } + + QModelIndex source_index = mapToSource(index); + + QStringList fields; + if(_showFields & NetworkField) { + fields << Client::networkModel()->networkName(bufid); + } + if(_showFields & BufferField) { + fields << Client::networkModel()->bufferName(bufid); } - return MessageFilter::data(index, role); + Message::Type messageType = (Message::Type)sourceModel()->data(source_index, MessageModel::TypeRole).toInt(); + if(messageType & (Message::Plain | Message::Notice)) { + QString sender = MessageFilter::data(index, ChatLineModel::EditRole).toString(); + fields << sender; + } + return QString("<%1>").arg(fields.join(":")); +} + +void ChatMonitorFilter::addShowField(int field) { + if(_showFields & field) + return; + + ChatViewSettings(idString()).setValue("ShowFields", _showFields | field); +} + +void ChatMonitorFilter::removeShowField(int field) { + if(!(_showFields & field)) + return; + + ChatViewSettings(idString()).setValue("ShowFields", _showFields ^ field); +} + +void ChatMonitorFilter::setShowOwnMessages(bool show) { + if(_showOwnMessages == show) + return; + + ChatViewSettings(idString()).setValue("ShowOwnMsgs", show); +} + +void ChatMonitorFilter::showFieldsSettingChanged(const QVariant &newValue) { + int newFields = newValue.toInt(); + if(_showFields == newFields) + return; + + _showFields = newFields; + + int rows = rowCount(); + if(rows == 0) + return; + + emit dataChanged(index(0, ChatLineModel::SenderColumn), index(rows - 1, ChatLineModel::SenderColumn)); +} + +void ChatMonitorFilter::showOwnMessagesSettingChanged(const QVariant &newValue) { + _showOwnMessages = newValue.toBool(); +} + +void ChatMonitorFilter::showHighlightsSettingChanged(const QVariant &newValue) { + _showHighlights = newValue.toBool(); +} + +void ChatMonitorFilter::operationModeSettingChanged(const QVariant &newValue) { + _operationMode = newValue.toInt(); +} + +void ChatMonitorFilter::buffersSettingChanged(const QVariant &newValue) { + _bufferIds.clear(); + foreach (QVariant v, newValue.toList()) { + _bufferIds << v.value(); + } }