Modified webpage: now tinymail repository is in gitorious.
[modest] / src / widgets / modest-header-window.c
index 5c121aa..c8ffcc3 100644 (file)
  */
 
 #include <modest-header-window.h>
+#ifdef MODEST_TOOLKIT_HILDON2
 #include <hildon/hildon.h>
+#include <modest-maemo-utils.h>
+#endif
 #include <modest-scrollable.h>
 #include <modest-window-mgr.h>
 #include <modest-window-priv.h>
 #include <modest-signal-mgr.h>
 #include <modest-runtime.h>
 #include <modest-platform.h>
-#include <modest-maemo-utils.h>
 #include <modest-icon-names.h>
 #include <modest-ui-constants.h>
 #include <modest-account-mgr.h>
@@ -48,6 +50,8 @@
 #include <modest-ui-dimming-rules.h>
 #include <modest-tny-folder.h>
 #include <tny-simple-list.h>
+#include <gdk/gdkkeysyms.h>
+#include <modest-isearch-toolbar.h>
 
 typedef enum {
        CONTENTS_STATE_NONE = 0,
@@ -55,10 +59,12 @@ typedef enum {
        CONTENTS_STATE_HEADERS = 2
 } ContentsState;
 
+#ifdef MODEST_TOOLKIT_HILDON2
 typedef enum {
        EDIT_MODE_COMMAND_MOVE = 1,
        EDIT_MODE_COMMAND_DELETE = 2,
 } EditModeCommand;
+#endif
 
 typedef struct _ModestHeaderWindowPrivate ModestHeaderWindowPrivate;
 struct _ModestHeaderWindowPrivate {
@@ -96,6 +102,8 @@ struct _ModestHeaderWindowPrivate {
 
        /* weak refs */
        GtkTreeModel *model_weak_ref;
+
+       GtkWidget   *isearch_toolbar;
 };
 #define MODEST_HEADER_WINDOW_GET_PRIVATE(o)  (G_TYPE_INSTANCE_GET_PRIVATE((o), \
                                                                          MODEST_TYPE_HEADER_WINDOW, \
@@ -131,10 +139,12 @@ static void on_header_activated (ModestHeaderView *header_view,
 static void on_updating_msg_list (ModestHeaderView *header_view,
                                  gboolean starting,
                                  gpointer user_data);
+#ifdef MODEST_TOOLKIT_HILDON2
 static void set_delete_edit_mode (GtkButton *button,
                                  ModestHeaderWindow *self);
 static void set_moveto_edit_mode (GtkButton *button,
                                  ModestHeaderWindow *self);
+#endif
 static gboolean on_expose_event(GtkTreeView *header_view,
                                GdkEventExpose *event,
                                gpointer user_data);
@@ -155,24 +165,39 @@ static void on_queue_changed    (ModestMailOperationQueue *queue,
                                 ModestMailOperation *mail_op,
                                 ModestMailOperationQueueNotification type,
                                 ModestHeaderWindow *self);
-static void modest_header_window_pack_toolbar (ModestHildon2Window *self,
+static void modest_header_window_pack_toolbar (ModestWindow *self,
                                               GtkPackType pack_type,
                                               GtkWidget *toolbar);
+#ifdef MODEST_TOOLKIT_HILDON2
 static void edit_mode_changed (ModestHeaderWindow *header_window,
                               gint edit_mode_id,
                               gboolean enabled,
                               ModestHeaderWindow *self);
+#endif
 static void on_progress_list_changed (ModestWindowMgr *mgr,
                                      ModestHeaderWindow *self);
 static void update_progress_hint (ModestHeaderWindow *self);
 static void on_header_view_model_destroyed (gpointer user_data,
                                            GObject *model);
+#ifdef MODEST_TOOLKIT_HILDON2
 static gboolean on_key_press(GtkWidget *widget,
                                        GdkEventKey *event,
                                        gpointer user_data);
+#endif
+
+static void  isearch_toolbar_close  (GtkWidget *widget,
+                                    ModestHeaderWindow *obj);
+static void  isearch_toolbar_search (GtkWidget *widget,
+                                    ModestHeaderWindow *obj);
+#ifndef MODEST_TOOLKIT_HILDON2
+static void  show_isearch_toolbar   (GtkWidget *obj, gpointer data);
+static void  toggle_isearch_toolbar (GtkWidget *obj,
+                                    gpointer data);
+#endif
+
 
 /* globals */
-static GtkWindowClass *parent_class = NULL;
+static ModestWindowParentClass *parent_class = NULL;
 
 #define EMPTYVIEW_XALIGN 0.5
 #define EMPTYVIEW_YALIGN 0.5
@@ -200,7 +225,12 @@ modest_header_window_get_type (void)
                        (GInstanceInitFunc) modest_header_window_init,
                        NULL
                };
-               my_type = g_type_register_static (MODEST_TYPE_HILDON2_WINDOW,
+               my_type = g_type_register_static (
+#ifdef MODEST_TOOLKIT_HILDON2
+                                                 MODEST_TYPE_HILDON2_WINDOW,
+#else
+                                                 MODEST_TYPE_SHELL_WINDOW,
+#endif
                                                  "ModestHeaderWindow",
                                                  &my_info, 0);
        }
@@ -213,7 +243,6 @@ modest_header_window_class_init (ModestHeaderWindowClass *klass)
        GObjectClass *gobject_class;
        gobject_class = (GObjectClass*) klass;
        ModestWindowClass *modest_window_class = (ModestWindowClass *) klass;
-       ModestHildon2WindowClass *modest_hildon2_window_class = (ModestHildon2WindowClass *) klass;
 
        parent_class            = g_type_class_peek_parent (klass);
        gobject_class->finalize = modest_header_window_finalize;
@@ -222,7 +251,7 @@ modest_header_window_class_init (ModestHeaderWindowClass *klass)
        g_type_class_add_private (gobject_class, sizeof(ModestHeaderWindowPrivate));
        
        modest_window_class->disconnect_signals_func = modest_header_window_disconnect_signals;
-       modest_hildon2_window_class->pack_toolbar_func = modest_header_window_pack_toolbar;
+       modest_window_class->pack_toolbar_func = modest_header_window_pack_toolbar;
 }
 
 static void
@@ -251,9 +280,6 @@ modest_header_window_init (ModestHeaderWindow *obj)
        priv->y_coord = 0;
        priv->notify_model = 0;
 
-       modest_window_mgr_register_help_id (modest_runtime_get_window_mgr(),
-                                           GTK_WINDOW(obj),
-                                           "applications_email_headerview");
 }
 
 static void
@@ -266,7 +292,7 @@ modest_header_window_dispose (GObject *obj)
 
        folder = modest_header_view_get_folder ((ModestHeaderView *) priv->header_view);
        if (folder) {
-               tny_folder_sync_async (folder, FALSE, NULL, NULL, NULL);
+               tny_folder_sync_async (folder, TRUE, NULL, NULL, NULL);
                g_object_unref (folder);
        }
 
@@ -383,13 +409,14 @@ connect_signals (ModestHeaderWindow *self)
                                                       G_OBJECT (modest_runtime_get_window_mgr ()),
                                                       "progress-list-changed",
                                                       G_CALLBACK (on_progress_list_changed), self);
+
+#ifdef MODEST_TOOLKIT_HILDON2
        priv->sighandlers =
                modest_signal_mgr_connect (priv->sighandlers,
                                           G_OBJECT (priv->new_message_button),
                                           "clicked",
                                           G_CALLBACK (modest_ui_actions_on_new_msg), self);
 
-#ifdef MODEST_TOOLKIT_HILDON2
        /* Delete using horizontal gesture */
        /* DISABLED because it's unreliabile */
        if (HILDON_IS_PANNABLE_AREA (priv->contents_view)) {
@@ -405,8 +432,10 @@ connect_signals (ModestHeaderWindow *self)
 #endif
 
 
+#ifdef MODEST_TOOLKIT_HILDON2
        g_signal_connect(G_OBJECT(self), "key-press-event",
                        G_CALLBACK(on_key_press), self);
+#endif
 }
 
 static void
@@ -418,52 +447,6 @@ folder_refreshed_cb (ModestMailOperation *mail_op,
        update_view (MODEST_HEADER_WINDOW (user_data), NULL);
 }
 
-static gboolean
-tap_and_hold_query_cb (GtkWidget *header_view,
-                      GdkEvent *event,
-                      gpointer user_data)
-{
-       ModestHeaderWindow *self;
-       ModestHeaderWindowPrivate *priv;
-
-       self = (ModestHeaderWindow *) user_data;
-       priv = MODEST_HEADER_WINDOW_GET_PRIVATE (self);
-
-       if (event->type == GDK_BUTTON_PRESS) {
-               TnyHeader *header;
-
-               priv->x_coord = ((GdkEventButton*)event)->x;
-               priv->y_coord = ((GdkEventButton*)event)->y;
-
-               /* Enable/Disable mark as (un)read */
-               header = modest_header_view_get_header_at_pos ((ModestHeaderView *) header_view,
-                                                              priv->x_coord, priv->y_coord);
-               if (header) {
-                       GList *children;
-                       GtkWidget *mark_read_item, *mark_unread_item;
-
-                       /* Show "mark as read" or "mark as unread" */
-                       children = gtk_container_get_children (GTK_CONTAINER (priv->csm_menu));
-                       mark_read_item = (GtkWidget *) g_list_nth_data (children, 1);
-                       mark_unread_item = (GtkWidget *) g_list_nth_data (children, 2);
-
-                       if (tny_header_get_flags (header) & TNY_HEADER_FLAG_SEEN) {
-                               gtk_widget_show (mark_unread_item);
-                               gtk_widget_hide (mark_read_item);
-                       } else {
-                               gtk_widget_show (mark_read_item);
-                               gtk_widget_hide (mark_unread_item);
-                       }
-                       g_object_unref (header);
-               } else {
-                       /* Do not show the CSM if there is no header below */
-                       return TRUE;
-               }
-       }
-
-       return FALSE;
-}
-
 static void
 delete_header (GtkWindow *parent,
               TnyHeader *header)
@@ -513,7 +496,8 @@ on_delete_csm_activated (GtkMenuItem *item,
        header = modest_header_view_get_header_at_pos ((ModestHeaderView *) priv->header_view,
                                                       priv->x_coord, priv->y_coord);
        if (header) {
-               delete_header ((GtkWindow *) self, header);
+               GtkWindow *toplevel = (GtkWindow *) gtk_widget_get_toplevel ((GtkWidget *) self);
+               delete_header ((GTK_WIDGET_TOPLEVEL (toplevel)) ? toplevel : NULL, header);
                g_object_unref (header);
        }
 }
@@ -533,7 +517,11 @@ on_mark_read_csm_activated (GtkMenuItem *item,
                                                       priv->x_coord, priv->y_coord);
 
        if (header) {
+               gchar *uid;
                tny_header_set_flag (header, TNY_HEADER_FLAG_SEEN);
+               uid = modest_tny_folder_get_header_unique_id (header);
+               modest_platform_emit_msg_read_changed_signal (uid, TRUE);
+               g_free (uid);
                g_object_unref (header);
        }
 }
@@ -553,7 +541,11 @@ on_mark_unread_csm_activated (GtkMenuItem *item,
                                                       priv->x_coord, priv->y_coord);
 
        if (header) {
+               gchar *uid;
                tny_header_unset_flag (header, TNY_HEADER_FLAG_SEEN);
+               uid = modest_tny_folder_get_header_unique_id (header);
+               modest_platform_emit_msg_read_changed_signal (uid, FALSE);
+               g_free (uid);
                g_object_unref (header);
        }
 }
@@ -598,6 +590,81 @@ on_header_view_model_changed (GObject *gobject,
        g_object_weak_ref ((GObject *) model, on_header_view_model_destroyed, self);
 }
 
+/* Returns TRUE if the user clicked over a valid TnyHeader instance */
+static gboolean
+show_context_menu (ModestHeaderWindow *self,
+                  GdkEventButton     *event)
+{
+       ModestHeaderWindowPrivate *priv;
+       TnyHeader *header;
+
+       priv = MODEST_HEADER_WINDOW_GET_PRIVATE (self);
+
+       priv->x_coord = event->x;
+       priv->y_coord = event->y;
+
+       /* Enable/Disable mark as (un)read */
+       header = modest_header_view_get_header_at_pos ((ModestHeaderView *) priv->header_view,
+                                                      priv->x_coord, priv->y_coord);
+       if (header) {
+               GList *children;
+               GtkWidget *mark_read_item, *mark_unread_item;
+
+               /* Show "mark as read" or "mark as unread" */
+               children = gtk_container_get_children (GTK_CONTAINER (priv->csm_menu));
+               mark_read_item = (GtkWidget *) g_list_nth_data (children, 1);
+               mark_unread_item = (GtkWidget *) g_list_nth_data (children, 2);
+
+               if (tny_header_get_flags (header) & TNY_HEADER_FLAG_SEEN) {
+                       gtk_widget_show (mark_unread_item);
+                       gtk_widget_hide (mark_read_item);
+               } else {
+                       gtk_widget_show (mark_read_item);
+                       gtk_widget_hide (mark_unread_item);
+               }
+               g_object_unref (header);
+       } else {
+               return FALSE;
+       }
+       return TRUE;
+}
+
+
+#ifdef MAEMO_CHANGES
+static gboolean
+tap_and_hold_query_cb (GtkWidget *header_view,
+                      GdkEvent *event,
+                      gpointer user_data)
+{
+       /* Ignore other clicks but right button single clicks */
+       if (event->type != GDK_BUTTON_PRESS)
+               return FALSE;
+
+       return !show_context_menu ((ModestHeaderWindow *) user_data,
+                                  (GdkEventButton *) event);
+}
+#else
+static gboolean
+on_button_press_cb (GtkWidget      *widget,
+                   GdkEventButton *event,
+                   gpointer        user_data)
+{
+       /* Ignore other clicks but right button single clicks */
+       if (event->type != GDK_BUTTON_PRESS || event->button != 3)
+               return FALSE;
+
+       if (show_context_menu ((ModestHeaderWindow *) user_data, event)) {
+               ModestHeaderWindowPrivate *priv;
+
+               priv = MODEST_HEADER_WINDOW_GET_PRIVATE (user_data);
+               gtk_menu_popup ((GtkMenu *) priv->csm_menu, NULL, NULL,
+                               NULL, NULL, event->button, event->time);
+       }
+
+       return FALSE;
+}
+#endif
+
 static GtkWidget *
 create_header_view (ModestWindow *self, TnyFolder *folder)
 {
@@ -619,20 +686,27 @@ create_header_view (ModestWindow *self, TnyFolder *folder)
 
        /* Create CSM menu */
        priv->csm_menu = gtk_menu_new ();
-       delete_item = gtk_menu_item_new_with_label (_HL("wdgt_bd_delete"));
+       delete_item = gtk_menu_item_new_with_label (_HL_DELETE);
        mark_read_item = gtk_menu_item_new_with_label (_("mcen_me_inbox_mark_as_read"));
        mark_unread_item = gtk_menu_item_new_with_label (_("mcen_me_inbox_mark_as_unread"));
        gtk_menu_shell_append (GTK_MENU_SHELL (priv->csm_menu), delete_item);
        gtk_menu_shell_append (GTK_MENU_SHELL (priv->csm_menu), mark_read_item);
        gtk_menu_shell_append (GTK_MENU_SHELL (priv->csm_menu), mark_unread_item);
+#ifdef MAEMO_CHANGES
        hildon_gtk_widget_set_theme_size (delete_item, MODEST_EDITABLE_SIZE);
        hildon_gtk_widget_set_theme_size (mark_unread_item, MODEST_EDITABLE_SIZE);
        hildon_gtk_widget_set_theme_size (mark_read_item, MODEST_EDITABLE_SIZE);
+#endif
        gtk_widget_show_all (priv->csm_menu);
 
        /* Connect signals */
+#ifdef MAEMO_CHANGES
        g_signal_connect ((GObject *) header_view, "tap-and-hold-query",
                          G_CALLBACK (tap_and_hold_query_cb), self);
+#else
+       g_signal_connect ((GObject *) header_view, "button-press-event",
+                         G_CALLBACK (on_button_press_cb), self);
+#endif
        g_signal_connect ((GObject *) delete_item, "activate",
                          G_CALLBACK (on_delete_csm_activated), self);
        g_signal_connect ((GObject *) mark_read_item, "activate",
@@ -641,7 +715,9 @@ create_header_view (ModestWindow *self, TnyFolder *folder)
                          G_CALLBACK (on_mark_unread_csm_activated), self);
 
        /* Add tap&hold handling */
+#ifdef MAEMO_CHANGES
        gtk_widget_tap_and_hold_setup (header_view, priv->csm_menu, NULL, 0);
+#endif
 
        return header_view;
 }
@@ -653,14 +729,14 @@ create_empty_view (ModestWindow *self)
        GtkWidget *label = NULL;
        GtkWidget *align = NULL;
        GtkWidget *vbox = NULL;
-       GtkWidget *button = NULL;
-       GdkPixbuf *new_message_pixbuf;
 
        vbox = gtk_vbox_new (0, FALSE);
 
        align = gtk_alignment_new(EMPTYVIEW_XALIGN, EMPTYVIEW_YALIGN, EMPTYVIEW_XSPACE, EMPTYVIEW_YSPACE);
        label = gtk_label_new (_("mcen_ia_nomessages"));
+#ifdef MODEST_TOOLKIT_HILDON2
        hildon_helper_set_logical_font (label, "LargeSystemFont");
+#endif
        gtk_misc_set_alignment (GTK_MISC (label), 0.5, 0.5);
        gtk_widget_show (label);
        gtk_widget_show (align);
@@ -668,6 +744,9 @@ create_empty_view (ModestWindow *self)
        gtk_container_add (GTK_CONTAINER (align), label);
        gtk_box_pack_end (GTK_BOX (vbox), align, TRUE, TRUE, 0);
 
+#ifdef MODEST_TOOLKIT_HILDON2
+       GdkPixbuf *new_message_pixbuf;
+       GtkWidget *button = NULL;
        button = hildon_button_new (MODEST_EDITABLE_SIZE, 
                                    HILDON_BUTTON_ARRANGEMENT_HORIZONTAL);
 
@@ -678,12 +757,15 @@ create_empty_view (ModestWindow *self)
        g_object_unref (new_message_pixbuf);
        gtk_widget_show_all (button);
        gtk_box_pack_start (GTK_BOX (vbox), button, FALSE, FALSE, 0);
+#endif
 
        gtk_widget_show (vbox);
 
+#ifdef MODEST_TOOLKIT_HILDON2
        g_signal_connect (button,
                          "clicked",
                          G_CALLBACK (modest_ui_actions_on_new_msg), self);
+#endif
 
        viewport = gtk_viewport_new ((GtkAdjustment *) gtk_adjustment_new (0, 0, 0, 0, 0, 0), 
                                     (GtkAdjustment *) gtk_adjustment_new (0, 0, 0, 0, 0, 0));
@@ -710,24 +792,24 @@ modest_header_window_new (TnyFolder *folder, const gchar *account_name, const gc
 {
        ModestHeaderWindow *self = NULL;        
        ModestHeaderWindowPrivate *priv = NULL;
-       HildonProgram *app;
        GdkPixbuf *window_icon;
        ModestAccountMgr *mgr;
        ModestAccountSettings *settings = NULL;
        ModestServerAccountSettings *store_settings = NULL;
-       GtkWidget *action_area_box;
-       GdkPixbuf *new_message_pixbuf;
        GtkWidget *alignment;
        gchar *account_display_name = NULL;
-       
+#ifdef MODEST_TOOLKIT_HILDON2
+       GtkWidget *live_search;
+#endif
+
        self  = MODEST_HEADER_WINDOW(g_object_new(MODEST_TYPE_HEADER_WINDOW, NULL));
        priv = MODEST_HEADER_WINDOW_GET_PRIVATE(self);
 
        priv->contents_view = modest_toolkit_factory_create_scrollable (modest_runtime_get_toolkit_factory ());
        alignment = gtk_alignment_new (0.0, 0.0, 1.0, 1.0);
        gtk_alignment_set_padding (GTK_ALIGNMENT (alignment),
-                                  HILDON_MARGIN_HALF, 0,
-                                  HILDON_MARGIN_DOUBLE, HILDON_MARGIN_DOUBLE);
+                                  MODEST_MARGIN_HALF, 0,
+                                  MODEST_MARGIN_DOUBLE, MODEST_MARGIN_DOUBLE);
 
        /* We need to do this here to properly listen for mail
           operations because create_header_view launches a mail
@@ -739,6 +821,10 @@ modest_header_window_new (TnyFolder *folder, const gchar *account_name, const gc
                                  self);
 
        priv->header_view  = create_header_view (MODEST_WINDOW (self), folder);
+#ifdef MODEST_TOOLKIT_HILDON2
+       live_search = modest_header_view_setup_live_search (MODEST_HEADER_VIEW (priv->header_view));
+       hildon_live_search_widget_hook (HILDON_LIVE_SEARCH (live_search), GTK_WIDGET (self), priv->header_view);
+#endif
        priv->empty_view = create_empty_view (MODEST_WINDOW (self));
 
        /* Transform the floating reference in a "hard" reference. We
@@ -749,6 +835,10 @@ modest_header_window_new (TnyFolder *folder, const gchar *account_name, const gc
        g_object_ref_sink (priv->header_view);
        g_object_ref_sink (priv->empty_view);
 
+#ifdef MODEST_TOOLKIT_HILDON2
+       GdkPixbuf *new_message_pixbuf;
+       GtkWidget *action_area_box;
+
        g_signal_connect (G_OBJECT (self), "edit-mode-changed",
                          G_CALLBACK (edit_mode_changed), (gpointer) self);
 
@@ -763,11 +853,15 @@ modest_header_window_new (TnyFolder *folder, const gchar *account_name, const gc
        gtk_box_pack_start (GTK_BOX (action_area_box), priv->new_message_button, TRUE, TRUE, 0);
        gtk_widget_show_all (priv->new_message_button);
        hildon_tree_view_set_action_area_visible (GTK_TREE_VIEW (priv->header_view), TRUE);
+#endif
        
        setup_menu (self);
 
         priv->top_vbox = gtk_vbox_new (FALSE, 0);
        gtk_container_add (GTK_CONTAINER (alignment), priv->contents_view);
+#ifdef MODEST_TOOLKIT_HILDON2
+       gtk_box_pack_end (GTK_BOX (priv->top_vbox), live_search, FALSE, FALSE, 0);
+#endif
        gtk_box_pack_end (GTK_BOX (priv->top_vbox), alignment, TRUE, TRUE, 0);
 
        gtk_container_add (GTK_CONTAINER (self), priv->top_vbox);
@@ -780,11 +874,15 @@ modest_header_window_new (TnyFolder *folder, const gchar *account_name, const gc
 
        update_view (self, NULL);
 
+#ifdef MODEST_TOOLKIT_HILDON2
+       HildonProgram *app;
+
        /* Get device name */
        modest_maemo_utils_get_device_name ();
-
        app = hildon_program_get_instance ();
        hildon_program_add_window (app, HILDON_WINDOW (self));
+#endif
+
 
        /* Set window icon */
        window_icon = modest_platform_get_icon (MODEST_APP_ICON, MODEST_ICON_SIZE_BIG);
@@ -800,16 +898,26 @@ modest_header_window_new (TnyFolder *folder, const gchar *account_name, const gc
         */
 
        /* setup edit modes */
+#ifdef MODEST_TOOLKIT_HILDON2
        modest_hildon2_window_register_edit_mode (MODEST_HILDON2_WINDOW (self), EDIT_MODE_COMMAND_DELETE,
-                                                 _("mcen_ti_edit_delete"), _HL("wdgt_bd_delete"),
+                                                 _("mcen_ti_edit_delete"), _HL_DELETE,
                                                  GTK_TREE_VIEW (priv->header_view),
                                                  GTK_SELECTION_MULTIPLE,
                                                  EDIT_MODE_CALLBACK (modest_ui_actions_on_edit_mode_delete_message));
        modest_hildon2_window_register_edit_mode (MODEST_HILDON2_WINDOW (self), EDIT_MODE_COMMAND_MOVE,
-                                                 _("mcen_ti_edit_move"), _HL("wdgt_bd_move"),
+                                                 _("mcen_ti_edit_move"), _HL_MOVE,
                                                  GTK_TREE_VIEW (priv->header_view),
                                                  GTK_SELECTION_MULTIPLE,
                                                  EDIT_MODE_CALLBACK (modest_ui_actions_on_edit_mode_move_to));
+#endif
+
+       priv->isearch_toolbar = modest_toolkit_factory_create_isearch_toolbar (modest_runtime_get_toolkit_factory (),
+                                                                              NULL);
+       modest_window_add_toolbar (MODEST_WINDOW (self), GTK_TOOLBAR (priv->isearch_toolbar));
+       g_signal_connect (G_OBJECT (priv->isearch_toolbar), "isearch-close", 
+                         G_CALLBACK (isearch_toolbar_close), self);
+       g_signal_connect (G_OBJECT (priv->isearch_toolbar), "isearch-search", 
+                         G_CALLBACK (isearch_toolbar_search), self);
 
 
        modest_window_set_active_account (MODEST_WINDOW (self), account_name);
@@ -877,6 +985,7 @@ static void setup_menu (ModestHeaderWindow *self)
        modest_window_add_to_menu (MODEST_WINDOW (self), _("mcen_me_inbox_sendandreceive"), NULL,
                                   MODEST_WINDOW_MENU_CALLBACK (modest_ui_actions_on_send_receive),
                                   MODEST_DIMMING_CALLBACK (modest_ui_dimming_rules_on_send_receive));
+#ifdef MODEST_TOOLKIT_HILDON2
        modest_window_add_to_menu (MODEST_WINDOW (self),
                                   dngettext(GETTEXT_PACKAGE,
                                             "mcen_me_move_message",
@@ -888,6 +997,19 @@ static void setup_menu (ModestHeaderWindow *self)
        modest_window_add_to_menu (MODEST_WINDOW (self), _("mcen_me_delete_messages"), NULL,
                                   MODEST_WINDOW_MENU_CALLBACK (set_delete_edit_mode),
                                   MODEST_DIMMING_CALLBACK (modest_ui_dimming_rules_on_delete));
+#else
+       modest_window_add_to_menu (MODEST_WINDOW (self),
+                                  dngettext(GETTEXT_PACKAGE,
+                                            "mcen_me_move_message",
+                                            "mcen_me_move_messages",
+                                            2),
+                                  NULL,
+                                  MODEST_WINDOW_MENU_CALLBACK (modest_ui_actions_on_move_to),
+                                  MODEST_DIMMING_CALLBACK (modest_ui_dimming_rules_on_move_to));
+       modest_window_add_to_menu (MODEST_WINDOW (self), _("mcen_me_delete_messages"), NULL,
+                                  MODEST_WINDOW_MENU_CALLBACK (modest_ui_actions_on_delete_message),
+                                  MODEST_DIMMING_CALLBACK (modest_ui_dimming_rules_on_delete));
+#endif
        modest_window_add_to_menu (MODEST_WINDOW (self), _("mcen_me_folder_details"), NULL,
                                   MODEST_WINDOW_MENU_CALLBACK (modest_ui_actions_on_details),
                                   MODEST_DIMMING_CALLBACK (modest_ui_dimming_rules_on_details));
@@ -898,7 +1020,7 @@ static void setup_menu (ModestHeaderWindow *self)
        hildon_button_set_alignment (HILDON_BUTTON (priv->show_more_button), 0.5, 0.5, 1.0, 1.0);
        hildon_button_set_title_alignment (HILDON_BUTTON (priv->show_more_button), 0.5, 0.5);
        hildon_button_set_value_alignment (HILDON_BUTTON (priv->show_more_button), 0.5, 0.5);
-       modest_window_add_item_to_menu (MODEST_WINDOW (self), GTK_BUTTON (priv->show_more_button),
+       modest_window_add_item_to_menu (MODEST_WINDOW (self), priv->show_more_button,
                                        NULL);
        gtk_widget_hide_all (priv->show_more_button);
 #endif
@@ -906,6 +1028,10 @@ static void setup_menu (ModestHeaderWindow *self)
        modest_window_add_to_menu (MODEST_WINDOW (self), _("mcen_me_outbox_cancelsend"), NULL,
                                   MODEST_WINDOW_MENU_CALLBACK (modest_ui_actions_cancel_send),
                                   MODEST_DIMMING_CALLBACK (modest_ui_dimming_rules_on_cancel_sending_all));
+#ifndef MODEST_TOOLKIT_HILDON2
+       modest_window_add_to_menu (MODEST_WINDOW (self), _HL("wdgt_bd_search"), "<Control>f",
+                                  MODEST_WINDOW_MENU_CALLBACK (toggle_isearch_toolbar), NULL);
+#endif
 }
 
 static void 
@@ -1043,7 +1169,7 @@ show_updating_banner (gpointer user_data)
                gdk_threads_enter ();
                priv->updating_banner = 
                        modest_platform_animation_banner (GTK_WIDGET (user_data), NULL,
-                                                         _CS ("ckdg_pb_updating"));
+                                                         _CS_UPDATING);
 
                /* We need this because banners in Maemo could be
                   destroyed by dialogs so we need to properly update
@@ -1095,6 +1221,7 @@ on_updating_msg_list (ModestHeaderView *header_view,
        }
 }
 
+#ifdef MODEST_TOOLKIT_HILDON2
 static void
 set_delete_edit_mode (GtkButton *button,
                      ModestHeaderWindow *self)
@@ -1108,6 +1235,7 @@ set_moveto_edit_mode (GtkButton *button,
 {
        modest_hildon2_window_set_edit_mode (MODEST_HILDON2_WINDOW (self), EDIT_MODE_COMMAND_MOVE);
 }
+#endif
 
 static gboolean 
 on_expose_event(GtkTreeView *header_view,
@@ -1115,12 +1243,15 @@ on_expose_event(GtkTreeView *header_view,
                gpointer user_data)
 {
        ModestHeaderWindow *self = (ModestHeaderWindow *) user_data;
-       ModestHeaderWindowPrivate *priv = MODEST_HEADER_WINDOW_GET_PRIVATE (self);
 
        g_return_val_if_fail (MODEST_IS_HEADER_WINDOW (self), FALSE);
 
+#ifdef MODEST_TOOLKIT_HILDON2
+       ModestHeaderWindowPrivate *priv = MODEST_HEADER_WINDOW_GET_PRIVATE (self);
+
        if (priv->autoscroll)
                modest_scrollable_jump_to (MODEST_SCROLLABLE (priv->contents_view), 0.0, 0.0);
+#endif
 
        return FALSE;
 }
@@ -1136,7 +1267,7 @@ on_map_event(GtkWidget *widget,
        g_return_val_if_fail (MODEST_IS_HEADER_WINDOW (self), FALSE);
 
        if (priv->progress_hint) {
-               hildon_gtk_window_set_progress_indicator (GTK_WINDOW (self), TRUE);
+               modest_window_show_progress (MODEST_WINDOW (self), TRUE);
        }
        return FALSE;
 }
@@ -1197,7 +1328,7 @@ update_progress_hint (ModestHeaderWindow *self)
        modest_ui_actions_check_menu_dimming_rules (MODEST_WINDOW (self));
 
        if (GTK_WIDGET_VISIBLE (self)) {
-               hildon_gtk_window_set_progress_indicator (GTK_WINDOW (self), priv->progress_hint?1:0);
+               modest_window_show_progress (MODEST_WINDOW (self), priv->progress_hint?1:0);
        }
 }
 
@@ -1291,7 +1422,7 @@ on_queue_changed (ModestMailOperationQueue *queue,
 }
 
 static void
-modest_header_window_pack_toolbar (ModestHildon2Window *self,
+modest_header_window_pack_toolbar (ModestWindow *self,
                                   GtkPackType pack_type,
                                   GtkWidget *toolbar)
 {
@@ -1307,6 +1438,7 @@ modest_header_window_pack_toolbar (ModestHildon2Window *self,
        }
 }
 
+#ifdef MODEST_TOOLKIT_HILDON2
 static void 
 edit_mode_changed (ModestHeaderWindow *header_window,
                   gint edit_mode_id,
@@ -1348,6 +1480,7 @@ edit_mode_changed (ModestHeaderWindow *header_window,
                                                 filter);
        }
 }
+#endif
 
 #ifdef MODEST_TOOLKIT_HILDON2
 static void
@@ -1386,6 +1519,7 @@ on_horizontal_movement (HildonPannableArea *hildonpannable,
 }
 #endif
 
+#ifdef MODEST_TOOLKIT_HILDON2
 static gboolean
 on_key_press(GtkWidget *widget, GdkEventKey *event, gpointer user_data)
 {
@@ -1416,3 +1550,60 @@ on_key_press(GtkWidget *widget, GdkEventKey *event, gpointer user_data)
 
        return FALSE;
 }
+#endif
+
+#ifndef MODEST_TOOLKIT_HILDON2
+/* Used for the Ctrl+F accelerator */
+static void
+toggle_isearch_toolbar (GtkWidget *obj,
+                       gpointer data)
+{
+       ModestHeaderWindow *window = MODEST_HEADER_WINDOW (data);
+       ModestHeaderWindowPrivate *priv = MODEST_HEADER_WINDOW_GET_PRIVATE (window);
+
+       if (GTK_WIDGET_VISIBLE (priv->isearch_toolbar)) {
+               isearch_toolbar_close (obj, data);
+       } else {
+               show_isearch_toolbar (obj, data);
+       }
+}
+
+/* Handler for menu option */
+static void
+show_isearch_toolbar (GtkWidget *obj,
+                     gpointer data)
+{
+       ModestHeaderWindow *window = MODEST_HEADER_WINDOW (data);
+       ModestHeaderWindowPrivate *priv = MODEST_HEADER_WINDOW_GET_PRIVATE (window);
+
+       gtk_widget_show (priv->isearch_toolbar);
+       modest_isearch_toolbar_highlight_entry (MODEST_ISEARCH_TOOLBAR (priv->isearch_toolbar), TRUE);
+}
+#endif
+
+/* Handler for click on the "X" close button in isearch toolbar */
+static void
+isearch_toolbar_close (GtkWidget *widget,
+                      ModestHeaderWindow *obj)
+{
+       ModestHeaderWindowPrivate *priv;
+
+       priv = MODEST_HEADER_WINDOW_GET_PRIVATE (obj);
+
+       /* Hide toolbar */
+       gtk_widget_hide (priv->isearch_toolbar);
+
+       modest_header_view_set_filter_string (MODEST_HEADER_VIEW (priv->header_view), NULL);
+}
+
+static void
+isearch_toolbar_search (GtkWidget *widget,
+                       ModestHeaderWindow *obj)
+{
+       ModestHeaderWindowPrivate *priv = MODEST_HEADER_WINDOW_GET_PRIVATE (obj);
+
+       /* TODO: set filter */
+       modest_header_view_set_filter_string (MODEST_HEADER_VIEW (priv->header_view), 
+                                             modest_isearch_toolbar_get_search (MODEST_ISEARCH_TOOLBAR (priv->isearch_toolbar)));
+
+}