#include "modest-platform.h"
#include <modest-hbox-cell-renderer.h>
#include <modest-vbox-cell-renderer.h>
+#include <modest-datetime-formatter.h>
static void modest_header_view_class_init (ModestHeaderViewClass *klass);
static void modest_header_view_init (ModestHeaderView *obj);
static GtkTreePath * get_selected_row (GtkTreeView *self, GtkTreeModel **model);
+#ifndef MODEST_TOOLKIT_HILDON2
static gboolean on_focus_in (GtkWidget *sef,
GdkEventFocus *event,
gpointer user_data);
static gboolean on_focus_out (GtkWidget *self,
GdkEventFocus *event,
gpointer user_data);
+#endif
static void folder_monitor_update (TnyFolderObserver *self,
TnyFolderChange *change);
HeaderViewStatus status;
guint status_timeout;
gboolean notify_status; /* whether or not the filter_row should notify about changes in the filtering */
+
+ ModestDatetimeFormatter *datetime_formatter;
};
typedef struct _HeadersCountChangedHelper HeadersCountChangedHelper;
G_SIGNAL_RUN_FIRST,
G_STRUCT_OFFSET (ModestHeaderViewClass,header_activated),
NULL, NULL,
- g_cclosure_marshal_VOID__POINTER,
- G_TYPE_NONE, 1, G_TYPE_POINTER);
+ gtk_marshal_VOID__POINTER_POINTER,
+ G_TYPE_NONE, 2, G_TYPE_POINTER, G_TYPE_POINTER);
signals[ITEM_NOT_FOUND_SIGNAL] =
NULL, NULL,
g_cclosure_marshal_VOID__BOOLEAN,
G_TYPE_NONE, 1, G_TYPE_BOOLEAN);
+
+#ifdef MODEST_TOOLKIT_HILDON2
+ gtk_rc_parse_string ("class \"ModestHeaderView\" style \"fremantle-touchlist\"");
+
+#endif
}
static void
g_object_set_data (G_OBJECT (renderer_recpt_box), "date-renderer", renderer_compact_date_or_status);
g_object_set (G_OBJECT (renderer_subject_box), "yalign", 1.0, NULL);
-#ifdef MODEST_PLATFORM_MAEMO
+#ifndef MODEST_TOOLKIT_GTK
gtk_cell_renderer_set_fixed_size (renderer_subject_box, -1, 32);
gtk_cell_renderer_set_fixed_size (renderer_recpt_box, -1, 32);
#endif
g_object_set (G_OBJECT (renderer_attach),
"yalign", 0.0, NULL);
-#ifdef MODEST_PLATFORM_MAEMO
+#ifndef MODEST_TOOLKIT_GTK
gtk_cell_renderer_set_fixed_size (renderer_attach, 32, 26);
gtk_cell_renderer_set_fixed_size (renderer_priority, 32, 26);
gtk_cell_renderer_set_fixed_size (renderer_compact_header, -1, 64);
}
static void
+datetime_format_changed (ModestDatetimeFormatter *formatter,
+ ModestHeaderView *self)
+{
+ gtk_widget_queue_draw (GTK_WIDGET (self));
+}
+
+static void
modest_header_view_init (ModestHeaderView *obj)
{
ModestHeaderViewPrivate *priv;
}
}
+ priv->datetime_formatter = modest_datetime_formatter_new ();
+ g_signal_connect (G_OBJECT (priv->datetime_formatter), "format-changed",
+ G_CALLBACK (datetime_format_changed), (gpointer) obj);
+
setup_drag_and_drop (GTK_WIDGET(obj));
}
self = MODEST_HEADER_VIEW(obj);
priv = MODEST_HEADER_VIEW_GET_PRIVATE(self);
+ if (priv->datetime_formatter) {
+ g_object_unref (priv->datetime_formatter);
+ priv->datetime_formatter = NULL;
+ }
+
/* Free in the dispose to avoid unref cycles */
if (priv->folder) {
tny_folder_remove_observer (priv->folder, TNY_FOLDER_OBSERVER (obj));
g_signal_connect (self, "row-activated",
G_CALLBACK (on_header_row_activated), NULL);
+#ifndef MODEST_TOOLKIT_HILDON2
g_signal_connect (self, "focus-in-event",
G_CALLBACK(on_focus_in), NULL);
g_signal_connect (self, "focus-out-event",
G_CALLBACK(on_focus_out), NULL);
+#endif
g_signal_connect (self, "button-press-event",
G_CALLBACK(on_button_press_event), NULL);
static void
scroll_to_selected (ModestHeaderView *self, GtkTreeIter *iter, gboolean up)
{
-#ifdef MODEST_PLATFORM_GNOME
+#ifdef MODEST_TOOLKIT_GTK
GtkTreePath *selected_path;
GtkTreePath *start, *end;
gtk_tree_path_free (start);
gtk_tree_path_free (end);
-#endif /* MODEST_PLATFORM_GNOME */
+#endif /* MODEST_TOOLKIT_GTK */
}
if (!model)
return FALSE;
+#ifdef MODEST_TOOLKIT_HILDON2
+ return FALSE;
+#endif
sel = gtk_tree_view_get_selection(header_view);
if(!gtk_tree_selection_count_selected_rows(sel)) {
if (gtk_tree_model_get_iter_first(model, &tree_iter)) {
modest_header_view_set_folder (ModestHeaderView *self,
TnyFolder *folder,
gboolean refresh,
+ ModestWindow *progress_window,
RefreshAsyncUserCallback callback,
gpointer user_data)
{
ModestHeaderViewPrivate *priv;
- ModestWindow *main_win;
g_return_if_fail (self);
priv = MODEST_HEADER_VIEW_GET_PRIVATE(self);
- main_win = modest_window_mgr_get_main_window (modest_runtime_get_window_mgr (),
- FALSE); /* don't create */
- if (!main_win) {
- g_warning ("%s: BUG: no main window", __FUNCTION__);
- return;
- }
-
if (priv->folder) {
if (priv->status_timeout) {
g_source_remove (priv->status_timeout);
info->user_data = user_data;
/* Create the mail operation (source will be the parent widget) */
- mail_op = modest_mail_operation_new_with_error_handling (G_OBJECT(main_win),
- refresh_folder_error_handler,
- NULL, NULL);
+ if (progress_window)
+ mail_op = modest_mail_operation_new_with_error_handling (G_OBJECT(progress_window),
+ refresh_folder_error_handler,
+ NULL, NULL);
if (refresh) {
modest_mail_operation_queue_add (modest_runtime_get_mail_operation_queue (),
mail_op);
/* Emit signal */
g_signal_emit (G_OBJECT(self),
signals[HEADER_ACTIVATED_SIGNAL],
- 0, header);
+ 0, header, path);
/* Free */
frees:
static void
enable_drag_and_drop (GtkWidget *self)
{
+#ifdef MODEST_TOOLKIT_HILDON2
+ return;
+#endif
gtk_drag_source_set (self, GDK_BUTTON1_MASK,
header_view_drag_types,
G_N_ELEMENTS (header_view_drag_types),
static void
disable_drag_and_drop (GtkWidget *self)
{
+#ifdef MODEST_TOOLKIT_HILDON2
+ return;
+#endif
gtk_drag_source_unset (self);
}
static void
setup_drag_and_drop (GtkWidget *self)
{
+#ifdef MODEST_TOOLKIT_HILDON2
+ return;
+#endif
enable_drag_and_drop(self);
g_signal_connect(G_OBJECT (self), "drag_data_get",
G_CALLBACK(drag_data_get_cb), NULL);
return path;
}
+#ifndef MODEST_TOOLKIT_HILDON2
/*
* This function moves the tree view scroll to the current selected
* row when the widget grabs the focus
}
return FALSE;
}
+#endif
static gboolean
on_button_release_event(GtkWidget * self, GdkEventButton * event, gpointer userdata)
{
g_return_if_fail (self && MODEST_IS_HEADER_VIEW(self));
- modest_header_view_set_folder (self, NULL, FALSE, NULL, NULL);
+ modest_header_view_set_folder (self, NULL, FALSE, NULL, NULL, NULL);
}
void
g_mutex_unlock(priv->observer_list_lock);
}
+const gchar *
+_modest_header_view_get_display_date (ModestHeaderView *self, time_t date)
+{
+ ModestHeaderViewPrivate *priv = NULL;
+
+ priv = MODEST_HEADER_VIEW_GET_PRIVATE(self);
+ return modest_datetime_formatter_display_datetime (priv->datetime_formatter, date);
+}