From 25d9eecfc68df3251dc96008aaa4cd7c81900da6 Mon Sep 17 00:00:00 2001 From: streetturtle Date: Fri, 19 Mar 2021 20:49:00 -0400 Subject: [volume] BREAKING CHANGE - new widget instead of old ones Having three widgets for volume led to a problem of code duplication - same logic was duplicated three times. However when an issue was discovered and fixed, it was fixed in only one of three widgets. So I decided to create a volume widget from scratch, adding new features, such as selecting input/output, better responsiveness, easily customizable widget ui (bar, text, icon, icon and text, arc). Should close #199, #198, #185, #182, #47, #122, #183. --- volumearc-widget/volumearc.lua | 140 ----------------------------------------- 1 file changed, 140 deletions(-) delete mode 100644 volumearc-widget/volumearc.lua (limited to 'volumearc-widget/volumearc.lua') diff --git a/volumearc-widget/volumearc.lua b/volumearc-widget/volumearc.lua deleted file mode 100644 index b104ad3..0000000 --- a/volumearc-widget/volumearc.lua +++ /dev/null @@ -1,140 +0,0 @@ -------------------------------------------------- --- Volume Arc Widget for Awesome Window Manager --- Shows the current volume level --- More details could be found here: --- https://github.com/streetturtle/awesome-wm-widgets/tree/master/volumearc-widget - --- @author Pavel Makhov --- @copyright 2018 Pavel Makhov -------------------------------------------------- - -local awful = require("awful") -local beautiful = require("beautiful") -local spawn = require("awful.spawn") -local watch = require("awful.widget.watch") -local wibox = require("wibox") -local gears = require("gears") - -local GET_VOLUME_CMD = 'amixer -D pulse sget Master' -local INC_VOLUME_CMD = 'amixer -q -D pulse sset Master 5%+' -local DEC_VOLUME_CMD = 'amixer -q -D pulse sset Master 5%-' -local TOG_VOLUME_CMD = 'amixer -q -D pulse sset Master toggle' - -local PATH_TO_ICON = "/usr/share/icons/Arc/status/symbolic/audio-volume-muted-symbolic.svg" - -local widget = {} - -local popup = awful.popup{ - ontop = true, - visible = false, - shape = gears.shape.rounded_rect, - border_width = 1, - border_color = beautiful.bg_focus, - maximum_width = 400, - offset = { y = 5 }, - widget = {} -} -local rows = { - { widget = wibox.widget.textbox }, - layout = wibox.layout.fixed.vertical, -} -local function worker(user_args) - - local args = user_args or {} - - local main_color = args.main_color or beautiful.fg_color - local bg_color = args.bg_color or '#ffffff11' - local mute_color = args.mute_color or beautiful.fg_urgent - local path_to_icon = args.path_to_icon or PATH_TO_ICON - local thickness = args.thickness or 2 - local margins = args.height or 18 - local timeout = args.timeout or 1 - - local get_volume_cmd = args.get_volume_cmd or GET_VOLUME_CMD - local inc_volume_cmd = args.inc_volume_cmd or INC_VOLUME_CMD - local dec_volume_cmd = args.dec_volume_cmd or DEC_VOLUME_CMD - local tog_volume_cmd = args.tog_volume_cmd or TOG_VOLUME_CMD - - local icon = { - id = "icon", - image = path_to_icon, - resize = true, - widget = wibox.widget.imagebox, - } - - local volumearc = wibox.widget { - icon, - max_value = 1, - thickness = thickness, - start_angle = 4.71238898, -- 2pi*3/4 - forced_height = margins, - forced_width = margins, - bg = bg_color, - paddings = 2, - widget = wibox.container.arcchart - } - - local update_graphic = function(widget, stdout, _, _, _) - local mute = "on" - local volume = 0 - if not (stdout == nil or stdout == '') then - mute = string.match(stdout, "%[(o%D%D?)%]") -- \[(o\D\D?)\] - [on] or [off] - volume = string.match(tostring(stdout), "(%d?%d?%d)%%") -- (\d?\d?\d)\%) - volume = tonumber(string.format("% 3d", volume)) - end - widget.value = volume / 100; - widget.colors = mute == 'off' - and { mute_color } - or { main_color } - end - - local button_press = args.button_press or function(_, _, _, button) - if (button == 4) then awful.spawn(inc_volume_cmd, false) - elseif (button == 5) then awful.spawn(dec_volume_cmd, false) - elseif (button == 1) then awful.spawn(tog_volume_cmd, false) - end - - spawn.easy_async(get_volume_cmd, function(stdout, stderr, exitreason, exitcode) - update_graphic(volumearc, stdout, stderr, exitreason, exitcode) - end) - end - volumearc:connect_signal("button::press", button_press) - - local rebuild_widget = function(stdout) - for i = 0, #rows do rows[i]=nil end - - for line in stdout:gmatch("[^\r\n]+") do - - local row = wibox.widget { - text = line, - widget = wibox.widget.textbox - } - table.insert(rows, row) - end - - popup:setup(rows) - end - - volumearc:buttons( - awful.util.table.join( - awful.button({}, 3, function() - if popup.visible then - popup.visible = not popup.visible - else - spawn.easy_async([[bash -c "cat /proc/asound/cards"]], function(stdout, stderr) - rebuild_widget(stdout, stderr) - popup:move_next_to(mouse.current_widget_geometry) - end) - end - end) - ) - ) - - - - watch(get_volume_cmd, timeout, update_graphic, volumearc) - - return volumearc -end - -return setmetatable(widget, { __call = function(_, ...) return worker(...) end }) -- cgit v1.2.3