diff --git a/.config/awesome/config.lua b/.config/awesome/config.lua new file mode 100644 index 0000000..314f796 --- /dev/null +++ b/.config/awesome/config.lua @@ -0,0 +1 @@ +return require("config_laptop") diff --git a/.config/awesome/config_common.lua b/.config/awesome/config_common.lua new file mode 100644 index 0000000..0b67981 --- /dev/null +++ b/.config/awesome/config_common.lua @@ -0,0 +1,7 @@ + +return { + terminal = "termite", + --editor = os.getenv("EDITOR") or "nvim", + --editor_cmd = terminal .. " -e " .. editor, + modkey = "Mod4", +} diff --git a/.config/awesome/icons.lua b/.config/awesome/icons.lua new file mode 100644 index 0000000..669523e --- /dev/null +++ b/.config/awesome/icons.lua @@ -0,0 +1,43 @@ + +return { + battery = { + not_charging = { + ["0"] = "", + ["10"] = "", + ["20"] = "", + ["30"] = "", + ["40"] = "", + ["50"] = "", + ["60"] = "", + ["70"] = "", + ["80"] = "", + ["90"] = "", + ["100"] = "" + }, + charging = { + ["0"] = "", + ["10"] = "", + ["20"] = "", + ["30"] = "", + ["40"] = "", + ["50"] = "", + ["60"] = "", + ["70"] = "", + ["80"] = "", + ["90"] = "", + ["100"] = "" + }, + }, + brightness = { + "", "", "", "", "", "", "" + }, + volume = { + levels = { + "", "", "" + }, + muted = "婢" + }, + thermal = { + "", "", "", "", "" + } +} diff --git a/.config/awesome/keys.lua b/.config/awesome/keys.lua new file mode 100644 index 0000000..ffc2234 --- /dev/null +++ b/.config/awesome/keys.lua @@ -0,0 +1,261 @@ + +-- Standard awesome library +local gears = require("gears") +local awful = require("awful") + +local hotkeys_popup = require("awful.hotkeys_popup") +-- Enable hotkeys help widget for VIM and other apps +-- when client with a matching name is opened: +require("awful.hotkeys_popup.keys") + +local Keys = {} + +Keys.globalbuttons = gears.table.join( + --awful.button({ }, 1, end_switcher) +) + +-- {{{ Key bindings +Keys.globalkeys = gears.table.join( + + awful.key({}, "XF86AudioRaiseVolume", function () + awful.spawn("sh -c 'pactl set-sink-mute "..config.volume.sink.." false && pactl set-sink-volume "..config.volume.sink.." +5%'") + gears.timer.start_new(0.2, function () vicious.force({ volumebox, }) end) + end), + awful.key({}, "XF86AudioLowerVolume", function () + awful.spawn("sh -c 'pactl set-sink-mute "..config.volume.sink.." false && pactl set-sink-volume "..config.volume.sink.." -5%'") + gears.timer.start_new(0.2, function () vicious.force({ volumebox, }) end) + end), + awful.key({}, "XF86AudioMute", function () + awful.spawn("pactl set-sink-mute "..config.volume.sink.." toggle") + gears.timer.start_new(0.2, function () vicious.force({ volumebox, }) end) + end), + + awful.key({ "Control" }, "XF86MonBrightnessUp", function () + awful.spawn("xbacklight -inc 1") + end), + awful.key({ "Control" }, "XF86MonBrightnessDown", function () + awful.spawn("xbacklight -dec 1") + end), + awful.key({}, "XF86MonBrightnessUp", function () + awful.spawn("xbacklight -inc 5") + end), + awful.key({}, "XF86MonBrightnessDown", function () + awful.spawn("xbacklight -dec 5") + end), + + --awful.key({ modkey }, "g", function () for s in screen do togglegaps(s, s.topwibox); s.dock_hide_timer:stop() end end), + --awful.key({ modkey }, "g", toggle_switcher), + awful.key({ modkey, }, "s", hotkeys_popup.show_help, + {description="show help", group="awesome"}), + awful.key({ modkey, }, "Left", awful.tag.viewprev, + {description = "view previous", group = "tag"}), + awful.key({ modkey, }, "Right", awful.tag.viewnext, + {description = "view next", group = "tag"}), + awful.key({ modkey, }, "Escape", awful.tag.history.restore, + {description = "go back", group = "tag"}), + + awful.key({ modkey, }, "j", + function () + awful.client.focus.byidx( 1) + end, + {description = "focus next by index", group = "client"} + ), + awful.key({ modkey, }, "k", + function () + awful.client.focus.byidx(-1) + end, + {description = "focus previous by index", group = "client"} + ), + awful.key({ modkey, }, "w", function () dropdown:toggle() end, + {description = "toggle dropdown terminal", group = "client"}), + + awful.key({ }, "F2", function () htop:toggle() end, + {description = "toggle dropdown htop terminal", group = "client"}), + + awful.key({ modkey, "Shift" }, "m", function () vimpc:toggle() end, + {description = "toggle dropdown vimpc terminal", group = "client"}), + + awful.key({ modkey, "Shift" }, "b", function () onboard:toggle() end, + {description = "toggle onboard", group = "client"}), + + -- Layout manipulation + awful.key({ modkey, "Shift" }, "j", function () awful.client.swap.byidx( 1) end, + {description = "swap with next client by index", group = "client"}), + awful.key({ modkey, "Shift" }, "k", function () awful.client.swap.byidx( -1) end, + {description = "swap with previous client by index", group = "client"}), + awful.key({ modkey, "Control" }, "j", function () awful.screen.focus_relative( 1) end, + {description = "focus the next screen", group = "screen"}), + awful.key({ modkey, "Control" }, "k", function () awful.screen.focus_relative(-1) end, + {description = "focus the previous screen", group = "screen"}), + awful.key({ modkey, }, "u", awful.client.urgent.jumpto, + {description = "jump to urgent client", group = "client"}), + + -- Standard program + awful.key({ modkey, }, "Return", function () awful.spawn(terminal) end, + {description = "open a terminal", group = "launcher"}), + awful.key({ modkey, "Control" }, "r", awesome.restart, + {description = "reload awesome", group = "awesome"}), + awful.key({ modkey, "Shift" }, "e", function() awful.spawn("/home/daan/.config/awesome/exit.sh") end, + {description = "quit awesome", group = "awesome"}), + awful.key({ modkey, }, "l", function () awful.tag.incmwfact( 0.05) end, + {description = "increase master width factor", group = "layout"}), + awful.key({ modkey, }, "h", function () awful.tag.incmwfact(-0.05) end, + {description = "decrease master width factor", group = "layout"}), + awful.key({ modkey, "Shift" }, "h", function () awful.tag.incnmaster( 1, nil, true) end, + {description = "increase the number of master clients", group = "layout"}), + awful.key({ modkey, "Shift" }, "l", function () awful.tag.incnmaster(-1, nil, true) end, + {description = "decrease the number of master clients", group = "layout"}), + awful.key({ modkey, "Control" }, "h", function () awful.tag.incncol( 1, nil, true) end, + {description = "increase the number of columns", group = "layout"}), + awful.key({ modkey, "Control" }, "l", function () awful.tag.incncol(-1, nil, true) end, + {description = "decrease the number of columns", group = "layout"}), + awful.key({ modkey, }, "space", function () + awful.layout.inc( 1); + layout_table[awful.screen.focused().selected_tag] = awful.screen.focused().selected_tag.layout + end, {description = "select next", group = "layout"}), + awful.key({ modkey, "Shift" }, "space", function () + awful.layout.inc(-1); + layout_table[awful.screen.focused().selected_tag] = awful.screen.focused().selected_tag.layout + end, {description = "select previous", group = "layout"}), + + awful.key({ modkey }, "m", function() awful.spawn("mpc toggle") end), + awful.key({ modkey }, "]", function() awful.spawn("mpc next") end), + awful.key({ modkey }, "[", function() awful.spawn("mpc prev") end), + + awful.key({ modkey, "Control" }, "n", + function () + local c = awful.client.restore() + -- Focus restored client + if c then + c:emit_signal( + "request::activate", "key.unminimize", {raise = true} + ) + end + end, + {description = "restore minimized", group = "client"}), + + -- Prompt + awful.key({ modkey }, "r", function () awful.screen.focused().mypromptbox:run() end, + {description = "run prompt", group = "launcher"}), + + awful.key({ modkey }, "x", + function () + awful.prompt.run { + prompt = "Run Lua code: ", + textbox = awful.screen.focused().mypromptbox.widget, + exe_callback = awful.util.eval, + history_path = awful.util.get_cache_dir() .. "/history_eval" + } + end, + {description = "lua execute prompt", group = "awesome"}), + -- Menubar + awful.key({ modkey }, "p", function() game_mode_toggle() end, + {description = "show the menubar", group = "launcher"}), + awful.key({ modkey }, "d", function() rofi_spawn("rofi -show drun -me-select-entry '' -me-accept-entry 'MousePrimary'") end, + {description = "launch rofi", group = "launcher"}), + awful.key({ modkey, "Shift" }, "g", + function (c) + rofi_spawn("dmenu_script lutris.sh") + end , + {description = "Play a Game"}) +) + +Keys.clientkeys = gears.table.join( + awful.key({ modkey, }, "f", + function (c) + c.fullscreen = not c.fullscreen + c:raise() + end, + {description = "toggle fullscreen", group = "client"}), + awful.key({ modkey, "Shift" }, "q", function (c) c:kill() end, + {description = "close", group = "client"}), + awful.key({ modkey, "Control" }, "space", awful.client.floating.toggle , + {description = "toggle floating", group = "client"}), + awful.key({ modkey, "Control", "Shift" }, "space", function (c) + c.maximized = false + c.maximized_vertical = false + c.maximized_horizontal = false + end, + {description = "toggle floating", group = "client"}), + awful.key({ modkey, "Control" }, "Return", function (c) c:swap(awful.client.getmaster()) end, + {description = "move to master", group = "client"}), + awful.key({ modkey, }, "o", function (c) c:move_to_screen() end, + {description = "move to screen", group = "client"}), + awful.key({ modkey, }, "t", function (c) c.ontop = not c.ontop end, + {description = "toggle keep on top", group = "client"}), + awful.key({ modkey, }, "n", + function (c) + -- The client currently has the input focus, so it cannot be + -- minimized, since minimized clients can't have the focus. + c.minimized = true + end , + {description = "minimize", group = "client"}) +) + +-- Bind all key numbers to tags. +-- Be careful: we use keycodes to make it work on any keyboard layout. +-- This should map on the top row of your keyboard, usually 1 to 9. +for i = 1, 9 do + Keys.globalkeys = gears.table.join(Keys.globalkeys, + -- View tag only. + awful.key({ modkey }, "#" .. i + 9, + function () + local screen = awful.screen.focused() + local tag = screen.tags[i] + if tag then + tag:view_only() + end + end, + {description = "view tag #"..i, group = "tag"}), + -- Toggle tag display. + awful.key({ modkey, "Control" }, "#" .. i + 9, + function () + local screen = awful.screen.focused() + local tag = screen.tags[i] + if tag then + awful.tag.viewtoggle(tag) + end + end, + {description = "toggle tag #" .. i, group = "tag"}), + -- Move client to tag. + awful.key({ modkey, "Shift" }, "#" .. i + 9, + function () + if client.focus then + local tag = client.focus.screen.tags[i] + if tag then + client.focus:move_to_tag(tag) + end + end + end, + {description = "move focused client to tag #"..i, group = "tag"}), + -- Toggle tag on focused client. + awful.key({ modkey, "Control", "Shift" }, "#" .. i + 9, + function () + if client.focus then + local tag = client.focus.screen.tags[i] + if tag then + client.focus:toggle_tag(tag) + end + end + end, + {description = "toggle focused client on tag #" .. i, group = "tag"}) + ) +end + +Keys.clientbuttons = gears.table.join( + awful.button({ }, 1, function (c) + c:emit_signal("request::activate", "mouse_click", {raise = true}) + end), + awful.button({ }, 3, function (c) + end), + awful.button({ modkey }, 1, function (c) + c:emit_signal("request::activate", "mouse_click", {raise = true}) + awful.mouse.client.move(c) + end), + awful.button({ modkey }, 3, function (c) + c:emit_signal("request::activate", "mouse_click", {raise = true}) + awful.mouse.client.resize(c) + end) +) + +return Keys diff --git a/.config/awesome/rc.lua b/.config/awesome/rc.lua index 29fc3e2..a2e5ec1 100644 --- a/.config/awesome/rc.lua +++ b/.config/awesome/rc.lua @@ -16,7 +16,7 @@ local menubar = require("menubar") local hotkeys_popup = require("awful.hotkeys_popup") local vicious = require("vicious") local timer = require("gears.timer") -local config = require("config_desktop") +local config = require("config_laptop") local quake = require("quake") -- Enable hotkeys help widget for VIM and other apps @@ -51,7 +51,7 @@ local vimpc = quake:new({ app = "alacritty", name = "QuakeVimpc", argname = "--class %s", - extra = "-e mpc-rs", + extra = "-e /home/daan/.cargo/bin/mpc-rs", border = 0, height = 0.25, width = 0.33, diff --git a/.config/awesome/rc_new.lua b/.config/awesome/rc_new.lua new file mode 100644 index 0000000..161eceb --- /dev/null +++ b/.config/awesome/rc_new.lua @@ -0,0 +1,286 @@ +-- If LuaRocks is installed, make sure that packages installed through it are +-- found (e.g. lgi). If LuaRocks is not installed, do nothing. +pcall(require, "luarocks.loader") + +-- Standard awesome library +local gears = require("gears") +local awful = require("awful") +require("awful.autofocus") +-- Widget and layout library +local wibox = require("wibox") +-- Theme handling library +local beautiful = require("beautiful") +-- Notification library +local naughty = require("naughty") +local menubar = require("menubar") +local hotkeys_popup = require("awful.hotkeys_popup") +local vicious = require("vicious") +local timer = require("gears.timer") + +-- Enable hotkeys help widget for VIM and other apps +-- when client with a matching name is opened: +require("awful.hotkeys_popup.keys") + + +local util = require("util") +local terminal = require("terminal") +local wiboxes = require("wiboxes") +local keys = require("keys") + +-- Load the config file +local config = require("config") + +-- {{{ Error handling +-- Check if awesome encountered an error during startup and fell back to +-- another config (This code will only ever execute for the fallback config) +if awesome.startup_errors then + naughty.notify({ preset = naughty.config.presets.critical, + title = "Oops, there were errors during startup!", + text = awesome.startup_errors }) +end + +-- Handle runtime errors after startup +do + local in_error = false + awesome.connect_signal("debug::error", function (err) + -- Make sure we don't go into an endless error loop + if in_error then return end + in_error = true + + naughty.notify({ preset = naughty.config.presets.critical, + title = "Oops, an error happened!", + text = tostring(err) }) + in_error = false + end) +end +-- }}} + +-- {{{ Variable definitions +-- Themes define colours, icons, font and wallpapers. +if not beautiful.init("/home/daan/.config/awesome/theme.lua") then + print("Mr. Theme did an oopsie!") +end +beautiful.font = "Hack Nerd Font 9" + +-- Table of layouts to cover with awful.layout.inc, order matters. +awful.layout.layouts = { + awful.layout.suit.spiral.dwindle, + --awful.layout.suit.floating, + awful.layout.suit.tile, + --awful.layout.suit.tile.left + awful.layout.suit.tile.bottom, + awful.layout.suit.tile.top, + awful.layout.suit.fair, + --awful.layout.suit.fair.horizontal, + --awful.layout.suit.spiral, + --awful.layout.suit.max, + --awful.layout.suit.max.fullscreen, + --awful.layout.suit.magnifier, + --awful.layout.suit.corner.nw, + -- awful.layout.suit.corner.ne, + -- awful.layout.suit.corner.sw, + -- awful.layout.suit.corner.se, +} +-- }}} + +-- Autorun commands +awful.spawn.with_shell("/home/daan/.config/awesome/autorun.sh") + + +local function set_wallpaper(s) + -- Wallpaper + if beautiful.wallpaper then + local wallpaper = beautiful.wallpaper + -- If wallpaper is a function, call it with the screen + if type(wallpaper) == "function" then + wallpaper = wallpaper(s) + end + gears.wallpaper.maximized(wallpaper, s, true) + end +end + +-- Re-set wallpaper when a screen's geometry changes (e.g. different resolution) +screen.connect_signal("property::geometry", set_wallpaper) + + +awful.screen.connect_for_each_screen(function(s) + -- Wallpaper + set_wallpaper(s) + + wiboxes.connect_screen(s) +end) +-- }}} + +-- {{{ Mouse bindings +root.buttons(gears.table.join( + awful.button({ }, 3, function () mymainmenu:toggle() end), + awful.button({ }, 4, awful.tag.viewnext), + awful.button({ }, 5, awful.tag.viewprev) +)) +-- }}} + +-- {{{ Game mode +local game_mode = false + +function game_mode_start () + if game_mode == true then return else game_mode = true end + awful.spawn("killall compton") + for s in screen do + s.dock_trigger.visible = false + end +end + +function game_mode_stop () + if game_mode == false then return else game_mode = false end + awful.spawn.with_shell("~/.config/compton/launch.sh") + for s in screen do + s.dock_trigger.visible = true + end +end + +function game_mode_toggle () + if game_mode then game_mode_stop() else game_mode_start() end +end + +-- }}} + +-- Set keys +root.keys(keys.globalkeys) +root.buttons(keys.globalbuttons) +-- }}} + +-- {{{ Rules +-- Rules to apply to new clients (through the "manage" signal). +awful.rules.rules = { + -- All clients will match this rule. + { rule = { }, + properties = { border_width = 0, + border_color = 0, + focus = awful.client.focus.filter, + raise = true, + keys = keys.clientkeys, + buttons = keys.clientbuttons, + screen = awful.screen.preferred, + placement = awful.placement.no_overlap+awful.placement.no_offscreen, + maximized_vertical = false, + maximized_horizontal = false, + maximized = false + } + }, + + -- Floating clients. + { rule_any = { + instance = { + "DTA", -- Firefox addon DownThemAll. + "copyq", -- Includes session name in class. + "pinentry", + }, + class = { + "Arandr", + "Blueman-manager", + "Gpick", + "Kruler", + "MessageWin", -- kalarm. + "Sxiv", + "Tor Browser", -- Needs a fixed window size to avoid fingerprinting by screen size. + "Wpa_gui", + "veromix", + "xtightvncviewer", + "tilda", + "Tilda" + }, + + -- Note that the name property shown in xprop might be set slightly after creation of the client + -- and the name shown there might not match defined rules here. + name = { + "Event Tester", -- xev. + }, + role = { + "AlarmWindow", -- Thunderbird's calendar. + "ConfigManager", -- Thunderbird's about:config. + "pop-up", -- e.g. Google Chrome's (detached) Developer Tools. + } + }, properties = { floating = true }}, + + { rule_any = { + name = { + "Onboard", + }, + class = { + "onboard", "Onboard" + } + }, properties = { focusable = false }}, + + + -- Add titlebars to normal clients and dialogs + { rule_any = {type = { "normal", "dialog" } + }, properties = { titlebars_enabled = false } + }, + + -- Set Firefox to always map on the tag named "2" on screen 1. + -- { rule = { class = "Firefox" }, + -- properties = { screen = 1, tag = "2" } }, +} +-- }}} + +-- {{{ Signals +-- Signal function to execute when a new client appears. +client.connect_signal("manage", function (c) + -- Set the windows at the slave, + -- i.e. put it at the end of others instead of setting it master. + -- if not awesome.startup then awful.client.setslave(c) end + + if awesome.startup + and not c.size_hints.user_position + and not c.size_hints.program_position then + -- Prevent clients from being unreachable after screen count changes. + awful.placement.no_offscreen(c) + end +end) + +-- Add a titlebar if titlebars_enabled is set to true in the rules. +client.connect_signal("request::titlebars", function(c) + -- buttons for the titlebar + local buttons = gears.table.join( + awful.button({ }, 1, function() + c:emit_signal("request::activate", "titlebar", {raise = true}) + awful.mouse.client.move(c) + end), + awful.button({ }, 3, function() + c:emit_signal("request::activate", "titlebar", {raise = true}) + awful.mouse.client.resize(c) + end) + ) + + awful.titlebar(c, { + bg_normal = beautiful.border_normal + }) : setup { + { -- Left + awful.titlebar.widget.iconwidget(c), + buttons = buttons, + layout = wibox.layout.fixed.horizontal + }, + { -- Middle + { -- Title + align = "center", + widget = awful.titlebar.widget.titlewidget(c) + }, + buttons = buttons, + layout = wibox.layout.flex.horizontal + }, + { -- Right + layout = wibox.layout.fixed.horizontal() + }, + layout = wibox.layout.align.horizontal + } + +end) + +-- Enable sloppy focus, so that focus follows mouse. +client.connect_signal("mouse::enter", function(c) + c:emit_signal("request::activate", "mouse_enter", {raise = false}) +end) + + + + diff --git a/.config/awesome/terminal.lua b/.config/awesome/terminal.lua new file mode 100644 index 0000000..36e05b9 --- /dev/null +++ b/.config/awesome/terminal.lua @@ -0,0 +1,41 @@ +local quake = require("quake") + +local Terminal = { + dropdown = quake:new({ + app = "termite", + argname = "--name %s", + border = 0, + height = 0.37 + }), + htop = quake:new({ + app = "termite", + name = "QuakeHtop", + argname = "--name %s", + extra = "-e htop", + border = 0, + height = 0.13, + width = 0.25 + }), + vimpc = quake:new({ + app = "termite", + name = "QuakeVimpc", + argname = "--name %s", + extra = "-e vimpc", + border = 0, + height = 0.25, + width = 0.33, + horiz = "center", + vert = "bottom" + }), + onboard = quake:new({ + app = "onboard", + name = "QuakeOnboard", + argname = "--name %s", + extra = "", + border = 0, + height = 0.25, + width = 1, + horiz = "center", + vert = "bottom" + }) +} diff --git a/.config/awesome/util.lua b/.config/awesome/util.lua new file mode 100644 index 0000000..4a11173 --- /dev/null +++ b/.config/awesome/util.lua @@ -0,0 +1,17 @@ + +local Util = {} + +function Util.round(x) + if x%2 ~= 0.5 then + return math.floor(x+0.5) + end + return x-0.5 +end + +function table.copy(t) + local u = { } + for k, v in pairs(t) do u[k] = v end + return setmetatable(u, getmetatable(t)) +end + +return Util diff --git a/.config/awesome/wiboxes.lua b/.config/awesome/wiboxes.lua new file mode 100644 index 0000000..f00109f --- /dev/null +++ b/.config/awesome/wiboxes.lua @@ -0,0 +1,199 @@ + +-- Standard awesome library +local gears = require("gears") +local awful = require("awful") + +-- Widget and layout library +local wibox = require("wibox") +local menubar = require("menubar") + +-- Load the config file +local config = require("config") + +local widgets = require("widgets") + +-- Menubar configuration +menubar.utils.terminal = terminal -- Set the terminal for applications that require it +-- }}} + +-- Keyboard map indicator and switcher +mykeyboardlayout = awful.widget.keyboardlayout() + +-- {{{ Wibar +-- Create a textclock widget +mytextclock = wibox.widget.textclock() + +-- Create a wibox for each screen and add it +local taglist_buttons = gears.table.join( + awful.button({ }, 1, function(t) t:view_only() end), + awful.button({ modkey }, 1, function(t) + if client.focus then + client.focus:move_to_tag(t) + end + end), + awful.button({ }, 3, awful.tag.viewtoggle), + awful.button({ modkey }, 3, function(t) + if client.focus then + client.focus:toggle_tag(t) + end + end), + awful.button({ }, 4, function(t) awful.tag.viewnext(t.screen) end), + awful.button({ }, 5, function(t) awful.tag.viewprev(t.screen) end) + ) + +local tasklist_buttons = gears.table.join( + awful.button({ }, 1, function (c) + if c == client.focus then + c.minimized = true + else + c:emit_signal( + "request::activate", + "tasklist", + {raise = true} + ) + end + end), + awful.button({ }, 3, function() + awful.menu.client_list({ theme = { width = 250 } }) + end), + awful.button({ }, 4, function () + awful.client.focus.byidx(1) + end), + awful.button({ }, 5, function () + awful.client.focus.byidx(-1) + end)) + +local Wiboxes = {} + +function Wiboxes.connect_screen(s) + -- Each screen has its own tag table. + awful.tag({ "1", "2", "3", "4", "5", "6", "7", "8", "9" }, s, awful.layout.layouts[1]) + + -- We need one layoutbox per screen. + s.mylayoutbox = awful.widget.layoutbox(s) + s.mylayoutbox:buttons(gears.table.join( + awful.button({ }, 1, function () awful.layout.inc( 1) end), + awful.button({ }, 3, function () awful.layout.inc(-1) end), + awful.button({ }, 4, function () awful.layout.inc( 1) end), + awful.button({ }, 5, function () awful.layout.inc(-1) end))) + -- Create a taglist widget + s.mytaglist = awful.widget.taglist { + screen = s, + filter = awful.widget.taglist.filter.all, + buttons = taglist_buttons + } + + -- Create a tasklist widget + s.mytasklist = awful.widget.tasklist { + screen = s, + filter = awful.widget.tasklist.filter.currenttags, + buttons = tasklist_buttons + } + + -- Create the wibox + s.topwibox = awful.wibar({ + position = "top", + screen = s, + bg = { + type = "linear", + from = { 0, 0, 0 }, + to = { 0, 20, 0 }, + stops = { { 0, "#000000aa" }, { 0.6, "#00000066"}, { 1, "#00000000" } } + }, + visible = false + }) + + -- Add widgets to the wibox + s.topwibox:setup { + layout = wibox.layout.align.horizontal, + { -- Left widgets + layout = wibox.layout.fixed.horizontal, + s.mytaglist, + + table.unpack(widgets.get(config.widgets.top.left)) + }, + { + layout = wibox.layout.flex.horizontal, + + wibox.widget { widget = wibox.widget.separator, visible = false }, + + table.unpack(widgets.get(config.widgets.top.mid)), + + wibox.widget { widget = wibox.widget.separator, visible = false }, + }, + { -- Right widgets + layout = wibox.layout.fixed.horizontal, + + table.unpack(widgets.get(config.widgets.top.right)), + }, + } + + s.bottomwibox = awful.wibar({ + position = "bottom", + screen = s, + bg = { + type = "linear", + from = { 0, 20, 0 }, + to = { 0, 0, 0 }, + stops = { { 0, "#000000aa" }, { 0.6, "#00000066"}, { 1, "#00000000" } } + }, + visible = false + }) + + s.bottomwibox:setup { + layout = wibox.layout.align.horizontal, + { -- Left widgets + layout = wibox.layout.fixed.horizontal, + + wibox.widget.systray(), + + table.unpack(widgets.get(config.widgets.bottom.left)) + }, + { + layout = wibox.layout.flex.horizontal, + + table.unpack(widgets.get(config.widgets.bottom.mid)), + }, + { -- Right widgets + layout = wibox.layout.fixed.horizontal, + + table.unpack(widgets.get(config.widgets.bottom.right)), + }, + } + + s.dock_trigger = wibox({ bg = "#00000000", opacity = 0, ontop = true, visible = true }) + s.dock_trigger:geometry({ width = 100, height = 1 }) + + s.topwibox:connect_signal("mouse::enter", function() enable_bars() end) + s.topwibox:connect_signal("mouse::leave", function() bar_timer:again() end) + s.bottomwibox:connect_signal("mouse::enter", function() enable_bars() end) + s.bottomwibox:connect_signal("mouse::leave", function() bar_timer:again() end) + s.dock_trigger:connect_signal("mouse::enter", function() enable_bars() end) + s.dock_trigger:connect_signal("mouse::leave", function() bar_timer:again() end) +end + +bar_timer = timer({ timeout = 0.2 }) +bar_timer:connect_signal("timeout", function () disable_bars() end) +bar_mode = false + +function enable_bars () + if bar_timer.started then bar_timer:stop() end + if bar_mode == true then return else bar_mode = true end + + for s in screen do + s.topwibox.visible = true + s.bottomwibox.visible = true + end +end + +function disable_bars () + if bar_timer.started then bar_timer:stop() end + if bar_mode == false then return else bar_mode = false end + + for s in screen do + s.topwibox.visible = false + s.bottomwibox.visible = false + end +end + +return Wiboxes diff --git a/.config/awesome/widgets.lua b/.config/awesome/widgets.lua new file mode 100644 index 0000000..d3a8039 --- /dev/null +++ b/.config/awesome/widgets.lua @@ -0,0 +1,146 @@ + +-- Standard awesome library +local gears = require("gears") +local awful = require("awful") + +-- Widget and layout library +local wibox = require("wibox") + +local icons = require("icons") +local config = require("config") +local vicious = require("vicious") + +local util = require("util") + +local backlight_widget_type = { + async = function (format, warg, callback) + awful.spawn.easy_async("xbacklight ", function (stdout) + callback{ round(tonumber(stdout)) } + end) + end +} + +local function format_widget(...) + local result = " " + for _, v in ipairs({...}) do + result = result .. v .. " " + end + return result +end + +local function battery_icon(percent, charging) + local key = ""..math.floor(util.round(percent / 10) * 10).."" + if charging then + return icons.battery.charging[key] + else + + return icons.battery.not_charging[key] + end +end + +local function format_battery(widget, args) + return format_widget(battery_icon(args[2], args[1] == "+"), args[2]) +end + +local function format_wifi(widget, args) + if args["{ssid}"] ~= "N/A" then + return format_widget("", args["{linp}"]) + end + return "" +end + +local function format_brightness(widget, args) + local index = math.min(util.round(args[1] / 100 * 6 + 1), 7) + return format_widget(icons.brightness[index], args[1]) +end + +local function format_volume(widget, args) + if args[2] == "🔉" then + local index = math.min(util.round(args[1] / 100 * 2 + 1), 3) + return format_widget(icons.volume.levels[index], args[1]) + else + return format_widget(icons.volume.muted, "") + end +end + +local function format_memory(widget, args) + return format_widget("", util.round(args[2] / 100) / 10 .. " GiB") +end + +local function format_cpu(widget, args) + return format_widget("", args[1]) +end + +local function format_mpd(widget, args) + if args["{state}"] == "Stop" then + return '' + else + local icon = (args["{state}"] == "Pause" and "" or "") + return format_widget(icon, + ('%s - %s'):format(args["{Artist}"], args["{Title}"]), icon) + end +end + +local function format_thermal(widget, args) + local key = math.floor(math.min(util.round(math.max(args[1] - 30, 0) / 60 * 4 + 1), 5)) + return format_widget(icons.thermal[key], args[1]) +end + +volumebox = wibox.widget.textbox() +vicious.cache(vicious.widgets.volume) +vicious.register(volumebox, vicious.widgets.volume, format_volume, 3, config.volume.options) + +backlightbox = wibox.widget.textbox() +vicious.cache(backlight_widget_type) +vicious.register(backlightbox, backlight_widget_type, format_brightness, 3) + +batwidget = wibox.widget.textbox() +vicious.cache(vicious.widgets.bat) +vicious.register(batwidget, vicious.widgets.bat, format_battery, 20, config.battery) + +wifiwidget = wibox.widget.textbox() +vicious.cache(vicious.widgets.wifiiw) +vicious.register(wifiwidget, vicious.widgets.wifiiw, format_wifi, 3, config.net_interface) + +cpuwidget = wibox.widget.textbox() +vicious.cache(vicious.widgets.cpu) +vicious.register(cpuwidget, vicious.widgets.cpu, format_cpu, 1) + +memwidget = wibox.widget.textbox() +vicious.cache(vicious.widgets.mem) +vicious.register(memwidget, vicious.widgets.mem, format_memory, 1) + +mpdwidget = wibox.widget.textbox() +mpdwidget.align = 'center' +vicious.cache(vicious.widgets.mpd) +vicious.register(mpdwidget, vicious.widgets.mpd, format_mpd) + +thermalwidget = wibox.widget.textbox() +vicious.cache(vicious.widgets.thermal) +vicious.register(thermalwidget, vicious.widgets.thermal, format_thermal, 2, config.thermal_zone) + +local widget_table = { + ["mpd"] = mpdwidget, + ["memory"] = memwidget, + ["cpu"] = cpuwidget, + ["volume"] = volumebox, + ["backlight"] = backlightbox, + ["wifi"] = wifiwidget, + ["battery"] = batwidget, + ["clock"] = mytextclock, + ["thermal"] = thermalwidget, +} + +Widgets = {} + +function Widgets.get(conf) + local t = {} + + for _, v in ipairs(conf) do + table.insert(t, widget_table[v]) + end + + return t +end + +return Widgets