Emit dbus signal on changing SEEN flag.
[modest] / src / hildon2 / modest-header-window.c
index c45b0ed..b44f12e 100644 (file)
 #include <hildon/hildon-button.h>
 #include <hildon/hildon-program.h>
 #include <hildon/hildon-banner.h>
+#include <hildon/hildon-find-toolbar.h>
 #include <modest-ui-dimming-rules.h>
 #include <modest-tny-folder.h>
 #include <modest-tny-account.h>
 #include <tny-simple-list.h>
+#include <gdk/gdkkeysyms.h>
 
 #define SHOW_LATEST_SIZE 250
 
@@ -106,6 +108,9 @@ struct _ModestHeaderWindowPrivate {
 
        /* weak refs */
        GtkTreeModel *model_weak_ref;
+
+       gboolean limit_headers;
+       GtkWidget   *isearch_toolbar;
 };
 #define MODEST_HEADER_WINDOW_GET_PRIVATE(o)  (G_TYPE_INSTANCE_GET_PRIVATE((o), \
                                                                          MODEST_TYPE_HEADER_WINDOW, \
@@ -183,6 +188,15 @@ static gboolean on_key_press(GtkWidget *widget,
                                        gpointer user_data);
 static void modest_header_window_show_more (GtkAction *action, ModestWindow *win);
 
+static void  show_isearch_toolbar   (GtkWidget *obj, gpointer data);
+static void  isearch_toolbar_close  (GtkWidget *widget,
+                                    ModestHeaderWindow *obj);
+static void  isearch_toolbar_search (GtkWidget *widget,
+                                    ModestHeaderWindow *obj);
+static void  toggle_isearch_toolbar (GtkWidget *obj,
+                                    gpointer data);
+
+
 /* globals */
 static GtkWindowClass *parent_class = NULL;
 
@@ -265,6 +279,7 @@ modest_header_window_init (ModestHeaderWindow *obj)
        priv->x_coord = 0;
        priv->y_coord = 0;
        priv->notify_model = 0;
+       priv->limit_headers = FALSE;
 
        modest_window_mgr_register_help_id (modest_runtime_get_window_mgr(),
                                            GTK_WINDOW(obj),
@@ -566,7 +581,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);
        }
 }
@@ -586,7 +605,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);
        }
 }
@@ -649,23 +672,23 @@ create_header_view (ModestWindow *self, TnyFolder *folder)
        ModestHeaderWindowPrivate *priv;
        TnyAccount *account;
        ModestProtocolType protocol_type;
-       gboolean limit_headers;
 
        priv = MODEST_HEADER_WINDOW_GET_PRIVATE (self);
 
        header_view  = modest_header_view_new (NULL, MODEST_HEADER_VIEW_STYLE_TWOLINES);
 
        account = modest_tny_folder_get_account (folder);
-       limit_headers = FALSE;
+       priv->limit_headers = FALSE;
        if (account) {
                protocol_type = modest_tny_account_get_protocol_type (account);
                if (modest_protocol_registry_protocol_type_has_tag (modest_runtime_get_protocol_registry (),
                                                                    protocol_type,
                                                                    MODEST_PROTOCOL_REGISTRY_STORE_LIMIT_HEADER_WINDOW)) {
-                       limit_headers = TRUE;
+                       priv->limit_headers = TRUE;
                }
+               g_object_unref (account);
        }
-       modest_header_view_set_show_latest (MODEST_HEADER_VIEW (header_view), limit_headers?SHOW_LATEST_SIZE:0);
+       modest_header_view_set_show_latest (MODEST_HEADER_VIEW (header_view), priv->limit_headers?SHOW_LATEST_SIZE:0);
 
        priv->notify_model = g_signal_connect ((GObject*) header_view, "notify::model",
                                               G_CALLBACK (on_header_view_model_changed), self);
@@ -775,7 +798,7 @@ on_vertical_movement (HildonPannableArea *area,
 ModestWindow *
 modest_header_window_new (TnyFolder *folder, const gchar *account_name, const gchar *mailbox)
 {
-       ModestHeaderWindow *self = NULL;        
+       ModestHeaderWindow *self = NULL;
        ModestHeaderWindowPrivate *priv = NULL;
        HildonProgram *app;
        GdkPixbuf *window_icon;
@@ -786,7 +809,7 @@ modest_header_window_new (TnyFolder *folder, const gchar *account_name, const gc
        GdkPixbuf *new_message_pixbuf;
        GtkWidget *alignment;
        gchar *account_display_name = NULL;
-       
+
        self  = MODEST_HEADER_WINDOW(g_object_new(MODEST_TYPE_HEADER_WINDOW, NULL));
        priv = MODEST_HEADER_WINDOW_GET_PRIVATE(self);
 
@@ -830,7 +853,7 @@ 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);
-       
+
        setup_menu (self);
 
         priv->top_vbox = gtk_vbox_new (FALSE, 0);
@@ -878,6 +901,13 @@ modest_header_window_new (TnyFolder *folder, const gchar *account_name, const gc
                                                  GTK_SELECTION_MULTIPLE,
                                                  EDIT_MODE_CALLBACK (modest_ui_actions_on_edit_mode_move_to));
 
+       priv->isearch_toolbar = hildon_find_toolbar_new (NULL);
+       hildon_window_add_toolbar (HILDON_WINDOW (self), GTK_TOOLBAR (priv->isearch_toolbar));
+       g_signal_connect (G_OBJECT (priv->isearch_toolbar), "close", 
+                         G_CALLBACK (isearch_toolbar_close), self);
+       g_signal_connect (G_OBJECT (priv->isearch_toolbar), "search", 
+                         G_CALLBACK (isearch_toolbar_search), self);
+
 
        modest_window_set_active_account (MODEST_WINDOW (self), account_name);
        modest_window_set_active_mailbox (MODEST_WINDOW (self), mailbox);
@@ -907,7 +937,7 @@ modest_header_window_new (TnyFolder *folder, const gchar *account_name, const gc
                } else {
                        folder_name = modest_tny_folder_get_display_name (folder);
                }
-               
+
                gtk_window_set_title (GTK_WINDOW (self), folder_name);
                g_free (folder_name);
        }
@@ -982,6 +1012,8 @@ static void setup_menu (ModestHeaderWindow *self)
        modest_hildon2_window_add_to_menu (MODEST_HILDON2_WINDOW (self), _("mcen_me_outbox_cancelsend"), NULL,
                                           APP_MENU_CALLBACK (modest_ui_actions_cancel_send),
                                           MODEST_DIMMING_CALLBACK (modest_ui_dimming_rules_on_cancel_sending_all));
+       modest_hildon2_window_add_to_menu (MODEST_HILDON2_WINDOW (self), _HL("wdgt_bd_search"), NULL,
+                                          APP_MENU_CALLBACK (toggle_isearch_toolbar), NULL);
 }
 
 static void 
@@ -1611,3 +1643,73 @@ modest_header_window_show_more (GtkAction *action, ModestWindow *win)
                update_view (self, NULL);
        }
 }
+
+/* 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);
+       hildon_find_toolbar_highlight_entry (HILDON_FIND_TOOLBAR (priv->isearch_toolbar), TRUE);
+}
+
+/* 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_show_latest (MODEST_HEADER_VIEW (priv->header_view), priv->limit_headers?SHOW_LATEST_SIZE:0);
+       modest_header_view_set_filter_string (MODEST_HEADER_VIEW (priv->header_view), NULL);
+       update_view (obj, NULL);
+}
+
+static void
+isearch_toolbar_search (GtkWidget *widget,
+                       ModestHeaderWindow *obj)
+{
+       ModestHeaderWindowPrivate *priv = MODEST_HEADER_WINDOW_GET_PRIVATE (obj);
+       gchar *current_search;
+
+       g_object_get (G_OBJECT (widget), "prefix", &current_search, NULL);
+
+       if (current_search && *current_search == '\0') {
+               g_free (current_search);
+               current_search = NULL;
+       }
+
+       /* TODO: set filter */
+       modest_header_view_set_filter_string (MODEST_HEADER_VIEW (priv->header_view), 
+                                             current_search);
+       if (current_search == NULL) {
+               modest_header_view_set_show_latest (MODEST_HEADER_VIEW (priv->header_view), priv->limit_headers?SHOW_LATEST_SIZE:0);
+       } else {
+               modest_header_view_set_show_latest (MODEST_HEADER_VIEW (priv->header_view), 0);
+       }
+       g_free (current_search);
+       update_view (obj, NULL);
+}