2007-05-23 Murray Cumming <murrayc@murrayc.com>
[modest] / src / widgets / modest-main-window.h
index fe0c2d6..6a4b130 100644 (file)
@@ -54,23 +54,37 @@ 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,
+} ModestMainWindowContentsStyle;
+
+/* toolbar modes  */
+typedef enum _ModestToolBarModes {
+       TOOLBAR_MODE_NORMAL,
+       TOOLBAR_MODE_TRANSFER,  
+} ModestToolBarModes;
+
 /**
  * modest_main_window_get_type:
  * 
@@ -90,6 +104,75 @@ 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_WIDGET_TYPE_HEADER_VIEW,
+       MODEST_WIDGET_TYPE_FOLDER_VIEW,
+       MODEST_WIDGET_TYPE_MSG_PREVIEW,
+       
+       MODEST_WIDGET_TYPE_NUM,
+} ModestWidgetType;
+
+
+/**
+ * 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,
+                                               ModestWidgetType widget_type);
+
+/**
+ * modest_main_window_close_all:
+ * @self: 
+ * 
+ * this function will ask the user about if the user wants to close
+ * all the windows or just the main one
+ * 
+ * Returns: TRUE if the user selected to close all the windows, otherwise FALSE
+ **/
+gboolean   modest_main_window_close_all        (ModestMainWindow *self);
+
+
+/**
+ * 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);
+
 
 G_END_DECLS