diff --git a/ISSUE_TEMPLATE.md b/ISSUE_TEMPLATE.md
index e98373d..e024e8b 100644
--- a/ISSUE_TEMPLATE.md
+++ b/ISSUE_TEMPLATE.md
@@ -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:
diff --git a/icons/redshift/redshift_off.png b/icons/redshift/redshift_off.png
deleted file mode 100644
index a92200f..0000000
Binary files a/icons/redshift/redshift_off.png and /dev/null differ
diff --git a/icons/redshift/redshift_on.png b/icons/redshift/redshift_on.png
deleted file mode 100644
index 205e0a7..0000000
Binary files a/icons/redshift/redshift_on.png and /dev/null differ
diff --git a/icons/taskwarrior/task.png b/icons/taskwarrior.png
similarity index 100%
rename from icons/taskwarrior/task.png
rename to icons/taskwarrior.png
diff --git a/icons/taskwarrior/tasksmall.png b/icons/taskwarrior/tasksmall.png
deleted file mode 100755
index 2de6946..0000000
Binary files a/icons/taskwarrior/tasksmall.png and /dev/null differ
diff --git a/widgets/calendar.lua b/widgets/calendar.lua
index a00caba..e4216e4 100644
--- a/widgets/calendar.lua
+++ b/widgets/calendar.lua
@@ -15,7 +15,6 @@ local os = { date = os.date }
local string = { format = string.format,
gsub = string.gsub }
local tonumber = tonumber
-local setmetatable = setmetatable
-- Calendar notification
-- lain.widgets.calendar
@@ -94,16 +93,18 @@ function calendar.attach(widget, args)
calendar.notification_preset.bg = "#000000"
end
- widget:connect_signal("mouse::enter", function () calendar.show(0, 0, calendar.scr_pos) end)
- widget:connect_signal("mouse::leave", function () calendar.hide() end)
- widget:buttons(awful.util.table.join(awful.button({ }, 1, function ()
- calendar.show(0, -1, calendar.scr_pos) end),
- awful.button({ }, 3, function ()
- calendar.show(0, 1, calendar.scr_pos) end),
- awful.button({ }, 4, function ()
- calendar.show(0, -1, calendar.scr_pos) end),
- awful.button({ }, 5, function ()
- calendar.show(0, 1, calendar.scr_pos) end)))
+ if widget then
+ widget:connect_signal("mouse::enter", function () calendar.show() end)
+ widget:connect_signal("mouse::leave", function () calendar.hide() end)
+ widget:buttons(awful.util.table.join(awful.button({ }, 1, function ()
+ calendar.show(0, -1, calendar.scr_pos) end),
+ awful.button({ }, 3, function ()
+ calendar.show(0, 1, calendar.scr_pos) end),
+ awful.button({ }, 4, function ()
+ calendar.show(0, -1, calendar.scr_pos) end),
+ awful.button({ }, 5, function ()
+ calendar.show(0, 1, calendar.scr_pos) end)))
+ end
end
-return setmetatable(calendar, { __call = function(_, ...) return create(...) end })
+return calendar
diff --git a/widgets/contrib/redshift.lua b/widgets/contrib/redshift.lua
index 8a768fb..fdda61f 100644
--- a/widgets/contrib/redshift.lua
+++ b/widgets/contrib/redshift.lua
@@ -46,7 +46,9 @@ end
function redshift:attach(widget, fun)
redshift.update_fun = fun or function() 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
return redshift
diff --git a/widgets/contrib/task.lua b/widgets/contrib/task.lua
index 6c8c9cc..2f57317 100644
--- a/widgets/contrib/task.lua
+++ b/widgets/contrib/task.lua
@@ -6,144 +6,77 @@
--]]
-local icons_dir = require("lain.helpers").icons_dir
-
-local awful = require("awful")
-local beautiful = require("beautiful")
-local naughty = require("naughty")
-
-local io = io
-local string = { len = string.len }
-local tonumber = tonumber
-
-local setmetatable = setmetatable
+local helpers = require("lain.helpers")
+local awful = require("awful")
+local naughty = require("naughty")
+local string = { format = string.format, gsub = string.gsub }
-- Taskwarrior notification
-- lain.widgets.contrib.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()
- if task_notification ~= nil then
- naughty.destroy(task_notification)
- task_notification = nil
- end
+ if not task.notification then return end
+ naughty.destroy(task.notification)
+ task.notification = nil
end
-function task.show(scr_pos)
+function task.show(scr)
task.hide()
- local f, c_text, scrp
-
if task.followtag then
- scrp = awful.screen.focused()
- else
- scrp = scr_pos or task.scr_pos
+ task.notification_preset.screen = awful.screen.focused()
+ elseif scr then
+ task.notification_preset.screen = scr
end
- f = io.popen('task ' .. task.cmdline)
- c_text = ""
- .. awful.util.escape(f:read("*all"):gsub("\n*$", ""))
- .. ""
- f:close()
-
- task_notification = 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 = scrp
- })
+ helpers.async(string.format("%s -c '%s'", awful.util.shell, task.cmd),
+ function(f)
+ task.notification = naughty.notify({
+ preset = task_notification_preset,
+ title = task.cmd,
+ text = markup.font(task.notification_preset.font,
+ awful.util.escape(f:gsub("\n*$", "")))
+ })
+ end)
end
-function task.prompt_add()
- awful.prompt.run({ prompt = "Add task: " },
- mypromptbox[awful.screen.focused()].widget,
- function (...)
- local f = io.popen("task add " .. ...)
- c_text = "\n"
- .. awful.util.escape(f:read("*all"))
- .. ""
- f:close()
-
- naughty.notify({
- text = c_text,
- icon = task.notify_icon,
- position = task.position,
- 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 = ""
- .. awful.util.escape(c_text)
- .. ""
- 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")
+function task.prompt()
+ awful.prompt.run {
+ prompt = task.prompt_text,
+ textbox = awful.screen.focused().mypromptbox.widget,
+ exe_callback = function(t)
+ helpers.async(string.format("%s -c '%s'", awful.util.shell, t),
+ function(f)
+ naughty.notify {
+ preset = task_notification_preset,
+ title = t,
+ text = markup.font(task.notification_preset.font,
+ awful.util.escape(f:gsub("\n*$", "")))
+ }
+ end)
+ end,
+ history_path = awful.util.getdir("cache") .. "/history_task"
+ }
end
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
- 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.followtag = args.followtag or false
- task.cmdline = args.cmdline or "next"
+ if not task.notification_preset then
+ task.notification_preset = naughty.config.defaults
+ task.notification_preset.font = "Monospace 10"
+ task.notification_preset.icon = helpers.icons_dir .. "/taskwarrior.png"
+ end
- 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)
+ if widget then
+ widget:connect_signal("mouse::enter", function () task.show() end)
+ widget:connect_signal("mouse::leave", function () task.hide() end)
+ end
end
-return setmetatable(task, { __call = function(_, ...) return create(...) end })
+return task
diff --git a/widgets/fs.lua b/widgets/fs.lua
index 391c260..3a97d4c 100644
--- a/widgets/fs.lua
+++ b/widgets/fs.lua
@@ -37,7 +37,7 @@ function fs.show(seconds, scr)
if fs.followtag then
fs.notification_preset.screen = focused()
elseif scr then
- fs.notification_preset.screen = scr
+ fs.notification_preset.screen = scr or 1
end
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)
-
function update()
fs_info, fs_now = {}, {}
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
naughty.notify({
- title = "Warning",
- text = partition .. " is empty!",
- timeout = 8,
- fg = "#000000",
- bg = "#FFFFFF"
+ preset = naughty.config.presets.critical,
+ title = "Warning",
+ text = partition .. " is empty",
})
helpers.set_map(partition, true)
else
diff --git a/wiki b/wiki
index 66836bb..2f7c2a9 160000
--- a/wiki
+++ b/wiki
@@ -1 +1 @@
-Subproject commit 66836bbf1ffc0dd3bd3aef4799fff78ded9df4ec
+Subproject commit 2f7c2a96a29a94829acf0b9e7fb614a7432a5092