+static void
+icon_cell_data (GtkTreeViewColumn *column, GtkCellRenderer *renderer,
+ GtkTreeModel *tree_model, GtkTreeIter *iter, gpointer data)
+{
+ GObject *rendobj;
+ GdkPixbuf *pixbuf;
+ TnyMsgFolderType type;
+ gchar *fname;
+ int unread;
+
+ rendobj = G_OBJECT(renderer);
+ gtk_tree_model_get (tree_model, iter,
+ TNY_ACCOUNT_TREE_MODEL_TYPE_COLUMN, &type,
+ TNY_ACCOUNT_TREE_MODEL_NAME_COLUMN, &fname,
+ TNY_ACCOUNT_TREE_MODEL_UNREAD_COLUMN, &unread, -1);
+ rendobj = G_OBJECT(renderer);
+
+ if (type == TNY_MSG_FOLDER_TYPE_NORMAL)
+ type = guess_folder_type (fname);
+
+ g_free (fname);
+
+ switch (type) {
+ case TNY_MSG_FOLDER_TYPE_INBOX:
+ pixbuf = modest_icon_factory_get_icon (MODEST_FOLDER_ICON_INBOX);
+ break;
+ case TNY_MSG_FOLDER_TYPE_OUTBOX:
+ pixbuf = modest_icon_factory_get_icon (MODEST_FOLDER_ICON_OUTBOX);
+ break;
+ case TNY_MSG_FOLDER_TYPE_JUNK:
+ pixbuf = modest_icon_factory_get_icon (MODEST_FOLDER_ICON_JUNK);
+ break;
+ case TNY_MSG_FOLDER_TYPE_SENT:
+ pixbuf = modest_icon_factory_get_icon (MODEST_FOLDER_ICON_SENT);
+ break;
+ case TNY_MSG_FOLDER_TYPE_DRAFTS:
+ pixbuf = modest_icon_factory_get_icon (MODEST_FOLDER_ICON_DRAFTS);
+ break;
+ case TNY_MSG_FOLDER_TYPE_NOTES:
+ pixbuf = modest_icon_factory_get_icon (MODEST_FOLDER_ICON_NOTES);
+ break;
+ case TNY_MSG_FOLDER_TYPE_CALENDAR:
+ pixbuf = modest_icon_factory_get_icon (MODEST_FOLDER_ICON_CALENDAR);
+ break;
+ case TNY_MSG_FOLDER_TYPE_CONTACTS:
+ pixbuf = modest_icon_factory_get_icon (MODEST_FOLDER_ICON_CONTACTS);
+ break;
+
+ case TNY_MSG_FOLDER_TYPE_NORMAL:
+ default:
+ pixbuf = modest_icon_factory_get_icon (MODEST_FOLDER_ICON_NORMAL);
+ break;
+ }
+
+ g_object_set (rendobj,
+ "pixbuf-expander-open",
+ modest_icon_factory_get_icon (MODEST_FOLDER_ICON_OPEN),
+ "pixbuf-expander-closed",
+ modest_icon_factory_get_icon (MODEST_FOLDER_ICON_CLOSED),
+ "pixbuf", pixbuf,
+ NULL);
+}