use widget.watch

This commit is contained in:
Pavel Makhov 2017-01-25 22:48:35 -05:00 committed by GitHub
parent bd1d147280
commit a079c79ab8
1 changed files with 39 additions and 40 deletions

View File

@ -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)