Fix battery reading in SOMA API (#99403)
Co-authored-by: Robert Resch <robert@resch.dev>
This commit is contained in:
parent
de1de926a9
commit
b9536732bc
1 changed files with 7 additions and 6 deletions
|
@ -43,11 +43,12 @@ class SomaSensor(SomaEntity, SensorEntity):
|
|||
async def async_update(self) -> None:
|
||||
"""Update the sensor with the latest data."""
|
||||
response = await self.get_battery_level_from_api()
|
||||
|
||||
# https://support.somasmarthome.com/hc/en-us/articles/360026064234-HTTP-API
|
||||
# battery_level response is expected to be min = 360, max 410 for
|
||||
# 0-100% levels above 410 are consider 100% and below 360, 0% as the
|
||||
# device considers 360 the minimum to move the motor.
|
||||
_battery = round(2 * (response["battery_level"] - 360))
|
||||
_battery = response.get("battery_percentage")
|
||||
if _battery is None:
|
||||
# https://support.somasmarthome.com/hc/en-us/articles/360026064234-HTTP-API
|
||||
# battery_level response is expected to be min = 360, max 410 for
|
||||
# 0-100% levels above 410 are consider 100% and below 360, 0% as the
|
||||
# device considers 360 the minimum to move the motor.
|
||||
_battery = round(2 * (response["battery_level"] - 360))
|
||||
battery = max(min(100, _battery), 0)
|
||||
self.battery_state = battery
|
||||
|
|
Loading…
Add table
Reference in a new issue