X-Git-Url: https://vcs.maemo.org/git/?a=blobdiff_plain;f=src%2Fmodest-ui-dimming-rules.c;h=0bbde7fb9ce21e3437ec177b94ecc537748dbf93;hb=07b7ad35990c57d36183fa0914b63e314ffe74ac;hp=c929b22fa8d505164c77e95e9dfe7c45f885686b;hpb=0d2a5000505e556cf6ba3e2cda699d9610a80782;p=modest diff --git a/src/modest-ui-dimming-rules.c b/src/modest-ui-dimming-rules.c index c929b22..0bbde7f 100644 --- a/src/modest-ui-dimming-rules.c +++ b/src/modest-ui-dimming-rules.c @@ -206,11 +206,7 @@ modest_ui_dimming_rules_on_delete (ModestWindow *win, gpointer user_data) rule = MODEST_DIMMING_RULE (user_data); if (MODEST_IS_FOLDER_WINDOW (win)) { -#ifdef MODEST_TOOLKIT_HILDON2 dimmed = modest_ui_dimming_rules_on_folder_window_delete (win, user_data); -#else - dimmed = FALSE; -#endif } else if (MODEST_IS_HEADER_WINDOW (win)) { if (!dimmed) @@ -424,11 +420,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_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")); } } } @@ -460,11 +459,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; } @@ -546,17 +558,9 @@ modest_ui_dimming_rules_on_move_to (ModestWindow *win, gpointer user_data) rule = MODEST_DIMMING_RULE (user_data); if (MODEST_IS_HEADER_WINDOW (win)) -#ifdef MODEST_TOOLKIT_HILDON2 dimmed = modest_ui_dimming_rules_on_header_window_move_to (win, user_data); -#else - dimmed = TRUE; -#endif else if (MODEST_IS_FOLDER_WINDOW (win)) -#ifdef MODEST_TOOLKIT_HILDON2 dimmed = modest_ui_dimming_rules_on_folder_window_move_to (win, user_data); -#else - dimmed = TRUE; -#endif else if (MODEST_IS_MSG_VIEW_WINDOW (win)) dimmed = modest_ui_dimming_rules_on_view_window_move_to (win, user_data); @@ -718,8 +722,7 @@ modest_ui_dimming_rules_on_select_all (ModestWindow *win, gpointer user_data) 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)); - + focused = gtk_container_get_focus_child ((GtkContainer *) win); if (!dimmed && GTK_IS_ENTRY (focused)) { const gchar *current_text; @@ -980,6 +983,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; @@ -1011,7 +1035,7 @@ modest_ui_dimming_rules_on_editor_paste (ModestWindow *win, gpointer user_data) g_return_val_if_fail (MODEST_IS_MSG_EDIT_WINDOW (win), TRUE); rule = MODEST_DIMMING_RULE (user_data); - focused = gtk_window_get_focus (GTK_WINDOW (win)); + focused = gtk_container_get_focus_child ((GtkContainer *) win); dimmed = MODEST_IS_ATTACHMENTS_VIEW (focused); @@ -1057,7 +1081,7 @@ 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; @@ -1087,6 +1111,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")); } @@ -1330,7 +1362,7 @@ _invalid_clipboard_selected (ModestWindow *win, g_return_val_if_fail (MODEST_IS_WINDOW(win), FALSE); /* Get focuesed widget */ - focused = gtk_window_get_focus (GTK_WINDOW (win)); + focused = gtk_container_get_focus_child ((GtkContainer *) win); if (MODEST_IS_MSG_EDIT_WINDOW (win)) { gboolean has_selection = FALSE; @@ -1671,10 +1703,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 @@ -1736,10 +1765,6 @@ _msgs_send_in_progress (void) return found; } -/*****************************************************************************/ -/********************** HILDON2 only dimming rules ***************************/ -/*****************************************************************************/ - gboolean modest_ui_dimming_rules_on_header_window_move_to (ModestWindow *win, gpointer user_data) { @@ -1813,7 +1838,7 @@ modest_ui_dimming_rules_on_folder_window_move_to (ModestWindow *win, gpointer us return dimmed; } -gboolean +gboolean modest_ui_dimming_rules_on_folder_window_delete (ModestWindow *win, gpointer user_data) { ModestDimmingRule *rule = NULL; @@ -1823,7 +1848,7 @@ modest_ui_dimming_rules_on_folder_window_delete (ModestWindow *win, gpointer use g_return_val_if_fail (MODEST_IS_DIMMING_RULE (user_data), FALSE); rule = MODEST_DIMMING_RULE (user_data); - /* Check dimmed rule */ + /* Check dimmed rule */ dimmed = _transfer_mode_enabled (win); if (dimmed) modest_dimming_rule_set_notification (rule, _("mail_ib_notavailable_downloading"));