Fixes NB#117330, allow numeric characters in providers picker
[modest] / src / hildon2 / modest-provider-picker.c
index fb6a1cd..bd5ed19 100644 (file)
@@ -28,6 +28,7 @@
  */
 
 #include "modest-provider-picker.h"
+#include <hildon/hildon-touch-selector-entry.h>
 #include <gtk/gtkliststore.h>
 #include <gtk/gtkcelllayout.h>
 #include <gtk/gtkcellrenderertext.h>
@@ -82,6 +83,21 @@ enum MODEL_COLS {
        MODEL_COL_ID_TYPE
 };
 
+static gint 
+id_type_index (ModestProviderPickerIdType id_type)
+{
+       switch (id_type) {
+       case MODEST_PROVIDER_PICKER_ID_OTHER:
+               return 2;
+               break;
+       case MODEST_PROVIDER_PICKER_ID_PLUGIN_PROTOCOL:
+               return 1;
+               break;
+       case MODEST_PROVIDER_PICKER_ID_PROVIDER:
+       default:
+               return 0;
+       }
+}
 
 /*
  * strictly, we should sort providers with mcc=0 after the other ones.... but, we don't have
@@ -91,10 +107,21 @@ static gint
 provider_sort_func (GtkTreeModel *model, GtkTreeIter *iter1, GtkTreeIter *iter2, gpointer user_data)
 {
        gchar *prov1, *prov2;
+       ModestProviderPickerIdType id_type1, id_type2;
        gint retval;
        
-       gtk_tree_model_get (model, iter1, MODEL_COL_NAME, &prov1, -1);
-       gtk_tree_model_get (model, iter2, MODEL_COL_NAME, &prov2, -1);
+       gtk_tree_model_get (model, iter1, 
+                           MODEL_COL_NAME, &prov1, 
+                           MODEL_COL_ID_TYPE, &id_type1,
+                           -1);
+       gtk_tree_model_get (model, iter2, 
+                           MODEL_COL_NAME, &prov2, 
+                           MODEL_COL_ID_TYPE, &id_type2,
+                           -1);
+
+       retval = id_type_index (id_type2) - id_type_index (id_type1);
+       if (retval != 0)
+               goto end;
 
        if (strcmp (prov1, prov2) == 0) 
                retval = 0;
@@ -104,7 +131,7 @@ provider_sort_func (GtkTreeModel *model, GtkTreeIter *iter1, GtkTreeIter *iter2,
                retval = 1;
        else
                retval = modest_text_utils_utf8_strcmp (prov1, prov2, TRUE);
-       
+end:
        g_free (prov1);
        g_free (prov2);
 
@@ -144,6 +171,7 @@ modest_provider_picker_new (HildonSizeType size,
        ModestProviderPicker *self;
        GtkCellRenderer *renderer;
        GtkWidget *selector;
+       HildonTouchSelectorColumn *column;
 
        self = g_object_new (MODEST_TYPE_PROVIDER_PICKER, 
                             "arrangement", arrangement,
@@ -166,12 +194,22 @@ 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_new ();
-       hildon_touch_selector_append_column (HILDON_TOUCH_SELECTOR (selector), GTK_TREE_MODEL (priv->model),
-                                            renderer, "text", MODEL_COL_NAME, NULL);
+       selector = hildon_touch_selector_entry_new ();
+       hildon_touch_selector_set_print_func (HILDON_TOUCH_SELECTOR (selector), 
+                                             (HildonTouchSelectorPrintFunc) touch_selector_print_func);
+       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_set_print_func (HILDON_TOUCH_SELECTOR (selector), (HildonTouchSelectorPrintFunc) touch_selector_print_func);
+       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_NUMERIC |
+                                                   HILDON_GTK_INPUT_MODE_AUTOCAP);
+
 
        hildon_picker_button_set_selector (HILDON_PICKER_BUTTON (self), HILDON_TOUCH_SELECTOR (selector));
        modest_provider_picker_set_others_provider (MODEST_PROVIDER_PICKER (self));