diff options
author | Guillaume Desmottes <guillaume.desmottes@collabora.co.uk> | 2011-08-05 17:57:25 +0800 |
---|---|---|
committer | Guillaume Desmottes <guillaume.desmottes@collabora.co.uk> | 2011-08-05 21:03:04 +0800 |
commit | 3aa8239213c026f5b09d50669f7a4a65c9906659 (patch) | |
tree | 6255d41f31612a653043d53baae8b6e6c3f2ac1a /libempathy-gtk | |
parent | 820b5479bd14c6b408a3818f9bc287ad0a3e2fb8 (diff) | |
download | gsoc2013-empathy-3aa8239213c026f5b09d50669f7a4a65c9906659.tar gsoc2013-empathy-3aa8239213c026f5b09d50669f7a4a65c9906659.tar.gz gsoc2013-empathy-3aa8239213c026f5b09d50669f7a4a65c9906659.tar.bz2 gsoc2013-empathy-3aa8239213c026f5b09d50669f7a4a65c9906659.tar.lz gsoc2013-empathy-3aa8239213c026f5b09d50669f7a4a65c9906659.tar.xz gsoc2013-empathy-3aa8239213c026f5b09d50669f7a4a65c9906659.tar.zst gsoc2013-empathy-3aa8239213c026f5b09d50669f7a4a65c9906659.zip |
Implement filtering logic in EmpathyInviteParticipantDialog
https://bugzilla.gnome.org/show_bug.cgi?id=656020
Diffstat (limited to 'libempathy-gtk')
-rw-r--r-- | libempathy-gtk/empathy-contact-chooser.c | 67 | ||||
-rw-r--r-- | libempathy-gtk/empathy-contact-chooser.h | 11 |
2 files changed, 35 insertions, 43 deletions
diff --git a/libempathy-gtk/empathy-contact-chooser.c b/libempathy-gtk/empathy-contact-chooser.c index 38956bac1..9605855f2 100644 --- a/libempathy-gtk/empathy-contact-chooser.c +++ b/libempathy-gtk/empathy-contact-chooser.c @@ -48,6 +48,9 @@ struct _EmpathyContactChooserPrivate /* Context representing the FolksIndividual which are added because of the * current search from the user. */ AddTemporaryIndividualCtx *add_temp_ctx; + + EmpathyContactChooserFilterFunc filter_func; + gpointer filter_data; }; static void @@ -237,10 +240,9 @@ filter_func (GtkTreeModel *model, { EmpathyContactChooser *self = user_data; FolksIndividual *individual; - TpContact *contact; gboolean is_online; - GList *members, *l; gboolean display = FALSE; + gboolean searching = FALSE; gtk_tree_model_get (model, iter, EMPATHY_INDIVIDUAL_STORE_COL_INDIVIDUAL, &individual, @@ -250,53 +252,21 @@ filter_func (GtkTreeModel *model, if (individual == NULL) goto out; - if (self->priv->search_words == NULL) - { - /* Not searching, display online contacts */ - if (!is_online) - goto out; - } - else + if (self->priv->search_words != NULL) { + searching = TRUE; + + /* Filter out the contact if we are searching and it doesn't match */ if (!empathy_individual_match_string (individual, self->priv->search_str, self->priv->search_words)) goto out; } - /* Filter out individuals not having a persona on the same connection as the - * EmpathyTpChat. */ - contact = get_tp_contact_for_chat (self, individual); - - if (contact == NULL) - goto out; - - /* Filter out contacts which are already in the chat */ - members = empathy_contact_list_get_members (EMPATHY_CONTACT_LIST ( - self->priv->tp_chat)); - - display = TRUE; - - for (l = members; l != NULL; l = g_list_next (l)) - { - EmpathyContact *member = l->data; - TpHandle handle; - - /* Try to get the non-channel specific handle. */ - handle = tp_channel_group_get_handle_owner ( - TP_CHANNEL (self->priv->tp_chat), - empathy_contact_get_handle (member)); - if (handle == 0) - handle = empathy_contact_get_handle (member); - - if (handle == tp_contact_get_handle (contact)) - { - display = FALSE; - break; - } - } - - g_list_free_full (members, g_object_unref); - + if (self->priv->filter_func == NULL) + display = TRUE; + else + display = self->priv->filter_func (self, individual, is_online, searching, + self->priv->filter_data); out: tp_clear_object (&individual); return display; @@ -491,3 +461,14 @@ empathy_contact_chooser_get_selected (EmpathyContactChooser *self) g_object_unref (individual); return contact; } + +void +empathy_contact_chooser_set_filter_func (EmpathyContactChooser *self, + EmpathyContactChooserFilterFunc func, + gpointer user_data) +{ + g_assert (self->priv->filter_func == NULL); + + self->priv->filter_func = func; + self->priv->filter_data = user_data; +} diff --git a/libempathy-gtk/empathy-contact-chooser.h b/libempathy-gtk/empathy-contact-chooser.h index 5af938d5d..142660a6b 100644 --- a/libempathy-gtk/empathy-contact-chooser.h +++ b/libempathy-gtk/empathy-contact-chooser.h @@ -31,6 +31,13 @@ typedef struct _EmpathyContactChooser EmpathyContactChooser; typedef struct _EmpathyContactChooserClass EmpathyContactChooserClass; typedef struct _EmpathyContactChooserPrivate EmpathyContactChooserPrivate; +typedef gboolean (*EmpathyContactChooserFilterFunc) ( + EmpathyContactChooser *self, + FolksIndividual *individual, + gboolean is_online, + gboolean searching, + gpointer user_data); + struct _EmpathyContactChooser { GtkBox parent; @@ -50,6 +57,10 @@ GtkWidget * empathy_contact_chooser_new (EmpathyTpChat *tp_chat); TpContact * empathy_contact_chooser_get_selected ( EmpathyContactChooser *self); +void empathy_contact_chooser_set_filter_func (EmpathyContactChooser *self, + EmpathyContactChooserFilterFunc func, + gpointer user_data); + G_END_DECLS #endif |