]> git.rmz.io Git - dotfiles.git/blobdiff - awesome/widgets/mpd_widget.lua
awesome/mpd_widget: request albumart when getting info
[dotfiles.git] / awesome / widgets / mpd_widget.lua
index f5f0ce74f640a32424504a1fc27d53e8bb539202..2c6ab78ec3ce8888db1fbe4393a54de3a588958e 100644 (file)
@@ -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
@@ -40,16 +48,29 @@ function widget:get_info(callback)
     self._connection:send("status", function(_, s) status = s end)
 
     local song = nil
-    self._connection:send("currentsong", function(_, s) song = s end)
 
-    self._connection:send("ping", function()
+    self._connection:send("currentsong", function(_, s)
+        song = s
+        self._connection:albumart(song.file, function(_, art)
+            local info = {}
+            if art and art.binary then
+                info.icon = '/tmp/test.jpg'
+                local f = io.open(info.icon, 'w')
+                f:write(art.binary)
+                f:close()
+            end
 
-        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 "")
-        callback(info)
-        return false
+            info.title = status.state .. " " .. status.song .. "/" .. status.playlistlength .. " " .. song_duration(status.elapsed, status.duration)
+            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)
+        end)
     end)
 end
 
@@ -58,10 +79,11 @@ function widget:popup_show()
         if self._notification then return end
         self._notification = naughty.notify(
             { title = table.title
-            -- , icon = img
+            , icon = table.icon
+            , icon_size = 64
             , text = table.text
             , timeout = 0
-            , destroy = function() self._timer:stop() end
+            , destroy = function() self._timer:stop(); self._notification = nil end
             })
         self._timer:start()
     end)
@@ -131,13 +153,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 +175,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,
+}