# panel_histogram.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 histogram 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 PanelHistogram(panel_base.PanelBaseExtOpt2):
'''
Dataclass encapsulating a histogram panel
'''
# logging level of this item
loglevel : int = 15
# attributes
bucketoffset = field( default=0,
validator=instance_of(int))
bucketsize = field( default=None,
validator=optional(instance_of(int)))
combine = field( default=False,
validator=instance_of(bool))
# message
def __attrs_post_init__(self):
'''
Attrs post init, just print a message.
'''
print (f' > Init Panel: {self.title} - type: PanelHistogram ')
[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' : {
'bucketOffset' : self.bucketoffset,
'combine' : self.combine,
},
'type' : 'histogram',
})
# optional JSON
if self.bucketsize is not None:
hjson['options']['bucketSize'] = self.bucketsize
# merge child class JSON
funcs.deepMerge(hjson, customjson)
return hjson
#******************************************************************************
# EXTRACT FUNCTIONS : EXTRACT A CREATION SCRIPT FROM A JSON
#******************************************************************************
# pylint: disable=invalid-name