GdkEventExpose *event,
gpointer user_data);
+static void on_notify_style (GObject *obj, GParamSpec *spec, gpointer userdata);
+static void update_style (ModestHeaderView *self);
+
typedef enum {
HEADER_VIEW_NON_EMPTY,
HEADER_VIEW_EMPTY,
struct _ModestHeaderViewPrivate {
TnyFolder *folder;
ModestHeaderViewStyle style;
+ gboolean is_outbox;
TnyFolderMonitor *monitor;
GMutex *observers_lock;
gchar **hidding_ids;
guint n_selected;
GtkTreeRowReference *autoselect_reference;
+ ModestHeaderViewFilter filter;
gint sort_colid[2][TNY_FOLDER_TYPE_NUM];
gint sort_type[2][TNY_FOLDER_TYPE_NUM];
gboolean notify_status; /* whether or not the filter_row should notify about changes in the filtering */
ModestDatetimeFormatter *datetime_formatter;
+
+ GtkCellRenderer *renderer_address;
+ GtkCellRenderer *renderer_date_status;
};
typedef struct _HeadersCountChangedHelper HeadersCountChangedHelper;
priv = MODEST_HEADER_VIEW_GET_PRIVATE(self);
+ priv->is_outbox = (type == TNY_FOLDER_TYPE_OUTBOX);
+
/* TODO: check whether these renderers need to be freed */
renderer_attach = gtk_cell_renderer_pixbuf_new ();
renderer_priority = gtk_cell_renderer_pixbuf_new ();
renderer_recpt_box = modest_hbox_cell_renderer_new ();
renderer_subject_box = modest_hbox_cell_renderer_new ();
renderer_recpt = gtk_cell_renderer_text_new ();
+ priv->renderer_address = renderer_recpt;
renderer_subject = gtk_cell_renderer_text_new ();
renderer_compact_date_or_status = gtk_cell_renderer_text_new ();
+ priv->renderer_date_status = renderer_compact_date_or_status;
modest_vbox_cell_renderer_append (MODEST_VBOX_CELL_RENDERER (renderer_compact_header), renderer_subject_box, FALSE);
g_object_set_data (G_OBJECT (renderer_compact_header), "subject-box-renderer", renderer_subject_box);
compact_column, NULL);
}
+ update_style (self);
+ g_signal_connect (G_OBJECT (self), "notify::style", G_CALLBACK (on_notify_style), (gpointer) self);
+
return TRUE;
}
priv = MODEST_HEADER_VIEW_GET_PRIVATE(obj);
priv->folder = NULL;
+ priv->is_outbox = FALSE;
priv->monitor = NULL;
priv->observers_lock = g_mutex_new ();
priv->clipboard = modest_runtime_get_email_clipboard ();
priv->hidding_ids = NULL;
priv->n_selected = 0;
+ priv->filter = MODEST_HEADER_VIEW_FILTER_NONE;
priv->selection_changed_handler = 0;
priv->acc_removed_handler = 0;
goto frees;
}
+ if (visible && (priv->filter & MODEST_HEADER_VIEW_FILTER_DELETABLE)) {
+ if (priv->is_outbox &&
+ modest_tny_all_send_queues_get_msg_status (header) == MODEST_TNY_SEND_QUEUE_SENDING) {
+ visible = FALSE;
+ goto frees;
+ }
+ }
+
+ if (visible && (priv->filter & MODEST_HEADER_VIEW_FILTER_MOVEABLE)) {
+ if (priv->is_outbox &&
+ modest_tny_all_send_queues_get_msg_status (header) == MODEST_TNY_SEND_QUEUE_SENDING) {
+ visible = FALSE;
+ goto frees;
+ }
+ }
+
/* If no data on clipboard, return always TRUE */
if (modest_email_clipboard_cleared(priv->clipboard)) {
visible = TRUE;
priv = MODEST_HEADER_VIEW_GET_PRIVATE(self);
return modest_datetime_formatter_display_datetime (priv->datetime_formatter, date);
}
+
+void
+modest_header_view_set_filter (ModestHeaderView *self,
+ ModestHeaderViewFilter filter)
+{
+ ModestHeaderViewPrivate *priv;
+ GtkTreeModel *filter_model;
+
+ g_return_if_fail (MODEST_IS_HEADER_VIEW (self));
+ priv = MODEST_HEADER_VIEW_GET_PRIVATE (self);
+
+ priv->filter |= filter;
+
+ filter_model = gtk_tree_view_get_model (GTK_TREE_VIEW (self));
+ if (GTK_IS_TREE_MODEL_FILTER(filter_model)) {
+ gtk_tree_model_filter_refilter (GTK_TREE_MODEL_FILTER (filter_model));
+ }
+}
+
+void
+modest_header_view_unset_filter (ModestHeaderView *self,
+ ModestHeaderViewFilter filter)
+{
+ ModestHeaderViewPrivate *priv;
+ GtkTreeModel *filter_model;
+
+ g_return_if_fail (MODEST_IS_HEADER_VIEW (self));
+ priv = MODEST_HEADER_VIEW_GET_PRIVATE (self);
+
+ priv->filter &= ~filter;
+
+ filter_model = gtk_tree_view_get_model (GTK_TREE_VIEW (self));
+ if (GTK_IS_TREE_MODEL_FILTER(filter_model)) {
+ gtk_tree_model_filter_refilter (GTK_TREE_MODEL_FILTER (filter_model));
+ }
+}
+
+static void
+on_notify_style (GObject *obj, GParamSpec *spec, gpointer userdata)
+{
+ if (strcmp ("style", spec->name) == 0) {
+ update_style (MODEST_HEADER_VIEW (obj));
+ gtk_widget_queue_draw (GTK_WIDGET (obj));
+ }
+}
+
+static void
+update_style (ModestHeaderView *self)
+{
+ ModestHeaderViewPrivate *priv;
+ GdkColor style_color;
+ PangoAttrList *attr_list;
+ GtkStyle *style;
+ PangoAttribute *attr;
+
+ g_return_if_fail (MODEST_IS_HEADER_VIEW (self));
+ priv = MODEST_HEADER_VIEW_GET_PRIVATE (self);
+
+ /* Set color */
+
+ attr_list = pango_attr_list_new ();
+ if (!gtk_style_lookup_color (GTK_WIDGET (self)->style, "SecondaryTextColor", &style_color)) {
+ gdk_color_parse ("grey", &style_color);
+ }
+ attr = pango_attr_foreground_new (style_color.red, style_color.green, style_color.blue);
+ pango_attr_list_insert (attr_list, attr);
+
+ /* set font */
+ style = gtk_rc_get_style_by_paths (gtk_widget_get_settings
+ (GTK_WIDGET(self)),
+ "SmallSystemFont", NULL,
+ G_TYPE_NONE);
+ if (style) {
+ attr = pango_attr_font_desc_new (pango_font_description_copy
+ (style->font_desc));
+ pango_attr_list_insert (attr_list, attr);
+
+ g_object_set (G_OBJECT (priv->renderer_address),
+ "foreground-gdk", &style_color,
+ "foreground-set", TRUE,
+ "attributes", attr_list,
+ NULL);
+ g_object_set (G_OBJECT (priv->renderer_date_status),
+ "foreground-gdk", &style_color,
+ "foreground-set", TRUE,
+ "attributes", attr_list,
+ NULL);
+ pango_attr_list_unref (attr_list);
+ }
+}
+