diff options
author | zachir <zachir@librem.one> | 2023-02-21 13:18:16 -0600 |
---|---|---|
committer | zachir <zachir@librem.one> | 2023-02-21 13:18:16 -0600 |
commit | f86bb2327fe62cbb604c7861c1f5bdb81563a7c9 (patch) | |
tree | 1182a12bb1d51a65c9d75a468752d44625bab921 /awesome/themes/gtk | |
parent | 8d7bb4e84f06957c0f5f4b882193e5d36a31af1c (diff) |
initialize config for wayland
Diffstat (limited to 'awesome/themes/gtk')
-rw-r--r-- | awesome/themes/gtk/theme.lua | 352 |
1 files changed, 0 insertions, 352 deletions
diff --git a/awesome/themes/gtk/theme.lua b/awesome/themes/gtk/theme.lua deleted file mode 100644 index bd9ffb2..0000000 --- a/awesome/themes/gtk/theme.lua +++ /dev/null @@ -1,352 +0,0 @@ ----------------------------------------------- --- Awesome theme which follows GTK+ 3 theme -- --- by Yauhen Kirylau -- ----------------------------------------------- - -local theme_assets = require("beautiful.theme_assets") -local dpi = require("beautiful.xresources").apply_dpi -local gfs = require("gears.filesystem") -local themes_path = gfs.get_themes_dir() -local gears_shape = require("gears.shape") -local wibox = require("wibox") -local awful_widget_clienticon = require("awful.widget.clienticon") -local gtk = require("beautiful.gtk") - - --- Helper functions for modifying hex colors: --- -local hex_color_match = "[a-fA-F0-9][a-fA-F0-9]" -local function darker(color_value, darker_n) - local result = "#" - local channel_counter = 1 - for s in color_value:gmatch(hex_color_match) do - local bg_numeric_value = tonumber("0x"..s) - if channel_counter <= 3 then - bg_numeric_value = bg_numeric_value - darker_n - end - if bg_numeric_value < 0 then bg_numeric_value = 0 end - if bg_numeric_value > 255 then bg_numeric_value = 255 end - result = result .. string.format("%02x", bg_numeric_value) - channel_counter = channel_counter + 1 - end - return result -end -local function is_dark(color_value) - local bg_numeric_value = 0; - local channel_counter = 1 - for s in color_value:gmatch(hex_color_match) do - bg_numeric_value = bg_numeric_value + tonumber("0x"..s); - if channel_counter == 3 then - break - end - channel_counter = channel_counter + 1 - end - local is_dark_bg = (bg_numeric_value < 383) - return is_dark_bg -end -local function mix(color1, color2, ratio) - ratio = ratio or 0.5 - local result = "#" - local channels1 = color1:gmatch(hex_color_match) - local channels2 = color2:gmatch(hex_color_match) - for _ = 1,3 do - local bg_numeric_value = math.ceil( - tonumber("0x"..channels1())*ratio + - tonumber("0x"..channels2())*(1-ratio) - ) - if bg_numeric_value < 0 then bg_numeric_value = 0 end - if bg_numeric_value > 255 then bg_numeric_value = 255 end - result = result .. string.format("%02x", bg_numeric_value) - end - return result -end -local function reduce_contrast(color, ratio) - ratio = ratio or 50 - return darker(color, is_dark(color) and -ratio or ratio) -end - -local function choose_contrast_color(reference, candidate1, candidate2) -- luacheck: no unused - if is_dark(reference) then - if not is_dark(candidate1) then - return candidate1 - else - return candidate2 - end - else - if is_dark(candidate1) then - return candidate1 - else - return candidate2 - end - end -end - - --- inherit xresources theme: -local theme = dofile(themes_path.."xresources/theme.lua") --- load and prepare for use gtk theme: -theme.gtk = gtk.get_theme_variables() -if not theme.gtk then - local gears_debug = require("gears.debug") - gears_debug.print_warning("Can't load GTK+3 theme. Using 'xresources' theme as a fallback.") - return theme -end -theme.gtk.button_border_radius = dpi(theme.gtk.button_border_radius or 0) -theme.gtk.button_border_width = dpi(theme.gtk.button_border_width or 1) -theme.gtk.bold_font = theme.gtk.font_family .. ' Bold ' .. theme.gtk.font_size -theme.gtk.menubar_border_color = mix( - theme.gtk.menubar_bg_color, - theme.gtk.menubar_fg_color, - 0.7 -) - - -theme.font = theme.gtk.font_family .. ' ' .. theme.gtk.font_size - -theme.bg_normal = theme.gtk.bg_color -theme.fg_normal = theme.gtk.fg_color - -theme.wibar_bg = theme.gtk.menubar_bg_color -theme.wibar_fg = theme.gtk.menubar_fg_color - -theme.bg_focus = theme.gtk.selected_bg_color -theme.fg_focus = theme.gtk.selected_fg_color - -theme.bg_urgent = theme.gtk.error_bg_color -theme.fg_urgent = theme.gtk.error_fg_color - -theme.bg_minimize = mix(theme.wibar_fg, theme.wibar_bg, 0.3) -theme.fg_minimize = mix(theme.wibar_fg, theme.wibar_bg, 0.9) - -theme.bg_systray = theme.wibar_bg - -theme.border_normal = theme.gtk.wm_border_unfocused_color -theme.border_focus = theme.gtk.wm_border_focused_color -theme.border_marked = theme.gtk.success_color - -theme.border_width = dpi(theme.gtk.button_border_width or 1) -theme.border_radius = theme.gtk.button_border_radius - -theme.useless_gap = dpi(3) - -local rounded_rect_shape = function(cr,w,h) - gears_shape.rounded_rect( - cr, w, h, theme.border_radius - ) -end - --- There are other variable sets --- overriding the default one when --- defined, the sets are: --- taglist_[bg|fg|shape|shape_border_color|shape_border_width]_[focus|urgent|occupied|empty|volatile] --- tasklist_[bg|fg|shape|shape_border_color|shape_border_width]_[focus|urgent|minimized] --- titlebar_[bg|fg]_[normal|focus] --- tooltip_[font|opacity|fg_color|bg_color|border_width|border_color] --- mouse_finder_[color|timeout|animate_timeout|radius|factor] - -theme.tasklist_fg_normal = theme.wibar_fg -theme.tasklist_bg_normal = theme.wibar_bg -theme.tasklist_fg_focus = theme.tasklist_fg_normal -theme.tasklist_bg_focus = theme.tasklist_bg_normal - -theme.tasklist_font_focus = theme.gtk.bold_font - -theme.tasklist_shape_minimized = rounded_rect_shape -theme.tasklist_shape_border_color_minimized = mix( - theme.bg_minimize, - theme.fg_minimize, - 0.85 -) -theme.tasklist_shape_border_width_minimized = theme.gtk.button_border_width - -theme.tasklist_spacing = theme.gtk.button_border_width - ---[[ Advanced taglist and tasklist styling: {{{ - ---- In order to get taglist and tasklist to follow GTK theme you need to --- modify your rc.lua in the following way: - -diff --git a/rc.lua b/rc.lua -index 231a2f68c..533a859d2 100644 ---- a/rc.lua -+++ b/rc.lua -@@ -217,24 +217,12 @@ awful.screen.connect_for_each_screen(function(s) - filter = awful.widget.taglist.filter.all, - buttons = taglist_buttons - } -+ -- and apply shape to it -+ if beautiful.taglist_shape_container then -+ local background_shape_wrapper = wibox.container.background(s.mytaglist) -+ background_shape_wrapper._do_taglist_update_now = s.mytaglist._do_taglist_update_now -+ background_shape_wrapper._do_taglist_update = s.mytaglist._do_taglist_update -+ background_shape_wrapper.shape = beautiful.taglist_shape_container -+ background_shape_wrapper.shape_clip = beautiful.taglist_shape_clip_container -+ background_shape_wrapper.shape_border_width = beautiful.taglist_shape_border_width_container -+ background_shape_wrapper.shape_border_color = beautiful.taglist_shape_border_color_container -+ s.mytaglist = background_shape_wrapper -+ end - - -- Create a tasklist widget - s.mytasklist = awful.widget.tasklist { - screen = s, - filter = awful.widget.tasklist.filter.currenttags, -+ buttons = tasklist_buttons, -+ widget_template = beautiful.tasklist_widget_template -- buttons = tasklist_buttons - } - ---]] -theme.tasklist_widget_template = { - { - { - { - { - id = 'clienticon', - widget = awful_widget_clienticon, - }, - margins = dpi(4), - widget = wibox.container.margin, - }, - { - id = 'text_role', - widget = wibox.widget.textbox, - }, - layout = wibox.layout.fixed.horizontal, - }, - left = dpi(2), - right = dpi(4), - widget = wibox.container.margin - }, - id = 'background_role', - widget = wibox.container.background, - create_callback = function(self, c) - self:get_children_by_id('clienticon')[1].client = c - end, -} - -theme.taglist_shape_container = rounded_rect_shape -theme.taglist_shape_clip_container = true -theme.taglist_shape_border_width_container = theme.gtk.button_border_width * 2 -theme.taglist_shape_border_color_container = theme.gtk.header_button_border_color --- }}} - -theme.taglist_bg_occupied = theme.gtk.header_button_bg_color -theme.taglist_fg_occupied = theme.gtk.header_button_fg_color - -theme.taglist_bg_empty = mix( - theme.gtk.menubar_bg_color, - theme.gtk.header_button_bg_color, - 0.3 -) -theme.taglist_fg_empty = mix( - theme.gtk.menubar_bg_color, - theme.gtk.header_button_fg_color -) - -theme.titlebar_font_normal = theme.gtk.bold_font -theme.titlebar_bg_normal = theme.gtk.wm_border_unfocused_color -theme.titlebar_fg_normal = theme.gtk.wm_title_unfocused_color ---theme.titlebar_fg_normal = choose_contrast_color( - --theme.titlebar_bg_normal, - --theme.gtk.menubar_fg_color, - --theme.gtk.menubar_bg_color ---) - -theme.titlebar_font_focus = theme.gtk.bold_font -theme.titlebar_bg_focus = theme.gtk.wm_border_focused_color -theme.titlebar_fg_focus = theme.gtk.wm_title_focused_color ---theme.titlebar_fg_focus = choose_contrast_color( - --theme.titlebar_bg_focus, - --theme.gtk.menubar_fg_color, - --theme.gtk.menubar_bg_color ---) - -theme.tooltip_fg = theme.gtk.tooltip_fg_color -theme.tooltip_bg = theme.gtk.tooltip_bg_color - --- Variables set for theming the menu: --- menu_[bg|fg]_[normal|focus] --- menu_[border_color|border_width] - -theme.menu_border_width = theme.gtk.button_border_width -theme.menu_border_color = theme.gtk.menubar_border_color -theme.menu_bg_normal = theme.gtk.menubar_bg_color -theme.menu_fg_normal = theme.gtk.menubar_fg_color - --- @TODO: get from gtk menu height -theme.menu_height = dpi(24) -theme.menu_width = dpi(150) -theme.menu_submenu_icon = nil -theme.menu_submenu = "▸ " - --- You can add as many variables as --- you wish and access them by using --- beautiful.variable in your rc.lua ---theme.bg_widget = "#cc0000" - - --- Recolor Layout icons: -theme = theme_assets.recolor_layout(theme, theme.wibar_fg) - --- Recolor titlebar icons: --- -theme = theme_assets.recolor_titlebar( - theme, theme.titlebar_fg_normal, "normal" -) -theme = theme_assets.recolor_titlebar( - theme, reduce_contrast(theme.titlebar_fg_normal, 50), "normal", "hover" -) -theme = theme_assets.recolor_titlebar( - theme, theme.gtk.error_bg_color, "normal", "press" -) -theme = theme_assets.recolor_titlebar( - theme, theme.titlebar_fg_focus, "focus" -) -theme = theme_assets.recolor_titlebar( - theme, reduce_contrast(theme.titlebar_fg_focus, 50), "focus", "hover" -) -theme = theme_assets.recolor_titlebar( - theme, theme.gtk.error_bg_color, "focus", "press" -) - --- Define the icon theme for application icons. If not set then the icons --- from /usr/share/icons and /usr/share/icons/hicolor will be used. -theme.icon_theme = nil - --- Generate Awesome icon: -theme.awesome_icon = theme_assets.awesome_icon( - theme.menu_height, mix(theme.bg_focus, theme.fg_normal), theme.wibar_bg -) - --- Generate taglist squares: ---local taglist_square_size = dpi(4) ---theme.taglist_squares_sel = theme_assets.taglist_squares_sel( - --taglist_square_size, theme.gtk.header_button_border_color ---) ---theme.taglist_squares_unsel = theme_assets.taglist_squares_unsel( - --taglist_square_size, theme.gtk.header_button_border_color ---) --- Or disable them: -theme.taglist_squares_sel = nil -theme.taglist_squares_unsel = nil - --- Generate wallpaper: -local wallpaper_bg = theme.gtk.base_color -local wallpaper_fg = theme.gtk.bg_color -local wallpaper_alt_fg = theme.gtk.selected_bg_color -if not is_dark(theme.bg_normal) then - wallpaper_bg, wallpaper_fg = wallpaper_fg, wallpaper_bg -end -wallpaper_bg = reduce_contrast(wallpaper_bg, 50) -wallpaper_fg = reduce_contrast(wallpaper_fg, 30) -wallpaper_fg = mix(wallpaper_fg, wallpaper_bg, 0.4) -wallpaper_alt_fg = mix(wallpaper_alt_fg, wallpaper_fg, 0.4) --- theme.wallpaper = function(s) --- return theme_assets.wallpaper(wallpaper_bg, wallpaper_fg, wallpaper_alt_fg, s) --- end -theme.wallpaper = "~/background.png" -wallpaper_cmd = "nitrogen --restore" - -return theme - --- vim: filetype=lua:expandtab:shiftwidth=4:tabstop=8:softtabstop=4:textwidth=80:foldmethod=marker |