aboutsummaryrefslogtreecommitdiffstats
path: root/libempathy-gtk/empathy-roster-item.c
diff options
context:
space:
mode:
authorGuillaume Desmottes <guillaume.desmottes@collabora.co.uk>2012-05-24 22:24:13 +0800
committerGuillaume Desmottes <guillaume.desmottes@collabora.co.uk>2012-06-14 15:21:47 +0800
commit2f9c2d7e591b876ac6c52953b687308b8aa06fe6 (patch)
treeb79927165f41097dbf0925dc97accf40c72763f0 /libempathy-gtk/empathy-roster-item.c
parent1a11cdd2f0e8ee312d0857db9a12da416f0adce9 (diff)
downloadgsoc2013-empathy-2f9c2d7e591b876ac6c52953b687308b8aa06fe6.tar
gsoc2013-empathy-2f9c2d7e591b876ac6c52953b687308b8aa06fe6.tar.gz
gsoc2013-empathy-2f9c2d7e591b876ac6c52953b687308b8aa06fe6.tar.bz2
gsoc2013-empathy-2f9c2d7e591b876ac6c52953b687308b8aa06fe6.tar.lz
gsoc2013-empathy-2f9c2d7e591b876ac6c52953b687308b8aa06fe6.tar.xz
gsoc2013-empathy-2f9c2d7e591b876ac6c52953b687308b8aa06fe6.tar.zst
gsoc2013-empathy-2f9c2d7e591b876ac6c52953b687308b8aa06fe6.zip
roster-item: track if individual is online or not
We cache the online status as we want to refresh the contact list only when the contact becomes online/offline, not each time his presence changes.
Diffstat (limited to 'libempathy-gtk/empathy-roster-item.c')
-rw-r--r--libempathy-gtk/empathy-roster-item.c59
1 files changed, 59 insertions, 0 deletions
diff --git a/libempathy-gtk/empathy-roster-item.c b/libempathy-gtk/empathy-roster-item.c
index 0f6fc644b..e9464cc32 100644
--- a/libempathy-gtk/empathy-roster-item.c
+++ b/libempathy-gtk/empathy-roster-item.c
@@ -16,6 +16,7 @@ G_DEFINE_TYPE (EmpathyRosterItem, empathy_roster_item, GTK_TYPE_ALIGNMENT)
enum
{
PROP_INDIVIDIUAL = 1,
+ PROP_ONLINE,
N_PROPS
};
@@ -38,6 +39,8 @@ struct _EmpathyRosterItemPriv
GtkWidget *presence_msg;
GtkWidget *presence_icon;
GtkWidget *phone_icon;
+
+ gboolean online;
};
static void
@@ -53,6 +56,9 @@ empathy_roster_item_get_property (GObject *object,
case PROP_INDIVIDIUAL:
g_value_set_object (value, self->priv->individual);
break;
+ case PROP_ONLINE:
+ g_value_set_boolean (value, self->priv->online);
+ break;
default:
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, property_id, pspec);
break;
@@ -211,11 +217,50 @@ update_presence_icon (EmpathyRosterItem *self)
}
static void
+update_online (EmpathyRosterItem *self)
+{
+ FolksPresenceType presence;
+ gboolean online;
+
+ presence = folks_presence_details_get_presence_type (
+ FOLKS_PRESENCE_DETAILS (self->priv->individual));
+
+ switch (presence)
+ {
+ case FOLKS_PRESENCE_TYPE_UNSET:
+ case FOLKS_PRESENCE_TYPE_OFFLINE:
+ case FOLKS_PRESENCE_TYPE_UNKNOWN:
+ case FOLKS_PRESENCE_TYPE_ERROR:
+ online = FALSE;
+ break;
+
+ case FOLKS_PRESENCE_TYPE_AVAILABLE:
+ case FOLKS_PRESENCE_TYPE_AWAY:
+ case FOLKS_PRESENCE_TYPE_EXTENDED_AWAY:
+ case FOLKS_PRESENCE_TYPE_HIDDEN:
+ case FOLKS_PRESENCE_TYPE_BUSY:
+ online = TRUE;
+ break;
+
+ default:
+ g_warning ("Unknown FolksPresenceType: %d", presence);
+ online = FALSE;
+ }
+
+ if (self->priv->online == online)
+ return;
+
+ self->priv->online = online;
+ g_object_notify (G_OBJECT (self), "online");
+}
+
+static void
presence_status_changed_cb (FolksIndividual *individual,
GParamSpec *spec,
EmpathyRosterItem *self)
{
update_presence_icon (self);
+ update_online (self);
}
static void
@@ -244,6 +289,8 @@ empathy_roster_item_constructed (GObject *object)
update_alias (self);
update_presence_msg (self);
update_presence_icon (self);
+
+ update_online (self);
}
static void
@@ -289,6 +336,12 @@ empathy_roster_item_class_init (
G_PARAM_READWRITE | G_PARAM_CONSTRUCT_ONLY | G_PARAM_STATIC_STRINGS);
g_object_class_install_property (oclass, PROP_INDIVIDIUAL, spec);
+ spec = g_param_spec_boolean ("online", "Online",
+ "TRUE if Individual is online",
+ FALSE,
+ G_PARAM_READABLE | G_PARAM_STATIC_STRINGS);
+ g_object_class_install_property (oclass, PROP_ONLINE, spec);
+
g_type_class_add_private (klass, sizeof (EmpathyRosterItemPriv));
}
@@ -377,3 +430,9 @@ empathy_roster_item_get_individual (EmpathyRosterItem *self)
{
return self->priv->individual;
}
+
+gboolean
+empathy_roster_item_is_online (EmpathyRosterItem *self)
+{
+ return self->priv->online;
+}