1cab419c62e8b10c851032b054c3b564ca9a7912
[modest] / src / modest-plugin-ui-actions.h
1 /* Copyright (c) 2008, 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 #ifndef __MODEST_PLUGIN_UI_ACTIONS_H__
31 #define __MODEST_PLUGIN_UI_ACTIONS_H__
32
33 /* This should contain simple facades for internal ui actions in modest
34  * that should be available in plugins.
35  */
36
37 #include <gtk/gtk.h>
38 #include <glib.h>
39
40 G_BEGIN_DECLS
41
42 /**
43  * modest_ui_actions_on_delete_account:
44  * @parent_window: the parent #GtkWindow of the dialog that will be shown
45  * @account_name: the modest name for the account to be deleted
46  * @account_display_name: the display name that will be used in the dialog
47  *
48  * This function will perform the actions required to delete an
49  * account. This function assumes that the account to be deleted is
50  * already disconnected, so the caller must verify that this is the
51  * case. Otherwise weird behaviours could happen
52  *
53  * Returns: TRUE if the account was successfully deleted, FALSE otherwise
54  **/
55 gboolean modest_ui_actions_on_delete_account (GtkWindow *parent_window,
56                                               const gchar *account_name,
57                                               const gchar *account_display_name);
58
59 /**
60  * modest_ui_actions_on_reload_message:
61  * @msg_id: a message id
62  *
63  * Reload the message if it's currently being shown in a view.
64  */
65 void
66 modest_ui_actions_on_reload_message (const gchar *msg_id);
67
68 /**
69  * modest_ui_actions_reply_calendar:
70  * @win: parent #ModestWindow
71  * @header_pairs: #TnyList of #TnyPair of header pairs
72  *
73  * this method opens the mail composer with a reply of a message with calendar
74  * allowing to add @header_pairs with the result of the calendar request.
75  *
76  * @win should be a #ModestMsgViewWindow. We don't put the exact type to avoid
77  * exporting to plugins #ModestMsgViewWindow API
78  */
79 void
80 modest_ui_actions_reply_calendar (ModestWindow *win, TnyList *header_pairs);
81
82 /**
83  * modest_ui_actions_on_send_msg:
84  * @window: parent window requesting to send the message
85  * @msg: a #TnyMsg
86  *
87  * This method will send @msg without showing the message editor.
88  *
89  * Returns: %TRUE if succesful, %FALSE otherwise
90  */
91 gboolean
92 modest_ui_actions_on_send_msg (ModestWindow *window,
93                                TnyMsg *msg);
94
95 /**
96  * modest_ui_actions_on_send_custom_msg:
97  * @account_name: the account name to use for sending
98  * @from: a string
99  * @to: a string
100  * @cc: a string
101  * @bcc: a string
102  * @plain_body: a string with body of the message in plain text
103  * @html_body: a string with body of the message in html (or %NULL if message is only in plain text)
104  * @attachments_list: a #GList of attachments to add (#TnyMimePart)
105  * @images_list: a #GList of embedded images to add (#TnyMimePart)
106  * @references: list of messages this new message refers to
107  * @in_reply_to: a string with new in-reply-to header
108  * @priority_flags: the priority of the message as #TnyHeaderFlag mask
109  * @header_pairs: a #TnyList of #TnyPair with custom headers to add
110  */
111 gboolean
112 modest_ui_actions_on_send_custom_msg (const gchar *account_name, 
113                                       const gchar *from, const gchar *to, const gchar *cc, const gchar *bcc,
114                                       const gchar *subject,
115                                       const gchar *plain_body, const gchar *html_body,
116                                       const GList *attachments_list, const GList *images_list,
117                                       const gchar *references, const gchar *in_reply_to,
118                                       TnyHeaderFlags priority_flags, TnyList *header_pairs);
119
120 /**
121  * modest_ui_actions_on_send_custom_msg:
122  * @transport_account: a #TnyTransportAccount
123  * @draft_msg: original draft message to delete on sending
124  * @from: a string
125  * @to: a string
126  * @cc: a string
127  * @bcc: a string
128  * @plain_body: a string with body of the message in plain text
129  * @html_body: a string with body of the message in html (or %NULL if message is only in plain text)
130  * @attachments_list: a #GList of attachments to add (#TnyMimePart)
131  * @images_list: a #GList of embedded images to add (#TnyMimePart)
132  * @references: list of messages this new message refers to
133  * @in_reply_to: a string with new in-reply-to header
134  * @priority_flags: the priority of the message as #TnyHeaderFlag mask
135  * @header_pairs: a #TnyList of #TnyPair with custom headers to add
136  */
137 gboolean
138 modest_ui_actions_send_msg_with_transport (TnyTransportAccount *transport_account, 
139                                            TnyMsg *draft_msg,
140                                            const gchar *from, const gchar *to, const gchar *cc, const gchar *bcc,
141                                            const gchar *subject,
142                                            const gchar *plain_body, const gchar *html_body,
143                                            const GList *attachments_list, const GList *images_list,
144                                            const gchar *references, const gchar *in_reply_to,
145                                            TnyHeaderFlags priority_flags, TnyList *header_pairs);
146
147 G_END_DECLS
148 #endif /* __MODEST_PLUGIN_UI_ACTIONS_H__ */