mirror of
https://github.com/XiaoMi/ha_xiaomi_home.git
synced 2026-01-16 14:40:43 +08:00
Merge 84e79c3435 into 5d4b975f85
This commit is contained in:
commit
a2a24eb47a
@ -93,7 +93,7 @@ class WaterHeater(MIoTServiceEntity, WaterHeaterEntity):
|
|||||||
_prop_target_temp: Optional[MIoTSpecProperty]
|
_prop_target_temp: Optional[MIoTSpecProperty]
|
||||||
_prop_mode: Optional[MIoTSpecProperty]
|
_prop_mode: Optional[MIoTSpecProperty]
|
||||||
|
|
||||||
_mode_list: Optional[dict[Any, Any]]
|
_mode_map: Optional[dict[int, str]]
|
||||||
|
|
||||||
def __init__(
|
def __init__(
|
||||||
self, miot_device: MIoTDevice, entity_data: MIoTEntityData
|
self, miot_device: MIoTDevice, entity_data: MIoTEntityData
|
||||||
@ -113,6 +113,8 @@ class WaterHeater(MIoTServiceEntity, WaterHeaterEntity):
|
|||||||
# on
|
# on
|
||||||
if prop.name == 'on':
|
if prop.name == 'on':
|
||||||
self._prop_on = prop
|
self._prop_on = prop
|
||||||
|
self._attr_supported_features |= (
|
||||||
|
WaterHeaterEntityFeature.ON_OFF)
|
||||||
# temperature
|
# temperature
|
||||||
if prop.name == 'temperature':
|
if prop.name == 'temperature':
|
||||||
if isinstance(prop.value_range, dict):
|
if isinstance(prop.value_range, dict):
|
||||||
@ -145,10 +147,10 @@ class WaterHeater(MIoTServiceEntity, WaterHeaterEntity):
|
|||||||
_LOGGER.error(
|
_LOGGER.error(
|
||||||
'mode value_list is None, %s', self.entity_id)
|
'mode value_list is None, %s', self.entity_id)
|
||||||
continue
|
continue
|
||||||
self._mode_list = {
|
self._mode_map = {
|
||||||
item['value']: item['description']
|
item['value']: item['description']
|
||||||
for item in prop.value_list}
|
for item in prop.value_list}
|
||||||
self._attr_operation_list = list(self._mode_list.values())
|
self._attr_operation_list = list(self._mode_map.values())
|
||||||
self._attr_supported_features |= (
|
self._attr_supported_features |= (
|
||||||
WaterHeaterEntityFeature.OPERATION_MODE)
|
WaterHeaterEntityFeature.OPERATION_MODE)
|
||||||
self._prop_mode = prop
|
self._prop_mode = prop
|
||||||
@ -184,7 +186,8 @@ class WaterHeater(MIoTServiceEntity, WaterHeaterEntity):
|
|||||||
prop=self._prop_on, value=True, update=False)
|
prop=self._prop_on, value=True, update=False)
|
||||||
await self.set_property_async(
|
await self.set_property_async(
|
||||||
prop=self._prop_mode,
|
prop=self._prop_mode,
|
||||||
value=self.__get_mode_value(description=operation_mode))
|
value=self.get_map_value(
|
||||||
|
map_=self._mode_map, description=operation_mode))
|
||||||
|
|
||||||
async def async_turn_away_mode_on(self) -> None:
|
async def async_turn_away_mode_on(self) -> None:
|
||||||
"""Set the water heater to away mode."""
|
"""Set the water heater to away mode."""
|
||||||
@ -207,20 +210,4 @@ class WaterHeater(MIoTServiceEntity, WaterHeaterEntity):
|
|||||||
return STATE_OFF
|
return STATE_OFF
|
||||||
if not self._prop_mode and self.get_prop_value(prop=self._prop_on):
|
if not self._prop_mode and self.get_prop_value(prop=self._prop_on):
|
||||||
return STATE_ON
|
return STATE_ON
|
||||||
return self.__get_mode_description(
|
return self._mode_map[self.get_prop_value(prop=self._prop_mode)]
|
||||||
key=self.get_prop_value(prop=self._prop_mode))
|
|
||||||
|
|
||||||
def __get_mode_description(self, key: int) -> Optional[str]:
|
|
||||||
"""Convert mode value to description."""
|
|
||||||
if self._mode_list is None:
|
|
||||||
return None
|
|
||||||
return self._mode_list.get(key, None)
|
|
||||||
|
|
||||||
def __get_mode_value(self, description: str) -> Optional[int]:
|
|
||||||
"""Convert mode description to value."""
|
|
||||||
if self._mode_list is None:
|
|
||||||
return None
|
|
||||||
for key, value in self._mode_list.items():
|
|
||||||
if value == description:
|
|
||||||
return key
|
|
||||||
return None
|
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user