]>
git.madduck.net Git - etc/awesome.git/blobdiff - widgets/mpd.lua
madduck's git repository
Every one of the projects in this repository is available at the canonical
URL git://git.madduck.net/madduck/pub/<projectpath> — see
each project's metadata for the exact URL.
All patches and comments are welcome. Please squash your changes to logical
commits before using git-format-patch and git-send-email to
patches@ git. madduck. net .
If you'd read over the Git project's submission guidelines and adhered to them,
I'd be especially grateful.
SSH access, as well as push access can be individually
arranged .
If you use my repositories frequently, consider adding the following
snippet to ~/.gitconfig and using the third clone URL listed for each
project:
[url "git://git.madduck.net/madduck/"]
insteadOf = madduck:
local naughty = require("naughty")
local wibox = require("wibox")
local naughty = require("naughty")
local wibox = require("wibox")
-local os = { execute = os.execute,
- getenv = os.getenv }
-local math = { floor = math.floor }
-local mouse = mouse
-local string = { format = string.format,
- match = string.match,
- gmatch = string.gmatch }
+local os = { execute = os.execute,
+ getenv = os.getenv }
+local math = { floor = math.floor }
+local string = { format = string.format,
+ match = string.match,
+ gmatch = string.gmatch }
local setmetatable = setmetatable
-- MPD infos
-- lain.widgets.mpd
local setmetatable = setmetatable
-- MPD infos
-- lain.widgets.mpd
+local mpd = helpers.make_widget_textbox()
local function worker(args)
local args = args or {}
local function worker(args)
local args = args or {}
local cover_size = args.cover_size or 100
local default_art = args.default_art or ""
local notify = args.notify or "on"
local cover_size = args.cover_size or 100
local default_art = args.default_art or ""
local notify = args.notify or "on"
- local followmouse = args.followmouse or false
+ local followtag = args.followtag or false
local echo_cmd = args.echo_cmd or "echo"
local settings = args.settings or function() end
local echo_cmd = args.echo_cmd or "echo"
local settings = args.settings or function() end
local mpdh = "telnet://" .. host .. ":" .. port
local echo = echo_cmd .. " 'password " .. password .. "\nstatus\ncurrentsong\nclose'"
local mpdh = "telnet://" .. host .. ":" .. port
local echo = echo_cmd .. " 'password " .. password .. "\nstatus\ncurrentsong\nclose'"
- mpd.widget = wibox.widget.textbox('')
-
mpd_notification_preset = {
title = "Now playing",
timeout = 6
mpd_notification_preset = {
title = "Now playing",
timeout = 6
artist = "N/A",
title = "N/A",
album = "N/A",
artist = "N/A",
title = "N/A",
album = "N/A",
+ genre = "N/A",
+ track = "N/A",
date = "N/A",
time = "N/A",
elapsed = "N/A"
date = "N/A",
time = "N/A",
elapsed = "N/A"
elseif k == "Artist" then mpd_now.artist = escape_f(v)
elseif k == "Title" then mpd_now.title = escape_f(v)
elseif k == "Album" then mpd_now.album = escape_f(v)
elseif k == "Artist" then mpd_now.artist = escape_f(v)
elseif k == "Title" then mpd_now.title = escape_f(v)
elseif k == "Album" then mpd_now.album = escape_f(v)
+ elseif k == "Genre" then mpd_now.genre = escape_f(v)
+ elseif k == "Track" then mpd_now.track = escape_f(v)
elseif k == "Date" then mpd_now.date = escape_f(v)
elseif k == "Time" then mpd_now.time = v
elseif k == "elapsed" then mpd_now.elapsed = string.match(v, "%d+")
elseif k == "Date" then mpd_now.date = escape_f(v)
elseif k == "Time" then mpd_now.time = v
elseif k == "elapsed" then mpd_now.elapsed = string.match(v, "%d+")
current_icon = default_art
end
current_icon = default_art
end
- if followmouse then
- mpd_notification_preset.screen = mouse.screen
+ if followtag then
+ mpd_notification_preset.screen = awful.screen.focused()
end
mpd.id = naughty.notify({
end
mpd.id = naughty.notify({
helpers.newtimer("mpd", timeout, mpd.update)
helpers.newtimer("mpd", timeout, mpd.update)
- return setmetatable(mpd, { __index = mpd.widget })
end
return setmetatable(mpd, { __call = function(_, ...) return worker(...) end })
end
return setmetatable(mpd, { __call = function(_, ...) return worker(...) end })