aboutsummaryrefslogtreecommitdiff
path: root/main/src/ui/conversation_selector/conversation_row.vala
diff options
context:
space:
mode:
authorfiaxh <git@lightrise.org>2019-04-12 17:43:47 +0200
committerfiaxh <git@lightrise.org>2019-04-14 09:46:54 +0200
commit6e1938b0893b47f0673bd773bdbfdbf6465ae018 (patch)
tree04ea42d63c7ef197923b49ebc5263371d4b81b9e /main/src/ui/conversation_selector/conversation_row.vala
parentd9e45071d0d3cd5a7a162908267c98c6366038bf (diff)
downloaddino-6e1938b0893b47f0673bd773bdbfdbf6465ae018.tar.gz
dino-6e1938b0893b47f0673bd773bdbfdbf6465ae018.zip
Clean up ConversationTitlebar
Diffstat (limited to 'main/src/ui/conversation_selector/conversation_row.vala')
-rw-r--r--main/src/ui/conversation_selector/conversation_row.vala277
1 files changed, 0 insertions, 277 deletions
diff --git a/main/src/ui/conversation_selector/conversation_row.vala b/main/src/ui/conversation_selector/conversation_row.vala
deleted file mode 100644
index 0d0db23a..00000000
--- a/main/src/ui/conversation_selector/conversation_row.vala
+++ /dev/null
@@ -1,277 +0,0 @@
-using Gee;
-using Gdk;
-using Gtk;
-using Pango;
-
-using Dino;
-using Dino.Entities;
-using Xmpp;
-
-namespace Dino.Ui.ConversationSelector {
-
-[GtkTemplate (ui = "/im/dino/Dino/conversation_selector/conversation_row.ui")]
-public class ConversationRow : ListBoxRow {
-
- public signal void closed();
-
- [GtkChild] protected AvatarImage image;
- [GtkChild] protected Label name_label;
- [GtkChild] protected Label time_label;
- [GtkChild] protected Label nick_label;
- [GtkChild] protected Label message_label;
- [GtkChild] protected Button x_button;
- [GtkChild] protected Revealer time_revealer;
- [GtkChild] protected Revealer xbutton_revealer;
- [GtkChild] public Revealer main_revealer;
-
- public Conversation conversation { get; private set; }
-
- protected const int AVATAR_SIZE = 40;
-
- protected ContentItem? last_content_item;
- protected bool read = true;
-
-
- protected StreamInteractor stream_interactor;
-
- construct {
- name_label.attributes = new AttrList();
- }
-
- public ConversationRow(StreamInteractor stream_interactor, Conversation conversation) {
- this.conversation = conversation;
- this.stream_interactor = stream_interactor;
-
- switch (conversation.type_) {
- case Conversation.Type.CHAT:
- stream_interactor.get_module(RosterManager.IDENTITY).updated_roster_item.connect((account, jid, roster_item) => {
- if (conversation.account.equals(account) && conversation.counterpart.equals(jid)) {
- update_name_label();
- }
- });
- break;
- case Conversation.Type.GROUPCHAT:
- closed.connect(() => {
- stream_interactor.get_module(MucManager.IDENTITY).part(conversation.account, conversation.counterpart);
- });
- stream_interactor.get_module(MucManager.IDENTITY).room_name_set.connect((account, jid, room_name) => {
- if (conversation != null && conversation.counterpart.equals_bare(jid) && conversation.account.equals(account)) {
- update_name_label();
- }
- });
- stream_interactor.get_module(MucManager.IDENTITY).private_room_occupant_updated.connect((account, room, occupant) => {
- if (conversation != null && conversation.counterpart.equals_bare(room.bare_jid) && conversation.account.equals(account)) {
- update_name_label();
- }
- });
- break;
- case Conversation.Type.GROUPCHAT_PM:
- break;
- }
-
- // Set tooltip
- switch (conversation.type_) {
- case Conversation.Type.CHAT:
- has_tooltip = true;
- query_tooltip.connect ((x, y, keyboard_tooltip, tooltip) => {
- tooltip.set_custom(generate_tooltip());
- return true;
- });
- break;
- case Conversation.Type.GROUPCHAT:
- has_tooltip = true;
- set_tooltip_text(conversation.counterpart.bare_jid.to_string());
- break;
- case Conversation.Type.GROUPCHAT_PM:
- break;
- }
-
- stream_interactor.get_module(ContentItemStore.IDENTITY).new_item.connect((item, c) => {
- if (conversation.equals(c)) {
- content_item_received(item);
- }
- });
- last_content_item = stream_interactor.get_module(ContentItemStore.IDENTITY).get_latest(conversation);
-
- x_button.clicked.connect(close_conversation);
- image.set_jid(stream_interactor, conversation.counterpart, conversation.account);
- conversation.notify["read-up-to"].connect(update_read);
-
- update_name_label();
- content_item_received();
- }
-
- public void update() {
- update_time_label();
- }
-
- public void content_item_received(ContentItem? ci = null) {
- last_content_item = stream_interactor.get_module(ContentItemStore.IDENTITY).get_latest(conversation) ?? ci;
- update_message_label();
- update_time_label();
- update_read();
- }
-
- protected void update_name_label() {
- name_label.label = Util.get_conversation_display_name(stream_interactor, conversation);
- }
-
- protected void update_time_label(DateTime? new_time = null) {
- if (last_content_item != null) {
- time_label.visible = true;
- time_label.label = get_relative_time(last_content_item.display_time.to_local());
- }
- }
-
- protected void update_message_label() {
- if (last_content_item != null) {
- switch (last_content_item.type_) {
- case MessageItem.TYPE:
- MessageItem message_item = last_content_item as MessageItem;
- Message last_message = message_item.message;
-
- if (conversation.type_ == Conversation.Type.GROUPCHAT) {
- nick_label.label = Util.get_message_display_name(stream_interactor, last_message, conversation.account) + ": ";
- } else {
- nick_label.label = last_message.direction == Message.DIRECTION_SENT ? _("Me") + ": " : "";
- }
-
- message_label.label = Markup.escape_text((/\s+/).replace_literal(last_message.body, -1, 0, " "));
- break;
- case FileItem.TYPE:
- FileItem file_item = last_content_item as FileItem;
- FileTransfer transfer = file_item.file_transfer;
-
- if (conversation.type_ == Conversation.Type.GROUPCHAT) {
- // TODO properly display nick for oneself
- string nick = transfer.direction == Message.DIRECTION_SENT ? _("Me") : Util.get_display_name(stream_interactor, file_item.file_transfer.counterpart, conversation.account);
- nick_label.label = nick + ": ";
- } else {
- nick_label.label = transfer.direction == Message.DIRECTION_SENT ? _("Me") + ": " : "";
- }
-
- bool file_is_image = transfer.mime_type != null && transfer.mime_type.has_prefix("image");
- if (transfer.direction == Message.DIRECTION_SENT) {
- message_label.label = "<i>" + (file_is_image ? _("Image sent") : _("File sent") ) + "</i>";
- } else {
- message_label.label = "<i>" + (file_is_image ? _("Image received") : _("File received") ) + "</i>";
- }
- break;
- }
- nick_label.visible = true;
- message_label.visible = true;
- }
- }
-
- protected void update_read() {
- MessageItem? message_item = last_content_item as MessageItem;
- if (message_item == null) return;
- Message last_message = message_item.message;
-
- bool read_was = read;
- read = last_message == null || (conversation.read_up_to != null && last_message.equals(conversation.read_up_to));
- if (read == read_was) return;
- if (read) {
- name_label.attributes.filter((attr) => attr.equal(attr_weight_new(Weight.BOLD)));
- time_label.attributes.filter((attr) => attr.equal(attr_weight_new(Weight.BOLD)));
- nick_label.attributes.filter((attr) => attr.equal(attr_weight_new(Weight.BOLD)));
- message_label.attributes.filter((attr) => attr.equal(attr_weight_new(Weight.BOLD)));
- } else {
- name_label.attributes.insert(attr_weight_new(Weight.BOLD));
- time_label.attributes.insert(attr_weight_new(Weight.BOLD));
- nick_label.attributes.insert(attr_weight_new(Weight.BOLD));
- message_label.attributes.insert(attr_weight_new(Weight.BOLD));
- }
- name_label.label = name_label.label; // TODO initializes redrawing, which would otherwise not happen. nicer?
- time_label.label = time_label.label;
- nick_label.label = nick_label.label;
- message_label.label = message_label.label;
- }
-
- protected Box get_fulljid_box(Jid full_jid) {
- Box box = new Box(Orientation.HORIZONTAL, 5) { visible=true };
-
- Show show = stream_interactor.get_module(PresenceManager.IDENTITY).get_last_show(full_jid, conversation.account);
- Image image = new Image() { visible=true };
- if (show.as == Show.AWAY) {
- image.set_from_icon_name("dino-status-away", IconSize.SMALL_TOOLBAR);
- } else if (show.as == Show.XA || show.as == Show.DND) {
- image.set_from_icon_name("dino-status-dnd", IconSize.SMALL_TOOLBAR);
- } else if (show.as == Show.CHAT) {
- image.set_from_icon_name("dino-status-chat", IconSize.SMALL_TOOLBAR);
- } else {
- image.set_from_icon_name("dino-status-online", IconSize.SMALL_TOOLBAR);
- }
- box.add(image);
-
- Label resource = new Label(full_jid.resourcepart) { visible=true };
- resource.xalign = 0;
- box.add(resource);
- box.show_all();
- return box;
- }
-
- private void close_conversation() {
- main_revealer.set_transition_type(RevealerTransitionType.SLIDE_UP);
- main_revealer.set_reveal_child(false);
- closed();
- main_revealer.notify["child-revealed"].connect(() => {
- stream_interactor.get_module(ConversationManager.IDENTITY).close_conversation(conversation);
- });
- }
-
- public override void state_flags_changed(StateFlags flags) {
- StateFlags curr_flags = get_state_flags();
- if ((curr_flags & StateFlags.PRELIGHT) != 0) {
- time_revealer.set_reveal_child(false);
- xbutton_revealer.set_reveal_child(true);
- } else {
- time_revealer.set_reveal_child(true);
- xbutton_revealer.set_reveal_child(false);
- }
- }
-
- private Widget generate_tooltip() {
- Builder builder = new Builder.from_resource("/im/dino/Dino/conversation_selector/chat_row_tooltip.ui");
- Box main_box = builder.get_object("main_box") as Box;
- Box inner_box = builder.get_object("inner_box") as Box;
- Label jid_label = builder.get_object("jid_label") as Label;
-
- jid_label.label = conversation.counterpart.to_string();
-
- Gee.List<Jid>? full_jids = stream_interactor.get_module(PresenceManager.IDENTITY).get_full_jids(conversation.counterpart, conversation.account);
- if (full_jids != null) {
- for (int i = 0; i < full_jids.size; i++) {
- inner_box.add(get_fulljid_box(full_jids[i]));
- }
- }
- return main_box;
- }
-
- private static string get_relative_time(DateTime datetime) {
- DateTime now = new DateTime.now_utc();
- TimeSpan timespan = now.difference(datetime);
- if (timespan > 365 * TimeSpan.DAY) {
- return datetime.get_year().to_string();
- } else if (timespan > 7 * TimeSpan.DAY) {
- // Day and month
- // xgettext:no-c-format
- return datetime.format(_("%b %d"));
- } else if (timespan > 2 * TimeSpan.DAY) {
- return datetime.format("%a");
- } else if (datetime.get_day_of_month() != now.get_day_of_month()) {
- return _("Yesterday");
- } else if (timespan > 9 * TimeSpan.MINUTE) {
- return datetime.format(Util.is_24h_format() ?
- /* xgettext:no-c-format */ /* Time in 24h format (w/o seconds) */ _("%H∶%M") :
- /* xgettext:no-c-format */ /* Time in 12h format (w/o seconds) */ _("%l∶%M %p"));
- } else if (timespan > 1 * TimeSpan.MINUTE) {
- ulong mins = (ulong) (timespan.abs() / TimeSpan.MINUTE);
- return n("%i min ago", "%i mins ago", mins).printf(mins);
- } else {
- return _("Just now");
- }
- }
-}
-
-}