local fs = {}
local fs_notification = nil
-function fs:hide()
+function fs.hide()
if fs_notification ~= nil then
naughty.destroy(fs_notification)
fs_notification = nil
end
end
-function fs:show(t_out)
- fs:hide()
+function fs.show(seconds, options, scr)
+ fs.hide()
- ws = helpers.read_pipe(helpers.scripts_dir .. "dfs"):gsub("\n*$", "")
+ local cmd = (options and string.format("dfs %s", options)) or "dfs"
+ local ws = helpers.read_pipe(helpers.scripts_dir .. cmd):gsub("\n*$", "")
if fs.followmouse then
fs.notification_preset.screen = mouse.screen
+ elseif scr then
+ fs.notification_preset.screen = scr
end
fs_notification = naughty.notify({
preset = fs.notification_preset,
text = ws,
- timeout = t_out
+ timeout = seconds or 5
})
end
local args = args or {}
local timeout = args.timeout or 600
local partition = args.partition or "/"
+ local showpopup = args.showpopup or "on"
+ local notify = args.notify or "on"
local settings = args.settings or function() end
fs.followmouse = args.followmouse or false
if u and m then -- Handle 1st line and broken regexp
fs_info[m .. " size_mb"] = string.format("%.1f", tonumber(s) / unit["mb"])
fs_info[m .. " size_gb"] = string.format("%.1f", tonumber(s) / unit["gb"])
+ fs_info[m .. " used_mb"] = string.format("%.1f", tonumber(u) / unit["mb"])
+ fs_info[m .. " used_gb"] = string.format("%.1f", tonumber(u) / unit["gb"])
fs_info[m .. " used_p"] = tonumber(p)
fs_info[m .. " avail_p"] = 100 - tonumber(p)
end
fs_now.available = tonumber(fs_info[partition .. " avail_p"]) or 0
fs_now.size_mb = tonumber(fs_info[partition .. " size_mb"]) or 0
fs_now.size_gb = tonumber(fs_info[partition .. " size_gb"]) or 0
+ fs_now.used_mb = tonumber(fs_info[partition .. " used_mb"]) or 0
+ fs_now.used_gb = tonumber(fs_info[partition .. " used_gb"]) or 0
+ notification_preset = fs.notification_preset
widget = fs.widget
settings()
- if fs_now.used >= 99 and not helpers.get_map(partition)
+ if notify == "on" and fs_now.used >= 99 and not helpers.get_map(partition)
then
naughty.notify({
title = "warning",
end
end
- fs.widget:connect_signal('mouse::enter', function () fs:show(0) end)
- fs.widget:connect_signal('mouse::leave', function () fs:hide() end)
+ if showpopup == "on" then
+ fs.widget:connect_signal('mouse::enter', function () fs.show(0) end)
+ fs.widget:connect_signal('mouse::leave', function () fs.hide() end)
+ end
helpers.newtimer(partition, timeout, update)