1 /* Copyright (c) 2006,2007 Nokia Corporation
4 * Redistribution and use in source and binary forms, with or without
5 * modification, are permitted provided that the following conditions are
8 * * Redistributions of source code must retain the above copyright
9 * notice, this list of conditions and the following disclaimer.
10 * * Redistributions in binary form must reproduce the above copyright
11 * notice, this list of conditions and the following disclaimer in the
12 * documentation and/or other materials provided with the distribution.
13 * * Neither the name of the Nokia Corporation nor the names of its
14 * contributors may be used to endorse or promote products derived from
15 * this software without specific prior written permission.
17 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS
18 * IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
19 * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A
20 * PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER
21 * OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
22 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
23 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
24 * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
25 * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
26 * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
27 * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
31 #ifndef __MODEST_MAIN_WINDOW_H__
32 #define __MODEST_MAIN_WINDOW_H__
34 #include <gtk/gtkwidget.h>
35 #include <widgets/modest-window.h>
36 #include <widgets/modest-header-view.h>
37 #include <widgets/modest-folder-view.h>
38 #include <widgets/modest-msg-view.h>
43 /* convenience macros */
44 #define MODEST_TYPE_MAIN_WINDOW (modest_main_window_get_type())
45 #define MODEST_MAIN_WINDOW(obj) (G_TYPE_CHECK_INSTANCE_CAST((obj),MODEST_TYPE_MAIN_WINDOW,ModestMainWindow))
46 #define MODEST_MAIN_WINDOW_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST((klass),MODEST_TYPE_MAIN_WINDOW,ModestWindow))
48 #define MODEST_IS_MAIN_WINDOW(obj) (G_TYPE_CHECK_INSTANCE_TYPE((obj),MODEST_TYPE_MAIN_WINDOW))
49 #define MODEST_IS_MAIN_WINDOW_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE((klass),MODEST_TYPE_MAIN_WINDOW))
50 #define MODEST_MAIN_WINDOW_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS((obj),MODEST_TYPE_MAIN_WINDOW,ModestMainWindowClass))
52 typedef struct _ModestMainWindow ModestMainWindow;
53 typedef struct _ModestMainWindowClass ModestMainWindowClass;
55 struct _ModestMainWindow {
59 struct _ModestMainWindowClass {
60 ModestWindowClass parent_class;
63 typedef enum _ModestMainWindowStyle {
64 MODEST_MAIN_WINDOW_STYLE_SIMPLE,
65 MODEST_MAIN_WINDOW_STYLE_SPLIT
66 } ModestMainWindowStyle;
69 * modest_main_window_get_type:
71 * get the GType for the ModestMainWindow class
73 * Returns: a GType for ModestMainWindow
75 GType modest_main_window_get_type (void) G_GNUC_CONST;
79 * modest_main_window_new
81 * instantiates a new ModestMainWindow widget
83 * Returns: a new ModestMainWindow, or NULL in case of error
85 ModestWindow* modest_main_window_new (void);
88 * we could use the GType instead, but that would require
89 * that there only on widget of a certain type; that is
90 * true now, but might not be. Therefore, these types
93 MODEST_WIDGET_TYPE_HEADER_VIEW,
94 MODEST_WIDGET_TYPE_FOLDER_VIEW,
95 MODEST_WIDGET_TYPE_MSG_PREVIEW,
97 MODEST_WIDGET_TYPE_NUM,
102 * modest_main_window_get_child_widget
104 * get a child window for this window
106 * Returns: a child window or NULL
108 GtkWidget* modest_main_window_get_child_widget (ModestMainWindow *self,
109 ModestWidgetType widget_type);
112 * modest_main_window_close_all:
115 * this function will ask the user about if the user wants to close
116 * all the windows or just the main one
118 * Returns: TRUE if the user selected to close all the windows, otherwise FALSE
120 gboolean modest_main_window_close_all (ModestMainWindow *self);
124 * modest_main_window_set_style:
125 * @self: the #ModestMainWindow
126 * @style: a #ModestMainWindowStyle that will be set
128 * sets the style of the main window, a splitview with folders at
129 * the left and messages at the right, or the simple view, with just
132 void modest_main_window_set_style (ModestMainWindow *self,
133 ModestMainWindowStyle style);
136 * modest_main_window_get_style:
139 * gets the current show style of the main window
141 * Return value: the current #ModestWindowStyle
143 ModestMainWindowStyle modest_main_window_get_style (ModestMainWindow *self);
147 #endif /* __MODEST_MAIN_WINDOW_H__ */