]> git.0d.be Git - empathy.git/blobdiff - libempathy-gtk/empathy-contact-menu.c
Factor out common blocking confirmation dialog
[empathy.git] / libempathy-gtk / empathy-contact-menu.c
index e03444ac965489e53c9e2d7c69bde345f0b7f419..64825b43cc96697abd4f583ff1e208294f8d5e99 100644 (file)
@@ -239,51 +239,32 @@ empathy_contact_block_menu_item_toggled (GtkCheckMenuItem *item,
        if (block_signal > 0)
                return;
 
-       manager = empathy_contact_manager_dup_singleton ();
        blocked = gtk_check_menu_item_get_active (item);
 
        if (blocked) {
                /* confirm the user really wishes to block the contact */
-               int res;
-               GtkWidget *parent, *dialog;
+               GtkWidget *parent;
 
                /* gtk_menu_get_attach_widget() doesn't behave properly here
                 * for some reason */
                parent = g_object_get_data (
                        G_OBJECT (gtk_widget_get_parent (GTK_WIDGET (item))),
                        "window");
-               dialog = gtk_message_dialog_new (GTK_WINDOW (parent),
-                               GTK_DIALOG_MODAL,
-                               GTK_MESSAGE_QUESTION, GTK_BUTTONS_NONE,
-                               _("Block %s?"),
-                               empathy_contact_get_id (contact));
-
-               gtk_message_dialog_format_secondary_text (
-                       GTK_MESSAGE_DIALOG (dialog),
-                       _("Are you sure you want to block the contact %s?"),
-                       empathy_contact_get_id (contact));
-               gtk_dialog_add_buttons (GTK_DIALOG (dialog),
-                               GTK_STOCK_CANCEL, GTK_RESPONSE_CANCEL,
-                               _("Block"), GTK_RESPONSE_REJECT,
-                               NULL);
-
-               res = gtk_dialog_run (GTK_DIALOG (dialog));
-               gtk_widget_destroy (dialog);
-
-               if (res != GTK_RESPONSE_REJECT)
-                       goto finally;
+
+               if (!empathy_block_contact_dialog_show (GTK_WINDOW (parent),
+                                       contact, NULL))
+                       return;
        }
 
+       manager = empathy_contact_manager_dup_singleton ();
        empathy_contact_list_set_blocked (EMPATHY_CONTACT_LIST (manager),
                                          contact, blocked);
+       g_object_unref (manager);
 
        /* update the toggle with the blocked status */
        block_signal++;
        gtk_check_menu_item_set_active (item, blocked);
        block_signal--;
-
-finally:
-       g_object_unref (manager);
 }
 
 static GtkWidget *