/*
* Sylpheed -- a GTK+ based, lightweight, and fast e-mail client
- * Copyright (C) 1999-2006 Hiroyuki Yamamoto and the Claws Mail team
+ * 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
static GdkCursor *watch_cursor = NULL;
static GdkCursor *hand_cursor = NULL;
+static gint iconified_count = 0;
+
static void main_window_menu_callback_block (MainWindow *mainwin);
static void main_window_menu_callback_unblock (MainWindow *mainwin);
static void main_window_show_cur_account (MainWindow *mainwin);
+static void main_window_separation_change (MainWindow *mainwin,
+ LayoutType layout_mode);
+
static void main_window_set_widgets (MainWindow *mainwin,
- SeparateType type);
+ LayoutType layout_mode);
static void toolbar_child_attached (GtkWidget *widget,
GtkWidget *child,
static gint main_window_close_cb (GtkWidget *widget,
GdkEventAny *event,
gpointer data);
-static gint folder_window_close_cb (GtkWidget *widget,
- GdkEventAny *event,
- gpointer data);
-static gint message_window_close_cb (GtkWidget *widget,
- GdkEventAny *event,
- gpointer data);
static void main_window_size_allocate_cb (GtkWidget *widget,
GtkAllocation *allocation,
guint action,
GtkWidget *widget);
-static void toggle_folder_cb (MainWindow *mainwin,
- guint action,
- GtkWidget *widget);
static void toggle_message_cb (MainWindow *mainwin,
guint action,
GtkWidget *widget);
static void toggle_statusbar_cb (MainWindow *mainwin,
guint action,
GtkWidget *widget);
-static void separate_widget_cb (MainWindow *mainwin,
+static void set_layout_cb (MainWindow *mainwin,
guint action,
GtkWidget *widget);
static void log_window_show_cb (MainWindow *mainwin,
guint action,
GtkWidget *widget);
+static void filtering_debug_window_show_cb (MainWindow *mainwin,
+ guint action,
+ GtkWidget *widget);
static void inc_cancel_cb (MainWindow *mainwin,
guint action,
static void select_thread_cb (MainWindow *mainwin,
guint action,
GtkWidget *widget);
+static void delete_thread_cb (MainWindow *mainwin,
+ guint action,
+ GtkWidget *widget);
static void create_filter_cb (MainWindow *mainwin,
guint action,
static void create_processing_cb (MainWindow *mainwin,
guint action,
GtkWidget *widget);
+static void open_urls_cb (MainWindow *mainwin,
+ guint action,
+ GtkWidget *widget);
static void prefs_template_open_cb (MainWindow *mainwin,
guint action,
static gboolean mainwindow_focus_in_event (GtkWidget *widget,
GdkEventFocus *focus,
gpointer data);
-void main_window_reply_cb (MainWindow *mainwin,
+static gboolean mainwindow_visibility_event_cb (GtkWidget *widget,
+ GdkEventVisibility *state,
+ gpointer data);
+static gboolean mainwindow_state_event_cb (GtkWidget *widget,
+ GdkEventWindowState *state,
+ gpointer data);
+static void main_window_reply_cb (MainWindow *mainwin,
guint action,
GtkWidget *widget);
-gboolean mainwindow_progressindicator_hook (gpointer source,
+static gboolean mainwindow_progressindicator_hook (gpointer source,
gpointer userdata);
static gint mailing_list_create_submenu(GtkItemFactory *ifactory,
static void mainwindow_quicksearch (MainWindow *mainwin,
guint action,
GtkWidget *widget);
+static gboolean any_folder_want_synchronise(void);
static GtkItemFactoryEntry mainwin_entries[] =
{
{N_("/_Edit/_Copy"), "<control>C", copy_cb, 0, NULL},
{N_("/_Edit/Select _all"), "<control>A", allsel_cb, 0, NULL},
{N_("/_Edit/Select _thread"), NULL, select_thread_cb, 0, NULL},
+ {N_("/_Edit/_Delete thread"), NULL, delete_thread_cb, 0, NULL},
{N_("/_Edit/---"), NULL, NULL, 0, "<Separator>"},
{N_("/_Edit/_Find in current message..."),
"<control>F", search_cb, 0, NULL},
{N_("/_Edit/_Quick search"), "slash", mainwindow_quicksearch, 0, NULL},
{N_("/_View"), NULL, NULL, 0, "<Branch>"},
{N_("/_View/Show or hi_de"), NULL, NULL, 0, "<Branch>"},
- {N_("/_View/Show or hi_de/_Folder tree"),
- NULL, toggle_folder_cb, 0, "<ToggleItem>"},
{N_("/_View/Show or hi_de/_Message view"),
"V", toggle_message_cb, 0, "<ToggleItem>"},
{N_("/_View/Show or hi_de/_Toolbar"),
{N_("/_View/Set displayed _columns/in _Message list..."),NULL, set_summary_display_item_cb, 0, NULL},
{N_("/_View/---"), NULL, NULL, 0, "<Separator>"},
- {N_("/_View/Separate f_older tree"), NULL, separate_widget_cb, SEPARATE_FOLDER, "<ToggleItem>"},
- {N_("/_View/Separate _message view"), NULL, separate_widget_cb, SEPARATE_MESSAGE, "<ToggleItem>"},
+ {N_("/_View/La_yout"), NULL, NULL, 0, "<Branch>"},
+ {N_("/_View/Layout/_Standard"), NULL, set_layout_cb, NORMAL_LAYOUT, "<RadioItem>"},
+ {N_("/_View/Layout/_Three columns"), NULL, set_layout_cb, VERTICAL_LAYOUT, "/View/Layout/Standard"},
+ {N_("/_View/Layout/_Wide message"), NULL, set_layout_cb, WIDE_LAYOUT, "/View/Layout/Standard"},
+ {N_("/_View/Layout/W_ide message list"),NULL, set_layout_cb, WIDE_MSGLIST_LAYOUT, "/View/Layout/Standard"},
+ {N_("/_View/Layout/S_mall screen"), NULL, set_layout_cb, SMALL_LAYOUT, "/View/Layout/Standard"},
{N_("/_View/---"), NULL, NULL, 0, "<Separator>"},
{N_("/_View/_Sort"), NULL, NULL, 0, "<Branch>"},
{N_("/_View/_Sort/by _number"), NULL, sort_summary_cb, SORT_BY_NUMBER, "<RadioItem>"},
{N_("/_Tools/C_reate processing rule/by _Subject"),
NULL, create_processing_cb, FILTER_BY_SUBJECT, NULL},
{N_("/_Tools/---"), NULL, NULL, 0, "<Separator>"},
+ {N_("/_Tools/List _URLs..."), "<shift><control>U", open_urls_cb, 0, NULL},
+ {N_("/_Tools/---"), NULL, NULL, 0, "<Separator>"},
{N_("/_Tools/Actio_ns"), NULL, NULL, 0, "<Branch>"},
{N_("/_Tools/---"), NULL, NULL, 0, "<Separator>"},
{N_("/_Tools/Ch_eck for new messages in all folders"),
NULL, ssl_manager_open_cb, 0, NULL},
#endif
{N_("/_Tools/---"), NULL, NULL, 0, "<Separator>"},
- {N_("/_Tools/_Log window"), "<shift><control>L", log_window_show_cb, 0, NULL},
+ {N_("/_Tools/Filtering Log"), NULL, filtering_debug_window_show_cb, 0, NULL},
+ {N_("/_Tools/Protocol _Log"), "<shift><control>L", log_window_show_cb, 0, NULL},
{N_("/_Configuration"), NULL, NULL, 0, "<Branch>"},
{N_("/_Configuration/C_hange current account"),
static gboolean offline_ask_sync = TRUE;
static guint lastkey;
+static gboolean is_obscured = FALSE;
static gboolean main_window_accel_activate (GtkAccelGroup *accelgroup,
GObject *arg1,
g_object_set_data(G_OBJECT(item), "mainwin",
mainwin);
gtk_widget_show(item);
- gtk_widget_add_accelerator(item, "activate",
+ if (i < 9)
+ gtk_widget_add_accelerator(item, "activate",
mainwin->menu_factory->accel_group,
GDK_1+i, GDK_CONTROL_MASK,
GTK_ACCEL_LOCKED | GTK_ACCEL_VISIBLE);
}
-
gtk_widget_show(menu);
gtk_menu_item_set_submenu(GTK_MENU_ITEM(label_menuitem), menu);
mainwin->colorlabel_menu = menu;
gtk_widget_hide(mainwin->warning_btn);
}
-MainWindow *main_window_create(SeparateType type)
+MainWindow *main_window_create()
{
MainWindow *mainwin;
GtkWidget *window;
mainwin = g_new0(MainWindow, 1);
/* main window */
- window = gtk_window_new(GTK_WINDOW_TOPLEVEL);
+ window = gtkut_window_new(GTK_WINDOW_TOPLEVEL, "mainwindow");
gtk_window_set_title(GTK_WINDOW(window), PROG_VERSION);
gtk_window_set_resizable(GTK_WINDOW(window), TRUE);
gtk_widget_hide(offline_switch);
gtk_widget_hide(warning_btn);
+
/* create views */
mainwin->folderview = folderview = folderview_create();
mainwin->summaryview = summaryview = summary_create();
mainwin->messageview = messageview = messageview_create(mainwin);
- mainwin->logwin = log_window_create();
+ /* init log instances data before creating log views */
+ set_log_title(LOG_PROTOCOL, _("Protocol log"));
+ set_log_prefs(LOG_PROTOCOL,
+ &prefs_common.logwin_width,
+ &prefs_common.logwin_height);
+ set_log_title(LOG_DEBUG_FILTERING, _("Filtering/processing debug log"));
+ set_log_prefs(LOG_DEBUG_FILTERING,
+ &prefs_common.filtering_debugwin_width,
+ &prefs_common.filtering_debugwin_height);
+
+ /* setup log windows */
+ mainwin->logwin = log_window_create(LOG_PROTOCOL);
log_window_init(mainwin->logwin);
- log_window_set_clipping(mainwin->logwin, prefs_common.cliplog,
+
+ mainwin->filtering_debugwin = log_window_create(LOG_DEBUG_FILTERING);
+ log_window_set_clipping(mainwin->logwin,
+ prefs_common.cliplog,
prefs_common.loglength);
+ log_window_init(mainwin->filtering_debugwin);
+ log_window_set_clipping(mainwin->filtering_debugwin,
+ prefs_common.filtering_debug_cliplog,
+ prefs_common.filtering_debug_loglength);
+ if (prefs_common.enable_filtering_debug)
+ log_message(LOG_DEBUG_FILTERING, _("filtering log enabled\n"));
+ else
+ log_message(LOG_DEBUG_FILTERING, _("filtering log disabled\n"));
+
folderview->mainwin = mainwin;
folderview->summaryview = summaryview;
messageview->visible = prefs_common.msgview_visible;
- main_window_set_widgets(mainwin, type);
+ main_window_set_widgets(mainwin, prefs_common.layout_mode);
g_signal_connect(G_OBJECT(window), "size_allocate",
G_CALLBACK(main_window_size_allocate_cb),
menu items in different menus */
menu_connect_identical_items();
-
gtk_window_iconify(GTK_WINDOW(mainwin->window));
+ g_signal_connect(G_OBJECT(window), "window_state_event",
+ G_CALLBACK(mainwindow_state_event_cb), mainwin);
+ g_signal_connect(G_OBJECT(window), "visibility_notify_event",
+ G_CALLBACK(mainwindow_visibility_event_cb), mainwin);
+ gtk_widget_add_events(GTK_WIDGET(window), GDK_VISIBILITY_NOTIFY_MASK);
+
+ if (prefs_common.layout_mode == VERTICAL_LAYOUT ||
+ prefs_common.layout_mode == SMALL_LAYOUT) {
+ summary_relayout(mainwin->summaryview);
+ }
+ summary_update_unread(mainwin->summaryview, NULL);
+
gtk_widget_show(mainwin->window);
/* initialize views */
online_switch_clicked (GTK_BUTTON(online_switch), mainwin);
mainwindow_colorlabel_menu_create(mainwin, FALSE);
-
+
return mainwin;
}
g_free(ac_name);
}
-GtkWidget *main_window_get_folder_window(MainWindow *mainwin)
-{
- switch (mainwin->type) {
- case SEPARATE_FOLDER:
- return mainwin->win.sep_folder.folderwin;
- case SEPARATE_BOTH:
- return mainwin->win.sep_both.folderwin;
- default:
- return NULL;
- }
-}
-
-GtkWidget *main_window_get_message_window(MainWindow *mainwin)
-{
- switch (mainwin->type) {
- case SEPARATE_MESSAGE:
- return mainwin->win.sep_message.messagewin;
- case SEPARATE_BOTH:
- return mainwin->win.sep_both.messagewin;
- default:
- return NULL;
- }
-}
-
-void main_window_separation_change(MainWindow *mainwin, SeparateType type)
+static void main_window_separation_change(MainWindow *mainwin, LayoutType layout_mode)
{
GtkWidget *folder_wid = GTK_WIDGET_PTR(mainwin->folderview);
GtkWidget *summary_wid = GTK_WIDGET_PTR(mainwin->summaryview);
- /* GtkWidget *message_wid = GTK_WIDGET_PTR(mainwin->messageview); */
GtkWidget *message_wid = mainwin->messageview->vbox;
- debug_print("Changing window separation type from %d to %d\n",
- mainwin->type, type);
+ if (layout_mode == prefs_common.layout_mode)
+ return;
- if (mainwin->type == type) return;
+ debug_print("Changing window separation type from %d to %d\n",
+ prefs_common.layout_mode, layout_mode);
/* remove widgets from those containers */
gtk_widget_ref(folder_wid);
gtkut_container_remove
(GTK_CONTAINER(message_wid->parent), message_wid);
- /* clean containers */
- switch (mainwin->type) {
- case SEPARATE_NONE:
- gtk_widget_destroy(mainwin->win.sep_none.hpaned);
- break;
- case SEPARATE_FOLDER:
- gtk_widget_destroy(mainwin->win.sep_folder.vpaned);
- gtk_widget_destroy(mainwin->win.sep_folder.folderwin);
- break;
- case SEPARATE_MESSAGE:
- gtk_widget_destroy(mainwin->win.sep_message.hpaned);
- gtk_widget_destroy(mainwin->win.sep_message.messagewin);
- break;
- case SEPARATE_BOTH:
- gtk_widget_destroy(mainwin->win.sep_both.messagewin);
- gtk_widget_destroy(mainwin->win.sep_both.folderwin);
- break;
- }
-
gtk_widget_hide(mainwin->window);
- main_window_set_widgets(mainwin, type);
+ main_window_set_widgets(mainwin, layout_mode);
gtk_widget_show(mainwin->window);
gtk_widget_unref(folder_wid);
gtk_widget_unref(message_wid);
}
+void mainwindow_reset_paned(GtkPaned *paned)
+{
+ gint min, max, mid;
+
+ if (gtk_paned_get_child1(GTK_PANED(paned)))
+ gtk_widget_show(gtk_paned_get_child1(GTK_PANED(paned)));
+ if (gtk_paned_get_child2(GTK_PANED(paned)))
+ gtk_widget_show(gtk_paned_get_child2(GTK_PANED(paned)));
+
+GTK_EVENTS_FLUSH();
+ g_object_get (G_OBJECT(paned),
+ "min-position",
+ &min, NULL);
+ g_object_get (G_OBJECT(paned),
+ "max-position",
+ &max, NULL);
+ mid = (min+max)/2;
+ gtk_paned_set_position(GTK_PANED(paned), mid);
+}
+
+static void mainwin_paned_show_first(GtkPaned *paned)
+{
+ gint max;
+ g_object_get (G_OBJECT(paned),
+ "max-position",
+ &max, NULL);
+
+ if (gtk_paned_get_child1(GTK_PANED(paned)))
+ gtk_widget_show(gtk_paned_get_child1(GTK_PANED(paned)));
+ if (gtk_paned_get_child2(GTK_PANED(paned)))
+ gtk_widget_hide(gtk_paned_get_child2(GTK_PANED(paned)));
+ gtk_paned_set_position(GTK_PANED(paned), max);
+}
+
+static void mainwin_paned_show_last(GtkPaned *paned)
+{
+ gint min;
+ g_object_get (G_OBJECT(paned),
+ "min-position",
+ &min, NULL);
+
+ if (gtk_paned_get_child1(GTK_PANED(paned)))
+ gtk_widget_hide(gtk_paned_get_child1(GTK_PANED(paned)));
+ if (gtk_paned_get_child2(GTK_PANED(paned)))
+ gtk_widget_show(gtk_paned_get_child2(GTK_PANED(paned)));
+ gtk_paned_set_position(GTK_PANED(paned), min);
+}
+
void main_window_toggle_message_view(MainWindow *mainwin)
{
SummaryView *summaryview = mainwin->summaryview;
- union CompositeWin *cwin = &mainwin->win;
- GtkWidget *vpaned = NULL;
+ GtkWidget *ppaned = NULL;
GtkWidget *container = NULL;
- GtkWidget *msgwin = NULL;
-
- switch (mainwin->type) {
- case SEPARATE_NONE:
- vpaned = cwin->sep_none.vpaned;
- container = cwin->sep_none.hpaned;
- break;
- case SEPARATE_FOLDER:
- vpaned = cwin->sep_folder.vpaned;
- container = mainwin->vbox_body;
- break;
- case SEPARATE_MESSAGE:
- msgwin = mainwin->win.sep_message.messagewin;
- break;
- case SEPARATE_BOTH:
- msgwin = mainwin->win.sep_both.messagewin;
+
+ switch (prefs_common.layout_mode) {
+ case NORMAL_LAYOUT:
+ case VERTICAL_LAYOUT:
+ case SMALL_LAYOUT:
+ ppaned = mainwin->vpaned;
+ container = mainwin->hpaned;
+ if (ppaned->parent != NULL) {
+ mainwin->messageview->visible = FALSE;
+ summaryview->displayed = NULL;
+ gtk_widget_ref(ppaned);
+ gtkut_container_remove(GTK_CONTAINER(container), ppaned);
+ gtk_widget_reparent(GTK_WIDGET_PTR(summaryview), container);
+ } else {
+ mainwin->messageview->visible = TRUE;
+ gtk_widget_reparent(GTK_WIDGET_PTR(summaryview), ppaned);
+ gtk_container_add(GTK_CONTAINER(container), ppaned);
+ gtk_widget_unref(ppaned);
+ }
break;
- }
-
- if (msgwin) {
- if (GTK_WIDGET_VISIBLE(msgwin)) {
- gtk_widget_hide(msgwin);
+ case WIDE_LAYOUT:
+ ppaned = mainwin->hpaned;
+ container = mainwin->vpaned;
+ if (mainwin->messageview->vbox->parent != NULL) {
mainwin->messageview->visible = FALSE;
summaryview->displayed = NULL;
+ gtk_widget_ref(mainwin->messageview->vbox);
+ gtkut_container_remove(GTK_CONTAINER(container), mainwin->messageview->vbox);
} else {
- gtk_widget_show(msgwin);
mainwin->messageview->visible = TRUE;
+ gtk_container_add(GTK_CONTAINER(container), mainwin->messageview->vbox);
+ gtk_widget_unref(mainwin->messageview->vbox);
}
- } else if (vpaned->parent != NULL) {
- mainwin->messageview->visible = FALSE;
- summaryview->displayed = NULL;
- gtk_widget_ref(vpaned);
- gtkut_container_remove(GTK_CONTAINER(container), vpaned);
- gtk_widget_reparent(GTK_WIDGET_PTR(summaryview), container);
- } else {
- mainwin->messageview->visible = TRUE;
- gtk_widget_reparent(GTK_WIDGET_PTR(summaryview), vpaned);
- gtk_container_add(GTK_CONTAINER(container), vpaned);
- gtk_widget_unref(vpaned);
+ break;
+ case WIDE_MSGLIST_LAYOUT:
+ g_warning("can't hide messageview in this wide msglist layout");
+ break;
}
if (messageview_is_visible(mainwin->messageview))
prefs_common.msgview_visible = mainwin->messageview->visible;
+ if (messageview_is_visible(mainwin->messageview)) {
+ gtk_widget_queue_resize(mainwin->hpaned);
+ gtk_widget_queue_resize(mainwin->vpaned);
+ }
summary_grab_focus(summaryview);
}
if (allocation->width > 1 && allocation->height > 1) {
prefs_common.summaryview_width = allocation->width;
- if ((mainwin->type == SEPARATE_NONE ||
- mainwin->type == SEPARATE_FOLDER) &&
- messageview_is_visible(mainwin->messageview))
+ if (messageview_is_visible(mainwin->messageview))
prefs_common.summaryview_height = allocation->height;
prefs_common.mainview_width = allocation->width;
void main_window_get_position(MainWindow *mainwin)
{
gint x, y;
- GtkWidget *window;
gtkut_widget_get_uposition(mainwin->window, &x, &y);
prefs_common.mainwin_y = y;
debug_print("main window position: %d, %d\n", x, y);
-
- window = main_window_get_folder_window(mainwin);
- if (window) {
- gtkut_widget_get_uposition(window, &x, &y);
- prefs_common.folderwin_x = x;
- prefs_common.folderwin_y = y;
- debug_print("folder window position: %d, %d\n", x, y);
- }
- window = main_window_get_message_window(mainwin);
- if (window) {
- gtkut_widget_get_uposition(window, &x, &y);
- prefs_common.main_msgwin_x = x;
- prefs_common.main_msgwin_y = y;
- debug_print("message window position: %d, %d\n", x, y);
- }
}
void main_window_progress_on(MainWindow *mainwin)
void main_window_empty_trash(MainWindow *mainwin, gboolean confirm)
{
- if (confirm) {
+ if (confirm && procmsg_have_trashed_mails_fast()) {
if (alertpanel(_("Empty trash"),
_("Delete all messages in trash folders?"),
- GTK_STOCK_CANCEL, _("+_Empty trash"), NULL)
+ GTK_STOCK_NO, "+" GTK_STOCK_YES, NULL)
!= G_ALERTALTERNATE)
return;
manage_window_focus_in(mainwin->window, NULL, NULL);
path = input_dialog(_("Add mailbox"),
_("Input the location of mailbox.\n"
- "If the existing mailbox is specified, it will be\n"
+ "If an existing mailbox is specified, it will be\n"
"scanned automatically."),
"Mail");
if (!path) return;
if (cur_account)
state |= M_HAVE_ACCOUNT;
+ if (any_folder_want_synchronise())
+ state |= M_WANT_SYNC;
+
for ( ; account_list != NULL; account_list = account_list->next) {
if (((PrefsAccount*)account_list->data)->protocol == A_NNTP) {
state |= M_HAVE_NEWS_ACCOUNT;
}
}
- if (procmsg_spam_can_learn()) {
+ if (procmsg_spam_can_learn() &&
+ (mainwin->summaryview->folder_item &&
+ mainwin->summaryview->folder_item->folder->klass->type != F_UNKNOWN &&
+ mainwin->summaryview->folder_item->folder->klass->type != F_NEWS)) {
state |= M_CAN_LEARN_SPAM;
}
if (inc_is_active())
state |= M_INC_ACTIVE;
+ if (imap_cancel_all_enabled())
+ state |= M_INC_ACTIVE;
if (mainwin->summaryview->deleted > 0 ||
mainwin->summaryview->moved > 0 ||
} entry[] = {
{"/File/Save as...", M_TARGET_EXIST},
{"/File/Print..." , M_TARGET_EXIST},
+ {"/File/Synchronise folders", M_WANT_SYNC},
{"/File/Exit" , M_UNLOCKED},
- {"/Edit/Select thread" , M_SINGLE_TARGET_EXIST},
+ {"/Edit/Select thread" , M_TARGET_EXIST},
+ {"/Edit/Delete thread" , M_TARGET_EXIST},
{"/Edit/Find in current message...", M_SINGLE_TARGET_EXIST},
+ {"/View/Set displayed columns/in Folder list..."
+ , M_UNLOCKED},
{"/View/Sort" , M_EXEC},
{"/View/Thread view" , M_EXEC},
{"/View/Expand all threads" , M_MSG_EXIST},
{"/Tools/Filter selected messages" , M_TARGET_EXIST|M_EXEC},
{"/Tools/Create filter rule" , M_SINGLE_TARGET_EXIST|M_UNLOCKED},
{"/Tools/Create processing rule" , M_SINGLE_TARGET_EXIST|M_UNLOCKED},
+ {"/Tools/List URLs..." , M_TARGET_EXIST},
{"/Tools/Actions" , M_TARGET_EXIST|M_ACTIONS_EXIST},
{"/Tools/Execute" , M_DELAY_EXEC},
{"/Tools/Delete duplicated messages/In selected folder" , M_MSG_EXIST|M_ALLOW_DELETE},
{"/Configuration", M_UNLOCKED},
+ {"/Configuration/Preferences for current account...", M_UNLOCKED},
+ {"/Configuration/Create new account...", M_UNLOCKED},
+ {"/Configuration/Edit accounts...", M_UNLOCKED},
{NULL, 0}
};
const gchar *buf;
gint i = 0;
buf = *buffer;
-
+ gboolean with_plus = TRUE;
+
if (buf == 0x00) {
*url_decoded = '\0';
*buffer = NULL;
/* First non space and non comment must be a < */
if (*buf =='<' ) {
buf++;
+ if (!strncmp(buf, "mailto:", strlen("mailto:")))
+ with_plus = FALSE;
for (i = 0; *buf != '>' && *buf != 0x00 && i<maxlen; tmp[i++] = *(buf++));
buf++;
}
if (i == maxlen) {
return;
}
- decode_uri (url_decoded, (const gchar *)tmp);
+ decode_uri_with_plus (url_decoded, (const gchar *)tmp, with_plus);
/* Prepare the work for the next url in the list */
/* after the closing bracket >, ignore space, comments and tabs */
main_window_show(mainwin);
gtkut_window_popup(mainwin->window);
-
- switch (mainwin->type) {
- case SEPARATE_FOLDER:
- gtkut_window_popup(mainwin->win.sep_folder.folderwin);
- break;
- case SEPARATE_MESSAGE:
- gtkut_window_popup(mainwin->win.sep_message.messagewin);
- break;
- case SEPARATE_BOTH:
- gtkut_window_popup(mainwin->win.sep_both.folderwin);
- gtkut_window_popup(mainwin->win.sep_both.messagewin);
- break;
- default:
- break;
+ if (prefs_common.layout_mode == SMALL_LAYOUT) {
+ if (mainwin->in_folder) {
+ mainwindow_enter_folder(mainwin);
+ } else {
+ mainwindow_exit_folder(mainwin);
+ }
}
}
gtk_widget_set_size_request(GTK_WIDGET_PTR(mainwin->messageview),
prefs_common.msgview_width,
prefs_common.msgview_height);
-
- if (mainwin->type & SEPARATE_FOLDER) {
- GtkWidget *folderwin;
-
- folderwin = main_window_get_folder_window(mainwin);
- gtk_widget_show(folderwin);
- gtk_widget_set_uposition(folderwin, prefs_common.folderwin_x,
- prefs_common.folderwin_y);
- }
-
- if (mainwin->type & SEPARATE_MESSAGE) {
- GtkWidget *messagewin;
-
- messagewin = main_window_get_message_window(mainwin);
- gtk_widget_show(messagewin);
- gtk_widget_set_uposition(messagewin, prefs_common.main_msgwin_x,
- prefs_common.main_msgwin_y);
- }
}
void main_window_hide(MainWindow *mainwin)
gtk_widget_hide(mainwin->window);
gtk_widget_hide(mainwin->vbox_body);
-
- if (mainwin->type & SEPARATE_FOLDER) {
- gtk_widget_hide(mainwin->win.sep_folder.folderwin);
- }
-
- if (mainwin->type & SEPARATE_MESSAGE) {
- gtk_widget_hide(mainwin->win.sep_message.messagewin);
- }
}
-static void main_window_set_widgets(MainWindow *mainwin, SeparateType type)
+static void main_window_set_widgets(MainWindow *mainwin, LayoutType layout_mode)
{
GtkWidget *folderwin = NULL;
GtkWidget *messagewin = NULL;
GtkWidget *vbox_body = mainwin->vbox_body;
GtkItemFactory *ifactory = mainwin->menu_factory;
GtkWidget *menuitem;
- GtkItemFactory *msgview_ifactory;
-
+ gboolean first_set = (mainwin->hpaned == NULL);
debug_print("Setting widgets... ");
- gtk_widget_set_size_request(GTK_WIDGET_PTR(mainwin->folderview),
+ if (layout_mode == SMALL_LAYOUT && first_set) {
+ gtk_widget_set_size_request(GTK_WIDGET_PTR(mainwin->folderview),
prefs_common.folderview_width,
prefs_common.folderview_height);
- gtk_widget_set_size_request(GTK_WIDGET_PTR(mainwin->summaryview),
+ gtk_widget_set_size_request(GTK_WIDGET_PTR(mainwin->summaryview),
+ 0,0);
+ gtk_widget_set_size_request(GTK_WIDGET_PTR(mainwin->messageview),
+ 0,0);
+ } else {
+ gtk_widget_set_size_request(GTK_WIDGET_PTR(mainwin->folderview),
+ prefs_common.folderview_width,
+ prefs_common.folderview_height);
+ gtk_widget_set_size_request(GTK_WIDGET_PTR(mainwin->summaryview),
prefs_common.summaryview_width,
prefs_common.summaryview_height);
- gtk_widget_set_size_request(GTK_WIDGET_PTR(mainwin->messageview),
+ gtk_widget_set_size_request(GTK_WIDGET_PTR(mainwin->messageview),
prefs_common.msgview_width,
prefs_common.msgview_height);
-
- /* create separated window(s) if needed */
- if (type & SEPARATE_FOLDER) {
- static GdkGeometry folderwin_geometry;
-
- folderwin = gtk_window_new(GTK_WINDOW_TOPLEVEL);
- gtk_window_set_title(GTK_WINDOW(folderwin),
- _("Claws Mail - Folder View"));
-
- gtk_window_move(GTK_WINDOW(folderwin),
- prefs_common.folderwin_x,
- prefs_common.folderwin_y);
-
- if (!folderwin_geometry.min_height) {
- folderwin_geometry.min_width = 320;
- folderwin_geometry.min_height = 200;
- }
- gtk_window_set_geometry_hints(GTK_WINDOW(folderwin), NULL,
- &folderwin_geometry, GDK_HINT_MIN_SIZE);
-
- gtk_widget_set_size_request(folderwin,
- prefs_common.folderview_width,
- prefs_common.folderview_height);
-
- gtk_container_set_border_width(GTK_CONTAINER(folderwin),
- BORDER_WIDTH);
-
- g_signal_connect(G_OBJECT(folderwin), "delete_event",
- G_CALLBACK(folder_window_close_cb),
- mainwin);
- gtk_container_add(GTK_CONTAINER(folderwin),
- GTK_WIDGET_PTR(mainwin->folderview));
- gtk_widget_realize(folderwin);
-
- if (prefs_common.folderview_visible)
- gtk_widget_show(folderwin);
}
- if (type & SEPARATE_MESSAGE) {
- static GdkGeometry msgwin_geometry;
-
- messagewin = gtk_window_new(GTK_WINDOW_TOPLEVEL);
- gtk_window_set_title(GTK_WINDOW(messagewin),
- _("Claws Mail - Message View"));
-
- gtk_window_move(GTK_WINDOW(messagewin),
- prefs_common.main_msgwin_x,
- prefs_common.main_msgwin_y);
-
- if (!msgwin_geometry.min_height) {
- msgwin_geometry.min_width = 320;
- msgwin_geometry.min_height = 200;
- }
- gtk_window_set_geometry_hints(GTK_WINDOW(messagewin), NULL,
- &msgwin_geometry, GDK_HINT_MIN_SIZE);
-
- gtk_widget_set_size_request(messagewin,
- prefs_common.msgwin_width,
- prefs_common.msgwin_height);
-
- gtk_container_set_border_width(GTK_CONTAINER(messagewin),
- BORDER_WIDTH);
- g_signal_connect(G_OBJECT(messagewin), "delete_event",
- G_CALLBACK(message_window_close_cb),
- mainwin);
- if (messageview_is_visible(mainwin->messageview))
- gtk_widget_show(messagewin);
- } else {
- mainwin->messageview->statusbar = mainwin->statusbar;
- mainwin->messageview->statusbar_cid = mainwin->messageview_cid;
+ mainwin->messageview->statusbar = mainwin->statusbar;
+ mainwin->messageview->statusbar_cid = mainwin->messageview_cid;
+
+ /* clean top-most container */
+ if (mainwin->hpaned) {
+ if (mainwin->hpaned->parent == mainwin->vpaned)
+ gtk_widget_destroy(mainwin->vpaned);
+ else
+ gtk_widget_destroy(mainwin->hpaned);
}
- switch (type) {
- case SEPARATE_NONE:
+ menu_set_sensitive(ifactory, "/View/Show or hide/Message view",
+ (layout_mode != WIDE_MSGLIST_LAYOUT && layout_mode != SMALL_LAYOUT));
+ switch (layout_mode) {
+ case VERTICAL_LAYOUT:
+ case NORMAL_LAYOUT:
+ case SMALL_LAYOUT:
hpaned = gtk_hpaned_new();
+ if (layout_mode == VERTICAL_LAYOUT)
+ vpaned = gtk_hpaned_new();
+ else
+ vpaned = gtk_vpaned_new();
gtk_box_pack_start(GTK_BOX(vbox_body), hpaned, TRUE, TRUE, 0);
gtk_paned_add1(GTK_PANED(hpaned),
GTK_WIDGET_PTR(mainwin->folderview));
gtk_widget_show(hpaned);
gtk_widget_queue_resize(hpaned);
- vpaned = gtk_vpaned_new();
if (messageview_is_visible(mainwin->messageview)) {
gtk_paned_add2(GTK_PANED(hpaned), vpaned);
gtk_paned_add1(GTK_PANED(vpaned),
gtk_paned_add2(GTK_PANED(vpaned),
GTK_WIDGET_PTR(mainwin->messageview));
gtk_widget_show(vpaned);
+ if (layout_mode == SMALL_LAYOUT && first_set) {
+ mainwin_paned_show_first(GTK_PANED(hpaned));
+ }
gtk_widget_queue_resize(vpaned);
-
- mainwin->win.sep_none.hpaned = hpaned;
- mainwin->win.sep_none.vpaned = vpaned;
-
- /* remove headerview if not in prefs */
- headerview_set_visibility(mainwin->messageview->headerview,
- prefs_common.display_header_pane);
break;
- case SEPARATE_FOLDER:
+ case WIDE_LAYOUT:
vpaned = gtk_vpaned_new();
+ hpaned = gtk_hpaned_new();
+ gtk_box_pack_start(GTK_BOX(vbox_body), vpaned, TRUE, TRUE, 0);
+ gtk_paned_add1(GTK_PANED(vpaned), hpaned);
+
+ gtk_paned_add1(GTK_PANED(hpaned),
+ GTK_WIDGET_PTR(mainwin->folderview));
+ gtk_paned_add2(GTK_PANED(hpaned),
+ GTK_WIDGET_PTR(mainwin->summaryview));
+
+ gtk_widget_show(hpaned);
+ gtk_widget_queue_resize(hpaned);
+
if (messageview_is_visible(mainwin->messageview)) {
- gtk_box_pack_start(GTK_BOX(vbox_body), vpaned,
- TRUE, TRUE, 0);
- gtk_paned_add1(GTK_PANED(vpaned),
- GTK_WIDGET_PTR(mainwin->summaryview));
+ gtk_paned_add2(GTK_PANED(vpaned),
+ GTK_WIDGET_PTR(mainwin->messageview));
} else {
- gtk_box_pack_start(GTK_BOX(vbox_body),
- GTK_WIDGET_PTR(mainwin->summaryview),
- TRUE, TRUE, 0);
- gtk_widget_ref(vpaned);
+ gtk_widget_ref(GTK_WIDGET_PTR(mainwin->messageview));
}
- gtk_paned_add2(GTK_PANED(vpaned),
- GTK_WIDGET_PTR(mainwin->messageview));
gtk_widget_show(vpaned);
gtk_widget_queue_resize(vpaned);
-
- mainwin->win.sep_folder.folderwin = folderwin;
- mainwin->win.sep_folder.vpaned = vpaned;
-
- /* remove headerview if not in prefs */
- headerview_set_visibility(mainwin->messageview->headerview,
- prefs_common.display_header_pane);
-
break;
- case SEPARATE_MESSAGE:
+ case WIDE_MSGLIST_LAYOUT:
+ vpaned = gtk_vpaned_new();
hpaned = gtk_hpaned_new();
- gtk_box_pack_start(GTK_BOX(vbox_body), hpaned, TRUE, TRUE, 0);
+ gtk_box_pack_start(GTK_BOX(vbox_body), vpaned, TRUE, TRUE, 0);
+
+ gtk_paned_add1(GTK_PANED(vpaned),
+ GTK_WIDGET_PTR(mainwin->summaryview));
gtk_paned_add1(GTK_PANED(hpaned),
GTK_WIDGET_PTR(mainwin->folderview));
- gtk_paned_add2(GTK_PANED(hpaned),
- GTK_WIDGET_PTR(mainwin->summaryview));
+
gtk_widget_show(hpaned);
gtk_widget_queue_resize(hpaned);
- messageview_add_toolbar(mainwin->messageview, messagewin);
- msgview_ifactory = gtk_item_factory_from_widget(mainwin->messageview->menubar);
- menu_set_sensitive(msgview_ifactory, "/File/Close", FALSE);
- mainwin->win.sep_message.messagewin = messagewin;
- mainwin->win.sep_message.hpaned = hpaned;
+ if (messageview_is_visible(mainwin->messageview)) {
+ gtk_paned_add2(GTK_PANED(hpaned),
+ GTK_WIDGET_PTR(mainwin->messageview));
+ } else {
+ gtk_widget_ref(GTK_WIDGET_PTR(mainwin->messageview));
+ }
+ gtk_paned_add2(GTK_PANED(vpaned), hpaned);
- gtk_widget_realize(messagewin);
- gtk_widget_show_all(GTK_WIDGET_PTR(mainwin->messageview));
- gtk_widget_show_all(messagewin);
- toolbar_set_style(mainwin->messageview->toolbar->toolbar,
- mainwin->messageview->handlebox,
- prefs_common.toolbar_style);
+ gtk_widget_show(vpaned);
+ gtk_widget_queue_resize(vpaned);
+ break;
+ default:
+ g_warning("Unknown layout");
+ return;
+ }
- /* remove headerview if not in prefs */
- headerview_set_visibility(mainwin->messageview->headerview,
- prefs_common.display_header_pane);
+ mainwin->hpaned = hpaned;
+ mainwin->vpaned = vpaned;
- break;
- case SEPARATE_BOTH:
- messageview_add_toolbar(mainwin->messageview, messagewin);
- msgview_ifactory = gtk_item_factory_from_widget(mainwin->messageview->menubar);
- menu_set_sensitive(msgview_ifactory, "/File/Close", FALSE);
-
- gtk_box_pack_start(GTK_BOX(vbox_body),
- GTK_WIDGET_PTR(mainwin->summaryview),
- TRUE, TRUE, 0);
-
- mainwin->win.sep_both.folderwin = folderwin;
- mainwin->win.sep_both.messagewin = messagewin;
-
- gtk_widget_realize(messagewin);
- gtk_widget_show_all(GTK_WIDGET_PTR(mainwin->messageview));
- gtk_widget_show_all(messagewin);
- toolbar_set_style(mainwin->messageview->toolbar->toolbar,
- mainwin->messageview->handlebox,
- prefs_common.toolbar_style);
-
- /* remove headerview if not in prefs */
- headerview_set_visibility(mainwin->messageview->headerview,
- prefs_common.display_header_pane);
+ if (layout_mode == SMALL_LAYOUT) {
+ if (mainwin->messageview->visible)
+ main_window_toggle_message_view(mainwin);
+ }
- break;
- }
+ if (layout_mode == SMALL_LAYOUT && first_set) {
+ gtk_widget_realize(mainwin->window);
+ gtk_widget_realize(mainwin->folderview->ctree);
+ gtk_widget_realize(mainwin->summaryview->hbox);
+ gtk_widget_realize(mainwin->summaryview->hbox_l);
+ gtk_widget_set_size_request(GTK_WIDGET_PTR(mainwin->folderview),
+ prefs_common.folderview_width,
+ prefs_common.folderview_height);
+ gtk_widget_set_size_request(GTK_WIDGET_PTR(mainwin->summaryview),
+ 0,0);
+ gtk_widget_set_size_request(GTK_WIDGET_PTR(mainwin->messageview),
+ 0,0);
+ gtk_widget_set_size_request(GTK_WIDGET(mainwin->window),
+ prefs_common.mainwin_width,
+ prefs_common.mainwin_height);
+ gtk_paned_set_position(GTK_PANED(mainwin->hpaned), 800);
+ }
+ /* remove headerview if not in prefs */
+ headerview_set_visibility(mainwin->messageview->headerview,
+ prefs_common.display_header_pane);
if (messageview_is_visible(mainwin->messageview))
gtk_arrow_set(GTK_ARROW(mainwin->summaryview->toggle_arrow),
else
gtk_widget_hide(mainwin->messageview->mimeview->ctree_mainbox);
- mainwin->type = type;
-
+ prefs_common.layout_mode = layout_mode;
- /* toggle menu state */
- menuitem = gtk_item_factory_get_item
- (ifactory, "/View/Show or hide/Folder tree");
- gtk_check_menu_item_set_active(GTK_CHECK_MENU_ITEM(menuitem),
- (type & SEPARATE_FOLDER) == 0 ? TRUE :
- prefs_common.folderview_visible);
- gtk_widget_set_sensitive(menuitem, ((type & SEPARATE_FOLDER) != 0));
menuitem = gtk_item_factory_get_item
(ifactory, "/View/Show or hide/Message view");
gtk_check_menu_item_set_active
(GTK_CHECK_MENU_ITEM(menuitem),
messageview_is_visible(mainwin->messageview));
- menuitem = gtk_item_factory_get_item
- (ifactory, "/View/Separate folder tree");
- gtk_check_menu_item_set_active(GTK_CHECK_MENU_ITEM(menuitem),
- ((type & SEPARATE_FOLDER) != 0));
- menuitem = gtk_item_factory_get_item
- (ifactory, "/View/Separate message view");
- gtk_check_menu_item_set_active(GTK_CHECK_MENU_ITEM(menuitem),
- ((type & SEPARATE_MESSAGE) != 0));
+#define SET_CHECK_MENU_ACTIVE(path, active) \
+{ \
+ menuitem = gtk_item_factory_get_widget(ifactory, path); \
+ gtk_check_menu_item_set_active(GTK_CHECK_MENU_ITEM(menuitem), active); \
+}
+
+ switch (prefs_common.layout_mode) {
+ case NORMAL_LAYOUT:
+ SET_CHECK_MENU_ACTIVE("/View/Layout/Standard", TRUE);
+ break;
+ case VERTICAL_LAYOUT:
+ SET_CHECK_MENU_ACTIVE("/View/Layout/Three columns", TRUE);
+ break;
+ case WIDE_LAYOUT:
+ SET_CHECK_MENU_ACTIVE("/View/Layout/Wide message", TRUE);
+ break;
+ case WIDE_MSGLIST_LAYOUT:
+ SET_CHECK_MENU_ACTIVE("/View/Layout/Wide message list", TRUE);
+ break;
+ case SMALL_LAYOUT:
+ SET_CHECK_MENU_ACTIVE("/View/Layout/Small screen", TRUE);
+ break;
+ }
+#undef SET_CHECK_MENU_ACTIVE
if (folderwin) {
g_signal_connect
gpointer data)
{
MainWindow *mainwin = (MainWindow *)data;
+ gboolean close_allowed = TRUE;
- if (mainwin->lock_count == 0)
- app_exit_cb(data, 0, widget);
+ hooks_invoke(MAIN_WINDOW_CLOSE, &close_allowed);
- return TRUE;
-}
-
-static gint folder_window_close_cb(GtkWidget *widget, GdkEventAny *event,
- gpointer data)
-{
- MainWindow *mainwin = (MainWindow *)data;
- GtkWidget *menuitem;
-
- menuitem = gtk_item_factory_get_item
- (mainwin->menu_factory, "/View/Show or hide/Folder tree");
- gtk_check_menu_item_set_active(GTK_CHECK_MENU_ITEM(menuitem), FALSE);
-
- return TRUE;
-}
-
-static gint message_window_close_cb(GtkWidget *widget, GdkEventAny *event,
- gpointer data)
-{
- MainWindow *mainwin = (MainWindow *)data;
- GtkWidget *menuitem;
-
- menuitem = gtk_item_factory_get_item
- (mainwin->menu_factory, "/View/Show or hide/Message view");
- gtk_check_menu_item_set_active(GTK_CHECK_MENU_ITEM(menuitem), FALSE);
-
- mainwin->messageview->statusbar = mainwin->statusbar;
- mainwin->messageview->statusbar_cid = mainwin->messageview_cid;
+ if (close_allowed && mainwin->lock_count == 0)
+ app_exit_cb(data, 0, widget);
return TRUE;
}
gpointer data)
{
MainWindow *mainwin = (MainWindow *)data;
-
main_window_get_size(mainwin);
}
static void mainwindow_quicksearch(MainWindow *mainwin, guint action, GtkWidget *widget)
{
- prefs_common.show_searchbar = TRUE;
- summaryview_activate_quicksearch(mainwin->summaryview);
-}
-
-static void toggle_folder_cb(MainWindow *mainwin, guint action,
- GtkWidget *widget)
-{
- gboolean active;
-
- active = GTK_CHECK_MENU_ITEM(widget)->active;
-
- switch (mainwin->type) {
- case SEPARATE_NONE:
- case SEPARATE_MESSAGE:
- break;
- case SEPARATE_FOLDER:
- debug_print("separate folder\n");
- if (active)
- gtk_widget_show(mainwin->win.sep_folder.folderwin);
- else
- gtk_widget_hide(mainwin->win.sep_folder.folderwin);
- break;
- case SEPARATE_BOTH:
- if (active)
- gtk_widget_show(mainwin->win.sep_both.folderwin);
- else
- gtk_widget_hide(mainwin->win.sep_both.folderwin);
- break;
- }
-
- prefs_common.folderview_visible = active;
+ summaryview_activate_quicksearch(mainwin->summaryview, TRUE);
}
static void toggle_message_cb(MainWindow *mainwin, guint action,
toolbar_toggle(action, mainwin);
}
-void main_window_reply_cb(MainWindow *mainwin, guint action,
+static void main_window_reply_cb(MainWindow *mainwin, guint action,
GtkWidget *widget)
{
MessageView *msgview = (MessageView*)mainwin->messageview;
}
}
-static void separate_widget_cb(MainWindow *mainwin, guint action,
+static void set_layout_cb(MainWindow *mainwin, guint action,
GtkWidget *widget)
{
- SeparateType type;
-
- if (GTK_CHECK_MENU_ITEM(widget)->active)
- type = mainwin->type | action;
- else
- type = mainwin->type & ~action;
-
- main_window_separation_change(mainwin, type);
-
- prefs_common.sep_folder = (type & SEPARATE_FOLDER) != 0;
- prefs_common.sep_msg = (type & SEPARATE_MESSAGE) != 0;
+ LayoutType layout_mode = action;
+ LayoutType old_layout_mode = prefs_common.layout_mode;
+ if (mainwin->menu_lock_count) {
+ return;
+ }
+ if (!GTK_CHECK_MENU_ITEM(widget)->active) {
+ return;
+ }
+
+ if (layout_mode == prefs_common.layout_mode) {
+ return;
+ }
+
+ if (!mainwin->messageview->visible && layout_mode != SMALL_LAYOUT)
+ main_window_toggle_message_view(mainwin);
+ else if (mainwin->messageview->visible && layout_mode == SMALL_LAYOUT)
+ main_window_toggle_message_view(mainwin);
+
+ main_window_separation_change(mainwin, layout_mode);
+ mainwindow_reset_paned(GTK_PANED(mainwin->vpaned));
+ if (old_layout_mode == SMALL_LAYOUT && layout_mode != SMALL_LAYOUT) {
+ mainwindow_reset_paned(GTK_PANED(mainwin->hpaned));
+ }
+ if (old_layout_mode != SMALL_LAYOUT && layout_mode == SMALL_LAYOUT) {
+ mainwin_paned_show_first(GTK_PANED(mainwin->hpaned));
+ mainwindow_exit_folder(mainwin);
+ }
+ summary_relayout(mainwin->summaryview);
+ summary_update_unread(mainwin->summaryview, NULL);
}
void main_window_toggle_work_offline (MainWindow *mainwin, gboolean offline,
main_window_toggle_work_offline(mainwin, GTK_CHECK_MENU_ITEM(widget)->active, TRUE);
}
-static void mainwindow_check_synchronise(MainWindow *mainwin, gboolean ask)
+static gboolean any_folder_want_synchronise(void)
{
GList *folderlist = folder_get_list();
- gboolean found = FALSE;
/* see if there are synchronised folders */
for (; folderlist; folderlist = folderlist->next) {
Folder *folder = (Folder *)folderlist->data;
if (folder_want_synchronise(folder)) {
- found = TRUE;
- break;
+ return TRUE;
}
}
- if (!found)
+ return FALSE;
+}
+
+static void mainwindow_check_synchronise(MainWindow *mainwin, gboolean ask)
+{
+
+ if (!any_folder_want_synchronise())
return;
-
+
if (offline_ask_sync && ask && alertpanel(_("Folder synchronisation"),
_("Do you want to synchronise your folders now?"),
GTK_STOCK_CANCEL, _("+_Synchronise"), NULL) != G_ALERTALTERNATE)
return;
-
- folder_synchronise(NULL);
+
+ if (offline_ask_sync)
+ folder_synchronise(NULL);
}
static void online_switch_clicked (GtkButton *btn, gpointer data)
log_window_show(mainwin->logwin);
}
+static void filtering_debug_window_show_cb(MainWindow *mainwin, guint action,
+ GtkWidget *widget)
+{
+ log_window_show(mainwin->filtering_debugwin);
+}
+
static void inc_cancel_cb(MainWindow *mainwin, guint action, GtkWidget *widget)
{
inc_cancel_all();
+ imap_cancel_all();
}
static void move_to_cb(MainWindow *mainwin, guint action, GtkWidget *widget)
summary_reedit(mainwin->summaryview);
}
+static void open_urls_cb(MainWindow *mainwin, guint action, GtkWidget *widget)
+{
+ if (!mainwin->summaryview->displayed && mainwin->summaryview->selected) {
+ summary_display_msg_selected(mainwin->summaryview,
+ mainwin->messageview->mimeview->textview->show_all_headers);
+ }
+ messageview_list_urls(mainwin->messageview);
+}
+
static void add_address_cb(MainWindow *mainwin, guint action,
GtkWidget *widget)
{
static void select_thread_cb(MainWindow *mainwin, guint action,
GtkWidget *widget)
{
- summary_select_thread(mainwin->summaryview);
+ summary_select_thread(mainwin->summaryview, FALSE);
+}
+
+static void delete_thread_cb(MainWindow *mainwin, guint action,
+ GtkWidget *widget)
+{
+ summary_select_thread(mainwin->summaryview, TRUE);
}
static void create_filter_cb(MainWindow *mainwin, guint action,
return FALSE;
}
+static gboolean mainwindow_visibility_event_cb(GtkWidget *widget, GdkEventVisibility *event,
+ gpointer data)
+{
+ is_obscured = (event->state == GDK_VISIBILITY_FULLY_OBSCURED);
+ return FALSE;
+}
+
+static gboolean mainwindow_state_event_cb(GtkWidget *widget, GdkEventWindowState *state,
+ gpointer data)
+{
+ if (!claws_is_starting()
+ && state->changed_mask&GDK_WINDOW_STATE_ICONIFIED
+ && state->new_window_state&GDK_WINDOW_STATE_ICONIFIED) {
+
+ if (iconified_count > 0)
+ hooks_invoke(MAIN_WINDOW_GOT_ICONIFIED, NULL);
+ iconified_count++;
+ }
+ if (state->new_window_state == 0)
+ gtk_window_set_skip_taskbar_hint(GTK_WINDOW(widget), FALSE);
+ return FALSE;
+}
+
+gboolean mainwindow_is_obscured(void)
+{
+ return is_obscured;
+}
+
#define BREAK_ON_MODIFIER_KEY() \
if ((event->state & (GDK_MOD1_MASK|GDK_CONTROL_MASK)) != 0) break
folderview_select_next_unread(mainwin->folderview, TRUE);
}
break;
+#ifdef MAEMO
+ case GDK_F6:
+ if (maemo_mainwindow_is_fullscreen(widget)) {
+ gtk_window_unfullscreen(GTK_WINDOW(widget));
+ } else {
+ gtk_window_fullscreen(GTK_WINDOW(widget));
+ }
+ break;
+#endif
default:
break;
}
return NULL;
}
-gboolean mainwindow_progressindicator_hook(gpointer source, gpointer userdata)
+static gboolean mainwindow_progressindicator_hook(gpointer source, gpointer userdata)
{
ProgressData *data = (ProgressData *) source;
MainWindow *mainwin = (MainWindow *) userdata;
summary_mark_as_spam(mainwin->summaryview, is_spam, NULL);
}
-void mainwindow_jump_to(const gchar *target)
+void mainwindow_jump_to(const gchar *target, gboolean popup)
{
gchar *tmp = NULL;
gchar *p = NULL;
return;
if (!mainwin) {
- printf(_("not initialized\n"));
+ printf("not initialized\n");
return;
}
*p = '\0';
if ((item = folder_find_item_from_identifier(tmp))) {
- printf(_("selecting folder '%s'\n"), tmp);
+ printf("selecting folder '%s'\n", tmp);
folderview_select(mainwin->folderview, item);
- main_window_popup(mainwin);
+ if (popup)
+ main_window_popup(mainwin);
g_free(tmp);
return;
}
if (msg) {
*msg++ = '\0';
if ((item = folder_find_item_from_identifier(tmp))) {
- printf(_("selecting folder '%s'\n"), tmp);
+ printf("selecting folder '%s'\n", tmp);
folderview_select(mainwin->folderview, item);
- }
+ } else {
+ printf("'%s' not found\n", tmp);
+ }
if (item && msg && atoi(msg)) {
- printf(_("selecting message %d\n"), atoi(msg));
+ printf("selecting message %d\n", atoi(msg));
summary_select_by_msgnum(mainwin->summaryview, atoi(msg));
summary_display_msg_selected(mainwin->summaryview, FALSE);
- main_window_popup(mainwin);
+ if (popup)
+ main_window_popup(mainwin);
g_free(tmp);
return;
- }
+ } else if (item && msg[0] == '<' && msg[strlen(msg)-1] == '>') {
+ MsgInfo *msginfo = NULL;
+ msg++;
+ msg[strlen(msg)-1] = '\0';
+ msginfo = folder_item_get_msginfo_by_msgid(item, msg);
+ if (msginfo) {
+ printf("selecting message %s\n", msg);
+ summary_select_by_msgnum(mainwin->summaryview, msginfo->msgnum);
+ summary_display_msg_selected(mainwin->summaryview, FALSE);
+ if (popup)
+ main_window_popup(mainwin);
+ g_free(tmp);
+ procmsg_msginfo_free(msginfo);
+ return;
+ } else {
+ printf("'%s' not found\n", msg);
+ }
+ } else {
+ printf("'%s' not found\n", msg);
+ }
+ } else {
+ printf("'%s' not found\n", tmp);
}
- printf("'%s' not found\n", tmp);
-
g_free(tmp);
}
+
+void mainwindow_exit_folder(MainWindow *mainwin) {
+ if (prefs_common.layout_mode == SMALL_LAYOUT) {
+ folderview_close_opened(mainwin->folderview);
+ mainwin_paned_show_first(GTK_PANED(mainwin->hpaned));
+ }
+ mainwin->in_folder = FALSE;
+}
+
+void mainwindow_enter_folder(MainWindow *mainwin) {
+ if (prefs_common.layout_mode == SMALL_LAYOUT) {
+ mainwin_paned_show_last(GTK_PANED(mainwin->hpaned));
+ }
+ mainwin->in_folder = TRUE;
+}
+
+#ifdef MAEMO
+gboolean maemo_mainwindow_is_fullscreen(GtkWidget *widget)
+{
+ gint w, h;
+ gtk_window_get_size(GTK_WINDOW(widget), &w, &h);
+ return (w == 800);
+}
+
+void maemo_window_full_screen_if_needed (GtkWindow *window)
+{
+ if (maemo_mainwindow_is_fullscreen(mainwindow_get_mainwindow()->window)) {
+ gtk_window_fullscreen(GTK_WINDOW(window));
+ }
+}
+
+void maemo_connect_key_press_to_mainwindow (GtkWindow *window)
+{
+ g_signal_connect(G_OBJECT(window), "key_press_event",
+ G_CALLBACK(mainwindow_key_pressed), mainwindow_get_mainwindow());
+}
+#endif