}
static void
+destroy_aggregator (ELHomeApplet *self)
+{
+ ELHomeAppletPrivate *priv = EL_HOME_APPLET(self)->priv;
+
+ if (priv->aggregator) {
+ if (priv->aggregator_ready_closure){
+ osso_abook_waitable_cancel (OSSO_ABOOK_WAITABLE (priv->aggregator),
+ priv->aggregator_ready_closure);
+ priv->aggregator_ready_closure = NULL;
+ }
+
+ g_object_unref (priv->aggregator);
+ priv->aggregator = NULL;
+ }
+}
+
+static void
dispose (GObject *self)
{
ELHomeAppletPrivate *priv = EL_HOME_APPLET(self)->priv;
pango_font_description_free (priv->font_desc);
priv->font_desc = NULL;
}
- if (priv->aggregator) {
- if (priv->aggregator_ready_closure){
- osso_abook_waitable_cancel (OSSO_ABOOK_WAITABLE (priv->aggregator),
- priv->aggregator_ready_closure);
- priv->aggregator_ready_closure = NULL;
- }
-
- g_object_unref (priv->aggregator);
- priv->aggregator = NULL;
- }
+ destroy_aggregator (EL_HOME_APPLET (self));
G_OBJECT_CLASS (el_home_applet_parent_class)->dispose (self);
}
}
static void
+aggregator_ready_cb (OssoABookWaitable *waitable,
+ const GError *error,
+ gpointer userdata)
+{
+ g_warning (G_STRFUNC);
+ ELHomeApplet *self = EL_HOME_APPLET(userdata);
+ ELHomeAppletPrivate *priv = self->priv;
+ GList *contacts;
+
+ priv->aggregator_ready_closure = NULL;
+
+ if (error) {
+ g_warning ("Failed to create aggregator: %s", error->message);
+ return;
+ }
+
+ contacts = osso_abook_aggregator_list_master_contacts
+ (OSSO_ABOOK_AGGREGATOR (priv->aggregator));
+ if (contacts && contacts->data) {
+ OssoABookContact *contact = OSSO_ABOOK_CONTACT (contacts->data);
+ gtk_label_set_text (GTK_LABEL (priv->sender),
+ osso_abook_contact_get_display_name (contact));
+ GdkPixbuf *avatar_image = osso_abook_avatar_get_image_rounded
+ (OSSO_ABOOK_AVATAR (contact),
+ HILDON_ICON_PIXEL_SIZE_THUMB,
+ HILDON_ICON_PIXEL_SIZE_THUMB,
+ TRUE,
+ -1,
+ priv->border_color);
+ g_warning ("%s av_img %p", G_STRFUNC, avatar_image);
+ if (avatar_image) {
+ g_warning ("SHOE AVATAR");
+ gtk_image_set_from_pixbuf (GTK_IMAGE (priv->avatar),
+ avatar_image);
+ gtk_widget_show (priv->avatar);
+ g_object_unref (avatar_image);
+ }
+ gtk_widget_queue_draw (GTK_WIDGET (self));
+ }
+}
+
+static void
resolve_contact (ELHomeApplet *self)
{
ELHomeAppletPrivate *priv = self->priv;
+ EBookQuery *query = NULL;
+ GError *error = NULL;
g_warning ("%s %s", G_STRFUNC, priv->contact_id);
+ destroy_aggregator (self);
+
if (priv->contact_id) {
- GList *contacts = osso_abook_aggregator_lookup (OSSO_ABOOK_AGGREGATOR (priv->aggregator),
- priv->contact_id);
- if (contacts && contacts->data) {
- OssoABookContact *contact = OSSO_ABOOK_CONTACT (contacts->data);
- gtk_label_set_text (GTK_LABEL (priv->sender),
- osso_abook_contact_get_display_name (contact));
- GdkPixbuf *avatar_image = osso_abook_avatar_get_image_rounded
- (OSSO_ABOOK_AVATAR (contact),
- HILDON_ICON_PIXEL_SIZE_THUMB,
- HILDON_ICON_PIXEL_SIZE_THUMB,
- TRUE,
- -1,
- priv->border_color);
- g_warning ("%s av_img %p", G_STRFUNC, avatar_image);
- if (avatar_image) {
- g_warning ("SHOE AVATAR");
- /* gtk_widget_hide (priv->icon); */
- /* gtk_widget_show (priv->avatar); */
- gtk_image_set_from_pixbuf (GTK_IMAGE (priv->avatar),
- avatar_image);
- g_object_unref (avatar_image);
- }
- }
+ query = e_book_query_vcard_field_test (EVC_UID,
+ E_BOOK_QUERY_IS,
+ priv->contact_id);
}
- else {
- /* TODO: use priv->remote_id and priv->local_id to lookup contact*/
+ else if (priv->local_id && priv->remote_id) {
+ const gchar *vcard = osso_abook_account_manager_get_vcard_field
+ (NULL, priv->local_id);
+ if (vcard)
+ query = e_book_query_vcard_field_test (vcard,
+ E_BOOK_QUERY_IS,
+ priv->remote_id);
+ else
+ query = e_book_query_any_field_contains (priv->remote_id);
+ }
+
+ if (query) {
+ priv->aggregator = osso_abook_aggregator_new_with_query (NULL,
+ query,
+ NULL,
+ 1,
+ &error);
+ e_book_query_unref (query);
+ }
+ if (error) {
+ g_warning ("Failed to create aggregator: %s", error->message);
+ g_error_free (error);
+ return;
+ }
+
+ if (priv->aggregator) {
+ OssoABookRosterManager *manager;
+
+ priv->aggregator_ready_closure = osso_abook_waitable_call_when_ready
+ (OSSO_ABOOK_WAITABLE (priv->aggregator),
+ aggregator_ready_cb,
+ self, NULL);
+
+ manager = osso_abook_aggregator_get_roster_manager
+ (OSSO_ABOOK_AGGREGATOR (priv->aggregator));
+ osso_abook_roster_manager_start (manager);
+ osso_abook_roster_start (priv->aggregator);
}
}
if (rtcom_el_iter_get_int (it, "start-time", (gint*)&received_t))
received = format_time (received_t);
- rtcom_el_iter_dup_string (it, "remote-id", &priv->remote_id);
+ rtcom_el_iter_dup_string (it, "remote-uid", &priv->remote_id);
if (!rtcom_el_iter_dup_string (it, "remote-name", &remote))
remote = g_strdup (priv->remote_id);
priv->event_id = -1;
}
+ gtk_widget_hide (priv->avatar);
+
if (priv->message) {
gtk_widget_hide (priv->empty);
+ /* TODO: don's show avatar at all, fix layout */
gtk_widget_show (priv->avatar);
gtk_image_set_from_icon_name (GTK_IMAGE (priv->avatar),
"general_default_avatar",
}
else {
gtk_widget_show (priv->empty);
- gtk_widget_hide (priv->avatar);
}
gtk_label_set_text (GTK_LABEL (priv->received), received);
gtk_widget_hide (priv->icon);
#endif
- if (priv->contact_id &&
- priv->aggregator &&
- !priv->aggregator_ready_closure) {
- resolve_contact (self);
- }
- else {
+ if (remote)
gtk_label_set_text (GTK_LABEL (priv->sender), remote);
- }
+ else if (priv->remote_id)
+ gtk_label_set_text (GTK_LABEL (priv->sender), priv->remote_id);
g_free (remote);
it = make_query (priv->eventlogger, -1);
show_event (self, it);
+ resolve_contact (self);
if (it) g_object_unref (it);
}
ELHomeAppletPrivate *priv = self->priv;
if (priv->event_id > 0) {
- if (event->y < C_Y + HEADER_HEIGHT)
- priv->active_header = TRUE;
+ if (event->y < C_Y + HEADER_HEIGHT) {
+ if (priv->aggregator &&
+ osso_abook_aggregator_get_master_contact_count
+ (OSSO_ABOOK_AGGREGATOR (priv->aggregator)) > 0)
+ priv->active_header = TRUE;
+ }
else
priv->active_body = TRUE;
gtk_widget_queue_draw (widget);
}
static void
-aggregator_ready_cb (OssoABookWaitable *waitable,
- const GError *error,
- gpointer userdata)
-{
- g_warning (G_STRFUNC);
- ELHomeApplet *self = EL_HOME_APPLET(userdata);
-
- self->priv->aggregator_ready_closure = NULL;
-
- if (!error) {
- resolve_contact (self);
- }
-}
-
-static void
el_home_applet_init (ELHomeApplet *self)
{
ELHomeAppletPrivate *priv;
read_new_event (self);
osso_abook_init_with_name (PACKAGE, NULL);
-
- priv->aggregator = osso_abook_aggregator_get_default (NULL);
- priv->aggregator_ready_closure = osso_abook_waitable_call_when_ready
- (OSSO_ABOOK_WAITABLE (priv->aggregator),
- aggregator_ready_cb,
- self, NULL);
#endif
}