X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fqtui%2Fchatmonitorfilter.cpp;h=1229fd4e4e6035a4d2d8416e3a1f5e9a8bc635f3;hp=e3dbd63b922ad113e867abaedd553ade2dd9e50f;hb=2c8434f74c68194d56f2084f637419123e61d18b;hpb=0a43227b8cd44625f4881cc1545d42c8c8a4876c diff --git a/src/qtui/chatmonitorfilter.cpp b/src/qtui/chatmonitorfilter.cpp index e3dbd63b..1229fd4e 100644 --- a/src/qtui/chatmonitorfilter.cpp +++ b/src/qtui/chatmonitorfilter.cpp @@ -1,5 +1,5 @@ /*************************************************************************** - * Copyright (C) 2005-2016 by the Quassel Project * + * Copyright (C) 2005-2018 by the Quassel Project * * devel@quassel-irc.org * * * * This program is free software; you can redistribute it and/or modify * @@ -29,11 +29,19 @@ ChatMonitorFilter::ChatMonitorFilter(MessageModel *model, QObject *parent) : MessageFilter(model, parent) { - ChatViewSettings viewSettings(idString()); + // Global configuration + ChatViewSettings defaultSettings; + defaultSettings.initAndNotify("ShowSenderBrackets", this, &ChatMonitorFilter::showSenderBracketsSettingChanged); + + // NOTE: Whenever changing defaults here, also update ChatMonitorSettingsPage::loadSettings() + // and ChatMonitorSettingsPage::defaults() to match + + // Chat Monitor specific configuration + ChatViewSettings viewSettings(ChatMonitorFilter::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 &))); + viewSettings.notify("ShowFields", this, &ChatMonitorFilter::showFieldsSettingChanged); + viewSettings.notify("ShowOwnMsgs", this, &ChatMonitorFilter::showOwnMessagesSettingChanged); // ChatMonitorSettingsPage QString showHighlightsSettingsId = "ShowHighlights"; @@ -41,20 +49,23 @@ ChatMonitorFilter::ChatMonitorFilter(MessageModel *model, QObject *parent) QString buffersSettingsId = "Buffers"; QString showBacklogSettingsId = "ShowBacklog"; QString includeReadSettingsId = "IncludeRead"; + QString alwaysOwnSettingsId = "AlwaysOwn"; _showHighlights = viewSettings.value(showHighlightsSettingsId, false).toBool(); - _operationMode = viewSettings.value(operationModeSettingsId, 0).toInt(); + _operationMode = viewSettings.value(operationModeSettingsId, ChatViewSettings::InvalidMode).toInt(); // read configured list of buffers to monitor/ignore foreach(QVariant v, viewSettings.value(buffersSettingsId, QVariant()).toList()) - _bufferIds << v.value(); + _bufferIds << v.value(); _showBacklog = viewSettings.value(showBacklogSettingsId, true).toBool(); - _includeRead = viewSettings.value(includeReadSettingsId, true).toBool(); - - viewSettings.notify(showHighlightsSettingsId, this, SLOT(showHighlightsSettingChanged(const QVariant &))); - viewSettings.notify(operationModeSettingsId, this, SLOT(operationModeSettingChanged(const QVariant &))); - viewSettings.notify(buffersSettingsId, this, SLOT(buffersSettingChanged(const QVariant &))); - viewSettings.notify(showBacklogSettingsId, this, SLOT(showBacklogSettingChanged(const QVariant &))); - viewSettings.notify(includeReadSettingsId, this, SLOT(includeReadSettingChanged(const QVariant &))); + _includeRead = viewSettings.value(includeReadSettingsId, false).toBool(); + _alwaysOwn = viewSettings.value(alwaysOwnSettingsId, false).toBool(); + + viewSettings.notify(showHighlightsSettingsId, this, &ChatMonitorFilter::showHighlightsSettingChanged); + viewSettings.notify(operationModeSettingsId, this, &ChatMonitorFilter::operationModeSettingChanged); + viewSettings.notify(buffersSettingsId, this, &ChatMonitorFilter::buffersSettingChanged); + viewSettings.notify(showBacklogSettingsId, this, &ChatMonitorFilter::showBacklogSettingChanged); + viewSettings.notify(includeReadSettingsId, this, &ChatMonitorFilter::includeReadSettingChanged); + viewSettings.notify(alwaysOwnSettingsId, this, &ChatMonitorFilter::alwaysOwnSettingChanged); } @@ -64,11 +75,15 @@ bool ChatMonitorFilter::filterAcceptsRow(int sourceRow, const QModelIndex &sourc QModelIndex source_index = sourceModel()->index(sourceRow, 0); BufferId bufferId = source_index.data(MessageModel::BufferIdRole).value(); - Message::Flags flags = (Message::Flags)source_index.data(MessageModel::FlagsRole).toInt(); - if ((flags & Message::Backlog) && (!_showBacklog || (!_includeRead && - (Client::networkModel()->lastSeenMsgId(bufferId) >= sourceModel()->data(source_index, MessageModel::MsgIdRole).value())))) - return false; + + if (flags & Message::Backlog) { + if (!_showBacklog) + return false; + + if (!_includeRead && Client::networkModel()->lastSeenMsgId(bufferId) >= sourceModel()->data(source_index, MessageModel::MsgIdRole).value()) + return false; + } if (!_showOwnMessages && flags & Message::Self) return false; @@ -78,13 +93,13 @@ bool ChatMonitorFilter::filterAcceptsRow(int sourceRow, const QModelIndex &sourc return false; // ChatMonitorSettingsPage - if (_operationMode == ChatViewSettings::OptOut - && !(_showHighlights && flags & Message::Highlight) - && _bufferIds.contains(bufferId)) + if (_showHighlights && flags & Message::Highlight) + ; // pass + else if (_alwaysOwn && flags & Message::Self) + ; // pass + else if (_operationMode == ChatViewSettings::OptOut && _bufferIds.contains(bufferId)) return false; - if (_operationMode == ChatViewSettings::OptIn - && !(_showHighlights && flags & Message::Highlight) - && !_bufferIds.contains(bufferId)) + else if (_operationMode == ChatViewSettings::OptIn && !_bufferIds.contains(bufferId)) return false; // ignorelist handling @@ -92,6 +107,7 @@ bool ChatMonitorFilter::filterAcceptsRow(int sourceRow, const QModelIndex &sourc if (!(flags & Message::ServerMsg) && Client::ignoreListManager() && Client::ignoreListManager()->match(source_index.data(MessageModel::MessageRole).value(), Client::networkModel()->networkName(bufferId))) return false; + return true; } @@ -123,7 +139,10 @@ QVariant ChatMonitorFilter::data(const QModelIndex &index, int role) const QString sender = MessageFilter::data(index, ChatLineModel::EditRole).toString(); fields << sender; } - return QString("<%1>").arg(fields.join(":")); + if (_showSenderBrackets) + return QString("<%1>").arg(fields.join(":")); + else + return QString("%1").arg(fields.join(":")); } @@ -175,6 +194,9 @@ void ChatMonitorFilter::showOwnMessagesSettingChanged(const QVariant &newValue) _showOwnMessages = newValue.toBool(); } +void ChatMonitorFilter::alwaysOwnSettingChanged(const QVariant &newValue) { + _alwaysOwn = newValue.toBool(); +} void ChatMonitorFilter::showHighlightsSettingChanged(const QVariant &newValue) { @@ -204,3 +226,8 @@ void ChatMonitorFilter::showBacklogSettingChanged(const QVariant &newValue) { void ChatMonitorFilter::includeReadSettingChanged(const QVariant &newValue) { _includeRead = newValue.toBool(); } + +void ChatMonitorFilter::showSenderBracketsSettingChanged(const QVariant &newValue) +{ + _showSenderBrackets = newValue.toBool(); +}