X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fqtui%2Fchatmonitorfilter.cpp;h=b2974dda3eed0416fddae9c36bf4c04007327e5f;hp=7605d6b9b4bbccb68541f21c044385367f1829c6;hb=695758015a80eb8c158a9ac4c0f1c0b547e70df3;hpb=04315f46a16fc3627218377071e008b6b9744992 diff --git a/src/qtui/chatmonitorfilter.cpp b/src/qtui/chatmonitorfilter.cpp index 7605d6b9..b2974dda 100644 --- a/src/qtui/chatmonitorfilter.cpp +++ b/src/qtui/chatmonitorfilter.cpp @@ -1,5 +1,5 @@ /*************************************************************************** - * Copyright (C) 2005-2013 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 * @@ -39,16 +39,22 @@ ChatMonitorFilter::ChatMonitorFilter(MessageModel *model, QObject *parent) QString showHighlightsSettingsId = "ShowHighlights"; QString operationModeSettingsId = "OperationMode"; QString buffersSettingsId = "Buffers"; + QString showBacklogSettingsId = "ShowBacklog"; + QString includeReadSettingsId = "IncludeRead"; _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(); + _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 &))); } @@ -57,17 +63,20 @@ bool ChatMonitorFilter::filterAcceptsRow(int sourceRow, const QModelIndex &sourc Q_UNUSED(sourceParent) 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 || (!_showOwnMessages && flags & Message::Self)) + if ((flags & Message::Backlog) && (!_showBacklog || (!_includeRead && + (Client::networkModel()->lastSeenMsgId(bufferId) >= sourceModel()->data(source_index, MessageModel::MsgIdRole).value())))) + return false; + + if (!_showOwnMessages && flags & Message::Self) return false; Message::Type type = (Message::Type)source_index.data(MessageModel::TypeRole).toInt(); if (!(type & (Message::Plain | Message::Notice | Message::Action))) return false; - BufferId bufferId = source_index.data(MessageModel::BufferIdRole).value(); - // ChatMonitorSettingsPage if (_operationMode == ChatViewSettings::OptOut && !(_showHighlights && flags & Message::Highlight) @@ -187,3 +196,11 @@ void ChatMonitorFilter::buffersSettingChanged(const QVariant &newValue) } invalidateFilter(); } + +void ChatMonitorFilter::showBacklogSettingChanged(const QVariant &newValue) { + _showBacklog = newValue.toBool(); +} + +void ChatMonitorFilter::includeReadSettingChanged(const QVariant &newValue) { + _includeRead = newValue.toBool(); +}