30c1f712a6
getting rid of thinking about consistent formatting...
63 lines
1.8 KiB
Python
63 lines
1.8 KiB
Python
# pylint: disable=C0111,R0903
|
|
|
|
"""Displays the indicator status, for numlock, scrolllock and capslock
|
|
|
|
Parameters:
|
|
* indicator.include: Comma-separated list of interface prefixes to include (defaults to 'numlock,capslock')
|
|
* indicator.signalstype: If you want the signali type color to be 'critical' or 'warning' (defaults to 'warning')
|
|
"""
|
|
|
|
import core.module
|
|
import core.widget
|
|
|
|
import util.cli
|
|
import util.format
|
|
|
|
|
|
class Module(core.module.Module):
|
|
def __init__(self, config, theme):
|
|
super().__init__(config, theme, [])
|
|
|
|
self.__include = tuple(
|
|
filter(
|
|
len, util.format.aslist(self.parameter("include", "NumLock,CapsLock"))
|
|
)
|
|
)
|
|
self.__signalType = (
|
|
self.parameter("signaltype")
|
|
if not self.parameter("signaltype") is None
|
|
else "warning"
|
|
)
|
|
|
|
def update(self):
|
|
status_line = ""
|
|
for line in (
|
|
util.cli.execute("xset q", ignore_errors=True).replace(" ", "").split("\n")
|
|
):
|
|
if "capslock" in line.lower():
|
|
status_line = line
|
|
break
|
|
for indicator in self.__include:
|
|
widget = self.widget(indicator)
|
|
if not widget:
|
|
widget = core.widget.Widget(name=indicator, module=self)
|
|
self.widgets().append(widget)
|
|
|
|
widget.set(
|
|
"status",
|
|
True
|
|
if "{}:on".format(indicator.lower()) in status_line.lower()
|
|
else False,
|
|
)
|
|
widget.full_text(indicator)
|
|
|
|
def state(self, widget):
|
|
states = []
|
|
if widget.get("status", False):
|
|
states.append(self.__signalType)
|
|
else:
|
|
states.append("normal")
|
|
return states
|
|
|
|
|
|
# vim: tabstop=8 expandtab shiftwidth=4 softtabstop=4
|