* Removed an invalid g_object_unref in a mail operation
[modest] / src / modest-ui-dimming-rules.c
index b7ddb0d..d9819b7 100644 (file)
@@ -31,6 +31,7 @@
 #include <config.h>
 #endif /*HAVE_CONFIG_H*/
 
+#include <string.h>
 #include "modest-ui-dimming-rules.h"
 #include "modest-tny-folder.h"
 #include <modest-runtime.h>
@@ -43,17 +44,59 @@ static gboolean _selected_msg_marked_as (ModestWindow *win, TnyHeaderFlags mask,
 static gboolean _selected_folder_not_writeable (ModestMainWindow *win);
 static gboolean _selected_folder_is_any_of_type (ModestMainWindow *win, TnyFolderType types[], guint ntypes);
 static gboolean _selected_folder_is_root (ModestMainWindow *win);
+static gboolean _msg_download_in_progress (ModestMsgViewWindow *win);
+
 
 gboolean 
-modest_ui_dimming_rules_on_new_folder (ModestWindow *win, gpointer user_data)
+modest_ui_dimming_rules_on_new_msg (ModestWindow *win, gpointer user_data)
 {
        gboolean dimmed = FALSE;
 
-       g_return_val_if_fail (MODEST_IS_MAIN_WINDOW(win), FALSE);
+       g_return_val_if_fail (MODEST_IS_MSG_VIEW_WINDOW(win), FALSE);
                
        /* Check dimmed rule */ 
        if (!dimmed)
+               dimmed = _msg_download_in_progress (MODEST_MSG_VIEW_WINDOW(win));
+
+       return dimmed;
+}
+
+gboolean 
+modest_ui_dimming_rules_on_new_folder (ModestWindow *win, gpointer user_data)
+{
+       gboolean dimmed = FALSE;
+       GtkWidget *folder_view = NULL;
+       TnyFolderStore *parent_folder = NULL;
+
+       g_return_val_if_fail (MODEST_IS_MAIN_WINDOW(win), FALSE);
+
+
+       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 it's the local account do not dimm */
+       if (modest_tny_folder_store_is_virtual_local_folders (parent_folder)) {
+               return FALSE;
+       } else if (TNY_IS_ACCOUNT (parent_folder)) {
+               /* If it's the MMC root folder then dimm it */
+               if (!strcmp (tny_account_get_id (TNY_ACCOUNT (parent_folder)), MODEST_MMC_ACCOUNT_ID)) {
+                       dimmed = TRUE;
+               } else {
+                       const gchar *proto_str = tny_account_get_proto (TNY_ACCOUNT (parent_folder));
+                       /* If it's POP then dimm */
+                       dimmed = (modest_protocol_info_get_transport_store_protocol (proto_str) == 
+                                 MODEST_PROTOCOL_STORE_POP) ? TRUE : FALSE;
+               }
+       } else {
+               /* TODO: the specs say that only one level of subfolder is allowed, is this true ? */
+
+               /* Apply folder rules */        
                dimmed = _selected_folder_not_writeable (MODEST_MAIN_WINDOW(win));
+       }
 
        return dimmed;
 }
@@ -94,19 +137,28 @@ modest_ui_dimming_rules_on_reply_msg (ModestWindow *win, gpointer user_data)
        gboolean dimmed = FALSE;
        TnyFolderType types[3];
 
-       g_return_val_if_fail (MODEST_IS_MAIN_WINDOW(win), FALSE);
-
-       types[0] = TNY_FOLDER_TYPE_DRAFTS; 
-       types[1] = TNY_FOLDER_TYPE_OUTBOX;
-       types[2] = TNY_FOLDER_TYPE_ROOT;
+       /* main window dimming rules */
+       if (MODEST_IS_MAIN_WINDOW(win)) {
+               
+               types[0] = TNY_FOLDER_TYPE_DRAFTS; 
+               types[1] = TNY_FOLDER_TYPE_OUTBOX;
+               types[2] = TNY_FOLDER_TYPE_ROOT;
+               
+               /* Check dimmed rule */ 
+               if (!dimmed)
+                       dimmed = _selected_folder_is_any_of_type (MODEST_MAIN_WINDOW(win), types, 3);
+               
+               if (!dimmed)
+                       dimmed = _invalid_msg_selected (MODEST_MAIN_WINDOW(win), FALSE);
 
-       /* Check dimmed rule */ 
-       if (!dimmed)
-               dimmed = _selected_folder_is_any_of_type (MODEST_MAIN_WINDOW(win), types, 3);
+       /* msg view window dimming rules */
+       } else if (MODEST_IS_MSG_VIEW_WINDOW(win)) {
+               
+               /* Check dimmed rule */ 
+               if (!dimmed)
+                       dimmed = _msg_download_in_progress (MODEST_MSG_VIEW_WINDOW(win));
+       }
        
-       if (!dimmed)
-               dimmed = _invalid_msg_selected (MODEST_MAIN_WINDOW(win), FALSE);
-
        return dimmed;
 }
 
@@ -159,12 +211,21 @@ modest_ui_dimming_rules_on_details_msg (ModestWindow *win, gpointer user_data)
 {
        gboolean dimmed = FALSE;
        
-       g_return_val_if_fail (MODEST_IS_MAIN_WINDOW(win), FALSE);
-       
-       /* Check dimmed rule */ 
-       if (!dimmed)
-               dimmed = _invalid_msg_selected (MODEST_MAIN_WINDOW(win), TRUE);
-       
+       /* main window dimming rules */
+       if (MODEST_IS_MAIN_WINDOW(win)) {
+               
+               /* Check dimmed rule */ 
+               if (!dimmed)
+                       dimmed = _invalid_msg_selected (MODEST_MAIN_WINDOW(win), TRUE);
+
+       /* msg view window dimming rules */
+       } else {
+
+               /* Check dimmed rule */ 
+               if (!dimmed)
+                       dimmed = _msg_download_in_progress (MODEST_MSG_VIEW_WINDOW(win));
+       }
+
        return dimmed;
 }
 
@@ -535,3 +596,13 @@ _selected_msg_marked_as (ModestWindow *win,
 
        return result;
 }
+
+static gboolean
+_msg_download_in_progress (ModestMsgViewWindow *win)
+{
+       gboolean result = FALSE;
+
+       g_return_val_if_fail (MODEST_IS_MSG_VIEW_WINDOW (win), FALSE);
+
+       return result;
+}