Show calendar flag in headers list.
[modest] / src / gtk / modest-shell.c
index 420621a..c506ec6 100644 (file)
 #include <modest-shell-window.h>
 #include <modest-icon-names.h>
 #include <modest-ui-actions.h>
+#include <modest-gtk-window-mgr.h>
+#include <modest-runtime.h>
 
 /* 'private'/'protected' functions */
 static void modest_shell_class_init (ModestShellClass *klass);
 static void modest_shell_instance_init (ModestShell *obj);
+static void modest_shell_dispose   (GObject *obj);
 static void modest_shell_finalize   (GObject *obj);
 
 static void update_title (ModestShell *self);
@@ -47,6 +50,10 @@ static void on_style_set (GtkWidget *widget, GtkStyle *old_style, ModestShell *s
 static gboolean on_delete_event (GtkWidget *widget,
                                 GdkEvent  *event,
                                 gpointer   user_data);
+static gboolean on_control_q (GtkAccelGroup *accel_group,
+                             GObject *acceleratable,
+                             guint keyval,
+                             GdkModifierType modifier);
 static gboolean on_key_pressed (GtkWidget *widget, GdkEventKey *event, ModestShell *shell);
 
 
@@ -106,6 +113,7 @@ modest_shell_class_init (ModestShellClass *klass)
        gobject_class = (GObjectClass*) klass;
 
        parent_class            = g_type_class_peek_parent (klass);
+       gobject_class->dispose = modest_shell_dispose;
        gobject_class->finalize = modest_shell_finalize;
 
        g_type_class_add_private (gobject_class, sizeof(ModestShellPrivate));
@@ -161,12 +169,6 @@ modest_shell_instance_init (ModestShell *obj)
        gtk_widget_show (GTK_WIDGET (priv->new_message_button));
        g_signal_connect (G_OBJECT (priv->new_message_button), "clicked", G_CALLBACK (on_new_msg_button_clicked), obj);
 
-       priv->back_button = gtk_tool_button_new_from_stock (GTK_STOCK_GO_BACK);
-       g_object_set (priv->back_button, "is-important", TRUE, NULL);
-       gtk_toolbar_insert (GTK_TOOLBAR (priv->top_toolbar), priv->back_button, -1);
-       gtk_widget_show (GTK_WIDGET (priv->back_button));
-       g_signal_connect (G_OBJECT (priv->back_button), "clicked", G_CALLBACK (on_back_button_clicked), obj);
-
        separator_toolitem = gtk_separator_tool_item_new ();
        gtk_toolbar_insert (GTK_TOOLBAR (priv->top_toolbar), separator_toolitem, -1);
        gtk_widget_show (GTK_WIDGET (separator_toolitem));
@@ -195,6 +197,12 @@ modest_shell_instance_init (ModestShell *obj)
        g_object_set (priv->title_button, "is-important", TRUE, NULL);
        g_signal_connect (G_OBJECT (priv->title_button), "clicked", G_CALLBACK (on_title_button_clicked), obj);
 
+       priv->back_button = gtk_tool_button_new_from_stock (GTK_STOCK_GO_BACK);
+       g_object_set (priv->back_button, "is-important", TRUE, NULL);
+       gtk_toolbar_insert (GTK_TOOLBAR (priv->top_toolbar), priv->back_button, -1);
+       gtk_widget_show (GTK_WIDGET (priv->back_button));
+       g_signal_connect (G_OBJECT (priv->back_button), "clicked", G_CALLBACK (on_back_button_clicked), obj);
+
        priv->notebook = gtk_notebook_new ();
        gtk_notebook_set_show_tabs ((GtkNotebook *)priv->notebook, FALSE);
        gtk_notebook_set_show_border ((GtkNotebook *)priv->notebook, FALSE);
@@ -215,6 +223,11 @@ modest_shell_instance_init (ModestShell *obj)
        gtk_accelerator_parse ("Escape", &accel_key, &accel_mods);
        gtk_widget_add_accelerator (GTK_WIDGET (priv->back_button), "clicked", accel_group,
                                    accel_key, accel_mods, 0);
+       gtk_accelerator_parse ("<Control>w", &accel_key, &accel_mods);
+       gtk_widget_add_accelerator (GTK_WIDGET (priv->back_button), "clicked", accel_group,
+                                   accel_key, accel_mods, 0);
+       gtk_accelerator_parse ("<Control>q", &accel_key, &accel_mods);
+       gtk_accel_group_connect (accel_group, accel_key, accel_mods, 0, g_cclosure_new (G_CALLBACK (on_control_q), NULL, NULL));
        gtk_accelerator_parse ("F10", &accel_key, &accel_mods);
        gtk_widget_add_accelerator (GTK_WIDGET (priv->title_button), "clicked", accel_group,
                                    accel_key, accel_mods, 0);
@@ -231,6 +244,20 @@ modest_shell_instance_init (ModestShell *obj)
 }
 
 static void
+modest_shell_dispose (GObject *obj)
+{
+       ModestShellPrivate *priv;
+
+       priv = MODEST_SHELL_GET_PRIVATE (obj);
+
+       if (priv->progress_timeout_id) {
+               g_source_remove (priv->progress_timeout_id);
+               priv->progress_timeout_id = 0;
+       }
+       G_OBJECT_CLASS(parent_class)->dispose (obj);
+}
+
+static void
 modest_shell_finalize (GObject *obj)
 {
        ModestShellPrivate *priv;
@@ -240,6 +267,7 @@ modest_shell_finalize (GObject *obj)
 
        if (priv->progress_timeout_id) {
                g_source_remove (priv->progress_timeout_id);
+               priv->progress_timeout_id = 0;
        }
        for (n = 0; n < 31; n++) {
                if (priv->progress_frames[n]) {
@@ -483,7 +511,11 @@ on_title_button_clicked (GtkToolButton *button, ModestShell *self)
        menu = modest_shell_window_get_menu (MODEST_SHELL_WINDOW (child));
 
        if (menu) {
-               gtk_menu_popup (GTK_MENU (menu), NULL, NULL, 
+               /* Run dimming rules */
+               ModestWindow *window = modest_shell_peek_window (self);
+               modest_ui_actions_check_menu_dimming_rules (window);
+
+               gtk_menu_popup (GTK_MENU (menu), NULL, NULL,
                                (GtkMenuPositionFunc) menu_position_cb, (gpointer) self,
                                1, gtk_get_current_event_time ());
        }
@@ -599,3 +631,20 @@ on_delete_event (GtkWidget *widget,
 
        return FALSE;
 }
+
+static gboolean 
+on_control_q (GtkAccelGroup *accel_group,
+             GObject *acceleratable,
+             guint keyval,
+             GdkModifierType modifier)
+{
+       ModestWindowMgr *mgr;
+       GtkWidget *shell;
+       gboolean ret_value;
+
+       mgr = modest_runtime_get_window_mgr ();
+       shell = modest_gtk_window_mgr_get_shell (MODEST_GTK_WINDOW_MGR (mgr));
+       g_signal_emit_by_name (G_OBJECT (shell), "delete-event", NULL, &ret_value);
+
+       return ret_value;
+}