ModestWindow *msg_win;
ModestEditType edit_type;
gchar *from;
- GError *err = NULL;
- TnyFolder *folder = NULL;
TnyAccount *account = NULL;
ModestWindowMgr *mgr;
gchar *signature = NULL;
goto cleanup;
}
- folder = modest_tny_account_get_special_folder (account, TNY_FOLDER_TYPE_DRAFTS);
- if (!folder) {
- g_printerr ("modest: failed to find Drafts folder\n");
- goto cleanup;
- }
-
- tny_folder_add_msg (folder, msg, &err);
- if (err) {
- g_printerr ("modest: error adding msg to Drafts folder: %s",
- err->message);
- g_error_free (err);
- goto cleanup;
- }
-
/* Create and register the windows */
msg_win = modest_msg_edit_window_new (new_msg, rf_helper->account_name);
mgr = modest_runtime_get_window_mgr ();
cleanup:
if (new_msg)
g_object_unref (G_OBJECT (new_msg));
- if (folder)
- g_object_unref (G_OBJECT (folder));
if (account)
g_object_unref (G_OBJECT (account));
g_object_unref (msg);
set_active_account_from_tny_account (TNY_ACCOUNT (folder_store), MODEST_WINDOW (main_window));
/* Show account details */
modest_main_window_set_contents_style (main_window, MODEST_MAIN_WINDOW_CONTENTS_STYLE_DETAILS);
- } else if (modest_tny_folder_store_is_virtual_local_folders (folder_store )) {
- //TODO: Set the virtual folder store as the "active account" somehow:
- modest_main_window_set_contents_style (main_window, MODEST_MAIN_WINDOW_CONTENTS_STYLE_DETAILS);
} else {
if (TNY_IS_FOLDER (folder_store) && selected) {
modest_msg_edit_window_free_msg_data (edit_window, data);
return;
}
+
+ if (!strcmp (account_name, MODEST_ACTUAL_LOCAL_FOLDERS_ACCOUNT_ID)) {
+ account_name = g_strdup (data->account_name);
+ }
+
transport_account =
TNY_TRANSPORT_ACCOUNT(modest_tny_account_store_get_tny_account_by_account
(modest_runtime_get_account_store(),
modest_mail_operation_save_to_drafts (mail_operation,
transport_account,
+ data->draft_msg,
from,
data->to,
data->cc,
g_printerr ("modest: no account found\n");
return;
}
+ MsgData *data = modest_msg_edit_window_get_msg_data (edit_window);
+
+ if (!strcmp (account_name, MODEST_ACTUAL_LOCAL_FOLDERS_ACCOUNT_ID)) {
+ account_name = g_strdup (data->account_name);
+ }
/* Get the currently-active transport account for this modest account: */
TnyTransportAccount *transport_account =
if (!transport_account) {
g_printerr ("modest: no transport account found for '%s'\n", account_name);
g_free (account_name);
+ modest_msg_edit_window_free_msg_data (edit_window, data);
return;
}
gchar *from = modest_account_mgr_get_from_string (account_mgr, account_name);
- MsgData *data = modest_msg_edit_window_get_msg_data (edit_window);
-
/* mail content checks and dialogs */
if (data->subject == NULL || data->subject[0] == '\0') {
GtkResponseType response;
modest_mail_operation_send_new_mail (mail_operation,
transport_account,
+ data->draft_msg,
from,
data->to,
data->cc,