aboutsummaryrefslogtreecommitdiffstats
path: root/src/ephy-history-window.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/ephy-history-window.c')
-rw-r--r--src/ephy-history-window.c90
1 files changed, 88 insertions, 2 deletions
diff --git a/src/ephy-history-window.c b/src/ephy-history-window.c
index 71ec221cc..144590247 100644
--- a/src/ephy-history-window.c
+++ b/src/ephy-history-window.c
@@ -102,6 +102,7 @@ struct EphyHistoryWindowPrivate
GtkWidget *window;
EggMenuMerge *ui_merge;
EggActionGroup *action_group;
+ GtkWidget *confirmation_dialog;
};
enum
@@ -176,12 +177,17 @@ static EggActionGroupEntry ephy_history_ui_entries [] = {
static guint ephy_history_ui_n_entries = G_N_ELEMENTS (ephy_history_ui_entries);
static void
-cmd_clear (EggAction *action,
- EphyHistoryWindow *editor)
+confirmation_dialog_response_cb (GtkDialog *dialog, gint response,
+ EphyHistoryWindow *editor)
{
const GList *windows;
Session *session;
+ gtk_widget_destroy (GTK_WIDGET (dialog));
+
+ if (response != GTK_RESPONSE_OK)
+ return;
+
session = ephy_shell_get_session (ephy_shell);
windows = session_get_windows (session);
@@ -196,10 +202,90 @@ cmd_clear (EggAction *action,
ephy_history_clear (editor->priv->history);
}
+static GtkWidget *
+confirmation_dialog_construct (EphyHistoryWindow *editor)
+{
+ GtkWidget *dialog;
+ GtkWidget *label;
+ GtkWidget *vbox;
+ GtkWidget *hbox;
+ GtkWidget *image;
+ char *str;
+
+ dialog = gtk_dialog_new_with_buttons (_("Clear history"),
+ GTK_WINDOW (editor),
+ GTK_DIALOG_DESTROY_WITH_PARENT |
+ GTK_DIALOG_NO_SEPARATOR,
+ GTK_STOCK_CANCEL,
+ GTK_RESPONSE_CANCEL,
+ GTK_STOCK_CLEAR,
+ GTK_RESPONSE_OK,
+ NULL);
+ gtk_dialog_set_default_response (GTK_DIALOG (dialog), GTK_RESPONSE_OK);
+ gtk_container_set_border_width (GTK_CONTAINER (dialog), 6);
+ gtk_box_set_spacing (GTK_BOX (GTK_DIALOG (dialog)->vbox), 12);
+
+ hbox = gtk_hbox_new (FALSE, 6);
+ gtk_widget_show (hbox);
+ gtk_box_pack_start (GTK_BOX (GTK_DIALOG (dialog)->vbox), hbox,
+ TRUE, TRUE, 0);
+
+ image = gtk_image_new_from_stock (GTK_STOCK_DIALOG_WARNING,
+ GTK_ICON_SIZE_DIALOG);
+ gtk_misc_set_alignment (GTK_MISC (image), 0.5, 0.0);
+ gtk_widget_show (image);
+ gtk_box_pack_start (GTK_BOX (hbox), image, TRUE, TRUE, 0);
+
+ vbox = gtk_vbox_new (FALSE, 6);
+ gtk_widget_show (vbox);
+ gtk_box_pack_start (GTK_BOX (hbox), vbox, TRUE, TRUE, 0);
+
+ label = gtk_label_new (NULL);
+ gtk_misc_set_alignment (GTK_MISC (label), 0.0, 0.5);
+ gtk_label_set_line_wrap (GTK_LABEL (label), TRUE);
+ str = g_strconcat ("<b><big>", _("Clear browsing history?"),
+ "</big></b>", NULL);
+ gtk_label_set_markup (GTK_LABEL (label), str);
+ g_free (str);
+ gtk_box_pack_start (GTK_BOX (vbox), label, TRUE, TRUE, 0);
+ gtk_widget_show (label);
+
+ label = gtk_label_new (_("Clearing the browsing history will cause all"
+ " history items to be permanently deleted."));
+ gtk_misc_set_alignment (GTK_MISC (label), 0.0, 0.5);
+ gtk_label_set_line_wrap (GTK_LABEL (label), TRUE);
+ gtk_box_pack_start (GTK_BOX (vbox), label, TRUE, TRUE, 0);
+ gtk_widget_show (label);
+
+ g_signal_connect (dialog, "response",
+ G_CALLBACK (confirmation_dialog_response_cb),
+ editor);
+
+ return dialog;
+}
+
+static void
+cmd_clear (EggAction *action,
+ EphyHistoryWindow *editor)
+{
+ if (editor->priv->confirmation_dialog == NULL)
+ {
+ editor->priv->confirmation_dialog = confirmation_dialog_construct (editor);
+ g_object_add_weak_pointer (G_OBJECT(editor->priv->confirmation_dialog),
+ (gpointer *)&editor->priv->confirmation_dialog);
+ }
+
+ gtk_widget_show (editor->priv->confirmation_dialog);
+}
+
static void
cmd_close (EggAction *action,
EphyHistoryWindow *editor)
{
+ if (editor->priv->confirmation_dialog != NULL)
+ {
+ gtk_widget_destroy (editor->priv->confirmation_dialog);
+ }
gtk_widget_hide (GTK_WIDGET (editor));
}