aboutsummaryrefslogtreecommitdiffstats
path: root/libempathy-gtk/empathy-contact-dialogs.c
diff options
context:
space:
mode:
authorDanielle Madeley <danielle.madeley@collabora.co.uk>2011-02-10 12:45:17 +0800
committerDanielle Madeley <danielle.madeley@collabora.co.uk>2011-02-10 12:45:17 +0800
commitbbd1ebc8ae5c785b6a4c5458155c90a05981000e (patch)
treea3c3a1923a918cade224a9b70a92256e3387cb8c /libempathy-gtk/empathy-contact-dialogs.c
parent9b421ab4f0806be9bfb841286fa991204aaa4780 (diff)
downloadgsoc2013-empathy-bbd1ebc8ae5c785b6a4c5458155c90a05981000e.tar
gsoc2013-empathy-bbd1ebc8ae5c785b6a4c5458155c90a05981000e.tar.gz
gsoc2013-empathy-bbd1ebc8ae5c785b6a4c5458155c90a05981000e.tar.bz2
gsoc2013-empathy-bbd1ebc8ae5c785b6a4c5458155c90a05981000e.tar.lz
gsoc2013-empathy-bbd1ebc8ae5c785b6a4c5458155c90a05981000e.tar.xz
gsoc2013-empathy-bbd1ebc8ae5c785b6a4c5458155c90a05981000e.tar.zst
gsoc2013-empathy-bbd1ebc8ae5c785b6a4c5458155c90a05981000e.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.c21
1 files changed, 20 insertions, 1 deletions
diff --git a/libempathy-gtk/empathy-contact-dialogs.c b/libempathy-gtk/empathy-contact-dialogs.c
index 7aba1fd7c..b51ce18c8 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);
@@ -97,8 +103,13 @@ empathy_subscription_dialog_show (EmpathyContact *contact,
GtkWidget *dialog;
GtkWidget *hbox_subscription;
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));
@@ -115,6 +126,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);
@@ -137,10 +149,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);
}