diff options
-rw-r--r-- | mail/ChangeLog | 13 | ||||
-rw-r--r-- | mail/Makefile.am | 1 | ||||
-rw-r--r-- | mail/folder-browser-factory.c | 7 | ||||
-rw-r--r-- | mail/mail-ops.c | 44 | ||||
-rw-r--r-- | mail/mail-view.c | 129 | ||||
-rw-r--r-- | mail/mail.h | 5 |
6 files changed, 199 insertions, 0 deletions
diff --git a/mail/ChangeLog b/mail/ChangeLog index 760b678752..0ec5dce9bc 100644 --- a/mail/ChangeLog +++ b/mail/ChangeLog @@ -1,5 +1,18 @@ 2000-08-07 Jeffrey Stedfast <fejj@helixcode.com> + * Makefile.am: Added mail-view.c + + * folder-browser-factory.c (control_activate): Adda menu item for + viewing the message + + * mail-view.c: New file containing methods for viewing messages in + separate windows + + * mail-ops.c (view_message): New callback for viewing messages in + a new window. + +2000-08-07 Jeffrey Stedfast <fejj@helixcode.com> + * component-factory.c (real_create_generic_storage): New function to replace real_create_imap_storage and real_create_news_storage (create_imap_storage): Updated. diff --git a/mail/Makefile.am b/mail/Makefile.am index 5386741906..faeddf2dfa 100644 --- a/mail/Makefile.am +++ b/mail/Makefile.am @@ -53,6 +53,7 @@ evolution_mail_SOURCES = \ mail-threads.h \ mail-types.h \ mail-vfolder.c \ + mail-view.c \ main.c \ message-list.c \ message-list.h \ diff --git a/mail/folder-browser-factory.c b/mail/folder-browser-factory.c index 2b034522b0..c391c5023d 100644 --- a/mail/folder-browser-factory.c +++ b/mail/folder-browser-factory.c @@ -79,6 +79,12 @@ control_activate (BonoboControl *control, BonoboUIHandler *uih, GNOME_STOCK_PIXMAP_MAIL_NEW, 0, 0, edit_message, folder_browser); + bonobo_ui_handler_menu_new_item (uih, "/Actions/View Message", _("_View Message"), + NULL, -1, + BONOBO_UI_HANDLER_PIXMAP_STOCK, + GNOME_STOCK_PIXMAP_MAIL_NEW, + 0, 0, view_message, folder_browser); + bonobo_ui_handler_menu_new_item (uih, "/Actions/Expunge", _("_Expunge"), NULL, -1, BONOBO_UI_HANDLER_PIXMAP_STOCK, @@ -143,6 +149,7 @@ control_deactivate (BonoboControl *control, BonoboUIHandler *uih, bonobo_ui_handler_menu_remove (uih, "/View/Threaded"); bonobo_ui_handler_menu_remove (uih, "/Actions/Mark all seen"); bonobo_ui_handler_menu_remove (uih, "/Actions/Edit Message"); + bonobo_ui_handler_menu_remove (uih, "/Actions/View Message"); bonobo_ui_handler_menu_remove (uih, "/Actions/Expunge"); bonobo_ui_handler_menu_remove (uih, "/Tools/Mail Filters ..."); bonobo_ui_handler_menu_remove (uih, "/Tools/vFolder Editor ..."); diff --git a/mail/mail-ops.c b/mail/mail-ops.c index 41211d20ea..768856a6f3 100644 --- a/mail/mail-ops.c +++ b/mail/mail-ops.c @@ -1028,3 +1028,47 @@ print_msg (GtkWidget *button, gpointer user_data) gtk_object_unref (GTK_OBJECT (print_master)); } + +struct view_msg_data { + FolderBrowser *fb; + CamelException *ex; +}; + +static void +real_view_msg (MessageList *ml, const char *uid, gpointer user_data) +{ + struct view_msg_data *data = user_data; + CamelMimeMessage *msg; + GtkWidget *view; + + if (camel_exception_is_set (data->ex)) + return; + + msg = camel_folder_get_message (ml->folder, uid, data->ex); + + view = mail_view_create (msg, data->fb); + + gtk_widget_show (view); +} + +void +view_message (BonoboUIHandler *uih, void *user_data, const char *path) +{ + struct view_msg_data data; + FolderBrowser *fb = user_data; + CamelException ex; + MessageList *ml; + + camel_exception_init (&ex); + + data.fb = fb; + data.ex = &ex; + + ml = fb->message_list; + message_list_foreach (ml, real_view_msg, &data); + if (camel_exception_is_set (&ex)) { + mail_exception_dialog ("Could not open message for viewing", &ex, fb); + camel_exception_clear (&ex); + return; + } +} diff --git a/mail/mail-view.c b/mail/mail-view.c new file mode 100644 index 0000000000..72ed83654d --- /dev/null +++ b/mail/mail-view.c @@ -0,0 +1,129 @@ +/* -*- Mode: C; tab-width: 8; indent-tabs-mode: t; c-basic-offset: 8 -*- */ +/* + * Authors: Jeffrey Stedfast <fejj@helixcode.com> + * + * Copyright 2000 Helix Code, Inc. (www.helixcode.com) + * + * 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 + * the Free Software Foundation; either version 2 of the License, or + * (at your option) any later version. + * + * 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 General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program; if not, write to the Free Software + * Foundation, Inc., 59 Temple Street #330, Boston, MA 02111-1307, USA. + * + */ + +#include <mail.h> +#include <camel.h> + +static void +on_close (GtkWidget *menuitem, gpointer user_data) +{ + GtkWidget *view; + + view = gtk_widget_get_toplevel (menuitem); + + gtk_widget_destroy (view); +} + +static GnomeUIInfo mail_view_toolbar [] = { + + /*GNOMEUIINFO_ITEM_STOCK (N_("Save"), N_("Save this message"), + save_msg, GNOME_STOCK_PIXMAP_SAVE),*/ + + GNOMEUIINFO_ITEM_STOCK (N_("Reply"), N_("Reply to the sender of this message"), + reply_to_sender, GNOME_STOCK_PIXMAP_MAIL_RPL), + + GNOMEUIINFO_ITEM_STOCK (N_("Reply to All"), N_("Reply to all recipients of this message"), + reply_to_all, GNOME_STOCK_PIXMAP_MAIL_RPL), + + GNOMEUIINFO_ITEM_STOCK (N_("Forward"), N_("Forward this message"), forward_msg, GNOME_STOCK_PIXMAP_MAIL_FWD), + + GNOMEUIINFO_SEPARATOR, + + GNOMEUIINFO_ITEM_STOCK (N_("Print"), N_("Print the selected message"), print_msg, GNOME_STOCK_PIXMAP_PRINT), + + GNOMEUIINFO_ITEM_STOCK (N_("Delete"), N_("Delete this message"), delete_msg, GNOME_STOCK_PIXMAP_TRASH), + + GNOMEUIINFO_SEPARATOR, + + /*GNOMEUIINFO_ITEM_STOCK (N_("Next"), N_("Next message"), mail_view_next_msg, GNOME_STOCK_PIXMAP_NEXT), + + GNOMEUIINFO_ITEM_STOCK (N_("Previous"), N_("Previous message"), mail_view_prev__msg, GNOME_STOCK_PIXMAP_PREVIOUS),*/ + + GNOMEUIINFO_END +}; + +static GnomeUIInfo file_menu[] = { + /*GNOMEUIINFO_MENU_SAVE_ITEM (save, NULL),*/ + /*GNOMEUIINFO_MENU_SAVE_AS_ITEM (save_as, NULL),*/ + /*GNOMEUIINFO_SEPARATOR,*/ + GNOMEUIINFO_MENU_CLOSE_ITEM (on_close, NULL), + GNOMEUIINFO_END +}; + +static GnomeUIInfo view_menu[] = +{ + GNOMEUIINFO_END +}; + +static GnomeUIInfo mail_view_menubar[] = +{ + GNOMEUIINFO_MENU_FILE_TREE (file_menu), + GNOMEUIINFO_MENU_VIEW_TREE (view_menu), + GNOMEUIINFO_END +}; + +GtkWidget * +mail_view_create (CamelMimeMessage *msg, FolderBrowser *folder_browser) +{ + GtkWidget *window; + GtkWidget *toolbar; + GtkWidget *mail_display; + char *subject; + + subject = (char *) camel_mime_message_get_subject (msg); + if (!subject) + subject = ""; + + window = gnome_app_new ("Evolution", subject); + toolbar = gtk_toolbar_new (GTK_ORIENTATION_HORIZONTAL, GTK_TOOLBAR_BOTH); + + gnome_app_fill_toolbar_with_data (GTK_TOOLBAR (toolbar), + mail_view_toolbar, + NULL, folder_browser); + + gnome_app_set_toolbar (GNOME_APP (window), GTK_TOOLBAR (toolbar)); + + gnome_app_create_menus (GNOME_APP (window), mail_view_menubar); + + gtk_widget_ref (mail_view_menubar[0].widget); + gtk_object_set_data_full (GTK_OBJECT (window), "file", + mail_view_menubar[0].widget, + (GtkDestroyNotify) gtk_widget_unref); + + gtk_widget_ref (file_menu[0].widget); + gtk_object_set_data_full (GTK_OBJECT (window), "close", + file_menu[0].widget, + (GtkDestroyNotify) gtk_widget_unref); + + gtk_widget_ref (mail_view_menubar[1].widget); + gtk_object_set_data_full (GTK_OBJECT (window), "view", + mail_view_menubar[1].widget, + (GtkDestroyNotify) gtk_widget_unref); + + mail_display = mail_display_new (folder_browser); + mail_display_set_message (MAIL_DISPLAY (mail_display), CAMEL_MEDIUM (msg)); + gtk_widget_set_usize (mail_display, 600, 600); + + gnome_app_set_contents (GNOME_APP (window), mail_display); + + return window; +} diff --git a/mail/mail.h b/mail/mail.h index 4643fc8be5..26a6276a80 100644 --- a/mail/mail.h +++ b/mail/mail.h @@ -22,6 +22,7 @@ #include "camel/camel.h" #include "composer/e-msg-composer.h" #include "mail-config.h" +#include "folder-browser.h" /* FIXME FIXME FIXME this sucks sucks sucks sucks */ @@ -71,11 +72,15 @@ void print_msg (GtkWidget *button, gpointer user_data); void mark_all_seen (BonoboUIHandler *uih, void *user_data, const char *path); void edit_message (BonoboUIHandler *uih, void *user_data, const char *path); +void view_message (BonoboUIHandler *uih, void *user_data, const char *path); void expunge_folder (BonoboUIHandler *uih, void *user_data, const char *path); void filter_edit (BonoboUIHandler *uih, void *user_data, const char *path); void vfolder_edit_vfolders (BonoboUIHandler *uih, void *user_data, const char *path); void providers_config (BonoboUIHandler *uih, void *user_data, const char *path); +/* mail view */ +GtkWidget *mail_view_create (CamelMimeMessage *msg, FolderBrowser *folder_browser); + /* session */ void session_init (void); char *mail_request_dialog (const char *prompt, gboolean secret, const char *key); |