mirror of
https://github.com/home-assistant/core.git
synced 2026-04-17 23:53:49 +01:00
Use different name source in Zinvolt (#164072)
This commit is contained in:
committed by
GitHub
parent
91ca674a36
commit
1d97729547
@@ -34,7 +34,7 @@ async def async_setup_entry(hass: HomeAssistant, entry: ZinvoltConfigEntry) -> b
|
||||
coordinators: dict[str, ZinvoltDeviceCoordinator] = {}
|
||||
tasks = []
|
||||
for battery in batteries:
|
||||
coordinator = ZinvoltDeviceCoordinator(hass, entry, client, battery.identifier)
|
||||
coordinator = ZinvoltDeviceCoordinator(hass, entry, client, battery)
|
||||
tasks.append(coordinator.async_config_entry_first_refresh())
|
||||
coordinators[battery.identifier] = coordinator
|
||||
await asyncio.gather(*tasks)
|
||||
|
||||
@@ -5,7 +5,7 @@ import logging
|
||||
|
||||
from zinvolt import ZinvoltClient
|
||||
from zinvolt.exceptions import ZinvoltError
|
||||
from zinvolt.models import BatteryState
|
||||
from zinvolt.models import Battery, BatteryState
|
||||
|
||||
from homeassistant.config_entries import ConfigEntry
|
||||
from homeassistant.core import HomeAssistant
|
||||
@@ -26,23 +26,23 @@ class ZinvoltDeviceCoordinator(DataUpdateCoordinator[BatteryState]):
|
||||
hass: HomeAssistant,
|
||||
config_entry: ZinvoltConfigEntry,
|
||||
client: ZinvoltClient,
|
||||
battery_id: str,
|
||||
battery: Battery,
|
||||
) -> None:
|
||||
"""Initialize the Zinvolt device."""
|
||||
super().__init__(
|
||||
hass,
|
||||
_LOGGER,
|
||||
config_entry=config_entry,
|
||||
name=f"Zinvolt {battery_id}",
|
||||
name=f"Zinvolt {battery.identifier}",
|
||||
update_interval=timedelta(minutes=5),
|
||||
)
|
||||
self.battery_id = battery_id
|
||||
self.battery = battery
|
||||
self.client = client
|
||||
|
||||
async def _async_update_data(self) -> BatteryState:
|
||||
"""Update data from Zinvolt."""
|
||||
try:
|
||||
return await self.client.get_battery_status(self.battery_id)
|
||||
return await self.client.get_battery_status(self.battery.identifier)
|
||||
except ZinvoltError as err:
|
||||
raise UpdateFailed(
|
||||
translation_key="update_failed",
|
||||
|
||||
@@ -18,6 +18,6 @@ class ZinvoltEntity(CoordinatorEntity[ZinvoltDeviceCoordinator]):
|
||||
self._attr_device_info = DeviceInfo(
|
||||
identifiers={(DOMAIN, coordinator.data.serial_number)},
|
||||
manufacturer="Zinvolt",
|
||||
name=coordinator.data.name,
|
||||
name=coordinator.battery.name,
|
||||
serial_number=coordinator.data.serial_number,
|
||||
)
|
||||
|
||||
@@ -126,5 +126,5 @@ class ZinvoltBatteryStateNumber(ZinvoltEntity, NumberEntity):
|
||||
async def async_set_native_value(self, value: float) -> None:
|
||||
"""Set the state of the sensor."""
|
||||
await self.entity_description.set_value_fn(
|
||||
self.coordinator.client, self.coordinator.battery_id, int(value)
|
||||
self.coordinator.client, self.coordinator.battery.identifier, int(value)
|
||||
)
|
||||
|
||||
@@ -1,6 +1,6 @@
|
||||
{
|
||||
"sn": "ZVG011025120088",
|
||||
"name": "Zinvolt Batterij",
|
||||
"name": "ZVG011025120088",
|
||||
"onlineStatus": "ONLINE",
|
||||
"currentPower": {
|
||||
"soc": 100,
|
||||
|
||||
Reference in New Issue
Block a user