#include "modest-utils.h"
#include "widgets/modest-connection-specific-smtp-window.h"
#include "widgets/modest-ui-constants.h"
-#include <widgets/modest-main-window.h>
#include <widgets/modest-msg-view-window.h>
#include <widgets/modest-account-view-window.h>
#include <widgets/modest-details-dialog.h>
#include <tny-camel-bs-msg.h>
#include <tny-camel-bs-mime-part.h>
+#include <gtk/gtk.h>
#include <gtkhtml/gtkhtml.h>
#define MODEST_MOVE_TO_DIALOG_FOLDER_VIEW "move-to-dialog-folder-view"
static gboolean remote_folder_has_leave_on_server (TnyFolderStore *folder);
-static void do_create_folder (GtkWindow *window,
+static void do_create_folder (ModestWindow *window,
TnyFolderStore *parent_folder,
const gchar *suggested_name);
static void modest_ui_actions_on_folder_window_move_to (GtkWidget *folder_view,
TnyFolderStore *dst_folder,
TnyList *selection,
- GtkWindow *win);
+ ModestWindow *win);
static void modest_ui_actions_on_window_move_to (GtkAction *action,
TnyList *list_to_move,
NULL
};
about = gtk_about_dialog_new ();
- gtk_about_dialog_set_name (GTK_ABOUT_DIALOG(about), PACKAGE_NAME);
+ gtk_about_dialog_set_program_name (GTK_ABOUT_DIALOG(about), PACKAGE_NAME);
gtk_about_dialog_set_version (GTK_ABOUT_DIALOG(about),PACKAGE_VERSION);
gtk_about_dialog_set_copyright (GTK_ABOUT_DIALOG(about),
_("Copyright (c) 2006, Nokia Corporation\n"
gint response;
ModestWindowMgr *mgr;
gboolean retval = TRUE;
- GtkWindow *toplevel;
g_return_val_if_fail (MODEST_IS_WINDOW(win), FALSE);
tny_list_get_length(header_list)), desc);
/* Confirmation dialog */
- toplevel = (GtkWindow *) gtk_widget_get_toplevel ((GtkWidget *) win);
- response = modest_platform_run_confirmation_dialog (toplevel, message);
+ response = modest_platform_run_confirmation_dialog (GTK_WINDOW (gtk_widget_get_toplevel (GTK_WIDGET (win))),
+ message);
if (response == GTK_RESPONSE_OK) {
GtkTreeSelection *sel = NULL;
void
modest_ui_actions_on_smtp_servers (GtkAction *action, ModestWindow *win)
{
- /* This is currently only implemented for Maemo,
- * because it requires an API (libconic) to detect different connection
- * possiblities.
- */
-#ifndef MODEST_TOOLKIT_GTK /* Defined in config.h */
-
/* Create the window if necessary: */
GtkWidget *specific_window = GTK_WIDGET (modest_connection_specific_smtp_window_new ());
modest_connection_specific_smtp_window_fill_with_connections (
modest_window_mgr_set_modal (modest_runtime_get_window_mgr (),
GTK_WINDOW (specific_window), (GtkWindow *) win);
gtk_widget_show (specific_window);
-#endif /* !MODEST_TOOLKIT_GTK */
}
static guint64
MODEST_TEXT_UTILS_SIGNATURE_MARKER,
"\n", signature, NULL) : g_strdup(body_str);
} else {
- body = use_signature ? g_strconcat("\n", MODEST_TEXT_UTILS_SIGNATURE_MARKER,
- "\n", signature, NULL) : g_strdup("");
+
+ gchar *gray_color_markup = NULL, *color_begin = NULL, *color_end = NULL;
+ GdkColor color;
+
+ if (win && gtk_style_lookup_color (gtk_widget_get_style ((GtkWidget *) win),
+ "SecondaryTextColor", &color))
+ gray_color_markup = modest_text_utils_get_color_string (&color);
+ if (!gray_color_markup)
+ gray_color_markup = g_strdup ("#babababababa");
+
+ color_begin = g_strdup_printf ("<font color=\"%s\">", gray_color_markup);
+ color_end = "</font>";
+
+ body = use_signature ? g_strconcat("<br/>\n", color_begin,
+ MODEST_TEXT_UTILS_SIGNATURE_MARKER, "<br/>\n",
+ signature, color_end, NULL) : g_strdup("");
+
+ g_free (gray_color_markup);
+ g_free (color_begin);
}
- msg = modest_tny_msg_new (to_str, from_str, cc_str, bcc_str, subject_str, NULL, NULL, body, NULL, NULL, NULL);
+ msg = modest_tny_msg_new_html_plain (to_str, from_str, cc_str, bcc_str, subject_str,
+ NULL, NULL, body, NULL, NULL, NULL, NULL, NULL);
if (!msg) {
g_printerr ("modest: failed to create new msg\n");
goto cleanup;
static void
open_msg_performer(gboolean canceled,
GError *err,
- GtkWindow *parent_window,
+ ModestWindow *parent_window,
TnyAccount *account,
gpointer user_data)
{
gboolean can_open;
gchar *account_name = get_info_from_header (helper->header, &is_draft, &can_open);
+ if (!g_strcmp0 (account_name, MODEST_LOCAL_FOLDERS_ACCOUNT_ID) ||
+ !g_strcmp0 (account_name, MODEST_MMC_ACCOUNT_ID)) {
+ g_free (account_name);
+ account_name = g_strdup (modest_window_get_active_account (MODEST_WINDOW (parent_window)));
+ }
+
if (!can_open) {
modest_window_mgr_unregister_header (modest_runtime_get_window_mgr (), helper->header);
g_free (account_name);
GtkWidget *header_view;
gchar *uid;
- header_view = get_header_view_from_window (MODEST_WINDOW (parent_window));
+ header_view = get_header_view_from_window (parent_window);
uid = modest_tny_folder_get_header_unique_id (helper->header);
if (header_view) {
const gchar *mailbox = NULL;
- mailbox = modest_window_get_active_mailbox (MODEST_WINDOW (parent_window));
+ mailbox = modest_window_get_active_mailbox (parent_window);
window = modest_msg_view_window_new_from_header_view
(MODEST_HEADER_VIEW (header_view), account_name, mailbox, uid, helper->rowref);
if (window != NULL) {
/* Connect to the account and perform */
if (!cached) {
- modest_platform_connect_and_perform ((GtkWindow *) win, TRUE, g_object_ref (account),
+ modest_platform_connect_and_perform (win, TRUE, g_object_ref (account),
open_msg_performer, helper);
} else {
/* Call directly the performer, do not need to connect */
- open_msg_performer (FALSE, NULL, (GtkWindow *) win,
+ open_msg_performer (FALSE, NULL, win,
g_object_ref (account), helper);
}
cleanup:
static void
reply_forward_performer (gboolean canceled,
GError *err,
- GtkWindow *parent_window,
+ ModestWindow *parent_window,
TnyAccount *account,
gpointer user_data)
{
TnyList *pending_parts;
TnyFolder *folder;
TnyAccount *account;
- GtkWindow *toplevel;
/* Create helper */
pending_parts = forward_pending_parts (msg);
folder = tny_header_get_folder (header);
account = tny_folder_get_account (folder);
- toplevel = (GtkWindow *) gtk_widget_get_toplevel ((GtkWidget *) win);
- modest_platform_connect_and_perform (toplevel,
+ modest_platform_connect_and_perform (win,
TRUE, account,
reply_forward_performer,
rf_helper);
rf_helper = create_reply_forward_helper (action, win,
reply_forward_type, header, NULL);
if (uncached_msgs > 0) {
- GtkWindow *toplevel = (GtkWindow *) gtk_widget_get_toplevel ((GtkWidget *) win);
-
- modest_platform_connect_and_perform (toplevel,
+ modest_platform_connect_and_perform (win,
TRUE, account,
reply_forward_performer,
rf_helper);
} else {
- GtkWindow *toplevel = (GtkWindow *) gtk_widget_get_toplevel ((GtkWidget *) win);
- reply_forward_performer (FALSE, NULL, toplevel,
+ reply_forward_performer (FALSE, NULL, win,
account, rf_helper);
}
}
static void
do_send_receive_performer (gboolean canceled,
GError *err,
- GtkWindow *parent_window,
+ ModestWindow *parent_window,
TnyAccount *account,
gpointer user_data)
{
modest_mail_operation_queue_add (modest_runtime_get_mail_operation_queue (), info->mail_op);
/* Invoke the connect and perform */
- GtkWindow *toplevel = (GtkWindow *) gtk_widget_get_toplevel ((GtkWidget *) win);
- modest_platform_connect_and_perform (toplevel,
- force_connection, info->account,
+ modest_platform_connect_and_perform (win, force_connection, info->account,
do_send_receive_performer, info);
}
full memory condition */
modest_platform_information_banner ((GtkWidget *) source_win, NULL,
_("mail_in_ui_folder_create_error"));
- do_create_folder ((GtkWindow *) gtk_widget_get_toplevel (GTK_WIDGET (source_win)),
+ do_create_folder ((ModestWindow *) source_win,
parent_folder, (const gchar *) suggested_name);
}
} else {
- /* the 'source_win' is either the ModestMainWindow, or the 'Move to folder'-dialog
+ /* the 'source_win' is either the ModestWindow, or the 'Move to folder'-dialog
* FIXME: any other? */
GtkWidget *folder_view;
static void
do_create_folder_performer (gboolean canceled,
- GError *err,
- GtkWindow *parent_window,
- TnyAccount *account,
- gpointer user_data)
+ GError *err,
+ ModestWindow *parent_window,
+ TnyAccount *account,
+ gpointer user_data)
{
CreateFolderConnect *helper = (CreateFolderConnect *) user_data;
ModestMailOperation *mail_op;
static void
-do_create_folder (GtkWindow *parent_window,
+do_create_folder (ModestWindow *parent_window,
TnyFolderStore *suggested_parent,
const gchar *suggested_name)
{
gint result;
gchar *folder_name = NULL;
TnyFolderStore *parent_folder = NULL;
+ GtkWindow *toplevel;
- result = modest_platform_run_new_folder_dialog (parent_window,
+ toplevel = (GtkWindow *) gtk_widget_get_toplevel ((GtkWidget *) parent_window);
+ result = modest_platform_run_new_folder_dialog (toplevel,
suggested_parent,
(gchar *) suggested_name,
&folder_name,
}
if (parent_folder) {
- do_create_folder (parent_window, parent_folder, NULL);
+ do_create_folder (MODEST_WINDOW (parent_window), parent_folder, NULL);
g_object_unref (parent_folder);
}
}
static void
on_rename_folder_performer (gboolean canceled,
GError *err,
- GtkWindow *parent_window,
+ ModestWindow *parent_window,
TnyAccount *account,
gpointer user_data)
{
if (response != GTK_RESPONSE_ACCEPT || strlen (folder_name) == 0) {
do_rename = FALSE;
} else {
- GtkWindow *toplevel = (GtkWindow *) gtk_widget_get_toplevel ((GtkWidget *) window);
RenameFolderInfo *rename_folder_data = g_new0 (RenameFolderInfo, 1);
rename_folder_data->folder = g_object_ref (folder);
rename_folder_data->new_name = folder_name;
- modest_platform_connect_if_remote_and_perform (toplevel, TRUE,
+ modest_platform_connect_if_remote_and_perform (window, TRUE,
folder, on_rename_folder_performer, rename_folder_data);
}
}
static void
on_delete_folder_cb (gboolean canceled,
- GError *err,
- GtkWindow *parent_window,
- TnyAccount *account,
- gpointer user_data)
+ GError *err,
+ ModestWindow *parent_window,
+ TnyAccount *account,
+ gpointer user_data)
{
DeleteFolderInfo *info = (DeleteFolderInfo*) user_data;
GtkWidget *folder_view;
ModestMailOperation *mail_op;
GtkTreeSelection *sel;
+ ModestWindow *modest_window;
+
+#ifdef MODEST_TOOLKIT_HILDON2
+ modest_window = (ModestWindow*) parent_window;
+#else
+ if (MODEST_IS_SHELL (parent_window)) {
+ modest_window = modest_shell_peek_window (MODEST_SHELL (parent_window));
+ } else {
+ modest_window = NULL;
+ }
+#endif
- if (!MODEST_IS_WINDOW(parent_window) || canceled || (err!=NULL)) {
+ if (!MODEST_IS_WINDOW(modest_window) || canceled || (err!=NULL)) {
/* Note that the connection process can fail due to
memory low conditions as it can not successfully
store the summary */
return;
}
- if (MODEST_IS_FOLDER_WINDOW (parent_window)) {
- folder_view = GTK_WIDGET (modest_folder_window_get_folder_view (MODEST_FOLDER_WINDOW (parent_window)));
+ if (MODEST_IS_FOLDER_WINDOW (modest_window)) {
+ folder_view = GTK_WIDGET (modest_folder_window_get_folder_view (MODEST_FOLDER_WINDOW (modest_window)));
} else {
g_object_unref (G_OBJECT (info->folder));
g_free (info);
GtkWidget *folder_view;
gint response;
gchar *message;
- GtkWindow *toplevel;
g_return_val_if_fail (MODEST_IS_WINDOW(window), FALSE);
- toplevel = (GtkWindow *) gtk_widget_get_toplevel ((GtkWidget *) window);
-
if (MODEST_IS_FOLDER_WINDOW (window)) {
folder_view = GTK_WIDGET (modest_folder_window_get_folder_view (MODEST_FOLDER_WINDOW (window)));
} else {
/* Show an error if it's an account */
if (!TNY_IS_FOLDER (folder)) {
- modest_platform_run_information_dialog (toplevel,
+ modest_platform_run_information_dialog (GTK_WINDOW (gtk_widget_get_toplevel (GTK_WIDGET (window))),
_("mail_in_ui_folder_delete_error"),
FALSE);
g_object_unref (G_OBJECT (folder));
/* Ask the user */
message = g_strdup_printf (_("mcen_nc_delete_folder_text"),
tny_folder_get_name (TNY_FOLDER (folder)));
- response = modest_platform_run_confirmation_dialog (toplevel,
+ response = modest_platform_run_confirmation_dialog (GTK_WINDOW (gtk_widget_get_toplevel (GTK_WIDGET (window))),
(const gchar *) message);
g_free (message);
info->move_to_trash = move_to_trash;
account = tny_folder_get_account (TNY_FOLDER (folder));
- modest_platform_connect_if_remote_and_perform (toplevel,
+ modest_platform_connect_if_remote_and_perform (window,
TRUE,
TNY_FOLDER_STORE (account),
on_delete_folder_cb, info);
gchar **password,
gboolean *cancel,
gboolean *remember,
- ModestMainWindow *main_window)
+ ModestWindow *window)
{
g_return_if_fail(server_account_name);
gboolean completed = FALSE;
MoveToInfo *helper = NULL;
ModestFolderView *folder_view;
gboolean unset_edit_mode = FALSE;
- GtkWindow *toplevel;
helper = (MoveToInfo *) user_data;
parent_win = (GtkWidget *) helper->win;
- toplevel = (GtkWindow *) gtk_widget_get_toplevel ((GtkWidget *) parent_win);
folder_view = MODEST_FOLDER_VIEW (g_object_get_data (G_OBJECT (dialog),
MODEST_MOVE_TO_DIALOG_FOLDER_VIEW));
switch (response) {
modest_ui_actions_on_folder_window_move_to (GTK_WIDGET (folder_view),
dst_folder,
helper->list,
- toplevel);
+ MODEST_WINDOW (parent_win));
} else {
/* if the user selected a root folder
(account) then do not perform any action */
modest_folder_view_set_style (MODEST_FOLDER_VIEW (tree_view),
MODEST_FOLDER_VIEW_STYLE_SHOW_ALL);
- /* modest_folder_view_update_model (MODEST_FOLDER_VIEW (tree_view), */
- /* TNY_ACCOUNT_STORE (modest_runtime_get_account_store ())); */
active_account_name = modest_window_get_active_account (MODEST_WINDOW (win));
mgr = modest_runtime_get_account_mgr ();
* wants to connect to complete it
*/
static void
-modest_ui_actions_xfer_messages_check (GtkWindow *parent_window,
+modest_ui_actions_xfer_messages_check (ModestWindow *parent_window,
TnyFolderStore *src_folder,
TnyList *headers,
TnyFolder *dst_folder,
if (uncached_msgs > 0) {
guint num_headers;
const gchar *msg;
+ GtkWindow *toplevel;
*need_connection = TRUE;
num_headers = tny_list_get_length (headers);
msg = ngettext ("mcen_nc_get_msg", "mcen_nc_get_msgs", num_headers);
+ toplevel = (GtkWindow *) gtk_widget_get_toplevel ((GtkWidget *) parent_window);
- if (modest_platform_run_confirmation_dialog (parent_window, msg) ==
+ if (modest_platform_run_confirmation_dialog (toplevel, msg) ==
GTK_RESPONSE_CANCEL) {
*do_xfer = FALSE;
} else {
static void
xfer_messages_performer (gboolean canceled,
GError *err,
- GtkWindow *parent_window,
+ ModestWindow *parent_window,
TnyAccount *account,
gpointer user_data)
{
- ModestWindow *win = MODEST_WINDOW (parent_window);
TnyAccount *dst_account = NULL;
gboolean dst_forbids_message_add = FALSE;
XferMsgsHelper *helper;
MODEST_PROTOCOL_REGISTRY_STORE_FORBID_INCOMING_XFERS);
if (dst_forbids_message_add) {
- modest_platform_information_banner (GTK_WIDGET (win),
+ modest_platform_information_banner (GTK_WIDGET (parent_window),
NULL,
ngettext("mail_in_ui_folder_move_target_error",
"mail_in_ui_folder_move_targets_error",
/* Perform the mail operation */
- mail_op = modest_mail_operation_new_with_error_handling (G_OBJECT(win),
+ mail_op = modest_mail_operation_new_with_error_handling (G_OBJECT(parent_window),
xfer_messages_error_handler,
g_object_ref (dst_account),
g_object_unref);
static void
on_move_folder_cb (gboolean canceled,
GError *err,
- GtkWindow *parent_window,
+ ModestWindow *parent_window,
TnyAccount *account,
gpointer user_data)
{
modest_ui_actions_on_folder_window_move_to (GtkWidget *folder_view,
TnyFolderStore *dst_folder,
TnyList *selection,
- GtkWindow *win)
+ ModestWindow *win)
{
TnyFolderStore *src_folder = NULL;
TnyIterator *iterator;
if (TNY_IS_ACCOUNT (dst_folder) &&
!MODEST_IS_TNY_LOCAL_FOLDERS_ACCOUNT (dst_folder) &&
!modest_tny_account_is_memory_card_account (TNY_ACCOUNT (dst_folder))) {
+ GtkWindow *toplevel = (GtkWindow *) gtk_widget_get_toplevel ((GtkWidget *) win);
+
do_xfer = FALSE;
/* Show an error */
- modest_platform_run_information_dialog (win,
+ modest_platform_run_information_dialog (toplevel,
_("mail_in_ui_folder_move_target_error"),
FALSE);
} else if (!TNY_IS_FOLDER (src_folder)) {
void
-modest_ui_actions_transfer_messages_helper (GtkWindow *win,
+modest_ui_actions_transfer_messages_helper (ModestWindow *win,
TnyFolder *src_folder,
TnyList *headers,
TnyFolder *dst_folder)
if (headers) {
TnyHeader *header = NULL;
TnyIterator *iter;
- GtkWindow *toplevel;
iter = tny_list_create_iterator (headers);
header = (TnyHeader *) tny_iterator_get_current (iter);
src_folder = tny_header_get_folder (header);
/* Transfer the messages */
- toplevel = (GtkWindow *) gtk_widget_get_toplevel ((GtkWidget *) win);
- modest_ui_actions_transfer_messages_helper (toplevel, src_folder,
+ modest_ui_actions_transfer_messages_helper (win, src_folder,
headers,
TNY_FOLDER (dst_folder));
}
/* Create and run the dialog */
+ dialog = create_move_to_dialog (win, NULL, list_to_move);
toplevel = (GtkWindow *) gtk_widget_get_toplevel ((GtkWidget *) win);
- dialog = create_move_to_dialog (toplevel, NULL, list_to_move);
modest_window_mgr_set_modal (modest_runtime_get_window_mgr (),
GTK_WINDOW (dialog),
toplevel);
static void
retrieve_msg_contents_performer (gboolean canceled,
GError *err,
- GtkWindow *parent_window,
+ ModestWindow *parent_window,
TnyAccount *account,
gpointer user_data)
{
g_object_unref (iter);
/* Connect and perform the message retrieval */
- modest_platform_connect_and_perform ((GtkWindow *) window, TRUE,
+ modest_platform_connect_and_perform (window, TRUE,
g_object_ref (account),
retrieve_msg_contents_performer,
g_object_ref (headers));
}
void
-modest_ui_actions_on_account_connection_error (GtkWindow *parent_window,
+modest_ui_actions_on_account_connection_error (ModestWindow *parent_window,
TnyAccount *account)
{
ModestProtocolType protocol_type;
if (error_note == NULL) {
g_warning ("%s: This should not be reached", __FUNCTION__);
} else {
- modest_platform_run_information_dialog (parent_window, error_note, FALSE);
+ GtkWindow *toplevel = (GtkWindow *) gtk_widget_get_toplevel ((GtkWidget *) parent_window);
+ modest_platform_run_information_dialog (toplevel, error_note, FALSE);
g_free (error_note);
}
}
static void
on_fetch_images_performer (gboolean canceled,
GError *err,
- GtkWindow *parent_window,
+ ModestWindow *parent_window,
TnyAccount *account,
gpointer user_data)
{
{
g_return_if_fail (MODEST_IS_MSG_VIEW_WINDOW (window));
- modest_platform_connect_and_perform ((GtkWindow *) window, TRUE,
+ modest_platform_connect_and_perform (window, TRUE,
NULL,
- on_fetch_images_performer,
+ on_fetch_images_performer,
g_object_ref (window));
}
store_conn_status = tny_account_get_connection_status (store_account);
if (store_conn_status == TNY_CONNECTION_STATUS_CONNECTED || sending) {
gint response;
- GtkWindow *toplevel = (GtkWindow *) gtk_widget_get_toplevel ((GtkWidget *) self);
- response = modest_platform_run_confirmation_dialog (toplevel,
+ response = modest_platform_run_confirmation_dialog (GTK_WINDOW (gtk_widget_get_toplevel (GTK_WIDGET (self))),
_("emev_nc_disconnect_account"));
if (response == GTK_RESPONSE_OK) {
retval = TRUE;