summaryrefslogtreecommitdiff
path: root/src/windows/mainwindow.cpp
diff options
context:
space:
mode:
authorouwou <26526779+ouwou@users.noreply.github.com>2021-12-22 01:44:26 -0500
committerouwou <26526779+ouwou@users.noreply.github.com>2021-12-22 01:44:26 -0500
commit145504bdd66e93fe13426fc943e903e4d0db08d1 (patch)
tree174eab05522a6c6073a8b92629af3accd402d8f5 /src/windows/mainwindow.cpp
parent9fd0d404a128923c29c7cb4b990ca88cc719e5d6 (diff)
downloadabaddon-portaudio-145504bdd66e93fe13426fc943e903e4d0db08d1.tar.gz
abaddon-portaudio-145504bdd66e93fe13426fc943e903e4d0db08d1.zip
add mark all as read
Diffstat (limited to 'src/windows/mainwindow.cpp')
-rw-r--r--src/windows/mainwindow.cpp19
1 files changed, 15 insertions, 4 deletions
diff --git a/src/windows/mainwindow.cpp b/src/windows/mainwindow.cpp
index d171a03..c8abb75 100644
--- a/src/windows/mainwindow.cpp
+++ b/src/windows/mainwindow.cpp
@@ -47,10 +47,12 @@ MainWindow::MainWindow()
m_menu_view_threads.set_label("Threads");
m_menu_view_mark_guild_as_read.set_label("Mark Server as Read");
m_menu_view_mark_guild_as_read.add_accelerator("activate", m_accels, GDK_KEY_Escape, Gdk::SHIFT_MASK, Gtk::ACCEL_VISIBLE);
+ m_menu_view_mark_all_as_read.set_label("Mark All as Read");
m_menu_view_sub.append(m_menu_view_friends);
m_menu_view_sub.append(m_menu_view_pins);
m_menu_view_sub.append(m_menu_view_threads);
m_menu_view_sub.append(m_menu_view_mark_guild_as_read);
+ m_menu_view_sub.append(m_menu_view_mark_all_as_read);
m_menu_view_sub.signal_popped_up().connect(sigc::mem_fun(*this, &MainWindow::OnViewSubmenuPopup));
m_menu_bar.append(m_menu_file);
@@ -109,10 +111,14 @@ MainWindow::MainWindow()
const auto channel_id = GetChatActiveChannel();
const auto channel = discord.GetChannel(channel_id);
if (channel.has_value() && channel->GuildID.has_value()) {
- discord.MarkGuildAsRead(*channel->GuildID, [](...) {});
+ discord.MarkGuildAsRead(*channel->GuildID, NOOP_CALLBACK);
}
});
+ m_menu_view_mark_all_as_read.signal_activate().connect([this] {
+ Abaddon::Get().GetDiscordClient().MarkAllAsRead(NOOP_CALLBACK);
+ });
+
m_content_box.set_hexpand(true);
m_content_box.set_vexpand(true);
m_content_box.show();
@@ -262,13 +268,18 @@ void MainWindow::OnDiscordSubmenuPopup(const Gdk::Rectangle *flipped_rect, const
}
void MainWindow::OnViewSubmenuPopup(const Gdk::Rectangle *flipped_rect, const Gdk::Rectangle *final_rect, bool flipped_x, bool flipped_y) {
- m_menu_view_friends.set_sensitive(Abaddon::Get().GetDiscordClient().IsStarted());
+ auto &discord = Abaddon::Get().GetDiscordClient();
+ const bool discord_active = discord.IsStarted();
+
+ m_menu_view_friends.set_sensitive(discord_active);
+ m_menu_view_mark_guild_as_read.set_sensitive(discord_active);
+ m_menu_view_mark_all_as_read.set_sensitive(discord_active);
+
auto channel_id = GetChatActiveChannel();
m_menu_view_pins.set_sensitive(false);
m_menu_view_threads.set_sensitive(false);
if (channel_id.IsValid()) {
- auto channel = Abaddon::Get().GetDiscordClient().GetChannel(channel_id);
- if (channel.has_value()) {
+ if (auto channel = discord.GetChannel(channel_id); channel.has_value()) {
m_menu_view_threads.set_sensitive(channel->Type == ChannelType::GUILD_TEXT || channel->IsThread());
m_menu_view_pins.set_sensitive(channel->Type == ChannelType::GUILD_TEXT || channel->Type == ChannelType::DM || channel->Type == ChannelType::GROUP_DM || channel->IsThread());
}