mirror of
https://github.com/home-assistant/core.git
synced 2025-07-27 07:07:28 +00:00
Update isy994 to use new fan entity model (#45536)
This commit is contained in:
parent
85e463d507
commit
ee592350b3
@ -1,36 +1,22 @@
|
|||||||
"""Support for ISY994 fans."""
|
"""Support for ISY994 fans."""
|
||||||
|
import math
|
||||||
from typing import Callable
|
from typing import Callable
|
||||||
|
|
||||||
from pyisy.constants import ISY_VALUE_UNKNOWN
|
from pyisy.constants import ISY_VALUE_UNKNOWN
|
||||||
|
|
||||||
from homeassistant.components.fan import (
|
from homeassistant.components.fan import DOMAIN as FAN, SUPPORT_SET_SPEED, FanEntity
|
||||||
DOMAIN as FAN,
|
|
||||||
SPEED_HIGH,
|
|
||||||
SPEED_LOW,
|
|
||||||
SPEED_MEDIUM,
|
|
||||||
SPEED_OFF,
|
|
||||||
SUPPORT_SET_SPEED,
|
|
||||||
FanEntity,
|
|
||||||
)
|
|
||||||
from homeassistant.config_entries import ConfigEntry
|
from homeassistant.config_entries import ConfigEntry
|
||||||
from homeassistant.helpers.typing import HomeAssistantType
|
from homeassistant.helpers.typing import HomeAssistantType
|
||||||
|
from homeassistant.util.percentage import (
|
||||||
|
percentage_to_ranged_value,
|
||||||
|
ranged_value_to_percentage,
|
||||||
|
)
|
||||||
|
|
||||||
from .const import _LOGGER, DOMAIN as ISY994_DOMAIN, ISY994_NODES, ISY994_PROGRAMS
|
from .const import _LOGGER, DOMAIN as ISY994_DOMAIN, ISY994_NODES, ISY994_PROGRAMS
|
||||||
from .entity import ISYNodeEntity, ISYProgramEntity
|
from .entity import ISYNodeEntity, ISYProgramEntity
|
||||||
from .helpers import migrate_old_unique_ids
|
from .helpers import migrate_old_unique_ids
|
||||||
|
|
||||||
VALUE_TO_STATE = {
|
SPEED_RANGE = (1, 255) # off is not included
|
||||||
0: SPEED_OFF,
|
|
||||||
63: SPEED_LOW,
|
|
||||||
64: SPEED_LOW,
|
|
||||||
190: SPEED_MEDIUM,
|
|
||||||
191: SPEED_MEDIUM,
|
|
||||||
255: SPEED_HIGH,
|
|
||||||
}
|
|
||||||
|
|
||||||
STATE_TO_VALUE = {}
|
|
||||||
for key in VALUE_TO_STATE:
|
|
||||||
STATE_TO_VALUE[VALUE_TO_STATE[key]] = key
|
|
||||||
|
|
||||||
|
|
||||||
async def async_setup_entry(
|
async def async_setup_entry(
|
||||||
@ -56,9 +42,11 @@ class ISYFanEntity(ISYNodeEntity, FanEntity):
|
|||||||
"""Representation of an ISY994 fan device."""
|
"""Representation of an ISY994 fan device."""
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def speed(self) -> str:
|
def percentage(self) -> str:
|
||||||
"""Return the current speed."""
|
"""Return the current speed percentage."""
|
||||||
return VALUE_TO_STATE.get(self._node.status)
|
if self._node.status == ISY_VALUE_UNKNOWN:
|
||||||
|
return None
|
||||||
|
return ranged_value_to_percentage(SPEED_RANGE, self._node.status)
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def is_on(self) -> bool:
|
def is_on(self) -> bool:
|
||||||
@ -67,17 +55,16 @@ class ISYFanEntity(ISYNodeEntity, FanEntity):
|
|||||||
return None
|
return None
|
||||||
return self._node.status != 0
|
return self._node.status != 0
|
||||||
|
|
||||||
def set_speed(self, speed: str) -> None:
|
def set_percentage(self, percentage: int) -> None:
|
||||||
"""Send the set speed command to the ISY994 fan device."""
|
"""Set node to speed percentage for the ISY994 fan device."""
|
||||||
self._node.turn_on(val=STATE_TO_VALUE.get(speed, 255))
|
if percentage == 0:
|
||||||
|
self._node.turn_off()
|
||||||
|
return
|
||||||
|
|
||||||
|
isy_speed = math.ceil(percentage_to_ranged_value(SPEED_RANGE, percentage))
|
||||||
|
|
||||||
|
self._node.turn_on(val=isy_speed)
|
||||||
|
|
||||||
#
|
|
||||||
# The fan entity model has changed to use percentages and preset_modes
|
|
||||||
# instead of speeds.
|
|
||||||
#
|
|
||||||
# Please review
|
|
||||||
# https://developers.home-assistant.io/docs/core/entity/fan/
|
|
||||||
#
|
|
||||||
def turn_on(
|
def turn_on(
|
||||||
self,
|
self,
|
||||||
speed: str = None,
|
speed: str = None,
|
||||||
@ -86,17 +73,12 @@ class ISYFanEntity(ISYNodeEntity, FanEntity):
|
|||||||
**kwargs,
|
**kwargs,
|
||||||
) -> None:
|
) -> None:
|
||||||
"""Send the turn on command to the ISY994 fan device."""
|
"""Send the turn on command to the ISY994 fan device."""
|
||||||
self.set_speed(speed)
|
self.set_percentage(percentage)
|
||||||
|
|
||||||
def turn_off(self, **kwargs) -> None:
|
def turn_off(self, **kwargs) -> None:
|
||||||
"""Send the turn off command to the ISY994 fan device."""
|
"""Send the turn off command to the ISY994 fan device."""
|
||||||
self._node.turn_off()
|
self._node.turn_off()
|
||||||
|
|
||||||
@property
|
|
||||||
def speed_list(self) -> list:
|
|
||||||
"""Get the list of available speeds."""
|
|
||||||
return [SPEED_OFF, SPEED_LOW, SPEED_MEDIUM, SPEED_HIGH]
|
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def supported_features(self) -> int:
|
def supported_features(self) -> int:
|
||||||
"""Flag supported features."""
|
"""Flag supported features."""
|
||||||
@ -107,9 +89,11 @@ class ISYFanProgramEntity(ISYProgramEntity, FanEntity):
|
|||||||
"""Representation of an ISY994 fan program."""
|
"""Representation of an ISY994 fan program."""
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def speed(self) -> str:
|
def percentage(self) -> str:
|
||||||
"""Return the current speed."""
|
"""Return the current speed percentage."""
|
||||||
return VALUE_TO_STATE.get(self._node.status)
|
if self._node.status == ISY_VALUE_UNKNOWN:
|
||||||
|
return None
|
||||||
|
return ranged_value_to_percentage(SPEED_RANGE, self._node.status)
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def is_on(self) -> bool:
|
def is_on(self) -> bool:
|
||||||
@ -121,13 +105,6 @@ class ISYFanProgramEntity(ISYProgramEntity, FanEntity):
|
|||||||
if not self._actions.run_then():
|
if not self._actions.run_then():
|
||||||
_LOGGER.error("Unable to turn off the fan")
|
_LOGGER.error("Unable to turn off the fan")
|
||||||
|
|
||||||
#
|
|
||||||
# The fan entity model has changed to use percentages and preset_modes
|
|
||||||
# instead of speeds.
|
|
||||||
#
|
|
||||||
# Please review
|
|
||||||
# https://developers.home-assistant.io/docs/core/entity/fan/
|
|
||||||
#
|
|
||||||
def turn_on(
|
def turn_on(
|
||||||
self,
|
self,
|
||||||
speed: str = None,
|
speed: str = None,
|
||||||
|
Loading…
x
Reference in New Issue
Block a user