]>
git.madduck.net Git - etc/awesome.git/blobdiff - widgets/contrib/gpmdp.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:
-
- Licensed under GNU General Public License v2
- * (c) 2016, Alexandre Terrien
-
+
+ Licensed under GNU General Public License v2
+ * (c) 2016, Alexandre Terrien
+
-local helpers = require("lain.helpers")
-local json = require("lain.util.dkjson")
-
-local pread = require("awful.util").pread
-
-local naughty = require("naughty")
-local wibox = require("wibox")
+local helpers = require("lain.helpers")
+local json = require("lain.util.dkjson")
+local focused = require("awful.screen").focused
+local pread = require("awful.util").pread
+local naughty = require("naughty")
+local wibox = require("wibox")
+local next = next
+local os = { getenv = os.getenv }
local setmetatable = setmetatable
local setmetatable = setmetatable
-- Google Play Music Desktop infos
-- lain.widget.contrib.gpmdp
-- Google Play Music Desktop infos
-- lain.widget.contrib.gpmdp
local args = args or {}
local timeout = args.timeout or 2
local notify = args.notify or "off"
local args = args or {}
local timeout = args.timeout or 2
local notify = args.notify or "off"
- local followmouse = args.followmouse or false
+ local followtag = args.followtag or false
local file_location = args.file_location or
local file_location = args.file_location or
- os.getenv("HOME") .. "/.config/Google Play Music Desktop Player/json_store/playback.json"
+ os.getenv("HOME") .. "/.config/Google Play Music Desktop Player/json_store/playback.json"
local settings = args.settings or function() end
gpmdp.widget = wibox.widget.textbox('')
local settings = args.settings or function() end
gpmdp.widget = wibox.widget.textbox('')
- helpers.set_map("gpmpd _current", nil)
+ helpers.set_map("gpmdp _current", nil)
- file, err = io.open(file_location, "r")
- if not file
+ local filelines = helpers.lines_from(file_location)
+
+ if not next(filelines)
- gpm_now = {
- running = false,
- playing = false
- }
+ local gpm_now = { running = false, playing = false }
- dict, pos, err = json.decode(file:read "*a", 1, nil)
- file:close()
- gpm_now = {}
- gpm_now.artist = dict.song.artist
- gpm_now.album = dict.song.album
- gpm_now.title = dict.song.title
- gpm_now.cover_url = dict.song.albumArt
- gpm_now.playing = dict.playing
+ dict, pos, err = json.decode(table.concat(filelines), 1, nil)
+ local gpm_now = {}
+ gpm_now.artist = dict.song.artist
+ gpm_now.album = dict.song.album
+ gpm_now.title = dict.song.title
+ gpm_now.cover_url = dict.song.albumArt
+ gpm_now.playing = dict.playing
- if (pread("pidof 'Google Play Music Desktop Player'") ~= '') then
+
+ if pread("pidof 'Google Play Music Desktop Player'") ~= '' then
gpm_now.running = true
else
gpm_now.running = false
end
gpm_now.running = true
else
gpm_now.running = false
end
- gpmdp_notification_preset.text = string.format(
- "%s (%s) - %s",
- gpm_now.artist,
- gpm_now.album,
- gpm_now.title)
+ gpmdp_notification_preset.text = string.format("%s (%s) - %s", gpm_now.artist, gpm_now.album, gpm_now.title)
widget = gpmdp.widget
settings()
if gpm_now.playing
then
widget = gpmdp.widget
settings()
if gpm_now.playing
then
- if notify == "on" and gpm_now.title ~= helpers.get_map("gpmpd _current")
+ if notify == "on" and gpm_now.title ~= helpers.get_map("gpmdp _current")
- helpers.set_map("gpmpd_current", gpm_now.title)
-
- current_icon = "/tmp/gpmcover.png"
- os.execute("curl " .. gpm_now.cover_url .. " -o " .. current_icon)
+ helpers.set_map("gpmdp_current", gpm_now.title)
+ os.execute(string.format("curl %d -o /tmp/gpmcover.png", gpm_now.cover_url))
- if followmouse then
- gpmdp_notification_preset.screen = mouse.screen
+ if followtag then
+ gpmdp_notification_preset.screen = focused()
end
gpmdp.id = naughty.notify({
preset = gpmdp_notification_preset,
end
gpmdp.id = naughty.notify({
preset = gpmdp_notification_preset,
+ icon = "/tmp/gpmcover.png" ,
replaces_id = gpmdp.id,
}).id
end
replaces_id = gpmdp.id,
}).id
end
- elseif (not gpm_now.running)
+ elseif not gpm_now.running
- helpers.set_map("current mpd track ", nil)
+ helpers.set_map("gpmdp_current ", nil)