wrap widget in a function

This commit is contained in:
streetturtle 2020-11-23 09:55:37 -05:00
parent 0e1d31ad6f
commit 30199568c6
1 changed files with 106 additions and 95 deletions

View File

@ -19,7 +19,7 @@ local TOGGLE_MPD_CMD = "playerctl play-pause"
local PAUSE_MPD_CMD = "playerctl pause" local PAUSE_MPD_CMD = "playerctl pause"
local STOP_MPD_CMD = "playerctl stop" local STOP_MPD_CMD = "playerctl stop"
local NEXT_MPD_CMD = "playerctl next" local NEXT_MPD_CMD = "playerctl next"
local PREV_MPD_CMD = "playerctl prev" local PREV_MPD_CMD = "playerctl previous"
local PATH_TO_ICONS = "/usr/share/icons/Arc" local PATH_TO_ICONS = "/usr/share/icons/Arc"
local PAUSE_ICON_NAME = PATH_TO_ICONS .. "/actions/24/player_pause.png" local PAUSE_ICON_NAME = PATH_TO_ICONS .. "/actions/24/player_pause.png"
@ -27,17 +27,22 @@ local PLAY_ICON_NAME = PATH_TO_ICONS .. "/actions/24/player_play.png"
local STOP_ICON_NAME = PATH_TO_ICONS .. "/actions/24/player_stop.png" local STOP_ICON_NAME = PATH_TO_ICONS .. "/actions/24/player_stop.png"
local LIBRARY_ICON_NAME = PATH_TO_ICONS .. "/actions/24/music-library.png" local LIBRARY_ICON_NAME = PATH_TO_ICONS .. "/actions/24/music-library.png"
-- retriving song info
current_song, artist = nil, nil
local icon = wibox.widget { local mpdarc_widget = {}
local function worker(args)
-- retriving song info
local current_song, artist, mpdstatus
local icon = wibox.widget {
id = "icon", id = "icon",
widget = wibox.widget.imagebox, widget = wibox.widget.imagebox,
image = PLAY_ICON_NAME image = PLAY_ICON_NAME
} }
local mirrored_icon = wibox.container.mirror(icon, {horizontal = true}) local mirrored_icon = wibox.container.mirror(icon, {horizontal = true})
local mpdarc = wibox.widget { local mpdarc = wibox.widget {
mirrored_icon, mirrored_icon,
-- max_value = 1, -- max_value = 1,
-- value = 0, -- value = 0,
@ -49,16 +54,16 @@ local mpdarc = wibox.widget {
bg = "#ffffff11", bg = "#ffffff11",
paddings = 0, paddings = 0,
widget = wibox.container.arcchart widget = wibox.container.arcchart
} }
local mpdarc_icon_widget = wibox.container.mirror(mpdarc, {horizontal = true}) local mpdarc_icon_widget = wibox.container.mirror(mpdarc, {horizontal = true})
local mpdarc_current_song_widget = wibox.widget { local mpdarc_current_song_widget = wibox.widget {
id = 'current_song', id = 'current_song',
widget = wibox.widget.textbox, widget = wibox.widget.textbox,
font = 'Play 10' font = 'Play 10'
} }
local update_graphic = function(widget, stdout, _, _, _) local update_graphic = function(widget, stdout, _, _, _)
mpdstatus, artist, current_song = stdout:match("(%w+)%;+(.-)%;(.*)") mpdstatus, artist, current_song = stdout:match("(%w+)%;+(.-)%;(.*)")
if current_song ~= nil then if current_song ~= nil then
if current_song.len == 18 then if current_song.len == 18 then
@ -86,9 +91,9 @@ local update_graphic = function(widget, stdout, _, _, _)
mpdarc_current_song_widget.markup = "" mpdarc_current_song_widget.markup = ""
widget.colors = {beautiful.widget_red} widget.colors = {beautiful.widget_red}
end end
end end
mpdarc:connect_signal("button::press", function(_, _, _, button) mpdarc:connect_signal("button::press", function(_, _, _, button)
if (button == 1) then if (button == 1) then
awful.spawn(TOGGLE_MPD_CMD, false) -- left click awful.spawn(TOGGLE_MPD_CMD, false) -- left click
elseif (button == 2) then elseif (button == 2) then
@ -104,10 +109,10 @@ mpdarc:connect_signal("button::press", function(_, _, _, button)
spawn.easy_async(GET_MPD_CMD, function(stdout, stderr, exitreason, exitcode) spawn.easy_async(GET_MPD_CMD, function(stdout, stderr, exitreason, exitcode)
update_graphic(mpdarc, stdout, stderr, exitreason, exitcode) update_graphic(mpdarc, stdout, stderr, exitreason, exitcode)
end) end)
end) end)
local notification local notification
function show_MPD_status() local function show_MPD_status()
spawn.easy_async(GET_MPD_CMD, function(stdout, _, _, _) spawn.easy_async(GET_MPD_CMD, function(stdout, _, _, _)
notification = naughty.notify { notification = naughty.notify {
text = current_song .. " by " .. artist, text = current_song .. " by " .. artist,
@ -117,20 +122,26 @@ function show_MPD_status()
width = 600 width = 600
} }
end) end)
end end
mpdarc:connect_signal("mouse::enter", function() mpdarc:connect_signal("mouse::enter", function()
if current_song ~= nil and artist ~= nil then show_MPD_status() end if current_song ~= nil and artist ~= nil then show_MPD_status() end
end) end)
mpdarc:connect_signal("mouse::leave", mpdarc:connect_signal("mouse::leave",
function() naughty.destroy(notification) end) function() naughty.destroy(notification) end)
watch(GET_MPD_CMD, 1, update_graphic, mpdarc) watch(GET_MPD_CMD, 1, update_graphic, mpdarc)
local mpdarc_widget = wibox.widget { mpdarc_widget = wibox.widget {
screen = 'primary', screen = 'primary',
mpdarc_icon_widget, mpdarc_icon_widget,
mpdarc_current_song_widget, mpdarc_current_song_widget,
layout = wibox.layout.align.horizontal layout = wibox.layout.align.horizontal
} }
return mpdarc_widget return mpdarc_widget
end
return setmetatable(mpdarc_widget, { __call = function(_, ...)
return worker(...)
end })