mirror of
https://github.com/home-assistant/core.git
synced 2025-07-23 13:17:32 +00:00
Update iOS sensor (battery icon fix and format updates) (#9032)
* Update ios.py Clean up battery and charging icons (MDI was missing some versions), fix minor bug when battery level = 95% * Update ios.py Migrated function to battery icon util
This commit is contained in:
parent
7ac1e469b7
commit
597f53ae30
@ -6,6 +6,7 @@ https://home-assistant.io/ecosystem/ios/
|
|||||||
"""
|
"""
|
||||||
from homeassistant.components import ios
|
from homeassistant.components import ios
|
||||||
from homeassistant.helpers.entity import Entity
|
from homeassistant.helpers.entity import Entity
|
||||||
|
from homeassistant.util.icon import icon_for_battery_level
|
||||||
|
|
||||||
DEPENDENCIES = ['ios']
|
DEPENDENCIES = ['ios']
|
||||||
|
|
||||||
@ -83,44 +84,22 @@ class IOSSensor(Entity):
|
|||||||
device_battery = self._device[ios.ATTR_BATTERY]
|
device_battery = self._device[ios.ATTR_BATTERY]
|
||||||
battery_state = device_battery[ios.ATTR_BATTERY_STATE]
|
battery_state = device_battery[ios.ATTR_BATTERY_STATE]
|
||||||
battery_level = device_battery[ios.ATTR_BATTERY_LEVEL]
|
battery_level = device_battery[ios.ATTR_BATTERY_LEVEL]
|
||||||
rounded_level = round(battery_level, -1)
|
if (battery_state == ios.ATTR_BATTERY_STATE_FULL or
|
||||||
returning_icon_level = DEFAULT_ICON_LEVEL
|
battery_state == ios.ATTR_BATTERY_STATE_UNPLUGGED):
|
||||||
if battery_state == ios.ATTR_BATTERY_STATE_FULL:
|
icon_level = icon_for_battery_level(battery_level=battery_level,
|
||||||
returning_icon_level = DEFAULT_ICON_LEVEL
|
charging=False)
|
||||||
if battery_state == ios.ATTR_BATTERY_STATE_CHARGING:
|
icon_state = "{}-off".format(DEFAULT_ICON_STATE)
|
||||||
returning_icon_state = DEFAULT_ICON_STATE
|
|
||||||
else:
|
|
||||||
returning_icon_state = "{}-off".format(DEFAULT_ICON_STATE)
|
|
||||||
elif battery_state == ios.ATTR_BATTERY_STATE_CHARGING:
|
elif battery_state == ios.ATTR_BATTERY_STATE_CHARGING:
|
||||||
# Why is MDI missing 10, 50, 70?
|
icon_level = "{}-charging".format(DEFAULT_ICON_LEVEL)
|
||||||
if rounded_level in (20, 30, 40, 60, 80, 90, 100):
|
icon_state = DEFAULT_ICON_STATE
|
||||||
returning_icon_level = "{}-charging-{}".format(
|
|
||||||
DEFAULT_ICON_LEVEL, str(rounded_level))
|
|
||||||
returning_icon_state = DEFAULT_ICON_STATE
|
|
||||||
else:
|
|
||||||
returning_icon_level = "{}-charging".format(
|
|
||||||
DEFAULT_ICON_LEVEL)
|
|
||||||
returning_icon_state = DEFAULT_ICON_STATE
|
|
||||||
elif battery_state == ios.ATTR_BATTERY_STATE_UNPLUGGED:
|
|
||||||
if rounded_level < 10:
|
|
||||||
returning_icon_level = "{}-outline".format(
|
|
||||||
DEFAULT_ICON_LEVEL)
|
|
||||||
returning_icon_state = "{}-off".format(DEFAULT_ICON_STATE)
|
|
||||||
elif battery_level > 95:
|
|
||||||
returning_icon_state = "{}-off".format(DEFAULT_ICON_STATE)
|
|
||||||
returning_icon_level = "{}-outline".format(
|
|
||||||
DEFAULT_ICON_LEVEL)
|
|
||||||
else:
|
|
||||||
returning_icon_level = "{}-{}".format(DEFAULT_ICON_LEVEL,
|
|
||||||
str(rounded_level))
|
|
||||||
returning_icon_state = "{}-off".format(DEFAULT_ICON_STATE)
|
|
||||||
elif battery_state == ios.ATTR_BATTERY_STATE_UNKNOWN:
|
elif battery_state == ios.ATTR_BATTERY_STATE_UNKNOWN:
|
||||||
returning_icon_level = "{}-unknown".format(DEFAULT_ICON_LEVEL)
|
icon_level = icon_for_battery_level(battery_level=None,
|
||||||
returning_icon_state = "{}-unknown".format(DEFAULT_ICON_LEVEL)
|
charging=False)
|
||||||
|
icon_state = "{}-unknown".format(DEFAULT_ICON_LEVEL)
|
||||||
|
|
||||||
if self.type == "state":
|
if self.type == "state":
|
||||||
return returning_icon_state
|
return icon_state
|
||||||
return returning_icon_level
|
return icon_level
|
||||||
|
|
||||||
def update(self):
|
def update(self):
|
||||||
"""Get the latest state of the sensor."""
|
"""Get the latest state of the sensor."""
|
||||||
|
Loading…
x
Reference in New Issue
Block a user