diff options
author | ouwou <26526779+ouwou@users.noreply.github.com> | 2021-06-17 01:08:09 -0400 |
---|---|---|
committer | ouwou <26526779+ouwou@users.noreply.github.com> | 2021-06-17 01:08:09 -0400 |
commit | 78f3164063f90c2be53d56fef6fd4a1cd085d923 (patch) | |
tree | 8d3b0fe411b4ab4501eb62b83b33091be2cac5aa /components | |
parent | 51fdcddaea49c8a23475be12b16c772d4d33b8ee (diff) | |
download | abaddon-portaudio-78f3164063f90c2be53d56fef6fd4a1cd085d923.tar.gz abaddon-portaudio-78f3164063f90c2be53d56fef6fd4a1cd085d923.zip |
add unpin to menu, refactor a bit
Diffstat (limited to 'components')
-rw-r--r-- | components/chatlist.cpp | 27 | ||||
-rw-r--r-- | components/chatlist.hpp | 7 | ||||
-rw-r--r-- | components/chatwindow.cpp | 7 | ||||
-rw-r--r-- | components/chatwindow.hpp | 3 |
4 files changed, 25 insertions, 19 deletions
diff --git a/components/chatlist.cpp b/components/chatlist.cpp index e9c0f8a..57d797f 100644 --- a/components/chatlist.cpp +++ b/components/chatlist.cpp @@ -34,18 +34,21 @@ ChatList::ChatList() { m_menu_copy_id->signal_activate().connect([this] { Gtk::Clipboard::get()->set_text(std::to_string(m_menu_selected_message)); }); + m_menu_copy_id->show(); m_menu.append(*m_menu_copy_id); m_menu_delete_message = Gtk::manage(new Gtk::MenuItem("Delete Message")); m_menu_delete_message->signal_activate().connect([this] { - m_signal_action_message_delete.emit(m_active_channel, m_menu_selected_message); + Abaddon::Get().GetDiscordClient().DeleteMessage(m_active_channel, m_menu_selected_message); }); + m_menu_delete_message->show(); m_menu.append(*m_menu_delete_message); m_menu_edit_message = Gtk::manage(new Gtk::MenuItem("Edit Message")); m_menu_edit_message->signal_activate().connect([this] { m_signal_action_message_edit.emit(m_active_channel, m_menu_selected_message); }); + m_menu_edit_message->show(); m_menu.append(*m_menu_edit_message); m_menu_copy_content = Gtk::manage(new Gtk::MenuItem("Copy Content")); @@ -54,15 +57,23 @@ ChatList::ChatList() { if (msg.has_value()) Gtk::Clipboard::get()->set_text(msg->Content); }); + m_menu_copy_content->show(); m_menu.append(*m_menu_copy_content); m_menu_reply_to = Gtk::manage(new Gtk::MenuItem("Reply To")); m_menu_reply_to->signal_activate().connect([this] { m_signal_action_reply_to.emit(m_menu_selected_message); }); + m_menu_reply_to->show(); m_menu.append(*m_menu_reply_to); - m_menu.show_all(); + m_menu_unpin = Gtk::manage(new Gtk::MenuItem("Unpin")); + m_menu_unpin->signal_activate().connect([this] { + Abaddon::Get().GetDiscordClient().Unpin(m_active_channel, m_menu_selected_message, [](...) {}); + }); + m_menu.append(*m_menu_unpin); + + m_menu.show(); } void ChatList::Clear() { @@ -148,6 +159,10 @@ void ChatList::ProcessNewMessage(const Message &data, bool prepend) { if (ev->type == GDK_BUTTON_PRESS && ev->button == GDK_BUTTON_SECONDARY) { m_menu_selected_message = id; + m_menu_edit_message->set_visible(!m_use_pinned_menu); + m_menu_reply_to->set_visible(!m_use_pinned_menu); + m_menu_unpin->set_visible(m_use_pinned_menu); + const auto &client = Abaddon::Get().GetDiscordClient(); const auto data = client.GetMessage(id); if (data->IsDeleted()) { @@ -261,6 +276,10 @@ void ChatList::SetSeparateAll(bool separate) { m_separate_all = true; } +void ChatList::SetUsePinnedMenu() { + m_use_pinned_menu = true; +} + void ChatList::OnScrollEdgeOvershot(Gtk::PositionType pos) { if (pos == Gtk::POS_TOP) m_signal_action_chat_load_history.emit(m_active_channel); @@ -286,10 +305,6 @@ void ChatList::RemoveMessageAndHeader(Gtk::Widget *widget) { m_num_messages--; } -ChatList::type_signal_action_message_delete ChatList::signal_action_message_delete() { - return m_signal_action_message_delete; -} - ChatList::type_signal_action_message_edit ChatList::signal_action_message_edit() { return m_signal_action_message_edit; } diff --git a/components/chatlist.hpp b/components/chatlist.hpp index e9470d2..2f63900 100644 --- a/components/chatlist.hpp +++ b/components/chatlist.hpp @@ -21,18 +21,22 @@ public: void SetFailedByNonce(const std::string &nonce); std::vector<Snowflake> GetRecentAuthors(); void SetSeparateAll(bool separate); + void SetUsePinnedMenu(); // i think i need a better way to do menus private: void OnScrollEdgeOvershot(Gtk::PositionType pos); void ScrollToBottom(); void RemoveMessageAndHeader(Gtk::Widget *widget); + bool m_use_pinned_menu = false; + Gtk::Menu m_menu; Gtk::MenuItem *m_menu_copy_id; Gtk::MenuItem *m_menu_copy_content; Gtk::MenuItem *m_menu_delete_message; Gtk::MenuItem *m_menu_edit_message; Gtk::MenuItem *m_menu_reply_to; + Gtk::MenuItem *m_menu_unpin; Snowflake m_menu_selected_message; Snowflake m_active_channel; @@ -48,7 +52,6 @@ private: public: // these are all forwarded by the parent - using type_signal_action_message_delete = sigc::signal<void, Snowflake, Snowflake>; using type_signal_action_message_edit = sigc::signal<void, Snowflake, Snowflake>; using type_signal_action_chat_submit = sigc::signal<void, std::string, Snowflake, Snowflake>; using type_signal_action_chat_load_history = sigc::signal<void, Snowflake>; @@ -59,7 +62,6 @@ public: using type_signal_action_reaction_remove = sigc::signal<void, Snowflake, Glib::ustring>; using type_signal_action_reply_to = sigc::signal<void, Snowflake>; - type_signal_action_message_delete signal_action_message_delete(); type_signal_action_message_edit signal_action_message_edit(); type_signal_action_chat_submit signal_action_chat_submit(); type_signal_action_chat_load_history signal_action_chat_load_history(); @@ -71,7 +73,6 @@ public: type_signal_action_reply_to signal_action_reply_to(); private: - type_signal_action_message_delete m_signal_action_message_delete; type_signal_action_message_edit m_signal_action_message_edit; type_signal_action_chat_submit m_signal_action_chat_submit; type_signal_action_chat_load_history m_signal_action_chat_load_history; diff --git a/components/chatwindow.cpp b/components/chatwindow.cpp index 4c2b561..57b412b 100644 --- a/components/chatwindow.cpp +++ b/components/chatwindow.cpp @@ -63,9 +63,6 @@ ChatWindow::ChatWindow() { // lowkey gross m_signal_action_insert_mention.emit(id); }); - m_chat->signal_action_message_delete().connect([this](Snowflake channel_id, Snowflake message_id) { - m_signal_action_message_delete.emit(channel_id, message_id); - }); m_chat->signal_action_message_edit().connect([this](Snowflake channel_id, Snowflake message_id) { m_signal_action_message_edit.emit(channel_id, message_id); }); @@ -202,10 +199,6 @@ void ChatWindow::OnMessageSendFail(const std::string &nonce, float retry_after) m_chat->SetFailedByNonce(nonce); } -ChatWindow::type_signal_action_message_delete ChatWindow::signal_action_message_delete() { - return m_signal_action_message_delete; -} - ChatWindow::type_signal_action_message_edit ChatWindow::signal_action_message_edit() { return m_signal_action_message_edit; } diff --git a/components/chatwindow.hpp b/components/chatwindow.hpp index e6280f6..ee2eef6 100644 --- a/components/chatwindow.hpp +++ b/components/chatwindow.hpp @@ -59,7 +59,6 @@ protected: Gtk::Box *m_meta; public: - typedef sigc::signal<void, Snowflake, Snowflake> type_signal_action_message_delete; typedef sigc::signal<void, Snowflake, Snowflake> type_signal_action_message_edit; typedef sigc::signal<void, std::string, Snowflake, Snowflake> type_signal_action_chat_submit; typedef sigc::signal<void, Snowflake> type_signal_action_chat_load_history; @@ -68,7 +67,6 @@ public: typedef sigc::signal<void, Snowflake, Glib::ustring> type_signal_action_reaction_add; typedef sigc::signal<void, Snowflake, Glib::ustring> type_signal_action_reaction_remove; - type_signal_action_message_delete signal_action_message_delete(); type_signal_action_message_edit signal_action_message_edit(); type_signal_action_chat_submit signal_action_chat_submit(); type_signal_action_chat_load_history signal_action_chat_load_history(); @@ -78,7 +76,6 @@ public: type_signal_action_reaction_remove signal_action_reaction_remove(); private: - type_signal_action_message_delete m_signal_action_message_delete; type_signal_action_message_edit m_signal_action_message_edit; type_signal_action_chat_submit m_signal_action_chat_submit; type_signal_action_chat_load_history m_signal_action_chat_load_history; |