Use GTK+ single includes
[modest] / src / widgets / modest-wizard-dialog.h
1 /* Copyright (c) 2006, 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_WIZARD_DIALOG_H__
32 #define __MODEST_WIZARD_DIALOG_H__
33
34 #include <gtk/gtk.h>
35
36 G_BEGIN_DECLS
37
38 #define MODEST_TYPE_WIZARD_DIALOG (modest_wizard_dialog_get_type())
39
40 #define MODEST_WIZARD_DIALOG(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), \
41             MODEST_TYPE_WIZARD_DIALOG, ModestWizardDialog))
42
43 #define MODEST_WIZARD_DIALOG_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), \
44             MODEST_TYPE_WIZARD_DIALOG, ModestWizardDialogClass))
45
46 #define MODEST_IS_WIZARD_DIALOG(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), \
47             MODEST_TYPE_WIZARD_DIALOG))
48
49 #define MODEST_IS_WIZARD_DIALOG_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), \
50             MODEST_TYPE_WIZARD_DIALOG))
51             
52 #define MODEST_WIZARD_DIALOG_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), \
53             MODEST_TYPE_WIZARD_DIALOG, ModestWizardDialogClass))
54
55 typedef struct _ModestWizardDialog ModestWizardDialog;
56
57 typedef struct _ModestWizardDialogClass ModestWizardDialogClass;
58
59 typedef struct _ModestWizardDialogPrivate ModestWizardDialogPrivate;
60
61 /* button response IDs */
62 enum {
63     MODEST_WIZARD_DIALOG_CANCEL = GTK_RESPONSE_CANCEL,
64     MODEST_WIZARD_DIALOG_PREVIOUS = 0,
65     MODEST_WIZARD_DIALOG_NEXT,
66     MODEST_WIZARD_DIALOG_FINISH
67 };
68
69 struct _ModestWizardDialog {
70     GtkDialog                   parent;
71     ModestWizardDialogPrivate   *priv;
72 };
73
74 struct _ModestWizardDialogClass {
75     GtkDialogClass          parent_class;
76     
77         /** Implementations of this vfunc should prepare the next page if necessary, 
78          * and only return TRUE if the navigation should be allowed.
79          * You may even change the next page, via the GtkNotebook API, in the signal handler. */
80         gboolean (* before_next) (ModestWizardDialog *dialog, GtkWidget *current_page, GtkWidget *next_page);
81
82         /** Implementations of this vfunc should enable or disable 
83          * the next/forward buttons appropriately, based on the entered data. */
84         void (* enable_buttons) (ModestWizardDialog *dialog, GtkWidget *current_page);
85
86
87     void (* update_model)  (ModestWizardDialog *dialog);
88     gboolean (*save)  (ModestWizardDialog *dialog);
89     void (*_gtk_reserved4)  (void);
90 };
91
92 /*
93  * Returning %TRUE means you don't allow further processing of the event in ModestWizardDialog
94  */
95 typedef gboolean (* ModestWizardDialogResponseOverrideFunc) (ModestWizardDialog *dialog, 
96                                                              gint response_id, gint page_number);
97
98
99 GType modest_wizard_dialog_get_type   (void) G_GNUC_CONST;
100
101 GtkWidget* modest_wizard_dialog_new   (GtkWindow        *parent,
102                                        const char       *wizard_name,
103                                        GtkNotebook      *notebook);
104                                        
105 void modest_wizard_dialog_force_title_update (ModestWizardDialog* wizard_dialog);
106 void modest_wizard_dialog_update_model (ModestWizardDialog *wizard_dialog);
107 gboolean modest_wizard_dialog_save (ModestWizardDialog *wizard_dialog);
108
109 void modest_wizard_dialog_set_response_override_handler (ModestWizardDialog *wizard_dialog,
110                                                          ModestWizardDialogResponseOverrideFunc callback);
111
112 G_END_DECLS
113
114 #endif /* __MODEST_WIZARD_DIALOG_H__ */