diff options
author | Guillaume Desmottes <guillaume.desmottes@collabora.co.uk> | 2009-12-16 19:18:37 +0800 |
---|---|---|
committer | Guillaume Desmottes <guillaume.desmottes@collabora.co.uk> | 2009-12-17 18:38:50 +0800 |
commit | 0af3c68b4c8c9392174d780712f5d4a12d0e13e6 (patch) | |
tree | 4d5fa6d6ab63a07b8ded2b0c9d2b4185937d963d | |
parent | 5631f4f5e4a4d446d5e4d81acd94b69567f9dcfa (diff) | |
download | gsoc2013-empathy-0af3c68b4c8c9392174d780712f5d4a12d0e13e6.tar gsoc2013-empathy-0af3c68b4c8c9392174d780712f5d4a12d0e13e6.tar.gz gsoc2013-empathy-0af3c68b4c8c9392174d780712f5d4a12d0e13e6.tar.bz2 gsoc2013-empathy-0af3c68b4c8c9392174d780712f5d4a12d0e13e6.tar.lz gsoc2013-empathy-0af3c68b4c8c9392174d780712f5d4a12d0e13e6.tar.xz gsoc2013-empathy-0af3c68b4c8c9392174d780712f5d4a12d0e13e6.tar.zst gsoc2013-empathy-0af3c68b4c8c9392174d780712f5d4a12d0e13e6.zip |
contact-selector-dialog: add API for subclass to redefine the accoutn filter function
-rw-r--r-- | libempathy-gtk/empathy-contact-selector-dialog.c | 18 | ||||
-rw-r--r-- | libempathy-gtk/empathy-contact-selector-dialog.h | 3 |
2 files changed, 19 insertions, 2 deletions
diff --git a/libempathy-gtk/empathy-contact-selector-dialog.c b/libempathy-gtk/empathy-contact-selector-dialog.c index c52ac6c56..6c0448441 100644 --- a/libempathy-gtk/empathy-contact-selector-dialog.c +++ b/libempathy-gtk/empathy-contact-selector-dialog.c @@ -230,6 +230,20 @@ entry_activate_cb (GtkEntry *entry, gtk_dialog_response (GTK_DIALOG (self), GTK_RESPONSE_ACCEPT); } +static gboolean +account_chooser_filter (TpAccount *account, + gpointer user_data) +{ + EmpathyContactSelectorDialog *self = user_data; + EmpathyContactSelectorDialogClass *class = \ + EMPATHY_CONTACT_SELECTOR_DIALOG_GET_CLASS (self); + + if (class->account_filter == NULL) + return empathy_account_chooser_filter_is_connected (account, user_data); + + return class->account_filter (self, account); +} + static void empathy_contact_selector_dialog_init (EmpathyContactSelectorDialog *dialog) { @@ -299,8 +313,8 @@ empathy_contact_selector_dialog_init (EmpathyContactSelectorDialog *dialog) 1, 2, 0, 1); empathy_account_chooser_set_filter ( EMPATHY_ACCOUNT_CHOOSER (priv->account_chooser), - empathy_account_chooser_filter_is_connected, - NULL); + account_chooser_filter, + dialog); gtk_widget_show (priv->account_chooser); contact_selector_dialog_account_changed_cb (priv->account_chooser, dialog); diff --git a/libempathy-gtk/empathy-contact-selector-dialog.h b/libempathy-gtk/empathy-contact-selector-dialog.h index 0f5279946..2315bc401 100644 --- a/libempathy-gtk/empathy-contact-selector-dialog.h +++ b/libempathy-gtk/empathy-contact-selector-dialog.h @@ -39,6 +39,9 @@ struct _EmpathyContactSelectorDialogClass { void (*got_response) (EmpathyContactSelectorDialog *self, TpConnection *connection, const gchar *contact_id); + + gboolean (*account_filter) (EmpathyContactSelectorDialog *self, + TpAccount *account); }; struct _EmpathyContactSelectorDialog { |