- bat_now.status = first_line(bstr .. "/status") or "N/A"
- bat_now.ac = first_line(string.format("/sys/class/power_supply/%s/online", ac)) or "N/A"
-
- local time_rat = 0
- if bat_now.status == "Charging"
- then
- time_rat = (tot - rem) / rate
- elseif bat_now.status == "Discharging"
- then
- time_rat = rem / rate
- end
-
- local hrs = math.floor(time_rat)
- if hrs < 0 then hrs = 0 elseif hrs > 23 then hrs = 23 end
-
- local min = math.floor((time_rat - hrs) * 60)
- if min < 0 then min = 0 elseif min > 59 then min = 59 end
-
- bat_now.time = string.format("%02d:%02d", hrs, min)
-
- local perc = tonumber(first_line(bstr .. "/capacity")) or math.floor((rem / tot) * 100)
-
- if perc <= 100 then
- bat_now.perc = string.format("%d", perc)
- elseif perc > 100 then
- bat_now.perc = "100"
- elseif perc < 0 then
- bat_now.perc = "0"
- end
-
- if current_now then
- bat_now.watt = string.format("%.2fW", (rate * ratev) / 1e12)
- else
- bat_now.watt = string.format("%.2fW", rate)
- end
- end
-
- widget = bat.widget
- settings()
-
- -- notifications for low and critical states
- if bat_now.status == "Discharging" and notify == "on" and bat_now.perc
- then
- local nperc = tonumber(bat_now.perc) or 100
- if nperc <= 5
- then
- bat.id = naughty.notify({
- preset = bat_notification_critical_preset,
- replaces_id = bat.id,
- }).id
- elseif nperc <= 15
- then
- bat.id = naughty.notify({
- preset = bat_notification_low_preset,
- replaces_id = bat.id,
- }).id
- end
- end
- end
-
- newtimer(battery, timeout, update)
-
- return setmetatable(bat, { __index = bat.widget })
+
+ local energy_percentage = tonumber(first_line(bstr .. "/capacity")) or
+ math.floor((energy_now / energy_full) * 100)
+
+ bat_now.status = first_line(bstr .. "/status") or "N/A"
+ bat_now.ac_status = first_line(astr .. "/online") or "N/A"
+
+ -- if rate = 0 or rate not defined skip the round
+ if not (rate_power and rate_power > 0) and
+ not (rate_current and rate_current > 0) and
+ not (bat_now.status == "Full")
+ then
+ return
+ end
+
+ local rate_time = 0
+ if bat_now.status == "Charging" then
+ rate_time = (energy_full - energy_now) / rate_power or rate_current
+ elseif bat_now.status == "Discharging" then
+ rate_time = energy_now / rate_power or rate_current
+ end
+
+ local hours = math.floor(rate_time)
+ local minutes = math.floor((rate_time - hours) * 60)
+
+ bat_now.perc = string.format("%d", energy_percentage)
+ bat_now.time = string.format("%02d:%02d", hours, minutes)
+ bat_now.watt = string.format("%.2fW", rate_power / 1e6 or (rate_voltage * rate_current) / 1e12)
+ end
+
+ widget = bat.widget
+ settings()
+
+ -- notifications for low and critical states
+ if bat_now.status == "Discharging" and notify == "on" and bat_now.perc then
+ local nperc = tonumber(bat_now.perc) or 100
+ if nperc <= 5 then
+ bat.id = naughty.notify({
+ preset = bat_notification_critical_preset,
+ replaces_id = bat.id,
+ }).id
+ elseif nperc <= 15 then
+ bat.id = naughty.notify({
+ preset = bat_notification_low_preset,
+ replaces_id = bat.id,
+ }).id
+ end
+ end
+ end
+
+ newtimer(battery, timeout, update)
+
+ return setmetatable(bat, { __index = bat.widget })