#include <glib/gi18n.h>
#include <string.h>
#include <modest-runtime.h>
+#include <modest-tny-folder.h>
#include <modest-tny-msg.h>
#include <modest-tny-account.h>
#include <modest-address-book.h>
if (MODEST_IS_MSG_VIEW_WINDOW (win)) {
gtk_widget_destroy (GTK_WIDGET(win));
- }
+ }
}
void
modest_ui_actions_on_quit (GtkAction *action, ModestWindow *win)
{
- /* FIXME: save size of main window */
-/* save_sizes (main_window); */
-/* gtk_widget_destroy (GTK_WIDGET (win)); */
gtk_main_quit ();
}
gchar *account_name = NULL;
gchar *from_str = NULL;
GError *err = NULL;
- TnyAccount *account;
+ TnyAccount *account = NULL;
ModestWindowMgr *mgr;
account_name = g_strdup(modest_window_get_active_account (win));
if (!account_name)
account_name = modest_account_mgr_get_default_account (modest_runtime_get_account_mgr());
+ if (!account_name) {
+ g_printerr ("modest: no account found\n");
+ goto cleanup;
+ }
account = modest_tny_account_store_get_tny_account_by_account (modest_runtime_get_account_store(),
account_name,
mail_op = modest_mail_operation_new ();
modest_mail_operation_queue_add (modest_runtime_get_mail_operation_queue (), mail_op);
modest_mail_operation_update_account (mail_op, TNY_STORE_ACCOUNT(tny_account));
+
g_object_unref (G_OBJECT(tny_account));
g_object_unref (G_OBJECT (mail_op));
void
-modest_ui_actions_toggle_view (GtkAction *action, ModestMainWindow *main_window)
+modest_ui_actions_toggle_header_list_view (GtkAction *action, ModestMainWindow *main_window)
{
ModestConf *conf;
GtkWidget *header_view;
modest_ui_actions_on_header_activated (ModestHeaderView *folder_view, TnyHeader *header,
ModestMainWindow *main_window)
{
- ModestWindow *win;
+ ModestWindow *win = NULL;
TnyFolder *folder = NULL;
TnyMsg *msg = NULL;
- gchar *account = NULL;
- GtkTreeModel *model = NULL;
- GtkTreeSelection *sel = NULL;
- GtkTreeIter iter;
ModestWindowMgr *mgr;
g_return_if_fail (MODEST_IS_MAIN_WINDOW(main_window));
folder = tny_header_get_folder (header);
if (!folder) {
g_printerr ("modest: cannot get folder for header\n");
- goto cleanup;
+ return;
}
/* FIXME: make async?; check error */
goto cleanup;
}
- account = g_strdup(modest_window_get_active_account(MODEST_WINDOW(main_window)));
- if (!account)
- account = modest_account_mgr_get_default_account (modest_runtime_get_account_mgr());
+ /* Look if we already have a message view for that header */
+ mgr = modest_runtime_get_window_mgr ();
+ win = modest_window_mgr_find_window_by_msguid (mgr, tny_header_get_uid (header));
+
+ /* If not, create a new window */
+ if (!win) {
+ gchar *account;
+
+ account = g_strdup(modest_window_get_active_account(MODEST_WINDOW(main_window)));
+ if (!account)
+ account = modest_account_mgr_get_default_account (modest_runtime_get_account_mgr());
- /* Create and register message view window */
- sel = gtk_tree_view_get_selection (GTK_TREE_VIEW (folder_view));
- if (gtk_tree_selection_get_selected (sel, &model, &iter)) {
- win = modest_msg_view_window_new_with_header_model (msg, account, model, iter);
- } else {
win = modest_msg_view_window_new (msg, account);
- }
- mgr = modest_runtime_get_window_mgr ();
- modest_window_mgr_register_window (mgr, win);
+ modest_window_mgr_register_window (mgr, win);
- gtk_window_set_transient_for (GTK_WINDOW (win),
- GTK_WINDOW (main_window));
+ gtk_window_set_transient_for (GTK_WINDOW (win),
+ GTK_WINDOW (main_window));
+ }
gtk_widget_show_all (GTK_WIDGET(win));
+
+ g_object_unref (G_OBJECT (msg));
cleanup:
- g_free (account);
-
- if (folder)
- g_object_unref (G_OBJECT (folder));
- if (msg)
- g_object_unref (G_OBJECT (msg));
+ g_object_unref (G_OBJECT (folder));
}
void
}
void
+modest_ui_actions_on_zoom_plus (GtkAction *action,
+ ModestWindow *window)
+{
+ g_return_if_fail (MODEST_IS_WINDOW (window));
+
+ modest_window_zoom_plus (MODEST_WINDOW (window));
+}
+
+void
+modest_ui_actions_on_zoom_minus (GtkAction *action,
+ ModestWindow *window)
+{
+ g_return_if_fail (MODEST_IS_WINDOW (window));
+
+ modest_window_zoom_minus (MODEST_WINDOW (window));
+}
+
+void
modest_ui_actions_on_toggle_fullscreen (GtkToggleAction *toggle,
ModestWindow *window)
{
+ ModestWindowMgr *mgr;
+ gboolean fullscreen, active;
g_return_if_fail (MODEST_IS_WINDOW (window));
- if (gtk_toggle_action_get_active (GTK_TOGGLE_ACTION (toggle))) {
- gtk_window_fullscreen (GTK_WINDOW (window));
- } else {
- gtk_window_unfullscreen (GTK_WINDOW (window));
+ mgr = modest_runtime_get_window_mgr ();
+
+ active = (gtk_toggle_action_get_active (GTK_TOGGLE_ACTION (toggle)))?1:0;
+ fullscreen = modest_window_mgr_get_fullscreen_mode (mgr);
+
+ if (active != fullscreen) {
+ modest_window_mgr_set_fullscreen_mode (mgr, active);
+ gtk_window_present (GTK_WINDOW (window));
}
}
+void
+modest_ui_actions_on_change_fullscreen (GtkAction *action,
+ ModestWindow *window)
+{
+ ModestWindowMgr *mgr;
+ gboolean fullscreen;
+
+ g_return_if_fail (MODEST_IS_WINDOW (window));
+
+ mgr = modest_runtime_get_window_mgr ();
+ fullscreen = modest_window_mgr_get_fullscreen_mode (mgr);
+ modest_window_mgr_set_fullscreen_mode (mgr, !fullscreen);
+
+ gtk_window_present (GTK_WINDOW (window));
+}
+
static void
modest_ui_actions_message_details_cb (gpointer msg_data,
gpointer helper_data)
g_return_if_reached ();
}
}
+
+void
+modest_ui_actions_on_toggle_show_cc (GtkToggleAction *toggle,
+ ModestMsgEditWindow *window)
+{
+ g_return_if_fail (MODEST_IS_MSG_EDIT_WINDOW (window));
+
+ modest_msg_edit_window_show_cc (window, gtk_toggle_action_get_active (toggle));
+}
+
+void
+modest_ui_actions_on_toggle_show_bcc (GtkToggleAction *toggle,
+ ModestMsgEditWindow *window)
+{
+ g_return_if_fail (MODEST_IS_MSG_EDIT_WINDOW (window));
+
+ modest_msg_edit_window_show_bcc (window, gtk_toggle_action_get_active (toggle));
+}
+
+void
+modest_ui_actions_toggle_folders_view (GtkAction *action,
+ ModestMainWindow *main_window)
+{
+ ModestConf *conf;
+
+ g_return_if_fail (MODEST_IS_MAIN_WINDOW(main_window));
+
+ conf = modest_runtime_get_conf ();
+
+ if (modest_main_window_get_style (main_window) == MODEST_MAIN_WINDOW_STYLE_SPLIT)
+ modest_main_window_set_style (main_window, MODEST_MAIN_WINDOW_STYLE_SIMPLE);
+ else
+ modest_main_window_set_style (main_window, MODEST_MAIN_WINDOW_STYLE_SPLIT);
+}
+
+void
+modest_ui_actions_on_toggle_toolbar (GtkToggleAction *toggle,
+ ModestWindow *window)
+{
+ gboolean active, fullscreen = FALSE;
+ ModestWindowMgr *mgr;
+
+ active = gtk_toggle_action_get_active (GTK_TOGGLE_ACTION (toggle));
+
+ /* Check if we want to toggle the toolbar vuew in fullscreen
+ or normal mode */
+ if (!strcmp (gtk_action_get_name (GTK_ACTION (toggle)),
+ "ViewShowToolbarFullScreen")) {
+ fullscreen = TRUE;
+ }
+
+ /* Toggle toolbar */
+ mgr = modest_runtime_get_window_mgr ();
+ modest_window_mgr_show_toolbars (mgr, active, fullscreen);
+}