From 1d7529e60925c36af5aa5a8702e7a0827e646f00 Mon Sep 17 00:00:00 2001 From: ouwou <26526779+ouwou@users.noreply.github.com> Date: Fri, 17 Dec 2021 02:34:14 -0500 Subject: handle mute/unmute of channels (USER_GUILD_SETTINGS_UPDATE) --- src/components/channels.cpp | 12 ++++++++++++ 1 file changed, 12 insertions(+) (limited to 'src/components/channels.cpp') diff --git a/src/components/channels.cpp b/src/components/channels.cpp index e91ed92..d49afca 100644 --- a/src/components/channels.cpp +++ b/src/components/channels.cpp @@ -174,6 +174,8 @@ ChannelList::ChannelList() discord.signal_removed_from_thread().connect(sigc::mem_fun(*this, &ChannelList::OnThreadRemoved)); discord.signal_guild_update().connect(sigc::mem_fun(*this, &ChannelList::UpdateGuild)); discord.signal_message_ack().connect(sigc::mem_fun(*this, &ChannelList::OnMessageAck)); + discord.signal_channel_muted().connect(sigc::mem_fun(*this, &ChannelList::OnChannelMute)); + discord.signal_channel_unmuted().connect(sigc::mem_fun(*this, &ChannelList::OnChannelUnmute)); } void ChannelList::UsePanedHack(Gtk::Paned &paned) { @@ -370,6 +372,16 @@ void ChannelList::DeleteThreadRow(Snowflake id) { m_model->erase(iter); } +void ChannelList::OnChannelMute(Snowflake id) { + if (auto iter = GetIteratorForChannelFromID(id)) + m_model->row_changed(m_model->get_path(iter), iter); +} + +void ChannelList::OnChannelUnmute(Snowflake id) { + if (auto iter = GetIteratorForChannelFromID(id)) + m_model->row_changed(m_model->get_path(iter), iter); +} + // create a temporary channel row for non-joined threads // and delete them when the active channel switches off of them if still not joined void ChannelList::SetActiveChannel(Snowflake id) { -- cgit v1.2.3