diff options
Diffstat (limited to 'capplet/settings/mail-view.c')
-rw-r--r-- | capplet/settings/mail-view.c | 914 |
1 files changed, 914 insertions, 0 deletions
diff --git a/capplet/settings/mail-view.c b/capplet/settings/mail-view.c new file mode 100644 index 0000000000..cb6afb659d --- /dev/null +++ b/capplet/settings/mail-view.c @@ -0,0 +1,914 @@ +/* + * This program is free software; you can redistribute it and/or + * modify it under the terms of the GNU Lesser General Public + * License as published by the Free Software Foundation; either + * version 2 of the License, or (at your option) version 3. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * Lesser General Public License for more details. + * + * You should have received a copy of the GNU Lesser General Public + * License along with the program; if not, see <http://www.gnu.org/licenses/> + * + * + * Authors: + * Srinivasa Ragavan <sragavan@novell.com> + * + * Copyright (C) 2009 Novell, Inc. (www.novell.com) + * + */ + +#ifdef HAVE_CONFIG_H +# include <config.h> +#endif +#include <glib/gi18n.h> +#include "mail/em-utils.h" +#include "mail/mail-send-recv.h" +#include "mail/mail-ops.h" +#include "mail-view.h" +#ifndef ANJAL_SETTINGS +#include "mail-folder-view.h" +#include "mail-composer-view.h" +#include "mail-conv-view.h" +#endif + +#include "mail-settings-view.h" + +#if HAVE_ANERLEY +# include "mail-people-view.h" +#endif +#include "anjal-mail-view.h" +#include "mail-account-view.h" +#include "mail/em-folder-tree.h" +#include <shell/e-shell-searchbar.h> + +struct _MailViewPrivate { + + GtkWidget *box; + GList *children; + MailViewChild *current_view; + GtkWidget *new; + GtkWidget *search; + GtkWidget *search_entry; +}; + +enum { + VIEW_NEW, + LAST_SIGNAL +}; + +static guint signals[LAST_SIGNAL] = { 0 }; + +#undef MV_NEW_TAB + +G_DEFINE_TYPE (MailView, mail_view, ANJAL_MAIL_VIEW_TYPE) +#ifndef ANJAL_SETTINGS +static MailConvView * mv_switch_message_view (MailView *mv, const char *uri); +#endif + +#define REALIGN_NODES(list,pdata) if (list->data != pdata) { \ + list = g_list_remove (list, pdata); \ + list = g_list_prepend (list, pdata); \ + } + +void anjal_shell_view_restore_state (EShellView *view, const char *uri); + +static void +mail_view_init (MailView *shell) +{ + shell->priv = g_new0(MailViewPrivate, 1); + shell->priv->children = NULL; + shell->priv->current_view = NULL; + shell->folder_tree = NULL; + shell->check_mail = NULL; + shell->sort_by = NULL; +} + +static void +mail_view_finalize (GObject *object) +{ + MailView *shell = (MailView *)object; + MailViewPrivate *priv = shell->priv; + + g_list_free (priv->children); + g_free (priv); + + G_OBJECT_CLASS (mail_view_parent_class)->finalize (object); +} + +static void +mv_set_folder_uri (AnjalMailView *mv, const char *uri) +{ +#ifndef ANJAL_SETTINGS + mail_view_set_folder_uri ((MailView *)mv, uri); +#endif +} + +static void set_folder_tree (AnjalMailView *mv, EMFolderTree *tree) +{ + mail_view_set_folder_tree ((MailView *)mv, (GtkWidget *)tree); +} + +static void +set_search (AnjalMailView *mv, const char *search) +{ +#ifndef ANJAL_SETTINGS + mail_view_set_search ((MailView *)mv, search); +#endif +} + +static void +mail_view_class_init (MailViewClass *klass) +{ + GObjectClass * object_class = G_OBJECT_CLASS (klass); + AnjalMailViewClass *pclass; + signals[VIEW_NEW] = + g_signal_new ("view-new", + G_OBJECT_CLASS_TYPE (object_class), + G_SIGNAL_RUN_FIRST, + G_STRUCT_OFFSET (MailViewClass , view_new), + NULL, NULL, + g_cclosure_marshal_VOID__VOID, + G_TYPE_NONE, 0); + + pclass = mail_view_parent_class = g_type_class_peek_parent (klass); + ((AnjalMailViewClass *)klass)->set_folder_uri = mv_set_folder_uri; + ((AnjalMailViewClass *)klass)->set_folder_tree = set_folder_tree; + ((AnjalMailViewClass *)klass)->set_search = set_search; + + object_class->finalize = mail_view_finalize; + +}; + +#ifdef MV_NEW_TAB +static void +mv_new_page (GtkButton *w, MailView *mv) +{ + mail_view_add_page (mv, MAIL_VIEW_FOLDER, NULL); + gtk_notebook_set_current_page (mv, g_list_length (mv->priv->children)-1); +} +#endif + +static void +mv_switch (GtkNotebook *notebook,GtkNotebookPage *page, guint page_num, gpointer user_data) +{ + MailView *shell = (MailView *)notebook; + MailViewPrivate *priv = shell->priv; + MailViewChild *curr = priv->current_view; + + curr->flags &= ~MAIL_VIEW_HOLD_FOCUS; + +#ifdef MV_NEW_TAB + if (page_num == g_list_length(priv->children) && shell->priv->new) { + mail_view_add_page (shell, MAIL_VIEW_FOLDER, NULL); + gtk_notebook_set_current_page (shell, g_list_length (shell->priv->children)-1); + } else { +#endif + MailViewChild *child; + int current_child = gtk_notebook_get_current_page (notebook); + + child = (MailViewChild *)gtk_notebook_get_nth_page (notebook, current_child); + + priv->current_view = child; + REALIGN_NODES(shell->priv->children,child); + +#ifndef ANJAL_SETTINGS + if (child->type == MAIL_VIEW_COMPOSER) + mail_composer_view_activate ((MailComposerView *)child, shell->folder_tree, shell->check_mail, shell->sort_by, TRUE); + else if (child->type == MAIL_VIEW_MESSAGE) + mail_conv_view_activate ((MailConvView *)child, shell->tree, shell->folder_tree, shell->check_mail, shell->sort_by, FALSE); + else if (child->type == MAIL_VIEW_FOLDER) { + mail_folder_view_activate ((MailFolderView *)child, shell->tree, shell->folder_tree, shell->check_mail, shell->sort_by, shell->slider, TRUE); + anjal_shell_view_restore_state (shell->shell_view, child->uri); + } else if (child->type == MAIL_VIEW_ACCOUNT) + mail_account_view_activate ((MailAccountView *)child, shell->tree, shell->folder_tree, shell->check_mail, shell->sort_by, FALSE); + else if (child->type == MAIL_VIEW_SETTINGS) + mail_settings_view_activate ((MailSettingsView *)child, shell->tree, shell->folder_tree, shell->check_mail, shell->sort_by, shell->slider, FALSE); +#else + if (child->type == MAIL_VIEW_ACCOUNT) + mail_account_view_activate ((MailAccountView *)child, shell->tree, shell->folder_tree, shell->check_mail, shell->sort_by, FALSE); + else if (child->type == MAIL_VIEW_SETTINGS) + mail_settings_view_activate ((MailSettingsView *)child, shell->tree, shell->folder_tree, shell->check_mail, shell->sort_by, shell->slider, FALSE); +#endif +#if HAVE_ANERLEY + else if (child->type == MAIL_VIEW_PEOPLE) + mail_people_view_activate ((MailPeopleView *)child, shell->tree, shell->folder_tree, shell->check_mail, shell->sort_by, shell->slider, FALSE); +#endif + + + +#ifdef MV_NEW_TAB + } +#endif +} + + +#ifdef MV_NEW_TAB +static gboolean +mv_btn_expose (GtkWidget *w, GdkEventExpose *event, MailView *mv) +{ + GdkPixbuf *img = g_object_get_data (w, "pbuf"); + cairo_t *cr = gdk_cairo_create (w->window); + int wid = w->allocation.width; + int heig = w->allocation.height; + cairo_save (cr); + gdk_cairo_set_source_pixbuf (cr, img, event->area.x-4, event->area.y-5); + cairo_paint(cr); + cairo_restore(cr); + cairo_destroy (cr); + + return TRUE; +} + +static void +mv_new_tab_button (MailView *shell) +{ + int position; + GtkWidget *label = gtk_button_new (), *img; + GdkPixbuf *pbuf = e_icon_factory_get_icon ("gtk-add", E_ICON_SIZE_MENU); + GtkWidget *box = gtk_hbox_new (FALSE, 0); + int w,h; + + img = gtk_image_new_from_pixbuf (pbuf); + g_object_set_data (img, "pbuf", pbuf); + g_signal_connect (img, "expose-event", mv_btn_expose, shell); + g_signal_connect (label, "clicked", G_CALLBACK(mv_new_page), shell); + gtk_button_set_image (label, img); + gtk_icon_size_lookup_for_settings (gtk_widget_get_settings(label) , GTK_ICON_SIZE_MENU, &w, &h); + gtk_widget_set_size_request (label, w+2, h+2); + + gtk_button_set_relief(label, GTK_RELIEF_NONE); + gtk_button_set_focus_on_click (label, FALSE); + gtk_widget_set_tooltip_text (label, _("New Tab")); + gtk_widget_show_all (label); + gtk_widget_show (box); + shell->priv->new = box; + position = gtk_notebook_append_page (shell, box, label); + gtk_notebook_set_tab_reorderable (GTK_NOTEBOOK (shell), box, FALSE); + gtk_notebook_set_tab_detachable (GTK_NOTEBOOK (shell), box, FALSE); + +} +#endif + +void +mail_view_construct (MailView *shell) +{ + gtk_notebook_set_show_tabs ((GtkNotebook *)shell, TRUE); + gtk_notebook_set_scrollable ((GtkNotebook *)shell, TRUE); + gtk_notebook_popup_disable ((GtkNotebook *)shell); +#ifdef MV_NEW_TAB + mv_new_tab_button (shell); +#endif + g_signal_connect_after (shell, "switch-page", G_CALLBACK(mv_switch), shell); +} + +MailView * +mail_view_new () +{ + MailView *shell = g_object_new (MAIL_VIEW_TYPE, NULL); + mail_view_construct (shell); + + return shell; +} + +static void +mv_message_shown (MailViewChild *mfv, MailView *mv) +{ + GtkWidget *arr; + + if (!mv->slider) + return; + + arr = g_object_get_data ((GObject *)mv->slider, "right-arrow"); + //gtk_widget_hide (mv->folder_tree); + gtk_widget_show (arr); + gtk_widget_show (mv->slider); +} + +static int +list_data_pos (GList *list, gpointer data) +{ + int i=-1; + while (list) { + i++; + if (list->data == data) + return i; + list = list->next; + } + + return i; +} + +static int +mv_get_page_number (GtkNotebook *note, GtkWidget *widget) +{ + int i, total; + + total = gtk_notebook_get_n_pages (note); + for (i=0; i<total; i++) { + if (gtk_notebook_get_nth_page(note, i) == widget) + return i; + } + + return total-1; +} + +static void +mv_close_mcv (MailViewChild *mfv, MailView *mv) +{ + int n = mv_get_page_number ((GtkNotebook *)mv, (GtkWidget *)mfv); + int pos = gtk_notebook_get_current_page ((GtkNotebook *)mv); + MailViewChild *child; + gboolean removing_viewed = FALSE; + + if (g_list_length(mv->priv->children) == 1) + return; + +#ifndef ANJAL_SETTINGS + /* Make sure atleast one folder view is open. */ + if (mfv->type == MAIL_VIEW_FOLDER) { + GList *tmp = mv->priv->children; + gboolean found = FALSE; + + while (!found && tmp) { + MailViewChild *tchild = (MailViewChild *)tmp->data; + + if (tchild && tchild != mfv && tchild->type == MAIL_VIEW_FOLDER) + found = true; + tmp = tmp->next; + } + + if (!found) + return; + } + + if (mfv->type == MAIL_VIEW_COMPOSER) { + if (!mail_composer_view_can_quit((MailComposerView *)mfv)) + return; + } +#endif + + g_signal_handlers_block_by_func(mv, mv_switch, mv); + gtk_notebook_remove_page ((GtkNotebook *)mv, n); + g_signal_handlers_unblock_by_func(mv, mv_switch, mv); + + if (mfv == mv->priv->children->data) + removing_viewed = TRUE; + mv->priv->children = g_list_remove (mv->priv->children, mfv); + + if (!removing_viewed) + return; + + child = (MailViewChild *)mv->priv->children->data; + mv->priv->current_view = child; + pos = mv_get_page_number ((GtkNotebook *)mv, (GtkWidget *)child); + gtk_notebook_set_current_page ((GtkNotebook *)mv, pos); + +#ifndef ANJAL_SETTINGS + if (child->type == MAIL_VIEW_COMPOSER) + mail_composer_view_activate ((MailComposerView *)child, mv->folder_tree, mv->check_mail, mv->sort_by, TRUE); + else if (child->type == MAIL_VIEW_MESSAGE) + mail_conv_view_activate ((MailConvView *)child, mv->tree, mv->folder_tree, mv->check_mail, mv->sort_by, FALSE); + else if (child->type == MAIL_VIEW_FOLDER) { + mail_folder_view_activate ((MailFolderView *)child, mv->tree, mv->folder_tree, mv->check_mail, mv->sort_by, mv->slider, TRUE); + anjal_shell_view_restore_state ((EShellView *)mv->shell_view, child->uri); + //mail_search_set_state (mv->priv->search, ((MailFolderView *)child)->search_str, ((MailFolderView *)child)->search_state); + } else if (child->type == MAIL_VIEW_ACCOUNT) + mail_account_view_activate ((MailAccountView *)child, mv->tree, mv->folder_tree, mv->check_mail, mv->sort_by, FALSE); + else if (child->type == MAIL_VIEW_SETTINGS) + mail_settings_view_activate ((MailSettingsView *)child, mv->tree, mv->folder_tree, mv->check_mail, mv->sort_by, mv->slider, FALSE); +#else + if (child->type == MAIL_VIEW_ACCOUNT) + mail_account_view_activate ((MailAccountView *)child, mv->tree, mv->folder_tree, mv->check_mail, mv->sort_by, FALSE); + else if (child->type == MAIL_VIEW_SETTINGS) + mail_settings_view_activate ((MailSettingsView *)child, mv->tree, mv->folder_tree, mv->check_mail, mv->sort_by, mv->slider, FALSE); + +#endif +#if HAVE_ANERLEY + else if (child->type == MAIL_VIEW_PEOPLE) + mail_people_view_activate ((MailPeopleView *)child, mv->tree, mv->folder_tree, mv->check_mail, mv->sort_by, mv->slider, FALSE); +#endif + +} + +#ifndef ANJAL_SETTINGS +static void +mv_message_new (MailFolderView *mfv, gpointer data, char *umid, MailView *mv) +{ + MailConvView *conv = (MailConvView *)mv_switch_message_view(mv, umid); + *(MailConvView **)data = conv; + + if (conv) + conv->uri = g_strdup(umid); + + return; +} + +static void +mv_search_set (MailFolderView *mfv, MailView *mv) +{ + anjal_shell_view_restore_state (mv->shell_view, ((MailViewChild *)mfv)->uri); + //mail_search_set_state (mv->priv->search, mfv->search_str, mfv->search_state); +} + +static void +mv_folder_loaded (MailFolderView *mfv, MailView *mv) +{ + g_signal_handlers_block_by_func(mfv, mv_folder_loaded, mv); + g_signal_emit (mv, signals[VIEW_NEW], 0); +} + +static MailViewChild * +mail_view_add_folder (MailView *mv, gpointer data, gboolean block) +{ + MailFolderView *mfv = mail_folder_view_new (); + gint position = 0; + mail_folder_view_set_folder_pane (mfv, mv->folder_tree); + if(!block) + mv->priv->current_view = (MailViewChild *)mfv; + mv->priv->children = block ? g_list_append(mv->priv->children, mfv) : g_list_prepend (mv->priv->children, mfv); + position = gtk_notebook_append_page ((GtkNotebook *)mv, (GtkWidget *)mfv, mfv->tab_label); + gtk_notebook_set_tab_reorderable (GTK_NOTEBOOK (mv), (GtkWidget *)mfv, TRUE); + gtk_notebook_set_tab_detachable (GTK_NOTEBOOK (mv), (GtkWidget *)mfv, FALSE); + + g_signal_connect (mfv, "view-close", G_CALLBACK(mv_close_mcv), mv); + if (!block) + gtk_notebook_set_current_page ((GtkNotebook *)mv, position); + gtk_notebook_set_tab_label_packing ((GtkNotebook *)mv, (GtkWidget *)mfv, FALSE, FALSE, 0); + g_signal_connect (mfv, "message-shown", G_CALLBACK(mv_message_shown), mv); + g_signal_connect (mfv, "message-new", G_CALLBACK(mv_message_new), mv); + g_signal_connect (mfv, "search-set", G_CALLBACK(mv_search_set), mv); + g_signal_connect (mfv, "view-loaded", G_CALLBACK (mv_folder_loaded), mv); + if (!block) + mail_folder_view_activate (mfv, mv->tree, mv->folder_tree, mv->check_mail, mv->sort_by, mv->slider, TRUE); + + return (MailViewChild *)mfv; +} + +static MailViewChild * +mail_view_add_composer (MailView *mv, gpointer data, gboolean block) +{ + MailComposerView *mcv; + gint position = 0; + gboolean special = FALSE; + + if (!data) + mcv = mail_composer_view_new (); + else if (data == (gpointer)-1) { + special = TRUE; + data = NULL; + } else + mcv = mail_composer_view_new_with_composer ((GtkWidget *)data); + if (!block) + mv->priv->current_view = (MailViewChild *)mcv; + mv->priv->children = block ? g_list_append(mv->priv->children, mcv) : g_list_prepend (mv->priv->children, mcv); + + if (!special) + position = gtk_notebook_append_page ((GtkNotebook *)mv, (GtkWidget *)mcv, mcv->tab_label); + else { + int position = gtk_notebook_get_current_page ((GtkNotebook *)mv); + gtk_notebook_insert_page ((GtkNotebook *)mv, (GtkWidget *)mcv, mcv->tab_label, position+1); + } + + gtk_notebook_set_tab_reorderable (GTK_NOTEBOOK (mv), (GtkWidget *)mcv, TRUE); + gtk_notebook_set_tab_detachable (GTK_NOTEBOOK (mv), (GtkWidget *)mcv, FALSE); + if (!block) + gtk_notebook_set_current_page ((GtkNotebook *)mv, position); + gtk_notebook_set_tab_label_packing ((GtkNotebook *)mv, (GtkWidget *)mcv, FALSE, FALSE, 0); + if (!block) + mail_composer_view_activate (mcv, mv->folder_tree, mv->check_mail, mv->sort_by, FALSE); + + g_signal_connect (mcv, "view-close", G_CALLBACK(mv_close_mcv), mv); + g_signal_connect (mcv, "message-shown", G_CALLBACK(mv_message_shown), mv); + + //mv_message_shown ((MailViewChild *)mcv, mv); + return (MailViewChild *)mcv; +} + +static MailViewChild * +mail_view_add_message (MailView *mv, gpointer data, gboolean block) +{ + MailConvView *mcv = mail_conv_view_new (); + gint position = 0; + + gtk_widget_show ((GtkWidget *)mcv); + mcv->type = MAIL_VIEW_MESSAGE; + if(!block) + mv->priv->current_view = (MailViewChild *)mcv; + mv->priv->children = block ? g_list_append(mv->priv->children, mcv) : g_list_prepend (mv->priv->children, mcv); + + position = gtk_notebook_get_current_page ((GtkNotebook *)mv); + gtk_notebook_insert_page ((GtkNotebook *)mv, (GtkWidget *)mcv, mail_conv_view_get_tab_widget(mcv), position+1); + gtk_notebook_set_tab_reorderable (GTK_NOTEBOOK (mv), (GtkWidget *)mcv, TRUE); + gtk_notebook_set_tab_detachable (GTK_NOTEBOOK (mv), (GtkWidget *)mcv, FALSE); + if (!block) + gtk_notebook_set_current_page ((GtkNotebook *)mv, position+1); + gtk_notebook_set_tab_label_packing ((GtkNotebook *)mv, (GtkWidget *)mcv, FALSE, FALSE, 0); + if (!block) + mail_conv_view_activate (mcv, mv->tree, mv->folder_tree, mv->check_mail, mv->sort_by, FALSE); + + g_signal_connect (mcv, "view-close", G_CALLBACK(mv_close_mcv), mv); + g_signal_connect (mcv, "message-shown", G_CALLBACK(mv_message_shown), mv); + + return (MailViewChild *)mcv; +} + +#endif + +static void +mv_show_acc_mcv (MailViewChild *mfv, EAccount *account, MailView *mv) +{ + mail_view_add_page(mv, MAIL_VIEW_ACCOUNT, account); +} + +static MailViewChild * +mail_view_add_settings (MailView *mv, gpointer data, gboolean block) +{ + MailSettingsView *msv = mail_settings_view_new (); + gint position = 0; + + gtk_widget_show ((GtkWidget *)msv); + if(!block) + mv->priv->current_view = (MailViewChild *)msv; + mv->priv->children = block ? g_list_append(mv->priv->children, msv) : g_list_prepend (mv->priv->children, msv); + + position = gtk_notebook_append_page ((GtkNotebook *)mv, (GtkWidget *)msv, mail_settings_view_get_tab_widget(msv)); + g_signal_connect (msv, "view-close", G_CALLBACK(mv_close_mcv), mv); + g_signal_connect (msv, "show-account", G_CALLBACK(mv_show_acc_mcv), mv); + gtk_notebook_set_tab_reorderable (GTK_NOTEBOOK (mv), (GtkWidget *)msv, TRUE); + gtk_notebook_set_tab_detachable (GTK_NOTEBOOK (mv), (GtkWidget *)msv, FALSE); + if (!block) + gtk_notebook_set_current_page ((GtkNotebook *)mv, position); + gtk_notebook_set_tab_label_packing ((GtkNotebook *)mv, (GtkWidget *)msv, FALSE, FALSE, 0); + if(!block) + mail_settings_view_activate (msv, mv->tree, mv->folder_tree, mv->check_mail, mv->sort_by, mv->slider, FALSE); + + return (MailViewChild *)msv; +} + +#if HAVE_ANERLEY +void +mail_view_switch_to_people (MailView* mv, MailViewChild *mpv) +{ + GList *tmp = mv->priv->children; + int position = 0; + + position = mv_get_page_number(mv, mpv); + REALIGN_NODES(mv->priv->children,mpv); + gtk_notebook_set_current_page ((GtkNotebook *)mv, position); + mail_people_view_activate ((MailPeopleView *)mpv, mv->tree, mv->folder_tree, mv->check_mail, mv->sort_by, mv->slider, FALSE); +} +#endif + +void +mail_view_switch_to_settings (MailView* mv, MailViewChild *mpv) +{ + int position = 0; + + position = mv_get_page_number((GtkNotebook *)mv, (GtkWidget *)mpv); + REALIGN_NODES(mv->priv->children,mpv); + gtk_notebook_set_current_page ((GtkNotebook *)mv, position); + mail_settings_view_activate ((MailSettingsView *)mpv, mv->tree, mv->folder_tree, mv->check_mail, mv->sort_by, mv->slider, FALSE); +} + +#if HAVE_ANERLEY +static MailViewChild * +mail_view_add_people (MailView *mv, gpointer data, gboolean block) +{ + MailPeopleView *msv = mail_people_view_new (); + gint position = 0; + + gtk_widget_show ((GtkWidget *)msv); + if (!block) + mv->priv->current_view = (MailViewChild *)msv; + mv->priv->children = block ? g_list_append(mv->priv->children, msv) : g_list_prepend (mv->priv->children, msv); + position = gtk_notebook_append_page ((GtkNotebook *)mv, (GtkWidget *)msv, mail_people_view_get_tab_widget(msv)); + g_signal_connect (msv, "view-close", G_CALLBACK(mv_close_mcv), mv); + gtk_notebook_set_tab_reorderable (GTK_NOTEBOOK (mv), (GtkWidget *)msv, TRUE); + gtk_notebook_set_tab_detachable (GTK_NOTEBOOK (mv), (GtkWidget *)msv, FALSE); + if (!block) + gtk_notebook_set_current_page ((GtkNotebook *)mv, position); + gtk_notebook_set_tab_label_packing ((GtkNotebook *)mv, (GtkWidget *)msv, FALSE, FALSE, 0); + if(!block) + mail_people_view_activate (msv, mv->tree, mv->folder_tree, mv->check_mail, mv->sort_by, mv->slider, FALSE); + + return (MailViewChild *)msv; +} +#endif + +static MailViewChild * +mail_view_add_account (MailView *mv, gpointer data, gboolean block) +{ + MailAccountView *msv = mail_account_view_new (data); + gint position = 0; + + gtk_widget_show ((GtkWidget *)msv); + if (!block) + mv->priv->current_view = (MailViewChild *)msv; + mv->priv->children = block ? g_list_append(mv->priv->children, msv) : g_list_prepend (mv->priv->children, msv); + position = gtk_notebook_append_page ((GtkNotebook *)mv, (GtkWidget *)msv, mail_account_view_get_tab_widget(msv)); + g_signal_connect_after (msv, "view-close", G_CALLBACK(mv_close_mcv), mv); + gtk_notebook_set_tab_reorderable (GTK_NOTEBOOK (mv), (GtkWidget *)msv, TRUE); + gtk_notebook_set_tab_detachable (GTK_NOTEBOOK (mv), (GtkWidget *)msv, FALSE); + if(!block) + gtk_notebook_set_current_page ((GtkNotebook *)mv, position); + gtk_notebook_set_tab_label_packing ((GtkNotebook *)mv, (GtkWidget *)msv, FALSE, FALSE, 0); + if(!block) + mail_account_view_activate (msv, mv->tree, mv->folder_tree, mv->check_mail, mv->sort_by, FALSE); + + return (MailViewChild *)msv; +} + +MailViewChild * +mail_view_add_page (MailView *mv, guint16 type, gpointer data) +{ + MailViewChild *child = NULL, *current_child; + gboolean block = FALSE; + + current_child = mv->priv->current_view; + if (current_child && (current_child->flags & MAIL_VIEW_HOLD_FOCUS)) + block = TRUE; + + g_signal_handlers_block_by_func(mv, mv_switch, mv); + switch (type){ +#ifndef ANJAL_SETTINGS + case MAIL_VIEW_FOLDER: + child = mail_view_add_folder (mv, data, block); + break; + + case MAIL_VIEW_COMPOSER: + child = mail_view_add_composer (mv, data, block); + break; + case MAIL_VIEW_MESSAGE: + child = mail_view_add_message (mv, data, block); + break; +#endif + case MAIL_VIEW_SETTINGS: + child = mail_view_add_settings (mv, data, block); + break; +#if HAVE_ANERLEY + case MAIL_VIEW_PEOPLE: + child = mail_view_add_people (mv, data, block); + break; +#endif + case MAIL_VIEW_ACCOUNT: + child = mail_view_add_account (mv, data, block); + break; + } + gtk_widget_grab_focus((GtkWidget *)child); + child->type = type; +#ifdef MV_NEW_TAB + gtk_notebook_reorder_child (mv, mv->priv->new, -1); + gtk_notebook_set_current_page (mv, g_list_length (mv->priv->children)-1); +#endif + g_signal_handlers_unblock_by_func(mv, mv_switch, mv); + + child->flags = 0; + + return child; +} + +#ifndef ANJAL_SETTINGS +static void +mv_switch_folder_view (MailView *mv, const char *uri) +{ + int i=0, len = g_list_length(mv->priv->children); + GList *tmp = mv->priv->children; + while (i<len) { + MailViewChild *child = (MailViewChild *)gtk_notebook_get_nth_page ((GtkNotebook *)mv, i); + + if (child->type == MAIL_VIEW_FOLDER && !strcmp (uri, child->uri)) { + if(child != mv->priv->current_view) { + gtk_notebook_set_current_page ((GtkNotebook *)mv, i); + //REALIGN_NODES(mv->priv->children, child); + } + return; + } + i++; + tmp = tmp->next; + } + + mail_view_add_page (mv, MAIL_VIEW_FOLDER, NULL); + mail_folder_view_set_folder_uri ((MailFolderView *)mv->priv->current_view, uri); +} + +static MailConvView * +mv_switch_message_view (MailView *mv, const char *uri) +{ + int i=0; + GList *tmp = mv->priv->children; + while (tmp) { + MailViewChild *child = tmp->data; + if (child->type == MAIL_VIEW_MESSAGE && !strcmp (uri, child->uri)) { + gtk_notebook_set_current_page ((GtkNotebook *)mv, i); + mail_conv_view_activate ((MailConvView *)child, mv->tree, mv->folder_tree, mv->check_mail, mv->sort_by, FALSE); + REALIGN_NODES(mv->priv->children,child); + return NULL; + } + i++; + tmp = tmp->next; + } + + return (MailConvView *)mail_view_add_page (mv, MAIL_VIEW_MESSAGE, NULL); +} + +void +mail_view_set_folder_uri (MailView *mv, const char *uri) +{ + + mv_switch_folder_view (mv, uri); + //mail_folder_view_set_folder_uri (mv->priv->current_view, uri); +} + +void +mail_view_show_sort_popup (MailView *mv, GtkWidget *button) +{ + mail_folder_view_show_sort_popup ((MailFolderView *)mv->priv->current_view, button); +} + +void +mail_view_show_list (MailView *mv) +{ + MailViewChild *child = (MailViewChild *)mv->priv->current_view; + + if (child->type == MAIL_VIEW_MESSAGE) + mv_close_mcv (child, mv); + else if (child->type == MAIL_VIEW_FOLDER) + mail_folder_view_show_list ((MailFolderView *)mv->priv->current_view); + + +} +#endif +void +mail_view_close_view (MailView *mv) +{ + MailViewChild *child = (MailViewChild *)mv->priv->current_view; + + mv_close_mcv (child, mv); +} + +#ifndef ANJAL_SETTINGS +static void +mv_slider_clicked (GtkButton *slider, MailView *mv) +{ + gtk_widget_hide (mv->slider); + gtk_widget_show (mv->folder_tree); + if (mv->priv->current_view->type == MAIL_VIEW_FOLDER) + mail_folder_view_show_list ((MailFolderView *)mv->priv->current_view); + else { + gtk_widget_show (mv->folder_tree); + gtk_widget_hide ((GtkWidget *)slider); + } +} + +void +mail_view_set_slider (MailView *mv, GtkWidget *slider) +{ + mv->slider = slider; + g_signal_connect (slider, "clicked", G_CALLBACK(mv_slider_clicked), mv); +} +#endif + +void +mail_view_set_folder_tree_widget (MailView *mv, GtkWidget *tree) +{ + mv->folder_tree = tree; +} + +#if 0 +static gboolean +mv_tree_click_cb (GtkWidget *w, GdkEventButton *event, MailView *mv) +{ + if ((event->button == 1 && event->type == GDK_2BUTTON_PRESS) || event->button == 2) { + GtkTreeSelection *selection; + GtkTreePath *tree_path; + + if (!gtk_tree_view_get_path_at_pos ((GtkTreeView *)w, (int) event->x, (int) event->y, &tree_path, NULL, NULL, NULL)) + return FALSE; + mail_view_add_page (mv, MAIL_VIEW_FOLDER, NULL); + gtk_notebook_set_current_page ((GtkNotebook *)mv, g_list_length (mv->priv->children)-1); + selection = gtk_tree_view_get_selection ((GtkTreeView *)w); + gtk_tree_selection_unselect_path (selection, tree_path); + gtk_tree_selection_select_path(selection, tree_path); + gtk_tree_view_set_cursor ((GtkTreeView *)w, tree_path, NULL, FALSE); + + + return TRUE; + } + return FALSE; +} +#endif + +void +mail_view_set_folder_tree (MailView *mv, GtkWidget *tree) +{ + mv->tree = tree; + //em_folder_tree_set_skip_double_click ((EMFolderTree *)tree, FALSE); + //g_signal_connect ((GObject *)em_folder_tree_get_tree_view((EMFolderTree *)tree), "button-press-event", G_CALLBACK(mv_tree_click_cb), mv); +} + +void +mail_view_set_check_email (MailView *mv, GtkWidget *button) +{ + mv->check_mail = button;; +} + +void +mail_view_set_sort_by (MailView *mv, GtkWidget *button) +{ + mv->sort_by = button;; +} + +static void +mv_spinner_show (MailView *mv, gboolean show) +{ + GtkWidget *spinner = g_object_get_data ((GObject *)mv->check_mail, "spinner"); + GtkWidget *icon = g_object_get_data ((GObject *)mv->check_mail, "icon"); + + if(show) { + gtk_widget_show (spinner); + gtk_widget_hide(icon); + gtk_button_set_relief ((GtkButton *)mv->check_mail, GTK_RELIEF_NORMAL); + + } else { + gtk_widget_show (icon); + gtk_widget_hide(spinner); + gtk_button_set_relief ((GtkButton *)mv->check_mail, GTK_RELIEF_NONE); + } +} + +static void +mv_spinner_done (CamelFolder *f, gpointer data) +{ + MailView *mv = (MailView *)data; + mv_spinner_show (mv, FALSE); +} +#ifndef ANJAL_SETTINGS +void +mail_view_check_mail(MailView *mv, gboolean deep) +{ + MailViewChild *child = (MailViewChild *)mv->priv->current_view; + + if (child && child->type == MAIL_VIEW_FOLDER) { + mail_folder_view_check_mail ((MailFolderView *)child); + CamelFolder *folder; + + if ((folder = em_folder_tree_get_selected_folder ((EMFolderTree *)mv->tree)) != NULL) { + mv_spinner_show (mv, TRUE); + mail_refresh_folder(folder, mv_spinner_done, mv); + } + } + + if (deep) { + em_utils_clear_get_password_canceled_accounts_flag (); + mail_send_receive (NULL); + } +} + +void +mail_view_save (MailView *mv) +{ + GList *child = mv->priv->children; + MailViewChild *cview; + + while (child) { + cview = (MailViewChild *)child->data; + if (cview->type == MAIL_VIEW_FOLDER) { + mail_folder_view_save ((MailFolderView *)cview); + } + child = child->next; + } +} + +void +mail_view_set_search (MailView *mv, const char *search) +{ + MailViewChild *child = (MailViewChild *)mv->priv->current_view; + + if (child && child->type == MAIL_VIEW_FOLDER) { + MailFolderView *mfv = (MailFolderView *)child; + + mail_folder_view_set_search (mfv, search, e_shell_searchbar_get_search_text ((EShellSearchbar *)mv->priv->search_entry)); + } +} +#endif + +void +mail_view_set_search_entry (MailView *mv, GtkWidget *entry) +{ + mv->priv->search_entry = entry; +} + +void +mail_view_init_search (MailView *mv, GtkWidget *search) +{ + mv->priv->search = search; +} + +void +mail_view_set_shell_view (MailView *mv, EShellView *shell) +{ + mv->shell_view = shell; +} |