started refactoring get_icons

This commit is contained in:
Johannes Braun
2022-12-08 21:51:43 +01:00
parent d7b43b9975
commit f2325a2dc5
3 changed files with 126 additions and 13 deletions

View File

@@ -6909,4 +6909,6 @@ def get_icon_id(ma_name):
return icons[ma_name] return icons[ma_name]
else: else:
return icons["alert-circle-outline"] return icons["alert-circle-outline"]
def get_icon_char(ma_name):
return get_icon_id(ma_name)

View File

@@ -1,4 +1,5 @@
from icon_mapping import get_icon_id from icon_mapping import get_icon_char
import apis
weather_mapping = { weather_mapping = {
'clear-night': 'weather-night', 'clear-night': 'weather-night',
@@ -126,6 +127,53 @@ cover_mapping = {
"window": ("window-open", "window-closed", "arrow-up", "stop", "arrow-down"), "window": ("window-open", "window-closed", "arrow-up", "stop", "arrow-down"),
} }
simple_type_mapping = {
'button': 'gesture-tap-button',
'navigate': 'gesture-tap-button',
'input_button': 'gesture-tap-button',
'input_select': 'gesture-tap-button',
'scene': 'palette',
'script': 'script-text',
'switch': 'light-switch',
'automation': 'robot',
'number': 'ray-vertex',
'input_number': 'ray-vertex',
'light': 'lightbulb',
'fan': 'fan',
'person': 'account',
'vacuum': 'robot-vacuum'
}
alarm_control_panel_mapping = {
'disarmed': 'shield-off',
'armed_home': 'shield-home',
'armed_away': 'shield-lock',
'armed_night': 'weather-night',
'armed_vacation': 'shield-airplane',
'arming': 'shield',
'pending': 'shield',
'triggered': 'bell-ring'
}
climate_mapping = {
'auto': 'calendar-sync',
'heat_cool': 'calendar-sync',
'heat': 'fire',
'off': 'power',
'cool': 'snowflake',
'dry': 'water-percent',
'fan_only': 'fan'
}
media_content_type_mapping = {
'music': 'music',
'tvshow': 'movie',
'video': 'video',
'episode': 'alert-circle-outline',
'channel': 'alert-circle-outline',
'playlist': 'alert-circle-outline'
}
def map_to_mdi_name(ha_type, state=None, device_class="_", cardType=None): def map_to_mdi_name(ha_type, state=None, device_class="_", cardType=None):
if ha_type == "weather": if ha_type == "weather":
return weather_mapping[state] if state in weather_mapping else "alert-circle-outline" return weather_mapping[state] if state in weather_mapping else "alert-circle-outline"
@@ -215,16 +263,16 @@ def map_to_mdi_name(ha_type, state=None, device_class="_", cardType=None):
def get_icon(ha_type, state=None, device_class=None, overwrite=None): def get_icon(ha_type, state=None, device_class=None, overwrite=None):
if overwrite is not None: if overwrite is not None:
if type(overwrite) is str: if type(overwrite) is str:
return get_icon_id(overwrite) return get_icon_char(overwrite)
if type(overwrite) is dict: if type(overwrite) is dict:
for overwrite_state, overwrite_icon in overwrite.items(): for overwrite_state, overwrite_icon in overwrite.items():
if overwrite_state == state: if overwrite_state == state:
return get_icon_id(overwrite_icon) return get_icon_char(overwrite_icon)
return get_icon_id(map_to_mdi_name(ha_type, state, device_class)) return get_icon_char(map_to_mdi_name(ha_type, state, device_class))
def get_action_icon(ha_type, action, device_class=None, overwrite=None): def get_action_icon(ha_type, action, device_class=None, overwrite=None):
if overwrite is not None: if overwrite is not None:
return get_icon_id(overwrite) return get_icon_char(overwrite)
if ha_type == "cover": if ha_type == "cover":
if action == "open": if action == "open":
actionicon = cover_mapping[device_class][2] if device_class in cover_mapping else "alert-circle-outline" actionicon = cover_mapping[device_class][2] if device_class in cover_mapping else "alert-circle-outline"
@@ -236,4 +284,70 @@ def get_action_icon(ha_type, action, device_class=None, overwrite=None):
actionicon = "alert-circle-outline" actionicon = "alert-circle-outline"
else: else:
actionicon = "alert-circle-outline" actionicon = "alert-circle-outline"
return get_icon_id(actionicon) return get_icon_char(actionicon)
def get_icon_ha(entity_id, overwrite=None):
if overwrite is not None:
if type(overwrite) is str:
return get_icon_char(overwrite)
if type(overwrite) is dict:
for overwrite_state, overwrite_icon in overwrite.items():
if overwrite_state == state:
return get_icon_char(overwrite_icon)
result_icon = "alert-circle-outline"
ha_type = entity_id.split(".")[0]
if (apis.ha_api.entity_exists(entity_id)):
entity = apis.ha_api.get_entity(entity_id)
state = entity.state
# icons only based on state
if ha_type in simple_type_mapping:
result_icon = get_icon_char(simple_type_mapping[ha_type])
elif ha_type == "weather":
result_icon = weather_mapping[state] if state in weather_mapping else "alert-circle-outline"
elif ha_type == "input_boolean":
result_icon = "check-circle-outline" if state == "on" else "close-circle-outline"
elif ha_type == "lock":
result_icon = "lock-open" if state == "unlocked" else "lock"
elif ha_type == "sun":
result_icon = "weather-sunset-up" if state == "above_horizon" else "weather-sunset-down"
elif ha_type == "alarm_control_panel":
if state in alarm_control_panel_mapping:
result_icon = alarm_control_panel_mapping[state]
elif ha_type == "climate":
if state in climate_mapping:
result_icon = climate_mapping[state]
# icons only based on state and device_class
elif ha_type == "cover":
device_class = get_attr_safe(entity, "device_class", "window")
if state == "closed":
result_icon = cover_mapping[device_class][1] if device_class in cover_mapping else "alert-circle-outline"
else:
result_icon = cover_mapping[device_class][0] if device_class in cover_mapping else "alert-circle-outline"
elif ha_type == "sensor":
device_class = get_attr_safe(entity, "device_class", "")
result_icon = sensor_mapping[device_class] if device_class in sensor_mapping else "alert-circle-outline"
elif ha_type == "binary_sensor":
device_class = get_attr_safe(entity, "device_class", "")
if state == "on":
result_icon = "checkbox-marked-circle"
if device_class in sensor_mapping_on:
result_icon = sensor_mapping_on[device_class]
else:
result_icon = "radiobox-blank"
if device_class in sensor_mapping_off:
result_icon = sensor_mapping_off[device_class]
# based on media_content_type
elif ha_type == "media_player":
result_icon = "speaker-off"
if "media_content_type" in entity.attributes:
if entity.attributes.media_content_type in media_content_type_mapping:
result_icon = media_content_type_mapping[entity.attributes.media_content_type]
# TODO: get rid of this one
elif ha_type == "alarm-arm-fail":
result_icon = "progress-alert"
else:
result_icon = "alert-circle-outline"
return get_icon_char(result_icon)

View File

@@ -5,7 +5,7 @@ import apis
from theme import get_screensaver_color_output from theme import get_screensaver_color_output
from icon_mapping import get_icon_id from icon_mapping import get_icon_id
from icons import get_icon from icons import get_icon, get_icon_ha
from icons import get_action_icon from icons import get_action_icon
from helper import scale, rgb_dec565, rgb_brightness, get_attr_safe, convert_temperature from helper import scale, rgb_dec565, rgb_brightness, get_attr_safe, convert_temperature
from localization import get_translation from localization import get_translation
@@ -355,10 +355,7 @@ class LuiPagesGen(object):
value = get_translation(self._locale, f"frontend.state_badge.alarm_control_panel.{entity.state}") value = get_translation(self._locale, f"frontend.state_badge.alarm_control_panel.{entity.state}")
elif entityType == "media_player": elif entityType == "media_player":
entityTypePanel = "text" entityTypePanel = "text"
icon_id = get_icon_id('speaker-off') icon_id = get_icon_ha(entityId)
if "media_content_type" in entity.attributes:
if entity.attributes.media_content_type == "music":
icon_id = get_icon_id("music")
value = entity.state value = entity.state
elif entityType == "sun": elif entityType == "sun":
entityTypePanel = "text" entityTypePanel = "text"
@@ -791,7 +788,7 @@ class LuiPagesGen(object):
def generate_thermo_detail_page(self, entity_id): def generate_thermo_detail_page(self, entity_id):
entity = apis.ha_api.get_entity(entity_id) entity = apis.ha_api.get_entity(entity_id)
icon_id = get_icon("climate", state=entity.state) icon_id = get_icon_ha(entity_id)
icon_color = self.get_entity_color(entity, ha_type="climate") icon_color = self.get_entity_color(entity, ha_type="climate")
modes_out = "" modes_out = ""