*/
#include <modest-accounts-window.h>
-#include <modest-osso-state-saving.h>
-#include <libosso.h>
-#include <hildon/hildon-pannable-area.h>
+#include <modest-scrollable.h>
#include <hildon/hildon-banner.h>
#include <hildon/hildon-helper.h>
#include <modest-ui-actions.h>
static gboolean on_key_press(GtkWidget *widget,
GdkEventKey *event,
gpointer user_data);
+static gboolean on_delete_event (GtkWidget *widget,
+ GdkEvent *event,
+ gpointer userdata);
typedef struct _ModestAccountsWindowPrivate ModestAccountsWindowPrivate;
struct _ModestAccountsWindowPrivate {
GtkWidget *box;
- GtkWidget *pannable;
+ GtkWidget *scrollable;
GtkWidget *account_view;
GtkWidget *no_accounts_container;
GtkWidget *new_message_button;
"clicked",
G_CALLBACK (modest_ui_actions_on_new_msg), self);
- priv->pannable = hildon_pannable_area_new ();
+ priv->scrollable = modest_toolkit_factory_create_scrollable (modest_runtime_get_toolkit_factory ());
priv->queue_change_handler =
g_signal_connect (G_OBJECT (modest_runtime_get_mail_operation_queue ()),
g_object_unref (new_message_pixbuf);
setup_menu (self);
- gtk_box_pack_start (GTK_BOX (priv->box), priv->pannable, TRUE, TRUE, 0);
+ gtk_box_pack_start (GTK_BOX (priv->box), priv->scrollable, TRUE, TRUE, 0);
gtk_container_add (GTK_CONTAINER (box_alignment), priv->box);
gtk_container_add (GTK_CONTAINER (self), box_alignment);
- gtk_widget_show (priv->pannable);
+ gtk_widget_show (priv->scrollable);
gtk_widget_show (priv->box);
gtk_widget_show (box_alignment);
action_area_box = hildon_tree_view_get_action_area_box (GTK_TREE_VIEW (priv->account_view));
gtk_box_pack_start (GTK_BOX (action_area_box), priv->new_message_button, TRUE, TRUE, 0);
hildon_tree_view_set_action_area_visible (GTK_TREE_VIEW (priv->account_view), TRUE);
- gtk_container_add (GTK_CONTAINER (priv->pannable), priv->account_view);
+ gtk_container_add (GTK_CONTAINER (priv->scrollable), priv->account_view);
connect_signals (MODEST_ACCOUNTS_WINDOW (self));
- /* Load previous osso state, for instance if we are being restored from
- * hibernation: */
- modest_osso_load_state ();
-
app = hildon_program_get_instance ();
hildon_program_add_window (app, HILDON_WINDOW (self));
g_signal_connect (G_OBJECT (self), "map-event",
G_CALLBACK (_modest_accounts_window_map_event),
G_OBJECT (self));
+ g_signal_connect (G_OBJECT (self), "delete-event",
+ G_CALLBACK (on_delete_event), self);
update_progress_hint (MODEST_ACCOUNTS_WINDOW (self));
row_count_changed (MODEST_ACCOUNTS_WINDOW (self));
- gtk_window_set_title (GTK_WINDOW (self), _("mcen_ap_name"));
+ modest_window_set_title (MODEST_WINDOW (self), _("mcen_ap_name"));
return self;
}
g_return_if_fail (MODEST_IS_ACCOUNTS_WINDOW(self));
/* Settings menu buttons */
- modest_hildon2_window_add_to_menu (MODEST_HILDON2_WINDOW (self), _("mcen_me_new_account"), NULL,
- APP_MENU_CALLBACK (modest_ui_actions_on_new_account),
- NULL);
- modest_hildon2_window_add_to_menu (MODEST_HILDON2_WINDOW (self),
- dngettext(GETTEXT_PACKAGE,
- "mcen_me_edit_account",
- "mcen_me_edit_accounts",
- 2),
- NULL,
- APP_MENU_CALLBACK (modest_ui_actions_on_accounts),
- MODEST_DIMMING_CALLBACK (modest_ui_dimming_rules_on_edit_accounts));
- modest_hildon2_window_add_to_menu (MODEST_HILDON2_WINDOW (self), _("mcen_me_inbox_globalsmtpservers"), NULL,
- APP_MENU_CALLBACK (modest_ui_actions_on_smtp_servers),
- MODEST_DIMMING_CALLBACK (modest_ui_dimming_rules_on_tools_smtp_servers));
- modest_hildon2_window_add_to_menu (MODEST_HILDON2_WINDOW (self), _("mcen_me_inbox_sendandreceive"), NULL,
- APP_MENU_CALLBACK (modest_ui_actions_on_send_receive),
- MODEST_DIMMING_CALLBACK (modest_ui_dimming_rules_on_send_receive_all));
- 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), _("mcen_me_inbox_options"), NULL,
- APP_MENU_CALLBACK (modest_ui_actions_on_settings),
- NULL);
+ modest_window_add_to_menu (MODEST_WINDOW (self), _("mcen_me_new_account"), NULL,
+ MODEST_WINDOW_MENU_CALLBACK (modest_ui_actions_on_new_account),
+ NULL);
+ modest_window_add_to_menu (MODEST_WINDOW (self),
+ dngettext(GETTEXT_PACKAGE,
+ "mcen_me_edit_account",
+ "mcen_me_edit_accounts",
+ 2),
+ NULL,
+ MODEST_WINDOW_MENU_CALLBACK (modest_ui_actions_on_accounts),
+ MODEST_DIMMING_CALLBACK (modest_ui_dimming_rules_on_edit_accounts));
+ modest_window_add_to_menu (MODEST_WINDOW (self), _("mcen_me_inbox_globalsmtpservers"), NULL,
+ MODEST_WINDOW_MENU_CALLBACK (modest_ui_actions_on_smtp_servers),
+ MODEST_DIMMING_CALLBACK (modest_ui_dimming_rules_on_tools_smtp_servers));
+ 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_all));
+ 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));
+ modest_window_add_to_menu (MODEST_WINDOW (self), _("mcen_me_inbox_options"), NULL,
+ MODEST_WINDOW_MENU_CALLBACK (modest_ui_actions_on_settings),
+ NULL);
}
gtk_widget_show (priv->account_view);
g_debug ("%s: showing accounts view", __FUNCTION__);
}
- gtk_container_child_set (GTK_CONTAINER(priv->box), priv->pannable,
+ gtk_container_child_set (GTK_CONTAINER(priv->box), priv->scrollable,
"expand", count > 0,
"fill", count > 0,
NULL);
on_key_press(GtkWidget *widget, GdkEventKey *event, gpointer user_data)
{
ModestAccountsWindowPrivate *priv;
- HildonPannableArea *pannable;
+ ModestScrollable *scrollable;
if (event->type == GDK_KEY_RELEASE)
return FALSE;
priv = MODEST_ACCOUNTS_WINDOW_GET_PRIVATE(user_data);
- pannable = HILDON_PANNABLE_AREA (priv->pannable);
+ scrollable = MODEST_SCROLLABLE (priv->scrollable);
switch (event->keyval) {
case GDK_Up:
- modest_maemo_utils_scroll_pannable(pannable, 0, -1);
+ modest_scrollable_scroll (scrollable, 0, -1);
break;
case GDK_Down:
- modest_maemo_utils_scroll_pannable(pannable, 0, 1);
+ modest_scrollable_scroll (scrollable, 0, 1);
break;
}
return FALSE;
}
+
+static gboolean
+on_delete_event (GtkWidget *widget,
+ GdkEvent *event,
+ gpointer userdata)
+{
+ ModestAccountsWindowPrivate *priv;
+
+ priv = MODEST_ACCOUNTS_WINDOW_GET_PRIVATE (widget);
+
+ modest_account_view_set_show_last_update (MODEST_ACCOUNT_VIEW (priv->account_view), FALSE);
+
+ gtk_widget_queue_resize (widget);
+
+ gdk_window_process_updates (priv->account_view->window, TRUE);
+ hildon_gtk_window_take_screenshot (GTK_WINDOW (widget), TRUE);
+
+ modest_account_view_set_show_last_update (MODEST_ACCOUNT_VIEW (priv->account_view), TRUE);
+
+ return FALSE;
+
+}