mirror of
https://github.com/joBr99/nspanel-lovelace-ui.git
synced 2026-02-19 12:44:44 +01:00
fixes #785
This commit is contained in:
@@ -53,24 +53,29 @@ class Card(object):
|
|||||||
self.entities.append(Entity(e))
|
self.entities.append(Entity(e))
|
||||||
self.id = f"{self.cardType}_{self.key}".replace(".","_").replace("~","_").replace(" ","_")
|
self.id = f"{self.cardType}_{self.key}".replace(".","_").replace("~","_").replace(" ","_")
|
||||||
|
|
||||||
def get_entity_names(self):
|
def get_entity_names(self, uuid=False):
|
||||||
entityIds = []
|
entityIds = {}
|
||||||
if self.entity is not None:
|
if self.entity is not None:
|
||||||
entityIds.append(self.entity.entityId)
|
entityIds[self.entity.uuid] = self.entity.entityId
|
||||||
if self.entity.status is not None:
|
if self.entity.status is not None:
|
||||||
entityIds.append(self.entity.status)
|
entityIds[self.entity.uuid] = self.entity.status
|
||||||
for e in self.entities:
|
for e in self.entities:
|
||||||
entityIds.append(e.entityId)
|
entityIds[e.uuid] = e.entityId
|
||||||
if e.status is not None:
|
if e.status is not None:
|
||||||
entityIds.append(e.status)
|
entityIds[e.uuid] = e.status
|
||||||
|
|
||||||
# additional keys to check
|
# additional keys to check
|
||||||
add_ent_keys = ['statusIcon1', 'statusIcon2', 'alarmControl']
|
add_ent_keys = ['statusIcon1', 'statusIcon2', 'alarmControl']
|
||||||
for ent_key in add_ent_keys:
|
for ent_key in add_ent_keys:
|
||||||
val = self.raw_config.get(ent_key)
|
val = self.raw_config.get(ent_key)
|
||||||
if val is not None:
|
if val is not None:
|
||||||
entityIds.append(val.get("entity"))
|
#entityIds.append(val.get("entity"))
|
||||||
return entityIds
|
entityIds["nouuid."] = val.get("entity")
|
||||||
|
|
||||||
|
if uuid:
|
||||||
|
return entityIds
|
||||||
|
else:
|
||||||
|
return entityIds.values()
|
||||||
|
|
||||||
def get_entity_list(self):
|
def get_entity_list(self):
|
||||||
entitys = []
|
entitys = []
|
||||||
|
|||||||
@@ -144,6 +144,8 @@ class LuiController(object):
|
|||||||
apis.ha_api.listen_state(self.update_screensaver_brightness_state_callback, entity_id=screen_brightness_config)
|
apis.ha_api.listen_state(self.update_screensaver_brightness_state_callback, entity_id=screen_brightness_config)
|
||||||
|
|
||||||
items = self._config.get_all_entity_names()
|
items = self._config.get_all_entity_names()
|
||||||
|
prefixes = ("navigate.")
|
||||||
|
items = [x for x in items if not x.startswith(prefixes)]
|
||||||
apis.ha_api.log(f"Registering callbacks for the following items: {items}")
|
apis.ha_api.log(f"Registering callbacks for the following items: {items}")
|
||||||
for item in items:
|
for item in items:
|
||||||
if apis.ha_api.entity_exists(item):
|
if apis.ha_api.entity_exists(item):
|
||||||
@@ -152,13 +154,21 @@ class LuiController(object):
|
|||||||
def state_change_callback(self, entity, attribute, old, new, kwargs):
|
def state_change_callback(self, entity, attribute, old, new, kwargs):
|
||||||
apis.ha_api.log(f"Got callback for: {entity}", level="DEBUG")
|
apis.ha_api.log(f"Got callback for: {entity}", level="DEBUG")
|
||||||
apis.ha_api.log(f"Current page has the following items: {self._current_card.get_entity_names()}", level="DEBUG")
|
apis.ha_api.log(f"Current page has the following items: {self._current_card.get_entity_names()}", level="DEBUG")
|
||||||
if entity in self._current_card.get_entity_names():
|
entities_on_card = self._current_card.get_entity_names(uuid=True)
|
||||||
|
|
||||||
|
# lookup uuid for enity on current card
|
||||||
|
res_uuid = "uuid.notfound"
|
||||||
|
if entity in entities_on_card.values():
|
||||||
|
for uuid, name in entities_on_card.items():
|
||||||
|
if entity == name:
|
||||||
|
res_uuid = uuid
|
||||||
|
|
||||||
apis.ha_api.log(f"Callback Entity is on current page: {entity}", level="DEBUG")
|
apis.ha_api.log(f"Callback Entity is on current page: {entity}", level="DEBUG")
|
||||||
self._pages_gen.render_card(self._current_card, send_page_type=False)
|
self._pages_gen.render_card(self._current_card, send_page_type=False)
|
||||||
# send detail page update, just in case
|
# send detail page update, just in case
|
||||||
if self._current_card.cardType in ["cardGrid", "cardEntities", "cardMedia"]:
|
if self._current_card.cardType in ["cardGrid", "cardEntities", "cardMedia"]:
|
||||||
if entity.startswith("light"):
|
if entity.startswith("light"):
|
||||||
self._pages_gen.generate_light_detail_page(entity)
|
self._pages_gen.generate_light_detail_page(res_uuid)
|
||||||
if entity.startswith("cover"):
|
if entity.startswith("cover"):
|
||||||
self._pages_gen.generate_shutter_detail_page(entity)
|
self._pages_gen.generate_shutter_detail_page(entity)
|
||||||
if entity.startswith("fan"):
|
if entity.startswith("fan"):
|
||||||
|
|||||||
Reference in New Issue
Block a user