diff options
-rw-r--r-- | libempathy-gtk/empathy-contact-selector.c | 100 |
1 files changed, 27 insertions, 73 deletions
diff --git a/libempathy-gtk/empathy-contact-selector.c b/libempathy-gtk/empathy-contact-selector.c index 3de39bef8..75b1dbf14 100644 --- a/libempathy-gtk/empathy-contact-selector.c +++ b/libempathy-gtk/empathy-contact-selector.c @@ -33,13 +33,6 @@ G_DEFINE_TYPE (EmpathyContactSelector, empathy_contact_selector, #define GET_PRIV(object) (G_TYPE_INSTANCE_GET_PRIVATE \ ((object), EMPATHY_TYPE_CONTACT_SELECTOR, EmpathyContactSelectorPriv)) -enum { - CONTACT_COL, - NAME_COL, - STATUS_ICON_NAME_COL, - NUM_COLS -}; - enum { PROP_0, @@ -51,12 +44,11 @@ typedef struct _EmpathyContactSelectorPriv EmpathyContactSelectorPriv; struct _EmpathyContactSelectorPriv { EmpathyContactListStore *store; - GtkListStore *list_store; gboolean is_blank_set; }; static void changed_cb (GtkComboBox *widget, gpointer data); -static gboolean get_iter_for_contact (GtkListStore *list_store, +static gboolean get_iter_for_contact (GtkTreeStore *store, GtkTreeIter *list_iter, EmpathyContact *contact); @@ -70,8 +62,8 @@ empathy_contact_selector_get_selected (EmpathyContactSelector *selector) if (!gtk_combo_box_get_active_iter (GTK_COMBO_BOX (selector), &iter)) return NULL; - gtk_tree_model_get (GTK_TREE_MODEL (priv->list_store), &iter, - CONTACT_COL, &contact, -1); + gtk_tree_model_get (GTK_TREE_MODEL (priv->store), &iter, + EMPATHY_CONTACT_LIST_STORE_COL_CONTACT, &contact, -1); return contact; } @@ -83,9 +75,10 @@ set_blank_contact (EmpathyContactSelector *selector) EmpathyContactSelectorPriv *priv = GET_PRIV (selector); GtkTreeIter blank_iter; - gtk_list_store_insert (priv->list_store, &blank_iter, 0); - gtk_list_store_set (priv->list_store, &blank_iter, CONTACT_COL, NULL, - NAME_COL, _("Select a contact"), -1); + gtk_tree_store_insert (GTK_TREE_STORE (priv->store), &blank_iter, NULL, 0); + gtk_tree_store_set (GTK_TREE_STORE (priv->store), &blank_iter, + EMPATHY_CONTACT_LIST_STORE_COL_CONTACT, NULL, + EMPATHY_CONTACT_LIST_STORE_COL_NAME, ("Select a contact"), -1); g_signal_handlers_block_by_func(selector, changed_cb, NULL); gtk_combo_box_set_active_iter (GTK_COMBO_BOX (selector), &blank_iter); g_signal_handlers_unblock_by_func(selector, changed_cb, NULL); @@ -107,9 +100,9 @@ notify_popup_shown_cb (GtkComboBox *widget, if (shown) { - if (get_iter_for_contact (priv->list_store, &blank_iter, NULL)) + if (get_iter_for_contact (GTK_TREE_STORE (priv->store), &blank_iter, NULL)) { - gtk_list_store_remove (priv->list_store, &blank_iter); + gtk_tree_store_remove (GTK_TREE_STORE (priv->store), &blank_iter); priv->is_blank_set = FALSE; } } @@ -118,7 +111,7 @@ notify_popup_shown_cb (GtkComboBox *widget, if (gtk_combo_box_get_active (widget) == -1) { set_blank_contact (selector); - if (gtk_tree_model_iter_n_children (GTK_TREE_MODEL (priv->list_store), + if (gtk_tree_model_iter_n_children (GTK_TREE_MODEL (priv->store), NULL) == 1) gtk_widget_set_sensitive (GTK_WIDGET (selector), FALSE); } @@ -143,15 +136,15 @@ changed_cb (GtkComboBox *widget, if (gtk_combo_box_get_active (widget) == -1) { set_blank_contact (selector); - if (gtk_tree_model_iter_n_children (GTK_TREE_MODEL (priv->list_store), + if (gtk_tree_model_iter_n_children (GTK_TREE_MODEL (priv->store), NULL) == 1) gtk_widget_set_sensitive (GTK_WIDGET (selector), FALSE); } else { - if (get_iter_for_contact (priv->list_store, &blank_iter, NULL)) + if (get_iter_for_contact (GTK_TREE_STORE (priv->store), &blank_iter, NULL)) { - gtk_list_store_remove (priv->list_store, &blank_iter); + gtk_tree_store_remove (GTK_TREE_STORE (priv->store), &blank_iter); priv->is_blank_set = FALSE; } } @@ -159,7 +152,7 @@ changed_cb (GtkComboBox *widget, static gboolean -get_iter_for_contact (GtkListStore *list_store, +get_iter_for_contact (GtkTreeStore *store, GtkTreeIter *list_iter, EmpathyContact *contact) { @@ -170,19 +163,20 @@ get_iter_for_contact (GtkListStore *list_store, /* Do a linear search to find the row with CONTACT_COL set to contact. */ path = gtk_tree_path_new_first (); - if (gtk_tree_model_get_iter (GTK_TREE_MODEL (list_store), &tmp_iter, path)) + if (gtk_tree_model_get_iter (GTK_TREE_MODEL (store), &tmp_iter, path)) { do { - gtk_tree_model_get (GTK_TREE_MODEL (list_store), - &tmp_iter, CONTACT_COL, &tmp_contact, -1); + gtk_tree_model_get (GTK_TREE_MODEL (store), + &tmp_iter, EMPATHY_CONTACT_LIST_STORE_COL_CONTACT, + &tmp_contact, -1); found = (tmp_contact == contact); if (found) { *list_iter = tmp_iter; break; } - } while (gtk_tree_model_iter_next (GTK_TREE_MODEL (list_store), + } while (gtk_tree_model_iter_next (GTK_TREE_MODEL (store), &tmp_iter)); } @@ -199,48 +193,9 @@ empathy_store_row_changed_cb (EmpathyContactListStore *empathy_store, { EmpathyContactSelector *selector = EMPATHY_CONTACT_SELECTOR (data); EmpathyContactSelectorPriv *priv = GET_PRIV (selector); - GtkTreeIter list_iter; - EmpathyContact *contact; - gchar *name; - gchar *icon_name; - gboolean is_online; gint children; - /* Synchronize the GtkListStore with the EmpathyContactListStore. */ - gtk_tree_model_get (GTK_TREE_MODEL (empathy_store), empathy_iter, - EMPATHY_CONTACT_LIST_STORE_COL_CONTACT, &contact, - EMPATHY_CONTACT_LIST_STORE_COL_NAME, &name, - EMPATHY_CONTACT_LIST_STORE_COL_ICON_STATUS, &icon_name, - EMPATHY_CONTACT_LIST_STORE_COL_IS_ONLINE, &is_online, -1); - - if (!contact) - { - g_free (name); - g_free (icon_name); - return; - } - - /* The store does not contain the contact, so create a new row and set it. */ - if (!get_iter_for_contact (priv->list_store, &list_iter, contact)) - { - gtk_list_store_append (priv->list_store, &list_iter); - gtk_list_store_set (priv->list_store, &list_iter, CONTACT_COL, - contact, -1); - } - - if (is_online) - { - gtk_list_store_set (priv->list_store, &list_iter, NAME_COL, name, - STATUS_ICON_NAME_COL, icon_name, -1); - } - else - { - /* We display only online contacts. */ - gtk_list_store_remove (priv->list_store, &list_iter); - } - - children = gtk_tree_model_iter_n_children (GTK_TREE_MODEL (priv->list_store), - NULL); + children = gtk_tree_model_iter_n_children (GTK_TREE_MODEL (priv->store), NULL); if (children == 1 && priv->is_blank_set) gtk_widget_set_sensitive (GTK_WIDGET (selector), FALSE); @@ -264,13 +219,12 @@ empathy_contact_selector_constructor (GType type, GtkCellRenderer *renderer; g_object_set (priv->store, "is-compact", TRUE, "show-avatars", FALSE, - "show-offline", FALSE, "sort-criterium", + "show-offline", FALSE, "sort-criterium", "show-groups", FALSE, EMPATHY_CONTACT_LIST_STORE_SORT_NAME, NULL); + empathy_contact_list_store_set_show_groups (priv->store, FALSE); - priv->list_store = gtk_list_store_new (NUM_COLS, EMPATHY_TYPE_CONTACT, - G_TYPE_STRING, G_TYPE_STRING); - gtk_tree_sortable_set_sort_column_id (GTK_TREE_SORTABLE (priv->list_store), - NAME_COL, GTK_SORT_ASCENDING); + gtk_tree_sortable_set_sort_column_id (GTK_TREE_SORTABLE (priv->store), + EMPATHY_CONTACT_LIST_STORE_COL_NAME, GTK_SORT_ASCENDING); g_signal_connect (priv->store, "row-changed", G_CALLBACK (empathy_store_row_changed_cb), (gpointer) contact_selector); @@ -280,7 +234,7 @@ empathy_contact_selector_constructor (GType type, G_CALLBACK (notify_popup_shown_cb), NULL); gtk_combo_box_set_model (GTK_COMBO_BOX (contact_selector), - GTK_TREE_MODEL (priv->list_store)); + GTK_TREE_MODEL (priv->store)); gtk_widget_set_sensitive (GTK_WIDGET (contact_selector), FALSE); /* Status icon */ @@ -288,14 +242,14 @@ empathy_contact_selector_constructor (GType type, gtk_cell_layout_pack_start (GTK_CELL_LAYOUT (contact_selector), renderer, FALSE); gtk_cell_layout_set_attributes (GTK_CELL_LAYOUT (contact_selector), renderer, - "icon-name", STATUS_ICON_NAME_COL, NULL); + "icon-name", EMPATHY_CONTACT_LIST_STORE_COL_ICON_STATUS, NULL); /* Contact name */ renderer = gtk_cell_renderer_text_new (); gtk_cell_layout_pack_start (GTK_CELL_LAYOUT (contact_selector), renderer, TRUE); gtk_cell_layout_set_attributes (GTK_CELL_LAYOUT (contact_selector), renderer, - "text", NAME_COL, NULL); + "text", EMPATHY_CONTACT_LIST_STORE_COL_NAME, NULL); set_blank_contact (contact_selector); |