bumblebee-status/bumblebee_status/modules/contrib/indicator.py

66 lines
1.8 KiB
Python
Raw Normal View History

# pylint: disable=C0111,R0903
2020-04-18 14:24:26 +00:00
"""Displays the indicator status, for numlock, scrolllock and capslock
2020-07-18 06:23:28 +00:00
Requires the following executable:
* xset
2020-04-18 14:24:26 +00:00
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')
contributed by `freed00m <https://github.com/freed00m>`_ - many thanks!
2020-04-18 14:24:26 +00:00
"""
import core.module
2020-04-18 14:24:26 +00:00
import util.cli
import util.format
2020-04-18 14:24:26 +00:00
class Module(core.module.Module):
def __init__(self, config, theme):
super().__init__(config, theme, [])
2020-04-18 14:24:26 +00:00
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"
)
2020-04-18 14:24:26 +00:00
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
2020-04-18 14:24:26 +00:00
break
for indicator in self.__include:
2020-04-18 14:24:26 +00:00
widget = self.widget(indicator)
if not widget:
widget = self.add_widget(name=indicator, full_text=indicator)
2020-04-18 14:24:26 +00:00
widget.set(
"status",
True
if "{}:on".format(indicator.lower()) in status_line.lower()
else False,
)
2020-04-18 14:24:26 +00:00
def state(self, widget):
states = []
if widget.get("status", False):
states.append(self.__signalType)
else:
states.append("normal")
return states
2020-04-18 14:24:26 +00:00
2020-04-18 14:24:26 +00:00
# vim: tabstop=8 expandtab shiftwidth=4 softtabstop=4