2020-09-03 05:54:40 +00:00
|
|
|
#include <sstream>
|
|
|
|
#include <iomanip>
|
2020-08-26 05:46:43 +00:00
|
|
|
#include "chatmessage.hpp"
|
2020-08-30 06:00:56 +00:00
|
|
|
#include "../abaddon.hpp"
|
2020-09-06 01:05:52 +00:00
|
|
|
#include "../util.hpp"
|
2020-08-26 05:46:43 +00:00
|
|
|
|
2020-09-10 03:59:40 +00:00
|
|
|
ChatMessageContainer::ChatMessageContainer(const Message *data) {
|
2020-08-30 02:45:27 +00:00
|
|
|
UserID = data->Author.ID;
|
2020-09-06 03:04:11 +00:00
|
|
|
ChannelID = data->ChannelID;
|
2020-08-30 02:45:27 +00:00
|
|
|
|
2020-08-27 22:50:47 +00:00
|
|
|
m_main_box = Gtk::manage(new Gtk::Box(Gtk::ORIENTATION_HORIZONTAL));
|
2020-08-30 02:45:27 +00:00
|
|
|
m_content_box = Gtk::manage(new Gtk::Box(Gtk::ORIENTATION_VERTICAL));
|
2020-08-27 22:50:47 +00:00
|
|
|
m_meta_box = Gtk::manage(new Gtk::Box(Gtk::ORIENTATION_HORIZONTAL));
|
|
|
|
m_author = Gtk::manage(new Gtk::Label);
|
|
|
|
m_timestamp = Gtk::manage(new Gtk::Label);
|
|
|
|
|
2020-09-12 07:17:34 +00:00
|
|
|
auto buf = Abaddon::Get().GetImageManager().GetFromURLIfCached(data->Author.GetAvatarURL());
|
|
|
|
if (buf)
|
|
|
|
m_avatar = Gtk::manage(new Gtk::Image(buf));
|
|
|
|
else
|
2020-09-12 23:35:24 +00:00
|
|
|
m_avatar = Gtk::manage(new Gtk::Image(Abaddon::Get().GetImageManager().GetPlaceholder(32)));
|
2020-09-12 07:17:34 +00:00
|
|
|
|
2020-09-10 22:28:42 +00:00
|
|
|
m_avatar->set_valign(Gtk::ALIGN_START);
|
|
|
|
m_avatar->set_margin_right(10);
|
|
|
|
|
2020-09-09 22:32:45 +00:00
|
|
|
get_style_context()->add_class("message-container");
|
|
|
|
m_author->get_style_context()->add_class("message-container-author");
|
|
|
|
m_timestamp->get_style_context()->add_class("message-container-timestamp");
|
2020-09-14 04:17:58 +00:00
|
|
|
m_avatar->get_style_context()->add_class("message-container-avatar");
|
2020-09-09 22:32:45 +00:00
|
|
|
|
2020-08-27 22:50:47 +00:00
|
|
|
m_author->set_markup("<span weight=\"bold\">" + Glib::Markup::escape_text(data->Author.Username) + "</span>");
|
|
|
|
m_author->set_single_line_mode(true);
|
|
|
|
m_author->set_line_wrap(false);
|
|
|
|
m_author->set_ellipsize(Pango::ELLIPSIZE_END);
|
|
|
|
m_author->set_xalign(0.f);
|
|
|
|
m_author->set_can_focus(false);
|
|
|
|
m_author->show();
|
|
|
|
|
|
|
|
m_timestamp->set_text(data->Timestamp);
|
|
|
|
m_timestamp->set_opacity(0.5);
|
|
|
|
m_timestamp->set_single_line_mode(true);
|
|
|
|
m_timestamp->set_margin_start(12);
|
|
|
|
m_timestamp->set_can_focus(false);
|
|
|
|
m_timestamp->show();
|
|
|
|
|
|
|
|
m_main_box->set_hexpand(true);
|
|
|
|
m_main_box->set_vexpand(true);
|
|
|
|
m_main_box->set_can_focus(true);
|
|
|
|
m_main_box->show();
|
|
|
|
|
|
|
|
m_meta_box->set_can_focus(false);
|
|
|
|
m_meta_box->show();
|
|
|
|
|
2020-08-30 02:45:27 +00:00
|
|
|
m_content_box->set_can_focus(false);
|
|
|
|
m_content_box->show();
|
2020-08-27 22:50:47 +00:00
|
|
|
|
|
|
|
m_meta_box->add(*m_author);
|
|
|
|
m_meta_box->add(*m_timestamp);
|
2020-08-30 02:45:27 +00:00
|
|
|
m_content_box->add(*m_meta_box);
|
2020-09-10 22:28:42 +00:00
|
|
|
m_main_box->add(*m_avatar);
|
2020-08-30 02:45:27 +00:00
|
|
|
m_main_box->add(*m_content_box);
|
2020-08-27 22:50:47 +00:00
|
|
|
add(*m_main_box);
|
2020-08-26 05:46:43 +00:00
|
|
|
set_margin_bottom(8);
|
|
|
|
|
|
|
|
show();
|
|
|
|
}
|
2020-08-27 22:50:47 +00:00
|
|
|
|
2020-09-12 07:17:34 +00:00
|
|
|
void ChatMessageContainer::SetAvatarFromPixbuf(Glib::RefPtr<Gdk::Pixbuf> pixbuf) {
|
|
|
|
m_avatar->property_pixbuf() = pixbuf;
|
|
|
|
}
|
|
|
|
|
2020-09-06 03:04:11 +00:00
|
|
|
void ChatMessageContainer::Update() {
|
2020-09-07 04:27:41 +00:00
|
|
|
auto &discord = Abaddon::Get().GetDiscordClient();
|
2020-09-06 03:04:11 +00:00
|
|
|
auto guild_id = discord.GetChannel(ChannelID)->GuildID;
|
|
|
|
auto role_id = discord.GetMemberHoistedRole(guild_id, UserID, true);
|
|
|
|
auto *user = discord.GetUser(UserID);
|
|
|
|
std::string md;
|
|
|
|
if (role_id.IsValid()) {
|
|
|
|
auto *role = discord.GetRole(role_id);
|
|
|
|
if (role != nullptr)
|
|
|
|
md = "<span weight='bold' color='#" + IntToCSSColor(role->Color) + "'>" + Glib::Markup::escape_text(user->Username) + "</span>";
|
|
|
|
} else {
|
2020-09-22 00:09:30 +00:00
|
|
|
md = "<span weight='bold' color='#eeeeee'>" + Glib::Markup::escape_text(user->Username) + "</span>";
|
2020-09-06 03:04:11 +00:00
|
|
|
}
|
|
|
|
m_author->set_markup(md);
|
|
|
|
}
|
|
|
|
|
2020-09-20 05:12:54 +00:00
|
|
|
// returns index (1-based) of removed item
|
|
|
|
int ChatMessageContainer::RemoveItem(Gtk::Widget *widget) {
|
|
|
|
auto children = m_content_box->get_children();
|
|
|
|
for (auto i = 0; i < children.size(); i++) {
|
|
|
|
if (widget == children[i]) {
|
|
|
|
m_content_box->remove(*widget);
|
|
|
|
return i;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
|
2020-08-30 02:45:27 +00:00
|
|
|
void ChatMessageContainer::AddNewContent(Gtk::Widget *widget, bool prepend) {
|
2020-09-20 05:12:54 +00:00
|
|
|
if (prepend) {
|
|
|
|
m_content_box->add(*widget);
|
|
|
|
m_content_box->reorder_child(*widget, 1);
|
|
|
|
} else {
|
|
|
|
m_content_box->add(*widget);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void ChatMessageContainer::AddNewContentAtIndex(Gtk::Widget *widget, int index) {
|
|
|
|
m_content_box->add(*widget);
|
|
|
|
m_content_box->reorder_child(*widget, index); // this doesn't seem very reliable
|
2020-08-27 22:50:47 +00:00
|
|
|
}
|
2020-08-28 22:21:08 +00:00
|
|
|
|
2020-08-30 06:00:56 +00:00
|
|
|
ChatMessageItem::ChatMessageItem() {
|
|
|
|
m_menu_copy_id = Gtk::manage(new Gtk::MenuItem("_Copy ID", true));
|
|
|
|
m_menu_copy_id->signal_activate().connect(sigc::mem_fun(*this, &ChatMessageItem::on_menu_copy_id));
|
|
|
|
m_menu.append(*m_menu_copy_id);
|
|
|
|
|
|
|
|
m_menu_delete_message = Gtk::manage(new Gtk::MenuItem("_Delete Message", true));
|
|
|
|
m_menu_delete_message->signal_activate().connect(sigc::mem_fun(*this, &ChatMessageItem::on_menu_message_delete));
|
|
|
|
m_menu.append(*m_menu_delete_message);
|
|
|
|
|
2020-08-31 02:55:36 +00:00
|
|
|
m_menu_edit_message = Gtk::manage(new Gtk::MenuItem("_Edit Message", true));
|
|
|
|
m_menu_edit_message->signal_activate().connect(sigc::mem_fun(*this, &ChatMessageItem::on_menu_message_edit));
|
|
|
|
m_menu.append(*m_menu_edit_message);
|
|
|
|
|
2020-08-30 06:00:56 +00:00
|
|
|
m_menu.show_all();
|
|
|
|
}
|
|
|
|
|
|
|
|
void ChatMessageItem::on_menu_message_delete() {
|
2020-09-07 06:45:46 +00:00
|
|
|
m_signal_action_message_delete.emit(ChannelID, ID);
|
2020-08-30 06:00:56 +00:00
|
|
|
}
|
|
|
|
|
2020-08-31 02:55:36 +00:00
|
|
|
void ChatMessageItem::on_menu_message_edit() {
|
2020-09-07 06:45:46 +00:00
|
|
|
m_signal_action_message_edit.emit(ChannelID, ID);
|
|
|
|
}
|
|
|
|
|
|
|
|
ChatMessageItem::type_signal_action_message_delete ChatMessageItem::signal_action_message_delete() {
|
|
|
|
return m_signal_action_message_delete;
|
|
|
|
}
|
|
|
|
|
|
|
|
ChatMessageItem::type_signal_action_message_edit ChatMessageItem::signal_action_message_edit() {
|
|
|
|
return m_signal_action_message_edit;
|
2020-08-31 02:55:36 +00:00
|
|
|
}
|
|
|
|
|
2020-08-30 06:00:56 +00:00
|
|
|
void ChatMessageItem::on_menu_copy_id() {
|
|
|
|
Gtk::Clipboard::get()->set_text(std::to_string(ID));
|
|
|
|
}
|
|
|
|
|
|
|
|
// broken format v
|
|
|
|
// clang-format off
|
|
|
|
void ChatMessageItem::AttachMenuHandler(Gtk::Widget *widget) {
|
|
|
|
widget->signal_button_press_event().connect([this](GdkEventButton *event) -> bool {
|
|
|
|
if (event->type == GDK_BUTTON_PRESS && event->button == GDK_BUTTON_SECONDARY) {
|
|
|
|
ShowMenu(reinterpret_cast<GdkEvent *>(event));
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
return false;
|
|
|
|
}, false);
|
|
|
|
}
|
|
|
|
// clang-format on
|
|
|
|
|
|
|
|
void ChatMessageItem::ShowMenu(const GdkEvent *event) {
|
2020-09-24 06:15:25 +00:00
|
|
|
const auto &client = Abaddon::Get().GetDiscordClient();
|
|
|
|
const auto *data = client.GetMessage(ID);
|
2020-09-24 06:43:27 +00:00
|
|
|
if (data->IsDeleted()) {
|
|
|
|
m_menu_delete_message->set_sensitive(false);
|
|
|
|
m_menu_edit_message->set_sensitive(false);
|
|
|
|
} else {
|
|
|
|
const bool can_edit = client.GetUserData().ID == data->Author.ID;
|
|
|
|
const bool can_delete = can_edit || client.HasChannelPermission(client.GetUserData().ID, ChannelID, Permission::MANAGE_MESSAGES);
|
|
|
|
m_menu_delete_message->set_sensitive(can_delete);
|
|
|
|
m_menu_edit_message->set_sensitive(can_edit);
|
|
|
|
}
|
2020-08-30 06:00:56 +00:00
|
|
|
m_menu.popup_at_pointer(event);
|
|
|
|
}
|
|
|
|
|
|
|
|
void ChatMessageItem::AddMenuItem(Gtk::MenuItem *item) {
|
|
|
|
item->show();
|
|
|
|
m_menu.append(*item);
|
|
|
|
}
|
|
|
|
|
2020-09-20 05:12:54 +00:00
|
|
|
void ChatMessageItem::SetContainer(ChatMessageContainer *container) {
|
|
|
|
m_container = container;
|
|
|
|
}
|
|
|
|
|
|
|
|
ChatMessageContainer *ChatMessageItem::GetContainer() const {
|
|
|
|
return m_container;
|
|
|
|
}
|
|
|
|
|
2020-09-10 03:59:40 +00:00
|
|
|
ChatMessageTextItem::ChatMessageTextItem(const Message *data) {
|
2020-08-31 00:24:02 +00:00
|
|
|
m_content = data->Content;
|
2020-09-20 05:12:54 +00:00
|
|
|
ID = data->ID;
|
2020-08-31 00:24:02 +00:00
|
|
|
|
2020-09-09 22:32:45 +00:00
|
|
|
get_style_context()->add_class("message-text");
|
|
|
|
|
2020-08-30 02:45:27 +00:00
|
|
|
set_can_focus(false);
|
|
|
|
set_editable(false);
|
|
|
|
set_wrap_mode(Gtk::WRAP_WORD_CHAR);
|
|
|
|
set_halign(Gtk::ALIGN_FILL);
|
|
|
|
set_hexpand(true);
|
|
|
|
get_buffer()->set_text(data->Content);
|
|
|
|
show();
|
2020-08-30 06:00:56 +00:00
|
|
|
|
|
|
|
AttachMenuHandler(this);
|
|
|
|
m_menu_copy_content = Gtk::manage(new Gtk::MenuItem("Copy _Message", true));
|
|
|
|
AddMenuItem(m_menu_copy_content);
|
|
|
|
m_menu_copy_content->signal_activate().connect(sigc::mem_fun(*this, &ChatMessageTextItem::on_menu_copy_content));
|
|
|
|
|
2020-09-20 05:12:54 +00:00
|
|
|
Update();
|
2020-08-31 00:24:02 +00:00
|
|
|
}
|
|
|
|
|
2020-08-30 06:00:56 +00:00
|
|
|
void ChatMessageTextItem::on_menu_copy_content() {
|
2020-08-31 00:24:02 +00:00
|
|
|
Gtk::Clipboard::get()->set_text(m_content);
|
2020-08-28 22:21:08 +00:00
|
|
|
}
|
2020-08-29 05:14:07 +00:00
|
|
|
|
2020-09-11 03:57:36 +00:00
|
|
|
void ChatMessageTextItem::Update() {
|
2020-08-31 00:24:02 +00:00
|
|
|
UpdateAttributes();
|
|
|
|
}
|
|
|
|
|
|
|
|
void ChatMessageTextItem::UpdateAttributes() {
|
2020-09-11 03:57:36 +00:00
|
|
|
const auto *data = Abaddon::Get().GetDiscordClient().GetMessage(ID);
|
|
|
|
if (data == nullptr) return;
|
|
|
|
bool deleted = data->IsDeleted();
|
|
|
|
bool edited = data->IsEdited();
|
2020-08-31 00:24:02 +00:00
|
|
|
|
2020-08-30 02:45:27 +00:00
|
|
|
auto buf = get_buffer();
|
2020-08-31 00:24:02 +00:00
|
|
|
buf->set_text(m_content);
|
2020-08-29 05:14:07 +00:00
|
|
|
Gtk::TextBuffer::iterator start, end;
|
|
|
|
buf->get_bounds(start, end);
|
2020-08-31 00:24:02 +00:00
|
|
|
|
|
|
|
if (deleted) {
|
|
|
|
buf->insert_markup(end, "<span color='#ff0000'> [deleted]</span>");
|
|
|
|
} else if (edited) {
|
|
|
|
buf->insert_markup(end, "<span color='#999999'> [edited]</span>");
|
|
|
|
}
|
2020-08-29 05:14:07 +00:00
|
|
|
}
|
2020-09-03 05:54:40 +00:00
|
|
|
|
2020-09-10 03:59:40 +00:00
|
|
|
ChatMessageEmbedItem::ChatMessageEmbedItem(const Message *data) {
|
2020-09-03 05:54:40 +00:00
|
|
|
m_embed = data->Embeds[0];
|
2020-09-20 05:12:54 +00:00
|
|
|
ID = data->ID;
|
2020-09-03 05:54:40 +00:00
|
|
|
|
|
|
|
DoLayout();
|
|
|
|
AttachMenuHandler(this);
|
2020-09-20 05:12:54 +00:00
|
|
|
|
|
|
|
Update();
|
2020-09-03 05:54:40 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void ChatMessageEmbedItem::DoLayout() {
|
|
|
|
m_main = Gtk::manage(new Gtk::Box(Gtk::ORIENTATION_VERTICAL));
|
|
|
|
|
|
|
|
auto children = get_children();
|
|
|
|
auto it = children.begin();
|
|
|
|
|
|
|
|
while (it != children.end()) {
|
|
|
|
delete *it;
|
|
|
|
it++;
|
|
|
|
}
|
|
|
|
|
2020-09-04 02:36:57 +00:00
|
|
|
if (m_embed.Author.Name.length() > 0) {
|
|
|
|
auto *author_lbl = Gtk::manage(new Gtk::Label);
|
|
|
|
author_lbl->set_halign(Gtk::ALIGN_START);
|
|
|
|
author_lbl->set_line_wrap(true);
|
|
|
|
author_lbl->set_line_wrap_mode(Pango::WRAP_WORD_CHAR);
|
|
|
|
author_lbl->set_hexpand(false);
|
|
|
|
author_lbl->set_text(m_embed.Author.Name);
|
|
|
|
author_lbl->get_style_context()->add_class("embed-author");
|
|
|
|
m_main->pack_start(*author_lbl);
|
|
|
|
}
|
|
|
|
|
2020-09-03 05:54:40 +00:00
|
|
|
if (m_embed.Title.length() > 0) {
|
|
|
|
auto *title_label = Gtk::manage(new Gtk::Label);
|
|
|
|
title_label->set_use_markup(true);
|
|
|
|
title_label->set_markup("<b>" + Glib::Markup::escape_text(m_embed.Title) + "</b>");
|
|
|
|
title_label->set_halign(Gtk::ALIGN_CENTER);
|
2020-09-03 21:44:23 +00:00
|
|
|
title_label->set_hexpand(false);
|
2020-09-09 22:32:45 +00:00
|
|
|
title_label->get_style_context()->add_class("embed-title");
|
2020-09-03 05:54:40 +00:00
|
|
|
m_main->pack_start(*title_label);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (m_embed.Description.length() > 0) {
|
|
|
|
auto *desc_label = Gtk::manage(new Gtk::Label);
|
|
|
|
desc_label->set_text(m_embed.Description);
|
|
|
|
desc_label->set_line_wrap(true);
|
|
|
|
desc_label->set_line_wrap_mode(Pango::WRAP_WORD_CHAR);
|
|
|
|
desc_label->set_max_width_chars(50);
|
|
|
|
desc_label->set_halign(Gtk::ALIGN_START);
|
2020-09-03 21:44:23 +00:00
|
|
|
desc_label->set_hexpand(false);
|
2020-09-09 22:32:45 +00:00
|
|
|
desc_label->get_style_context()->add_class("embed-description");
|
2020-09-03 05:54:40 +00:00
|
|
|
m_main->pack_start(*desc_label);
|
|
|
|
}
|
|
|
|
|
2020-09-03 22:47:45 +00:00
|
|
|
if (m_embed.Fields.size() > 0) {
|
|
|
|
auto *flow = Gtk::manage(new Gtk::FlowBox);
|
|
|
|
flow->set_orientation(Gtk::ORIENTATION_HORIZONTAL);
|
|
|
|
flow->set_min_children_per_line(3);
|
2020-09-04 02:36:57 +00:00
|
|
|
flow->set_max_children_per_line(3);
|
2020-09-03 22:47:45 +00:00
|
|
|
flow->set_halign(Gtk::ALIGN_START);
|
|
|
|
flow->set_hexpand(false);
|
|
|
|
flow->set_column_spacing(10);
|
2020-09-04 02:36:57 +00:00
|
|
|
flow->set_selection_mode(Gtk::SELECTION_NONE);
|
|
|
|
m_main->pack_start(*flow);
|
2020-09-03 22:47:45 +00:00
|
|
|
|
|
|
|
for (const auto &field : m_embed.Fields) {
|
|
|
|
auto *field_box = Gtk::manage(new Gtk::Box(Gtk::ORIENTATION_VERTICAL));
|
|
|
|
auto *field_lbl = Gtk::manage(new Gtk::Label);
|
|
|
|
auto *field_val = Gtk::manage(new Gtk::Label);
|
|
|
|
field_box->set_hexpand(false);
|
|
|
|
field_box->set_halign(Gtk::ALIGN_START);
|
2020-09-04 02:36:57 +00:00
|
|
|
field_box->set_valign(Gtk::ALIGN_START);
|
2020-09-03 22:47:45 +00:00
|
|
|
field_lbl->set_hexpand(false);
|
|
|
|
field_lbl->set_halign(Gtk::ALIGN_START);
|
2020-09-04 02:36:57 +00:00
|
|
|
field_lbl->set_valign(Gtk::ALIGN_START);
|
2020-09-03 22:47:45 +00:00
|
|
|
field_val->set_hexpand(false);
|
|
|
|
field_val->set_halign(Gtk::ALIGN_START);
|
2020-09-04 02:36:57 +00:00
|
|
|
field_val->set_valign(Gtk::ALIGN_START);
|
2020-09-03 22:47:45 +00:00
|
|
|
field_lbl->set_use_markup(true);
|
|
|
|
field_lbl->set_markup("<b>" + Glib::Markup::escape_text(field.Name) + "</b>");
|
|
|
|
field_lbl->set_max_width_chars(20);
|
|
|
|
field_lbl->set_line_wrap(true);
|
|
|
|
field_lbl->set_line_wrap_mode(Pango::WRAP_WORD_CHAR);
|
|
|
|
field_val->set_text(field.Value);
|
|
|
|
field_val->set_max_width_chars(20);
|
|
|
|
field_val->set_line_wrap(true);
|
|
|
|
field_val->set_line_wrap_mode(Pango::WRAP_WORD_CHAR);
|
|
|
|
field_box->pack_start(*field_lbl);
|
|
|
|
field_box->pack_start(*field_val);
|
2020-09-09 22:32:45 +00:00
|
|
|
field_lbl->get_style_context()->add_class("embed-field-title");
|
|
|
|
field_val->get_style_context()->add_class("embed-field-value");
|
2020-09-03 22:47:45 +00:00
|
|
|
flow->insert(*field_box, -1);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-09-04 02:36:57 +00:00
|
|
|
if (m_embed.Footer.Text.length() > 0) {
|
|
|
|
auto *footer_lbl = Gtk::manage(new Gtk::Label);
|
|
|
|
footer_lbl->set_halign(Gtk::ALIGN_START);
|
|
|
|
footer_lbl->set_line_wrap(true);
|
|
|
|
footer_lbl->set_line_wrap_mode(Pango::WRAP_WORD_CHAR);
|
|
|
|
footer_lbl->set_hexpand(false);
|
|
|
|
footer_lbl->set_text(m_embed.Footer.Text);
|
|
|
|
footer_lbl->get_style_context()->add_class("embed-footer");
|
|
|
|
m_main->pack_start(*footer_lbl);
|
|
|
|
}
|
|
|
|
|
2020-09-03 05:54:40 +00:00
|
|
|
auto style = m_main->get_style_context();
|
|
|
|
|
|
|
|
if (m_embed.Color != -1) {
|
|
|
|
auto provider = Gtk::CssProvider::create(); // this seems wrong
|
2020-09-06 01:05:52 +00:00
|
|
|
std::string css = ".embed { border-left: 2px solid #" + IntToCSSColor(m_embed.Color) + "; }";
|
|
|
|
provider->load_from_data(css);
|
2020-09-03 05:54:40 +00:00
|
|
|
style->add_provider(provider, GTK_STYLE_PROVIDER_PRIORITY_APPLICATION);
|
|
|
|
}
|
|
|
|
|
|
|
|
style->add_class("embed");
|
|
|
|
|
|
|
|
set_margin_bottom(8);
|
2020-09-03 21:44:23 +00:00
|
|
|
set_hexpand(false);
|
|
|
|
m_main->set_hexpand(false);
|
|
|
|
m_main->set_halign(Gtk::ALIGN_START);
|
|
|
|
set_halign(Gtk::ALIGN_START);
|
2020-09-03 05:54:40 +00:00
|
|
|
|
|
|
|
add(*m_main);
|
|
|
|
show_all();
|
|
|
|
}
|
|
|
|
|
|
|
|
void ChatMessageEmbedItem::UpdateAttributes() {
|
2020-09-11 03:57:36 +00:00
|
|
|
const auto *data = Abaddon::Get().GetDiscordClient().GetMessage(ID);
|
|
|
|
if (data == nullptr) return;
|
|
|
|
bool deleted = data->IsDeleted();
|
|
|
|
bool edited = data->IsEdited();
|
2020-09-03 05:54:40 +00:00
|
|
|
|
|
|
|
if (m_attrib_label == nullptr) {
|
|
|
|
m_attrib_label = Gtk::manage(new Gtk::Label);
|
|
|
|
m_attrib_label->set_use_markup(true);
|
|
|
|
m_attrib_label->show();
|
2020-09-11 03:57:36 +00:00
|
|
|
m_main->pack_start(*m_attrib_label);
|
2020-09-03 05:54:40 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
if (deleted)
|
|
|
|
m_attrib_label->set_markup(" <span color='#ff0000'> [deleted]</span>");
|
|
|
|
else if (edited)
|
|
|
|
m_attrib_label->set_markup(" <span color='#999999'> [edited]</span>");
|
|
|
|
}
|
|
|
|
|
2020-09-11 03:57:36 +00:00
|
|
|
void ChatMessageEmbedItem::Update() {
|
|
|
|
UpdateAttributes();
|
2020-09-03 05:54:40 +00:00
|
|
|
}
|
2020-09-22 01:01:32 +00:00
|
|
|
|
|
|
|
ChatMessageUserEventItem::ChatMessageUserEventItem(const Message *data) {
|
|
|
|
ID = data->ID;
|
|
|
|
|
|
|
|
m_label = Gtk::manage(new Gtk::Label);
|
|
|
|
|
|
|
|
get_style_context()->add_class("message-text");
|
|
|
|
get_style_context()->add_class("message-text-user-event");
|
|
|
|
|
|
|
|
set_can_focus(false);
|
|
|
|
set_halign(Gtk::ALIGN_FILL);
|
|
|
|
set_hexpand(true);
|
|
|
|
m_label->set_halign(Gtk::ALIGN_START);
|
|
|
|
m_label->set_use_markup();
|
2020-09-22 04:07:55 +00:00
|
|
|
switch (data->Type) {
|
|
|
|
case MessageType::GUILD_MEMBER_JOIN:
|
|
|
|
m_label->set_markup("<span color='#999999'><i>[user joined]</i></span>");
|
|
|
|
break;
|
|
|
|
case MessageType::CHANNEL_PINNED_MESSAGE:
|
|
|
|
m_label->set_markup("<span color='#999999'><i>[message pinned]</i></span>");
|
|
|
|
break;
|
|
|
|
default: break;
|
|
|
|
}
|
2020-09-22 01:01:32 +00:00
|
|
|
add(*m_label);
|
|
|
|
show_all();
|
|
|
|
|
|
|
|
AttachMenuHandler(this);
|
|
|
|
}
|
|
|
|
|
|
|
|
void ChatMessageUserEventItem::Update() {}
|