[themes] Make individual items theme-able (a bit)
Individual items in the bar can now be configured with a prefix and a suffix. It works like this: * If there is a specific module configuration in the theme configuration, use that (i.e. { "<modulename>": { "prefix: " a " } }) * Otherwise, if there is a configuration in the "default" section of the theme, use that * Otherwise, if the module object itself has a method called like the required attribute (prefix, suffix), use that * Otherwise, leave prefix/suffix empty ("")
This commit is contained in:
parent
e895400589
commit
3ca53dd0fa
7 changed files with 51 additions and 12 deletions
|
@ -6,4 +6,10 @@ class Module(object):
|
||||||
def theme(self):
|
def theme(self):
|
||||||
return self._theme
|
return self._theme
|
||||||
|
|
||||||
|
def data(self):
|
||||||
|
pass
|
||||||
|
|
||||||
|
def state(self):
|
||||||
|
return "default"
|
||||||
|
|
||||||
# vim: tabstop=8 expandtab shiftwidth=4 softtabstop=4
|
# vim: tabstop=8 expandtab shiftwidth=4 softtabstop=4
|
||||||
|
|
|
@ -9,8 +9,11 @@ class i3bar(bumblebee.output.Output):
|
||||||
return json.dumps({ "version": 1 }) + "["
|
return json.dumps({ "version": 1 }) + "["
|
||||||
|
|
||||||
def add(self, obj):
|
def add(self, obj):
|
||||||
|
theme = obj.theme()
|
||||||
self._data.append({
|
self._data.append({
|
||||||
"full_text": obj.data()
|
"full_text": "%s%s%s" % (theme.prefix(obj), obj.data(), theme.suffix(obj)),
|
||||||
|
"separator": False,
|
||||||
|
"separator_block_width": 0,
|
||||||
})
|
})
|
||||||
|
|
||||||
def get(self):
|
def get(self):
|
||||||
|
|
28
bumblebee/theme.py
Normal file
28
bumblebee/theme.py
Normal file
|
@ -0,0 +1,28 @@
|
||||||
|
import os
|
||||||
|
import json
|
||||||
|
|
||||||
|
class Theme:
|
||||||
|
def __init__(self, name="default"):
|
||||||
|
self._data = None
|
||||||
|
path = os.path.dirname(os.path.realpath(__file__))
|
||||||
|
with open("%s/themes/%s.json" % (path, name)) as f:
|
||||||
|
self._data = json.load(f)
|
||||||
|
self._defaults = self._data.get("defaults", {})
|
||||||
|
|
||||||
|
def _gettheme(self, obj, key):
|
||||||
|
module = obj.__module__.split(".")[-1]
|
||||||
|
module_theme = self._data.get(module, {})
|
||||||
|
|
||||||
|
value = getattr(obj, key)() if hasattr(obj, key) else ""
|
||||||
|
value = self._defaults.get(key, value)
|
||||||
|
value = module_theme.get(key, value)
|
||||||
|
|
||||||
|
return value
|
||||||
|
|
||||||
|
def prefix(self, obj):
|
||||||
|
return self._gettheme(obj, "prefix")
|
||||||
|
|
||||||
|
def suffix(self, obj):
|
||||||
|
return self._gettheme(obj, "suffix")
|
||||||
|
|
||||||
|
# vim: tabstop=8 expandtab shiftwidth=4 softtabstop=4
|
|
@ -1,6 +0,0 @@
|
||||||
|
|
||||||
class Theme:
|
|
||||||
def __init__(self, name):
|
|
||||||
pass
|
|
||||||
|
|
||||||
# vim: tabstop=8 expandtab shiftwidth=4 softtabstop=4
|
|
11
bumblebee/themes/default.json
Normal file
11
bumblebee/themes/default.json
Normal file
|
@ -0,0 +1,11 @@
|
||||||
|
{
|
||||||
|
"defaults": {
|
||||||
|
"prefix": " ",
|
||||||
|
"suffix" : " "
|
||||||
|
},
|
||||||
|
"battery": {
|
||||||
|
"prefix": "bat "
|
||||||
|
},
|
||||||
|
"time": {
|
||||||
|
}
|
||||||
|
}
|
|
@ -1,3 +0,0 @@
|
||||||
{
|
|
||||||
|
|
||||||
}
|
|
|
@ -4,7 +4,7 @@ import sys
|
||||||
import time
|
import time
|
||||||
import argparse
|
import argparse
|
||||||
import importlib
|
import importlib
|
||||||
import bumblebee.themes
|
import bumblebee.theme
|
||||||
import bumblebee.outputs.i3
|
import bumblebee.outputs.i3
|
||||||
|
|
||||||
def print_module_list():
|
def print_module_list():
|
||||||
|
@ -24,7 +24,7 @@ def main():
|
||||||
sys.exit(0)
|
sys.exit(0)
|
||||||
|
|
||||||
modules = []
|
modules = []
|
||||||
theme = bumblebee.themes.Theme(args.theme)
|
theme = bumblebee.theme.Theme(args.theme) if args.theme else bumblebee.theme.Theme()
|
||||||
for m in args.modules:
|
for m in args.modules:
|
||||||
# TODO: how to cleanly handle errors here?
|
# TODO: how to cleanly handle errors here?
|
||||||
# (useful error messages)
|
# (useful error messages)
|
||||||
|
|
Loading…
Reference in a new issue