aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorhiro <hiro@ee746299-78ed-0310-b773-934348b2243d>2014-03-19 08:33:29 +0000
committerhiro <hiro@ee746299-78ed-0310-b773-934348b2243d>2014-03-19 08:33:29 +0000
commitbf166a12fba39baa7d17ffd40c2a32131f8689c5 (patch)
tree951bac4dd69fba2c57e378bc4daf390cd8f57bde /src
parent394f514c0a07a93ee41e082b01ffbc9606095dae (diff)
made the display period of notification window configurable.
git-svn-id: svn://sylpheed.sraoss.jp/sylpheed/trunk@3355 ee746299-78ed-0310-b773-934348b2243d
Diffstat (limited to 'src')
-rw-r--r--src/inc.c2
-rw-r--r--src/notificationwindow.c15
-rw-r--r--src/prefs_common_dialog.c56
3 files changed, 65 insertions, 8 deletions
diff --git a/src/inc.c b/src/inc.c
index 1fd0cb31..8f638668 100644
--- a/src/inc.c
+++ b/src/inc.c
@@ -250,7 +250,7 @@ static void inc_finished(MainWindow *mainwin, IncResult *result)
}
}
- notification_window_open(buf, str->str, 5);
+ notification_window_open(buf, str->str, prefs_common.notify_window_period);
}
g_string_free(str, TRUE);
diff --git a/src/notificationwindow.c b/src/notificationwindow.c
index 018871cd..38681911 100644
--- a/src/notificationwindow.c
+++ b/src/notificationwindow.c
@@ -163,10 +163,10 @@ gint notification_window_open(const gchar *message, const gchar *submessage,
if (y < 0) y = 0;
gtk_window_move(GTK_WINDOW(window), x, y);
- if (timeout == 0)
- timeout = 1;
- notify_window.notify_tag = g_timeout_add(timeout * 1000,
- notify_timeout_cb, NULL);
+ if (timeout > 0) {
+ notify_window.notify_tag = g_timeout_add(timeout * 1000,
+ notify_timeout_cb, NULL);
+ }
debug_print("notification window created\n");
@@ -280,8 +280,11 @@ static gboolean nwin_motion_notify(GtkWidget *widget, GdkEventMotion *event,
notify_window.notify_event_count = 0;
gtk_window_move(GTK_WINDOW(notify_window.window),
notify_window.x, notify_window.y);
- notify_window.notify_tag = g_timeout_add(notify_window.timeout * 1000,
- notify_timeout_cb, NULL);
+ if (notify_window.timeout > 0) {
+ notify_window.notify_tag =
+ g_timeout_add(notify_window.timeout * 1000,
+ notify_timeout_cb, NULL);
+ }
return FALSE;
}
diff --git a/src/prefs_common_dialog.c b/src/prefs_common_dialog.c
index 598c6393..4a7bdbe7 100644
--- a/src/prefs_common_dialog.c
+++ b/src/prefs_common_dialog.c
@@ -1,6 +1,6 @@
/*
* Sylpheed -- a GTK+ based, lightweight, and fast e-mail client
- * Copyright (C) 1999-2013 Hiroyuki Yamamoto
+ * Copyright (C) 1999-2014 Hiroyuki Yamamoto
*
* 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
@@ -70,6 +70,8 @@ static struct Receive {
GtkWidget *checkbtn_scan_after_inc;
GtkWidget *checkbtn_newmsg_notify_window;
+ GtkWidget *spinbtn_notifywin;
+ GtkObject *spinbtn_notifywin_adj;
#ifdef G_OS_WIN32
GtkWidget *checkbtn_newmsg_sound;
GtkWidget *entry_newmsg_sound;
@@ -329,6 +331,8 @@ static PrefsUIData ui_data[] = {
#endif
{"enable_newmsg_notify_window", &receive.checkbtn_newmsg_notify_window,
prefs_set_data_from_toggle, prefs_set_toggle},
+ {"notify_window_period", &receive.spinbtn_notifywin,
+ prefs_set_data_from_spinbtn, prefs_set_spinbtn},
#ifndef G_OS_WIN32
{"inc_local", &receive.checkbtn_local,
@@ -854,6 +858,11 @@ static void prefs_receive_create(void)
GtkWidget *frame_notify;
GtkWidget *checkbtn_newmsg_notify_window;
+ GtkWidget *hbox_notifywin;
+ GtkWidget *hbox_spc;
+ GtkWidget *label_notifywin;
+ GtkObject *spinbtn_notifywin_adj;
+ GtkWidget *spinbtn_notifywin;
GtkWidget *checkbtn_newmsg_notify;
GtkWidget *label_newmsg_notify;
GtkWidget *entry_newmsg_notify;
@@ -931,6 +940,49 @@ static void prefs_receive_create(void)
(vbox4, checkbtn_newmsg_notify_window,
_("Show notification window when new messages arrive"));
+ hbox_notifywin = gtk_hbox_new (FALSE, 8);
+ gtk_widget_show (hbox_notifywin);
+ gtk_box_pack_start (GTK_BOX (vbox4), hbox_notifywin, FALSE, FALSE, 0);
+
+ hbox_spc = gtk_hbox_new (FALSE, 0);
+ gtk_widget_show (hbox_spc);
+ gtk_box_pack_start (GTK_BOX (hbox_notifywin), hbox_spc, FALSE, FALSE, 0);
+ gtk_widget_set_size_request (hbox_spc, 12, -1);
+
+ label_notifywin = gtk_label_new (_("Display window for"));
+ gtk_widget_show (label_notifywin);
+ gtk_box_pack_start (GTK_BOX (hbox_notifywin), label_notifywin, FALSE, FALSE, 0);
+
+ spinbtn_notifywin_adj = gtk_adjustment_new (10, 0, 1000, 1, 10, 0);
+ spinbtn_notifywin = gtk_spin_button_new
+ (GTK_ADJUSTMENT (spinbtn_notifywin_adj), 1, 0);
+ gtk_widget_show (spinbtn_notifywin);
+ gtk_box_pack_start (GTK_BOX (hbox_notifywin), spinbtn_notifywin, FALSE, FALSE, 0);
+ gtk_widget_set_size_request (spinbtn_notifywin, 64, -1);
+ gtk_spin_button_set_numeric (GTK_SPIN_BUTTON (spinbtn_notifywin), TRUE);
+
+ label_notifywin = gtk_label_new (_("second(s)"));
+ gtk_widget_show (label_notifywin);
+ gtk_box_pack_start (GTK_BOX (hbox_notifywin), label_notifywin, FALSE, FALSE, 0);
+
+ SET_TOGGLE_SENSITIVITY(checkbtn_newmsg_notify_window, hbox_notifywin);
+
+ hbox_notifywin = gtk_hbox_new (FALSE, 8);
+ gtk_widget_show (hbox_notifywin);
+ gtk_box_pack_start (GTK_BOX (vbox4), hbox_notifywin, FALSE, FALSE, 0);
+
+ hbox_spc = gtk_hbox_new (FALSE, 0);
+ gtk_widget_show (hbox_spc);
+ gtk_box_pack_start (GTK_BOX (hbox_notifywin), hbox_spc, FALSE, FALSE, 0);
+ gtk_widget_set_size_request (hbox_spc, 12, -1);
+
+ label_notifywin = gtk_label_new (_("0: don't auto-close"));
+ gtk_widget_show (label_notifywin);
+ gtk_box_pack_start (GTK_BOX (hbox_notifywin), label_notifywin, FALSE, FALSE, 0);
+ gtkut_widget_set_small_font_size (label_notifywin);
+
+ SET_TOGGLE_SENSITIVITY(checkbtn_newmsg_notify_window, hbox_notifywin);
+
#ifdef G_OS_WIN32
PACK_CHECK_BUTTON
(vbox4, checkbtn_newmsg_sound,
@@ -1023,6 +1075,8 @@ static void prefs_receive_create(void)
receive.checkbtn_scan_after_inc = checkbtn_scan_after_inc;
receive.checkbtn_newmsg_notify_window = checkbtn_newmsg_notify_window;
+ receive.spinbtn_notifywin = spinbtn_notifywin;
+ receive.spinbtn_notifywin_adj = spinbtn_notifywin_adj;
#ifdef G_OS_WIN32
receive.checkbtn_newmsg_sound = checkbtn_newmsg_sound;
receive.entry_newmsg_sound = entry_newmsg_sound;