diff options
author | ouwou <26526779+ouwou@users.noreply.github.com> | 2022-04-21 14:41:45 -0400 |
---|---|---|
committer | ouwou <26526779+ouwou@users.noreply.github.com> | 2022-04-21 14:41:45 -0400 |
commit | b4ab88f7086d87736848fc026bc87db651f8732e (patch) | |
tree | a1069413ae1345f65be23b95bd0248ef17d99a83 /src/components | |
parent | 2dab59547617f7830a4fecd3de380396b47de33f (diff) | |
download | abaddon-portaudio-b4ab88f7086d87736848fc026bc87db651f8732e.tar.gz abaddon-portaudio-b4ab88f7086d87736848fc026bc87db651f8732e.zip |
add opened tabs to state
Diffstat (limited to 'src/components')
-rw-r--r-- | src/components/channeltabswitcherhandy.cpp | 22 | ||||
-rw-r--r-- | src/components/channeltabswitcherhandy.hpp | 3 | ||||
-rw-r--r-- | src/components/chatwindow.cpp | 8 | ||||
-rw-r--r-- | src/components/chatwindow.hpp | 3 |
4 files changed, 36 insertions, 0 deletions
diff --git a/src/components/channeltabswitcherhandy.cpp b/src/components/channeltabswitcherhandy.cpp index a9d2aef..bb28272 100644 --- a/src/components/channeltabswitcherhandy.cpp +++ b/src/components/channeltabswitcherhandy.cpp @@ -81,6 +81,28 @@ void ChannelTabSwitcherHandy::ReplaceActiveTab(Snowflake id) { } } +TabsState ChannelTabSwitcherHandy::GetTabsState() { + TabsState state; + + const gint num_pages = hdy_tab_view_get_n_pages(m_tab_view); + for (gint i = 0; i < num_pages; i++) { + auto *page = hdy_tab_view_get_nth_page(m_tab_view, i); + if (page != nullptr) { + if (const auto it = m_pages_rev.find(page); it != m_pages_rev.end()) { + state.Channels.push_back(it->second); + } + } + } + + return state; +} + +void ChannelTabSwitcherHandy::UseTabsState(const TabsState &state) { + for (auto id : state.Channels) { + AddChannelTab(id); + } +} + void ChannelTabSwitcherHandy::CheckUnread(Snowflake id) { if (auto it = m_pages.find(id); it != m_pages.end()) { hdy_tab_page_set_needs_attention(it->second, Abaddon::Get().GetDiscordClient().GetUnreadStateForChannel(id) > -1); diff --git a/src/components/channeltabswitcherhandy.hpp b/src/components/channeltabswitcherhandy.hpp index 6a2dbff..41c9c92 100644 --- a/src/components/channeltabswitcherhandy.hpp +++ b/src/components/channeltabswitcherhandy.hpp @@ -5,6 +5,7 @@ #include <unordered_map> #include <handy.h> #include "discord/snowflake.hpp" + #include "state.hpp" class ChannelData; @@ -18,6 +19,8 @@ public: void AddChannelTab(Snowflake id); // switches to existing tab if it exists void ReplaceActiveTab(Snowflake id); + TabsState GetTabsState(); + void UseTabsState(const TabsState &state); private: void CheckUnread(Snowflake id); diff --git a/src/components/chatwindow.cpp b/src/components/chatwindow.cpp index 99ec8a0..f51b58f 100644 --- a/src/components/chatwindow.cpp +++ b/src/components/chatwindow.cpp @@ -172,6 +172,14 @@ void ChatWindow::SetTopic(const std::string &text) { void ChatWindow::OpenNewTab(Snowflake id) { m_tab_switcher->AddChannelTab(id); } + +TabsState ChatWindow::GetTabsState() { + return m_tab_switcher->GetTabsState(); +} + +void ChatWindow::UseTabsState(const TabsState &state) { + m_tab_switcher->UseTabsState(state); +} #endif Snowflake ChatWindow::GetActiveChannel() const { diff --git a/src/components/chatwindow.hpp b/src/components/chatwindow.hpp index d77afec..d09a87b 100644 --- a/src/components/chatwindow.hpp +++ b/src/components/chatwindow.hpp @@ -4,6 +4,7 @@ #include <set> #include "discord/discord.hpp" #include "completer.hpp" +#include "state.hpp" #ifdef WITH_LIBHANDY class ChannelTabSwitcherHandy; @@ -36,6 +37,8 @@ public: #ifdef WITH_LIBHANDY void OpenNewTab(Snowflake id); + TabsState GetTabsState(); + void UseTabsState(const TabsState &state); #endif protected: |