-local mpc = require("widgets/mpc")
-local textbox = require("wibox.widget.textbox")
-local gears = require("gears")
-local awful = require("awful")
+local awful = require("awful")
+local gears = require("gears")
+local mpc = require("widgets/mpc")
local naughty = require("naughty")
-local timer = require("gears.timer")
-
---TODO remove
-local dbg = require("gears.debug")
+local textbox = require("wibox.widget.textbox")
+local timer = require("gears.timer")
+local wibox = require("wibox")
local widget = {}
widget._textbox = textbox()
widget._currentsong = {}
+widget.scroll = wibox.widget {
+ layout = wibox.container.scroll.horizontal,
+ max_size = 200,
+ extra_space = 10,
+ step_function = wibox.container.scroll.step_functions.linear_increase,
+ speed = 20,
+ {
+ widget = widget._textbox,
+ }
+}
+
function widget:update_widget()
local text = ""
local artist = self._currentsong.artist
local title = self._currentsong.title
local file = self._currentsong.file
- text = text .. tostring(artist or "") .. " - " .. tostring(title or "")
if not artist then
text = string.format("%s", title or file )
else
local info = {}
info.title = status.state .. " " .. status.song .. "/" .. status.playlistlength .. " " .. song_duration(status.elapsed, status.duration)
- info.text = tostring(song.artist or "") .. " - " .. tostring(song.title or "") .. "\n"
- .. tostring(song.album or "")
+ if not song.artist then
+ info.text = string.format("%s", song.title or song.file)
+ else
+ info.text = string.format("%s - %s", song.artist, song.title)
+ end
+ if song.album then
+ info.text = info.text .. "\n" .. tostring(song.album or "")
+ end
callback(info)
- return false
end)
end
-- , icon = img
, text = table.text
, timeout = 0
- , destroy = function() self._timer:stop() end
+ , destroy = function() self._timer:stop(); self._notification = nil end
})
self._timer:start()
end)
self._timer:connect_signal("timeout", function() self:popup_update() end)
self._hover = false;
- self._textbox:connect_signal("mouse::enter", function() self._hover = true; self:popup_show() end)
- self._textbox:connect_signal("mouse::leave", function() self._hover = false; self:popup_hide(2) end)
+ self.scroll:connect_signal("mouse::enter", function() self._hover = true; self:popup_show() end)
+ self.scroll:connect_signal("mouse::leave", function() self._hover = false; self:popup_hide(2) end)
end
widget:run()
-widget._textbox:buttons(gears.table.join(
+widget.scroll:buttons(gears.table.join(
awful.button({}, 1, function() widget._connection:toggle_play() end)
, awful.button({}, 4, function() widget._connection:change_volume(5) end)
, awful.button({}, 5, function() widget._connection:change_volume(-5) end))
awful.key({ modkey }, ".", function() widget._connection:send("next") end,
{ description = "next track", group = "mpd" })
)
-return widget._textbox
+return {
+ layout = wibox.layout.align.horizontal,
+ forced_width = 200,
+ expand = "outside",
+ nil,
+ widget.scroll,
+ nil,
+}