summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authortastytea <tastytea@tastytea.de>2022-01-12 23:26:50 +0100
committerNicolas Werner <nicolas.werner@hotmail.de>2022-02-10 00:48:35 +0100
commitf0bb64030ed054137608282b8bbc2bb2eacca06d (patch)
tree1d9c8aaefe84af8049e2ea4a20bcff8fb8eeaa4c /src
parentd4cc3507f8b2266742bfe332afca460c8f110865 (diff)
Hidden events: Incorporate suggestions from review
- Set TitleHint flag on dialog - Store hidden events as QSet<QString> instead of std::vector<bool> - Change wording in dialog (disable events instead of turning the hiding on)
Diffstat (limited to 'src')
-rw-r--r--src/ui/RoomSettings.cpp62
-rw-r--r--src/ui/RoomSettings.h10
2 files changed, 22 insertions, 50 deletions
diff --git a/src/ui/RoomSettings.cpp b/src/ui/RoomSettings.cpp
index 2180b5c1..0502b281 100644
--- a/src/ui/RoomSettings.cpp
+++ b/src/ui/RoomSettings.cpp
@@ -13,8 +13,11 @@
#include <QStandardPaths>
#include <QVBoxLayout>
#include <algorithm>
+#include <mtx/events/event_type.hpp>
+#include <mtx/events/nheko_extensions/hidden_events.hpp>
#include <mtx/responses/common.hpp>
#include <mtx/responses/media.hpp>
+#include <mtxclient/http/client.hpp>
#include "Cache.h"
#include "Cache_p.h"
@@ -22,9 +25,6 @@
#include "Logging.h"
#include "MatrixClient.h"
#include "Utils.h"
-#include "mtx/events/event_type.hpp"
-#include "mtx/events/nheko_extensions/hidden_events.hpp"
-#include "mtxclient/http/client.hpp"
#include "ui/TextField.h"
using namespace mtx::events;
@@ -231,21 +231,13 @@ RoomSettings::RoomSettings(QString roomid, QObject *parent)
emit accessJoinRulesChanged();
// Get room's hidden events and store it in member variable.
- using mtx::events::EventType;
- if (auto hiddenEvents =
- cache::client()->getAccountData(EventType::NhekoHiddenEvents, roomid_.toStdString())) {
+ if (auto hiddenEvents = cache::client()->getAccountData(
+ mtx::events::EventType::NhekoHiddenEvents, roomid_.toStdString())) {
if (auto tmp = std::get_if<mtx::events::EphemeralEvent<
mtx::events::account_data::nheko_extensions::HiddenEvents>>(&*hiddenEvents)) {
- const auto &types = tmp->content.hidden_event_types;
- auto is_hidden{[&types](EventType searchFor) {
- return std::find_if(types.begin(), types.end(), [&searchFor](const auto curType) {
- return curType == searchFor;
- }) != types.end();
- }};
-
- hiddenEvents_ = {is_hidden(EventType::RoomMember),
- is_hidden(EventType::RoomPowerLevels),
- is_hidden(EventType::Sticker)};
+ for (const auto event : tmp->content.hidden_event_types) {
+ hiddenEvents_.insert(mtx::events::to_string(event).data());
+ }
}
}
}
@@ -319,17 +311,9 @@ RoomSettings::accessJoinRules()
}
bool
-RoomSettings::eventHidden(int index)
+RoomSettings::eventHidden(const QString event) const
{
- try {
- // Is empty if there are no preferences stored for this room.
- if (!hiddenEvents_.empty()) {
- return hiddenEvents_.at(index);
- }
- } catch (...) {
- nhlog::db()->warn("Failed to retrieve hidden event setting at {}", index);
- }
- return false;
+ return hiddenEvents_.contains(event);
}
void
@@ -443,30 +427,18 @@ RoomSettings::openEditModal()
}
void
-RoomSettings::saveHiddenEventsSettings(const bool toggleRoomMember,
- const bool toggleRoomPowerLevels,
- const bool toggleSticker)
+RoomSettings::saveHiddenEventsSettings(const QSet<QString> events)
{
- const auto roomid = roomid_.toStdString();
- nhlog::ui()->debug("Setting events to hidden in room {}: m.room.member={}, "
- "m.room.power_levels={}, m.sticker={}",
- roomid,
- toggleRoomMember,
- toggleRoomPowerLevels,
- toggleSticker);
-
+ // TODO: Make this reusable for global account settings.
mtx::events::account_data::nheko_extensions::HiddenEvents hiddenEvents;
hiddenEvents.hidden_event_types = {
EventType::Reaction, EventType::CallCandidates, EventType::Unsupported};
- if (toggleRoomMember) {
- hiddenEvents.hidden_event_types.emplace_back(mtx::events::EventType::RoomMember);
- }
- if (toggleRoomPowerLevels) {
- hiddenEvents.hidden_event_types.emplace_back(mtx::events::EventType::RoomPowerLevels);
- }
- if (toggleSticker) {
- hiddenEvents.hidden_event_types.emplace_back(mtx::events::EventType::Sticker);
+ for (const auto &event : events) {
+ hiddenEvents.hidden_event_types.emplace_back(
+ mtx::events::getEventType(event.toStdString()));
}
+
+ const auto roomid = roomid_.toStdString();
http::client()->put_room_account_data(roomid, hiddenEvents, [&roomid](mtx::http::RequestErr e) {
if (e) {
nhlog::net()->error("Failed to update room account data in {}: {}", roomid, *e);
diff --git a/src/ui/RoomSettings.h b/src/ui/RoomSettings.h
index ee353d44..d5d42ce0 100644
--- a/src/ui/RoomSettings.h
+++ b/src/ui/RoomSettings.h
@@ -8,10 +8,11 @@
#include <QLabel>
#include <QObject>
#include <QPushButton>
+#include <QSet>
#include <QString>
+#include <mtx/events/event_type.hpp>
#include <mtx/events/guest_access.hpp>
-#include <vector>
#include "CacheStructs.h"
@@ -108,11 +109,10 @@ public:
Q_INVOKABLE void enableEncryption();
Q_INVOKABLE void updateAvatar();
Q_INVOKABLE void openEditModal();
- Q_INVOKABLE void
- saveHiddenEventsSettings(bool toggleRoomMember, bool toggleRoomPowerLevels, bool toggleSticker);
+ Q_INVOKABLE void saveHiddenEventsSettings(QSet<QString> events);
Q_INVOKABLE void changeAccessRules(int index);
Q_INVOKABLE void changeNotifications(int currentIndex);
- Q_INVOKABLE bool eventHidden(int index);
+ Q_INVOKABLE bool eventHidden(QString event) const;
signals:
void loadingChanged();
@@ -141,5 +141,5 @@ private:
RoomInfo info_;
int notifications_ = 0;
int accessRules_ = 0;
- std::vector<bool> hiddenEvents_;
+ QSet<QString> hiddenEvents_;
};