diff options
author | Jeffrey Stedfast <fejj@ximian.com> | 2001-04-24 05:16:00 +0800 |
---|---|---|
committer | Jeffrey Stedfast <fejj@src.gnome.org> | 2001-04-24 05:16:00 +0800 |
commit | 373b8669f5e8b377ba0d17d938641e8650551abb (patch) | |
tree | d63d1ce1faa9fc617c84058fa6ad704580eaf7fc /mail/message-browser.c | |
parent | 23faa57aef230148a5ab1c746a325be4ba029b02 (diff) | |
download | gsoc2013-evolution-373b8669f5e8b377ba0d17d938641e8650551abb.tar gsoc2013-evolution-373b8669f5e8b377ba0d17d938641e8650551abb.tar.gz gsoc2013-evolution-373b8669f5e8b377ba0d17d938641e8650551abb.tar.bz2 gsoc2013-evolution-373b8669f5e8b377ba0d17d938641e8650551abb.tar.lz gsoc2013-evolution-373b8669f5e8b377ba0d17d938641e8650551abb.tar.xz gsoc2013-evolution-373b8669f5e8b377ba0d17d938641e8650551abb.tar.zst gsoc2013-evolution-373b8669f5e8b377ba0d17d938641e8650551abb.zip |
Use the message-browser widget rather than the mail-view window.
2001-04-23 Jeffrey Stedfast <fejj@ximian.com>
* mail-callbacks.c (do_view_message): Use the message-browser
widget rather than the mail-view window.
* mail-view.c: Removed.
* folder-browser.c: Added a folder_loaded signal.
* message-browser.[c,h]: New window to solve all our message
browsing needs. This replaces mail-view.c.
* message-list.c (message_list_select_uid): New function needed by
the new message-browser window.
svn path=/trunk/; revision=9525
Diffstat (limited to 'mail/message-browser.c')
-rw-r--r-- | mail/message-browser.c | 282 |
1 files changed, 282 insertions, 0 deletions
diff --git a/mail/message-browser.c b/mail/message-browser.c new file mode 100644 index 0000000000..2286772f50 --- /dev/null +++ b/mail/message-browser.c @@ -0,0 +1,282 @@ +/* -*- Mode: C; tab-width: 8; indent-tabs-mode: t; c-basic-offset: 8 -*- */ +/* + * Authors: Jeffrey Stedfast <fejj@ximian.com> + * + * Copyright 2001 Ximian, Inc. (www.ximian.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. + * + */ + +#ifdef HAVE_CONFIG_H +#include <config.h> +#endif + +#include "message-browser.h" + +#include "mail.h" +#include "mail-callbacks.h" +#include "mail-tools.h" +#include "message-list.h" +#include "mail-ops.h" +#include "mail-vfolder.h" +#include "mail-autofilter.h" +#include "mail-mlist-magic.h" +#include "mail-mt.h" + +#include "mail-local.h" +#include "mail-config.h" + +#define d(x) x + +#define MINIMUM_WIDTH 600 +#define MINIMUM_HEIGHT 400 + +#define PARENT_TYPE (gnome_app_get_type ()) + +/* Size of the window last time it was changed. */ +static GtkAllocation last_allocation = { 0, 0 }; + +static GnomeAppClass *message_browser_parent_class; + +static void +message_browser_destroy (GtkObject *object) +{ + MessageBrowser *message_browser; + + message_browser = MESSAGE_BROWSER (object); + + gtk_object_unref (GTK_OBJECT (message_browser->fb)); + + gtk_widget_destroy (GTK_WIDGET (message_browser)); +} + +static void +message_browser_class_init (GtkObjectClass *object_class) +{ + object_class->destroy = message_browser_destroy; + + message_browser_parent_class = gtk_type_class (PARENT_TYPE); +} + +static void +message_browser_init (GtkObject *object) +{ + +} + +static void +message_browser_close (GtkWidget *menuitem, gpointer user_data) +{ + gtk_widget_destroy (GTK_WIDGET (user_data)); +} + +static void +message_browser_reply_to_sender (GtkWidget *widget, gpointer user_data) +{ + MessageBrowser *mb = MESSAGE_BROWSER (user_data); + + reply_to_sender (NULL, mb->fb); +} + +static void +message_browser_reply_to_all (GtkWidget *widget, gpointer user_data) +{ + MessageBrowser *mb = MESSAGE_BROWSER (user_data); + + reply_to_all (NULL, mb->fb); +} + +static void +message_browser_forward_msg (GtkWidget *widget, gpointer user_data) +{ + MessageBrowser *mb = MESSAGE_BROWSER (user_data); + + forward_attached (NULL, mb->fb); +} + +static void +message_browser_print_msg (GtkWidget *widget, gpointer user_data) +{ + MessageBrowser *mb = MESSAGE_BROWSER (user_data); + + mail_print_msg (mb->fb->mail_display); +} + +static void +message_browser_delete_msg (GtkWidget *button, gpointer user_data) +{ + MessageBrowser *mb = MESSAGE_BROWSER (user_data); + + delete_msg (NULL, mb->fb); +} + +static void +message_browser_next_msg (GtkWidget *button, gpointer user_data) +{ + MessageBrowser *mb = MESSAGE_BROWSER (user_data); + + next_msg (NULL, mb->fb); +} + +static void +message_browser_prev_msg (GtkWidget *button, gpointer user_data) +{ + MessageBrowser *mb = MESSAGE_BROWSER (user_data); + + previous_msg (NULL, mb->fb); +} + +static void +message_browser_message_selected (MessageList *ml, const char *uid, MessageBrowser *mb) +{ + CamelMimeMessage *message; + char *subject = NULL; + + g_warning ("got 'message_selected' event"); + + message = mb->fb->mail_display->current_message; + + if (message) + subject = (char *) camel_mime_message_get_subject (message); + + gtk_window_set_title (GTK_WINDOW (mb), subject ? subject : ""); +} + +static void +message_browser_folder_loaded (FolderBrowser *fb, const char *uri, MessageBrowser *mb) +{ + const char *uid = gtk_object_get_data (GTK_OBJECT (mb), "uid"); + + g_warning ("got 'folder_loaded' event"); + + gtk_signal_connect (GTK_OBJECT (fb->message_list), "message_selected", + message_browser_message_selected, mb); + + message_list_select_uid (fb->message_list, uid); +} + +static GnomeUIInfo message_browser_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"), + message_browser_reply_to_sender, GNOME_STOCK_PIXMAP_MAIL_RPL), + + GNOMEUIINFO_ITEM_STOCK (N_("Reply to All"), N_("Reply to all recipients of this message"), + message_browser_reply_to_all, GNOME_STOCK_PIXMAP_MAIL_RPL), + + GNOMEUIINFO_ITEM_STOCK (N_("Forward"), N_("Forward this message"), + message_browser_forward_msg, GNOME_STOCK_PIXMAP_MAIL_FWD), + + GNOMEUIINFO_SEPARATOR, + + GNOMEUIINFO_ITEM_STOCK (N_("Print"), N_("Print the selected message"), + message_browser_print_msg, GNOME_STOCK_PIXMAP_PRINT), + + GNOMEUIINFO_ITEM_STOCK (N_("Delete"), N_("Delete this message"), + message_browser_delete_msg, GNOME_STOCK_PIXMAP_TRASH), + + GNOMEUIINFO_SEPARATOR, + + GNOMEUIINFO_ITEM_STOCK (N_("Previous"), N_("Previous message"), + message_browser_prev_msg, GNOME_STOCK_PIXMAP_BACK), + + GNOMEUIINFO_ITEM_STOCK (N_("Next"), N_("Next message"), + message_browser_next_msg, GNOME_STOCK_PIXMAP_FORWARD), + + 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 (message_browser_close, NULL), + GNOMEUIINFO_END +}; + +static GnomeUIInfo view_menu[] = +{ + GNOMEUIINFO_END +}; + +static GnomeUIInfo message_browser_menubar[] = +{ + GNOMEUIINFO_MENU_FILE_TREE (file_menu), + GNOMEUIINFO_MENU_VIEW_TREE (view_menu), + GNOMEUIINFO_END +}; + +static void +set_default_size (GtkWidget *widget) +{ + int width, height; + + width = MAX (MINIMUM_WIDTH, last_allocation.width); + height = MAX (MINIMUM_HEIGHT, last_allocation.height); + + gtk_window_set_default_size (GTK_WINDOW (widget), width, height); +} + +GtkWidget * +message_browser_new (const GNOME_Evolution_Shell shell, const char *uri, const char *uid) +{ + GtkWidget *toolbar, *vbox; + MessageBrowser *new; + FolderBrowser *fb; + + new = gtk_type_new (message_browser_get_type ()); + + gnome_app_construct (GNOME_APP (new), "Evolution", ""); + + gtk_object_set_data_full (GTK_OBJECT (new), "uid", g_strdup (uid), g_free); + + toolbar = gtk_toolbar_new (GTK_ORIENTATION_HORIZONTAL, GTK_TOOLBAR_BOTH); + gnome_app_fill_toolbar_with_data (GTK_TOOLBAR (toolbar), + message_browser_toolbar, + NULL, new); + + gnome_app_set_toolbar (GNOME_APP (new), GTK_TOOLBAR (toolbar)); + gnome_app_create_menus (GNOME_APP (new), message_browser_menubar); + + fb = FOLDER_BROWSER (folder_browser_new (shell)); + new->fb = fb; + + /* some evil hackery action... */ + vbox = gtk_vbox_new (TRUE, 0); + gtk_widget_ref (GTK_WIDGET (fb->mail_display)); + gtk_widget_reparent (GTK_WIDGET (fb->mail_display), vbox); + gtk_widget_show (GTK_WIDGET (fb->mail_display)); + gtk_widget_show (vbox); + + gnome_app_set_contents (GNOME_APP (new), vbox); + gtk_widget_grab_focus (GTK_WIDGET (MAIL_DISPLAY (fb->mail_display)->html)); + + set_default_size (GTK_WIDGET (new)); + + /* more evil hackery... */ + gtk_signal_connect (GTK_OBJECT (fb), "folder_loaded", + message_browser_folder_loaded, new); + + folder_browser_set_uri (fb, uri); + + return GTK_WIDGET (new); +} + + +E_MAKE_TYPE (message_browser, "MessageBrowser", MessageBrowser, message_browser_class_init, + message_browser_init, PARENT_TYPE); |