Improved battery module for 2 batteries

This commit is contained in:
Alex 2018-11-03 17:52:02 +01:00
parent 316dde0dbe
commit 9b4d1c52e6

View file

@ -78,16 +78,17 @@ class Module(bumblebee.engine.Module):
return "n/a"
capacity = capacity if capacity < 100 else 100
widget.set("capacity", capacity)
if bumblebee.util.asbool(self.parameter("showdevice", False)):
widget.set("theme.minwidth", "100% ({})".format(os.path.basename(widget.name)))
return "{}% ({})".format(capacity, os.path.basename(widget.name))
output = "{}%".format(capacity)
widget.set("theme.minwidth", "100%")
remaining = None
if bumblebee.util.asbool(self.parameter("showremaining", True)):
remaining = self.remaining()
if bumblebee.util.asbool(self.parameter("showremaining", True))\
and self.getCharge(widget) == "Discharging":
output = "{} {}".format(output, self.remaining())
return "{}%{}".format(capacity, "" if not remaining else " ({})".format(remaining))
if bumblebee.util.asbool(self.parameter("showdevice", True)):
output = "{} ({})".format(output, os.path.basename(widget.name))
return output
def state(self, widget):
state = []
@ -104,14 +105,11 @@ class Module(bumblebee.engine.Module):
if widget.get("ac"):
state.append("AC")
else:
charge = ""
try:
with open("{}/status".format(widget.name)) as f:
charge = f.read().strip()
except IOError:
pass
charge = self.getCharge(widget)
if charge == "Discharging":
state.append("discharging-{}".format(min([10, 25, 50, 80, 100], key=lambda i: abs(i-capacity))))
elif charge == "Unknown":
state.append("unknown")
else:
if capacity > 95:
state.append("charged")
@ -120,4 +118,12 @@ class Module(bumblebee.engine.Module):
return state
def getCharge(self, widget):
charge = ""
try:
with open("{}/status".format(widget.name)) as f:
charge = f.read().strip()
except IOError:
pass
return charge
# vim: tabstop=8 expandtab shiftwidth=4 softtabstop=4