Fixes NB#118450, Ctrl-F must launch the find toolbar in message view window
[modest] / src / hildon2 / modest-number-editor.c
index d24c77e..254e3e7 100644 (file)
@@ -1,8 +1,31 @@
 /*
- * This file is a part of modest
+ * Copyright (C) 2008 Nokia Corporation, all rights reserved.
+ * All rights reserved.
  *
- * Copyright (C) 2005, 2006, 2008 Nokia Corporation, all rights reserved.
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions are
+ * met:
  *
+ * * Redistributions of source code must retain the above copyright
+ *   notice, this list of conditions and the following disclaimer.
+ * * Redistributions in binary form must reproduce the above copyright
+ *   notice, this list of conditions and the following disclaimer in the
+ *   documentation and/or other materials provided with the distribution.
+ * * Neither the name of the Nokia Corporation nor the names of its
+ *   contributors may be used to endorse or promote products derived from
+ *   this software without specific prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS
+ * IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
+ * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A
+ * PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER
+ * OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
+ * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
+ * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
+ * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
+ * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
+ * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
+ * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  */
 
 /**
@@ -221,21 +244,6 @@ modest_number_editor_init                       (ModestNumberEditor *editor)
     g_assert (priv);
 
     priv->select_all_idle_id = 0;
-
-    /* Connect child widget signals */
-    g_signal_connect (GTK_OBJECT (editor), "changed",
-            G_CALLBACK (modest_number_editor_entry_changed),
-            editor);
-
-    g_signal_connect (GTK_OBJECT (editor), "focus-out-event",
-            G_CALLBACK (modest_number_editor_entry_focusout),
-            editor);
-
-    hildon_gtk_entry_set_input_mode (GTK_ENTRY (editor), 
-                                    HILDON_GTK_INPUT_MODE_NUMERIC);
-
-    modest_number_editor_set_range (editor, G_MININT, G_MAXINT);
-
     priv->is_valid = TRUE;
 }
 
@@ -353,6 +361,7 @@ modest_number_editor_validate_value             (ModestNumberEditor *editor,
                modest_number_editor_set_value (editor, fixup_value);
                g_signal_emit (editor, ModestNumberEditor_signal[RANGE_ERROR], 0, error_code, &r);
                add_select_all_idle (editor);
+               is_valid = modest_number_editor_is_valid (editor);
        }
 
        if (priv->is_valid != is_valid) {
@@ -375,10 +384,15 @@ modest_number_editor_entry_focusout             (GtkWidget *widget,
                                                  GdkEventFocus *event,
                                                  gpointer data)
 {
-    g_assert (MODEST_IS_NUMBER_EDITOR(data));
+       GtkWidget *window;
+       
+       g_assert (MODEST_IS_NUMBER_EDITOR(data));
 
-    modest_number_editor_validate_value (MODEST_NUMBER_EDITOR(data), FALSE);
-    return FALSE;
+       window = gtk_widget_get_toplevel (widget);
+       if (window && gtk_window_has_toplevel_focus (GTK_WINDOW (window)))
+               modest_number_editor_validate_value (MODEST_NUMBER_EDITOR(data), FALSE);
+
+       return FALSE;
 }
 
 static gboolean
@@ -439,9 +453,23 @@ modest_number_editor_new                        (gint min,
 {
     ModestNumberEditor *editor = g_object_new (MODEST_TYPE_NUMBER_EDITOR, NULL);
 
+    /* Connect child widget signals */
+    g_signal_connect (GTK_OBJECT (editor), "changed",
+            G_CALLBACK (modest_number_editor_entry_changed),
+            editor);
+
+    g_signal_connect (GTK_OBJECT (editor), "focus-out-event",
+            G_CALLBACK (modest_number_editor_entry_focusout),
+            editor);
+
+    /* Numeric input mode */
+    hildon_gtk_entry_set_input_mode (GTK_ENTRY (editor), 
+                                    HILDON_GTK_INPUT_MODE_NUMERIC);
+
     /* Set user inputted range to editor */
     modest_number_editor_set_range (editor, min, max);
 
+
     return GTK_WIDGET (editor);
 }