X-Git-Url: http://git.maemo.org/git/?a=blobdiff_plain;f=src%2Fwidgets%2Fmodest-main-window.h;h=de2a0aa341df108986d2c53b329cad1bf83c899e;hb=354a038d69d6b9ac42b49e6c6d3751f7978c4adb;hp=fe0c2d6254cf1a12398e2d04122f7ce7f052173b;hpb=8885ff625adf8c47b51e306b1d9a9ae4c8bb8d67;p=modest diff --git a/src/widgets/modest-main-window.h b/src/widgets/modest-main-window.h index fe0c2d6..de2a0aa 100644 --- a/src/widgets/modest-main-window.h +++ b/src/widgets/modest-main-window.h @@ -36,7 +36,7 @@ #include #include #include - +#include G_BEGIN_DECLS @@ -54,23 +54,39 @@ typedef struct _ModestMainWindowClass ModestMainWindowClass; struct _ModestMainWindow { ModestWindow parent; - - /* public members; - * NOTE: these can be NULL as not all frontends - * (gtk, maemo, ...) may use all of them. - */ - ModestHeaderView *header_view; - ModestFolderView *folder_view; - ModestMsgView *msg_preview; - - GtkWidget *status_bar; - GtkWidget *progress_bar; }; struct _ModestMainWindowClass { ModestWindowClass parent_class; }; +/* + * MODEST_MAIN_WINDOW_STYLE_SIMPLE: shows only the header list + * MODEST_MAIN_WINDOW_STYLE_SPLIT: shows a right pane with the folder + * tree and a left pane with the header list + */ +typedef enum _ModestMainWindowStyle { + MODEST_MAIN_WINDOW_STYLE_SIMPLE, + MODEST_MAIN_WINDOW_STYLE_SPLIT +} ModestMainWindowStyle; + +/* + * MODEST_MAIN_WINDOW_FOLDER_CONTENTS_STYLE_HEADERS + * MODEST_MAIN_WINDOW_FOLDER_CONTENTS_STYLE_HEADERS + */ +typedef enum _ModestMainWindowContentsStyle { + MODEST_MAIN_WINDOW_CONTENTS_STYLE_HEADERS, + MODEST_MAIN_WINDOW_CONTENTS_STYLE_DETAILS, + MODEST_MAIN_WINDOW_CONTENTS_STYLE_EMPTY, + MODEST_MAIN_WINDOW_CONTENTS_STYLE_FOLDERS, +} ModestMainWindowContentsStyle; + +/* toolbar modes */ +typedef enum _ModestToolBarModes { + TOOLBAR_MODE_NORMAL, + TOOLBAR_MODE_TRANSFER, +} ModestToolBarModes; + /** * modest_main_window_get_type: * @@ -90,6 +106,121 @@ GType modest_main_window_get_type (void) G_GNUC_CONST; */ ModestWindow* modest_main_window_new (void); +/* + * we could use the GType instead, but that would require + * that there only on widget of a certain type; that is + * true now, but might not be. Therefore, these types + */ +typedef enum { + MODEST_MAIN_WINDOW_WIDGET_TYPE_HEADER_VIEW, + MODEST_MAIN_WINDOW_WIDGET_TYPE_FOLDER_VIEW, + MODEST_MAIN_WINDOW_WIDGET_TYPE_MSG_PREVIEW, + + MODEST_MAIN_WINDOW_WIDGET_TYPE_NUM, +} ModestMainWindowWidgetType; + + +/** + * modest_main_window_get_child_widget + * + * get a child window for this window + * + * Returns: a child window or NULL + */ +GtkWidget* modest_main_window_get_child_widget (ModestMainWindow *self, + ModestMainWindowWidgetType widget_type); + + +/** + * modest_main_window_set_style: + * @self: the #ModestMainWindow + * @style: a #ModestMainWindowStyle that will be set + * + * sets the style of the main window, a splitview with folders at + * the left and messages at the right, or the simple view, with just + * messages. + **/ +void modest_main_window_set_style (ModestMainWindow *self, + ModestMainWindowStyle style); + +/** + * modest_main_window_get_style: + * @self: + * + * gets the current show style of the main window + * + * Return value: the current #ModestWindowStyle + **/ +ModestMainWindowStyle modest_main_window_get_style (ModestMainWindow *self); + +/** + * modest_main_window_set_contents_style: + * @self: the #ModestMainWindow + * @style: a #ModestMainWindowContentsStyle that will be set. Either headers or details. + * + * Shows either the folder details, or the header list of the current + * selected folder. + **/ +void modest_main_window_set_contents_style (ModestMainWindow *self, + ModestMainWindowContentsStyle style); + +/** + * modest_main_window_get_contents_style: + * @self: the #ModestMainWindow + * + * Gets the currently selected #ModestMainWindowContentsStyle + * + * Returns: the #ModestMainWindowContentsStyle of the main window + **/ +ModestMainWindowContentsStyle modest_main_window_get_contents_style (ModestMainWindow *self); + + + +/** + * modest_main_window_notify_send_receive_initied: + * @self: the #ModestMainWindow + * + * Determines if send&receive operaiton is currently in + * progress. + * + * Returns: TRUE if send$receive operaton is in + * progress, FALSE otherwise. + **/ +gboolean modest_main_window_send_receive_in_progress (ModestMainWindow *self); + +/** + * modest_main_window_notify_send_receive_initied: + * @self: the #ModestMainWindow + * + * Notifies main window that send/receive operaiton was just started. + **/ +void modest_main_window_notify_send_receive_initied (ModestMainWindow *self); + +/** + * modest_main_window_notify_send_receive_completed: + * @self: the #ModestMainWindow + * + * Notifies main window that send/receive operaiton was completed. + **/ +void modest_main_window_notify_send_receive_completed (ModestMainWindow *self); + + +gboolean modest_main_window_on_msg_view_window_msg_changed (ModestMsgViewWindow *view_window, + GtkTreeModel *model, + GtkTreeRowReference *row_reference, + ModestMainWindow *self); + +/** + * modest_main_window_transfer_mode_enabled: + * @window: a #ModestMainWindow + * + * Determines if some transfer operation is in progress. + * + * Returns: TRUE if transfer mode is enabled, FASE otherwise. +*/ +gboolean modest_main_window_transfer_mode_enabled (ModestMainWindow *self); + +gboolean modest_main_window_screen_is_on (ModestMainWindow *self); G_END_DECLS