X-Git-Url: http://git.maemo.org/git/?a=blobdiff_plain;f=src%2Fmodest-ui-dimming-rules.c;h=a640b99298b80fa7bba4deffc9438647a7729b65;hb=08dcf1a20e55e6c05502615b11ff979fa8bac9a9;hp=9ef6c77b4ab72a491c734b419db971262b0e625a;hpb=9ae7eceeacd008dc51dbe04054b06e2ee0bb4e13;p=modest diff --git a/src/modest-ui-dimming-rules.c b/src/modest-ui-dimming-rules.c index 9ef6c77..a640b99 100644 --- a/src/modest-ui-dimming-rules.c +++ b/src/modest-ui-dimming-rules.c @@ -863,11 +863,14 @@ modest_ui_dimming_rules_on_delete_msg (ModestWindow *win, gpointer user_data) * or when viewing a search result. */ if (!dimmed) { - 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)); - if (dimmed) { - modest_dimming_rule_set_notification (rule, _CS("ckct_ib_unable_to_delete")); - } + TnyMsg *top_msg = NULL; + top_msg = modest_msg_view_window_get_top_message ((ModestMsgViewWindow *) win); + if (top_msg != NULL) { + g_object_unref (top_msg); + dimmed = TRUE; + } + if (dimmed) { + modest_dimming_rule_set_notification (rule, _CS("ckct_ib_unable_to_delete")); } } } @@ -947,11 +950,24 @@ gboolean modest_ui_dimming_rules_on_fetch_images (ModestWindow *win, gpointer user_data) { gboolean dimmed = FALSE; + ModestDimmingRule *rule = NULL; g_return_val_if_fail (MODEST_IS_MSG_VIEW_WINDOW (win), FALSE); + rule = MODEST_DIMMING_RULE (user_data); dimmed = !modest_msg_view_window_has_blocked_external_images (MODEST_MSG_VIEW_WINDOW (win)); + if (!dimmed) { + dimmed = _transfer_mode_enabled (win); + if (dimmed) + modest_dimming_rule_set_notification (rule, _("mail_ib_notavailable_downloading")); + } + if (!dimmed) { + dimmed = _msg_download_in_progress (win); + if (dimmed) + modest_dimming_rule_set_notification (rule, _("mcen_ib_unable_to_reply")); + } + return dimmed; } @@ -1193,14 +1209,34 @@ modest_ui_dimming_rules_on_main_window_move_to (ModestWindow *win, gpointer user static gboolean _forbid_outgoing_xfers (ModestWindow *window) { - const gchar *account_name; - TnyAccount *account; + const gchar *account_name = NULL; + TnyAccount *account = NULL; gboolean dimmed = FALSE; - account_name = modest_window_get_active_account (window); - account = modest_tny_account_store_get_server_account (modest_runtime_get_account_store (), - account_name, - TNY_ACCOUNT_TYPE_STORE); +#ifdef MODEST_TOOLKIT_HILDON2 + /* We cannot just get the active account because the active + account of a header window that shows the headers of a + local account is the ID of the remote account */ + if (MODEST_IS_HEADER_WINDOW (window)) { + ModestHeaderView *header_view; + TnyFolder *folder; + + header_view = modest_header_window_get_header_view ((ModestHeaderWindow *) window); + folder = modest_header_view_get_folder (header_view); + + if (folder) { + account = modest_tny_folder_get_account (folder); + g_object_unref (folder); + } + } +#endif + + if (!account) { + account_name = modest_window_get_active_account (window); + account = modest_tny_account_store_get_server_account (modest_runtime_get_account_store (), + account_name, + TNY_ACCOUNT_TYPE_STORE); + } if (account) { ModestProtocolType protocol_type; @@ -1774,6 +1810,27 @@ modest_ui_dimming_rules_on_set_style (ModestWindow *win, gpointer user_data) } gboolean +modest_ui_dimming_rules_on_editor_show_toolbar (ModestWindow *win, gpointer user_data) +{ + ModestDimmingRule *rule = NULL; + gboolean dimmed = FALSE; + + g_return_val_if_fail (MODEST_IS_DIMMING_RULE (user_data), FALSE); + g_return_val_if_fail (MODEST_IS_MSG_EDIT_WINDOW (win), TRUE); + rule = MODEST_DIMMING_RULE (user_data); + + /* Check common dimming rules */ + ModestMsgEditFormat format; + format = modest_msg_edit_window_get_format (MODEST_MSG_EDIT_WINDOW (win)); + + dimmed = (format != MODEST_MSG_EDIT_FORMAT_HTML); + if (dimmed) + modest_dimming_rule_set_notification (rule, _("mcen_ib_item_unavailable_plaintext")); + + return dimmed; +} + +gboolean modest_ui_dimming_rules_on_zoom (ModestWindow *win, gpointer user_data) { ModestDimmingRule *rule = NULL; @@ -1856,42 +1913,29 @@ modest_ui_dimming_rules_on_editor_remove_attachment (ModestWindow *win, gpointer return dimmed; } -gboolean +gboolean modest_ui_dimming_rules_on_send (ModestWindow *win, gpointer user_data) { ModestDimmingRule *rule = NULL; gboolean dimmed = FALSE; - GtkWidget *subject_field, *body_field; - const gchar *subject = NULL; + GtkWidget *body_field; g_return_val_if_fail (MODEST_IS_DIMMING_RULE (user_data), FALSE); g_return_val_if_fail (MODEST_IS_MSG_EDIT_WINDOW (win), TRUE); rule = MODEST_DIMMING_RULE (user_data); - body_field = modest_msg_edit_window_get_child_widget ( - MODEST_MSG_EDIT_WINDOW (win), + body_field = modest_msg_edit_window_get_child_widget (MODEST_MSG_EDIT_WINDOW (win), MODEST_MSG_EDIT_WINDOW_WIDGET_TYPE_BODY); - subject_field = modest_msg_edit_window_get_child_widget ( - MODEST_MSG_EDIT_WINDOW (win), - MODEST_MSG_EDIT_WINDOW_WIDGET_TYPE_SUBJECT); - subject = gtk_entry_get_text (GTK_ENTRY (subject_field)); - - dimmed = (subject == NULL || subject[0] == '\0'); - if (dimmed) - modest_dimming_rule_set_notification (rule, _("mcen_ib_subject_not_modified")); if (!dimmed) { GtkWidget *to_field, *cc_field, *bcc_field; GtkTextBuffer * to_buffer, *cc_buffer, *bcc_buffer; - cc_field = modest_msg_edit_window_get_child_widget ( - MODEST_MSG_EDIT_WINDOW (win), - MODEST_MSG_EDIT_WINDOW_WIDGET_TYPE_CC); - to_field = modest_msg_edit_window_get_child_widget ( - MODEST_MSG_EDIT_WINDOW (win), - MODEST_MSG_EDIT_WINDOW_WIDGET_TYPE_TO); - bcc_field = modest_msg_edit_window_get_child_widget ( - MODEST_MSG_EDIT_WINDOW (win), - MODEST_MSG_EDIT_WINDOW_WIDGET_TYPE_BCC); + cc_field = modest_msg_edit_window_get_child_widget (MODEST_MSG_EDIT_WINDOW (win), + MODEST_MSG_EDIT_WINDOW_WIDGET_TYPE_CC); + to_field = modest_msg_edit_window_get_child_widget (MODEST_MSG_EDIT_WINDOW (win), + MODEST_MSG_EDIT_WINDOW_WIDGET_TYPE_TO); + bcc_field = modest_msg_edit_window_get_child_widget (MODEST_MSG_EDIT_WINDOW (win), + MODEST_MSG_EDIT_WINDOW_WIDGET_TYPE_BCC); to_buffer = modest_recpt_editor_get_buffer (MODEST_RECPT_EDITOR (to_field)); cc_buffer = modest_recpt_editor_get_buffer (MODEST_RECPT_EDITOR (cc_field)); bcc_buffer = modest_recpt_editor_get_buffer (MODEST_RECPT_EDITOR (bcc_field)); @@ -1899,6 +1943,14 @@ modest_ui_dimming_rules_on_send (ModestWindow *win, gpointer user_data) dimmed = ((gtk_text_buffer_get_char_count (to_buffer) + gtk_text_buffer_get_char_count (cc_buffer) + gtk_text_buffer_get_char_count (bcc_buffer)) == 0); + + if (!dimmed) { + if (modest_text_utils_no_recipient (to_buffer) && + modest_text_utils_no_recipient (cc_buffer) && + modest_text_utils_no_recipient (bcc_buffer)) + dimmed = TRUE; + } + if (dimmed) modest_dimming_rule_set_notification (rule, _("mcen_ib_add_recipients_first")); } @@ -2086,45 +2138,52 @@ modest_ui_dimming_rules_on_send_receive_all (ModestWindow *win, gpointer user_da gboolean modest_ui_dimming_rules_on_add_to_contacts (ModestWindow *win, gpointer user_data) { - TnyMsg *msg; - GSList *recipients, *node; + GSList *recipients = NULL; 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)); + if (MODEST_IS_MSG_VIEW_WINDOW (win)) { + TnyMsg *msg; - /* Message is loaded asynchronously, so this could happen */ - if (!msg) { -#ifdef MODEST_TOOLKIT_HILDON2 - TnyHeader *header; + msg = modest_msg_view_window_get_message (MODEST_MSG_VIEW_WINDOW (win)); - header = modest_msg_view_window_get_header (MODEST_MSG_VIEW_WINDOW (win)); - if (!header) - return TRUE; + /* Message is loaded asynchronously, so this could happen */ + if (!msg) { + TnyHeader *header; - 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); + 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 { + recipients = modest_tny_msg_get_all_recipients_list (msg); + g_object_unref (msg); + } + } else if (MODEST_IS_MSG_EDIT_WINDOW (win)) { + /* Check if there are pending addresses to add */ + return !modest_msg_edit_window_has_pending_addresses ((ModestMsgEditWindow *) win); } 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; + + if (recipients) { + GSList *node; + for (node = recipients; node != NULL; node = g_slist_next (node)) { + const gchar *recipient = (const gchar *) node->data; + if (modest_text_utils_validate_recipient (recipient, NULL)) { + if (!modest_address_book_has_address (recipient)) { + has_recipients_to_add = TRUE; + break; + } + } } + g_slist_foreach (recipients, (GFunc) g_free, NULL); + g_slist_free (recipients); } - g_slist_foreach (recipients, (GFunc) g_free, NULL); - g_slist_free (recipients); - return !has_recipients_to_add; } #else @@ -3082,10 +3141,7 @@ modest_ui_dimming_rules_on_insert_image (ModestWindow *win, { g_return_val_if_fail (MODEST_MSG_EDIT_WINDOW (win), FALSE); - ModestMsgEditFormat format = - modest_msg_edit_window_get_format (MODEST_MSG_EDIT_WINDOW (win)); - - return (format != MODEST_MSG_EDIT_FORMAT_HTML); + return modest_ui_dimming_rules_on_set_style (win, user_data); } static gboolean @@ -3209,7 +3265,7 @@ modest_ui_dimming_rules_on_folder_window_move_to (ModestWindow *win, gpointer us if (!dimmed) dimmed = _forbid_outgoing_xfers (win); - if (MODEST_IS_FOLDER_WINDOW (win)) { + if (!dimmed && MODEST_IS_FOLDER_WINDOW (win)) { ModestFolderView *folder_view; folder_view = modest_folder_window_get_folder_view (MODEST_FOLDER_WINDOW (win)); dimmed = !modest_folder_view_any_folder_fulfils_rules (folder_view,