#include <modest-widget-memory.h>
#include <tny-error.h>
#include <tny-simple-list.h>
+#include <tny-msg-view.h>
#define MODEST_UI_GET_PRIVATE(o) (G_TYPE_INSTANCE_GET_PRIVATE((o), \
MODEST_TYPE_UI, \
static void
modest_ui_finalize (GObject *obj)
{
-
ModestUIPrivate *priv = MODEST_UI_GET_PRIVATE(obj);
if (priv->widget_factory) {
g_object_unref (G_OBJECT(priv->ui_manager));
priv->ui_manager = NULL;
}
-
+
G_OBJECT_CLASS(parent_class)->finalize (obj);
}
g_object_unref (G_OBJECT (widget_factory));
g_object_unref (G_OBJECT (account_store));
- gtk_widget_show (GTK_WIDGET (msg_win));
+ gtk_widget_show_all (GTK_WIDGET (msg_win));
}
static void
g_object_unref (G_OBJECT (account_store));
modest_edit_msg_window_set_msg (MODEST_EDIT_MSG_WINDOW (msg_win),
new_msg);
- gtk_widget_show (GTK_WIDGET (msg_win));
+ gtk_widget_show_all (GTK_WIDGET (msg_win));
/* Clean */
g_object_unref (G_OBJECT (new_msg));
gtk_window_set_title (GTK_WINDOW(main_window), "Modest");
modest_header_view_set_folder (header_view, NULL);
} else { /* the folder was selected */
- guint num, unread;
- gchar *title;
- num = tny_folder_get_all_count (folder);
- unread = tny_folder_get_unread_count (folder);
-
- title = g_strdup_printf ("Modest: %s",
- tny_folder_get_name (folder));
-
- gtk_window_set_title (GTK_WINDOW(main_window), title);
- g_free (title);
+ if (folder) { /* folder may be NULL */
+ guint num, unread;
+ gchar *title;
- txt = g_strdup_printf (_("%d %s, %d unread"),
- num, num==1 ? _("item") : _("items"), unread);
- gtk_label_set_label (GTK_LABEL(folder_info_label), txt);
- g_free (txt);
+ num = tny_folder_get_all_count (folder);
+ unread = tny_folder_get_unread_count (folder);
+
+ title = g_strdup_printf ("Modest: %s",
+ tny_folder_get_name (folder));
+ gtk_window_set_title (GTK_WINDOW(main_window), title);
+ g_free (title);
+
+ txt = g_strdup_printf (_("%d %s, %d unread"),
+ num, num==1 ? _("item") : _("items"), unread);
+ gtk_label_set_label (GTK_LABEL(folder_info_label), txt);
+ g_free (txt);
+ }
modest_header_view_set_folder (header_view, folder);
modest_widget_memory_restore (conf, G_OBJECT(header_view),
"header-view");
gtk_main_iteration ();
}
-/****************************************************/
-/*
- * below some stuff to clearup statusbar messages after 1,5 seconds....
- */
-typedef struct {
- GtkWidget *status_bar;
- GtkWidget *progress_bar;
- guint msg_id;
-} StatusRemoveData;
static gboolean
-on_statusbar_remove_msg (StatusRemoveData *data)
+progress_bar_clean (GtkWidget *bar)
+{
+ if (GTK_IS_PROGRESS_BAR(bar)) {
+ gtk_progress_bar_set_text (GTK_PROGRESS_BAR(bar), "");
+ gtk_progress_bar_set_fraction (GTK_PROGRESS_BAR(bar), 1.0);
+ }
+ return FALSE;
+}
+static gboolean
+statusbar_clean (GtkWidget *bar)
{
- /* we need to test types, as this callback maybe called after the
- * widgets have been destroyed
- */
- if (GTK_IS_STATUSBAR(data->status_bar))
- gtk_statusbar_remove (GTK_STATUSBAR(data->status_bar),
- 0, data->msg_id);
- if (GTK_IS_PROGRESS_BAR(data->progress_bar))
- gtk_progress_bar_set_fraction (GTK_PROGRESS_BAR(data->progress_bar),
- 1.0);
- g_free (data);
+ if (GTK_IS_STATUSBAR(bar))
+ gtk_statusbar_push (GTK_STATUSBAR(bar), 0, "");
return FALSE;
}
+
static void
statusbar_push (ModestWidgetFactory *factory, guint context_id, const gchar *msg)
{
- guint id;
- StatusRemoveData *data;
GtkWidget *status_bar, *progress_bar;
if (!msg)
progress_bar = modest_widget_factory_get_progress_bar (factory);
status_bar = modest_widget_factory_get_status_bar (factory);
-
- id = gtk_statusbar_push (GTK_STATUSBAR(status_bar), 0, msg);
- data = g_new (StatusRemoveData, 1);
- data->status_bar = status_bar;
- data->progress_bar = progress_bar;
- data->msg_id = id;
+ gtk_widget_show (GTK_WIDGET(status_bar));
+ gtk_widget_show (GTK_WIDGET(progress_bar));
+
+ gtk_statusbar_push (GTK_STATUSBAR(status_bar), 0, msg);
- g_timeout_add (1500, (GSourceFunc)on_statusbar_remove_msg, data);
+ g_timeout_add (1500, (GSourceFunc)statusbar_clean, status_bar);
+ g_timeout_add (3000, (GSourceFunc)progress_bar_clean, progress_bar);
}
/****************************************************************************/
{
GtkWidget *progress_bar;
ModestWidgetFactory *widget_factory;
-
+ char* txt;
+
widget_factory = modest_window_get_widget_factory (MODEST_WINDOW (main_window));
progress_bar = modest_widget_factory_get_progress_bar (widget_factory);
else
gtk_progress_bar_pulse (GTK_PROGRESS_BAR(progress_bar));
+ txt = g_strdup_printf (_("Downloading %d of %d"), num, total);
+ gtk_progress_bar_set_text (GTK_PROGRESS_BAR(progress_bar), txt);
+ g_free (txt);
+
statusbar_push (widget_factory, 0, msg);
-
+
/* Free */
g_object_unref (G_OBJECT (widget_factory));
}
_modest_ui_actions_on_rename_folder (GtkWidget *widget,
ModestMainWindow *main_window)
{
- g_print ("Rename Folder");
+ TnyFolder *folder;
+ ModestFolderView *folder_view;
+ ModestWidgetFactory *widget_factory;
+
+ widget_factory = modest_window_get_widget_factory (MODEST_WINDOW (main_window));
+ folder_view = modest_widget_factory_get_folder_view (widget_factory);
+ folder = modest_folder_view_get_selected (folder_view);
+
+ if (folder) {
+ gchar *folder_name;
+
+ folder_name = ask_for_folder_name (GTK_WINDOW (main_window),
+ _("Please enter a new name for the folder"));
+
+ if (folder_name != NULL && strlen (folder_name) > 0) {
+ ModestMailOperation *mail_op;
+
+ mail_op = modest_mail_operation_new ();
+ modest_mail_operation_rename_folder (mail_op,
+ folder,
+ (const gchar *) folder_name);
+ g_object_unref (mail_op);
+ }
+ g_object_unref (folder);
+ }
+ g_object_unref (G_OBJECT (widget_factory));
+}
+
+static void
+delete_folder (ModestMainWindow *main_window,
+ gboolean move_to_trash)
+{
+ TnyFolder *folder;
+ ModestFolderView *folder_view;
+ ModestWidgetFactory *widget_factory;
+ ModestMailOperation *mail_op;
+
+ widget_factory = modest_window_get_widget_factory (MODEST_WINDOW (main_window));
+ folder_view = modest_widget_factory_get_folder_view (widget_factory);
+ folder = modest_folder_view_get_selected (folder_view);
+
+ mail_op = modest_mail_operation_new ();
+ modest_mail_operation_remove_folder (mail_op, folder, move_to_trash);
+ g_object_unref (mail_op);
}
void
_modest_ui_actions_on_delete_folder (GtkWidget *widget,
ModestMainWindow *main_window)
{
- g_print ("Delete Folder");
+ delete_folder (main_window, FALSE);
+}
+
+void
+_modest_ui_actions_on_move_to_trash_folder (GtkWidget *widget,
+ ModestMainWindow *main_window)
+{
+ delete_folder (main_window, TRUE);
}