2000-11-03 Not Zed <NotZed@HelixCode.com> * mail-view.c: Added mail-display.h. * mail-autofilter.c: Removed unecessary headers. Who ran indent over this code? Sigh. * mail-ops.c (display_message_input_s): Added messagedisplay. (mail_do_display_message): Added messagedisplay arg. (mail_do_display_message): Dont bother doing another thread when we know we dont have a uid. (): Added folder-browser.h to headers. Sigh. * folder-browser-factory.c (control_activate): Setup the viewthreaded callback to the folder_browser function. * folder-browser.c (my_folder_browser_init): Connect to right_click of etable of the messagelist here. (on_right_click): Changed for argument changes. (folder_browser_toggle_threads): Changed to take a fb, and to set threaded mode on the messagelist. (my_folder_browser_init): Connect also to the double_click signal. (my_folder_browser_init): Connect to the message_selected signal of the message_list. (on_message_selected): Signal handler for message selected. (my_folder_browser_init): Fix for change to message_list_new(). * message-list.h: Dont include folder-browser.h. (message_list_toggle_threads): Moved into folder-browser.h. (struct _MessageList): Removed folderbrowser. * mail.h: Dont include folder-browser.h here either, but mail-types.h instead. Moved prototypes moved into folder-browser.c into folder-browser.h. (vfolder_*, filter_*). * mail-display.h: Dont include folder-browser.h here, but mail-types.h and specific camel headers. * message-thread.c (sort_node): Invert the sort order logic so the list is sorted in mailbox order, not reverse mailbox order. * message-list.c (free_tree_ids): Fix a merge foo. (remove_node_diff): Removed unused row argument. Fixed callers/prototype. (clear_tree): pre_change on the removal of the root node. (build_flat): Only perform pre_change if we are rebuilding the whole lot. For incremental change let etable do its thing. (build_tree): Likewise for building the tree view. If making incremental updates, do them as we build it. (vfolder_subject): (vfolder_sender): (vfolder_recipient): (filter_subject): (filter_sender): (filter_recipient): (filter_mlist): (on_right_click): Moved to folder-browser.c, where they belong. (message_list_init): Dont connect to right_click anymore. (message_list_toggle_threads): Moved to folder-browser.c, renamed. (on_double_click): Moved to folder-browser.c (on_click): Set the flags directly, rather than in anothre thread, which is just not necessary. (message_list_class_init): Added a new signal 'message_selected', to indicate when a message was selected. (on_cursor_change_idle): Emit a signal, rather than directly triggering the display update. (select_row): Removed, no longer used. (idle_select_row): And this too. (select_msg): Removed as well. (message_list_select): Emit a signal, rather thandisplaying/clearing the mail-display directly. (mark_msg_seen): Moved to folder-browser.c (message_list_new): Removed folderbrowser argument. svn path=/trunk/; revision=6365
93 lines
2.8 KiB
C
93 lines
2.8 KiB
C
/* -*- Mode: C; tab-width: 8; indent-tabs-mode: t; c-basic-offset: 8 -*- */
|
|
|
|
|
|
#ifndef _FOLDER_BROWSER_H_
|
|
#define _FOLDER_BROWSER_H_
|
|
|
|
#include "mail-types.h"
|
|
#include <gtk/gtktable.h>
|
|
#include "camel/camel-stream.h"
|
|
#include <bonobo/bonobo-property-bag.h>
|
|
#include "filter/filter-rule.h"
|
|
#include "filter/filter-context.h" /*eek*/
|
|
#include "message-list.h"
|
|
#include "mail-display.h"
|
|
#include "shell/Evolution.h"
|
|
|
|
|
|
#define FOLDER_BROWSER_TYPE (folder_browser_get_type ())
|
|
#define FOLDER_BROWSER(o) (GTK_CHECK_CAST ((o), FOLDER_BROWSER_TYPE, FolderBrowser))
|
|
#define FOLDER_BROWSER_CLASS(k) (GTK_CHECK_CLASS_CAST((k), FOLDER_BROWSER_TYPE, FolderBrowserClass))
|
|
#define IS_FOLDER_BROWSER(o) (GTK_CHECK_TYPE ((o), FOLDER_BROWSER_TYPE))
|
|
#define IS_FOLDER_BROWSER_CLASS(k) (GTK_CHECK_CLASS_TYPE ((k), FOLDER_BROWSER_TYPE))
|
|
|
|
struct _FolderBrowser {
|
|
GtkTable parent;
|
|
|
|
BonoboPropertyBag *properties;
|
|
|
|
Evolution_Shell shell;
|
|
|
|
/* This is a kludge for the toolbar problem. */
|
|
int serial;
|
|
|
|
/*
|
|
* The current URI being displayed by the FolderBrowser
|
|
*/
|
|
char *uri;
|
|
CamelFolder *folder;
|
|
|
|
MessageList *message_list;
|
|
GtkWidget *message_list_w;
|
|
MailDisplay *mail_display;
|
|
GtkWidget *vpaned;
|
|
GtkWidget *search_menu;
|
|
GtkWidget *search_entry;
|
|
FilterRule *search_full; /* if we have a full search active */
|
|
|
|
gboolean preview_shown;
|
|
|
|
/* Stuff to allow on-demand filtering */
|
|
GSList *filter_menu_paths;
|
|
FilterContext *filter_context;
|
|
};
|
|
|
|
|
|
typedef struct {
|
|
GtkTableClass parent_class;
|
|
} FolderBrowserClass;
|
|
|
|
struct fb_ondemand_closure {
|
|
FilterRule *rule;
|
|
FolderBrowser *fb;
|
|
gchar *path;
|
|
};
|
|
|
|
GtkType folder_browser_get_type (void);
|
|
GtkWidget *folder_browser_new (const Evolution_Shell shell);
|
|
|
|
gboolean folder_browser_set_uri (FolderBrowser *folder_browser,
|
|
const char *uri);
|
|
|
|
void folder_browser_set_message_preview (FolderBrowser *folder_browser,
|
|
gboolean show_message_preview);
|
|
void folder_browser_clear_search (FolderBrowser *fb);
|
|
|
|
/* callbacks for functions on the folder-browser */
|
|
void vfolder_subject (GtkWidget *w, FolderBrowser *fb);
|
|
void vfolder_sender (GtkWidget *w, FolderBrowser *fb);
|
|
void vfolder_recipient (GtkWidget *w, FolderBrowser *fb);
|
|
|
|
void filter_subject (GtkWidget *w, FolderBrowser *fb);
|
|
void filter_sender (GtkWidget *w, FolderBrowser *fb);
|
|
void filter_recipient (GtkWidget *w, FolderBrowser *fb);
|
|
void filter_mlist (GtkWidget *w, FolderBrowser *fb);
|
|
|
|
void folder_browser_toggle_threads (BonoboUIComponent *component,
|
|
const char *path,
|
|
Bonobo_UIComponent_EventType type,
|
|
const char *state,
|
|
gpointer user_data);
|
|
|
|
#endif /* _FOLDER_BROWSER_H_ */
|