diff options
author | Danielle Madeley <danielle.madeley@collabora.co.uk> | 2011-02-10 12:45:17 +0800 |
---|---|---|
committer | Chandni Verma <chandniverma2112@gmail.com> | 2011-03-08 12:04:28 +0800 |
commit | 9968dc5978d6eb12ccc1f1cc76ca08fc0a739e85 (patch) | |
tree | f7d13b110293cc7ff036f231c5828e3fa6055d61 /libempathy-gtk/empathy-contact-dialogs.c | |
parent | 8e95ee8c1455390b18126d2280bcd218777379a8 (diff) | |
download | gsoc2013-empathy-9968dc5978d6eb12ccc1f1cc76ca08fc0a739e85.tar gsoc2013-empathy-9968dc5978d6eb12ccc1f1cc76ca08fc0a739e85.tar.gz gsoc2013-empathy-9968dc5978d6eb12ccc1f1cc76ca08fc0a739e85.tar.bz2 gsoc2013-empathy-9968dc5978d6eb12ccc1f1cc76ca08fc0a739e85.tar.lz gsoc2013-empathy-9968dc5978d6eb12ccc1f1cc76ca08fc0a739e85.tar.xz gsoc2013-empathy-9968dc5978d6eb12ccc1f1cc76ca08fc0a739e85.tar.zst gsoc2013-empathy-9968dc5978d6eb12ccc1f1cc76ca08fc0a739e85.zip |
Add Block button to the subscription authorization dialog
Diffstat (limited to 'libempathy-gtk/empathy-contact-dialogs.c')
-rw-r--r-- | libempathy-gtk/empathy-contact-dialogs.c | 21 |
1 files changed, 20 insertions, 1 deletions
diff --git a/libempathy-gtk/empathy-contact-dialogs.c b/libempathy-gtk/empathy-contact-dialogs.c index fb67c41cc..15f344bb8 100644 --- a/libempathy-gtk/empathy-contact-dialogs.c +++ b/libempathy-gtk/empathy-contact-dialogs.c @@ -79,9 +79,15 @@ subscription_dialog_response_cb (GtkDialog *dialog, empathy_contact_set_alias (contact, empathy_contact_widget_get_alias (contact_widget)); } - else if (response == GTK_RESPONSE_NO) { + else if (response == GTK_RESPONSE_NO || + response == GTK_RESPONSE_REJECT) { empathy_contact_list_remove (EMPATHY_CONTACT_LIST (manager), contact, ""); + + if (response == GTK_RESPONSE_REJECT) { + empathy_contact_list_set_blocked ( + EMPATHY_CONTACT_LIST (manager), contact, TRUE); + } } subscription_dialogs = g_list_remove (subscription_dialogs, dialog); @@ -99,8 +105,13 @@ empathy_subscription_dialog_show (EmpathyContact *contact, GtkWidget *hbox_subscription; GtkWidget *vbox; GtkWidget *contact_widget; + GtkWidget *block_user_button; GList *l; gchar *filename; + EmpathyContactManager *manager; + EmpathyContactListFlags flags; + + manager = empathy_contact_manager_dup_singleton (); g_return_if_fail (EMPATHY_IS_CONTACT (contact)); @@ -117,6 +128,7 @@ empathy_subscription_dialog_show (EmpathyContact *contact, gui = empathy_builder_get_file (filename, "subscription_request_dialog", &dialog, "hbox_subscription", &hbox_subscription, + "block-user-button", &block_user_button, NULL); g_free (filename); g_object_unref (gui); @@ -161,10 +173,17 @@ empathy_subscription_dialog_show (EmpathyContact *contact, G_CALLBACK (subscription_dialog_response_cb), contact_widget); + flags = empathy_contact_manager_get_flags_for_connection (manager, + empathy_contact_get_connection (contact)); + + if (flags & EMPATHY_CONTACT_LIST_CAN_BLOCK) + gtk_widget_show (block_user_button); + if (parent) { gtk_window_set_transient_for (GTK_WINDOW (dialog), parent); } + g_object_unref (manager); gtk_widget_show (dialog); } |