mirror of https://github.com/lcpz/lain.git
taskwarrior: asynchronous; #213 enhanced
This commit is contained in:
parent
156515eb28
commit
099e23aac2
|
@ -1,4 +1,4 @@
|
||||||
**Please read the wiki and browse the Issues section first.**
|
**Please read the [wiki](https://github.com/copycat-killer/lain/wiki) and search the [Issues section](https://github.com/copycat-killer/lain/issues) first.**
|
||||||
|
|
||||||
If you can't find a solution there, then go ahead and provide:
|
If you can't find a solution there, then go ahead and provide:
|
||||||
|
|
||||||
|
|
Binary file not shown.
Before Width: | Height: | Size: 267 B |
Binary file not shown.
Before Width: | Height: | Size: 253 B |
Before Width: | Height: | Size: 1.2 KiB After Width: | Height: | Size: 1.2 KiB |
Binary file not shown.
Before Width: | Height: | Size: 941 B |
|
@ -15,7 +15,6 @@ local os = { date = os.date }
|
||||||
local string = { format = string.format,
|
local string = { format = string.format,
|
||||||
gsub = string.gsub }
|
gsub = string.gsub }
|
||||||
local tonumber = tonumber
|
local tonumber = tonumber
|
||||||
local setmetatable = setmetatable
|
|
||||||
|
|
||||||
-- Calendar notification
|
-- Calendar notification
|
||||||
-- lain.widgets.calendar
|
-- lain.widgets.calendar
|
||||||
|
@ -94,16 +93,18 @@ function calendar.attach(widget, args)
|
||||||
calendar.notification_preset.bg = "#000000"
|
calendar.notification_preset.bg = "#000000"
|
||||||
end
|
end
|
||||||
|
|
||||||
widget:connect_signal("mouse::enter", function () calendar.show(0, 0, calendar.scr_pos) end)
|
if widget then
|
||||||
widget:connect_signal("mouse::leave", function () calendar.hide() end)
|
widget:connect_signal("mouse::enter", function () calendar.show() end)
|
||||||
widget:buttons(awful.util.table.join(awful.button({ }, 1, function ()
|
widget:connect_signal("mouse::leave", function () calendar.hide() end)
|
||||||
calendar.show(0, -1, calendar.scr_pos) end),
|
widget:buttons(awful.util.table.join(awful.button({ }, 1, function ()
|
||||||
awful.button({ }, 3, function ()
|
calendar.show(0, -1, calendar.scr_pos) end),
|
||||||
calendar.show(0, 1, calendar.scr_pos) end),
|
awful.button({ }, 3, function ()
|
||||||
awful.button({ }, 4, function ()
|
calendar.show(0, 1, calendar.scr_pos) end),
|
||||||
calendar.show(0, -1, calendar.scr_pos) end),
|
awful.button({ }, 4, function ()
|
||||||
awful.button({ }, 5, function ()
|
calendar.show(0, -1, calendar.scr_pos) end),
|
||||||
calendar.show(0, 1, calendar.scr_pos) end)))
|
awful.button({ }, 5, function ()
|
||||||
|
calendar.show(0, 1, calendar.scr_pos) end)))
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
return setmetatable(calendar, { __call = function(_, ...) return create(...) end })
|
return calendar
|
||||||
|
|
|
@ -46,7 +46,9 @@ end
|
||||||
function redshift:attach(widget, fun)
|
function redshift:attach(widget, fun)
|
||||||
redshift.update_fun = fun or function() end
|
redshift.update_fun = fun or function() end
|
||||||
if not redshift.pid then redshift:start() end
|
if not redshift.pid then redshift:start() end
|
||||||
widget:buttons(awful.util.table.join(awful.button({}, 1, function () redshift:toggle() end)))
|
if widget then
|
||||||
|
widget:buttons(awful.util.table.join(awful.button({}, 1, function () redshift:toggle() end)))
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
return redshift
|
return redshift
|
||||||
|
|
|
@ -6,144 +6,77 @@
|
||||||
|
|
||||||
--]]
|
--]]
|
||||||
|
|
||||||
local icons_dir = require("lain.helpers").icons_dir
|
local helpers = require("lain.helpers")
|
||||||
|
local awful = require("awful")
|
||||||
local awful = require("awful")
|
local naughty = require("naughty")
|
||||||
local beautiful = require("beautiful")
|
local string = { format = string.format, gsub = string.gsub }
|
||||||
local naughty = require("naughty")
|
|
||||||
|
|
||||||
local io = io
|
|
||||||
local string = { len = string.len }
|
|
||||||
local tonumber = tonumber
|
|
||||||
|
|
||||||
local setmetatable = setmetatable
|
|
||||||
|
|
||||||
-- Taskwarrior notification
|
-- Taskwarrior notification
|
||||||
-- lain.widgets.contrib.task
|
-- lain.widgets.contrib.task
|
||||||
local task = {}
|
local task = {}
|
||||||
|
|
||||||
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()
|
function task.hide()
|
||||||
if task_notification ~= nil then
|
if not task.notification then return end
|
||||||
naughty.destroy(task_notification)
|
naughty.destroy(task.notification)
|
||||||
task_notification = nil
|
task.notification = nil
|
||||||
end
|
|
||||||
end
|
end
|
||||||
|
|
||||||
function task.show(scr_pos)
|
function task.show(scr)
|
||||||
task.hide()
|
task.hide()
|
||||||
|
|
||||||
local f, c_text, scrp
|
|
||||||
|
|
||||||
if task.followtag then
|
if task.followtag then
|
||||||
scrp = awful.screen.focused()
|
task.notification_preset.screen = awful.screen.focused()
|
||||||
else
|
elseif scr then
|
||||||
scrp = scr_pos or task.scr_pos
|
task.notification_preset.screen = scr
|
||||||
end
|
end
|
||||||
|
|
||||||
f = io.popen('task ' .. task.cmdline)
|
helpers.async(string.format("%s -c '%s'", awful.util.shell, task.cmd),
|
||||||
c_text = "<span font='"
|
function(f)
|
||||||
.. task.font .. " "
|
task.notification = naughty.notify({
|
||||||
.. task.font_size .. "'>"
|
preset = task_notification_preset,
|
||||||
.. awful.util.escape(f:read("*all"):gsub("\n*$", ""))
|
title = task.cmd,
|
||||||
.. "</span>"
|
text = markup.font(task.notification_preset.font,
|
||||||
f:close()
|
awful.util.escape(f:gsub("\n*$", "")))
|
||||||
|
})
|
||||||
task_notification = naughty.notify({ title = "[task next]",
|
end)
|
||||||
text = c_text,
|
|
||||||
icon = task.notify_icon,
|
|
||||||
position = task.position,
|
|
||||||
fg = task.fg,
|
|
||||||
bg = task.bg,
|
|
||||||
timeout = task.timeout,
|
|
||||||
screen = scrp
|
|
||||||
})
|
|
||||||
end
|
end
|
||||||
|
|
||||||
function task.prompt_add()
|
function task.prompt()
|
||||||
awful.prompt.run({ prompt = "Add task: " },
|
awful.prompt.run {
|
||||||
mypromptbox[awful.screen.focused()].widget,
|
prompt = task.prompt_text,
|
||||||
function (...)
|
textbox = awful.screen.focused().mypromptbox.widget,
|
||||||
local f = io.popen("task add " .. ...)
|
exe_callback = function(t)
|
||||||
c_text = "\n<span font='"
|
helpers.async(string.format("%s -c '%s'", awful.util.shell, t),
|
||||||
.. task.font .. " "
|
function(f)
|
||||||
.. task.font_size .. "'>"
|
naughty.notify {
|
||||||
.. awful.util.escape(f:read("*all"))
|
preset = task_notification_preset,
|
||||||
.. "</span>"
|
title = t,
|
||||||
f:close()
|
text = markup.font(task.notification_preset.font,
|
||||||
|
awful.util.escape(f:gsub("\n*$", "")))
|
||||||
naughty.notify({
|
}
|
||||||
text = c_text,
|
end)
|
||||||
icon = task.notify_icon,
|
end,
|
||||||
position = task.position,
|
history_path = awful.util.getdir("cache") .. "/history_task"
|
||||||
fg = task.fg,
|
}
|
||||||
bg = task.bg,
|
|
||||||
timeout = task.timeout,
|
|
||||||
})
|
|
||||||
end,
|
|
||||||
nil,
|
|
||||||
awful.util.getdir("cache") .. "/history_task_add")
|
|
||||||
end
|
|
||||||
|
|
||||||
function task.prompt_search()
|
|
||||||
awful.prompt.run({ prompt = "Search task: " },
|
|
||||||
mypromptbox[awful.screen.focused()].widget,
|
|
||||||
function (...)
|
|
||||||
local f = io.popen("task " .. ...)
|
|
||||||
c_text = f:read("*all"):gsub(" \n*$", "")
|
|
||||||
f:close()
|
|
||||||
|
|
||||||
if string.len(c_text) == 0
|
|
||||||
then
|
|
||||||
c_text = "No results found."
|
|
||||||
else
|
|
||||||
c_text = "<span font='"
|
|
||||||
.. task.font .. " "
|
|
||||||
.. task.font_size .. "'>"
|
|
||||||
.. awful.util.escape(c_text)
|
|
||||||
.. "</span>"
|
|
||||||
end
|
|
||||||
|
|
||||||
naughty.notify({
|
|
||||||
title = "[task next " .. ... .. "]",
|
|
||||||
text = c_text,
|
|
||||||
icon = task.notify_icon,
|
|
||||||
position = task.position,
|
|
||||||
fg = task.fg,
|
|
||||||
bg = task.bg,
|
|
||||||
timeout = task.timeout,
|
|
||||||
screen = awful.screen.focused()
|
|
||||||
})
|
|
||||||
end,
|
|
||||||
nil,
|
|
||||||
awful.util.getdir("cache") .. "/history_task")
|
|
||||||
end
|
end
|
||||||
|
|
||||||
function task.attach(widget, args)
|
function task.attach(widget, args)
|
||||||
local args = args or {}
|
local args = args or {}
|
||||||
|
task.show_cmd = args.cmd or "task"
|
||||||
|
task.prompt_text = args.prompt_text or "Enter task command: "
|
||||||
|
task.followtag = args.followtag or false
|
||||||
|
task.notification_preset = args.notification_preset
|
||||||
|
|
||||||
task.font_size = tonumber(args.font_size) or 12
|
if not task.notification_preset then
|
||||||
task.font = args.font or beautiful.font:sub(beautiful.font:find(""),
|
task.notification_preset = naughty.config.defaults
|
||||||
findLast(beautiful.font, " "))
|
task.notification_preset.font = "Monospace 10"
|
||||||
task.fg = args.fg or beautiful.fg_normal or "#FFFFFF"
|
task.notification_preset.icon = helpers.icons_dir .. "/taskwarrior.png"
|
||||||
task.bg = args.bg or beautiful.bg_normal or "#FFFFFF"
|
end
|
||||||
task.position = args.position or "top_right"
|
|
||||||
task.timeout = args.timeout or 7
|
|
||||||
task.scr_pos = args.scr_pos or 1
|
|
||||||
task.followtag = args.followtag or false
|
|
||||||
task.cmdline = args.cmdline or "next"
|
|
||||||
|
|
||||||
task.notify_icon = icons_dir .. "/taskwarrior/task.png"
|
if widget then
|
||||||
task.notify_icon_small = icons_dir .. "/taskwarrior/tasksmall.png"
|
widget:connect_signal("mouse::enter", function () task.show() end)
|
||||||
|
widget:connect_signal("mouse::leave", function () task.hide() end)
|
||||||
widget:connect_signal("mouse::enter", function () task.show(task.scr_pos) end)
|
end
|
||||||
widget:connect_signal("mouse::leave", function () task.hide() end)
|
|
||||||
end
|
end
|
||||||
|
|
||||||
return setmetatable(task, { __call = function(_, ...) return create(...) end })
|
return task
|
||||||
|
|
|
@ -37,7 +37,7 @@ function fs.show(seconds, scr)
|
||||||
if fs.followtag then
|
if fs.followtag then
|
||||||
fs.notification_preset.screen = focused()
|
fs.notification_preset.screen = focused()
|
||||||
elseif scr then
|
elseif scr then
|
||||||
fs.notification_preset.screen = scr
|
fs.notification_preset.screen = scr or 1
|
||||||
end
|
end
|
||||||
|
|
||||||
local cmd = (fs.options and string.format("dfs %s", fs.options)) or "dfs"
|
local cmd = (fs.options and string.format("dfs %s", fs.options)) or "dfs"
|
||||||
|
@ -74,7 +74,6 @@ local function worker(args)
|
||||||
|
|
||||||
helpers.set_map(partition, false)
|
helpers.set_map(partition, false)
|
||||||
|
|
||||||
|
|
||||||
function update()
|
function update()
|
||||||
fs_info, fs_now = {}, {}
|
fs_info, fs_now = {}, {}
|
||||||
helpers.async(string.format("%s -c 'LC_ALL=C df -k --output=target,size,used,avail,pcent'", shell), function(f)
|
helpers.async(string.format("%s -c 'LC_ALL=C df -k --output=target,size,used,avail,pcent'", shell), function(f)
|
||||||
|
@ -107,11 +106,9 @@ local function worker(args)
|
||||||
|
|
||||||
if notify == "on" and tonumber(fs_now.used) >= 99 and not helpers.get_map(partition) then
|
if notify == "on" and tonumber(fs_now.used) >= 99 and not helpers.get_map(partition) then
|
||||||
naughty.notify({
|
naughty.notify({
|
||||||
title = "Warning",
|
preset = naughty.config.presets.critical,
|
||||||
text = partition .. " is empty!",
|
title = "Warning",
|
||||||
timeout = 8,
|
text = partition .. " is empty",
|
||||||
fg = "#000000",
|
|
||||||
bg = "#FFFFFF"
|
|
||||||
})
|
})
|
||||||
helpers.set_map(partition, true)
|
helpers.set_map(partition, true)
|
||||||
else
|
else
|
||||||
|
|
2
wiki
2
wiki
|
@ -1 +1 @@
|
||||||
Subproject commit 66836bbf1ffc0dd3bd3aef4799fff78ded9df4ec
|
Subproject commit 2f7c2a96a29a94829acf0b9e7fb614a7432a5092
|
Loading…
Reference in New Issue