X-Git-Url: http://git.maemo.org/git/?p=modest;a=blobdiff_plain;f=src%2Fmodest-ui-dimming-rules.c;h=59d56175d963410c550d98180832c208d0793256;hp=767d5e80b1d785719545cc2bdce38ca071a4dc80;hb=b3e33b42465084b4e1cf2dbf90302bd1b43d05ad;hpb=465af7a0332b1b77bf150054a33deb5dbdaf7da3 diff --git a/src/modest-ui-dimming-rules.c b/src/modest-ui-dimming-rules.c index 767d5e8..59d5617 100644 --- a/src/modest-ui-dimming-rules.c +++ b/src/modest-ui-dimming-rules.c @@ -40,6 +40,7 @@ #include #include #include +#include static gboolean _folder_is_any_of_type (TnyFolder *folder, TnyFolderType types[], guint ntypes); @@ -62,7 +63,7 @@ static gboolean _header_view_is_all_selected (ModestMainWindow *win); static gboolean _selected_folder_is_empty (ModestMainWindow *win); static gboolean _folder_view_has_focus (ModestWindow *win); static gboolean _selected_folder_is_same_as_source (ModestWindow *win); -static gboolean _msg_download_in_progress (ModestMsgViewWindow *win); +static gboolean _msg_download_in_progress (ModestWindow *win); static gboolean _msg_download_completed (ModestMainWindow *win); static gboolean _selected_msg_sent_in_progress (ModestWindow *win); static gboolean _sending_in_progress (ModestWindow *win); @@ -100,7 +101,7 @@ _define_main_window_dimming_state (ModestMainWindow *window) /* Init state */ state = g_slice_new0 (DimmedState); state->n_selected = 0; - state->already_opened_msg = FALSE; + state->already_opened_msg = 0; state->any_marked_as_deleted = FALSE; state->all_marked_as_deleted = FALSE; state->any_marked_as_seen = FALSE; @@ -120,7 +121,7 @@ _define_main_window_dimming_state (ModestMainWindow *window) } else if (MODEST_IS_HEADER_VIEW (focused_widget)) { header_view = focused_widget; } else { - header_view = modest_main_window_get_child_widget (window, MODEST_WIDGET_TYPE_HEADER_VIEW); + header_view = modest_main_window_get_child_widget (window, MODEST_MAIN_WINDOW_WIDGET_TYPE_HEADER_VIEW); } /* Get header view and selected headers */ @@ -139,8 +140,8 @@ _define_main_window_dimming_state (ModestMainWindow *window) /* Already opened */ mgr = modest_runtime_get_window_mgr (); - if (!state->already_opened_msg) - state->already_opened_msg = modest_window_mgr_find_registered_header (mgr, header, NULL); + if (modest_window_mgr_find_registered_header (mgr, header, NULL)) + state->already_opened_msg++; /* Mark as deleted */ @@ -194,7 +195,7 @@ _define_main_window_dimming_state (ModestMainWindow *window) if (model != NULL){ gint count; count = gtk_tree_model_iter_n_children(model, NULL); - if(state->n_selected == count != 0) + if(state->n_selected == count) state->all_selected = TRUE; } @@ -229,7 +230,7 @@ _define_msg_view_window_dimming_state (ModestMsgViewWindow *window) /* Init state */ state = g_slice_new0 (DimmedState); state->n_selected = 0; - state->already_opened_msg = FALSE; + state->already_opened_msg = 0; state->any_marked_as_deleted = FALSE; state->all_marked_as_deleted = FALSE; state->any_marked_as_seen = FALSE; @@ -241,6 +242,8 @@ _define_msg_view_window_dimming_state (ModestMsgViewWindow *window) state->sent_in_progress = FALSE; header = modest_msg_view_window_get_header (MODEST_MSG_VIEW_WINDOW(window)); + if (header == NULL) + return state; g_return_val_if_fail (TNY_IS_HEADER(header), state); flags = tny_header_get_flags (header); @@ -269,7 +272,7 @@ _define_msg_view_window_dimming_state (ModestMsgViewWindow *window) all_has_attach = all_has_attach && (flags & TNY_HEADER_FLAG_ATTACHMENTS); state->all_has_attachments = all_has_attach; if (!state->any_has_attachments) - state->any_has_attachments = flags & TNY_HEADER_FLAG_ATTACHMENTS; + state->any_has_attachments = (flags & TNY_HEADER_FLAG_ATTACHMENTS)?1:0; /* sent in progress */ msg_uid = modest_tny_send_queue_get_msg_id (header); @@ -321,15 +324,24 @@ modest_ui_dimming_rules_on_new_msg (ModestWindow *win, gpointer user_data) ModestDimmingRule *rule = NULL; gboolean dimmed = FALSE; - g_return_val_if_fail (MODEST_IS_MSG_VIEW_WINDOW(win), FALSE); + g_return_val_if_fail (MODEST_IS_WINDOW(win), FALSE); g_return_val_if_fail (MODEST_IS_DIMMING_RULE (user_data), FALSE); rule = MODEST_DIMMING_RULE (user_data); /* Check dimmed rule */ - if (!dimmed) { - dimmed = _msg_download_in_progress (MODEST_MSG_VIEW_WINDOW(win)); - if (dimmed) - modest_dimming_rule_set_notification (rule, ""); + if (MODEST_IS_MSG_VIEW_WINDOW(win)) { + if (!dimmed) { + dimmed = _msg_download_in_progress (win); + if (dimmed) + modest_dimming_rule_set_notification (rule, ""); + } + } else if (MODEST_IS_MAIN_WINDOW(win)) { + if (!dimmed) { + dimmed = !modest_account_mgr_has_accounts(modest_runtime_get_account_mgr(), + TRUE); + if (dimmed) + modest_dimming_rule_set_notification (rule, _("mcen_nc_no_email_acnts_defined")); + } } return dimmed; @@ -347,9 +359,17 @@ modest_ui_dimming_rules_on_new_folder (ModestWindow *win, gpointer user_data) g_return_val_if_fail (MODEST_IS_DIMMING_RULE (user_data), FALSE); rule = MODEST_DIMMING_RULE (user_data); + if (!dimmed) { + dimmed = _transfer_mode_enabled (win); + if (dimmed) { + modest_dimming_rule_set_notification (rule, _("mail_in_ui_folder_create_error")); + return dimmed; + } + } + /* Get selected folder as parent of new folder to create */ folder_view = modest_main_window_get_child_widget (MODEST_MAIN_WINDOW(win), - MODEST_WIDGET_TYPE_FOLDER_VIEW); + MODEST_MAIN_WINDOW_WIDGET_TYPE_FOLDER_VIEW); parent_folder = modest_folder_view_get_selected (MODEST_FOLDER_VIEW(folder_view)); if (!parent_folder) return TRUE; @@ -392,7 +412,7 @@ modest_ui_dimming_rules_on_new_folder (ModestWindow *win, gpointer user_data) /* if not the folder is selected then dim */ folder_view = modest_main_window_get_child_widget (MODEST_MAIN_WINDOW(win), - MODEST_WIDGET_TYPE_FOLDER_VIEW); + MODEST_MAIN_WINDOW_WIDGET_TYPE_FOLDER_VIEW); if (folder_view && !gtk_widget_is_focus (folder_view)) dimmed = TRUE; @@ -415,11 +435,11 @@ modest_ui_dimming_rules_on_delete (ModestWindow *win, gpointer user_data) if (MODEST_IS_MAIN_WINDOW (win)) { /* Get the folder view */ folder_view = modest_main_window_get_child_widget (MODEST_MAIN_WINDOW(win), - MODEST_WIDGET_TYPE_FOLDER_VIEW); + MODEST_MAIN_WINDOW_WIDGET_TYPE_FOLDER_VIEW); /* Get header view */ header_view = modest_main_window_get_child_widget (MODEST_MAIN_WINDOW(win), - MODEST_WIDGET_TYPE_HEADER_VIEW); + MODEST_MAIN_WINDOW_WIDGET_TYPE_HEADER_VIEW); if (header_view && gtk_widget_is_focus (header_view)) dimmed = modest_ui_dimming_rules_on_delete_msg (win, rule); @@ -548,6 +568,11 @@ modest_ui_dimming_rules_on_rename_folder (ModestWindow *win, gpointer user_data) if (dimmed) modest_dimming_rule_set_notification (rule, ""); } + if (!dimmed) { + dimmed = _transfer_mode_enabled (win); + if (dimmed) + modest_dimming_rule_set_notification (rule, ""); + } return dimmed; } @@ -623,7 +648,7 @@ modest_ui_dimming_rules_on_reply_msg (ModestWindow *win, gpointer user_data) modest_dimming_rule_set_notification (rule, _("mail_ib_notavailable_downloading")); } if (!dimmed) { - dimmed = _msg_download_in_progress (MODEST_MSG_VIEW_WINDOW (win)); + dimmed = _msg_download_in_progress (win); if (dimmed) modest_dimming_rule_set_notification (rule, _("mcen_ib_unable_to_reply")); } @@ -674,7 +699,6 @@ gboolean modest_ui_dimming_rules_on_delete_msg (ModestWindow *win, gpointer user_data) { ModestDimmingRule *rule = NULL; - guint n_messages = 0; const DimmedState *state = NULL; gboolean dimmed = FALSE; @@ -693,14 +717,15 @@ modest_ui_dimming_rules_on_delete_msg (ModestWindow *win, gpointer user_data) dimmed = _invalid_msg_selected (MODEST_MAIN_WINDOW(win), FALSE, user_data); } if (!dimmed) { - dimmed = state->already_opened_msg; - n_messages = state->n_selected; + dimmed = (state->already_opened_msg > 0) ? TRUE : FALSE; if (dimmed) { - gchar *num = g_strdup_printf ("%d", n_messages); - gchar *message = g_strdup_printf(_("mcen_nc_unable_to_delete_n_messages"), num); + gchar *num = NULL, *message = NULL; + + num = g_strdup_printf ("%d", state->already_opened_msg); + message = g_strdup_printf(_("mcen_nc_unable_to_delete_n_messages"), num); modest_dimming_rule_set_notification (rule, message); + g_free(num); g_free(message); - g_free(num); } } @@ -727,6 +752,11 @@ modest_ui_dimming_rules_on_delete_msg (ModestWindow *win, gpointer user_data) if (dimmed) modest_dimming_rule_set_notification (rule, _("mcen_ib_message_already_deleted")); } + if (!dimmed) { + dimmed = state->sent_in_progress; + if (dimmed) + modest_dimming_rule_set_notification (rule, _CS("ckct_ib_unable_to_delete")); + } /* The delete button should be dimmed when viewing an attachment, * but should be enabled when viewing a message from the list, @@ -760,7 +790,7 @@ modest_ui_dimming_rules_on_details (ModestWindow *win, gpointer user_data) /* Check dimmed rule */ header_view = modest_main_window_get_child_widget (MODEST_MAIN_WINDOW (win), - MODEST_WIDGET_TYPE_HEADER_VIEW); + MODEST_MAIN_WINDOW_WIDGET_TYPE_HEADER_VIEW); /* If the header view has the focus: */ if (header_view && gtk_widget_is_focus (header_view)) { @@ -771,7 +801,7 @@ modest_ui_dimming_rules_on_details (ModestWindow *win, gpointer user_data) else { /* If the folder view has the focus: */ GtkWidget *folder_view = modest_main_window_get_child_widget (MODEST_MAIN_WINDOW (win), - MODEST_WIDGET_TYPE_FOLDER_VIEW); + MODEST_MAIN_WINDOW_WIDGET_TYPE_FOLDER_VIEW); if (folder_view && gtk_widget_is_focus (folder_view)) { TnyFolderStore *folder_store = modest_folder_view_get_selected (MODEST_FOLDER_VIEW (folder_view)); @@ -786,7 +816,16 @@ modest_ui_dimming_rules_on_details (ModestWindow *win, gpointer user_data) } g_object_unref (folder_store); + } else { + dimmed = TRUE; + modest_dimming_rule_set_notification (rule, ""); } + if (!dimmed) { + dimmed = _msg_download_in_progress (win); + if (dimmed) + modest_dimming_rule_set_notification (rule, ""); + } + } } @@ -797,7 +836,7 @@ modest_ui_dimming_rules_on_details (ModestWindow *win, gpointer user_data) /* Check dimmed rule */ if (!dimmed) { if (MODEST_IS_MSG_VIEW_WINDOW (win)) - dimmed = _msg_download_in_progress (MODEST_MSG_VIEW_WINDOW (win)); + dimmed = _msg_download_in_progress (win); if (dimmed) modest_dimming_rule_set_notification (rule, ""); } @@ -885,7 +924,6 @@ modest_ui_dimming_rules_on_main_window_move_to (ModestWindow *win, gpointer user { GtkWidget *folder_view = NULL; ModestDimmingRule *rule = NULL; - guint n_messages = 0; const DimmedState *state = NULL; gboolean dimmed = FALSE; @@ -896,7 +934,7 @@ modest_ui_dimming_rules_on_main_window_move_to (ModestWindow *win, gpointer user /* Get the folder view */ folder_view = modest_main_window_get_child_widget (MODEST_MAIN_WINDOW(win), - MODEST_WIDGET_TYPE_FOLDER_VIEW); + MODEST_MAIN_WINDOW_WIDGET_TYPE_FOLDER_VIEW); /* Check diming rules for folders transfer */ @@ -924,10 +962,10 @@ modest_ui_dimming_rules_on_main_window_move_to (ModestWindow *win, gpointer user /* Check diming rules for messages transfer */ if (!dimmed) { - dimmed = state->already_opened_msg; - n_messages = state->n_selected; + dimmed = (state->already_opened_msg > 0) ? TRUE : FALSE; if (dimmed) { - gchar *message = g_strdup_printf(_("emev_bd_unabletomove_items"), n_messages); + gchar *message = g_strdup_printf(_("emev_bd_unabletomove_items"), + state->already_opened_msg); modest_dimming_rule_set_notification (rule, message); g_free(message); } @@ -964,6 +1002,11 @@ modest_ui_dimming_rules_on_view_window_move_to (ModestWindow *win, gpointer user } if (!dimmed) { + dimmed = _selected_msg_sent_in_progress (win); + if (dimmed) + modest_dimming_rule_set_notification (rule, _("mcen_ib_unable_to_move_mail_attachment")); + } + if (!dimmed) { if (MODEST_IS_MSG_VIEW_WINDOW (win)) { /* The move_to button should be dimmed when viewing an attachment, * but should be enabled when viewing a message from the list, @@ -1055,7 +1098,7 @@ modest_ui_dimming_rules_on_paste (ModestWindow *win, gpointer user_data) if (dimmed) modest_dimming_rule_set_notification (rule, _("mcen_ib_unable_to_copy_samefolder")); } - + return dimmed; } @@ -1065,21 +1108,34 @@ modest_ui_dimming_rules_on_select_all (ModestWindow *win, gpointer user_data) { ModestDimmingRule *rule = NULL; gboolean dimmed = FALSE; + GtkWidget *focused = NULL; - g_return_val_if_fail (MODEST_IS_MAIN_WINDOW(win), FALSE); + g_return_val_if_fail (MODEST_IS_WINDOW(win), FALSE); g_return_val_if_fail (MODEST_IS_DIMMING_RULE (user_data), FALSE); rule = MODEST_DIMMING_RULE (user_data); - /* Check dimmed rule */ - if (!dimmed) + focused = gtk_window_get_focus (GTK_WINDOW (win)); + + /* Main window dimming rules */ + if (!dimmed && MODEST_IS_MAIN_WINDOW (win)) dimmed = _selected_folder_is_empty (MODEST_MAIN_WINDOW(win)); - if (!dimmed) + if (!dimmed && MODEST_IS_MAIN_WINDOW (win)) dimmed = _header_view_is_all_selected (MODEST_MAIN_WINDOW(win)); - if (dimmed) - modest_dimming_rule_set_notification (rule, ""); - + if (!dimmed && GTK_IS_ENTRY (focused)) { + const gchar *current_text; + current_text = gtk_entry_get_text (GTK_ENTRY (focused)); + dimmed = ((current_text == NULL) || (current_text[0] == '\0')); + } + + if (!dimmed && GTK_IS_TEXT_VIEW (focused)) { + GtkTextBuffer *buffer = gtk_text_view_get_buffer (GTK_TEXT_VIEW (focused)); + dimmed = (gtk_text_buffer_get_char_count (buffer) < 1); + } + + if (dimmed && MODEST_IS_ATTACHMENTS_VIEW (focused)) + dimmed = FALSE; return dimmed; } @@ -1162,7 +1218,7 @@ modest_ui_dimming_rules_on_remove_attachments (ModestWindow *win, gpointer user_ /* Check if the selected message in main window has attachments */ if (!dimmed && MODEST_IS_MAIN_WINDOW (win)) { - dimmed = state->any_has_attachments; + dimmed = !(state->any_has_attachments); if (dimmed) modest_dimming_rule_set_notification (rule, _("mail_ib_unable_to_purge_attachments")); } @@ -1193,11 +1249,32 @@ modest_ui_dimming_rules_on_undo (ModestWindow *win, gpointer user_data) rule = MODEST_DIMMING_RULE (user_data); /* Check dimmed rule */ - if (!dimmed) { + if (!dimmed && MODEST_IS_MAIN_WINDOW (win)) { dimmed = _clipboard_is_empty (win); if (dimmed) modest_dimming_rule_set_notification (rule, ""); } + + if (!dimmed && MODEST_IS_MSG_EDIT_WINDOW (win)) { + dimmed = !modest_msg_edit_window_can_undo (MODEST_MSG_EDIT_WINDOW (win)); + } + + return dimmed; +} + +gboolean +modest_ui_dimming_rules_on_redo (ModestWindow *win, gpointer user_data) +{ + 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 */ + if (!dimmed && MODEST_IS_MSG_EDIT_WINDOW (win)) { + dimmed = !modest_msg_edit_window_can_redo (MODEST_MSG_EDIT_WINDOW (win)); + } return dimmed; } @@ -1235,7 +1312,7 @@ modest_ui_dimming_rules_on_cut (ModestWindow *win, gpointer user_data) modest_dimming_rule_set_notification (rule, _("mcen_ib_unable_to_cut_mess")); } if (!dimmed) { - dimmed = state->already_opened_msg; + dimmed = (state->already_opened_msg > 0) ? TRUE : FALSE; if(dimmed) modest_dimming_rule_set_notification (rule, _("mcen_ib_unable_to_cut_mess")); } @@ -1302,7 +1379,7 @@ modest_ui_dimming_rules_on_copy (ModestWindow *win, gpointer user_data) modest_dimming_rule_set_notification (rule, _("")); } if (!dimmed) { - dimmed = state->already_opened_msg; + dimmed = (state->already_opened_msg > 0) ? TRUE : FALSE; if(dimmed) modest_dimming_rule_set_notification (rule, _("")); } @@ -1331,6 +1408,190 @@ modest_ui_dimming_rules_on_copy (ModestWindow *win, gpointer user_data) } gboolean +modest_ui_dimming_rules_on_set_style (ModestWindow *win, gpointer user_data) +{ + ModestDimmingRule *rule = NULL; + const DimmedState *state = 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); + state = modest_window_get_dimming_state (win); + + + /* Check common dimming rules */ + if (!dimmed) { + 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")); + } + + if (!dimmed) { + GtkWidget *body; + body = modest_msg_edit_window_get_child_widget (MODEST_MSG_EDIT_WINDOW (win), + MODEST_MSG_EDIT_WINDOW_WIDGET_TYPE_BODY); + + dimmed = ((body == NULL)||(!gtk_widget_is_focus (body))); + if (dimmed) + modest_dimming_rule_set_notification (rule, _("mcen_ib_move_cursor_to_message")); + } + + + return dimmed; +} + +gboolean +modest_ui_dimming_rules_on_zoom (ModestWindow *win, gpointer user_data) +{ + ModestDimmingRule *rule = NULL; + const DimmedState *state = 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); + state = modest_window_get_dimming_state (win); + + if (!dimmed) { + GtkWidget *body; + body = modest_msg_edit_window_get_child_widget (MODEST_MSG_EDIT_WINDOW (win), + MODEST_MSG_EDIT_WINDOW_WIDGET_TYPE_BODY); + + dimmed = ((body == NULL)||(!gtk_widget_is_focus (body))); + if (dimmed) + modest_dimming_rule_set_notification (rule, _("mcen_ib_move_cursor_to_message")); + } + + + return dimmed; +} + +gboolean +modest_ui_dimming_rules_on_editor_paste (ModestWindow *win, gpointer user_data) +{ + ModestDimmingRule *rule = NULL; + const DimmedState *state = NULL; + 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_MSG_EDIT_WINDOW (win), TRUE); + rule = MODEST_DIMMING_RULE (user_data); + state = modest_window_get_dimming_state (win); + + focused = gtk_window_get_focus (GTK_WINDOW (win)); + + if (!dimmed) { + dimmed = MODEST_IS_ATTACHMENTS_VIEW (focused); + } + + if (!dimmed) { + dimmed = GTK_IS_TOGGLE_BUTTON (focused); + } + + if (!dimmed) { + ModestEmailClipboard *e_clipboard = modest_runtime_get_email_clipboard (); + dimmed = modest_email_clipboard_cleared (e_clipboard) && + (modest_msg_edit_window_get_clipboard_text(MODEST_MSG_EDIT_WINDOW (win)) == NULL) && + !gtk_clipboard_wait_is_text_available(gtk_clipboard_get(GDK_SELECTION_CLIPBOARD)); + } + + return dimmed; +} + +gboolean +modest_ui_dimming_rules_on_editor_remove_attachment (ModestWindow *win, gpointer user_data) +{ + ModestDimmingRule *rule = NULL; + const DimmedState *state = 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); + state = modest_window_get_dimming_state (win); + + if (!dimmed) { + GList *selected_attachments = NULL; + gint n_att_selected = 0; + GtkWidget *attachments_view; + attachments_view = modest_msg_edit_window_get_child_widget ( + MODEST_MSG_EDIT_WINDOW (win), + MODEST_MSG_EDIT_WINDOW_WIDGET_TYPE_ATTACHMENTS); + + selected_attachments = modest_attachments_view_get_selection ( + MODEST_ATTACHMENTS_VIEW (attachments_view)); + n_att_selected = g_list_length (selected_attachments); + g_list_free (selected_attachments); + + dimmed = (n_att_selected != 1); + } + + return dimmed; +} + +gboolean +modest_ui_dimming_rules_on_send (ModestWindow *win, gpointer user_data) +{ + ModestDimmingRule *rule = NULL; + const DimmedState *state = 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); + state = modest_window_get_dimming_state (win); + + if (!dimmed) { + GtkWidget *subject_field, *body_field; + GtkTextBuffer *body_buffer; + const gchar *subject = NULL; + 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); + body_buffer = gtk_text_view_get_buffer (GTK_TEXT_VIEW (body_field)); + subject = gtk_entry_get_text (GTK_ENTRY (subject_field)); + + dimmed = ((subject == NULL || subject[0] == '\0') + || (gtk_text_buffer_get_char_count(body_buffer) == 0)); + if (dimmed) + modest_dimming_rule_set_notification (rule, _("mcen_ib_subject_or_body_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); + 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)); + + 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) + modest_dimming_rule_set_notification (rule, _("mcen_ib_add_recipients_first")); + } + + return dimmed; +} + +gboolean modest_ui_dimming_rules_on_view_previous (ModestWindow *win, gpointer user_data) { ModestDimmingRule *rule = NULL; @@ -1397,7 +1658,6 @@ modest_ui_dimming_rules_on_cancel_sending (ModestWindow *win, gpointer user_data { ModestDimmingRule *rule = NULL; TnyFolderType types[1]; - guint n_messages = 0; const DimmedState *state = NULL; gboolean dimmed = FALSE; @@ -1410,16 +1670,40 @@ modest_ui_dimming_rules_on_cancel_sending (ModestWindow *win, gpointer user_data /* Check dimmed rules */ if (!dimmed) { - dimmed = state->already_opened_msg; - n_messages = state->n_selected; + dimmed = !_selected_folder_is_any_of_type (win, types, 1); if (dimmed) - modest_dimming_rule_set_notification (rule, _("mcen_ib_message_unableto_cancel_send")); + modest_dimming_rule_set_notification (rule, ""); + } + if (!dimmed) { + dimmed = !_sending_in_progress (win); + if (dimmed) + modest_dimming_rule_set_notification (rule, ""); } + + return dimmed; +} + +gboolean +modest_ui_dimming_rules_on_csm_cancel_sending (ModestWindow *win, gpointer user_data) +{ + ModestDimmingRule *rule = NULL; + TnyFolderType types[1]; + const DimmedState *state = NULL; + gboolean dimmed = FALSE; + + 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); + state = modest_window_get_dimming_state (win); + + types[0] = TNY_FOLDER_TYPE_OUTBOX; + + /* Check dimmed rules */ if (!dimmed) { dimmed = !_selected_folder_is_any_of_type (win, types, 1); if (dimmed) modest_dimming_rule_set_notification (rule, ""); - } + } if (!dimmed) { dimmed = !_sending_in_progress (win); if (dimmed) @@ -1489,7 +1773,7 @@ _selected_folder_not_writeable (ModestMainWindow *win, /* Get folder view */ folder_view = modest_main_window_get_child_widget (MODEST_MAIN_WINDOW(win), - MODEST_WIDGET_TYPE_FOLDER_VIEW); + MODEST_MAIN_WINDOW_WIDGET_TYPE_FOLDER_VIEW); /* If no folder view, always dimmed */ if (!folder_view) return TRUE; @@ -1537,7 +1821,7 @@ _selected_folder_not_deletable (ModestMainWindow *win) /* Get folder view */ folder_view = modest_main_window_get_child_widget (MODEST_MAIN_WINDOW(win), - MODEST_WIDGET_TYPE_FOLDER_VIEW); + MODEST_MAIN_WINDOW_WIDGET_TYPE_FOLDER_VIEW); /* If no folder view, always dimmed */ if (!folder_view) return TRUE; @@ -1573,7 +1857,7 @@ _selected_folder_not_moveable (ModestMainWindow *win) /* Get folder view */ folder_view = modest_main_window_get_child_widget (MODEST_MAIN_WINDOW(win), - MODEST_WIDGET_TYPE_FOLDER_VIEW); + MODEST_MAIN_WINDOW_WIDGET_TYPE_FOLDER_VIEW); /* If no folder view, always dimmed */ if (!folder_view) return TRUE; @@ -1609,7 +1893,7 @@ _selected_folder_not_renameable (ModestMainWindow *win) /* Get folder view */ folder_view = modest_main_window_get_child_widget (MODEST_MAIN_WINDOW(win), - MODEST_WIDGET_TYPE_FOLDER_VIEW); + MODEST_MAIN_WINDOW_WIDGET_TYPE_FOLDER_VIEW); /* If no folder view, always dimmed */ if (!folder_view) return TRUE; @@ -1666,7 +1950,7 @@ _selected_folder_is_root (ModestMainWindow *win) /* All accounts are root items: */ GtkWidget *folder_view = modest_main_window_get_child_widget (MODEST_MAIN_WINDOW(win), - MODEST_WIDGET_TYPE_FOLDER_VIEW); + MODEST_MAIN_WINDOW_WIDGET_TYPE_FOLDER_VIEW); if (folder_view) { gboolean is_account = FALSE; TnyFolderStore *folder_store = @@ -1703,7 +1987,7 @@ _selected_folder_is_MMC_or_POP_root (ModestMainWindow *win) gboolean result = FALSE; folder_view = modest_main_window_get_child_widget (MODEST_MAIN_WINDOW(win), - MODEST_WIDGET_TYPE_FOLDER_VIEW); + MODEST_MAIN_WINDOW_WIDGET_TYPE_FOLDER_VIEW); if (!folder_view) return FALSE; @@ -1756,7 +2040,7 @@ _selected_folder_is_empty (ModestMainWindow *win) /* Get folder view */ folder_view = modest_main_window_get_child_widget (MODEST_MAIN_WINDOW(win), - MODEST_WIDGET_TYPE_FOLDER_VIEW); + MODEST_MAIN_WINDOW_WIDGET_TYPE_FOLDER_VIEW); /* If no folder view, always dimmed */ if (!folder_view) return TRUE; @@ -1787,7 +2071,7 @@ _folder_view_has_focus (ModestWindow *win) /* Get folder view */ folder_view = modest_main_window_get_child_widget (MODEST_MAIN_WINDOW(win), - MODEST_WIDGET_TYPE_FOLDER_VIEW); + MODEST_MAIN_WINDOW_WIDGET_TYPE_FOLDER_VIEW); if (!folder_view) return FALSE; @@ -1809,7 +2093,7 @@ _selected_folder_is_same_as_source (ModestWindow *win) /* Get folder view */ folder_view = modest_main_window_get_child_widget (MODEST_MAIN_WINDOW(win), - MODEST_WIDGET_TYPE_FOLDER_VIEW); + MODEST_MAIN_WINDOW_WIDGET_TYPE_FOLDER_VIEW); if (!folder_view) return FALSE; @@ -1854,7 +2138,7 @@ _selected_folder_is_any_of_type (ModestWindow *win, /* Get folder view */ folder_view = modest_main_window_get_child_widget (MODEST_MAIN_WINDOW(win), - MODEST_WIDGET_TYPE_FOLDER_VIEW); + MODEST_MAIN_WINDOW_WIDGET_TYPE_FOLDER_VIEW); /* If no folder view, always dimmed */ if (!folder_view) return FALSE; @@ -1898,7 +2182,9 @@ _folder_is_any_of_type (TnyFolder *folder, /* Get folder type */ folder_type = modest_tny_folder_guess_folder_type (folder); - + if (folder_type == TNY_FOLDER_TYPE_INVALID) + g_warning ("%s: BUG: TNY_FOLDER_TYPE_INVALID", __FUNCTION__); + /* Check foler type */ for (i=0; i < ntypes; i++) { result = result || folder_type == types[i]; @@ -1928,22 +2214,31 @@ _invalid_clipboard_selected (ModestWindow *win, { const DimmedState *state = NULL; gboolean result = FALSE; + GtkWidget *focused = NULL; g_return_val_if_fail (MODEST_IS_WINDOW(win), FALSE); state = modest_window_get_dimming_state (win); - - if (MODEST_IS_MSG_VIEW_WINDOW (win)) { + /* Get focuesed widget */ + focused = gtk_window_get_focus (GTK_WINDOW (win)); + + if (MODEST_IS_MSG_EDIT_WINDOW (win)) { + gboolean has_selection = FALSE; + if (GTK_IS_TEXT_VIEW (focused)) { + GtkTextBuffer *buffer = NULL; + buffer = gtk_text_view_get_buffer (GTK_TEXT_VIEW (focused)); + has_selection = gtk_text_buffer_get_has_selection (GTK_TEXT_BUFFER (buffer)); + } else if (GTK_IS_EDITABLE (focused)) { + has_selection = gtk_editable_get_selection_bounds (GTK_EDITABLE (focused), NULL, NULL); + } + result = !has_selection; + } else if (MODEST_IS_MSG_VIEW_WINDOW (win)) { GtkClipboard *clipboard = NULL; gchar *selection = NULL; - GtkWidget *focused = NULL; /* Get clipboard selection*/ clipboard = gtk_clipboard_get (GDK_SELECTION_PRIMARY); selection = gtk_clipboard_wait_for_text (clipboard); - /* Get focuesed widget */ - focused = gtk_window_get_focus (GTK_WINDOW (win)); - /* Check dimming */ result = ((selection == NULL) || (MODEST_IS_ATTACHMENTS_VIEW (focused))); @@ -2080,8 +2375,10 @@ _purged_attach_selected (ModestWindow *win, gboolean all, ModestDimmingRule *rul else result = (purged > 0); + /* This string no longer exists, refer to NB#75415 for more info if (result && (rule != NULL)) modest_dimming_rule_set_notification (rule, _("mail_ib_attachment_already_purged")); + */ return result; } @@ -2101,7 +2398,7 @@ _invalid_msg_selected (ModestMainWindow *win, /* Get folder view to check focus */ folder_view = modest_main_window_get_child_widget (MODEST_MAIN_WINDOW (win), - MODEST_WIDGET_TYPE_FOLDER_VIEW); + MODEST_MAIN_WINDOW_WIDGET_TYPE_FOLDER_VIEW); /* Check dimmed rule (TODO: check focus on widgets */ if (!result) { @@ -2121,13 +2418,18 @@ _invalid_msg_selected (ModestMainWindow *win, static gboolean -_msg_download_in_progress (ModestMsgViewWindow *win) +_msg_download_in_progress (ModestWindow *win) { gboolean result = FALSE; - g_return_val_if_fail (MODEST_IS_MSG_VIEW_WINDOW (win), FALSE); + g_return_val_if_fail (MODEST_IS_WINDOW (win), FALSE); - result = modest_msg_view_window_toolbar_on_transfer_mode (win); + if (MODEST_IS_MSG_VIEW_WINDOW (win)) { + result = modest_msg_view_window_toolbar_on_transfer_mode (MODEST_MSG_VIEW_WINDOW(win)); + } + else if (MODEST_IS_MAIN_WINDOW (win)) { + result = modest_main_window_transfer_mode_enabled (MODEST_MAIN_WINDOW(win)); + } return result; } @@ -2157,13 +2459,28 @@ _selected_msg_sent_in_progress (ModestWindow *win) static gboolean _sending_in_progress (ModestWindow *win) { + GHashTable *send_queue_cache = NULL; + ModestCacheMgr *cache_mgr = NULL; + ModestTnySendQueue *send_queue = NULL; + GSList *send_queues = NULL, *node = NULL; gboolean result = FALSE; g_return_val_if_fail (MODEST_IS_MAIN_WINDOW (win), FALSE); - - /* Check if send operation is in progress */ - result = modest_main_window_send_receive_in_progress (MODEST_MAIN_WINDOW (win)); - + + /* Get send queue */ + 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 && !result; node = g_slist_next (node)) { + send_queue = MODEST_TNY_SEND_QUEUE (node->data); + + /* Check if send operation is in progress */ + result = modest_tny_send_queue_sending_in_progress (send_queue); + } + return result; } @@ -2171,7 +2488,6 @@ static gboolean _invalid_folder_for_purge (ModestWindow *win, ModestDimmingRule *rule) { - TnyMsg *msg = NULL; TnyFolder *folder = NULL; TnyAccount *account = NULL; gboolean result = FALSE; @@ -2179,17 +2495,17 @@ _invalid_folder_for_purge (ModestWindow *win, if (MODEST_IS_MSG_VIEW_WINDOW (win)) { /* Get folder and account of message */ - msg = modest_msg_view_window_get_message (MODEST_MSG_VIEW_WINDOW (win)); + TnyMsg *msg = modest_msg_view_window_get_message (MODEST_MSG_VIEW_WINDOW (win)); g_return_val_if_fail(msg != NULL, TRUE); folder = tny_msg_get_folder (msg); + g_object_unref (msg); if (folder == NULL) { modest_dimming_rule_set_notification (rule, _("mail_ib_unable_to_purge_attachments")); goto frees; } - g_object_unref (msg); } else if (MODEST_IS_MAIN_WINDOW (win)) { GtkWidget *folder_view = modest_main_window_get_child_widget (MODEST_MAIN_WINDOW (win), - MODEST_WIDGET_TYPE_FOLDER_VIEW); + MODEST_MAIN_WINDOW_WIDGET_TYPE_FOLDER_VIEW); if (!folder_view) return FALSE; folder = TNY_FOLDER (modest_folder_view_get_selected (MODEST_FOLDER_VIEW (folder_view))); @@ -2211,9 +2527,7 @@ _invalid_folder_for_purge (ModestWindow *win, result = TRUE; modest_dimming_rule_set_notification (rule, _("mail_ib_unable_to_purge_editable_msg")); } else { - /* We're currently disabling purge in any local store */ - result = TRUE; - modest_dimming_rule_set_notification (rule, _("mail_ib_unable_to_purge_attachments")); + result = FALSE; } } else { const gchar *proto_str = tny_account_get_proto (TNY_ACCOUNT (account)); @@ -2278,7 +2592,7 @@ _selected_folder_has_subfolder_with_same_name (ModestWindow *win) /*Get current parent folder */ folder_view = modest_main_window_get_child_widget (MODEST_MAIN_WINDOW(win), - MODEST_WIDGET_TYPE_FOLDER_VIEW); + MODEST_MAIN_WINDOW_WIDGET_TYPE_FOLDER_VIEW); /* If no folder view, always dimmed */ if (!folder_view) return FALSE; @@ -2292,9 +2606,9 @@ _selected_folder_has_subfolder_with_same_name (ModestWindow *win) if (folder_name == NULL) goto frees; /* Check source subfolders names */ - result = modest_tny_folder_has_subfolder_with_name (folder, folder_name); - - + result = modest_tny_folder_has_subfolder_with_name (folder, folder_name, + TRUE); + /* Free */ frees: if (folder != NULL) @@ -2304,3 +2618,33 @@ _selected_folder_has_subfolder_with_same_name (ModestWindow *win) return result; } +gboolean +modest_ui_dimming_rules_on_save_to_drafts (ModestWindow *win, + gpointer user_data) +{ + ModestDimmingRule *rule = NULL; + gboolean dimmed = FALSE; + + g_return_val_if_fail (MODEST_MSG_EDIT_WINDOW (win), FALSE); + g_return_val_if_fail (MODEST_IS_DIMMING_RULE (user_data), FALSE); + rule = MODEST_DIMMING_RULE (user_data); + + /* Check dimmed rule */ + if (!dimmed) { + dimmed = !modest_msg_edit_window_is_modified (MODEST_MSG_EDIT_WINDOW (win)); + } + + return dimmed; +} + +gboolean +modest_ui_dimming_rules_on_insert_image (ModestWindow *win, + gpointer user_data) +{ + 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); +}