diff options
author | Will Thompson <will.thompson@collabora.co.uk> | 2009-08-14 07:00:21 +0800 |
---|---|---|
committer | Will Thompson <will.thompson@collabora.co.uk> | 2012-01-30 21:28:00 +0800 |
commit | a6ac0f003a4f9ad6f21d98387cd6cebc72ee492f (patch) | |
tree | 9eccd00c007ec0b4574b752b1ff76db5d31240f6 /src | |
parent | 088cc0d11c82359e9c45be8429945445731b765b (diff) | |
download | gsoc2013-empathy-a6ac0f003a4f9ad6f21d98387cd6cebc72ee492f.tar gsoc2013-empathy-a6ac0f003a4f9ad6f21d98387cd6cebc72ee492f.tar.gz gsoc2013-empathy-a6ac0f003a4f9ad6f21d98387cd6cebc72ee492f.tar.bz2 gsoc2013-empathy-a6ac0f003a4f9ad6f21d98387cd6cebc72ee492f.tar.lz gsoc2013-empathy-a6ac0f003a4f9ad6f21d98387cd6cebc72ee492f.tar.xz gsoc2013-empathy-a6ac0f003a4f9ad6f21d98387cd6cebc72ee492f.tar.zst gsoc2013-empathy-a6ac0f003a4f9ad6f21d98387cd6cebc72ee492f.zip |
Confirm closing chat room tabs
I often accidentally close tabs with Control-W, and more occasionally by
clicking the [X] by mistake. This is okay for 1-1 conversations (I can
just reopen them) but is destructive for chat rooms. So let's make the
user confirm.
https://bugzilla.gnome.org/show_bug.cgi?id=591756
Diffstat (limited to 'src')
-rw-r--r-- | src/empathy-chat-window.c | 61 |
1 files changed, 59 insertions, 2 deletions
diff --git a/src/empathy-chat-window.c b/src/empathy-chat-window.c index 3e197796d..979139078 100644 --- a/src/empathy-chat-window.c +++ b/src/empathy-chat-window.c @@ -213,13 +213,70 @@ chat_window_find_chat (EmpathyChat *chat) } static void +confirm_close_response_cb (GtkWidget *dialog, + int response, + EmpathyChatWindow *window) +{ + EmpathyChat *chat; + + chat = g_object_get_data (G_OBJECT (dialog), "chat"); + + gtk_widget_destroy (dialog); + + if (response == GTK_RESPONSE_ACCEPT) + empathy_chat_window_remove_chat (window, chat); +} + +static void +maybe_close_chat (EmpathyChatWindow *window, + EmpathyChat *chat) +{ + EmpathyChatWindowPriv *priv; + + priv = GET_PRIV (window); + + if (empathy_chat_is_room (chat)) { + gchar *chat_name = empathy_chat_dup_name (chat); + GtkWidget *dialog = gtk_message_dialog_new ( + GTK_WINDOW (priv->dialog), + GTK_DIALOG_MODAL | GTK_DIALOG_DESTROY_WITH_PARENT, + GTK_MESSAGE_WARNING, + GTK_BUTTONS_CANCEL, + _("Leave %s?"), + chat_name); + + gtk_window_set_title (GTK_WINDOW (dialog), ""); + + gtk_message_dialog_format_secondary_text ( + GTK_MESSAGE_DIALOG (dialog), + _("You will not receive any further messages from " + "this chat room unless you rejoin.")); + + gtk_dialog_add_button (GTK_DIALOG (dialog), + _("Leave chat room"), GTK_RESPONSE_ACCEPT); + gtk_dialog_set_default_response (GTK_DIALOG (dialog), + GTK_RESPONSE_ACCEPT); + + g_object_set_data (G_OBJECT (dialog), "chat", chat); + + g_signal_connect (dialog, "response", + G_CALLBACK (confirm_close_response_cb), window); + + gtk_window_present (GTK_WINDOW (dialog)); + g_free (chat_name); + } else { + empathy_chat_window_remove_chat (window, chat); + } +} + +static void chat_window_close_clicked_cb (GtkAction *action, EmpathyChat *chat) { EmpathyChatWindow *window; window = chat_window_find_chat (chat); - empathy_chat_window_remove_chat (window, chat); + maybe_close_chat (window, chat); } static void @@ -1027,7 +1084,7 @@ chat_window_close_activate_cb (GtkAction *action, g_return_if_fail (priv->current_chat != NULL); - empathy_chat_window_remove_chat (window, priv->current_chat); + maybe_close_chat (window, priv->current_chat); } static void |