]>
git.madduck.net Git - etc/awesome.git/blobdiff - widgets/contrib/task.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:
local task_notification = nil
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)
task_notification = nil
end
end
if task_notification ~= nil then
naughty.destroy(task_notification)
task_notification = nil
end
end
-function task: show(scr_pos)
- task: hide()
+function task. show(scr_pos)
+ task. hide()
- if task.followmouse then
- local scrp = mouse.screen
+ if task.followtag then
+ scrp = awful.screen.focused()
- local scrp = scr_pos or task.scr_pos
+ scrp = scr_pos or task.scr_pos
end
f = io.popen('task ' .. task.cmdline)
c_text = "<span font='"
.. task.font .. " "
.. task.font_size .. "'>"
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*$", "") )
-function task: prompt_add()
+function task. prompt_add()
awful.prompt.run({ prompt = "Add task: " },
awful.prompt.run({ prompt = "Add task: " },
- mypromptbox[mouse.screen ].widget,
+ mypromptbox[awful.screen.focused() ].widget,
function (...)
local f = io.popen("task add " .. ...)
c_text = "\n<span font='"
.. task.font .. " "
.. task.font_size .. "'>"
function (...)
local f = io.popen("task add " .. ...)
c_text = "\n<span font='"
.. task.font .. " "
.. task.font_size .. "'>"
+ .. awful.util.escape(f:read("*all") )
awful.util.getdir("cache") .. "/history_task_add")
end
awful.util.getdir("cache") .. "/history_task_add")
end
-function task: prompt_search()
+function task. prompt_search()
awful.prompt.run({ prompt = "Search task: " },
awful.prompt.run({ prompt = "Search task: " },
- mypromptbox[mouse.screen ].widget,
+ mypromptbox[awful.screen.focused() ].widget,
function (...)
local f = io.popen("task " .. ...)
c_text = f:read("*all"):gsub(" \n*$", "")
function (...)
local f = io.popen("task " .. ...)
c_text = f:read("*all"):gsub(" \n*$", "")
c_text = "<span font='"
.. task.font .. " "
.. task.font_size .. "'>"
c_text = "<span font='"
.. task.font .. " "
.. task.font_size .. "'>"
+ .. awful.util.escape(c_text)
fg = task.fg,
bg = task.bg,
timeout = task.timeout,
fg = task.fg,
bg = task.bg,
timeout = task.timeout,
+ screen = awful.screen.focused()
})
end,
nil,
awful.util.getdir("cache") .. "/history_task")
end
})
end,
nil,
awful.util.getdir("cache") .. "/history_task")
end
-function task: attach(widget, args)
+function task. attach(widget, args)
local args = args or {}
task.font_size = tonumber(args.font_size) or 12
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.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.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.followtag = args.followtag 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"
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(task.scr_pos) end)
- widget:connect_signal("mouse::leave", function () task: hide() end)
+ widget:connect_signal("mouse::enter", function () task. show(task.scr_pos) end)
+ widget:connect_signal("mouse::leave", function () task. hide() end)
end
return setmetatable(task, { __call = function(_, ...) return create(...) end })
end
return setmetatable(task, { __call = function(_, ...) return create(...) end })