
# Please keep this gtkrc in sync with the other ones from Clearlooks based themes.

gtk-color-scheme = "base_color:#ffffff\nbg_color:#ededed\ntooltip_bg_color:#343434\nselected_bg_color:#4a90d9\ntext_color:#2e3436\nfg_color:#2e3436\ntooltip_fg_color:#ffffff\nselected_fg_color:#ffffff\nlink_color:#4a90d9\nframe_color:#8a9580\ninactive_frame_color:#c7ccc1\nwarning_color:#f57900\nerror_color:#cc0000\nsuccess_color:#4e9a06"

gtk-auto-mnemonics = 1
gtk-cursor-blink = 0
gtk-button-images = 0
gtk-menu-images = 0

style "default" {

        font_name = "Droid Sans" # Until we get the font upstream
        xthickness = 1
        ythickness = 1

        #######################
        # Style Properties
        #######################
        GtkButton::child-displacement-x = 1
        GtkButton::child-displacement-y = 1
        GtkButton::default-border = { 0, 0, 0, 0 }
        GtkButton::image-spacing = 4
        GtkToolButton::icon-spacing = 4

        GtkCheckButton::indicator-size = 14

        GtkTextView::error-underline-color = "#cc0000"

        GtkPaned::handle-size = 6

        # The size for scrollbars. The slider is 2px smaller, but we keep it
        # up so that the whole area is sensitive to button presses for the
        # slider. The stepper button is larger in both directions, the slider
        # only in the width
        GtkRange::stepper-position-details = 1
        GtkRange::trough-border = 0
        GtkRange::slider-width = 20
        GtkRange::stepper-size = 20

        GtkScale::slider-length = 15
        GtkScale::slider-width = 21
        GtkScale::trough-side-details = 1

        GtkScrollbar::min-slider-length = 30
        GtkMenuBar::internal-padding = 0
        GtkExpander::expander-size = 16         # ???
        GtkToolbar::internal-padding = 4        # ???
        GtkTreeView::expander-size = 14         # ???
        GtkTreeView::vertical-separator = 0     # ???

        GtkScrolledWindow::scrollbar-spacing = 0
        GtkScrolledWindow::scrollbars-within-bevel = 1



        GtkMenu::horizontal-padding = 0
        GtkMenu::vertical-padding = 0

        GtkWidget::link-color = @link_color
        GtkWidget::visited-link-color = @link_color
        GtkIMHtml::hyperlink-color = @link_color
        GtkHTML::link-color = @link_color

        WnckTasklist::fade-overlay-rect = 0
        # The following line hints to gecko (and possibly other appliations)
        # that the entry should be drawn transparently on the canvas.
        # Without this, gecko will fill in the background of the entry.
        GtkEntry::honors-transparent-bg-hint = 1

        NautilusIconContainer::selection_box_color = @selected_bg_color
        NautilusIconContainer::dark_info_color = shade (0.6, @selected_bg_color)
        NautilusIconContainer::light_info_color = shade (0.6, @selected_fg_color)
        NautilusIconContainer::prelight_icon_color = "#ffffff"
        NautilusIconContainer::prelight_icon_brightness = 255
        NautilusIconContainer::selection_box_alpha = 0x40
        NautilusIconContainer::selection_highlight_alpha = 0x00

        GtkEntry::inner-border = { 3, 3, 3, 3 }
        GtkEntry::progress-border = { 0, 0, 0, 0 }

        GtkNotebook::tab-overlay = 10
        GtkNotebook::tab-curvature = 5

        GtkSeparatorToolItem::shadow-type = GTK_SHADOW_NONE

        ####################
        # Color Definitions
        ####################
        bg[NORMAL]        = @bg_color
        bg[PRELIGHT]      = shade (1.02, @bg_color)
        bg[SELECTED]      = @selected_bg_color
        bg[INSENSITIVE]   = shade (1.07, @bg_color)
        bg[ACTIVE]        = shade (0.915, @bg_color)

        fg[NORMAL]        = @fg_color
        fg[PRELIGHT]      = @fg_color
        fg[SELECTED]      = @selected_fg_color
        fg[INSENSITIVE]   = darker (@bg_color)
        fg[ACTIVE]        = @fg_color

        text[NORMAL]      = @text_color
        text[PRELIGHT]    = @text_color
        text[SELECTED]    = @selected_fg_color
        text[INSENSITIVE] = shade (0.75, @bg_color)
        text[ACTIVE]      = shade (1.2, @selected_bg_color)

        base[NORMAL]      = @base_color
        base[PRELIGHT]    = shade (0.95, @bg_color)
        base[SELECTED]    = shade(1.07, @selected_bg_color)
        base[INSENSITIVE] = shade (1.07, @bg_color)
        base[ACTIVE]      = shade (0.9, @selected_bg_color)


        engine "clearlooks" {
                colorize_scrollbar = FALSE      # XXX, will we support this?
                animation = FALSE
                radius = 3.0
                style = GNOME3
                accel_label_shade = 0.5

                # Set a hint to disable backward compatibility fallbacks.
                hint = "use-hints"
        }
}

style "wide" {
        xthickness = 2
        ythickness = 2
}

style "wider" {
        xthickness = 3
        ythickness = 3
}

style "entry" {
        xthickness = 2
        ythickness = 2

        base[ACTIVE] = @base_color
        bg[SELECTED] = @selected_bg_color
        fg[SELECTED] = @selected_fg_color
}

style "spinbutton" {

        engine "clearlooks" {
                hint = "spinbutton"
        }
}

style "scale" {
        xthickness = 2
        ythickness = 2

        engine "clearlooks" {
                hint = "scale"
        }
}

style "vscale" {

        engine "clearlooks" {
                hint = "vscale"
        }
}

style "hscale" {

        engine "clearlooks" {
                hint = "hscale"
        }
}

style "scrollbar" {
        xthickness = 2
        ythickness = 2

        # Similar to buttons ...
        bg[NORMAL] = @base_color
        bg[SELECTED] = @base_color
        fg[SELECTED] = @selected_bg_color

        fg[NORMAL] = mix (0.6, @bg_color, @fg_color)
        fg[PRELIGHT] = @selected_bg_color
        bg[PRELIGHT] = @base_color

        fg [ACTIVE] = @selected_bg_color
        text [NORMAL] = "green"
        text [ACTIVE] = "green"
        text [PRELIGHT] = "green"
        text [SELECTED] = "green"

        engine "clearlooks" {
                hint = "scrollbar"
        }
}

style "hscrollbar" {

        engine "clearlooks" {
                hint = "hscrollbar"
        }
}

style "vscrollbar" {

        engine "clearlooks" {
                hint = "vscrollbar"
        }
}

style "notebook_bg" {
        bg[NORMAL]        = shade (1.12, @bg_color)
}

style "button" {
        xthickness = 3
        ythickness = 3

#       bg[NORMAL]        = shade (1.04, @bg_color)
#       bg[PRELIGHT]      = shade (1.06, @bg_color)
#       bg[ACTIVE]        = shade (0.85, @bg_color)

        engine "clearlooks" {
                focus_color =  mix (0.5 , @bg_color, @selected_bg_color)
		focus_fill_color = @selected_bg_color
		focus_fill_alpha = 0.05
        }

}

# The color is changed by the notebook_bg style, this style
# changes the x/ythickness
style "notebook" {
        xthickness = 3
        ythickness = 3
}

style "statusbar" {
        xthickness = 5
        ythickness = 5
        fg [NORMAL] = @fg_color
        fg [PRELIGHT] = @fg_color
        GtkStatusbar::shadow-type = GTK_SHADOW_NONE
        engine "clearlooks" {
                hint = "statusbar"
        }
}


style "statusbar-children" {
        xthickness = 50
        ythickness = 50
        GtkStatusbar::shadow-type = GTK_SHADOW_NONE
        engine "clearlooks" {
                hint = "statusbar"
        }
}
widget_class "<GtkStatusbar>*" style "statusbar-children"

style "comboboxentry" {

        engine "clearlooks" {
                # Note:
                # If you set the appears-as-list option on comboboxes in the theme,
                # then you should set this hint on the combobox instead.
                hint = "comboboxentry"
        }
}

style "menubar" {
        xthickness = 0
        bg [NORMAL] = "#E0E0DC"
        bg [ACTIVE] = "#c7ccc1" # second gradient color
	GtkWidget::window-dragging = 1
        engine "clearlooks" {
                hint = "menubar"
		vertical_gradient {
			stop 0.0 shade (0.94, @bg_color)
			stop 1.0 @bg_color
		}
        }
}

style "menu" {
        xthickness = 0
        ythickness = 4

        GtkMenu::vertical-offset = 0
        GtkMenu::horizontal-offset = -1

        bg[NORMAL]        = @base_color

        engine "clearlooks" {
                radius = 0.0
        }
}

style "menu_item" {
        xthickness = 5
        ythickness = 4
        GtkMenuItem::arrow-scaling = 0.4
        fg[PRELIGHT]      = @selected_fg_color
}

# This style is there to modify the separator menu items. The goals are:
# 1. Get a specific height.
# 2. The line should go to the edges (ie. no border at the left/right)
style "separator_menu_item" {
        xthickness = 1
        ythickness = 0

        GtkSeparatorMenuItem::horizontal-padding = 0
        GtkWidget::wide-separators = 1
        GtkWidget::separator-width = 1
        GtkWidget::separator-height = 7
}

style "separator_tool_item" {
        xthickness = 0
        ythickness = 1

        GtkVSeparator::vertical-padding = 0
        GtkWidget::wide-separators = 1
        GtkWidget::separator-width = 7
        GtkWidget::separator-height = 1
	bg[NORMAL] = shade (0.8, @bg_color)
}

style "frame_title" {

        fg[NORMAL]        = lighter (@fg_color)
}

style "treeview" {

        engine "clearlooks" {
                hint = "treeview"
        }
}

# The almost useless progress bar style
style "progressbar" {
        xthickness = 0
        ythickness = 0

        fg[PRELIGHT]      = @selected_fg_color

        engine "clearlooks" {
                # Explicitly set the radius for the progress bars inside menu items.
                radius = 3.0

                hint = "progressbar"
        }
}

# This style is based on the default style, so that the colors from the button
# style are overriden again.
style "treeview_header" = "default" {
        xthickness = 2
        ythickness = 1

        engine "clearlooks" {
                hint = "treeview-header"
        }
}

style "tooltips" {
        xthickness = 4
        ythickness = 4

        bg[NORMAL]        = @tooltip_bg_color
        fg[NORMAL]        = @tooltip_fg_color
}

style "toolbar" {
	engine "clearlooks" {
		vertical_gradient {
			stop 0.0 shade (0.6, @bg_color)
			stop 0.02 shade (0.6, @bg_color)
			stop 0.03 shade (0.7, @bg_color)
			stop 0.2 shade (0.75, @bg_color)
			stop 0.8 shade (0.8, @bg_color)
			stop 0.96 shade (0.95, @bg_color)
			stop 0.97 shade (0.8, @bg_color)
			stop 0.98 shade (1.2, @bg_color)
			stop 1.0 shade (1.2, @bg_color)
		}
	}
}

style "toolbarbutton" = "button" {
	bg[ACTIVE] = shade (0.7, @bg_color)
	engine "clearlooks" {
		vertical_gradient {
			stop 0.0 shade (0.75, @bg_color)
			stop 0.3 shade (0.9, @bg_color)
			stop 0.6 shade (0.9, @bg_color)
			stop 1.0 shade (0.85, @bg_color)
		}
		focus_color = shade (0.9, @bg_color)
	}
}

style "separator" = "wide" {
        GtkSeparator::shadow-type = GTK_SHADOW_NONE
}

style "nautilus_location" {

        bg[NORMAL]        = mix (0.60, shade (1.05, @bg_color), @selected_bg_color)
}

# Wrokaroudn style for places where the text color is used instead of the fg color.
style "text_is_fg_color_workaround" {

        text[NORMAL]      = @fg_color
        text[PRELIGHT]    = @fg_color
        text[SELECTED]    = @selected_fg_color
        text[ACTIVE]      = @fg_color
        text[INSENSITIVE] = darker (@bg_color)
}

# Workaround style for menus where the text color is used instead of the fg color.
style "menuitem_text_is_fg_color_workaround" {

        text[NORMAL]      = @fg_color
        text[PRELIGHT]    = @selected_fg_color
        text[SELECTED]    = @selected_fg_color
        text[ACTIVE]      = @fg_color
        text[INSENSITIVE] = darker (@bg_color)
}

# Workaround style for places where the fg color is used instead of the text color.
style "fg_is_text_color_workaround" {

        fg[NORMAL]        = @text_color
        fg[PRELIGHT]      = @text_color
        fg[SELECTED]      = @selected_fg_color
        fg[ACTIVE]        = @selected_fg_color
        fg[INSENSITIVE]   = darker (@bg_color)
}

# Style to set the toolbar to use a flat style. This is because the "New" button in
# Evolution is not drawn transparent. So if there is a gradient in the background it will
# look really wrong.
# See http://bugzilla.gnome.org/show_bug.cgi?id=446953.
style "evo_new_button_workaround" {

        engine "clearlooks" {
                toolbarstyle = 0
        }
}

style "eye-of-gnome" {
        bg[NORMAL]        = "#1e1a17"
        EogScrollView::shadow-type = GTK_SHADOW_NONE
}
widget_class "*.EogScrollView" style "eye-of-gnome"

style "evince" {
        bg[NORMAL]        = "#1e1a17"
}
widget_class "*.EvView" style "evince"

style "abiword" {
        bg[NORMAL]        = "#1e1a17"
}
widget_class "*.ApDocView" style "abiword"

style "cheese-thumbs" {
        bg[NORMAL]        = "#1e1a17"
}
widget_class "*<CheeseThumbView>*" style "cheese-thumbs"

style "terminal" {
        text[NORMAL] = "#ffffff"
        base[NORMAL] = "#1e1a17"
        TerminalScreen::background-darkness = 0.95
}
class "TerminalScreen" style "terminal"

style "infobar" {
        bg[NORMAL] = "#ffffff"
        TerminalScreen::background-darkness = 0.95
}
class "GtkInfobar" style "infobar"

style "dark_panel" {
        bg[NORMAL] = "#1e1a17"
        fg[NORMAL] = "#fff"
}

# For old gnome-panel
widget "*PanelWidget*"                                  style "dark_panel"
widget "*PanelApplet*"                                  style "dark_panel"
widget "*fast-user-switch*"                             style "dark_panel"
class "PanelApp*"                                       style "dark_panel"
class "PanelToplevel*"                                  style "dark_panel"
widget_class "*notif*"                                  style "dark_panel"
widget_class "*Notif*"                                  style "dark_panel"


###############################################################################
# The following part of the gtkrc applies the different styles to the widgets.
###############################################################################

# The default style is applied to every widget
class "GtkWidget" style "default"

class "GtkSeparator" style "separator"
class "GtkFrame" style "wide"
class "GtkCalendar" style "wide"
class "GtkEntry" style "entry"

class "GtkSpinButton" style "spinbutton"
class "GtkToolbar" style "toolbar"
class "GtkScale" style "scale"
class "GtkVScale" style "vscale"
class "GtkHScale" style "hscale"
class "GtkScrollbar" style "scrollbar"
class "GtkHScrollbar" style "hscrollbar"
class "GtkVScrollbar" style "vscrollbar"

# General matching follows. The order is choosen so that the right styles override
# each other. EG. progressbar needs to be more important than the menu match.
widget_class "*<GtkNotebook>" style "notebook_bg"
# This is not perfect, it could be done better.
# (That is modify *every* widget in the notebook, and change those back that
# we really don't want changed)
widget_class "*<GtkNotebook>*<GtkEventBox>" style "notebook_bg"
widget_class "*<GtkNotebook>*<GtkDrawingArea>" style "notebook_bg"
widget_class "*<GtkNotebook>*<GtkLayout>" style "notebook_bg"
widget_class "*<GtkNotebook>*<GtkViewport>" style "notebook_bg"
widget_class "*<GtkNotebook>*<GtkScrolledWindow>" style "notebook_bg"

widget_class "*<GtkButton>" style "button"
widget_class "*<GtkToolbar>.*.<GtkButton>" style "toolbarbutton"
widget_class "*<GtkNotebook>" style "notebook"
widget_class "*<GtkStatusbar>*" style "statusbar"

widget_class "*<GtkComboBoxEntry>*" style "comboboxentry"
widget_class "*<GtkCombo>*" style "comboboxentry"

widget_class "*<GtkMenuBar>*" style "menubar"
widget_class "*<GtkMenu>*" style "menu"
widget_class "*<GtkMenuItem>*" style "menu_item"
widget_class "*<GtkSeparatorMenuItem>*" style "separator_menu_item"
widget_class "*<GtkSeparatorToolItem>*" style "separator_tool_item"

widget_class "*.<GtkFrame>.<GtkLabel>" style "frame_title"
widget_class "*.<GtkTreeView>*" style "treeview"

widget_class "*<GtkProgressBar>" style "progressbar"

# Treeview headers (and similar stock GTK+ widgets)
widget_class "*.<GtkTreeView>.<GtkButton>" style "treeview_header"
widget_class "*.<GtkCTree>.<GtkButton>" style "treeview_header"
widget_class "*.<GtkList>.<GtkButton>" style "treeview_header"
widget_class "*.<GtkCList>.<GtkButton>" style "treeview_header"

# The window of the tooltip is called "gtk-tooltip"
##################################################################
# FIXME:
# This will not work if one embeds eg. a button into the tooltip.
# As far as I can tell right now we will need to rework the theme
# quite a bit to get this working correctly.
# (It will involve setting different priorities, etc.)
##################################################################
widget "gtk-tooltip*" style "tooltips"

##########################################################################
# Following are special cases and workarounds for issues in applications.
##########################################################################

# Workaround for the evolution ETable (bug #527532)
widget_class "*.<ETable>.<ECanvas>" style "treeview_header"
# Workaround for the evolution ETree
widget_class "*.<ETree>.<ECanvas>" style "treeview_header"

# Special case the nautilus-extra-view-widget
# ToDo: A more generic approach for all applications that have a widget like this.
widget "*.nautilus-extra-view-widget" style : highest "nautilus_location"

# Work around for http://bugzilla.gnome.org/show_bug.cgi?id=382646
# Note that this work around assumes that the combobox is _not_ in appears-as-list mode.
widget_class "*.<GtkComboBox>.<GtkCellView>" style "text_is_fg_color_workaround"
# This is the part of the workaround that fixes the menus
widget "*.gtk-combobox-popup-menu.*" style "menuitem_text_is_fg_color_workaround"

# Work around the usage of GtkLabel inside GtkListItems to display text.
# This breaks because the label is shown on a background that is based on the base color.
widget_class "*<GtkListItem>*" style "fg_is_text_color_workaround"
# GtkCList also uses the fg color to draw text on top of the base colors.
widget_class "*<GtkCList>" style "fg_is_text_color_workaround"
# Nautilus when renaming files, and maybe other places.
widget_class "*<EelEditableLabel>" style "fg_is_text_color_workaround"

# See the documentation of the style.
widget_class "EShellWindow.GtkVBox.BonoboDock.BonoboDockBand.BonoboDockItem*" style "evo_new_button_workaround"
