From 48df364e202b040d389debd3f07211f26e777333 Mon Sep 17 00:00:00 2001 From: Luka5W <74739057+Luka5W@users.noreply.github.com> Date: Thu, 5 Oct 2023 22:17:03 +0000 Subject: [PATCH 1/7] added options card, value_type, mixer for amixer and added toggle_cmd which overrides broken amixer unmute --- volume-widget/volume.lua | 24 ++++++++++++++++-------- 1 file changed, 16 insertions(+), 8 deletions(-) diff --git a/volume-widget/volume.lua b/volume-widget/volume.lua index 4c440422..6de3ef8b 100644 --- a/volume-widget/volume.lua +++ b/volume-widget/volume.lua @@ -17,10 +17,10 @@ local utils = require("awesome-wm-widgets.volume-widget.utils") local LIST_DEVICES_CMD = [[sh -c "pacmd list-sinks; pacmd list-sources"]] -local function GET_VOLUME_CMD(device) return 'amixer -D ' .. device .. ' sget Master' end -local function INC_VOLUME_CMD(device, step) return 'amixer -D ' .. device .. ' sset Master ' .. step .. '%+' end -local function DEC_VOLUME_CMD(device, step) return 'amixer -D ' .. device .. ' sset Master ' .. step .. '%-' end -local function TOG_VOLUME_CMD(device) return 'amixer -D ' .. device .. ' sset Master toggle' end +local function GET_VOLUME_CMD(card, device, mixer) return 'amixer -c '..card..' -D '..device..' sget '..mixer end +local function INC_VOLUME_CMD(card, device, mixer, value_type, step) return 'amixer -c '..card..' -D '..device..' sset '..mixer..' '..value_type..' '..step..'%+' end +local function DEC_VOLUME_CMD(card, device, mixer, value_type, step) return 'amixer -c '..card..' -D '..device..' sset '..mixer..' '..value_type..' '..step..'%-' end +local function TOG_VOLUME_CMD(card, device, mixer) return 'amixer -c '..card..' -D '..device..' sset '..mixer..' toggle' end local widget_types = { @@ -167,7 +167,11 @@ local function worker(user_args) local widget_type = args.widget_type local refresh_rate = args.refresh_rate or 1 local step = args.step or 5 + local card = args.card or 1 local device = args.device or 'pulse' + local mixer = args.mixer or 'Master' + local value_type = args.value_type or '-M' + local toggle_cmd = args.toggle_cmd or nil if widget_types[widget_type] == nil then volume.widget = widget_types['icon_and_text'].get_widget(args.icon_and_text_args) @@ -186,15 +190,19 @@ local function worker(user_args) end function volume:inc(s) - spawn.easy_async(INC_VOLUME_CMD(device, s or step), function(stdout) update_graphic(volume.widget, stdout) end) + spawn.easy_async(INC_VOLUME_CMD(card, device, mixer, value_type, s or step), function(stdout) update_graphic(volume.widget, stdout) end) end function volume:dec(s) - spawn.easy_async(DEC_VOLUME_CMD(device, s or step), function(stdout) update_graphic(volume.widget, stdout) end) + spawn.easy_async(DEC_VOLUME_CMD(card, device, mixer, value_type, s or step), function(stdout) update_graphic(volume.widget, stdout) end) end function volume:toggle() - spawn.easy_async(TOG_VOLUME_CMD(device), function(stdout) update_graphic(volume.widget, stdout) end) + if toggle_cmd == nil then + spawn.easy_async(TOG_VOLUME_CMD(card, device, mixer), function(stdout) update_graphic(volume.widget, stdout) end) + else + spawn.easy_async(toggle_cmd, function(stdout) spawn.easy_async(GET_VOLUME_CMD(card, device, mixer), function(stdout) update_graphic(volume.widget, stdout) end) end) + end end function volume:mixer() @@ -220,7 +228,7 @@ local function worker(user_args) ) ) - watch(GET_VOLUME_CMD(device), refresh_rate, update_graphic, volume.widget) + watch(GET_VOLUME_CMD(card, device, mixer), refresh_rate, update_graphic, volume.widget) return volume.widget end From 3f9c9b93e6d34a76f75a38bba2902021efe99ddf Mon Sep 17 00:00:00 2001 From: Luka5W <74739057+Luka5W@users.noreply.github.com> Date: Thu, 5 Oct 2023 23:12:05 +0000 Subject: [PATCH 2/7] changed the name to match the suggested name in #396 --- volume-widget/volume.lua | 20 ++++++++++---------- 1 file changed, 10 insertions(+), 10 deletions(-) diff --git a/volume-widget/volume.lua b/volume-widget/volume.lua index 6de3ef8b..fdcc2a0f 100644 --- a/volume-widget/volume.lua +++ b/volume-widget/volume.lua @@ -17,10 +17,10 @@ local utils = require("awesome-wm-widgets.volume-widget.utils") local LIST_DEVICES_CMD = [[sh -c "pacmd list-sinks; pacmd list-sources"]] -local function GET_VOLUME_CMD(card, device, mixer) return 'amixer -c '..card..' -D '..device..' sget '..mixer end -local function INC_VOLUME_CMD(card, device, mixer, value_type, step) return 'amixer -c '..card..' -D '..device..' sset '..mixer..' '..value_type..' '..step..'%+' end -local function DEC_VOLUME_CMD(card, device, mixer, value_type, step) return 'amixer -c '..card..' -D '..device..' sset '..mixer..' '..value_type..' '..step..'%-' end -local function TOG_VOLUME_CMD(card, device, mixer) return 'amixer -c '..card..' -D '..device..' sset '..mixer..' toggle' end +local function GET_VOLUME_CMD(card, device, mixctrl) return 'amixer -c '..card..' -D '..device..' sget '..mixctrl end +local function INC_VOLUME_CMD(card, device, mixctrl, value_type, step) return 'amixer -c '..card..' -D '..device..' sset '..mixctrl..' '..value_type..' '..step..'%+' end +local function DEC_VOLUME_CMD(card, device, mixctrl, value_type, step) return 'amixer -c '..card..' -D '..device..' sset '..mixctrl..' '..value_type..' '..step..'%-' end +local function TOG_VOLUME_CMD(card, device, mixctrl) return 'amixer -c '..card..' -D '..device..' sset '..mixctrl..' toggle' end local widget_types = { @@ -169,7 +169,7 @@ local function worker(user_args) local step = args.step or 5 local card = args.card or 1 local device = args.device or 'pulse' - local mixer = args.mixer or 'Master' + local mixctrl = args.mixctrl or 'Master' local value_type = args.value_type or '-M' local toggle_cmd = args.toggle_cmd or nil @@ -190,18 +190,18 @@ local function worker(user_args) end function volume:inc(s) - spawn.easy_async(INC_VOLUME_CMD(card, device, mixer, value_type, s or step), function(stdout) update_graphic(volume.widget, stdout) end) + spawn.easy_async(INC_VOLUME_CMD(card, device, mixctrl, value_type, s or step), function(stdout) update_graphic(volume.widget, stdout) end) end function volume:dec(s) - spawn.easy_async(DEC_VOLUME_CMD(card, device, mixer, value_type, s or step), function(stdout) update_graphic(volume.widget, stdout) end) + spawn.easy_async(DEC_VOLUME_CMD(card, device, mixctrl, value_type, s or step), function(stdout) update_graphic(volume.widget, stdout) end) end function volume:toggle() if toggle_cmd == nil then - spawn.easy_async(TOG_VOLUME_CMD(card, device, mixer), function(stdout) update_graphic(volume.widget, stdout) end) + spawn.easy_async(TOG_VOLUME_CMD(card, device, mixctrl), function(stdout) update_graphic(volume.widget, stdout) end) else - spawn.easy_async(toggle_cmd, function(stdout) spawn.easy_async(GET_VOLUME_CMD(card, device, mixer), function(stdout) update_graphic(volume.widget, stdout) end) end) + spawn.easy_async(toggle_cmd, function(stdout) spawn.easy_async(GET_VOLUME_CMD(card, device, mixctrl), function(stdout) update_graphic(volume.widget, stdout) end) end) end end @@ -228,7 +228,7 @@ local function worker(user_args) ) ) - watch(GET_VOLUME_CMD(card, device, mixer), refresh_rate, update_graphic, volume.widget) + watch(GET_VOLUME_CMD(card, device, mixctrl), refresh_rate, update_graphic, volume.widget) return volume.widget end From d2e04c462649214ef32fb0332150e17125bba325 Mon Sep 17 00:00:00 2001 From: Luka5W <74739057+Luka5W@users.noreply.github.com> Date: Fri, 6 Oct 2023 00:33:02 +0000 Subject: [PATCH 3/7] fixed colors for light themes --- volume-widget/volume.lua | 21 +++++++++++++++++---- 1 file changed, 17 insertions(+), 4 deletions(-) diff --git a/volume-widget/volume.lua b/volume-widget/volume.lua index fdcc2a0f..54918fba 100644 --- a/volume-widget/volume.lua +++ b/volume-widget/volume.lua @@ -36,6 +36,7 @@ local rows = { layout = wibox.layout.fixed.vertical } local popup = awful.popup{ bg = beautiful.bg_normal, + fg = beautiful.fg_normal, ontop = true, visible = false, shape = gears.shape.rounded_rect, @@ -60,12 +61,12 @@ local function build_rows(devices, on_checkbox_click, device_type) local checkbox = wibox.widget { checked = device.is_default, - color = beautiful.bg_normal, + color = beautiful.fg_normal, paddings = 2, shape = gears.shape.circle, forced_width = 20, forced_height = 20, - check_color = beautiful.fg_urgent, + check_color = beautiful.fg_normal, widget = wibox.widget.checkbox } @@ -99,11 +100,22 @@ local function build_rows(devices, on_checkbox_click, device_type) layout = wibox.container.margin }, bg = beautiful.bg_normal, + fg = beautiful.fg_normal, widget = wibox.container.background } - row:connect_signal("mouse::enter", function(c) c:set_bg(beautiful.bg_focus) end) - row:connect_signal("mouse::leave", function(c) c:set_bg(beautiful.bg_normal) end) + row:connect_signal("mouse::enter", function(c) + checkbox:set_color(beautiful.fg_focus) + checkbox:set_check_color(beautiful.fg_focus) + c:set_fg(beautiful.fg_focus) + c:set_bg(beautiful.bg_focus) + end) + row:connect_signal("mouse::leave", function(c) + checkbox:set_color(beautiful.fg_normal) + checkbox:set_check_color(beautiful.fg_normal) + c:set_fg(beautiful.fg_normal) + c:set_bg(beautiful.bg_normal) + end) local old_cursor, old_wibox row:connect_signal("mouse::enter", function() @@ -138,6 +150,7 @@ local function build_header_row(text) widget = wibox.widget.textbox }, bg = beautiful.bg_normal, + fg = beautiful.fg_normal, widget = wibox.container.background } end From df4dd6d0f6f51f89e43631ff35e5204534fe931a Mon Sep 17 00:00:00 2001 From: Luka5W <74739057+Luka5W@users.noreply.github.com> Date: Sat, 7 Oct 2023 20:27:32 +0000 Subject: [PATCH 4/7] added documentation for added options, added additional info for icon_path --- volume-widget/README.md | 40 ++++++++++++++++++++++++++-------------- 1 file changed, 26 insertions(+), 14 deletions(-) diff --git a/volume-widget/README.md b/volume-widget/README.md index 034a8032..9b546a87 100644 --- a/volume-widget/README.md +++ b/volume-widget/README.md @@ -36,7 +36,15 @@ s.mytasklist, -- Middle widget }, ``` -Note that widget uses following command the get the current volume: `amixer -D pulse sget Master`, so please make sure that it works for you, otherwise you need to set parameter `device = 'default'`. +Note that the widget uses following command to get the current volume: `amixer -c 1 -D pulse sget Master`, so please make sure that it works for you, otherwise you need to set some parameters by entering this command in the terminal: + +Command output: +- Some data of a mixer: Override all parameters you've changed +- Error `Invalid card number`: Change parameter `-c`/ `card` +- Error `Mixer attach pulse error: No such file or directory`: Change parameter `-D`/ `device` +- Error `Unable to find simple control 'Master',0`: Change parameter `mixctrl` + +Note: `amixer[ -c ...][ -D ...]` returns a list of Mixers for the selected card/ device. omitting `-D` falls back to `default`. ### Shortcuts @@ -54,20 +62,24 @@ It is possible to customize the widget by providing a table with all or some of ### Generic parameter -| Name | Default | Description | -|---|---|---| -| `mixer_cmd` | `pavucontrol` | command to run on middle click (e.g. a mixer program) | -| `step` | 5 | How much the volume is raised or lowered at once (in %) | -| `widget_type`| `icon_and_text`| Widget type, one of `horizontal_bar`, `vertical_bar`, `icon`, `icon_and_text`, `arc` | -| `device` | `pulse` | Select the device name to control | +| Name | Default | Description | +|---------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------| +| `mixer_cmd` | `pavucontrol` | command to run on middle click (e.g. a mixer program) | +| `toggle_cmd` | *nil* | Use custom command instead of `amixer ... toggle` because [amixer's unmute option seems to be broken](https://superuser.com/a/822085) | +| `step` | 5 | How much the volume is raised or lowered at once (in %) | +| `widget_type` | `icon_and_text` | Widget type, one of `horizontal_bar`, `vertical_bar`, `icon`, `icon_and_text`, `arc` | +| `card` | 1 | Select the card name to control | +| `device` | `pulse` | Select the device name to control | +| `mixctrl` | `Master` | Select the mixer name to control | +| `value_type` | `-M` | Select how the volume is increased/ decreased (intended for `-M`/ `-R` parameters). See `man amixer` for additional info | Depends on the chosen widget type add parameters from the corresponding section below: #### `icon` parameters -| Name | Default | Description | -|---|---|---| -| `icon_dir`| `./icons`| Path to the folder with icons | +| Name | Default | Description | +|------------|----------------------|-----------------------------------------------| +| `icon_dir` | `[widget_dir]/icons` | Path to the folder with icons (absolute path) | _Note:_ if you are changing icons, the folder should contain following .svg images: - audio-volume-high-symbolic @@ -77,10 +89,10 @@ _Note:_ if you are changing icons, the folder should contain following .svg imag #### `icon_and_text` parameters -| Name | Default | Description | -|---|---|---| -| `icon_dir`| `./icons`| Path to the folder with icons | -| `font` | `beautiful.font` | Font name and size, like `Play 12` | +| Name | Default | Description | +|------------|----------------------|-----------------------------------------------| +| `icon_dir` | `[widget_dir]/icons` | Path to the folder with icons (absolute path) | +| `font` | `beautiful.font` | Font name and size, like `Play 12` | #### `arc` parameters From 390f501e52e59224b63bef2e797d53ce92531100 Mon Sep 17 00:00:00 2001 From: Luka5W <74739057+Luka5W@users.noreply.github.com> Date: Sat, 7 Oct 2023 20:47:23 +0000 Subject: [PATCH 5/7] added info about alternative toggle_command --- volume-widget/README.md | 2 ++ 1 file changed, 2 insertions(+) diff --git a/volume-widget/README.md b/volume-widget/README.md index 9b546a87..a1df845c 100644 --- a/volume-widget/README.md +++ b/volume-widget/README.md @@ -73,6 +73,8 @@ It is possible to customize the widget by providing a table with all or some of | `mixctrl` | `Master` | Select the mixer name to control | | `value_type` | `-M` | Select how the volume is increased/ decreased (intended for `-M`/ `-R` parameters). See `man amixer` for additional info | +Note: If unmuting or toggling using the default amixer command does not work, this command may work: `pactl set-sink-mute [card] toggle` + Depends on the chosen widget type add parameters from the corresponding section below: #### `icon` parameters From c76ea148334ee40d378a2d60cfcafad21b7fe3bb Mon Sep 17 00:00:00 2001 From: Luka5W <74739057+Luka5W@users.noreply.github.com> Date: Sat, 7 Oct 2023 21:50:02 +0000 Subject: [PATCH 6/7] bugfix: volume level was not displayed correctly --- volume-widget/volume.lua | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/volume-widget/volume.lua b/volume-widget/volume.lua index 54918fba..39dcd991 100644 --- a/volume-widget/volume.lua +++ b/volume-widget/volume.lua @@ -17,7 +17,7 @@ local utils = require("awesome-wm-widgets.volume-widget.utils") local LIST_DEVICES_CMD = [[sh -c "pacmd list-sinks; pacmd list-sources"]] -local function GET_VOLUME_CMD(card, device, mixctrl) return 'amixer -c '..card..' -D '..device..' sget '..mixctrl end +local function GET_VOLUME_CMD(card, device, mixctrl, value_type) return 'amixer -c '..card..' -D '..device..' sget '..mixctrl..' '..value_type end local function INC_VOLUME_CMD(card, device, mixctrl, value_type, step) return 'amixer -c '..card..' -D '..device..' sset '..mixctrl..' '..value_type..' '..step..'%+' end local function DEC_VOLUME_CMD(card, device, mixctrl, value_type, step) return 'amixer -c '..card..' -D '..device..' sset '..mixctrl..' '..value_type..' '..step..'%-' end local function TOG_VOLUME_CMD(card, device, mixctrl) return 'amixer -c '..card..' -D '..device..' sset '..mixctrl..' toggle' end @@ -214,7 +214,7 @@ local function worker(user_args) if toggle_cmd == nil then spawn.easy_async(TOG_VOLUME_CMD(card, device, mixctrl), function(stdout) update_graphic(volume.widget, stdout) end) else - spawn.easy_async(toggle_cmd, function(stdout) spawn.easy_async(GET_VOLUME_CMD(card, device, mixctrl), function(stdout) update_graphic(volume.widget, stdout) end) end) + spawn.easy_async(toggle_cmd, function(stdout) spawn.easy_async(GET_VOLUME_CMD(card, device, mixctrl, value_type), function(stdout) update_graphic(volume.widget, stdout) end) end) end end @@ -241,7 +241,7 @@ local function worker(user_args) ) ) - watch(GET_VOLUME_CMD(card, device, mixctrl), refresh_rate, update_graphic, volume.widget) + watch(GET_VOLUME_CMD(card, device, mixctrl, value_type), refresh_rate, update_graphic, volume.widget) return volume.widget end From 7ebd572f8b2a710e53572bb25fa29f000d9566ed Mon Sep 17 00:00:00 2001 From: Luka5W <74739057+Luka5W@users.noreply.github.com> Date: Sat, 7 Oct 2023 21:52:14 +0000 Subject: [PATCH 7/7] code cleanup --- volume-widget/volume.lua | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/volume-widget/volume.lua b/volume-widget/volume.lua index 39dcd991..3d3c16eb 100644 --- a/volume-widget/volume.lua +++ b/volume-widget/volume.lua @@ -214,7 +214,7 @@ local function worker(user_args) if toggle_cmd == nil then spawn.easy_async(TOG_VOLUME_CMD(card, device, mixctrl), function(stdout) update_graphic(volume.widget, stdout) end) else - spawn.easy_async(toggle_cmd, function(stdout) spawn.easy_async(GET_VOLUME_CMD(card, device, mixctrl, value_type), function(stdout) update_graphic(volume.widget, stdout) end) end) + spawn.easy_async(toggle_cmd, function(_stdout) spawn.easy_async(GET_VOLUME_CMD(card, device, mixctrl, value_type), function(stdout) update_graphic(volume.widget, stdout) end) end) end end