Convert provider picker to use live search
[modest] / src / hildon2 / modest-provider-picker.c
index 918d40e..539089f 100644 (file)
@@ -28,7 +28,7 @@
  */
 
 #include "modest-provider-picker.h"
-#include <hildon/hildon-touch-selector-entry.h>
+#include <hildon/hildon.h>
 #include <gtk/gtkliststore.h>
 #include <gtk/gtkcelllayout.h>
 #include <gtk/gtkcellrenderertext.h>
@@ -56,12 +56,15 @@ typedef struct _ModestProviderPickerPrivate ModestProviderPickerPrivate;
 struct _ModestProviderPickerPrivate
 {
        GtkTreeModel *model;
+       GHashTable *enabled_plugin_ids;
 };
 static void
 modest_provider_picker_finalize (GObject *object)
 {
        ModestProviderPickerPrivate *priv = MODEST_PROVIDER_PICKER_GET_PRIVATE (object);
 
+       g_hash_table_destroy (priv->enabled_plugin_ids);
+
        g_object_unref (G_OBJECT (priv->model));
 
        G_OBJECT_CLASS (modest_provider_picker_parent_class)->finalize (object);
@@ -161,6 +164,8 @@ modest_provider_picker_init (ModestProviderPicker *self)
 
        priv = MODEST_PROVIDER_PICKER_GET_PRIVATE (self);
        priv->model = NULL;
+       priv->enabled_plugin_ids = g_hash_table_new_full (g_str_hash, g_str_equal,
+                                                         g_free, NULL);
 }
 
 ModestProviderPicker*
@@ -194,25 +199,21 @@ modest_provider_picker_new (HildonSizeType size,
        renderer = gtk_cell_renderer_text_new ();
        g_object_set (G_OBJECT (renderer), "ellipsize", PANGO_ELLIPSIZE_END, NULL);
 
-       selector = hildon_touch_selector_entry_new ();
+       selector = hildon_touch_selector_new ();
        hildon_touch_selector_set_print_func (HILDON_TOUCH_SELECTOR (selector), 
                                              (HildonTouchSelectorPrintFunc) touch_selector_print_func);
+       hildon_touch_selector_set_model (HILDON_TOUCH_SELECTOR (selector), 0, GTK_TREE_MODEL (priv->model));
        column = hildon_touch_selector_append_column (HILDON_TOUCH_SELECTOR (selector), GTK_TREE_MODEL (priv->model),
                                                      renderer, "text", MODEL_COL_NAME, NULL);
-       hildon_touch_selector_entry_set_text_column (HILDON_TOUCH_SELECTOR_ENTRY (selector),
-                                                    MODEL_COL_NAME);
-
-       /* Set this _after_ loading from file, it makes loading faster */
-       hildon_touch_selector_set_model (HILDON_TOUCH_SELECTOR (selector), 0, GTK_TREE_MODEL (priv->model));
-       hildon_touch_selector_entry_set_input_mode (HILDON_TOUCH_SELECTOR_ENTRY (selector),
-                                                   HILDON_GTK_INPUT_MODE_ALPHA |
-                                                   HILDON_GTK_INPUT_MODE_SPECIAL |
-                                                   HILDON_GTK_INPUT_MODE_AUTOCAP);
+       hildon_touch_selector_column_set_text_column (column, MODEL_COL_NAME);
 
 
        hildon_picker_button_set_selector (HILDON_PICKER_BUTTON (self), HILDON_TOUCH_SELECTOR (selector));
        modest_provider_picker_set_others_provider (MODEST_PROVIDER_PICKER (self));
 
+       /* For theming purpouses. Widget name must end in Button-finger */
+       gtk_widget_set_name ((GtkWidget *) self, "ModestProviderPickerButton-finger");
+
        return self;
 }
 
@@ -242,6 +243,8 @@ modest_provider_picker_fill (ModestProviderPicker *self,
        iter_provider_names = provider_names;
        iter_provider_ids = provider_ids;
 
+       g_hash_table_remove_all (priv->enabled_plugin_ids);
+
        while(iter_provider_names && *iter_provider_names && iter_provider_ids && *iter_provider_ids) {
                const gchar* provider_name = *iter_provider_names;
                const gchar* provider_id = *iter_provider_ids;
@@ -311,6 +314,7 @@ modest_provider_picker_fill (ModestProviderPicker *self,
                                    MODEL_COL_NAME, name,
                                    MODEL_COL_ID_TYPE, MODEST_PROVIDER_PICKER_ID_PLUGIN_PROTOCOL,
                                    -1);
+               g_hash_table_insert (priv->enabled_plugin_ids, g_strdup (modest_protocol_get_name (proto)), NULL);
        }
        g_slist_free (provider_protos);
        
@@ -334,6 +338,87 @@ modest_provider_picker_fill (ModestProviderPicker *self,
        
 }
 
+void
+modest_provider_picker_refresh (ModestProviderPicker *self)
+{      
+       ModestProviderPickerPrivate *priv;
+       GtkListStore *liststore;        
+       GSList *provider_protos, *tmp;
+       ModestProtocolRegistry *registry;
+
+       g_return_if_fail (MODEST_IS_PROVIDER_PICKER(self));
+
+       priv = MODEST_PROVIDER_PICKER_GET_PRIVATE (self);
+       liststore = GTK_LIST_STORE (priv->model);
+       /* Add the provider protocols */
+       registry = modest_runtime_get_protocol_registry ();
+       provider_protos = modest_protocol_registry_get_by_tag (registry, 
+                                                              MODEST_PROTOCOL_REGISTRY_PROVIDER_PROTOCOLS);
+       for (tmp = provider_protos; tmp != NULL; tmp = g_slist_next (tmp)) {
+
+               GtkTreeIter iter;
+               ModestProtocol *proto = MODEST_PROTOCOL (tmp->data);
+               const gchar *name = modest_protocol_get_display_name (proto);
+               gboolean provider_exists;
+
+               /* only add store protocols, no need to duplicate them */
+               if (!modest_protocol_registry_protocol_type_has_tag (registry, 
+                                                                    modest_protocol_get_type_id (proto),
+                                                                    MODEST_PROTOCOL_REGISTRY_STORE_PROTOCOLS))
+                       continue;
+                 
+               if (modest_protocol_registry_protocol_type_has_tag 
+                   (registry,
+                    modest_protocol_get_type_id (proto),
+                    MODEST_PROTOCOL_REGISTRY_SINGLETON_PROVIDER_PROTOCOLS)) {
+                       /* Check if there's already an account configured with this account type */
+                       if (modest_account_mgr_singleton_protocol_exists (modest_runtime_get_account_mgr (),
+                                                                         modest_protocol_get_type_id (proto)))
+                               continue;
+               }
+
+               provider_exists = g_hash_table_lookup_extended (priv->enabled_plugin_ids, modest_protocol_get_name (proto),
+                                                               NULL, NULL);
+
+               if (MODEST_ACCOUNT_PROTOCOL (proto) && 
+                   !modest_account_protocol_is_supported (MODEST_ACCOUNT_PROTOCOL (proto))) {
+
+                       if (provider_exists) {
+                               GtkTreeIter iter;
+
+                               if (!gtk_tree_model_get_iter_first (priv->model, &iter))
+                                       continue;
+
+                               do {
+                                       gchar *id = NULL;
+                                       gtk_tree_model_get (priv->model, &iter,
+                                                           MODEL_COL_ID, &id,
+                                                           -1);
+
+                                       if (g_strcmp0 (id, modest_protocol_get_name (proto)) == 0) {
+                                               gtk_list_store_remove (GTK_LIST_STORE (priv->model), &iter);
+                                               break;
+                                       }
+
+                               } while (gtk_tree_model_iter_next (priv->model, &iter));
+                       }
+
+                       continue;
+               }
+
+               if (!provider_exists) {
+                       gtk_list_store_append (liststore, &iter);
+                       gtk_list_store_set (liststore, &iter,
+                                           MODEL_COL_ID, modest_protocol_get_name (proto),
+                                           MODEL_COL_NAME, name,
+                                           MODEL_COL_ID_TYPE, MODEST_PROVIDER_PICKER_ID_PLUGIN_PROTOCOL,
+                                           -1);
+               }
+       }
+       g_slist_free (provider_protos);
+       
+}
+
 /**
  * Returns the MCC number of the selected provider, 
  * or NULL if no provider was selected, or "Other" was selected.