#include "prefs_folder_item.h"
#include "prefs_summary_column.h"
#include "prefs_template.h"
-#include "prefs_toolbar.h"
#include "account.h"
#include "addressbook.h"
#include "logwindow.h"
#include "selective_download.h"
#include "ssl_manager.h"
#include "sslcertwindow.h"
+#include "prefs_gtk.h"
+#include "pluginwindow.h"
+#include "hooks.h"
+#include "progressindicator.h"
#define AC_LABEL_WIDTH 240
static void sel_download_cb (MainWindow *mainwin,
guint action,
GtkWidget *widget);
-static void prefs_toolbar_cb (MainWindow *mainwin,
- guint action,
- GtkWidget *widget);
-
static void inc_cancel_cb (MainWindow *mainwin,
guint action,
static void account_menu_cb (GtkMenuItem *menuitem,
gpointer data);
+static void prefs_open_cb (GtkMenuItem *menuitem,
+ gpointer data);
+static void plugins_open_cb (GtkMenuItem *menuitem,
+ gpointer data);
+
static void online_switch_clicked(GtkButton *btn,
gpointer data);
guint action,
GtkWidget *widget );
+static gboolean mainwindow_focus_in_event (GtkWidget *widget,
+ GdkEventFocus *focus,
+ gpointer data);
+void main_window_reply_cb (MainWindow *mainwin,
+ guint action,
+ GtkWidget *widget);
+gboolean mainwindow_progressindicator_hook (gpointer source,
+ gpointer userdata);
#define SEPARATE_ACTION 500
static GtkItemFactoryEntry mainwin_entries[] =
{N_("/_View/_Sort/by _color label"),
NULL, sort_summary_cb, SORT_BY_LABEL, "/View/Sort/by number"},
{N_("/_View/_Sort/by _mark"), NULL, sort_summary_cb, SORT_BY_MARK, "/View/Sort/by number"},
- {N_("/_View/_Sort/by _unread"), NULL, sort_summary_cb, SORT_BY_UNREAD, "/View/Sort/by number"},
+ {N_("/_View/_Sort/by _status"), NULL, sort_summary_cb, SORT_BY_STATUS, "/View/Sort/by number"},
{N_("/_View/_Sort/by a_ttachment"),
NULL, sort_summary_cb, SORT_BY_MIME, "/View/Sort/by number"},
{N_("/_View/_Sort/by score"), NULL, sort_summary_cb, SORT_BY_SCORE, "/View/Sort/by number"},
{N_("/_View/_Code set/7bit ascii (US-ASC_II)"),
CODESET_ACTION(C_US_ASCII)},
-#if HAVE_LIBJCONV
+#if HAVE_ICONV
{N_("/_View/_Code set/Unicode (_UTF-8)"),
CODESET_ACTION(C_UTF_8)},
CODESET_SEPARATOR,
{N_("/_View/_Code set/Western European (ISO-8859-15)"),
CODESET_ACTION(C_ISO_8859_15)},
CODESET_SEPARATOR,
-#if HAVE_LIBJCONV
+#if HAVE_ICONV
{N_("/_View/_Code set/Central European (ISO-8859-_2)"),
CODESET_ACTION(C_ISO_8859_2)},
CODESET_SEPARATOR,
#endif
{N_("/_View/_Code set/Japanese (ISO-2022-_JP)"),
CODESET_ACTION(C_ISO_2022_JP)},
-#if HAVE_LIBJCONV
+#if HAVE_ICONV
{N_("/_View/_Code set/Japanese (ISO-2022-JP-2)"),
CODESET_ACTION(C_ISO_2022_JP_2)},
#endif
CODESET_ACTION(C_EUC_JP)},
{N_("/_View/_Code set/Japanese (_Shift__JIS)"),
CODESET_ACTION(C_SHIFT_JIS)},
-#if HAVE_LIBJCONV
+#if HAVE_ICONV
CODESET_SEPARATOR,
{N_("/_View/_Code set/Simplified Chinese (_GB2312)"),
CODESET_ACTION(C_GB2312)},
{N_("/_Message/---"), NULL, NULL, 0, "<Separator>"},
{N_("/_Message/Compose a_n email message"), "<control>M", compose_mail_cb, 0, NULL},
{N_("/_Message/Compose a news message"), NULL, compose_news_cb, 0, NULL},
- {N_("/_Message/_Reply"), "<control>R", reply_cb, COMPOSE_REPLY, NULL},
+ {N_("/_Message/_Reply"), "<control>R", main_window_reply_cb, COMPOSE_REPLY, NULL},
{N_("/_Message/Repl_y to"), NULL, NULL, 0, "<Branch>"},
- {N_("/_Message/Repl_y to/_all"), "<shift><control>R", reply_cb, COMPOSE_REPLY_TO_ALL, NULL},
- {N_("/_Message/Repl_y to/_sender"), NULL, reply_cb, COMPOSE_REPLY_TO_SENDER, NULL},
+ {N_("/_Message/Repl_y to/_all"), "<shift><control>R", main_window_reply_cb, COMPOSE_REPLY_TO_ALL, NULL},
+ {N_("/_Message/Repl_y to/_sender"), NULL, main_window_reply_cb, COMPOSE_REPLY_TO_SENDER, NULL},
{N_("/_Message/Repl_y to/mailing _list"),
- "<control>L", reply_cb, COMPOSE_REPLY_TO_LIST, NULL},
- {N_("/_Message/Follow-up and reply to"),NULL, reply_cb, COMPOSE_FOLLOWUP_AND_REPLY_TO, NULL},
+ "<control>L", main_window_reply_cb, COMPOSE_REPLY_TO_LIST, NULL},
+ {N_("/_Message/Follow-up and reply to"),NULL, main_window_reply_cb, COMPOSE_FOLLOWUP_AND_REPLY_TO, NULL},
{N_("/_Message/---"), NULL, NULL, 0, "<Separator>"},
- {N_("/_Message/_Forward"), "<control><alt>F", reply_cb, COMPOSE_FORWARD, NULL},
- {N_("/_Message/Redirect"), NULL, reply_cb, COMPOSE_REDIRECT, NULL},
+ {N_("/_Message/_Forward"), "<control><alt>F", main_window_reply_cb, COMPOSE_FORWARD, NULL},
+ {N_("/_Message/Redirect"), NULL, main_window_reply_cb, COMPOSE_REDIRECT, NULL},
{N_("/_Message/---"), NULL, NULL, 0, "<Separator>"},
{N_("/_Message/Re-_edit"), NULL, reedit_cb, 0, NULL},
{N_("/_Message/---"), NULL, NULL, 0, "<Separator>"},
{N_("/_Tools/_Log window"), "<shift><control>L", log_window_show_cb, 0, NULL},
{N_("/_Configuration"), NULL, NULL, 0, "<Branch>"},
+ {N_("/_Configuration/C_hange current account"),
+ NULL, NULL, 0, "<Branch>"},
+ {N_("/_Configuration/_Preferences for current account..."),
+ NULL, prefs_account_open_cb, 0, NULL},
+ {N_("/_Configuration/Create _new account..."),
+ NULL, new_account_cb, 0, NULL},
+ {N_("/_Configuration/_Edit accounts..."),
+ NULL, account_edit_open, 0, NULL},
+ {N_("/_Configuration/---"), NULL, NULL, 0, "<Separator>"},
{N_("/_Configuration/_Common preferences..."),
NULL, prefs_common_open_cb, 0, NULL},
- {N_("/_Configuration/C_ustomize toolbars"),
- NULL, NULL, 0, "<Branch>"},
- {N_("/_Configuration/C_ustomize toolbars/_Main window..."),
- NULL, prefs_toolbar_cb, TOOLBAR_MAIN, NULL},
- {N_("/_Configuration/C_ustomize toolbars/_Compose window..."),
- NULL, prefs_toolbar_cb, TOOLBAR_COMPOSE, NULL},
- {N_("/_Configuration/C_ustomize toolbars/M_essage view..."),
- NULL, prefs_toolbar_cb, TOOLBAR_MSGVIEW, NULL},
{N_("/_Configuration/_Scoring..."),
NULL, prefs_scoring_open_cb, 0, NULL},
{N_("/_Configuration/_Filtering..."),
NULL, prefs_filtering_open_cb, 0, NULL},
{N_("/_Configuration/_Templates..."), NULL, prefs_template_open_cb, 0, NULL},
{N_("/_Configuration/_Actions..."), NULL, prefs_actions_open_cb, 0, NULL},
- {N_("/_Configuration/---"), NULL, NULL, 0, "<Separator>"},
- {N_("/_Configuration/_Preferences for current account..."),
- NULL, prefs_account_open_cb, 0, NULL},
- {N_("/_Configuration/Create _new account..."),
- NULL, new_account_cb, 0, NULL},
- {N_("/_Configuration/_Edit accounts..."),
- NULL, account_edit_open, 0, NULL},
- {N_("/_Configuration/C_hange current account"),
- NULL, NULL, 0, "<Branch>"},
+ {N_("/_Configuration/_Other Preferences..."), NULL, prefs_open_cb, 0, NULL},
+ {N_("/_Configuration/Plugins..."), NULL, plugins_open_cb, 0, NULL},
{N_("/_Help"), NULL, NULL, 0, "<Branch>"},
{N_("/_Help/_Manual (Local)"), NULL, manual_open_cb, MANUAL_MANUAL_LOCAL, NULL},
GtkWidget *offline_pixmap;
GtkWidget *online_switch;
GtkWidget *offline_switch;
+ GtkTooltips *offline_tip;
+ GtkTooltips *online_tip;
+ GtkTooltips *sel_ac_tip;
FolderView *folderview;
SummaryView *summaryview;
gtk_signal_connect(GTK_OBJECT(window), "delete_event",
GTK_SIGNAL_FUNC(main_window_close_cb), mainwin);
MANAGE_WINDOW_SIGNALS_CONNECT(window);
+ gtk_signal_connect(GTK_OBJECT(window), "focus_in_event",
+ GTK_SIGNAL_FUNC(mainwindow_focus_in_event),
+ mainwin);
gtk_signal_connect(GTK_OBJECT(window), "key_press_event",
GTK_SIGNAL_FUNC(mainwindow_key_pressed), mainwin);
online_pixmap = stock_pixmap_widget(hbox_stat, STOCK_PIXMAP_WORK_ONLINE);
offline_pixmap = stock_pixmap_widget(hbox_stat, STOCK_PIXMAP_WORK_OFFLINE);
+ online_tip = gtk_tooltips_new();
online_switch = gtk_button_new ();
+ gtk_tooltips_set_tip(GTK_TOOLTIPS(online_tip),
+ online_switch, _("Go offline"), NULL);
+ offline_tip = gtk_tooltips_new();
offline_switch = gtk_button_new ();
+ gtk_tooltips_set_tip(GTK_TOOLTIPS(offline_tip),
+ offline_switch, _("Go online"), NULL);
gtk_container_add (GTK_CONTAINER(online_switch), online_pixmap);
gtk_button_set_relief (GTK_BUTTON(online_switch), GTK_RELIEF_NONE);
gtk_signal_connect (GTK_OBJECT(online_switch), "clicked", (GtkSignalFunc)online_switch_clicked, mainwin);
statuslabel = gtk_label_new("");
gtk_box_pack_start(GTK_BOX(hbox_stat), statuslabel, FALSE, FALSE, 0);
+ sel_ac_tip = gtk_tooltips_new();
ac_button = gtk_button_new();
+ gtk_tooltips_set_tip(GTK_TOOLTIPS(sel_ac_tip),
+ ac_button, _("Select account"), NULL);
gtk_button_set_relief(GTK_BUTTON(ac_button), GTK_RELIEF_NONE);
GTK_WIDGET_UNSET_FLAGS(ac_button, GTK_CAN_FOCUS);
gtk_widget_set_usize(ac_button, -1, 1);
summaryview->color_dim.red = summaryview->color_dim.green =
summaryview->color_dim.blue = COLOR_DIM;
- folderview->color_new.red = (guint16)55000;
- folderview->color_new.green = folderview->color_new.blue = 15000;
+ gtkut_convert_int_to_gdk_color(prefs_common.color_new,
+ &folderview->color_new);
gtkut_convert_int_to_gdk_color(prefs_common.tgt_folder_col,
&folderview->color_op);
gtk_widget_hide(GTK_WIDGET(mainwin->summaryview->hbox_search));
- if (prefs_common.show_searchbar)
+ if (prefs_common.show_searchbar) {
gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(mainwin->summaryview->toggle_search), TRUE);
-
+ if (prefs_common.summary_quicksearch_type != S_SEARCH_EXTENDED)
+ gtk_widget_hide(summaryview->search_description);
+ }
/* set account selection menu */
ac_menu = gtk_item_factory_get_widget
/* create actions menu */
update_mainwin_actions_menu(ifactory, mainwin);
+ /* attach accel groups to main window */
+#define ADD_MENU_ACCEL_GROUP_TO_WINDOW(menu,win) \
+ gtk_window_add_accel_group \
+ (GTK_WINDOW(win), \
+ gtk_item_factory_from_widget(menu)->accel_group)
+
+ ADD_MENU_ACCEL_GROUP_TO_WINDOW(summaryview->popupmenu,mainwin->window);
+
+ /* connect the accelerators for equivalent
+ menu items in different menus */
+ menu_connect_identical_items();
+
+
+
/* show main window */
gtk_widget_set_uposition(mainwin->window,
prefs_common.mainwin_x,
mainwin->menu_lock_count = 0;
mainwin->cursor_count = 0;
+ mainwin->progressindicator_hook =
+ hooks_register_hook(PROGRESSINDICATOR_HOOKLIST, mainwindow_progressindicator_hook, mainwin);
+
if (!watch_cursor)
watch_cursor = gdk_cursor_new(GDK_WATCH);
procmsg_empty_trash();
- for (list = folder_get_list(); list != NULL; list = list->next) {
- folder = list->data;
- if (folder && folder->trash) {
- folder_update_item(folder->trash, TRUE);
- }
- }
-
if (mainwin->summaryview->folder_item &&
mainwin->summaryview->folder_item->stype == F_TRASH)
gtk_widget_grab_focus(mainwin->folderview->ctree);
g_free(path);
return;
}
- if (!strcmp(path, "Mail"))
- folder = folder_new(F_MH, _("Mailbox"), path);
- else
- folder = folder_new(F_MH, g_basename(path), path);
+ folder = folder_new(folder_get_class_from_string("mh"),
+ !strcmp(path, "Mail") ? _("Mailbox") : g_basename(path),
+ path);
g_free(path);
- if (folder->create_tree(folder) < 0) {
+ if (folder->class->create_tree(folder) < 0) {
alertpanel_error(_("Creation of the mailbox failed.\n"
"Maybe some files already exist, or you don't have the permission to write there."));
folder_destroy(folder);
return;
}
- /*
- if (!strcmp(path, "Mail"))
- folder = folder_new(F_MBOX, _("Mailbox"), path);
- else
- */
-
- folder = folder_new(F_MBOX, g_basename(path), path);
+ folder = folder_new(folder_get_class_from_string("mbox"),
+ g_basename(path), path);
g_free(path);
- if (folder->create_tree(folder) < 0) {
+ if (folder->class->create_tree(folder) < 0) {
alertpanel_error(_("Creation of the mailbox failed."));
folder_destroy(folder);
return;
if (selection == SUMMARY_SELECTED_SINGLE)
state |= M_SINGLE_TARGET_EXIST;
if (mainwin->summaryview->folder_item &&
- mainwin->summaryview->folder_item->folder->type == F_NEWS)
+ mainwin->summaryview->folder_item->folder->class->type == F_NEWS)
state |= M_NEWS;
else
state |= M_NOT_NEWS;
menu_path = "/View/Sort/by color label"; break;
case SORT_BY_MARK:
menu_path = "/View/Sort/by mark"; break;
- case SORT_BY_UNREAD:
- menu_path = "/View/Sort/by unread"; break;
+ case SORT_BY_STATUS:
+ menu_path = "/View/Sort/by status"; break;
case SORT_BY_MIME:
menu_path = "/View/Sort/by attachment"; break;
case SORT_BY_SCORE:
toolbar_toggle(action, mainwin);
}
-/* END Toolbar Stuff */
+void main_window_reply_cb(MainWindow *mainwin, guint action,
+ GtkWidget *widget)
+{
+ MessageView *msgview = (MessageView*)mainwin->messageview;
+ GSList *msginfo_list = NULL;
+ gchar *body;
+
+ g_return_if_fail(msgview != NULL);
+
+ msginfo_list = summary_get_selection(mainwin->summaryview);
+ g_return_if_fail(msginfo_list != NULL);
+
+ body = messageview_get_selection(msgview);
+ compose_reply_mode((ComposeMode)action, msginfo_list, body);
+ g_free(body);
+ g_slist_free(msginfo_list);
+}
+
static void toggle_statusbar_cb(MainWindow *mainwin, guint action,
GtkWidget *widget)
selective_download(mainwin);
}
-static void prefs_toolbar_cb(MainWindow *mainwin, guint action,
- GtkWidget *widget)
-{
- prefs_toolbar_open((ToolbarType)action);
-}
-
static void inc_cancel_cb(MainWindow *mainwin, guint action, GtkWidget *widget)
{
inc_cancel_all();
main_window_reflect_prefs_all();
}
+static void prefs_open_cb(GtkMenuItem *menuitem, gpointer data)
+{
+ prefs_gtk_open();
+}
+
+static void plugins_open_cb(GtkMenuItem *menuitem, gpointer data)
+{
+ pluginwindow_create();
+}
+
static void manual_open_cb(MainWindow *mainwin, guint action,
GtkWidget *widget)
{
g_free(str);
}
+static gboolean mainwindow_focus_in_event(GtkWidget *widget, GdkEventFocus *focus,
+ gpointer data)
+{
+ SummaryView *summary;
+
+ g_return_val_if_fail(data, FALSE);
+ summary = ((MainWindow *)data)->summaryview;
+ g_return_val_if_fail(summary, FALSE);
+ if (summary->selected != summary->displayed)
+ summary_select_node(summary, summary->displayed, FALSE, TRUE);
+ return FALSE;
+}
+
#define BREAK_ON_MODIFIER_KEY() \
if ((event->state & (GDK_MOD1_MASK|GDK_CONTROL_MASK)) != 0) break
summary_harvest_address( mainwin->summaryview );
}
+/*!
+ *\brief get a MainWindow
+ *
+ *\return MainWindow * The first mainwindow in the mainwin_list
+ */
+MainWindow *mainwindow_get_mainwindow(void)
+{
+ if (mainwin_list && mainwin_list->data)
+ return (MainWindow *)(mainwin_list->data);
+ else
+ return NULL;
+}
+
+gboolean mainwindow_progressindicator_hook(gpointer source, gpointer userdata)
+{
+ ProgressData *data = (ProgressData *) source;
+ MainWindow *mainwin = (MainWindow *) userdata;
+
+ switch (data->cmd) {
+ case PROGRESS_COMMAND_START:
+ case PROGRESS_COMMAND_STOP:
+ gtk_progress_set_percentage(GTK_PROGRESS(mainwin->progressbar), 0.0);
+ break;
+ case PROGRESS_COMMAND_SET_PERCENTAGE:
+ gtk_progress_set_percentage(GTK_PROGRESS(mainwin->progressbar), data->value);
+ break;
+ }
+ while (gtk_events_pending()) gtk_main_iteration ();
+
+ return FALSE;
+}
+
/*
* End of Source.
*/