diff options
author | Emilio Pozuelo Monfort <emilio.pozuelo@collabora.co.uk> | 2011-06-29 22:47:58 +0800 |
---|---|---|
committer | Emilio Pozuelo Monfort <emilio.pozuelo@collabora.co.uk> | 2011-06-30 16:48:26 +0800 |
commit | 1b1b4a31eb331b8f836d0b00340216890ccef14e (patch) | |
tree | 5adb5b692da73eca29134212162b10eaea86ff19 | |
parent | c3d0a65fca3e4e0fcba10ffb6143d4bfcfd0966b (diff) | |
download | gsoc2013-empathy-1b1b4a31eb331b8f836d0b00340216890ccef14e.tar gsoc2013-empathy-1b1b4a31eb331b8f836d0b00340216890ccef14e.tar.gz gsoc2013-empathy-1b1b4a31eb331b8f836d0b00340216890ccef14e.tar.bz2 gsoc2013-empathy-1b1b4a31eb331b8f836d0b00340216890ccef14e.tar.lz gsoc2013-empathy-1b1b4a31eb331b8f836d0b00340216890ccef14e.tar.xz gsoc2013-empathy-1b1b4a31eb331b8f836d0b00340216890ccef14e.tar.zst gsoc2013-empathy-1b1b4a31eb331b8f836d0b00340216890ccef14e.zip |
Autocomplete contacts when blocking by alias
https://bugzilla.gnome.org/show_bug.cgi?id=653650
-rw-r--r-- | libempathy-gtk/empathy-contact-blocking-dialog.c | 83 |
1 files changed, 81 insertions, 2 deletions
diff --git a/libempathy-gtk/empathy-contact-blocking-dialog.c b/libempathy-gtk/empathy-contact-blocking-dialog.c index 08757545f..1cb2b279c 100644 --- a/libempathy-gtk/empathy-contact-blocking-dialog.c +++ b/libempathy-gtk/empathy-contact-blocking-dialog.c @@ -68,6 +68,7 @@ enum /* blocked-contacts columns */ { COL_IDENTIFIER, COL_HANDLE, + COL_TEXT, N_COLUMNS }; @@ -634,12 +635,19 @@ contact_blocking_dialog_account_changed (GtkWidget *account_chooser, for (ptr = members; ptr != NULL; ptr = ptr->next) { EmpathyContact *contact = ptr->data; + gchar *tmpstr; + + tmpstr = g_strdup_printf ("%s (%s)", + empathy_contact_get_alias (contact), + empathy_contact_get_id (contact)); gtk_list_store_insert_with_values (self->priv->completion_contacts, NULL, -1, COL_IDENTIFIER, empathy_contact_get_id (contact), + COL_TEXT, tmpstr, -1); + g_free (tmpstr); g_object_unref (contact); } @@ -660,6 +668,68 @@ contact_blocking_dialog_view_selection_changed (GtkTreeSelection *selection, g_list_free (rows); } +static gboolean +contact_selector_dialog_match_func (GtkEntryCompletion *completion, + const gchar *key, + GtkTreeIter *iter, + gpointer user_data) +{ + GtkTreeModel *model; + gchar *str, *lower; + gboolean v = FALSE; + + model = gtk_entry_completion_get_model (completion); + if (model == NULL || iter == NULL) + return FALSE; + + gtk_tree_model_get (model, iter, COL_TEXT, &str, -1); + lower = g_utf8_strdown (str, -1); + if (strstr (lower, key)) + { + DEBUG ("Key %s is matching name **%s**", key, str); + v = TRUE; + goto out; + } + g_free (str); + g_free (lower); + + gtk_tree_model_get (model, iter, COL_IDENTIFIER, &str, -1); + lower = g_utf8_strdown (str, -1); + if (strstr (lower, key)) + { + DEBUG ("Key %s is matching ID **%s**", key, str); + v = TRUE; + goto out; + } + +out: + g_free (str); + g_free (lower); + + return v; +} + +static gboolean +contact_selector_dialog_match_selected_cb (GtkEntryCompletion *widget, + GtkTreeModel *model, + GtkTreeIter *iter, + EmpathyContactBlockingDialog *self) +{ + gchar *id; + + if (iter == NULL || model == NULL) + return FALSE; + + gtk_tree_model_get (model, iter, COL_IDENTIFIER, &id, -1); + gtk_entry_set_text (GTK_ENTRY (self->priv->add_contact_entry), id); + + DEBUG ("Got selected match **%s**", id); + + g_free (id); + + return TRUE; +} + static void contact_blocking_dialog_dispose (GObject *self) { @@ -736,11 +806,20 @@ empathy_contact_blocking_dialog_init (EmpathyContactBlockingDialog *self) G_CALLBACK (contact_blocking_dialog_view_selection_changed), self); /* build the contact entry */ - self->priv->completion_contacts = gtk_list_store_new (1, G_TYPE_STRING); + self->priv->completion_contacts = gtk_list_store_new (N_COLUMNS, + G_TYPE_STRING, /* id */ + G_TYPE_UINT, /* handle */ + G_TYPE_STRING); /* text */ completion = gtk_entry_completion_new (); gtk_entry_completion_set_model (completion, GTK_TREE_MODEL (self->priv->completion_contacts)); - gtk_entry_completion_set_text_column (completion, COL_IDENTIFIER); + gtk_entry_completion_set_text_column (completion, COL_TEXT); + gtk_entry_completion_set_match_func (completion, + contact_selector_dialog_match_func, + NULL, NULL); + g_signal_connect (completion, "match-selected", + G_CALLBACK (contact_selector_dialog_match_selected_cb), + self); gtk_entry_set_completion (GTK_ENTRY (self->priv->add_contact_entry), completion); g_object_unref (completion); |