X-Git-Url: http://git.maemo.org/git/?p=modest;a=blobdiff_plain;f=src%2Fwidgets%2Fmodest-main-window.h;h=1256cc2c6fbcd3ea9c52cab152161163535e0b4f;hp=7cbe801ef22ff28639248f6f7759c5e232c0c19d;hb=1607d4b15dc3b82e6dcc07ed06aba900f4c22d17;hpb=96e1a73bf56f41cfe52d4bf6419fccecc067ad79 diff --git a/src/widgets/modest-main-window.h b/src/widgets/modest-main-window.h index 7cbe801..1256cc2 100644 --- a/src/widgets/modest-main-window.h +++ b/src/widgets/modest-main-window.h @@ -31,12 +31,12 @@ #ifndef __MODEST_MAIN_WINDOW_H__ #define __MODEST_MAIN_WINDOW_H__ -#ifdef HAVE_CONFIG_H -#include -#endif /*HAVE_CONFIG_H*/ - -#include +#include #include +#include +#include +#include +#include G_BEGIN_DECLS @@ -54,21 +54,171 @@ typedef struct _ModestMainWindowClass ModestMainWindowClass; struct _ModestMainWindow { ModestWindow parent; - /* insert public members, if any */ }; struct _ModestMainWindowClass { ModestWindowClass parent_class; - /* insert signal callback declarations, eg. */ - /* void (* my_event) (ModestMainWindow* obj); */ }; -/* member functions */ +/* + * 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, +} ModestMainWindowContentsStyle; + +/* toolbar modes */ +typedef enum _ModestToolBarModes { + TOOLBAR_MODE_NORMAL, + TOOLBAR_MODE_TRANSFER, +} ModestToolBarModes; + +/** + * modest_main_window_get_type: + * + * get the GType for the ModestMainWindow class + * + * Returns: a GType for ModestMainWindow + */ GType modest_main_window_get_type (void) G_GNUC_CONST; -GtkWidget* modest_main_window_new (ModestWidgetFactory *factory, - GtkUIManager *ui_manager); +/** + * modest_main_window_new + * + * instantiates a new ModestMainWindow widget + * + * Returns: a new ModestMainWindow, or NULL in case of error + */ +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); G_END_DECLS