X-Git-Url: http://git.maemo.org/git/?p=modest;a=blobdiff_plain;f=src%2Fmodest-ui-dimming-rules.c;h=1738cadafa2f18954b98f065cba5e0062d18c5a6;hp=113eea48236bdcd2b6f276fa799aae3f537fd046;hb=de624fe2927ec169f0094c4b8cfd83c65a9336d5;hpb=24c5dee833bff8a499b6b6bca3c58231ae2a7f96 diff --git a/src/modest-ui-dimming-rules.c b/src/modest-ui-dimming-rules.c index 113eea4..1738cad 100644 --- a/src/modest-ui-dimming-rules.c +++ b/src/modest-ui-dimming-rules.c @@ -41,7 +41,7 @@ #include "modest-tny-msg.h" #include "modest-tny-mime-part.h" #include "modest-text-utils.h" -#include +#include "modest-address-book.h" #include #include #include @@ -912,17 +912,21 @@ modest_ui_dimming_rules_on_mark_as_read_msg_in_view (ModestWindow *win, gpointer TnyHeader *header; TnyHeaderFlags flags; gboolean dimmed = FALSE; - + g_return_val_if_fail (MODEST_IS_MSG_VIEW_WINDOW(win), FALSE); g_return_val_if_fail (MODEST_IS_DIMMING_RULE (user_data), FALSE); rule = MODEST_DIMMING_RULE (user_data); - + header = modest_msg_view_window_get_header (MODEST_MSG_VIEW_WINDOW (win)); if (!header) { dimmed = TRUE; } + /* If the viewer is showing a message sent as attachment */ + if (!dimmed) + dimmed = !modest_msg_view_window_has_headers_model (MODEST_MSG_VIEW_WINDOW (win)); + if (!dimmed) { flags = tny_header_get_flags (header); if (flags & TNY_HEADER_FLAG_SEEN) @@ -953,6 +957,10 @@ modest_ui_dimming_rules_on_mark_as_unread_msg_in_view (ModestWindow *win, gpoint dimmed = TRUE; } + /* If the viewer is showing a message sent as attachment */ + if (!dimmed) + dimmed = !modest_msg_view_window_has_headers_model (MODEST_MSG_VIEW_WINDOW (win)); + if (!dimmed) { flags = tny_header_get_flags (header); if (!(flags & TNY_HEADER_FLAG_SEEN)) @@ -1877,13 +1885,13 @@ modest_ui_dimming_rules_on_send_receive_all (ModestWindow *win, gpointer user_da { ModestDimmingRule *rule = NULL; gboolean dimmed = FALSE; - + g_return_val_if_fail (MODEST_IS_DIMMING_RULE (user_data), FALSE); rule = MODEST_DIMMING_RULE (user_data); /* Check dimmed rule */ GSList *account_names = modest_account_mgr_account_names (modest_runtime_get_account_mgr (), TRUE); - if (g_slist_length (account_names) <= 1) + if (g_slist_length (account_names) < 1) dimmed = TRUE; if (dimmed) modest_dimming_rule_set_notification (rule, _("mcen_nc_no_email_acnts_defined")); @@ -2523,29 +2531,48 @@ _invalid_attach_selected (ModestWindow *win, TnyIterator *iter; iter = tny_list_create_iterator (attachments); while (!tny_iterator_is_done (iter) && !result) { +#ifdef MODEST_TOOLKIT_HILDON2 + gboolean not_selectable = FALSE; +#endif TnyMimePart *mime_part = TNY_MIME_PART (tny_iterator_get_current (iter)); TnyList *nested_list = tny_simple_list_new (); + tny_mime_part_get_parts (mime_part, nested_list); if (!for_remove && modest_tny_mime_part_is_msg (mime_part)) { TnyMsg *window_msg; window_msg = modest_msg_view_window_get_message (MODEST_MSG_VIEW_WINDOW (win)); if ((TnyMimePart *) window_msg != mime_part) { selected_messages = TRUE; +#ifdef MODEST_TOOLKIT_HILDON2 + not_selectable = TRUE; +#else result = TRUE; +#endif } g_object_unref (window_msg); } - tny_mime_part_get_parts (mime_part, nested_list); if (!for_remove && tny_list_get_length (nested_list) > 0) { nested_attachments = TRUE; +#ifdef MODEST_TOOLKIT_HILDON2 + not_selectable = TRUE; +#else result = TRUE; +#endif } +#ifdef MODEST_TOOLKIT_HILDON2 + if (not_selectable) + n_selected --; +#endif g_object_unref (nested_list); g_object_unref (mime_part); tny_iterator_next (iter); } g_object_unref (iter); } + + /* No valid attachment available */ + if (n_selected == 0) + result = TRUE; /* Set notifications */ if (result && rule != NULL) { @@ -2884,12 +2911,12 @@ _msgs_send_in_progress (void) cache_mgr = modest_runtime_get_cache_mgr (); send_queue_cache = modest_cache_mgr_get_cache (cache_mgr, MODEST_CACHE_MGR_CACHE_TYPE_SEND_QUEUE); - + g_hash_table_foreach (send_queue_cache, (GHFunc) fill_list_of_caches, &send_queues); - + for (node = send_queues; node != NULL && !found; node = g_slist_next (node)) { send_queue = MODEST_TNY_SEND_QUEUE (node->data); - + /* Check if msg uid is being processed inside send queue */ if (modest_tny_send_queue_sending_in_progress (send_queue)) { found = TRUE;