use widget.watch
This commit is contained in:
parent
bd1d147280
commit
a079c79ab8
|
@ -1,59 +1,58 @@
|
||||||
local wibox = require("wibox")
|
local wibox = require("wibox")
|
||||||
local awful = require("awful")
|
local awful = require("awful")
|
||||||
local naughty = require("naughty")
|
local naughty = require("naughty")
|
||||||
|
local watch = require("awful.widget.watch")
|
||||||
|
|
||||||
|
-- Battery 0: Discharging, 75%, 01:51:38 remaining
|
||||||
|
-- Battery 0: Charging, 53%, 00:57:43 until charged
|
||||||
|
|
||||||
batteryIcon = wibox.widget {
|
batteryIcon = wibox.widget { widget = wibox.widget.imagebox }
|
||||||
widget = wibox.widget.imagebox
|
|
||||||
}
|
|
||||||
|
|
||||||
function refresh_icon()
|
watch(
|
||||||
awful.spawn.easy_async([[bash -c 'acpi | cut -d, -f 2 | egrep -o "[0-9]{1,3}"']],
|
"acpi", 10,
|
||||||
function(stdout, stderr, reason, exit_code)
|
function(widget, stdout, stderr, exitreason, exitcode)
|
||||||
local batteryType
|
local batteryType
|
||||||
local charge = tonumber(stdout)
|
local bar, status, charge, time = string.match(stdout, '(.+): (%a+), (%d%d)%%, (.+)')
|
||||||
if (charge >= 0 and charge < 20) then
|
charge = tonumber(charge)
|
||||||
batteryType="battery-empty"
|
if (charge >= 0 and charge < 20) then
|
||||||
show_battery_warning()
|
batteryType="battery-empty"
|
||||||
|
show_battery_warning()
|
||||||
elseif (charge >= 20 and charge < 40) then batteryType="battery-caution"
|
elseif (charge >= 20 and charge < 40) then batteryType="battery-caution"
|
||||||
elseif (charge >= 40 and charge < 60) then batteryType="battery-low"
|
elseif (charge >= 40 and charge < 60) then batteryType="battery-low"
|
||||||
elseif (charge >= 60 and charge < 80) then batteryType="battery-good"
|
elseif (charge >= 60 and charge < 80) then batteryType="battery-good"
|
||||||
elseif (charge >= 80 and charge <= 100) then batteryType="battery-full"
|
elseif (charge >= 80 and charge <= 100) then batteryType="battery-full"
|
||||||
end
|
end
|
||||||
batteryIcon.image = "/usr/share/icons/Arc-Icons/panel/22/" .. batteryType .. ".svg"
|
if status == 'Charging' then
|
||||||
end)
|
batteryType = batteryType .. '-charging'
|
||||||
end
|
end
|
||||||
|
batteryIcon.image = "/usr/share/icons/Arc-Icons/panel/22/" .. batteryType .. ".svg"
|
||||||
|
end
|
||||||
|
)
|
||||||
|
|
||||||
function show_battery_status()
|
function show_battery_status()
|
||||||
awful.spawn.easy_async([[bash -c 'acpi | cut -d, -f 2,3']],
|
awful.spawn.easy_async([[bash -c 'acpi']],
|
||||||
function(stdout, stderr, reason, exit_code)
|
function(stdout, stderr, reason, exit_code)
|
||||||
naughty.notify{
|
naughty.notify{
|
||||||
text = stdout,
|
text = stdout,
|
||||||
title = "Battery status",
|
title = "Battery status",
|
||||||
timeout = 5, hover_timeout = 0.5,
|
timeout = 5, hover_timeout = 0.5,
|
||||||
width = 200,
|
width = 200,
|
||||||
}
|
}
|
||||||
end
|
end
|
||||||
)
|
)
|
||||||
end
|
end
|
||||||
|
|
||||||
function show_battery_warning()
|
function show_battery_warning()
|
||||||
naughty.notify{
|
naughty.notify{
|
||||||
text = "Huston, we have a problem",
|
text = "Huston, we have a problem",
|
||||||
title = "Battery is dying",
|
title = "Battery is dying",
|
||||||
timeout = 5, hover_timeout = 0.5,
|
timeout = 5, hover_timeout = 0.5,
|
||||||
position = "bottom_right",
|
position = "bottom_right",
|
||||||
bg = "#F06060",
|
bg = "#F06060",
|
||||||
fg = "#EEE9EF",
|
fg = "#EEE9EF",
|
||||||
width = 200,
|
width = 200,
|
||||||
}
|
}
|
||||||
end
|
end
|
||||||
|
|
||||||
-- timer to refresh icon
|
|
||||||
local batteryWidgetTimer = timer({ timeout = 60 })
|
|
||||||
batteryWidgetTimer:connect_signal("timeout", function() refresh_icon() end)
|
|
||||||
batteryWidgetTimer:start()
|
|
||||||
batteryWidgetTimer:emit_signal("timeout")
|
|
||||||
|
|
||||||
-- popup with battery info
|
-- popup with battery info
|
||||||
batteryIcon:connect_signal("mouse::enter", function() show_battery_status() end)
|
batteryIcon:connect_signal("mouse::enter", function() show_battery_status() end)
|
Loading…
Reference in New Issue