diff options
Diffstat (limited to 'mail/em-folder-view.c')
-rw-r--r-- | mail/em-folder-view.c | 63 |
1 files changed, 43 insertions, 20 deletions
diff --git a/mail/em-folder-view.c b/mail/em-folder-view.c index cb55b049fc..fae2f6f11f 100644 --- a/mail/em-folder-view.c +++ b/mail/em-folder-view.c @@ -42,6 +42,8 @@ #include <gal/menus/gal-view-etable.h> #include <gal/menus/gal-view-factory-etable.h> +#include <gal/menus/gal-view-instance.h> +#include "widgets/menus/gal-view-menus.h" #include <camel/camel-mime-message.h> #include <camel/camel-stream.h> @@ -127,6 +129,9 @@ struct _EMFolderViewPrivate { GtkWidget *invisible; char *selection_uri; + + GalViewInstance *view_instance; + GalViewMenus *view_menus; }; static GtkVBoxClass *emfv_parent; @@ -155,6 +160,7 @@ emfv_init(GObject *o) p = emfv->priv = g_malloc0(sizeof(struct _EMFolderViewPrivate)); emfv->statusbar_active = TRUE; + emfv->list_active = FALSE; emfv->ui_files = g_slist_append(NULL, EVOLUTION_UIDIR "/evolution-mail-message.xml"); emfv->ui_app_name = "evolution-mail"; @@ -378,8 +384,6 @@ em_folder_view_open_selected(EMFolderView *emfv) } /* ******************************************************************************** */ -static GalViewCollection *collection = NULL; - static void emfv_list_display_view(GalViewInstance *instance, GalView *view, EMFolderView *emfv) { @@ -388,10 +392,12 @@ emfv_list_display_view(GalViewInstance *instance, GalView *view, EMFolderView *e } static void -emfv_create_view_instance(EMFolderView *emfv) +emfv_setup_view_instance(EMFolderView *emfv) { + struct _EMFolderViewPrivate *p = emfv->priv; gboolean outgoing; char *id; + static GalViewCollection *collection = NULL; g_assert(emfv->folder); g_assert(emfv->folder_uri); @@ -421,27 +427,32 @@ emfv_create_view_instance(EMFolderView *emfv) gal_view_collection_load (collection); } - - if (emfv->view_instance) { - g_object_unref(emfv->view_instance); - emfv->view_instance = NULL; + + if (p->view_instance) { + g_object_unref(p->view_instance); + p->view_instance = NULL; } - + + if (p->view_menus) { + g_object_unref(p->view_menus); + p->view_menus = NULL; + } + outgoing = em_utils_folder_is_drafts (emfv->folder, emfv->folder_uri) || em_utils_folder_is_sent (emfv->folder, emfv->folder_uri) || em_utils_folder_is_outbox (emfv->folder, emfv->folder_uri); /* TODO: should this go through mail-config api? */ id = mail_config_folder_to_safe_url (emfv->folder); - emfv->view_instance = gal_view_instance_new (collection, id); + p->view_instance = gal_view_instance_new (collection, id); g_free (id); if (outgoing) - gal_view_instance_set_default_view (emfv->view_instance, "As_Sent_Folder"); + gal_view_instance_set_default_view(p->view_instance, "As_Sent_Folder"); - gal_view_instance_load (emfv->view_instance); + gal_view_instance_load(p->view_instance); - if (!gal_view_instance_exists (emfv->view_instance)) { + if (!gal_view_instance_exists(p->view_instance)) { struct stat st; char *path; @@ -461,15 +472,20 @@ emfv_create_view_instance(EMFolderView *emfv) gal_view_etable_set_state (GAL_VIEW_ETABLE (view), state); g_object_unref (state); - gal_view_instance_set_custom_view (emfv->view_instance, view); + gal_view_instance_set_custom_view(p->view_instance, view); g_object_unref (view); } g_free (path); } + + g_signal_connect(p->view_instance, "display_view", G_CALLBACK(emfv_list_display_view), emfv); + emfv_list_display_view(p->view_instance, gal_view_instance_get_current_view(p->view_instance), emfv); - g_signal_connect (emfv->view_instance, "display_view", G_CALLBACK (emfv_list_display_view), emfv); - emfv_list_display_view (emfv->view_instance, gal_view_instance_get_current_view (emfv->view_instance), emfv); + if (emfv->list_active && emfv->uic) { + p->view_menus = gal_view_menus_new(p->view_instance); + gal_view_menus_apply(p->view_menus, emfv->uic, NULL); + } } /* ********************************************************************** */ @@ -506,7 +522,7 @@ emfv_set_folder(EMFolderView *emfv, CamelFolder *folder, const char *uri) camel_object_ref(folder); mail_refresh_folder(folder, NULL, NULL); /* We need to set this up to get the right view options for the message-list, even if we're not showing it */ - emfv_create_view_instance(emfv); + emfv_setup_view_instance(emfv); } emfv_enable_menus(emfv); @@ -1708,6 +1724,8 @@ emfv_charset_changed(BonoboUIComponent *uic, const char *path, Bonobo_UIComponen static void emfv_activate(EMFolderView *emfv, BonoboUIComponent *uic, int act) { + struct _EMFolderViewPrivate *p = emfv->priv; + if (act) { em_format_mode_t style; gboolean state; @@ -1744,7 +1762,7 @@ emfv_activate(EMFolderView *emfv, BonoboUIComponent *uic, int act) /* We need to set this up to get the right view options for the message-list, even if we're not showing it */ if (emfv->folder) - emfv_create_view_instance(emfv); + emfv_setup_view_instance(emfv); } else { const BonoboUIVerb *v; @@ -1752,9 +1770,14 @@ emfv_activate(EMFolderView *emfv, BonoboUIComponent *uic, int act) for (v = &emfv_message_verbs[0]; v->cname; v++) bonobo_ui_component_remove_verb(uic, v->cname); - if (emfv->view_instance) { - g_object_unref(emfv->view_instance); - emfv->view_instance = NULL; + if (p->view_instance) { + g_object_unref(p->view_instance); + p->view_instance = NULL; + } + + if (p->view_menus) { + g_object_unref(p->view_menus); + p->view_menus = NULL; } if (emfv->folder) |