[rhythmbox/gobject-introspection: 40/41] allow user css to override the search entry active colors
- From: Jonathan Matthew <jmatthew src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [rhythmbox/gobject-introspection: 40/41] allow user css to override the search entry active colors
- Date: Sun, 12 Dec 2010 10:01:30 +0000 (UTC)
commit 3215c835aeb64357a1091d99236161ed9c5d589d
Author: Jonathan Matthew <jonathan d14n org>
Date: Sun Dec 12 19:11:25 2010 +1000
allow user css to override the search entry active colors
widgets/rb-search-entry.c | 24 +++++++++++++++++++-----
1 files changed, 19 insertions(+), 5 deletions(-)
---
diff --git a/widgets/rb-search-entry.c b/widgets/rb-search-entry.c
index a56150a..3aa4646 100644
--- a/widgets/rb-search-entry.c
+++ b/widgets/rb-search-entry.c
@@ -265,18 +265,32 @@ rb_search_entry_set_text (RBSearchEntry *entry, const char *text)
static void
rb_search_entry_check_style (RBSearchEntry *entry)
{
- static const GdkRGBA bg_colour = { 0.9686, 0.9686, 0.7451, 1.0}; /* yellow-ish */
- static const GdkRGBA fg_colour = { 0, 0, 0, 1.0 }; /* black. */
+ static const GdkRGBA fallback_bg_color = { 0.9686, 0.9686, 0.7451, 1.0}; /* yellow-ish */
+ static const GdkRGBA fallback_fg_color = { 0, 0, 0, 1.0 }; /* black. */
+ GdkRGBA bg_color = {0,};
+ GdkRGBA fg_color = {0,};
const gchar* text;
if (entry->priv->is_a11y_theme)
return;
+ /* allow user style to override the colors */
+ if (gtk_style_context_lookup_color (gtk_widget_get_style_context (GTK_WIDGET (entry)),
+ "rb-search-active-bg",
+ &bg_color) == FALSE) {
+ bg_color = fallback_bg_color;
+ }
+ if (gtk_style_context_lookup_color (gtk_widget_get_style_context (GTK_WIDGET (entry)),
+ "rb-search-active-fg",
+ &fg_color) == FALSE) {
+ fg_color = fallback_fg_color;
+ }
+
text = gtk_entry_get_text (GTK_ENTRY (entry->priv->entry));
if (text && *text) {
- gtk_widget_override_color (entry->priv->entry, GTK_STATE_NORMAL, &fg_colour);
- gtk_widget_override_background_color (entry->priv->entry, GTK_STATE_NORMAL, &bg_colour);
- gtk_widget_override_cursor (entry->priv->entry, &fg_colour, &fg_colour);
+ gtk_widget_override_color (entry->priv->entry, GTK_STATE_NORMAL, &fg_color);
+ gtk_widget_override_background_color (entry->priv->entry, GTK_STATE_NORMAL, &bg_color);
+ gtk_widget_override_cursor (entry->priv->entry, &fg_color, &fg_color);
} else {
gtk_widget_override_color (entry->priv->entry, GTK_STATE_NORMAL, NULL);
gtk_widget_override_background_color (entry->priv->entry, GTK_STATE_NORMAL, NULL);
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]