X-Git-Url: https://git.rmz.io/dotfiles.git/blobdiff_plain/1529a3b60191542f2283015ec4bf1faea8f4725b..f7aa325093c2effacf903b6dbfb668371355421e:/awesome/widgets/mpd_widget.lua diff --git a/awesome/widgets/mpd_widget.lua b/awesome/widgets/mpd_widget.lua index f5f0ce7..4673929 100644 --- a/awesome/widgets/mpd_widget.lua +++ b/awesome/widgets/mpd_widget.lua @@ -1,23 +1,31 @@ -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 @@ -49,7 +57,6 @@ function widget:get_info(callback) info.text = tostring(song.artist or "") .. " - " .. tostring(song.title or "") .. "\n" .. tostring(song.album or "") callback(info) - return false end) end @@ -131,13 +138,13 @@ function widget:run() 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)) @@ -153,4 +160,11 @@ globalkeys = gears.table.join(globalkeys, 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, +}