--]]
-local first_line = require("lain.helpers").first_line
-local newtimer = require("lain.helpers").newtimer
-local naughty = require("naughty")
-local wibox = require("wibox")
-local math = { abs = math.abs,
- floor = math.floor,
- log10 = math.log10,
- min = math.min }
-local string = { format = string.format }
-local ipairs = ipairs
-local type = type
-local tonumber = tonumber
-local setmetatable = setmetatable
+local first_line = require("lain.helpers").first_line
+local newtimer = require("lain.helpers").newtimer
+local naughty = require("naughty")
+local wibox = require("wibox")
+local math = { abs = math.abs,
+ floor = math.floor,
+ log10 = math.log10,
+ min = math.min }
+local string = { format = string.format }
+local ipairs = ipairs
+local tonumber = tonumber
-- Battery infos
-- lain.widget.bat
-local function worker(args)
+local function factory(args)
local bat = { widget = wibox.widget.textbox() }
local args = args or {}
local timeout = args.timeout or 30
if bat_now.status ~= "N/A" then
if bat_now.status ~= "Full" and sum_rate_power == 0 and bat_now.ac_status == 1 then
- bat_now.perc = math.floor(math.min(100, (sum_energy_now / sum_energy_full) * 100))
- bat_now.time = "00:00"
- bat_now.watt = 0
+ bat_now.perc = math.floor(math.min(100, (sum_energy_now / sum_energy_full) * 100))
+ bat_now.time = "00:00"
+ bat_now.watt = 0
-- update {perc,time,watt} iff battery not full and rate > 0
elseif bat_now.status ~= "Full" then
settings()
-- notifications for low and critical states
- if notify == "on" and type(bat_now.perc) == "number" and bat_now.status == "Discharging" then
- if bat_now.perc <= 5 then
+ if notify == "on" and bat_now.status == "Discharging" then
+ if tonumber(bat_now.perc) <= 5 then
bat.id = naughty.notify({
preset = bat_notification_critical_preset,
replaces_id = bat.id
}).id
- elseif bat_now.perc <= 15 then
+ elseif tonumber(bat_now.perc) <= 15 then
bat.id = naughty.notify({
preset = bat_notification_low_preset,
replaces_id = bat.id
return bat
end
-return setmetatable({}, { __call = function(_, ...) return worker(...) end })
+return factory