diff options
-rw-r--r-- | widgets/ChangeLog | 6 | ||||
-rw-r--r-- | widgets/misc/e-source-selector.c | 58 |
2 files changed, 50 insertions, 14 deletions
diff --git a/widgets/ChangeLog b/widgets/ChangeLog index e1674cc07f..47f811c116 100644 --- a/widgets/ChangeLog +++ b/widgets/ChangeLog @@ -1,3 +1,9 @@ +2004-06-11 Larry Ewing <lewing@ximian.com> + + * misc/e-source-selector.c: make the source selector use a colock + block instead of setting the foreground to indicate the source + color. + 2004-05-20 Rodney Dawes <dobey@ximian.com> * e-timezone-dialog/e-timezone-dialog.c (e_timezone_dialog_construct): diff --git a/widgets/misc/e-source-selector.c b/widgets/misc/e-source-selector.c index f26ce4030b..8983af5585 100644 --- a/widgets/misc/e-source-selector.c +++ b/widgets/misc/e-source-selector.c @@ -378,28 +378,55 @@ text_cell_data_func (GtkTreeViewColumn *column, ESource *source; guint32 color; gboolean has_color; - + g_assert (E_IS_SOURCE (data)); source = E_SOURCE (data); - + g_object_set (renderer, "text", e_source_peek_name (source), "weight", PANGO_WEIGHT_NORMAL, + "foreground_set", FALSE, NULL); + } - has_color = e_source_get_color (source, &color); - if (!has_color) { - g_object_set (renderer, - "foreground_set", FALSE, - NULL); - } else { - char *color_string = g_strdup_printf ("#%06x", color); - g_object_set (renderer, - "foreground_set", TRUE, - "foreground", color_string, - NULL); - g_free (color_string); + g_object_unref (data); +} + +static void +pixbuf_cell_data_func (GtkTreeViewColumn *column, + GtkCellRenderer *renderer, + GtkTreeModel *model, + GtkTreeIter *iter, + ESourceSelector *selector) +{ + void *data; + + gtk_tree_model_get (model, iter, 0, &data, -1); + + if (E_IS_SOURCE_GROUP (data)) { + g_object_set (renderer, + "pixbuf", NULL, + NULL); + } else { + ESource *source; + guint32 color; + gboolean has_color; + GdkPixbuf *pixbuf; + + g_assert (E_IS_SOURCE (data)); + source = E_SOURCE (data); + + if (e_source_get_color (source, &color)) { + pixbuf = gdk_pixbuf_new (GDK_COLORSPACE_RGB, FALSE, 8, 16, 16); + gdk_pixbuf_fill (pixbuf, color << 8); } + + g_object_set (renderer, + "pixbuf", pixbuf, + NULL); + + if (pixbuf) + g_object_unref (pixbuf); } g_object_unref (data); @@ -710,6 +737,9 @@ init (ESourceSelector *selector) column = gtk_tree_view_column_new (); gtk_tree_view_append_column (GTK_TREE_VIEW (selector), column); + cell_renderer = gtk_cell_renderer_pixbuf_new (); + gtk_tree_view_column_pack_start (column, cell_renderer, FALSE); + gtk_tree_view_column_set_cell_data_func (column, cell_renderer, (GtkTreeCellDataFunc) pixbuf_cell_data_func, selector, NULL); cell_renderer = gtk_cell_renderer_toggle_new (); gtk_tree_view_column_pack_start (column, cell_renderer, FALSE); gtk_tree_view_column_set_cell_data_func (column, cell_renderer, (GtkTreeCellDataFunc) toggle_cell_data_func, selector, NULL); |