add MESSAGE_DELETE handling

This commit is contained in:
ouwou
2020-08-29 01:14:07 -04:00
parent 4e7ae1af1d
commit 299ecc71d9
12 changed files with 73 additions and 0 deletions

View File

@@ -83,6 +83,10 @@ void Abaddon::DiscordNotifyMessageCreate(Snowflake id) {
m_main_window->UpdateChatNewMessage(id); m_main_window->UpdateChatNewMessage(id);
} }
void Abaddon::DiscordNotifyMessageDelete(Snowflake id, Snowflake channel_id) {
m_main_window->UpdateChatMessageDeleted(id, channel_id);
}
void Abaddon::ActionConnect() { void Abaddon::ActionConnect() {
if (!m_discord.IsStarted()) if (!m_discord.IsStarted())
StartDiscord(); StartDiscord();

View File

@@ -35,6 +35,7 @@ public:
void DiscordNotifyReady(); void DiscordNotifyReady();
void DiscordNotifyChannelListFullRefresh(); void DiscordNotifyChannelListFullRefresh();
void DiscordNotifyMessageCreate(Snowflake id); void DiscordNotifyMessageCreate(Snowflake id);
void DiscordNotifyMessageDelete(Snowflake id, Snowflake channel_id);
private: private:
DiscordClient m_discord; DiscordClient m_discord;

View File

@@ -62,3 +62,10 @@ void ChatMessageTextItem::PrependNewContent(std::string content) {
auto buf = m_text->get_buffer(); auto buf = m_text->get_buffer();
buf->set_text(content + "\n" + buf->get_text()); buf->set_text(content + "\n" + buf->get_text());
} }
void ChatMessageTextItem::MarkAsDeleted() {
auto buf = m_text->get_buffer();
Gtk::TextBuffer::iterator start, end;
buf->get_bounds(start, end);
buf->insert_markup(end, "<span color='#ff0000'> [deleted]</span>");
}

View File

@@ -11,6 +11,8 @@ class ChatMessageItem : public Gtk::ListBoxRow {
public: public:
Snowflake ID; Snowflake ID;
ChatDisplayType MessageType; ChatDisplayType MessageType;
virtual void MarkAsDeleted() = 0;
}; };
class ChatMessageTextItem : public ChatMessageItem { class ChatMessageTextItem : public ChatMessageItem {
@@ -18,6 +20,7 @@ public:
ChatMessageTextItem(const MessageData *data); ChatMessageTextItem(const MessageData *data);
void AppendNewContent(std::string content); void AppendNewContent(std::string content);
void PrependNewContent(std::string content); void PrependNewContent(std::string content);
virtual void MarkAsDeleted();
protected: protected:
Gtk::Box *m_main_box; Gtk::Box *m_main_box;

View File

@@ -6,6 +6,7 @@ ChatWindow::ChatWindow() {
m_message_set_dispatch.connect(sigc::mem_fun(*this, &ChatWindow::SetMessagesInternal)); m_message_set_dispatch.connect(sigc::mem_fun(*this, &ChatWindow::SetMessagesInternal));
m_new_message_dispatch.connect(sigc::mem_fun(*this, &ChatWindow::AddNewMessageInternal)); m_new_message_dispatch.connect(sigc::mem_fun(*this, &ChatWindow::AddNewMessageInternal));
m_new_history_dispatch.connect(sigc::mem_fun(*this, &ChatWindow::AddNewHistoryInternal)); m_new_history_dispatch.connect(sigc::mem_fun(*this, &ChatWindow::AddNewHistoryInternal));
m_message_delete_dispatch.connect(sigc::mem_fun(*this, &ChatWindow::DeleteMessageInternal));
m_main = Gtk::manage(new Gtk::Box(Gtk::ORIENTATION_VERTICAL)); m_main = Gtk::manage(new Gtk::Box(Gtk::ORIENTATION_VERTICAL));
m_listbox = Gtk::manage(new Gtk::ListBox); m_listbox = Gtk::manage(new Gtk::ListBox);
@@ -188,6 +189,12 @@ void ChatWindow::AddNewHistory(const std::vector<MessageData> &msgs) {
m_new_history_dispatch.emit(); m_new_history_dispatch.emit();
} }
void ChatWindow::DeleteMessage(Snowflake id) {
std::scoped_lock<std::mutex> guard(m_update_mutex);
m_message_delete_queue.push(id);
m_message_delete_dispatch.emit();
}
void ChatWindow::ClearMessages() { void ChatWindow::ClearMessages() {
std::scoped_lock<std::mutex> guard(m_update_mutex); std::scoped_lock<std::mutex> guard(m_update_mutex);
m_message_set_queue.push(std::unordered_set<const MessageData *>()); m_message_set_queue.push(std::unordered_set<const MessageData *>());
@@ -230,6 +237,31 @@ void ChatWindow::AddNewHistoryInternal() {
} }
} }
void ChatWindow::DeleteMessageInternal() {
Snowflake id;
{
std::scoped_lock<std::mutex> guard(m_update_mutex);
id = m_message_delete_queue.front();
m_message_delete_queue.pop();
}
ChatMessageItem *row = nullptr;
for (const auto &child : m_listbox->get_children()) {
ChatMessageItem *tmp = dynamic_cast<ChatMessageItem *>(child);
if (tmp == nullptr) continue;
if (tmp->ID == id) {
row = tmp;
break;
}
}
if (row == nullptr) return;
// todo actually delete it when it becomes setting
row->MarkAsDeleted();
}
void ChatWindow::SetMessagesInternal() { void ChatWindow::SetMessagesInternal() {
auto children = m_listbox->get_children(); auto children = m_listbox->get_children();
auto it = children.begin(); auto it = children.begin();

View File

@@ -17,6 +17,7 @@ public:
void SetMessages(std::unordered_set<const MessageData *> msgs); void SetMessages(std::unordered_set<const MessageData *> msgs);
void AddNewMessage(Snowflake id); void AddNewMessage(Snowflake id);
void AddNewHistory(const std::vector<MessageData> &msgs); void AddNewHistory(const std::vector<MessageData> &msgs);
void DeleteMessage(Snowflake id);
void ClearMessages(); void ClearMessages();
protected: protected:
@@ -24,6 +25,7 @@ protected:
void SetMessagesInternal(); void SetMessagesInternal();
void AddNewMessageInternal(); void AddNewMessageInternal();
void AddNewHistoryInternal(); void AddNewHistoryInternal();
void DeleteMessageInternal();
ChatDisplayType GetMessageDisplayType(const MessageData *data); ChatDisplayType GetMessageDisplayType(const MessageData *data);
ChatMessageItem *CreateChatEntryComponentText(const MessageData *data); ChatMessageItem *CreateChatEntryComponentText(const MessageData *data);
ChatMessageItem *CreateChatEntryComponent(const MessageData *data); ChatMessageItem *CreateChatEntryComponent(const MessageData *data);
@@ -41,6 +43,8 @@ protected:
std::queue<Snowflake> m_new_message_queue; std::queue<Snowflake> m_new_message_queue;
Glib::Dispatcher m_new_history_dispatch; Glib::Dispatcher m_new_history_dispatch;
std::queue<std::vector<Snowflake>> m_new_history_queue; std::queue<std::vector<Snowflake>> m_new_history_queue;
Glib::Dispatcher m_message_delete_dispatch;
std::queue<Snowflake> m_message_delete_queue;
std::mutex m_update_mutex; std::mutex m_update_mutex;
Snowflake m_active_channel; Snowflake m_active_channel;

View File

@@ -243,6 +243,9 @@ void DiscordClient::HandleGatewayMessage(std::string str) {
case GatewayEvent::MESSAGE_CREATE: { case GatewayEvent::MESSAGE_CREATE: {
HandleGatewayMessageCreate(m); HandleGatewayMessageCreate(m);
} break; } break;
case GatewayEvent::MESSAGE_DELETE: {
HandleGatewayMessageDelete(m);
} break;
} }
} break; } break;
default: default:
@@ -269,6 +272,10 @@ void DiscordClient::HandleGatewayMessageCreate(const GatewayMessage &msg) {
StoreMessage(data.ID, data); StoreMessage(data.ID, data);
m_abaddon->DiscordNotifyMessageCreate(data.ID); m_abaddon->DiscordNotifyMessageCreate(data.ID);
} }
void DiscordClient::HandleGatewayMessageDelete(const GatewayMessage &msg) {
MessageDeleteData data = msg.Data;
m_abaddon->DiscordNotifyMessageDelete(data.ID, data.ChannelID);
}
void DiscordClient::StoreGuild(Snowflake id, const GuildData &g) { void DiscordClient::StoreGuild(Snowflake id, const GuildData &g) {
assert(id.IsValid() && id == g.ID); assert(id.IsValid() && id == g.ID);
@@ -315,4 +322,5 @@ void DiscordClient::SendIdentify() {
void DiscordClient::LoadEventMap() { void DiscordClient::LoadEventMap() {
m_event_map["READY"] = GatewayEvent::READY; m_event_map["READY"] = GatewayEvent::READY;
m_event_map["MESSAGE_CREATE"] = GatewayEvent::MESSAGE_CREATE; m_event_map["MESSAGE_CREATE"] = GatewayEvent::MESSAGE_CREATE;
m_event_map["MESSAGE_DELETE"] = GatewayEvent::MESSAGE_DELETE;
} }

View File

@@ -85,6 +85,7 @@ private:
void HandleGatewayMessage(std::string str); void HandleGatewayMessage(std::string str);
void HandleGatewayReady(const GatewayMessage &msg); void HandleGatewayReady(const GatewayMessage &msg);
void HandleGatewayMessageCreate(const GatewayMessage &msg); void HandleGatewayMessageCreate(const GatewayMessage &msg);
void HandleGatewayMessageDelete(const GatewayMessage &msg);
void HeartbeatThread(); void HeartbeatThread();
void SendIdentify(); void SendIdentify();

View File

@@ -155,6 +155,12 @@ void from_json(const nlohmann::json &j, MessageData &m) {
JS_O("flags", m.Flags); JS_O("flags", m.Flags);
} }
void from_json(const nlohmann::json &j, MessageDeleteData &m) {
JS_D("id", m.ID);
JS_D("channel_id", m.ChannelID);
JS_O("guild_id", m.GuildID);
}
void from_json(const nlohmann::json &j, ReadyEventData &m) { void from_json(const nlohmann::json &j, ReadyEventData &m) {
JS_D("v", m.GatewayVersion); JS_D("v", m.GatewayVersion);
JS_D("user", m.User); JS_D("user", m.User);

View File

@@ -62,6 +62,7 @@ enum class GatewayOp : int {
enum class GatewayEvent : int { enum class GatewayEvent : int {
READY, READY,
MESSAGE_CREATE, MESSAGE_CREATE,
MESSAGE_DELETE,
}; };
struct GatewayMessage { struct GatewayMessage {

View File

@@ -110,6 +110,11 @@ void MainWindow::UpdateChatNewMessage(Snowflake id) {
m_chat.AddNewMessage(id); m_chat.AddNewMessage(id);
} }
void MainWindow::UpdateChatMessageDeleted(Snowflake id, Snowflake channel_id) {
if (channel_id == GetChatActiveChannel())
m_chat.DeleteMessage(id);
}
void MainWindow::UpdateChatPrependHistory(const std::vector<MessageData> &msgs) { void MainWindow::UpdateChatPrependHistory(const std::vector<MessageData> &msgs) {
m_chat.AddNewHistory(msgs); m_chat.AddNewHistory(msgs);
} }

View File

@@ -16,6 +16,7 @@ public:
void UpdateChatActiveChannel(Snowflake id); void UpdateChatActiveChannel(Snowflake id);
Snowflake GetChatActiveChannel() const; Snowflake GetChatActiveChannel() const;
void UpdateChatNewMessage(Snowflake id); void UpdateChatNewMessage(Snowflake id);
void UpdateChatMessageDeleted(Snowflake id, Snowflake channel_id);
void UpdateChatPrependHistory(const std::vector<MessageData> &msgs); void UpdateChatPrependHistory(const std::vector<MessageData> &msgs);
protected: protected: