-local markup = require("lain.util.markup")
-local run_in_terminal = require("lain.helpers").run_in_terminal
-
-local awful = require("awful")
-local beautiful = require("beautiful")
-local wibox = require("wibox")
-
-local io = io
-local string = { format = string.format,
- match = string.match }
-
-local setmetatable = setmetatable
-
--- ALSA volume infos
--- nain.widgets.alsa
-local alsa = {
- volume = 0,
- mute = false,
-}
-
-function worker(args)
- local args = args or {}
- local channel = args.channel or "Master"
- local step = args.step or "1%"
- local header = args.header or " Vol "
- local header_color = args.header_color or beautiful.fg_normal or "#FFFFFF"
- local color = args.color or beautiful.fg_focus or "#FFFFFF"
-
- local myvolume = wibox.widget.textbox()
- local myvolumeupdate = function()
- local f = io.popen('amixer get ' .. channel)
- local mixer = f:read("*all")
- f:close()
-
- local volume, mute = string.match(mixer, "([%d]+)%%.*%[([%l]*)")
-
- if volume == nil
- then
- alsa.volume = 0
- else
- alsa.volume = volume
- end
-
- if mute == nil or mute == 'on'
- then
- alsa.mute = true
- mute = ''
- else
- alsa.mute = false
- mute = 'M'
- end
-
- local ret = markup(color, string.format("%d%s", volume, mute))
- myvolume:set_markup(markup(header_color, header) .. ret .. " ")
+local helpers = require("lain.helpers")
+local shell = require("awful.util").shell
+local wibox = require("wibox")
+local string = { match = string.match,
+ format = string.format }
+local setmetatable = setmetatable
+
+-- ALSA volume
+-- lain.widgets.alsa
+local alsa = helpers.make_widget_textbox()
+
+local function worker(args)
+ local args = args or {}
+ local timeout = args.timeout or 5
+ local settings = args.settings or function() end
+
+ alsa.cmd = args.cmd or "amixer"
+ alsa.channel = args.channel or "Master"
+ alsa.togglechannel = args.togglechannel
+
+ if alsa.togglechannel then
+ alsa.cmd = { shell, "-c", string.format("%s get %s; %s get %s",
+ alsa.cmd, alsa.channel, alsa.cmd, alsa.togglechannel) }