summaryrefslogtreecommitdiff
path: root/components
diff options
context:
space:
mode:
authorouwou <26526779+ouwou@users.noreply.github.com>2021-06-17 01:08:09 -0400
committerouwou <26526779+ouwou@users.noreply.github.com>2021-06-17 01:08:09 -0400
commit78f3164063f90c2be53d56fef6fd4a1cd085d923 (patch)
tree8d3b0fe411b4ab4501eb62b83b33091be2cac5aa /components
parent51fdcddaea49c8a23475be12b16c772d4d33b8ee (diff)
downloadabaddon-portaudio-78f3164063f90c2be53d56fef6fd4a1cd085d923.tar.gz
abaddon-portaudio-78f3164063f90c2be53d56fef6fd4a1cd085d923.zip
add unpin to menu, refactor a bit
Diffstat (limited to 'components')
-rw-r--r--components/chatlist.cpp27
-rw-r--r--components/chatlist.hpp7
-rw-r--r--components/chatwindow.cpp7
-rw-r--r--components/chatwindow.hpp3
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;