mirror of
https://github.com/joBr99/nspanel-lovelace-ui.git
synced 2025-12-21 23:14:25 +01:00
fix config override bug
This commit is contained in:
@@ -1,5 +1,3 @@
|
|||||||
from helper import dict_recursive_update
|
|
||||||
|
|
||||||
class Entity(object):
|
class Entity(object):
|
||||||
def __init__(self, entity_input_config):
|
def __init__(self, entity_input_config):
|
||||||
if type(entity_input_config) is not dict:
|
if type(entity_input_config) is not dict:
|
||||||
@@ -47,57 +45,13 @@ class Card(object):
|
|||||||
|
|
||||||
class LuiBackendConfig(object):
|
class LuiBackendConfig(object):
|
||||||
|
|
||||||
_DEFAULT_CONFIG = {
|
def dict_recursive_update(self, source: dict, target: dict) -> dict:
|
||||||
'panelRecvTopic': "tele/tasmota_your_mqtt_topic/RESULT",
|
for sk, sv in source.items():
|
||||||
'panelSendTopic': "cmnd/tasmota_your_mqtt_topic/CustomSend",
|
if sk in target and isinstance(target[sk], dict):
|
||||||
'updateMode': "auto-notify",
|
target[sk] = self.dict_recursive_update(sv, target[sk])
|
||||||
'model': "eu",
|
else:
|
||||||
'sleepTimeout': 20,
|
target[sk] = sv
|
||||||
'sleepBrightness': 20,
|
return target
|
||||||
'sleepTracking': None,
|
|
||||||
'locale': "en_US",
|
|
||||||
'timeFormat': "%H:%M",
|
|
||||||
'dateFormatBabel': "full",
|
|
||||||
'dateFormat': "%A, %d. %B %Y",
|
|
||||||
'cards': [{
|
|
||||||
'type': 'cardEntities',
|
|
||||||
'entities': [{
|
|
||||||
'entity': 'switch.test_item',
|
|
||||||
'name': 'Test Item'
|
|
||||||
}, {
|
|
||||||
'entity': 'switch.test_item'
|
|
||||||
}],
|
|
||||||
'title': 'Example Entities Page'
|
|
||||||
}, {
|
|
||||||
'type': 'cardGrid',
|
|
||||||
'entities': [{
|
|
||||||
'entity': 'switch.test_item'
|
|
||||||
}, {
|
|
||||||
'entity': 'switch.test_item'
|
|
||||||
}, {
|
|
||||||
'entity': 'switch.test_item'
|
|
||||||
}
|
|
||||||
],
|
|
||||||
'title': 'Example Grid Page'
|
|
||||||
}, {
|
|
||||||
'type': 'climate',
|
|
||||||
'entity': 'climate.test_item',
|
|
||||||
}],
|
|
||||||
'screensaver': {
|
|
||||||
'type': 'screensaver',
|
|
||||||
'entity': 'weather.example',
|
|
||||||
'weatherUnit': 'celsius',
|
|
||||||
'weatherOverrideForecast1': None,
|
|
||||||
'weatherOverrideForecast2': None,
|
|
||||||
'weatherOverrideForecast3': None,
|
|
||||||
'weatherOverrideForecast4': None,
|
|
||||||
'doubleTapToUnlock': False,
|
|
||||||
'alternativeLayout': False,
|
|
||||||
'defaultCard': None,
|
|
||||||
'key': 'screensaver'
|
|
||||||
},
|
|
||||||
'hiddenCards': []
|
|
||||||
}
|
|
||||||
|
|
||||||
def __init__(self, ha_api, config_in):
|
def __init__(self, ha_api, config_in):
|
||||||
self._ha_api = ha_api
|
self._ha_api = ha_api
|
||||||
@@ -106,12 +60,64 @@ class LuiBackendConfig(object):
|
|||||||
self._config_screensaver = None
|
self._config_screensaver = None
|
||||||
self._config_hidden_cards = []
|
self._config_hidden_cards = []
|
||||||
|
|
||||||
|
self._DEFAULT_CONFIG = {
|
||||||
|
'panelRecvTopic': "tele/tasmota_your_mqtt_topic/RESULT",
|
||||||
|
'panelSendTopic': "cmnd/tasmota_your_mqtt_topic/CustomSend",
|
||||||
|
'updateMode': "auto-notify",
|
||||||
|
'model': "eu",
|
||||||
|
'sleepTimeout': 20,
|
||||||
|
'sleepBrightness': 20,
|
||||||
|
'sleepTracking': None,
|
||||||
|
'locale': "en_US",
|
||||||
|
'timeFormat': "%H:%M",
|
||||||
|
'dateFormatBabel': "full",
|
||||||
|
'dateFormat': "%A, %d. %B %Y",
|
||||||
|
'cards': [{
|
||||||
|
'type': 'cardEntities',
|
||||||
|
'entities': [{
|
||||||
|
'entity': 'switch.test_item',
|
||||||
|
'name': 'Test Item'
|
||||||
|
}, {
|
||||||
|
'entity': 'switch.test_item'
|
||||||
|
}],
|
||||||
|
'title': 'Example Entities Page'
|
||||||
|
}, {
|
||||||
|
'type': 'cardGrid',
|
||||||
|
'entities': [{
|
||||||
|
'entity': 'switch.test_item'
|
||||||
|
}, {
|
||||||
|
'entity': 'switch.test_item'
|
||||||
|
}, {
|
||||||
|
'entity': 'switch.test_item'
|
||||||
|
}
|
||||||
|
],
|
||||||
|
'title': 'Example Grid Page'
|
||||||
|
}, {
|
||||||
|
'type': 'climate',
|
||||||
|
'entity': 'climate.test_item',
|
||||||
|
}],
|
||||||
|
'screensaver': {
|
||||||
|
'type': 'screensaver',
|
||||||
|
'entity': 'weather.example',
|
||||||
|
'weatherUnit': 'celsius',
|
||||||
|
'weatherOverrideForecast1': None,
|
||||||
|
'weatherOverrideForecast2': None,
|
||||||
|
'weatherOverrideForecast3': None,
|
||||||
|
'weatherOverrideForecast4': None,
|
||||||
|
'doubleTapToUnlock': False,
|
||||||
|
'alternativeLayout': False,
|
||||||
|
'defaultCard': None,
|
||||||
|
'key': 'screensaver'
|
||||||
|
},
|
||||||
|
'hiddenCards': []
|
||||||
|
}
|
||||||
|
|
||||||
self.load(config_in)
|
self.load(config_in)
|
||||||
|
|
||||||
def load(self, inconfig):
|
def load(self, inconfig):
|
||||||
self._ha_api.log(f"Input config: {inconfig}")
|
self._ha_api.log("Input config: %s", inconfig)
|
||||||
self._config = dict_recursive_update(inconfig, self._DEFAULT_CONFIG)
|
self._config = self.dict_recursive_update(inconfig, self._DEFAULT_CONFIG)
|
||||||
self._ha_api.log(f"Loaded config: {self._config}")
|
self._ha_api.log("Loaded config: %s", self._config)
|
||||||
|
|
||||||
# parse cards displayed on panel
|
# parse cards displayed on panel
|
||||||
pos = 0
|
pos = 0
|
||||||
|
|||||||
@@ -54,12 +54,4 @@ def get_attr_safe(entity, attr, default):
|
|||||||
res = entity.attributes.get(attr, default)
|
res = entity.attributes.get(attr, default)
|
||||||
if res is None:
|
if res is None:
|
||||||
res = default
|
res = default
|
||||||
return res
|
return res
|
||||||
|
|
||||||
def dict_recursive_update(source: dict, target: dict) -> dict:
|
|
||||||
for sk, sv in source.items():
|
|
||||||
if sk in target and isinstance(target[sk], dict):
|
|
||||||
target[sk] = dict_recursive_update(sv, target[sk])
|
|
||||||
else:
|
|
||||||
target[sk] = sv
|
|
||||||
return target
|
|
||||||
Reference in New Issue
Block a user