taskwarrior: asynchronous; #213 enhanced

This commit is contained in:
copycat-killer 2017-01-23 20:58:19 +01:00
parent 156515eb28
commit 099e23aac2
10 changed files with 74 additions and 141 deletions

View File

@ -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

View File

Before

Width:  |  Height:  |  Size: 1.2 KiB

After

Width:  |  Height:  |  Size: 1.2 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 941 B

View File

@ -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

View File

@ -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

View File

@ -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

View File

@ -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

@ -1 +1 @@
Subproject commit 66836bbf1ffc0dd3bd3aef4799fff78ded9df4ec Subproject commit 2f7c2a96a29a94829acf0b9e7fb614a7432a5092