From 916e797c10d10ba556e9a3339353f1bd97663d15 Mon Sep 17 00:00:00 2001 From: Anthony Bilinski Date: Mon, 14 Feb 2022 02:28:57 -0800 Subject: [PATCH] feat(Settings): Add setting for hiding group join and leave system messages Messages can become spammy is long lasting quiet groups, drowning out real user messages Backported from 1be5b99d1741b0f4c92f9e8b51150e0d44ca0a42 --- src/persistence/igroupsettings.h | 4 ++++ src/persistence/settings.cpp | 17 +++++++++++++++++ src/persistence/settings.h | 6 +++++- test/model/groupmessagedispatcher_test.cpp | 4 ++++ 4 files changed, 30 insertions(+), 1 deletion(-) diff --git a/src/persistence/igroupsettings.h b/src/persistence/igroupsettings.h index ab48b3d10..59ea3a24b 100644 --- a/src/persistence/igroupsettings.h +++ b/src/persistence/igroupsettings.h @@ -33,7 +33,11 @@ public: virtual bool getGroupAlwaysNotify() const = 0; virtual void setGroupAlwaysNotify(bool newValue) = 0; + virtual bool getShowGroupJoinLeaveMessages() const = 0; + virtual void setShowGroupJoinLeaveMessages(bool newValue) = 0; + DECLARE_SIGNAL(blackListChanged, QStringList const& blist); + DECLARE_SIGNAL(showGroupJoinLeaveMessagesChanged, bool show); }; #endif /*IGROUP_SETTINGS_H*/ diff --git a/src/persistence/settings.cpp b/src/persistence/settings.cpp index e724775f3..0d8bbe3e3 100644 --- a/src/persistence/settings.cpp +++ b/src/persistence/settings.cpp @@ -203,6 +203,7 @@ void Settings::loadGlobal() lightTrayIcon = s.value("lightTrayIcon", false).toBool(); useEmoticons = s.value("useEmoticons", true).toBool(); statusChangeNotificationEnabled = s.value("statusChangeNotificationEnabled", false).toBool(); + showGroupJoinLeaveMessages = s.value("showGroupJoinLeaveMessages", false).toBool(); spellCheckingEnabled = s.value("spellCheckingEnabled", true).toBool(); themeColor = s.value("themeColor", 0).toInt(); style = s.value("style", "").toString(); @@ -680,6 +681,7 @@ void Settings::saveGlobal() s.setValue("style", style); s.setValue("nameColors", nameColors); s.setValue("statusChangeNotificationEnabled", statusChangeNotificationEnabled); + s.setValue("showGroupJoinLeaveMessages", showGroupJoinLeaveMessages); s.setValue("spellCheckingEnabled", spellCheckingEnabled); } s.endGroup(); @@ -1155,6 +1157,21 @@ void Settings::setStatusChangeNotificationEnabled(bool newValue) } } +bool Settings::getShowGroupJoinLeaveMessages() const +{ + QMutexLocker locker{&bigLock}; + return showGroupJoinLeaveMessages; +} + +void Settings::setShowGroupJoinLeaveMessages(bool newValue) +{ + QMutexLocker locker{&bigLock}; + if (newValue != showGroupJoinLeaveMessages) { + showGroupJoinLeaveMessages = newValue; + emit showGroupJoinLeaveMessagesChanged(showGroupJoinLeaveMessages); + } +} + bool Settings::getSpellCheckingEnabled() const { const QMutexLocker locker{&bigLock}; diff --git a/src/persistence/settings.h b/src/persistence/settings.h index a8fd1525d..30d1f246d 100644 --- a/src/persistence/settings.h +++ b/src/persistence/settings.h @@ -464,9 +464,12 @@ public: QStringList getBlackList() const override; void setBlackList(const QStringList& blist) override; - SIGNAL_IMPL(Settings, blackListChanged, QStringList const& blist) + bool getShowGroupJoinLeaveMessages() const override; + void setShowGroupJoinLeaveMessages(bool newValue) override; + SIGNAL_IMPL(Settings, showGroupJoinLeaveMessagesChanged, bool show) + // State QByteArray getWindowGeometry() const; void setWindowGeometry(const QByteArray& value); @@ -654,6 +657,7 @@ private: QString timestampFormat; QString dateFormat; bool statusChangeNotificationEnabled; + bool showGroupJoinLeaveMessages; bool spellCheckingEnabled; // Privacy diff --git a/test/model/groupmessagedispatcher_test.cpp b/test/model/groupmessagedispatcher_test.cpp index 323cd0f2b..50c6efa45 100644 --- a/test/model/groupmessagedispatcher_test.cpp +++ b/test/model/groupmessagedispatcher_test.cpp @@ -151,6 +151,10 @@ public: void setGroupAlwaysNotify(bool newValue) override {} SIGNAL_IMPL(MockGroupSettings, blackListChanged, QStringList const& blist) + bool getShowGroupJoinLeaveMessages() const override { return true; }; + void setShowGroupJoinLeaveMessages(bool newValue) override {}; + SIGNAL_IMPL(MockGroupSettings, showGroupJoinLeaveMessagesChanged, bool show) + private: QStringList blacklist; };