summaryrefslogtreecommitdiff
path: root/components/chatwindow.cpp
diff options
context:
space:
mode:
authorouwou <26526779+ouwou@users.noreply.github.com>2020-09-10 23:57:36 -0400
committerouwou <26526779+ouwou@users.noreply.github.com>2020-09-10 23:57:36 -0400
commitb9fb7c536ae6ab46f15c355176edbd5d25db6669 (patch)
tree89d40423dbc35bd3b8ee4ffd2afa9a975fe0dca3 /components/chatwindow.cpp
parent54a8244bfdd26656260b3c82391db2213f937ac7 (diff)
downloadabaddon-portaudio-b9fb7c536ae6ab46f15c355176edbd5d25db6669.tar.gz
abaddon-portaudio-b9fb7c536ae6ab46f15c355176edbd5d25db6669.zip
fix edited/deleted being reset on channel change
Diffstat (limited to 'components/chatwindow.cpp')
-rw-r--r--components/chatwindow.cpp6
1 files changed, 4 insertions, 2 deletions
diff --git a/components/chatwindow.cpp b/components/chatwindow.cpp
index 42e0a2c..d8ae2b7 100644
--- a/components/chatwindow.cpp
+++ b/components/chatwindow.cpp
@@ -129,12 +129,14 @@ void ChatWindow::ProcessMessage(const Message *data, bool prepend) {
text->signal_action_message_edit().connect([this](Snowflake channel_id, Snowflake id) {
m_signal_action_message_edit.emit(channel_id, id);
});
+ text->Update();
container->AddNewContent(text, prepend);
m_id_to_widget[data->ID] = text;
} else if (type == ChatDisplayType::Embed) {
auto *widget = Gtk::manage(new ChatMessageEmbedItem(data));
widget->ID = data->ID;
widget->ChannelID = m_active_channel;
+ widget->Update();
container->AddNewContent(widget, prepend);
m_id_to_widget[data->ID] = widget;
}
@@ -266,7 +268,7 @@ void ChatWindow::DeleteMessageInternal() {
// todo actually delete it when it becomes setting
auto *item = m_id_to_widget.at(id);
- item->MarkAsDeleted();
+ item->Update();
}
void ChatWindow::UpdateMessageContentInternal() {
@@ -284,7 +286,7 @@ void ChatWindow::UpdateMessageContentInternal() {
auto *item = dynamic_cast<ChatMessageTextItem *>(m_id_to_widget.at(id));
if (item != nullptr) {
item->EditContent(msg->Content);
- item->MarkAsEdited();
+ item->Update();
}
}