/*
* Sylpheed -- a GTK+ based, lightweight, and fast e-mail client
- * Copyright (C) 1999-2001 Hiroyuki Yamamoto
+ * Copyright (C) 1999-2007 Hiroyuki Yamamoto and the Claws Mail team
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
- * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
*/
#ifdef HAVE_CONFIG_H
# include "config.h"
#endif
+#include <stddef.h>
+
+#include <glib.h>
+#include <glib/gi18n.h>
#include <gtk/gtk.h>
#include <gdk/gdkkeysyms.h>
-#include "intl.h"
+#include "mainwindow.h"
#include "alertpanel.h"
#include "manage_window.h"
#include "utils.h"
#include "gtkutils.h"
#include "inc.h"
+#include "logwindow.h"
+#include "prefs_common.h"
-#define TITLE_FONT "-*-helvetica-medium-r-normal--17-*-*-*-*-*-*-*," \
- "-*-*-medium-r-normal--16-*-*-*-*-*-*-*,*"
-#define MESSAGE_FONT "-*-helvetica-medium-r-normal--14-*-*-*-*-*-*-*," \
- "-*-*-medium-r-normal--14-*-*-*-*-*-*-*,*"
#define ALERT_PANEL_WIDTH 380
#define TITLE_HEIGHT 72
#define MESSAGE_HEIGHT 62
-static gboolean alertpanel_is_open = FALSE;
+gboolean alertpanel_is_open = FALSE;
static AlertValue value;
static GtkWidget *dialog;
const gchar *button2_label,
const gchar *button3_label,
gboolean can_disable,
- GtkWidget *custom_widget);
+ GtkWidget *custom_widget,
+ gint alert_type,
+ AlertValue default_value);
static void alertpanel_button_toggled (GtkToggleButton *button,
gpointer data);
static gint alertpanel_deleted (GtkWidget *widget,
GdkEventAny *event,
gpointer data);
-static void alertpanel_close (GtkWidget *widget,
+static gboolean alertpanel_close (GtkWidget *widget,
GdkEventAny *event,
gpointer data);
-AlertValue alertpanel(const gchar *title,
- const gchar *message,
- const gchar *button1_label,
- const gchar *button2_label,
- const gchar *button3_label)
-{
- if (alertpanel_is_open)
- return -1;
- else
- alertpanel_is_open = TRUE;
-
- alertpanel_create(title, message, button1_label, button2_label,
- button3_label, FALSE, NULL);
- alertpanel_show();
-
- debug_print("return value = %d\n", value);
- return value;
-}
-
AlertValue alertpanel_with_widget(const gchar *title,
const gchar *message,
const gchar *button1_label,
const gchar *button2_label,
const gchar *button3_label,
+ gboolean can_disable,
GtkWidget *widget)
+{
+ return alertpanel_full(title, message, button1_label,
+ button2_label, button3_label,
+ can_disable, widget, ALERT_QUESTION,
+ G_ALERTDEFAULT);
+}
+
+AlertValue alertpanel_full(const gchar *title, const gchar *message,
+ const gchar *button1_label,
+ const gchar *button2_label,
+ const gchar *button3_label,
+ gboolean can_disable,
+ GtkWidget *widget,
+ AlertType alert_type,
+ AlertValue default_value)
{
if (alertpanel_is_open)
return -1;
else
alertpanel_is_open = TRUE;
- alertpanel_create(title, message, button1_label, button2_label,
- button3_label, FALSE, widget);
+
+ alertpanel_create(title, message, button1_label, button2_label,
+ button3_label, can_disable, widget, alert_type,
+ default_value);
alertpanel_show();
debug_print("return value = %d\n", value);
return value;
}
-void alertpanel_message(const gchar *title, const gchar *message)
-{
- if (alertpanel_is_open)
- return;
- else
- alertpanel_is_open = TRUE;
- alertpanel_create(title, message, NULL, NULL, NULL, FALSE, NULL);
- alertpanel_show();
+AlertValue alertpanel(const gchar *title,
+ const gchar *message,
+ const gchar *button1_label,
+ const gchar *button2_label,
+ const gchar *button3_label)
+{
+ return alertpanel_full(title, message, button1_label, button2_label,
+ button3_label, FALSE, NULL, ALERT_QUESTION,
+ G_ALERTDEFAULT);
}
-AlertValue alertpanel_message_with_disable(const gchar *title,
- const gchar *message)
+static void alertpanel_message(const gchar *title, const gchar *message, gint type)
{
if (alertpanel_is_open)
- return 0;
+ return;
else
alertpanel_is_open = TRUE;
- alertpanel_create(title, message, NULL, NULL, NULL, TRUE, NULL);
+ alertpanel_create(title, message, GTK_STOCK_CLOSE, NULL, NULL,
+ FALSE, NULL, type, G_ALERTDEFAULT);
alertpanel_show();
-
- return value;
}
void alertpanel_notice(const gchar *format, ...)
va_end(args);
strretchomp(buf);
- alertpanel_message(_("Notice"), buf);
+ alertpanel_message(_("Notice"), buf, ALERT_NOTICE);
}
void alertpanel_warning(const gchar *format, ...)
va_end(args);
strretchomp(buf);
- alertpanel_message(_("Warning"), buf);
+ alertpanel_message(_("Warning"), buf, ALERT_WARNING);
}
void alertpanel_error(const gchar *format, ...)
{
va_list args;
+ gchar buf[512];
+
+ va_start(args, format);
+ g_vsnprintf(buf, sizeof(buf), format, args);
+ va_end(args);
+ strretchomp(buf);
+
+ alertpanel_message(_("Error"), buf, ALERT_ERROR);
+}
+
+/*!
+ *\brief display an error with a View Log button
+ *
+ */
+void alertpanel_error_log(const gchar *format, ...)
+{
+ va_list args;
+ int val;
+ MainWindow *mainwin;
gchar buf[256];
va_start(args, format);
va_end(args);
strretchomp(buf);
- alertpanel_message(_("Error"), buf);
+ mainwin = mainwindow_get_mainwindow();
+
+ if (mainwin && mainwin->logwin) {
+ mainwindow_clear_error(mainwin);
+ val = alertpanel_full(_("Error"), buf, GTK_STOCK_CLOSE,
+ _("_View log"), NULL, FALSE, NULL,
+ ALERT_ERROR, G_ALERTDEFAULT);
+ if (val == G_ALERTALTERNATE)
+ log_window_show(mainwin->logwin);
+ } else
+ alertpanel_error(buf);
}
static void alertpanel_show(void)
const gchar *button2_label,
const gchar *button3_label,
gboolean can_disable,
- GtkWidget *custom_widget)
+ GtkWidget *custom_widget,
+ gint alert_type,
+ AlertValue default_value)
{
- static GdkFont *titlefont;
- GtkStyle *style;
+ static PangoFontDescription *font_desc;
+ GtkWidget *image;
GtkWidget *label;
GtkWidget *hbox;
GtkWidget *vbox;
- GtkWidget *spc_vbox;
- GtkWidget *msg_vbox;
- GtkWidget *disable_chkbtn;
+ GtkWidget *disable_checkbtn;
GtkWidget *confirm_area;
GtkWidget *button1;
GtkWidget *button2;
GtkWidget *button3;
const gchar *label2;
const gchar *label3;
-
+ gchar *tmp = title?g_markup_printf_escaped("%s", title)
+ :g_strdup("");
+ gchar *title_full = g_strdup_printf("<span weight=\"bold\" "
+ "size=\"larger\">%s</span>",
+ tmp);
+ g_free(tmp);
debug_print("Creating alert panel dialog...\n");
dialog = gtk_dialog_new();
gtk_window_set_title(GTK_WINDOW(dialog), title);
- gtk_window_set_policy(GTK_WINDOW(dialog), FALSE, FALSE, FALSE);
- gtk_container_set_border_width
- (GTK_CONTAINER(GTK_DIALOG(dialog)->action_area), 5);
- gtk_window_position(GTK_WINDOW(dialog), GTK_WIN_POS_CENTER);
- gtk_signal_connect(GTK_OBJECT(dialog), "delete_event",
- GTK_SIGNAL_FUNC(alertpanel_deleted),
- (gpointer)G_ALERTOTHER);
- gtk_signal_connect(GTK_OBJECT(dialog), "key_press_event",
- GTK_SIGNAL_FUNC(alertpanel_close),
- (gpointer)G_ALERTOTHER);
- gtk_widget_realize(dialog);
-
- /* for title label */
- hbox = gtk_hbox_new(FALSE, 0);
+ gtk_window_set_resizable(GTK_WINDOW(dialog), TRUE);
+
+ gtk_window_set_default_size(GTK_WINDOW(dialog), 375, 100);
+ gtk_dialog_set_has_separator (GTK_DIALOG (dialog), FALSE);
+
+ gtk_window_set_position(GTK_WINDOW(dialog), GTK_WIN_POS_CENTER);
+ g_signal_connect(G_OBJECT(dialog), "delete_event",
+ G_CALLBACK(alertpanel_deleted),
+ (gpointer)G_ALERTCANCEL);
+ g_signal_connect(G_OBJECT(dialog), "key_press_event",
+ G_CALLBACK(alertpanel_close),
+ (gpointer)G_ALERTCANCEL);
+
+ /* for title icon, label and message */
+ hbox = gtk_hbox_new(FALSE, 12);
+ gtk_container_set_border_width(GTK_CONTAINER(hbox), 12);
gtk_box_pack_start(GTK_BOX(GTK_DIALOG(dialog)->vbox),
- hbox, TRUE, TRUE, 16);
-
- /* title label */
- /* pixmapwid = create_pixmapwid(dialog, GNUstep_xpm); */
- /* gtk_box_pack_start(GTK_BOX(hbox), pixmapwid, FALSE, FALSE, 16); */
- label = gtk_label_new(title);
- gtk_box_pack_start(GTK_BOX(hbox), label, TRUE, TRUE, 16);
+ hbox, FALSE, FALSE, 0);
+
+ /* title icon */
+ switch (alert_type) {
+ case ALERT_QUESTION:
+ image = gtk_image_new_from_stock
+ (GTK_STOCK_DIALOG_QUESTION, GTK_ICON_SIZE_DIALOG);
+ break;
+ case ALERT_WARNING:
+ image = gtk_image_new_from_stock
+ (GTK_STOCK_DIALOG_WARNING, GTK_ICON_SIZE_DIALOG);
+ break;
+ case ALERT_ERROR:
+ image = gtk_image_new_from_stock
+ (GTK_STOCK_DIALOG_ERROR, GTK_ICON_SIZE_DIALOG);
+ break;
+ case ALERT_NOTICE:
+ default:
+ image = gtk_image_new_from_stock
+ (GTK_STOCK_DIALOG_INFO, GTK_ICON_SIZE_DIALOG);
+ break;
+ }
+ gtk_misc_set_alignment(GTK_MISC(image), 0.5, 0.0);
+ gtk_box_pack_start(GTK_BOX(hbox), image, FALSE, FALSE, 0);
+
+ vbox = gtk_vbox_new (FALSE, 12);
+ gtk_box_pack_start (GTK_BOX (hbox), vbox, TRUE, TRUE, 0);
+ gtk_widget_show (vbox);
+
+ label = gtk_label_new(title_full);
gtk_misc_set_alignment(GTK_MISC(label), 0, 0.5);
- style = gtk_style_copy(gtk_widget_get_style(label));
- if (!titlefont)
- titlefont = gdk_fontset_load(TITLE_FONT);
- if (titlefont)
- style->font = titlefont;
- gtk_widget_set_style(label, style);
-
- /* for message and button(s) */
- vbox = gtk_vbox_new(FALSE, 0);
- gtk_container_add(GTK_CONTAINER(GTK_DIALOG(dialog)->action_area),
- vbox);
-
- spc_vbox = gtk_vbox_new(FALSE, 0);
- gtk_box_pack_start(GTK_BOX(vbox), spc_vbox, FALSE, FALSE, 0);
- gtk_widget_set_usize(spc_vbox, -1, 16);
-
- msg_vbox = gtk_vbox_new(FALSE, 0);
- gtk_box_pack_start(GTK_BOX(vbox), msg_vbox, FALSE, FALSE, 0);
-
- /* for message label */
- hbox = gtk_hbox_new(FALSE, 0);
- gtk_box_pack_start(GTK_BOX(msg_vbox), hbox, FALSE, FALSE, 0);
-
- /* message label */
+ gtk_label_set_justify(GTK_LABEL(label), GTK_JUSTIFY_LEFT);
+ gtk_label_set_use_markup(GTK_LABEL (label), TRUE);
+ gtk_box_pack_start(GTK_BOX(vbox), label, FALSE, FALSE, 0);
+ gtk_label_set_line_wrap(GTK_LABEL(label), TRUE);
+ if (!font_desc) {
+ gint size;
+
+ size = pango_font_description_get_size
+ (label->style->font_desc);
+ font_desc = pango_font_description_new();
+ pango_font_description_set_weight
+ (font_desc, PANGO_WEIGHT_BOLD);
+ pango_font_description_set_size
+ (font_desc, size * PANGO_SCALE_LARGE);
+ }
+ if (font_desc)
+ gtk_widget_modify_font(label, font_desc);
+ g_free(title_full);
+
label = gtk_label_new(message);
- gtk_box_pack_start(GTK_BOX(hbox), label, TRUE, TRUE, 24);
gtk_misc_set_alignment(GTK_MISC(label), 0, 0.5);
gtk_label_set_justify(GTK_LABEL(label), GTK_JUSTIFY_LEFT);
-
+ gtk_label_set_line_wrap(GTK_LABEL(label), TRUE);
+ gtk_label_set_selectable(GTK_LABEL(label), TRUE);
+ gtk_label_set_use_markup(GTK_LABEL(label), TRUE);
+ GTK_WIDGET_UNSET_FLAGS(label, GTK_CAN_FOCUS);
+ gtk_box_pack_start(GTK_BOX(vbox), label, FALSE, FALSE, 0);
+ gtk_widget_show(label);
+
/* Claws: custom widget */
if (custom_widget) {
- GtkWidget *custom_hbox = gtk_hbox_new(FALSE, 0);
- gtk_box_pack_start(GTK_BOX(msg_vbox), custom_hbox, FALSE,
+ gtk_box_pack_start(GTK_BOX(vbox), custom_widget, FALSE,
FALSE, 0);
- gtk_box_pack_start(GTK_BOX(custom_hbox), custom_widget, FALSE,
- FALSE, 24);
}
+
if (can_disable) {
hbox = gtk_hbox_new(FALSE, 0);
- gtk_box_pack_start(GTK_BOX(vbox), hbox, FALSE, FALSE, 0);
- gtk_container_set_border_width(GTK_CONTAINER(hbox), 8);
+ gtk_box_pack_start(GTK_BOX(GTK_DIALOG(dialog)->vbox), hbox,
+ FALSE, FALSE, 0);
- disable_chkbtn = gtk_check_button_new_with_label
+ disable_checkbtn = gtk_check_button_new_with_label
(_("Show this message next time"));
- gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(disable_chkbtn),
+ gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(disable_checkbtn),
TRUE);
- gtk_box_pack_start(GTK_BOX(hbox), disable_chkbtn,
- FALSE, FALSE, 0);
- gtk_signal_connect(GTK_OBJECT(disable_chkbtn), "toggled",
- GTK_SIGNAL_FUNC(alertpanel_button_toggled),
- GUINT_TO_POINTER(G_ALERTDISABLE));
- } else {
- spc_vbox = gtk_vbox_new(FALSE, 0);
- gtk_box_pack_start(GTK_BOX(vbox), spc_vbox, FALSE, FALSE, 0);
- gtk_widget_set_usize(spc_vbox, -1, 20);
+ gtk_box_pack_start(GTK_BOX(hbox), disable_checkbtn,
+ FALSE, FALSE, 12);
+ g_signal_connect(G_OBJECT(disable_checkbtn), "toggled",
+ G_CALLBACK(alertpanel_button_toggled),
+ GUINT_TO_POINTER(G_ALERTDISABLE));
}
/* for button(s) */
if (!button1_label)
- button1_label = _("OK");
+ button1_label = GTK_STOCK_OK;
label2 = button2_label;
label3 = button3_label;
if (label2 && *label2 == '+') label2++;
if (label3 && *label3 == '+') label3++;
- gtkut_button_set_create(&confirm_area,
- &button1, button1_label,
- button2_label ? &button2 : NULL, label2,
- button3_label ? &button3 : NULL, label3);
+ gtkut_stock_button_set_create(&confirm_area,
+ &button1, button1_label,
+ button2_label ? &button2 : NULL, label2,
+ button3_label ? &button3 : NULL, label3);
- gtk_box_pack_end(GTK_BOX(vbox), confirm_area, FALSE, FALSE, 0);
+ gtk_box_pack_end(GTK_BOX(GTK_DIALOG(dialog)->action_area),
+ confirm_area, FALSE, FALSE, 0);
+ gtk_container_set_border_width(GTK_CONTAINER(confirm_area), 5);
gtk_widget_grab_default(button1);
gtk_widget_grab_focus(button1);
- if (button2_label && *button2_label == '+') {
+ if (button2_label &&
+ (default_value == G_ALERTALTERNATE || *button2_label == '+')) {
gtk_widget_grab_default(button2);
gtk_widget_grab_focus(button2);
}
- if (button3_label && *button3_label == '+') {
+ if (button3_label &&
+ (default_value == G_ALERTOTHER || *button3_label == '+')) {
gtk_widget_grab_default(button3);
gtk_widget_grab_focus(button3);
}
- gtk_signal_connect(GTK_OBJECT(button1), "clicked",
- GTK_SIGNAL_FUNC(alertpanel_button_clicked),
- GUINT_TO_POINTER(G_ALERTDEFAULT));
+ g_signal_connect(G_OBJECT(button1), "clicked",
+ G_CALLBACK(alertpanel_button_clicked),
+ GUINT_TO_POINTER(G_ALERTDEFAULT));
if (button2_label)
- gtk_signal_connect(GTK_OBJECT(button2), "clicked",
- GTK_SIGNAL_FUNC(alertpanel_button_clicked),
- GUINT_TO_POINTER(G_ALERTALTERNATE));
+ g_signal_connect(G_OBJECT(button2), "clicked",
+ G_CALLBACK(alertpanel_button_clicked),
+ GUINT_TO_POINTER(G_ALERTALTERNATE));
if (button3_label)
- gtk_signal_connect(GTK_OBJECT(button3), "clicked",
- GTK_SIGNAL_FUNC(alertpanel_button_clicked),
- GUINT_TO_POINTER(G_ALERTOTHER));
+ g_signal_connect(G_OBJECT(button3), "clicked",
+ G_CALLBACK(alertpanel_button_clicked),
+ GUINT_TO_POINTER(G_ALERTOTHER));
gtk_widget_show_all(dialog);
}
return TRUE;
}
-static void alertpanel_close(GtkWidget *widget, GdkEventAny *event,
- gpointer data)
+static gboolean alertpanel_close(GtkWidget *widget, GdkEventAny *event,
+ gpointer data)
{
if (event->type == GDK_KEY_PRESS)
if (((GdkEventKey *)event)->keyval != GDK_Escape)
- return;
+ return FALSE;
value = (value & ~G_ALERT_VALUE_MASK) | (AlertValue)data;
+ return FALSE;
}