X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fqtui%2Fchatmonitorfilter.cpp;h=bbf391892f0f036674f06c20866c1e5e07bd7b96;hp=c93c235e77ea359ccbe2fe37cd250202606d31eb;hb=38880d99a159fd670915d910bcb2c4280b3efc51;hpb=0f16a547d17c536cc567bfb2746824bfca3424cd diff --git a/src/qtui/chatmonitorfilter.cpp b/src/qtui/chatmonitorfilter.cpp index c93c235e..bbf39189 100644 --- a/src/qtui/chatmonitorfilter.cpp +++ b/src/qtui/chatmonitorfilter.cpp @@ -29,10 +29,25 @@ ChatMonitorFilter::ChatMonitorFilter(MessageModel *model, QObject *parent) : MessageFilter(model, parent) { ChatViewSettings viewSettings(idString()); - _showFields = viewSettings.value("showFields", AllFields).toInt(); - _showOwnMessages = viewSettings.value("showOwnMsgs", true).toBool(); - viewSettings.notify("showFields", this, SLOT(showFieldsSettingsChanged(const QVariant &))); - viewSettings.notify("showOwnMsgs", this, SLOT(showOwnMessagesSettingChanged(const QVariant &))); + _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 { @@ -46,6 +61,16 @@ bool ChatMonitorFilter::filterAcceptsRow(int sourceRow, const QModelIndex &sourc if(!(type & (Message::Plain | Message::Notice | Message::Action))) return false; + // 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; } @@ -72,9 +97,8 @@ QVariant ChatMonitorFilter::data(const QModelIndex &index, int role) const { Message::Type messageType = (Message::Type)sourceModel()->data(source_index, MessageModel::TypeRole).toInt(); if(messageType & (Message::Plain | Message::Notice)) { - QString sender = MessageFilter::data(index, role).toString(); - // we have to strip leading and traling < / > - fields << sender.mid(1, sender.count() - 2); + QString sender = MessageFilter::data(index, ChatLineModel::EditRole).toString(); + fields << sender; } return QString("<%1>").arg(fields.join(":")); } @@ -83,30 +107,30 @@ void ChatMonitorFilter::addShowField(int field) { if(_showFields & field) return; - ChatViewSettings(idString()).setValue("showFields", _showFields | field); + ChatViewSettings(idString()).setValue("ShowFields", _showFields | field); } void ChatMonitorFilter::removeShowField(int field) { if(!(_showFields & field)) return; - ChatViewSettings(idString()).setValue("showFields", _showFields ^ field); + ChatViewSettings(idString()).setValue("ShowFields", _showFields ^ field); } void ChatMonitorFilter::setShowOwnMessages(bool show) { if(_showOwnMessages == show) return; - ChatViewSettings(idString()).setValue("showOwnMsgs", show); + ChatViewSettings(idString()).setValue("ShowOwnMsgs", show); } -void ChatMonitorFilter::showFieldsSettingsChanged(const QVariant &newValue) { +void ChatMonitorFilter::showFieldsSettingChanged(const QVariant &newValue) { int newFields = newValue.toInt(); if(_showFields == newFields) return; _showFields = newFields; - + int rows = rowCount(); if(rows == 0) return; @@ -117,3 +141,18 @@ void ChatMonitorFilter::showFieldsSettingsChanged(const QVariant &newValue) { 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(); + } +}