]> git.madduck.net Git - etc/awesome.git/blobdiff - widget/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:

bat: notify full only once before discharging
[etc/awesome.git] / widget / bat.lua
index e39c921acc71cda41069c0458c774574c854bb9f..d48b12a6ca0f3603534400ab34bfd640886b8496 100644 (file)
@@ -48,8 +48,8 @@ local function factory(args)
     }
 
     bat_notification_charged_preset = {
-        title = "Battery full",
-        text  = "You can unplug the cable",
+        title   = "Battery full",
+        text    = "You can unplug the cable",
         timeout = 15,
         fg      = "#202020",
         bg      = "#CDCDCD"
@@ -70,6 +70,9 @@ local function factory(args)
         bat_now.n_perc[i] = 0
     end
 
+    -- used to notify full charge only once before discharging
+    local fullnotification = false
+
     function bat.update()
         local sum_rate_current = 0
         local sum_rate_voltage = 0
@@ -170,7 +173,7 @@ local function factory(args)
                 if tonumber(bat_now.perc) <= n_perc[1] then
                     bat.id = naughty.notify({
                         preset = bat_notification_critical_preset,
-                                   replaces_id = bat.id
+                        replaces_id = bat.id
                     }).id
                 elseif tonumber(bat_now.perc) <= n_perc[2] then
                     bat.id = naughty.notify({
@@ -178,11 +181,13 @@ local function factory(args)
                         replaces_id = bat.id
                     }).id
                 end
-            elseif bat_now.status == "Full" then
+                fullnotification = false
+            elseif bat_now.status == "Full" and not fullnotification then
                 bat.id = naughty.notify({
                     preset = bat_notification_charged_preset,
                     replaces_id = bat.id
                 }).id
+                fullnotification = true
             end
         end
     end