diff options
author | pmakhov <pavel.makhov@savoirfairelinux.com> | 2017-10-09 17:14:03 -0400 |
---|---|---|
committer | pmakhov <pavel.makhov@savoirfairelinux.com> | 2017-10-09 17:14:03 -0400 |
commit | 2b4dba4853fc1840c5aef300b747c5a182655ba4 (patch) | |
tree | 8e24c36c6e4d8994f3fc4f35b97f256e7e570067 /batteryarc-widget/batteryarc.lua | |
parent | 4057e5c379f48c02f8997e307c607a9d4f0b5b85 (diff) |
batteryarc widget
Diffstat (limited to 'batteryarc-widget/batteryarc.lua')
-rw-r--r-- | batteryarc-widget/batteryarc.lua | 82 |
1 files changed, 56 insertions, 26 deletions
diff --git a/batteryarc-widget/batteryarc.lua b/batteryarc-widget/batteryarc.lua index 14db87c..29e8bcd 100644 --- a/batteryarc-widget/batteryarc.lua +++ b/batteryarc-widget/batteryarc.lua @@ -1,23 +1,32 @@ local awful = require("awful") +local beautiful = require("beautiful") local naughty = require("naughty") local wibox = require("wibox") local watch = require("awful.widget.watch") -local USERNAME = os.getenv("USER") +local HOME = os.getenv("HOME") -batteryarc_widget = wibox.widget { - { - id = "txt", - text = "1", - font = "Play 5", - widget = wibox.widget.textbox - }, +-- only text +local text = wibox.widget { + id = "txt", + font = "Play 5", + widget = wibox.widget.textbox +} + +-- mirror the text, because the whole widget will be mirrored after +local mirrored_text = wibox.container.mirror(text, { horizontal = true }) + +-- mirrored text with background +local mirrored_text_with_background = wibox.container.background(mirrored_text) + +local batteryarc = wibox.widget { + mirrored_text_with_background, max_value = 1, rounded_edge = true, thickness = 2, start_angle = 4.71238898, -- 2pi*3/4 - forced_height = 16, - forced_width = 16, + forced_height = 17, + forced_width = 17, bg = "#ffffff11", paddings = 2, widget = wibox.container.arcchart, @@ -26,17 +35,36 @@ batteryarc_widget = wibox.widget { end, } -watch( - "acpi", 10, +-- mirror the widget, so that chart value increases clockwise +batteryarc_widget = wibox.container.mirror(batteryarc, { horizontal = true }) + +watch("acpi", 10, function(widget, stdout, stderr, exitreason, exitcode) local batteryType local _, status, charge_str, time = string.match(stdout, '(.+): (%a+), (%d?%d%d)%%,? ?.*') local charge = tonumber(charge_str) widget.value = charge / 100 - widget.txt.text = charge + if status == 'Charging' then + mirrored_text_with_background.bg = beautiful.widget_green + mirrored_text_with_background.fg = beautiful.widget_black + else + mirrored_text_with_background.bg = beautiful.widget_transparent + mirrored_text_with_background.fg = beautiful.widget_main_color + end + + if charge < 15 then + batteryarc.colors = { beautiful.widget_red } + if status ~= 'Charging' then + show_battery_warning() + end + elseif charge > 15 and charge < 40 then + batteryarc.colors = { beautiful.widget_yellow } + else + batteryarc.colors = { beautiful.widget_main_color } + end + text.text = charge end, - batteryarc_widget -) + batteryarc) -- Popup with battery info -- One way of creating a pop-up notification - naughty.notify @@ -44,17 +72,18 @@ local notification function show_battery_status() awful.spawn.easy_async([[bash -c 'acpi']], function(stdout, _, _, _) - notification = naughty.notify{ - text = stdout, + notification = naughty.notify { + text = stdout, title = "Battery status", - timeout = 5, hover_timeout = 0.5, + timeout = 5, + hover_timeout = 0.5, width = 200, } - end - ) + end) end -batteryarc_widget:connect_signal("mouse::enter", function() show_battery_status() end) -batteryarc_widget:connect_signal("mouse::leave", function() naughty.destroy(notification) end) + +batteryarc:connect_signal("mouse::enter", function() show_battery_status() end) +batteryarc:connect_signal("mouse::leave", function() naughty.destroy(notification) end) -- Alternative to naughty.notify - tooltip. You can compare both and choose the preferred one @@ -67,12 +96,13 @@ batteryarc_widget:connect_signal("mouse::leave", function() naughty.destroy(noti --[[ Show warning notification ]] function show_battery_warning() - naughty.notify{ - icon = "/home/" .. USERNAME .. "/.config/awesome/nichosi.png", - icon_size=100, + naughty.notify { + icon = HOME .. "/.config/awesome/nichosi.png", + icon_size = 100, text = "Huston, we have a problem", title = "Battery is dying", - timeout = 5, hover_timeout = 0.5, + timeout = 5, + hover_timeout = 0.5, position = "bottom_right", bg = "#F06060", fg = "#EEE9EF", |