aboutsummaryrefslogtreecommitdiff
path: root/libdino/src/ui/conversation_summary/merged_status_item.vala
diff options
context:
space:
mode:
authorfiaxh <git@mx.ax.lt>2017-03-10 19:53:24 +0100
committerfiaxh <git@mx.ax.lt>2017-03-10 19:53:24 +0100
commit24b55d83a1f9e21b028c8d5ac9778e75565f417d (patch)
tree195b0f332e32d08e1a18fc3d8a5a6725c5ed11d7 /libdino/src/ui/conversation_summary/merged_status_item.vala
parent4c48c5c16d5f5b010c2e5dfb1affcb59f937510c (diff)
parent29ca70a6d534e1cd79963718c793ae740318cff1 (diff)
downloaddino-24b55d83a1f9e21b028c8d5ac9778e75565f417d.tar.gz
dino-24b55d83a1f9e21b028c8d5ac9778e75565f417d.zip
Merge branch 'master' of github.com:dino/dino
Diffstat (limited to 'libdino/src/ui/conversation_summary/merged_status_item.vala')
-rw-r--r--libdino/src/ui/conversation_summary/merged_status_item.vala31
1 files changed, 31 insertions, 0 deletions
diff --git a/libdino/src/ui/conversation_summary/merged_status_item.vala b/libdino/src/ui/conversation_summary/merged_status_item.vala
new file mode 100644
index 00000000..1fe8ecf3
--- /dev/null
+++ b/libdino/src/ui/conversation_summary/merged_status_item.vala
@@ -0,0 +1,31 @@
+using Gee;
+using Gtk;
+
+using Dino.Entities;
+
+namespace Dino.Ui.ConversationSummary {
+
+private class MergedStatusItem : Expander {
+
+ private StreamInteractor stream_interactor;
+ private Conversation conversation;
+ private ArrayList<Show> statuses = new ArrayList<Show>();
+
+ public MergedStatusItem(StreamInteractor stream_interactor, Conversation conversation, Show show) {
+ set_hexpand(true);
+ add_status(show);
+ }
+
+ public void add_status(Show show) {
+ statuses.add(show);
+ StatusItem status_item = new StatusItem(stream_interactor, conversation, @"is $(show.as)");
+ if (statuses.size == 1) {
+ label = show.as;
+ } else {
+ label = @"changed their status $(statuses.size) times";
+ add(new Label(show.as));
+ }
+ }
+}
+
+} \ No newline at end of file