2007-04-15 Sergio Villar Senin <svillar@igalia.com>
[modest] / src / widgets / modest-main-window.h
1 /* Copyright (c) 2006,2007 Nokia Corporation
2  * All rights reserved.
3  *
4  * Redistribution and use in source and binary forms, with or without
5  * modification, are permitted provided that the following conditions are
6  * met:
7  *
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.
16  *
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.
28  */
29
30
31 #ifndef __MODEST_MAIN_WINDOW_H__
32 #define __MODEST_MAIN_WINDOW_H__
33
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>
39
40
41 G_BEGIN_DECLS
42
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))
47
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))
51
52 typedef struct _ModestMainWindow      ModestMainWindow;
53 typedef struct _ModestMainWindowClass ModestMainWindowClass;
54
55 struct _ModestMainWindow {
56         ModestWindow parent;
57 };
58
59 struct _ModestMainWindowClass {
60         ModestWindowClass parent_class;
61 };
62
63 typedef enum _ModestMainWindowStyle {
64         MODEST_MAIN_WINDOW_STYLE_SIMPLE,
65         MODEST_MAIN_WINDOW_STYLE_SPLIT
66 } ModestMainWindowStyle;
67
68 /**
69  * modest_main_window_get_type:
70  * 
71  * get the GType for the ModestMainWindow class
72  *
73  * Returns: a GType for ModestMainWindow
74  */
75 GType modest_main_window_get_type (void) G_GNUC_CONST;
76
77
78 /**
79  * modest_main_window_new
80  * 
81  * instantiates a new ModestMainWindow widget
82  *
83  * Returns: a new ModestMainWindow, or NULL in case of error
84  */
85 ModestWindow* modest_main_window_new (void);
86
87 /*
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
91  */
92 typedef enum {
93         MODEST_WIDGET_TYPE_HEADER_VIEW,
94         MODEST_WIDGET_TYPE_FOLDER_VIEW,
95         MODEST_WIDGET_TYPE_MSG_PREVIEW,
96         
97         MODEST_WIDGET_TYPE_NUM,
98 } ModestWidgetType;
99
100
101 /**
102  * modest_main_window_get_child_widget
103  * 
104  * get a child window for this window
105  *
106  * Returns: a child window or NULL
107  */
108 GtkWidget* modest_main_window_get_child_widget (ModestMainWindow *self,
109                                                 ModestWidgetType widget_type);
110
111 /**
112  * modest_main_window_close_all:
113  * @self: 
114  * 
115  * this function will ask the user about if the user wants to close
116  * all the windows or just the main one
117  * 
118  * Returns: TRUE if the user selected to close all the windows, otherwise FALSE
119  **/
120 gboolean   modest_main_window_close_all        (ModestMainWindow *self);
121
122
123 /**
124  * modest_main_window_set_style:
125  * @self: the #ModestMainWindow
126  * @style: a #ModestMainWindowStyle that will be set
127  * 
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
130  * messages.
131  **/
132 void       modest_main_window_set_style        (ModestMainWindow *self, 
133                                                 ModestMainWindowStyle style);
134
135 /**
136  * modest_main_window_get_style:
137  * @self: 
138  * 
139  * gets the current show style of the main window
140  * 
141  * Return value: the current #ModestWindowStyle
142  **/
143 ModestMainWindowStyle       modest_main_window_get_style        (ModestMainWindow *self);
144
145 G_END_DECLS
146
147 #endif /* __MODEST_MAIN_WINDOW_H__ */