local beautiful = require("beautiful")
local naughty = require("naughty")
+local mouse = mouse
local io = io
local string = { len = string.len }
local tonumber = tonumber
local task_notification = nil
+function findLast(haystack, needle)
+ local i=haystack:match(".*"..needle.."()")
+ if i==nil then return nil else return i-1 end
+end
+
function task:hide()
if task_notification ~= nil then
naughty.destroy(task_notification)
local f, c_text
- f = io.popen('task')
+ if task.followmouse then
+ local scrp = mouse.screen
+ else
+ local scrp = scr_pos or task.scr_pos
+ end
+
+ f = io.popen('task ' .. task.cmdline)
c_text = "<span font='"
.. task.font .. " "
.. task.font_size .. "'>"
- .. f:read("*all"):gsub("\n*$", "")
+ .. awful.util.escape(f:read("*all"):gsub("\n*$", ""))
.. "</span>"
f:close()
fg = task.fg,
bg = task.bg,
timeout = task.timeout,
- screen = scr_pos or 1
+ screen = scrp
})
end
c_text = "\n<span font='"
.. task.font .. " "
.. task.font_size .. "'>"
- .. f:read("*all")
+ .. awful.util.escape(f:read("*all"))
.. "</span>"
f:close()
c_text = "<span font='"
.. task.font .. " "
.. task.font_size .. "'>"
- .. c_text
+ .. awful.util.escape(c_text)
.. "</span>"
end
end
function task:attach(widget, args)
- local args = args or {}
-
- task.font_size = tonumber(args.font_size) or 12
- task.font = beautiful.font:sub(beautiful.font:find(""),
- beautiful.font:find(" "))
- task.fg = args.fg or beautiful.fg_normal or "#FFFFFF"
- task.bg = args.bg or beautiful.bg_normal or "#FFFFFF"
- task.position = args.position or "top_right"
- task.timeout = args.timeout or 7
- task.scr_pos = args.scr_pos or 1
+ local args = args or {}
+
+ task.font_size = tonumber(args.font_size) or 12
+ task.font = args.font or beautiful.font:sub(beautiful.font:find(""),
+ findLast(beautiful.font, " "))
+ task.fg = args.fg or beautiful.fg_normal or "#FFFFFF"
+ task.bg = args.bg or beautiful.bg_normal or "#FFFFFF"
+ task.position = args.position or "top_right"
+ task.timeout = args.timeout or 7
+ task.scr_pos = args.scr_pos or 1
+ task.followmouse = args.followmouse or false
+ task.cmdline = args.cmdline or "next"
task.notify_icon = icons_dir .. "/taskwarrior/task.png"
task.notify_icon_small = icons_dir .. "/taskwarrior/tasksmall.png"
- widget:connect_signal("mouse::enter", function () task:show(scr_pos) end)
+ widget:connect_signal("mouse::enter", function () task:show(task.scr_pos) end)
widget:connect_signal("mouse::leave", function () task:hide() end)
end