Skip to content

Commit

Permalink
Refactor of unique ID and entity description handling in Rituals Perf…
Browse files Browse the repository at this point in the history
…ume Genie (#92545)
  • Loading branch information
frenck committed May 4, 2023
1 parent 7b8936b commit 9e529d1
Show file tree
Hide file tree
Showing 6 changed files with 9 additions and 16 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -77,9 +77,7 @@ def __init__(
description: RitualsBinarySensorEntityDescription,
) -> None:
"""Initialize Rituals binary sensor entity."""
super().__init__(coordinator)
self.entity_description = description
self._attr_unique_id = f"{coordinator.diffuser.hublot}-{description.key}"
super().__init__(coordinator, description)
self._attr_name = f"{coordinator.diffuser.name} {description.name}"

@property
Expand Down
5 changes: 4 additions & 1 deletion homeassistant/components/rituals_perfume_genie/entity.py
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
"""Base class for Rituals Perfume Genie diffuser entity."""
from __future__ import annotations

from homeassistant.helpers.entity import DeviceInfo
from homeassistant.helpers.entity import DeviceInfo, EntityDescription
from homeassistant.helpers.update_coordinator import CoordinatorEntity

from .const import DOMAIN
Expand All @@ -18,9 +18,12 @@ class DiffuserEntity(CoordinatorEntity[RitualsDataUpdateCoordinator]):
def __init__(
self,
coordinator: RitualsDataUpdateCoordinator,
description: EntityDescription,
) -> None:
"""Init from config, hookup diffuser and coordinator."""
super().__init__(coordinator)
self.entity_description = description
self._attr_unique_id = f"{coordinator.diffuser.hublot}-{description.key}"
self._attr_device_info = DeviceInfo(
identifiers={(DOMAIN, coordinator.diffuser.hublot)},
manufacturer=MANUFACTURER,
Expand Down
4 changes: 1 addition & 3 deletions homeassistant/components/rituals_perfume_genie/number.py
Original file line number Diff line number Diff line change
Expand Up @@ -72,9 +72,7 @@ def __init__(
description: RitualsNumberEntityDescription,
) -> None:
"""Initialize the diffuser perfume amount number."""
super().__init__(coordinator)
self.entity_description = description
self._attr_unique_id = f"{coordinator.diffuser.hublot}-{description.key}"
super().__init__(coordinator, description)
self._attr_name = f"{coordinator.diffuser.name} {description.name}"

@property
Expand Down
4 changes: 1 addition & 3 deletions homeassistant/components/rituals_perfume_genie/select.py
Original file line number Diff line number Diff line change
Expand Up @@ -76,12 +76,10 @@ def __init__(
description: RitualsSelectEntityDescription,
) -> None:
"""Initialize the diffuser room size select entity."""
super().__init__(coordinator)
self.entity_description = description
super().__init__(coordinator, description)
self._attr_entity_registry_enabled_default = (
self.coordinator.diffuser.has_battery
)
self._attr_unique_id = f"{coordinator.diffuser.hublot}-{description.key}"
self._attr_name = f"{coordinator.diffuser.name} {description.name}"

@property
Expand Down
4 changes: 1 addition & 3 deletions homeassistant/components/rituals_perfume_genie/sensor.py
Original file line number Diff line number Diff line change
Expand Up @@ -98,9 +98,7 @@ def __init__(
description: RitualsSensorEntityDescription,
) -> None:
"""Initialize the diffuser sensor."""
super().__init__(coordinator)
self.entity_description = description
self._attr_unique_id = f"{coordinator.diffuser.hublot}-{description.key}"
super().__init__(coordinator, description)
self._attr_name = f"{coordinator.diffuser.name} {description.name}"

@property
Expand Down
4 changes: 1 addition & 3 deletions homeassistant/components/rituals_perfume_genie/switch.py
Original file line number Diff line number Diff line change
Expand Up @@ -72,9 +72,7 @@ def __init__(
description: RitualsSwitchEntityDescription,
) -> None:
"""Initialize the diffuser switch."""
super().__init__(coordinator)
self.entity_description = description
self._attr_unique_id = f"{coordinator.diffuser.hublot}-{description.key}"
super().__init__(coordinator, description)
self._attr_name = coordinator.diffuser.name
self._attr_is_on = description.is_on_fn(coordinator.diffuser)

Expand Down

0 comments on commit 9e529d1

Please sign in to comment.