# panel_text.py
# V0.5.0 LDO 19/10/2022: initial version
# V0.5.1 LDO 12/11/2022: refactor modules
# V0.6.1 LDO 17/12/2022: release candidate 1
'''
grafanacode:
class for generating stat panels
'''
#******************************************************************************
# EXTERNAL MODULE REFERENCES
#******************************************************************************
from attrs import define, field, Factory
from attr.validators import in_, instance_of, optional, deep_iterable
from grafanacode import funcs
from grafanacode.plugins import panel_base
#******************************************************************************
# Panel Property classes: store panel property configuration parts
#******************************************************************************
#******************************************************************************
# Panel Class
#******************************************************************************
[docs]@define(slots=False)
class PanelStat(panel_base.PanelBaseExtOpt1):
'''
Dataclass encapsulating a stat panel
'''
# logging level of this item
loglevel : int = 15
# attributes
colormode = field( default='value',
validator=optional(in_(['none', 'value', 'background'])))
graphmode = field( default='none',
validator=optional(in_(['none', 'area'])))
justify = field( default='center',
validator=optional(in_(['auto', 'center'])))
textmode = field( default='value',
validator=instance_of(str))
# message
def __attrs_post_init__(self):
'''
Attrs post init, just print a message.
'''
print (f' > Init Panel: {self.title} - type: PanelStat ')
[docs] def getJson(self, customjson={}, dashboard=None, panel=None):
'''
Create the json to pack this panel.
Parameters:
customjson (dict): custom or child class json code to add
Returns:
dict: panel json code
'''
# pylint: disable=unused-argument
hjson = super().getJson(
{
'options' : {
'colorMode' : self.colormode,
'graphMode' : self.graphmode,
'justifyMode' : self.justify,
'textMode' : self.textmode,
},
'type' : 'stat',
})
# merge child class JSON
funcs.deepMerge(hjson, customjson)
return hjson
#******************************************************************************
# EXTRACT FUNCTIONS : EXTRACT A CREATION SCRIPT FROM A JSON
#******************************************************************************
# pylint: disable=invalid-name