X-Git-Url: http://git.maemo.org/git/?p=modest;a=blobdiff_plain;f=src%2Fmodest-ui-dimming-rules.c;h=e8ba56601dd164e49c595b322452316ed48a6616;hp=fe02ad4c3445bda7d73e3a74f7ed70445976c398;hb=c48ace10ca6cf4b9d4d1cae8d0b9a66b07b9f8c5;hpb=f487b24500a08f1961e36135a4fa4e6db6ddb893 diff --git a/src/modest-ui-dimming-rules.c b/src/modest-ui-dimming-rules.c index fe02ad4..e8ba566 100644 --- a/src/modest-ui-dimming-rules.c +++ b/src/modest-ui-dimming-rules.c @@ -38,13 +38,19 @@ #include "modest-debug.h" #include "modest-tny-folder.h" #include "modest-tny-account.h" +#include "modest-tny-msg.h" #include "modest-tny-mime-part.h" #include "modest-text-utils.h" +#include "modest-address-book.h" #include #include #include #include #include +#include +#ifdef MODEST_TOOLKIT_HILDON2 +#include +#endif static gboolean _folder_is_any_of_type (TnyFolder *folder, TnyFolderType types[], guint ntypes); @@ -73,6 +79,8 @@ static gboolean _invalid_folder_for_purge (ModestWindow *win, ModestDimmingRule static gboolean _transfer_mode_enabled (ModestWindow *win); static gboolean _selected_folder_has_subfolder_with_same_name (ModestWindow *win); static void fill_list_of_caches (gpointer key, gpointer value, gpointer userdata); +static gboolean _send_receive_in_progress (ModestWindow *win); +static gboolean _msgs_send_in_progress (void); static DimmedState * @@ -337,9 +345,11 @@ modest_ui_dimming_rules_on_new_msg (ModestWindow *win, gpointer user_data) /* Check dimmed rule */ if (MODEST_IS_MSG_VIEW_WINDOW(win)) { +#ifndef MODEST_TOOLKIT_HILDON2 dimmed = _msg_download_in_progress (win); if (dimmed) - modest_dimming_rule_set_notification (rule, ""); + modest_dimming_rule_set_notification (rule, ""); +#endif } else if (MODEST_IS_MAIN_WINDOW(win)) { dimmed = !modest_account_mgr_has_accounts(modest_runtime_get_account_mgr(), TRUE); @@ -456,8 +466,31 @@ modest_ui_dimming_rules_on_delete (ModestWindow *win, gpointer user_data) !gtk_widget_is_focus (header_view) && !gtk_widget_is_focus (folder_view)) { dimmed = TRUE; - modest_dimming_rule_set_notification (rule, dgettext("hildon-common-strings", "ckct_ib_nothing_to_delete")); + modest_dimming_rule_set_notification (rule, _CS("ckct_ib_nothing_to_delete")); + } + +#ifdef MODEST_TOOLKIT_HILDON2 + } else if (MODEST_IS_HEADER_WINDOW (win)) { + + if (!dimmed) { + dimmed = _transfer_mode_enabled (win); + } + if (dimmed) + modest_dimming_rule_set_notification (rule, _("mail_ib_notavailable_downloading")); + + if (!dimmed) { + GtkWidget *header_view; + TnyFolder *folder; + + header_view = GTK_WIDGET (modest_header_window_get_header_view (MODEST_HEADER_WINDOW (win))); + folder = modest_header_view_get_folder (MODEST_HEADER_VIEW (header_view)); + if (folder) { + dimmed = (tny_folder_get_all_count (TNY_FOLDER (folder)) == 0); + g_object_unref (folder); + } } + +#endif } else { dimmed = modest_ui_dimming_rules_on_delete_folder (win, rule); } @@ -515,10 +548,16 @@ modest_ui_dimming_rules_on_sort (ModestWindow *win, gpointer user_data) ModestDimmingRule *rule = NULL; gboolean dimmed = FALSE; +#ifdef MODEST_TOOLKIT_HILDON2 + if (MODEST_IS_HEADER_WINDOW (win)) { + return FALSE; + } +#endif + g_return_val_if_fail (MODEST_IS_MAIN_WINDOW(win), FALSE); g_return_val_if_fail (MODEST_IS_DIMMING_RULE (user_data), FALSE); rule = MODEST_DIMMING_RULE (user_data); - + /* Check dimmed rule */ dimmed = _selected_folder_is_root (MODEST_MAIN_WINDOW(win)); @@ -853,7 +892,7 @@ modest_ui_dimming_rules_on_details (ModestWindow *win, gpointer user_data) dimmed = _msg_download_in_progress (win); if (dimmed) modest_dimming_rule_set_notification (rule, ""); - if (!dimmed) { + if (!dimmed && MODEST_IS_MSG_VIEW_WINDOW (win)) { if (!modest_msg_view_window_is_search_result (MODEST_MSG_VIEW_WINDOW(win))) { dimmed = !modest_msg_view_window_has_headers_model (MODEST_MSG_VIEW_WINDOW (win)); } @@ -867,6 +906,65 @@ modest_ui_dimming_rules_on_details (ModestWindow *win, gpointer user_data) gboolean +modest_ui_dimming_rules_on_mark_as_read_msg_in_view (ModestWindow *win, gpointer user_data) +{ + ModestDimmingRule *rule = NULL; + 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 (!dimmed) { + flags = tny_header_get_flags (header); + if (flags & TNY_HEADER_FLAG_SEEN) + dimmed = TRUE; + } + + if (header) + g_object_unref (header); + return dimmed; +} + + +gboolean +modest_ui_dimming_rules_on_mark_as_unread_msg_in_view (ModestWindow *win, gpointer user_data) +{ + ModestDimmingRule *rule = NULL; + 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 (!dimmed) { + flags = tny_header_get_flags (header); + if (!(flags & TNY_HEADER_FLAG_SEEN)) + dimmed = TRUE; + } + + if (header) + g_object_unref (header); + return dimmed; +} + +gboolean modest_ui_dimming_rules_on_mark_as_read_msg (ModestWindow *win, gpointer user_data) { ModestDimmingRule *rule = NULL; @@ -929,6 +1027,10 @@ modest_ui_dimming_rules_on_move_to (ModestWindow *win, gpointer user_data) if (MODEST_IS_MAIN_WINDOW (win)) dimmed = modest_ui_dimming_rules_on_main_window_move_to (win, user_data); +#ifdef MODEST_TOOLKIT_HILDON2 + else if (MODEST_IS_HEADER_WINDOW (win)) + dimmed = modest_ui_dimming_rules_on_header_window_move_to (win, user_data); +#endif else if (MODEST_IS_MSG_VIEW_WINDOW (win)) dimmed = modest_ui_dimming_rules_on_view_window_move_to (win, user_data); @@ -1051,6 +1153,38 @@ modest_ui_dimming_rules_on_view_window_move_to (ModestWindow *win, gpointer user return dimmed; } +#ifdef MODEST_TOOLKIT_HILDON2 +gboolean +modest_ui_dimming_rules_on_header_window_move_to (ModestWindow *win, gpointer user_data) +{ + ModestDimmingRule *rule = NULL; + gboolean dimmed = FALSE; + + g_return_val_if_fail (MODEST_IS_HEADER_WINDOW(win), FALSE); + g_return_val_if_fail (MODEST_IS_DIMMING_RULE (user_data), FALSE); + rule = MODEST_DIMMING_RULE (user_data); + + /* Check dimmed rule */ + dimmed = _transfer_mode_enabled (win); + if (dimmed) + modest_dimming_rule_set_notification (rule, _("mail_ib_notavailable_downloading")); + + if (!dimmed) { + GtkWidget *header_view; + TnyFolder *folder; + + header_view = GTK_WIDGET (modest_header_window_get_header_view (MODEST_HEADER_WINDOW (win))); + folder = modest_header_view_get_folder (MODEST_HEADER_VIEW (header_view)); + if (folder) { + dimmed = (tny_folder_get_all_count (TNY_FOLDER (folder)) == 0); + g_object_unref (folder); + } + } + + return dimmed; +} +#endif + gboolean modest_ui_dimming_rules_on_find_msg (ModestWindow *win, gpointer user_data) { @@ -1088,28 +1222,24 @@ modest_ui_dimming_rules_on_paste (ModestWindow *win, gpointer user_data) dimmed = _clipboard_is_empty (win); if (dimmed) modest_dimming_rule_set_notification (rule, - dgettext("hildon-common-strings", - "ecoc_ib_edwin_nothing_to_paste")); + _CS("ecoc_ib_edwin_nothing_to_paste")); if (!dimmed) { dimmed = _selected_folder_is_any_of_type (win, types, 3); if (dimmed) modest_dimming_rule_set_notification (rule, - dgettext("hildon-common-strings", - "ckct_ib_unable_to_paste_here")); + _CS("ckct_ib_unable_to_paste_here")); } if (!dimmed) { dimmed = !_folder_view_has_focus (win); if (dimmed) modest_dimming_rule_set_notification (rule, - dgettext("hildon-common-strings", - "ckct_ib_unable_to_paste_here")); + _CS("ckct_ib_unable_to_paste_here")); } if (!dimmed) { dimmed = _selected_folder_not_writeable (MODEST_MAIN_WINDOW(win), TRUE); if (dimmed) modest_dimming_rule_set_notification (rule, - dgettext("hildon-common-strings", - "ckct_ib_unable_to_paste_here")); + _CS("ckct_ib_unable_to_paste_here")); } if (!dimmed) { dimmed = _selected_folder_is_same_as_source (win); @@ -1232,6 +1362,7 @@ modest_ui_dimming_rules_on_remove_attachments (ModestWindow *win, gpointer user_ modest_dimming_rule_set_notification (rule, _("FIXME:no attachment selected")); } +#ifndef MODEST_TOOLKIT_HILDON2 /* Messages as attachments could not be removed */ if (!dimmed && MODEST_IS_MSG_VIEW_WINDOW (win)) { TnyList *attachments; @@ -1251,6 +1382,7 @@ modest_ui_dimming_rules_on_remove_attachments (ModestWindow *win, gpointer user_ g_object_unref (attachments); } } +#endif if (!dimmed) { @@ -1711,17 +1843,29 @@ modest_ui_dimming_rules_on_cancel_sending (ModestWindow *win, gpointer user_data } gboolean +modest_ui_dimming_rules_on_cancel_sending_all (ModestWindow *win, gpointer user_data) +{ + /* We dim if no msg send is in progress (and then cancelling send all has no + * effect */ + return !_msgs_send_in_progress (); +} + +gboolean modest_ui_dimming_rules_on_send_receive (ModestWindow *win, gpointer user_data) { ModestDimmingRule *rule = NULL; gboolean dimmed = FALSE; - + ModestAccountMgr *mgr; + const gchar* account_name; + g_return_val_if_fail (MODEST_IS_DIMMING_RULE (user_data), FALSE); rule = MODEST_DIMMING_RULE (user_data); - - /* Check dimmed rule */ - dimmed = !modest_account_mgr_has_accounts(modest_runtime_get_account_mgr(), - TRUE); + mgr = modest_runtime_get_account_mgr(); + + /* Check dimmed rule */ + account_name = modest_window_get_active_account (win); + dimmed = modest_account_mgr_account_is_busy (mgr, account_name); + if (dimmed) modest_dimming_rule_set_notification (rule, _("mcen_nc_no_email_acnts_defined")); @@ -1733,22 +1877,72 @@ 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")); - + modest_account_mgr_free_account_names (account_names); + if (!dimmed) { + dimmed = _send_receive_in_progress (win); + } + return dimmed; } +#ifdef MODEST_TOOLKIT_HILDON2 +gboolean +modest_ui_dimming_rules_on_add_to_contacts (ModestWindow *win, gpointer user_data) +{ + TnyMsg *msg; + GSList *recipients, *node; + gboolean has_recipients_to_add; + + g_return_val_if_fail (MODEST_IS_DIMMING_RULE (user_data), FALSE); + g_return_val_if_fail (MODEST_IS_MSG_VIEW_WINDOW (win), FALSE); + + msg = modest_msg_view_window_get_message (MODEST_MSG_VIEW_WINDOW (win)); + + /* Message is loaded asynchronously, so this could happen */ + if (!msg) { +#ifdef MODEST_TOOLKIT_HILDON2 + TnyHeader *header; + + header = modest_msg_view_window_get_header (MODEST_MSG_VIEW_WINDOW (win)); + if (!header) + return TRUE; + + recipients = modest_tny_msg_header_get_all_recipients_list (header); + g_object_unref (header); +#else + return TRUE; +#endif + } else { + recipients = modest_tny_msg_get_all_recipients_list (msg); + g_object_unref (msg); + } + + has_recipients_to_add = FALSE; + for (node = recipients; node != NULL; node = g_slist_next (node)) { + if (!modest_address_book_has_address ((const gchar *) node->data)) { + has_recipients_to_add = TRUE; + break; + } + } + + g_slist_foreach (recipients, (GFunc) g_free, NULL); + g_slist_free (recipients); + + return !has_recipients_to_add; +} +#else gboolean modest_ui_dimming_rules_on_add_to_contacts (ModestWindow *win, gpointer user_data) { @@ -1756,7 +1950,7 @@ modest_ui_dimming_rules_on_add_to_contacts (ModestWindow *win, gpointer user_dat gboolean dimmed = FALSE; GtkWidget *focused = NULL; - g_return_val_if_fail (MODEST_IS_DIMMING_RULE (user_data), FALSE); + g_return_val_if_fail (MODEST_IS_DIMMING_RULE (user_data), FALSE); rule = MODEST_DIMMING_RULE (user_data); focused = gtk_window_get_focus (GTK_WINDOW (win)); @@ -1796,6 +1990,7 @@ modest_ui_dimming_rules_on_add_to_contacts (ModestWindow *win, gpointer user_dat return dimmed; } +#endif /* *********************** static utility functions ******************** */ @@ -2330,9 +2525,15 @@ _invalid_attach_selected (ModestWindow *win, while (!tny_iterator_is_done (iter) && !result) { TnyMimePart *mime_part = TNY_MIME_PART (tny_iterator_get_current (iter)); TnyList *nested_list = tny_simple_list_new (); + if (!for_remove && modest_tny_mime_part_is_msg (mime_part)) { - selected_messages = TRUE; - result = TRUE; + 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; + result = TRUE; + } + g_object_unref (window_msg); } tny_mime_part_get_parts (mime_part, nested_list); if (!for_remove && tny_list_get_length (nested_list) > 0) { @@ -2390,7 +2591,7 @@ _purged_attach_selected (ModestWindow *win, gboolean all, ModestDimmingRule *rul if (attachments == NULL) return FALSE; - if (tny_list_get_length (attachments)) { + if (tny_list_get_length (attachments) == 0) { g_object_unref (attachments); return FALSE; } @@ -2568,6 +2769,10 @@ _transfer_mode_enabled (ModestWindow *win) result = modest_msg_view_window_transfer_mode_enabled (MODEST_MSG_VIEW_WINDOW (win)); } else if (MODEST_IS_MAIN_WINDOW(win)) { result = modest_main_window_transfer_mode_enabled (MODEST_MAIN_WINDOW (win)); +#ifdef MODEST_TOOLKIT_HILDON2 + } else if (MODEST_IS_HEADER_WINDOW (win)) { + result = modest_header_window_transfer_mode_enabled (MODEST_HEADER_WINDOW (win)); +#endif } else { g_warning("_transfer_mode_enabled called with wrong window type"); } @@ -2639,3 +2844,60 @@ modest_ui_dimming_rules_on_insert_image (ModestWindow *win, return (format != MODEST_MSG_EDIT_FORMAT_HTML); } + +static gboolean +_send_receive_in_progress (ModestWindow *win) +{ + ModestMailOperationQueue *queue; + GSList *op_list, *node; + gboolean found_send_receive; + + queue = modest_runtime_get_mail_operation_queue (); + op_list = modest_mail_operation_queue_get_by_source (queue, G_OBJECT (win)); + + found_send_receive = FALSE; + for (node = op_list; node != NULL; node = g_slist_next (node)) { + ModestMailOperation *op; + + op = (ModestMailOperation *) node->data; + if (modest_mail_operation_get_type_operation (op) == MODEST_MAIL_OPERATION_TYPE_SEND_AND_RECEIVE) { + found_send_receive = TRUE; + break; + } + } + + g_slist_foreach (op_list, (GFunc) g_object_unref, NULL); + g_slist_free (op_list); + + return found_send_receive; +} + +static gboolean +_msgs_send_in_progress (void) +{ + ModestCacheMgr *cache_mgr; + GHashTable *send_queue_cache; + ModestTnySendQueue *send_queue; + GSList *send_queues = NULL, *node = NULL; + gboolean found = FALSE; + + 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; + break; + } + } + + g_slist_free (send_queues); + + return found; +}