]>
git.madduck.net Git - etc/awesome.git/blobdiff - widgets/bat.lua
madduck's git repository
Every one of the projects in this repository is available at the canonical
URL git://git.madduck.net/madduck/pub/<projectpath> — see
each project's metadata for the exact URL.
All patches and comments are welcome. Please squash your changes to logical
commits before using git-format-patch and git-send-email to
patches@ git. madduck. net .
If you'd read over the Git project's submission guidelines and adhered to them,
I'd be especially grateful.
SSH access, as well as push access can be individually
arranged .
If you use my repositories frequently, consider adding the following
snippet to ~/.gitconfig and using the third clone URL listed for each
project:
[url "git://git.madduck.net/madduck/"]
insteadOf = madduck:
-local markup = require("lain.util.markup")
+local newtimer = require("lain.helpers").newtimer
local first_line = require("lain.helpers").first_line
local first_line = require("lain.helpers").first_line
-local beautiful = require("beautiful")
local naughty = require("naughty")
local wibox = require("wibox")
local naughty = require("naughty")
local wibox = require("wibox")
-- Battery infos
-- lain.widgets.bat
-- Battery infos
-- lain.widgets.bat
-local bat = {
- status = "not present",
- perc = "N/A",
- time = "N/A",
-}
+local function worker(args)
+ local timeout = args.timeout or 30
local battery = args.battery or "BAT0"
local battery = args.battery or "BAT0"
- local show_all = args.show_all or false
- local refresh_timeout = args.refresh_timeout or 30
- local header = args.header or " Bat "
- local header_color = args.header_color or beautiful.fg_normal or "#FFFFFF"
- local color = args.color or beautiful.fg_focus or "#FFFFFF"
- local shadow = args.shadow or false
+ local settings = args.settings or function() end
- local mybattery = wibox.widget.textbox( )
+ bat.widget = wibox.widget.textbox('' )
- local mybatteryupdate = function()
+ bat_now = {
+ status = "not present",
+ perc = "N/A",
+ time = "N/A",
+ watt = "N/A"
+ }
+
+ function bat.update()
local present = first_line("/sys/class/power_supply/"
.. battery
.. "/present")
local present = first_line("/sys/class/power_supply/"
.. battery
.. "/present")
local tot = first_line("/sys/class/power_supply/"
.. battery ..
"/energy_full")
local tot = first_line("/sys/class/power_supply/"
.. battery ..
"/energy_full")
- bat.status = first_line("/sys/class/power_supply/"
+ bat_now .status = first_line("/sys/class/power_supply/"
.. battery ..
"/status")
local time_rat = 0
.. battery ..
"/status")
local time_rat = 0
- if bat.status == "Charging"
+ if bat_now .status == "Charging"
time_rat = (tot - rem) / rate
time_rat = (tot - rem) / rate
- elseif bat.status == "Discharging"
+ elseif bat_now .status == "Discharging"
end
local hrs = math.floor(time_rat)
local min = (time_rat - hrs) * 60
end
local hrs = math.floor(time_rat)
local min = (time_rat - hrs) * 60
- bat.time = string.format("%02d:%02d", hrs, min)
-
- local amount = (rem / tot) * 100
- if shadow
- then
- bat.perc = string.format("%d", amount)
- else
- bat.perc = string.format("%d%%", amount)
- end
-
- local watt = string.format("%.2fW", (rate * ratev) / 1e12)
-
- if show_all
- then
- text = watt .. " " .. bat.perc .. " " .. bat.time .. " " .. bat.status
- else
- text = bat.perc
- end
+ bat_now.time = string.format("%02d:%02d", hrs, min)
+ bat_now.perc = (rem / tot) * 100
+ bat_now.watt = string.format("%.2fW", (rate * ratev) / 1e12)
-- notifications for low and critical states
-- notifications for low and critical states
+ bat.id = naughty.notify( {
text = "shutdown imminent",
title = "battery nearly exhausted",
position = "top_right",
timeout = 15,
fg="#000000",
bg="#ffffff",
text = "shutdown imminent",
title = "battery nearly exhausted",
position = "top_right",
timeout = 15,
fg="#000000",
bg="#ffffff",
- ontop = true
- }
- elseif amount <= 15
+ ontop = true,
+ replaces_id = bat.id
+ }).id
+ elseif bat.perc <= 15
- old_id = naughty.notify {
+ bat.id = naughty.notify( {
text = "plug the cable",
title = "battery low",
position = "top_right",
text = "plug the cable",
title = "battery low",
position = "top_right",
fg="#202020",
bg="#cdcdcd",
fg="#202020",
bg="#cdcdcd",
+ ontop = true,
+ replaces_id = bat.id
+ }).id
- else
- text = "none"
- end
- if shadow
- then
- mybattery:set_text('')
- else
- mybattery:set_markup(markup(header_color, header)
- .. markup(color, text) .. " ")
+ bat_now.perc = string.format("%d", bat_now.perc)
- local mybatterytimer = timer({ timeout = refresh_timeout })
- mybatterytimer:connect_signal("timeout", mybatteryupdate)
- mybatterytimer:start()
- mybatterytimer:emit_signal("timeout")
+ widget = bat.widget
+ settings()
+ end
+ newtimer("bat", timeout, bat.update)
- return setmetatable(bat, { __index = bat.widget })
end
return setmetatable(bat, { __call = function(_, ...) return worker(...) end })
end
return setmetatable(bat, { __call = function(_, ...) return worker(...) end })