2023-01-08 13:24:20 +00:00
|
|
|
"""Battery sensor for the Nuki Lock."""
|
2024-03-08 14:04:07 +00:00
|
|
|
|
2023-01-26 21:03:36 +00:00
|
|
|
from __future__ import annotations
|
|
|
|
|
|
|
|
from pynuki.device import NukiDevice
|
2023-01-08 13:24:20 +00:00
|
|
|
|
|
|
|
from homeassistant.components.sensor import SensorDeviceClass, SensorEntity
|
|
|
|
from homeassistant.config_entries import ConfigEntry
|
2023-02-09 19:15:37 +00:00
|
|
|
from homeassistant.const import PERCENTAGE, EntityCategory
|
2023-01-08 13:24:20 +00:00
|
|
|
from homeassistant.core import HomeAssistant
|
2025-02-10 20:08:03 +00:00
|
|
|
from homeassistant.helpers.entity_platform import AddConfigEntryEntitiesCallback
|
2023-01-08 13:24:20 +00:00
|
|
|
|
2024-09-23 09:55:03 +00:00
|
|
|
from . import NukiEntryData
|
2024-09-06 12:49:05 +00:00
|
|
|
from .const import DOMAIN as NUKI_DOMAIN
|
2024-09-23 09:55:03 +00:00
|
|
|
from .entity import NukiEntity
|
2023-01-08 13:24:20 +00:00
|
|
|
|
|
|
|
|
|
|
|
async def async_setup_entry(
|
2025-02-10 20:08:03 +00:00
|
|
|
hass: HomeAssistant,
|
|
|
|
entry: ConfigEntry,
|
|
|
|
async_add_entities: AddConfigEntryEntitiesCallback,
|
2023-01-08 13:24:20 +00:00
|
|
|
) -> None:
|
|
|
|
"""Set up the Nuki lock sensor."""
|
2023-10-22 14:30:34 +00:00
|
|
|
entry_data: NukiEntryData = hass.data[NUKI_DOMAIN][entry.entry_id]
|
2023-01-08 13:24:20 +00:00
|
|
|
|
|
|
|
async_add_entities(
|
2023-10-22 14:30:34 +00:00
|
|
|
NukiBatterySensor(entry_data.coordinator, lock) for lock in entry_data.locks
|
2023-01-08 13:24:20 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
|
2023-01-26 21:03:36 +00:00
|
|
|
class NukiBatterySensor(NukiEntity[NukiDevice], SensorEntity):
|
2023-01-08 13:24:20 +00:00
|
|
|
"""Representation of a Nuki Lock Battery sensor."""
|
|
|
|
|
|
|
|
_attr_has_entity_name = True
|
|
|
|
_attr_native_unit_of_measurement = PERCENTAGE
|
|
|
|
_attr_device_class = SensorDeviceClass.BATTERY
|
|
|
|
_attr_entity_category = EntityCategory.DIAGNOSTIC
|
|
|
|
|
|
|
|
@property
|
|
|
|
def unique_id(self) -> str:
|
|
|
|
"""Return a unique ID."""
|
|
|
|
return f"{self._nuki_device.nuki_id}_battery_level"
|
|
|
|
|
|
|
|
@property
|
|
|
|
def native_value(self) -> float:
|
|
|
|
"""Return the state of the sensor."""
|
|
|
|
return self._nuki_device.battery_charge
|