X-Git-Url: http://git.maemo.org/git/?a=blobdiff_plain;f=src%2Fmodest-ui-dimming-rules.c;h=4cb01674d0d56c1bb8a81252fc1b0951065104d7;hb=480298cb7c35991ef6cd6c0ec4edae81568a7061;hp=e044d9d1bd9b6d662ebaf6993041bd778e5e7c80;hpb=40e92875620a12ce1d34126c9a9c6bce97b21e6c;p=modest diff --git a/src/modest-ui-dimming-rules.c b/src/modest-ui-dimming-rules.c index e044d9d..4cb0167 100644 --- a/src/modest-ui-dimming-rules.c +++ b/src/modest-ui-dimming-rules.c @@ -47,6 +47,8 @@ static gboolean _selected_folder_is_any_of_type (ModestMainWindow *win, TnyFolde static gboolean _selected_folder_is_root (ModestMainWindow *win); static gboolean _selected_folder_is_empty (ModestMainWindow *win); static gboolean _msg_download_in_progress (ModestMsgViewWindow *win); +static gboolean _msg_sent_in_progress (ModestWindow *win); +static gboolean _marked_as_deleted (ModestWindow *win); gboolean @@ -151,6 +153,10 @@ modest_ui_dimming_rules_on_open_msg (ModestWindow *win, gpointer user_data) /* Check dimmed rule */ if (!dimmed) dimmed = _invalid_msg_selected (MODEST_MAIN_WINDOW(win), TRUE, user_data); + if (!dimmed) { + dimmed = _msg_sent_in_progress (win); + modest_dimming_rule_set_notification (rule, _("TEST")); + } return dimmed; } @@ -246,6 +252,14 @@ modest_ui_dimming_rules_on_delete_msg (ModestWindow *win, gpointer user_data) dimmed = _already_opened_msg (win); modest_dimming_rule_set_notification (rule, _("mcen_nc_unable_to_delete_n_messages")); } + if (!dimmed) { + dimmed = _marked_as_deleted (win); + modest_dimming_rule_set_notification (rule, _("mcen_ib_message_unableto_delete")); + } + if (!dimmed) { + dimmed = _msg_sent_in_progress (win); + modest_dimming_rule_set_notification (rule, _("mcen_ib_message_unableto_delete")); + } return dimmed; } @@ -284,6 +298,7 @@ modest_ui_dimming_rules_on_details (ModestWindow *win, gpointer user_data) return dimmed; } + gboolean modest_ui_dimming_rules_on_mark_as_read_msg (ModestWindow *win, gpointer user_data) { @@ -418,9 +433,37 @@ modest_ui_dimming_rules_on_delete_msgs (ModestWindow *win, gpointer user_data) return dimmed; } +gboolean +modest_ui_dimming_rules_on_select_all (ModestWindow *win, gpointer user_data) +{ + gboolean dimmed = FALSE; + + /* Check dimmed rule */ + if (!dimmed) + dimmed = _selected_folder_is_empty (MODEST_MAIN_WINDOW(win)); + + return dimmed; +} + /* *********************** static utility functions ******************** */ +static gboolean +_marked_as_deleted (ModestWindow *win) +{ + gboolean result = FALSE; + TnyHeaderFlags flags; + + g_return_val_if_fail (MODEST_IS_MAIN_WINDOW(win), FALSE); + + flags = TNY_HEADER_FLAG_DELETED; + + /* Check dimmed rule */ + result = _selected_msg_marked_as (win, flags, FALSE); + + return result; +} + static gboolean _selected_folder_not_writeable (ModestMainWindow *win) { @@ -467,6 +510,36 @@ _selected_folder_is_root (ModestMainWindow *win) /* Check folder type */ result = _selected_folder_is_any_of_type (win, types, 2); + if (!result) { + GtkWidget *folder_view = NULL; + TnyFolderStore *parent_folder = NULL; + + folder_view = modest_main_window_get_child_widget (MODEST_MAIN_WINDOW(win), + MODEST_WIDGET_TYPE_FOLDER_VIEW); + /* Get selected folder as parent of new folder to create */ + parent_folder = modest_folder_view_get_selected (MODEST_FOLDER_VIEW(folder_view)); + if (!parent_folder) + return TRUE; + + if (TNY_IS_ACCOUNT (parent_folder)) { + /* If it's the local account then do not dim */ + if (modest_tny_account_is_virtual_local_folders ( + TNY_ACCOUNT (parent_folder))) + return FALSE; + else { + /* If it's the MMC root folder then dim it */ + if (!strcmp (tny_account_get_id (TNY_ACCOUNT (parent_folder)), MODEST_MMC_ACCOUNT_ID)) { + result = TRUE; + } else { + const gchar *proto_str = tny_account_get_proto (TNY_ACCOUNT (parent_folder)); + /* If it's POP then dim */ + result = (modest_protocol_info_get_transport_store_protocol (proto_str) == + MODEST_PROTOCOL_STORE_POP) ? TRUE : FALSE; + } + } + } + } + return result; } @@ -590,7 +663,7 @@ _invalid_msg_selected (ModestMainWindow *win, (GTK_WIDGET_HAS_FOCUS (folder_view))); modest_dimming_rule_set_notification (rule, _("mcen_ib_no_message_selected")); } - if (!result) { + if (!result && unique) { result = tny_list_get_length (selected_headers) > 1; modest_dimming_rule_set_notification (rule, _("mcen_ib_select_one_message")); } @@ -699,3 +772,67 @@ _msg_download_in_progress (ModestMsgViewWindow *win) return result; } + +static gboolean +_msg_sent_in_progress (ModestWindow *win) +{ +/* ModestTnySendQueue *send_queue = NULL; */ +/* GtkWidget *header_view = NULL; */ +/* ModestTnyAccountStore *acc_store = NULL; */ +/* TnyAccount *account = NULL; */ +/* TnyList *header_list = NULL; */ +/* TnyIterator *iter = NULL; */ +/* TnyHeader *header = NULL; */ +/* const gchar *account_name = NULL; */ + gboolean result = FALSE; +/* gchar *id = NULL; */ + +/* g_return_val_if_fail (MODEST_IS_MSG_VIEW_WINDOW (win), FALSE); */ + +/* /\* Get transport account *\/ */ +/* acc_store = modest_runtime_get_account_store(); */ +/* account_name = modest_window_get_active_account (win); */ +/* account = modest_tny_account_store_get_transport_account_for_open_connection (acc_store, account_name); */ + +/* /\* Get send queue for current ransport account *\/ */ +/* send_queue = modest_runtime_get_send_queue (TNY_TRANSPORT_ACCOUNT(account)); */ +/* g_return_val_if_fail (MODEST_IS_TNY_SEND_QUEUE (send_queue), FALSE); */ + +/* if (MODEST_IS_MAIN_WINDOW(win)) { */ + +/* /\* Get header view to check selected messages *\/ */ +/* header_view = modest_main_window_get_child_widget (MODEST_MAIN_WINDOW(win), */ +/* MODEST_WIDGET_TYPE_HEADER_VIEW); */ + +/* /\* Get selected headers *\/ */ +/* header_list = modest_header_view_get_selected_headers (MODEST_HEADER_VIEW(header_view)); */ + +/* /\* Get message header *\/ */ +/* if (!header_list) return FALSE; */ +/* iter = tny_list_create_iterator (header_list); */ +/* header = TNY_HEADER (tny_iterator_get_current (iter)); */ + +/* /\* Get message id *\/ */ +/* id = g_strdup(tny_header_get_message_id (header)); */ + +/* } else if (MODEST_IS_MSG_VIEW_WINDOW(win)) { */ + +/* /\* Get message header *\/ */ +/* header = modest_msg_view_window_get_header (MODEST_MSG_VIEW_WINDOW(win)); */ + +/* /\* Get message id *\/ */ +/* id = g_strdup(tny_header_get_message_id (header)); */ +/* } */ + +/* /\* Check if msg id is being processed inside send queue *\/ */ +/* result = modest_tny_send_queue_msg_is_being_sent (send_queue, id); */ + +/* /\* Free *\/ */ +/* g_free(id); */ +/* g_object_unref (header); */ +/* g_free(header_list); */ +/* g_free(iter); */ + + return result; +} +