aboutsummaryrefslogtreecommitdiffstats
path: root/mail/mail-callbacks.c
diff options
context:
space:
mode:
authorJeffrey Stedfast <fejj@helixcode.com>2000-09-02 09:44:59 +0800
committerJeffrey Stedfast <fejj@src.gnome.org>2000-09-02 09:44:59 +0800
commit754164e503ba405f85d0ce5123b907a6c5809712 (patch)
tree7a183dd0d4373d9c78100776bdcb5d90f8b4d358 /mail/mail-callbacks.c
parenta029bb7982e6f00a84d5cf43f96188dac0be3c49 (diff)
downloadgsoc2013-evolution-754164e503ba405f85d0ce5123b907a6c5809712.tar.gz
gsoc2013-evolution-754164e503ba405f85d0ce5123b907a6c5809712.tar.zst
gsoc2013-evolution-754164e503ba405f85d0ce5123b907a6c5809712.zip
Attach a callback to the postpone signal (send_to_url): Same (mail_reply):
2000-09-01 Jeffrey Stedfast <fejj@helixcode.com> * mail-callbacks.c (compose_msg): Attach a callback to the postpone signal (send_to_url): Same (mail_reply): Same (forward_msg): Same (composer_postpone_cb): Callback function for the postpone signal * mail-ops.c (mail_do_setup_outbox): New convenience function to load the Outbox folder (mail_do_setup_sentbox): Same, but for Sentbox. (do_send_mail): Now saves messages in Sentbox if sent successfully (mail_do_append_mail): New convenience async function for appending messages to a folder * component-factory.c: Added outbox_folder and sent_folder (owner_set_cb): Call our new convenience functions to load Outbox and Sentbox svn path=/trunk/; revision=5178
Diffstat (limited to 'mail/mail-callbacks.c')
-rw-r--r--mail/mail-callbacks.c66
1 files changed, 53 insertions, 13 deletions
diff --git a/mail/mail-callbacks.c b/mail/mail-callbacks.c
index 970221eadf..70ae463a29 100644
--- a/mail/mail-callbacks.c
+++ b/mail/mail-callbacks.c
@@ -239,6 +239,35 @@ composer_send_cb (EMsgComposer *composer, gpointer data)
}
}
+void
+composer_postpone_cb (EMsgComposer *composer, gpointer data)
+{
+ /* FIXME: do we want to use post_send_data to set flags and stuff? */
+ extern CamelFolder *outbox_folder;
+ CamelMimeMessage *message;
+ CamelMessageInfo *info;
+ const char *subject;
+
+ /* Get the message */
+ message = e_msg_composer_get_message (composer);
+
+ /* Check for no subject */
+ subject = camel_mime_message_get_subject (message);
+ if (subject == NULL || subject[0] == '\0') {
+ if (!ask_confirm_for_empty_subject (composer)) {
+ camel_object_unref (CAMEL_OBJECT (message));
+ return;
+ }
+ }
+
+ /* Save the message in Outbox */
+ info = g_new0 (CamelMessageInfo, 1);
+ info->flags = 0;
+ mail_do_append_mail (outbox_folder, message, info);
+ g_free (info);
+ gtk_widget_destroy (GTK_WIDGET (composer));
+}
+
static GtkWidget *
create_msg_composer (const char *url)
{
@@ -268,14 +297,17 @@ void
compose_msg (GtkWidget *widget, gpointer user_data)
{
GtkWidget *composer;
-
+
if (!check_send_configuration (FOLDER_BROWSER (user_data)))
return;
-
+
composer = create_msg_composer (NULL);
-
+
gtk_signal_connect (GTK_OBJECT (composer), "send",
GTK_SIGNAL_FUNC (composer_send_cb), NULL);
+ gtk_signal_connect (GTK_OBJECT (composer), "postpone",
+ GTK_SIGNAL_FUNC (composer_postpone_cb), NULL);
+
gtk_widget_show (composer);
}
@@ -284,16 +316,19 @@ void
send_to_url (const char *url)
{
GtkWidget *composer;
-
+
/* FIXME: no way to get folder browser? Not without
* big pain in the ass, as far as I can tell */
if (!check_send_configuration (NULL))
return;
-
+
composer = create_msg_composer (url);
-
+
gtk_signal_connect (GTK_OBJECT (composer), "send",
GTK_SIGNAL_FUNC (composer_send_cb), NULL);
+ gtk_signal_connect (GTK_OBJECT (composer), "postpone",
+ GTK_SIGNAL_FUNC (composer_postpone_cb), NULL);
+
gtk_widget_show (composer);
}
@@ -318,7 +353,9 @@ mail_reply (CamelFolder *folder, CamelMimeMessage *msg, const char *uid, gboolea
composer = mail_generate_reply (msg, to_all);
gtk_signal_connect (GTK_OBJECT (composer), "send",
- GTK_SIGNAL_FUNC (composer_send_cb), psd);
+ GTK_SIGNAL_FUNC (composer_send_cb), psd);
+ gtk_signal_connect (GTK_OBJECT (composer), "postpone",
+ GTK_SIGNAL_FUNC (composer_postpone_cb), psd);
gtk_signal_connect (GTK_OBJECT (composer), "destroy",
GTK_SIGNAL_FUNC (free_psd), psd);
@@ -369,6 +406,8 @@ forward_msg (GtkWidget *widget, gpointer user_data)
gtk_signal_connect (GTK_OBJECT (composer), "send",
GTK_SIGNAL_FUNC (composer_send_cb), NULL);
+ gtk_signal_connect (GTK_OBJECT (composer), "postpone",
+ GTK_SIGNAL_FUNC (composer_postpone_cb), NULL);
mail_do_forward_message (cursor_msg,
fb->message_list->folder,
@@ -459,22 +498,23 @@ edit_msg (GtkWidget *widget, gpointer user_data)
FolderBrowser *fb = FOLDER_BROWSER (user_data);
GPtrArray *uids;
extern CamelFolder *drafts_folder;
-
+
if (fb->folder != drafts_folder) {
GtkWidget *message;
-
+
message = gnome_warning_dialog (_("You may only edit messages saved\n"
- "in the Drafts folder."));
+ "in the Drafts folder."));
gnome_dialog_run_and_close (GNOME_DIALOG (message));
return;
}
-
+
if (!check_send_configuration (fb))
return;
-
+
uids = g_ptr_array_new();
message_list_foreach (fb->message_list, enumerate_msg, uids);
-
+
+ /* FIXME: do we need to pass the postpone callback too? */
mail_do_edit_messages (fb->folder, uids, (GtkSignalFunc) composer_send_cb);
}