diff options
author | Guillaume Desmottes <guillaume.desmottes@collabora.co.uk> | 2012-05-17 20:58:16 +0800 |
---|---|---|
committer | Guillaume Desmottes <guillaume.desmottes@collabora.co.uk> | 2012-06-14 15:21:46 +0800 |
commit | 184e9a705cd0932e06d3acba778b285a0a3c2063 (patch) | |
tree | f65acd97a072b3df99a33a632742b6cafe6d728e | |
parent | 2a65dce4efc5a484b4956d12f3576b0aeb81eba5 (diff) | |
download | gsoc2013-empathy-184e9a705cd0932e06d3acba778b285a0a3c2063.tar gsoc2013-empathy-184e9a705cd0932e06d3acba778b285a0a3c2063.tar.gz gsoc2013-empathy-184e9a705cd0932e06d3acba778b285a0a3c2063.tar.bz2 gsoc2013-empathy-184e9a705cd0932e06d3acba778b285a0a3c2063.tar.lz gsoc2013-empathy-184e9a705cd0932e06d3acba778b285a0a3c2063.tar.xz gsoc2013-empathy-184e9a705cd0932e06d3acba778b285a0a3c2063.tar.zst gsoc2013-empathy-184e9a705cd0932e06d3acba778b285a0a3c2063.zip |
roster-item: display the contact alias
-rw-r--r-- | libempathy-gtk/empathy-roster-item.c | 65 |
1 files changed, 65 insertions, 0 deletions
diff --git a/libempathy-gtk/empathy-roster-item.c b/libempathy-gtk/empathy-roster-item.c index 0e32a75f9..62ff42762 100644 --- a/libempathy-gtk/empathy-roster-item.c +++ b/libempathy-gtk/empathy-roster-item.c @@ -31,6 +31,8 @@ struct _EmpathyRosterItemPriv FolksIndividual *individual; GtkWidget *avatar; + GtkWidget *alias; + GtkWidget *presence_msg; }; static void @@ -120,6 +122,44 @@ avatar_changed_cb (FolksIndividual *individual, } static void +update_alias (EmpathyRosterItem *self) +{ + const gchar *alias; + + alias = folks_alias_details_get_alias (FOLKS_ALIAS_DETAILS ( + self->priv->individual)); + + gtk_label_set_text (GTK_LABEL (self->priv->alias), alias); +} + +static void +alias_changed_cb (FolksIndividual *individual, + GParamSpec *spec, + EmpathyRosterItem *self) +{ + update_alias (self); +} + +static void +update_presence_msg (EmpathyRosterItem *self) +{ + const gchar *msg; + + msg = folks_presence_details_get_presence_message ( + FOLKS_PRESENCE_DETAILS (self->priv->individual)); + + gtk_label_set_text (GTK_LABEL (self->priv->presence_msg), msg); +} + +static void +presence_message_changed_cb (FolksIndividual *individual, + GParamSpec *spec, + EmpathyRosterItem *self) +{ + update_presence_msg (self); +} + +static void empathy_roster_item_constructed (GObject *object) { EmpathyRosterItem *self = EMPATHY_ROSTER_ITEM (object); @@ -133,8 +173,15 @@ empathy_roster_item_constructed (GObject *object) tp_g_signal_connect_object (self->priv->individual, "notify::avatar", G_CALLBACK (avatar_changed_cb), self, 0); + tp_g_signal_connect_object (self->priv->individual, "notify::alias", + G_CALLBACK (alias_changed_cb), self, 0); + tp_g_signal_connect_object (self->priv->individual, + "notify::presence-message", + G_CALLBACK (presence_message_changed_cb), self, 0); update_avatar (self); + update_alias (self); + update_presence_msg (self); } static void @@ -186,6 +233,8 @@ empathy_roster_item_class_init ( static void empathy_roster_item_init (EmpathyRosterItem *self) { + GtkWidget *box; + self->priv = G_TYPE_INSTANCE_GET_PRIVATE (self, EMPATHY_TYPE_ROSTER_ITEM, EmpathyRosterItemPriv); @@ -196,6 +245,22 @@ empathy_roster_item_init (EmpathyRosterItem *self) gtk_box_pack_start (GTK_BOX (self), self->priv->avatar, FALSE, FALSE, 0); gtk_widget_show (self->priv->avatar); + + box = gtk_box_new (GTK_ORIENTATION_VERTICAL, 0); + + /* Alias */ + self->priv->alias = gtk_label_new (NULL); + gtk_misc_set_alignment (GTK_MISC (self->priv->alias), 0, 0.5); + gtk_box_pack_start (GTK_BOX (box), self->priv->alias, TRUE, TRUE, 0); + + gtk_box_pack_start (GTK_BOX (self), box, TRUE, TRUE, 0); + + /* Presence */ + self->priv->presence_msg = gtk_label_new (NULL); + gtk_misc_set_alignment (GTK_MISC (self->priv->presence_msg), 0, 0.5); + gtk_box_pack_start (GTK_BOX (box), self->priv->presence_msg, TRUE, TRUE, 0); + + gtk_widget_show_all (box); } GtkWidget * |