mirror of https://github.com/djcb/mu.git
* mu-msg-list: make unread mailheaders bold, important ones read. Fix
mu-msg-iter.cc while doing so.
This commit is contained in:
parent
9902137ddf
commit
df57723ec7
|
@ -33,12 +33,15 @@ enum {
|
|||
LAST_SIGNAL
|
||||
};
|
||||
|
||||
|
||||
enum {
|
||||
MUG_COL_DATE,
|
||||
MUG_COL_FROM,
|
||||
MUG_COL_TO,
|
||||
MUG_COL_SUBJECT,
|
||||
MUG_COL_PATH,
|
||||
MUG_COL_PRIO,
|
||||
MUG_COL_FLAGS,
|
||||
|
||||
MUG_N_COLS
|
||||
};
|
||||
|
@ -127,6 +130,28 @@ on_cursor_changed (GtkTreeView *tview, MugMsgListView *lst)
|
|||
}
|
||||
}
|
||||
|
||||
|
||||
static void
|
||||
treecell_func (GtkTreeViewColumn *tree_column, GtkCellRenderer *renderer,
|
||||
GtkTreeModel *tree_model, GtkTreeIter *iter, gpointer data)
|
||||
{
|
||||
MuMsgFlags flags;
|
||||
MuMsgPrio prio;
|
||||
|
||||
gtk_tree_model_get (tree_model, iter,
|
||||
MUG_COL_FLAGS, &flags,
|
||||
MUG_COL_PRIO, &prio,
|
||||
-1);
|
||||
|
||||
g_object_set (G_OBJECT(renderer),
|
||||
"weight", (flags & MU_MSG_FLAG_NEW) ? 800 : 400,
|
||||
"weight", (flags & MU_MSG_FLAG_UNREAD) ? 800 : 400,
|
||||
"weight", (flags & MU_MSG_FLAG_SEEN) ? 400 : 800,
|
||||
"foreground", prio == MU_MSG_PRIO_HIGH ? "red" : NULL,
|
||||
NULL);
|
||||
}
|
||||
|
||||
|
||||
static GtkTreeViewColumn *
|
||||
get_col (const char* label, int colidx, gint maxwidth)
|
||||
{
|
||||
|
@ -151,12 +176,13 @@ get_col (const char* label, int colidx, gint maxwidth)
|
|||
gtk_tree_view_column_set_sizing (col, GTK_TREE_VIEW_COLUMN_GROW_ONLY);
|
||||
gtk_tree_view_column_set_expand (col, TRUE);
|
||||
}
|
||||
|
||||
gtk_tree_view_column_set_cell_data_func
|
||||
(col, renderer, (GtkTreeCellDataFunc) treecell_func, NULL, NULL);
|
||||
|
||||
return col;
|
||||
}
|
||||
|
||||
|
||||
|
||||
static void
|
||||
mug_msg_list_view_init (MugMsgListView *obj)
|
||||
{
|
||||
|
@ -172,7 +198,9 @@ mug_msg_list_view_init (MugMsgListView *obj)
|
|||
G_TYPE_STRING,
|
||||
G_TYPE_STRING,
|
||||
G_TYPE_STRING,
|
||||
G_TYPE_STRING);
|
||||
G_TYPE_STRING,
|
||||
G_TYPE_UINT,
|
||||
G_TYPE_UINT);
|
||||
|
||||
gtk_tree_view_set_model (GTK_TREE_VIEW (obj),
|
||||
GTK_TREE_MODEL(priv->_store));
|
||||
|
@ -310,13 +338,13 @@ update_model (GtkListStore *store, const char *xpath, const char *query)
|
|||
|
||||
GtkTreeIter treeiter;
|
||||
const gchar *date, *from, *subject, *path, *to;
|
||||
|
||||
|
||||
date = mu_msg_str_date_s ("%x",
|
||||
mu_msg_iter_get_date (iter));
|
||||
from = mu_msg_iter_get_from(iter);
|
||||
to = mu_msg_iter_get_to (iter);
|
||||
subject = mu_msg_iter_get_subject (iter);
|
||||
path = mu_msg_iter_get_path (iter);
|
||||
path = mu_msg_iter_get_path (iter);
|
||||
|
||||
gtk_list_store_append (store, &treeiter);
|
||||
gtk_list_store_set (store, &treeiter,
|
||||
|
@ -325,6 +353,8 @@ update_model (GtkListStore *store, const char *xpath, const char *query)
|
|||
MUG_COL_TO, to,
|
||||
MUG_COL_SUBJECT, subject,
|
||||
MUG_COL_PATH, path,
|
||||
MUG_COL_PRIO, mu_msg_iter_get_prio(iter),
|
||||
MUG_COL_FLAGS, mu_msg_iter_get_flags(iter),
|
||||
-1);
|
||||
}
|
||||
mu_query_destroy (xapian);
|
||||
|
|
|
@ -43,7 +43,7 @@ enum _MuMsgFlags {
|
|||
MU_MSG_FLAG_ENCRYPTED = 1 << 11,
|
||||
MU_MSG_FLAG_HAS_ATTACH = 1 << 12
|
||||
|
||||
/* any new fields go here */
|
||||
/* any new fields go here */
|
||||
/* so the existing numbers stay valid note that we're also */
|
||||
/* using these numbers in the database, so they should not change */
|
||||
};
|
||||
|
|
|
@ -311,14 +311,23 @@ mu_msg_iter_get_date (MuMsgIter *iter)
|
|||
MuMsgFlags
|
||||
mu_msg_iter_get_flags (MuMsgIter *iter)
|
||||
{
|
||||
static const MuMsgField *flags_field =
|
||||
mu_msg_field_from_id (MU_MSG_FIELD_ID_FLAGS);
|
||||
|
||||
g_return_val_if_fail (!mu_msg_iter_is_done(iter), MU_MSG_FLAG_NONE);
|
||||
return static_cast<MuMsgFlags>
|
||||
(get_field_number (iter, MU_MSG_FIELD_ID_FLAGS));
|
||||
|
||||
return static_cast<MuMsgFlags>(mu_msg_iter_get_field_numeric
|
||||
(iter, flags_field));
|
||||
}
|
||||
|
||||
MuMsgPrio
|
||||
mu_msg_iter_get_prio (MuMsgIter *iter)
|
||||
{
|
||||
static const MuMsgField *prio_field =
|
||||
mu_msg_field_from_id (MU_MSG_FIELD_ID_PRIO);
|
||||
|
||||
g_return_val_if_fail (!mu_msg_iter_is_done(iter), MU_MSG_PRIO_NONE);
|
||||
return static_cast<MuMsgPrio>(get_field_number (iter, MU_MSG_FIELD_ID_PRIO));
|
||||
|
||||
return static_cast<MuMsgPrio>(mu_msg_iter_get_field_numeric
|
||||
(iter, prio_field));
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue