+ /* check if all the headers are selected or not */
+ model = gtk_tree_view_get_model(GTK_TREE_VIEW(header_view));
+ if (model != NULL){
+ gint count;
+ count = gtk_tree_model_iter_n_children(model, NULL);
+ if(state->n_selected == count != 0)
+ state->all_selected = TRUE;
+ }
+
+ /* Free */
+ g_free(msg_uid);
+ g_object_unref(selected_headers);
+ g_object_unref(iter);
+ g_slist_free (send_queues);
+
+ return state;
+}
+
+static DimmedState *
+_define_msg_view_window_dimming_state (ModestMsgViewWindow *window)
+{
+ DimmedState *state = NULL;
+ TnyHeader *header = NULL;
+ ModestCacheMgr *cache_mgr = NULL;
+ GHashTable *send_queue_cache = NULL;
+ ModestTnySendQueue *send_queue = NULL;
+ GSList *send_queues = NULL, *node = NULL;
+ gboolean found = FALSE;
+ gchar *msg_uid = NULL;
+ TnyHeaderFlags flags;
+ gboolean all_deleted = TRUE;
+ gboolean all_seen = TRUE;
+ gboolean all_cached = TRUE;
+ gboolean all_has_attach = TRUE;
+
+ g_return_val_if_fail (MODEST_IS_MSG_VIEW_WINDOW(window), NULL);
+
+ /* Init state */
+ state = g_slice_new0 (DimmedState);
+ state->n_selected = 0;
+ state->already_opened_msg = FALSE;
+ state->any_marked_as_deleted = FALSE;
+ state->all_marked_as_deleted = FALSE;
+ state->any_marked_as_seen = FALSE;
+ state->all_marked_as_seen = FALSE;
+ state->any_marked_as_cached = FALSE;
+ state->all_marked_as_cached = FALSE;
+ state->any_has_attachments = FALSE;
+ state->all_has_attachments = FALSE;
+ state->sent_in_progress = FALSE;
+
+ header = modest_msg_view_window_get_header (MODEST_MSG_VIEW_WINDOW(window));
+ g_return_val_if_fail (TNY_IS_HEADER(header), state);
+ flags = tny_header_get_flags (header);
+
+ /* Selected */
+ state->n_selected++;
+
+ /* Mark as deleted */
+ all_deleted = all_deleted && (flags & TNY_HEADER_FLAG_DELETED);
+ state->all_marked_as_deleted = all_deleted;
+ if (!state->any_marked_as_deleted)
+ state->any_marked_as_deleted = flags & TNY_HEADER_FLAG_DELETED;
+
+ /* Mark as seen */
+ all_seen = all_seen && (flags & TNY_HEADER_FLAG_SEEN);
+ state->all_marked_as_seen = all_seen;
+ if (!state->any_marked_as_seen)
+ state->any_marked_as_seen = flags & TNY_HEADER_FLAG_SEEN;
+
+ /* Mark as cached */
+ all_cached = all_cached && (flags & TNY_HEADER_FLAG_CACHED);
+ state->all_marked_as_cached = all_cached;
+ if (!state->any_marked_as_cached)
+ state->any_marked_as_cached = flags & TNY_HEADER_FLAG_CACHED;
+
+ /* Mark has_attachments */
+ 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;
+
+ /* sent in progress */
+ msg_uid = modest_tny_send_queue_get_msg_id (header);
+ if (!state->sent_in_progress) {
+ 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 */
+ found = modest_tny_send_queue_msg_is_being_sent (send_queue, msg_uid);
+ }
+ state->sent_in_progress = found;
+ }
+
+ /* Free */
+ g_free(msg_uid);
+ g_object_unref (header);
+ g_slist_free (send_queues);
+
+ return state;
+}
+
+
+DimmedState *
+modest_ui_dimming_rules_define_dimming_state (ModestWindow *window)
+{
+ DimmedState *state = NULL;
+
+ g_return_val_if_fail (MODEST_IS_WINDOW(window), NULL);
+
+ if (MODEST_IS_MAIN_WINDOW (window))
+ state = _define_main_window_dimming_state (MODEST_MAIN_WINDOW(window));
+ else if (MODEST_IS_MSG_VIEW_WINDOW (window)) {
+ state = _define_msg_view_window_dimming_state (MODEST_MSG_VIEW_WINDOW(window));
+ }
+
+ return state;