mirror of
https://github.com/XiaoMi/ha_xiaomi_home.git
synced 2025-04-03 08:15:30 +08:00
Merge 9d88e609ca6dab0754f2237abece4c08a8d9e965 into 7d9250914ce7c820e3cdc7d81bcf7aff3070751f
This commit is contained in:
commit
9bc36e2c3a
@ -213,6 +213,12 @@ class MIoTSpecValueList:
|
|||||||
return item.description
|
return item.description
|
||||||
return None
|
return None
|
||||||
|
|
||||||
|
def get_name_by_value(self, value: Any) -> Optional[str]:
|
||||||
|
for item in self.items:
|
||||||
|
if item.value == value:
|
||||||
|
return item.name
|
||||||
|
return None
|
||||||
|
|
||||||
def dump(self) -> list:
|
def dump(self) -> list:
|
||||||
return [item.dump() for item in self.items]
|
return [item.dump() for item in self.items]
|
||||||
|
|
||||||
|
@ -54,7 +54,8 @@ from homeassistant.core import HomeAssistant
|
|||||||
from homeassistant.helpers.entity_platform import AddEntitiesCallback
|
from homeassistant.helpers.entity_platform import AddEntitiesCallback
|
||||||
from homeassistant.components.vacuum import (
|
from homeassistant.components.vacuum import (
|
||||||
StateVacuumEntity,
|
StateVacuumEntity,
|
||||||
VacuumEntityFeature
|
VacuumEntityFeature,
|
||||||
|
VacuumActivity
|
||||||
)
|
)
|
||||||
|
|
||||||
from .miot.const import DOMAIN
|
from .miot.const import DOMAIN
|
||||||
@ -191,10 +192,47 @@ class Vacuum(MIoTServiceEntity, StateVacuumEntity):
|
|||||||
|
|
||||||
@property
|
@property
|
||||||
def state(self) -> Optional[str]:
|
def state(self) -> Optional[str]:
|
||||||
"""Return the current state of the vacuum cleaner."""
|
"""Return the current state of the vacuum cleaner.
|
||||||
|
|
||||||
|
To fix the HA warning below:
|
||||||
|
Detected that custom integration 'xiaomi_home' is setting state
|
||||||
|
directly.Entity XXX(<class 'custom_components.xiaomi_home.vacuum
|
||||||
|
.Vacuum'>)should implement the 'activity' property and return
|
||||||
|
its state using the VacuumActivity enum.This will stop working in
|
||||||
|
Home Assistant 2026.1.
|
||||||
|
|
||||||
|
Refer to
|
||||||
|
https://developers.home-assistant.io/blog/2024/12/08/new-vacuum-state-property
|
||||||
|
|
||||||
|
There are only 6 states in VacuumActivity enum. To be compatible with
|
||||||
|
more constants, try get matching VacuumActivity enum first, return state
|
||||||
|
string as before if there is no match. In Home Assistant 2026.1, every
|
||||||
|
state should map to a VacuumActivity enum.
|
||||||
|
"""
|
||||||
|
if (activity := self.activity) is not None:
|
||||||
|
return activity
|
||||||
return self.get_map_value(
|
return self.get_map_value(
|
||||||
map_=self._status_map,
|
map_=self._status_map,
|
||||||
key=self.get_prop_value(prop=self._prop_status))
|
key=self.get_prop_value(prop=self._prop_status)
|
||||||
|
)
|
||||||
|
|
||||||
|
@property
|
||||||
|
def activity(self) -> VacuumActivity | None:
|
||||||
|
"""Return the current vacuum activity."""
|
||||||
|
state_trans_map = {
|
||||||
|
'Sleep': VacuumActivity.IDLE,
|
||||||
|
'Idle': VacuumActivity.IDLE,
|
||||||
|
'Paused': VacuumActivity.PAUSED,
|
||||||
|
'Go Charging': VacuumActivity.RETURNING,
|
||||||
|
'Charging': VacuumActivity.DOCKED,
|
||||||
|
'Sweeping': VacuumActivity.CLEANING,
|
||||||
|
'Sweeping and Mopping': VacuumActivity.CLEANING,
|
||||||
|
'Mopping': VacuumActivity.CLEANING,
|
||||||
|
'Error': VacuumActivity.ERROR,
|
||||||
|
}
|
||||||
|
prop_value = self.get_prop_value(prop=self._prop_status)
|
||||||
|
state_name = self._prop_status.value_list.get_name_by_value(prop_value)
|
||||||
|
return state_trans_map.get(state_name)
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def battery_level(self) -> Optional[int]:
|
def battery_level(self) -> Optional[int]:
|
||||||
|
Loading…
x
Reference in New Issue
Block a user