return TRUE;
}
+typedef struct {
+ guint idle_handler;
+ gchar *message;
+ GtkWidget *banner;
+} OpenMsgBannerInfo;
+
+gboolean
+open_msg_banner_idle (gpointer userdata)
+{
+ OpenMsgBannerInfo *banner_info = (OpenMsgBannerInfo *) userdata;
+
+ gdk_threads_enter ();
+ banner_info->idle_handler = 0;
+ banner_info->banner = modest_platform_animation_banner (NULL, NULL, banner_info->message);
+ g_object_ref (banner_info->banner);
+
+ gdk_threads_leave ();
+
+ return FALSE;
+
+}
+
static void
open_msg_cb (ModestMailOperation *mail_op,
TnyHeader *header,
gchar *account = NULL;
TnyFolder *folder;
gboolean open_in_editor = FALSE;
+ OpenMsgBannerInfo *banner_info = (OpenMsgBannerInfo *) user_data;
/* Do nothing if there was any problem with the mail
operation. The error will be shown by the error_handler of
the mail operation */
if (!modest_ui_actions_msg_retrieval_check (mail_op, header, msg))
- return;
+ goto banner_cleanup;
parent_win = (ModestWindow *) modest_mail_operation_get_source (mail_op);
folder = tny_header_get_folder (header);
win = modest_msg_edit_window_new (msg, account, TRUE);
- /* Show banner */
- modest_platform_information_banner_with_timeout
- (NULL, NULL, _("mail_ib_opening_draft_message"), 1200);
} else {
gchar *uid = modest_tny_folder_get_header_unique_id (header);
g_free(account);
g_object_unref (parent_win);
g_object_unref (folder);
+banner_cleanup:
+ if (banner_info) {
+ g_free (banner_info->message);
+ if (banner_info->idle_handler > 0) {
+ g_source_remove (banner_info->idle_handler);
+ banner_info->idle_handler = 0;
+ }
+ if (banner_info->banner != NULL) {
+ gtk_widget_destroy (banner_info->banner);
+ g_object_unref (banner_info->banner);
+ banner_info->banner = NULL;
+ }
+ g_slice_free (OpenMsgBannerInfo, banner_info);
+ }
}
void
ModestTransportStoreProtocol proto;
TnyList *not_opened_headers;
TnyConnectionStatus status;
+ gboolean show_open_draft = FALSE;
+ OpenMsgBannerInfo *banner_info = NULL;
not_opened_headers = TNY_LIST (user_data);
g_object_unref (header);
g_object_unref (iter);
} else {
+ TnyHeader *header;
+ TnyFolder *folder;
+ TnyIterator *iter;
+ TnyFolderType folder_type;
+
+ iter = tny_list_create_iterator (not_opened_headers);
+ header = TNY_HEADER (tny_iterator_get_current (iter));
+ folder = tny_header_get_folder (header);
+ folder_type = modest_tny_folder_get_local_or_mmc_folder_type (folder);
+ show_open_draft = (folder_type == TNY_FOLDER_TYPE_DRAFTS);
+ g_object_unref (folder);
+ g_object_unref (header);
+ g_object_unref (iter);
error_msg = g_strdup (_("mail_ni_ui_folder_get_msg_folder_error"));
}
} else {
error_msg, g_free);
modest_mail_operation_queue_add (modest_runtime_get_mail_operation_queue (),
mail_op);
-
+
+ if (show_open_draft) {
+ banner_info = g_slice_new (OpenMsgBannerInfo);
+ banner_info->message = g_strdup (_("mail_ib_opening_draft_message"));
+ banner_info->banner = NULL;
+ banner_info->idle_handler = g_timeout_add (500, open_msg_banner_idle, banner_info);
+ }
+
modest_mail_operation_get_msgs_full (mail_op,
not_opened_headers,
open_msg_cb,
- NULL,
+ banner_info,
NULL);
/* Frees */
#include <modest-platform.h>
#include <string.h>
+typedef enum {
+ RENDER_CELL_STYLE_DEFAULT=0,
+ RENDER_CELL_STYLE_GREY
+} RenderCellStyle;
static const gchar *
get_status_string (ModestTnySendQueueStatus status)
NULL);
}
+static void
+set_cell_text (GtkCellRenderer *renderer,
+ const gchar *text,
+ TnyHeaderFlags flags,
+ RenderCellStyle style)
+{
+ PangoWeight weight;
+ gboolean strikethrough;
+
+ weight = (flags & TNY_HEADER_FLAG_SEEN) ? PANGO_WEIGHT_NORMAL: PANGO_WEIGHT_ULTRABOLD;
+ strikethrough = (flags & TNY_HEADER_FLAG_DELETED) ? TRUE:FALSE;
+ g_object_freeze_notify (G_OBJECT (renderer));
+ g_object_set (G_OBJECT (renderer), "text", text, NULL);
+ if (!(flags & TNY_HEADER_FLAG_SEEN))
+ g_object_set (G_OBJECT (renderer), "weight", PANGO_WEIGHT_ULTRABOLD, NULL);
+ if (flags & TNY_HEADER_FLAG_DELETED)
+ g_object_set (G_OBJECT (renderer), "strikethrough", TRUE, NULL);
+ switch (style) {
+ case RENDER_CELL_STYLE_GREY:
+ g_object_set (G_OBJECT (renderer),
+ "foreground", "#666666",
+ "scale", PANGO_SCALE_SMALL,
+ NULL);
+ break;
+ case RENDER_CELL_STYLE_DEFAULT:
+ break;
+ }
+ g_object_thaw_notify (G_OBJECT (renderer));
+}
+
void
_modest_header_view_msgtype_cell_data (GtkTreeViewColumn *column, GtkCellRenderer *renderer,
date_col, &date,
-1);
- g_object_set (G_OBJECT(renderer), "text", modest_text_utils_get_display_date (date),
- NULL);
-
- set_common_flags (renderer, flags);
+ set_cell_text (renderer, modest_text_utils_get_display_date (date),
+ flags, RENDER_CELL_STYLE_DEFAULT);
}
void
-1);
modest_text_utils_get_display_address (address); /* string is changed in-place */
- g_object_set (G_OBJECT(renderer),
- "text",
- address,
- NULL);
+ set_cell_text (renderer, address, flags, RENDER_CELL_STYLE_DEFAULT);
g_free (address);
-
- set_common_flags (renderer, flags);
}
/*
* this for both incoming and outgoing mail, depending on the the user_data
TnyHeaderFlags flags = 0;
gchar *address = NULL;
gchar *subject = NULL;
- gchar *header = NULL;
time_t date;
GtkCellRenderer *recipient_cell, *date_or_status_cell, *subject_cell,
*attach_cell, *priority_cell,
*recipient_box, *subject_box = NULL;
TnyHeader *msg_header = NULL;
- gchar *display_date = NULL, *tmp_date = NULL;
TnyHeaderFlags prio = 0;
get_pixbuf_for_flag (prio),
NULL);
- if (subject && strlen (subject)) {
- gchar* escaped_subject = g_markup_escape_text (subject, -1);
- g_object_set (G_OBJECT (subject_cell), "markup",
- escaped_subject, NULL);
- g_free (escaped_subject);
- } else {
- g_object_set (G_OBJECT (subject_cell), "markup",
- _("mail_va_no_subject"), NULL);
- }
-
+ set_cell_text (subject_cell, (subject && subject[0] != 0)?subject:_("mail_va_no_subject"),
+ flags, RENDER_CELL_STYLE_DEFAULT);
g_free (subject);
- set_common_flags (subject_cell, flags);
/* FIXME: we hardcode the color to #666666; instead we should use SecondaryTextColour from the
* theme (gtkrc file) */
modest_text_utils_get_display_address (address); /* changed in-place */
- header = g_markup_printf_escaped ("<span size='small' foreground='#666666'>%s</span>",
- address);
- g_free (address);
- g_object_set (G_OBJECT (recipient_cell),
- "markup", header,
- NULL);
- g_free (header);
- header = NULL;
- set_common_flags (recipient_cell, flags);
+ set_cell_text (recipient_cell, address, flags, RENDER_CELL_STYLE_GREY);
if (header_mode == MODEST_HEADER_VIEW_COMPACT_HEADER_MODE_OUTBOX) {
ModestTnySendQueueStatus status = MODEST_TNY_SEND_QUEUE_UNKNOWN;
}
status_str = get_status_string (status);
- display_date = g_strdup_printf("<span size='small' foreground='#666666'>%s</span>", status_str);
- g_object_set (G_OBJECT (date_or_status_cell),
- "markup", display_date,
- NULL);
- g_free (display_date);
- display_date = NULL;
+ set_cell_text (date_or_status_cell, status_str, flags, RENDER_CELL_STYLE_GREY);
} else {
- display_date = g_strdup_printf ("<span size='small' foreground='#666666'>%s</span>",
- date ? modest_text_utils_get_display_date (date) : "");
- g_object_set (G_OBJECT (date_or_status_cell),
- "markup", display_date,
- NULL);
- g_free (tmp_date);
- tmp_date = NULL;
- g_free (display_date);
- display_date = NULL;
+ set_cell_text (date_or_status_cell, date ? modest_text_utils_get_display_date (date) : "",
+ flags, RENDER_CELL_STYLE_GREY);
}
if (msg_header != NULL)
g_object_unref (msg_header);
-
- set_common_flags (date_or_status_cell, flags);
}
size_str = modest_text_utils_get_display_size (size);
- g_object_set (G_OBJECT(renderer), "text", size_str, NULL);
- set_common_flags (renderer, flags);
+ set_cell_text (renderer, size_str, flags, RENDER_CELL_STYLE_DEFAULT);
g_free (size_str);
}
else
status_str = g_strdup(_("mcen_li_outbox_waiting"));
- g_object_set (G_OBJECT(renderer), "text", status_str, NULL);
- set_common_flags (renderer, flags);
+ set_cell_text (renderer, status_str, flags, RENDER_CELL_STYLE_DEFAULT);
g_free (status_str);
}