aboutsummaryrefslogtreecommitdiff
path: root/main/src/ui/conversation_summary/slashme_message_display.vala
diff options
context:
space:
mode:
Diffstat (limited to 'main/src/ui/conversation_summary/slashme_message_display.vala')
-rw-r--r--main/src/ui/conversation_summary/slashme_message_display.vala75
1 files changed, 75 insertions, 0 deletions
diff --git a/main/src/ui/conversation_summary/slashme_message_display.vala b/main/src/ui/conversation_summary/slashme_message_display.vala
new file mode 100644
index 00000000..58d93142
--- /dev/null
+++ b/main/src/ui/conversation_summary/slashme_message_display.vala
@@ -0,0 +1,75 @@
+using Gtk;
+
+using Dino.Entities;
+
+namespace Dino.Ui.ConversationSummary {
+
+public class SlashmeMessageDisplay : Plugins.MessageDisplayProvider, Object {
+ public string id { get; set; default="slashme"; }
+ public double priority { get; set; default=1; }
+
+ public StreamInteractor stream_interactor;
+
+ public SlashmeMessageDisplay(StreamInteractor stream_interactor) {
+ this.stream_interactor = stream_interactor;
+ }
+
+ public bool can_display(Entities.Message? message) {
+ return message.body.has_prefix("/me");
+ }
+
+ public Plugins.MetaConversationItem? get_item(Entities.Message message, Conversation conversation) {
+ return new MetaSlashmeItem(stream_interactor, message, conversation);
+ }
+}
+
+public class MetaSlashmeItem : Plugins.MetaConversationItem {
+ public override Jid? jid { get; set; }
+ public override DateTime? sort_time { get; set; }
+ public override DateTime? display_time { get; set; }
+ public override Encryption? encryption { get; set; }
+
+ private StreamInteractor stream_interactor;
+ private Conversation conversation;
+ private Message message;
+ private TextTag nick_tag;
+ private MessageTextView text_view;
+
+ public MetaSlashmeItem(StreamInteractor stream_interactor, Message message, Conversation conversation) {
+ this.stream_interactor = stream_interactor;
+ this.conversation = conversation;
+ this.message = message;
+ this.jid = message.from;
+ this.sort_time = message.local_time;
+ this.display_time = message.time;
+ this.encryption = message.encryption;
+ }
+
+ public override bool can_merge { get; set; default=false; }
+ public override bool requires_avatar { get; set; default=true; }
+ public override bool requires_header { get; set; default=false; }
+
+ public override Object get_widget(Plugins.WidgetType widget_type) {
+ text_view = new MessageTextView() { valign=Align.CENTER, vexpand=true, visible = true };
+
+ string display_name = Util.get_message_display_name(stream_interactor, message, conversation.account);
+ string color = Util.get_name_hex_color(stream_interactor, conversation.account, conversation.counterpart, Util.is_dark_theme(text_view));
+ nick_tag = text_view.buffer.create_tag("nick", foreground: "#" + color);
+ TextIter iter;
+ text_view.buffer.get_start_iter(out iter);
+ text_view.buffer.insert_with_tags(ref iter, display_name, display_name.length, nick_tag);
+
+ text_view.add_text(message.body.substring(3));
+ text_view.style_updated.connect(update_style);
+ text_view.realize.connect(update_style);
+ return text_view;
+ }
+
+ private void update_style() {
+ string display_name = Util.get_message_display_name(stream_interactor, message, conversation.account);
+ string color = Util.get_name_hex_color(stream_interactor, conversation.account, message.real_jid ?? message.from, Util.is_dark_theme(text_view));
+ nick_tag.foreground = "#" + color;
+ }
+}
+
+}