diff --git a/.github/ISSUE_TEMPLATE/bug_report.md b/.github/ISSUE_TEMPLATE/bug_report.md
new file mode 100644
index 0000000..661bc9c
--- /dev/null
+++ b/.github/ISSUE_TEMPLATE/bug_report.md
@@ -0,0 +1,39 @@
+---
+name: Bug report
+about: Create a report to help us improve
+title: ''
+labels: bug
+assignees: Andre0512
+
+---
+
+**Describe the bug**
+A clear and concise description of what the bug is.
+
+**To Reproduce**
+Steps to reproduce the behavior:
+1. Go to '...'
+2. Click on '....'
+3. Scroll down to '....'
+4. See error
+
+**Expected behavior**
+A clear and concise description of what you expected to happen.
+
+**Screenshots**
+If applicable, add screenshots to help explain your problem.
+
+**Environment (please complete the following information):**
+ - Home Assistant Version: [e.g. `2023.6.1`]
+ - hOn Integration Version [e.g. `0.8.1`, can be found in HACS]
+ - pyhOn Version [e.g. `0.13.1`, can be found in device log]
+
+**Additional context**
+Add any other context about the problem here.
+
+**Device Log**
+Post your device info here (if available)
+1. Enable the "Show Device Info" button
+_This button can be found in the diagnostic section of your device or in the entity overview if "show disabled entities" is enabled._
+2. Press the button to create a notification
+3. Open home assistant notifications and copy the message (Crtl+A, Ctrl+C)
diff --git a/.github/ISSUE_TEMPLATE/feature_request.md b/.github/ISSUE_TEMPLATE/feature_request.md
new file mode 100644
index 0000000..cb133ce
--- /dev/null
+++ b/.github/ISSUE_TEMPLATE/feature_request.md
@@ -0,0 +1,26 @@
+---
+name: Feature request
+about: Suggest an idea for this project
+title: ''
+labels: enhancement
+assignees: Andre0512
+
+---
+
+**Is your feature request related to a problem? Please describe.**
+A clear and concise description of what the problem is. Ex. I'm always frustrated when [...]
+
+**Describe the solution you'd like**
+A clear and concise description of what you want to happen.
+
+**Describe alternatives you've considered**
+A clear and concise description of any alternative solutions or features you've considered.
+
+**Device Log**
+Post your device info here (if available)
+1. Enable the "Show Device Info" button
+_This button can be found in the diagnostic section of your device or in the entity overview if "show disabled entities" is enabled._
+2. Press the button to create a notification
+3. Open home assistant notifications and copy the message (Crtl+A, Ctrl+C)
+**Additional context**
+Add any other context or screenshots about the feature request here.
diff --git a/README.md b/README.md
index 06b1777..e5e4f34 100644
--- a/README.md
+++ b/README.md
@@ -14,9 +14,10 @@ Home Assistant integration for [Haier's mobile app hOn](https://hon-smarthome.co
- [Dish Washer](https://github.com/Andre0512/hon#dish-washer)
- [Air conditioner](https://github.com/Andre0512/hon#air-conditioner)
- [Fridge](https://github.com/Andre0512/hon#fridge)
-- [Hob](https://github.com/Andre0512/hon#hob) [BETA]
+- [Induction Hob](https://github.com/Andre0512/hon#induction-hob) [BETA]
- [Hood](https://github.com/Andre0512/hon#hood) [BETA]
- [Wine Cellar](https://github.com/Andre0512/hon#wine-cellar) [BETA]
+- [Air Purifier](https://github.com/Andre0512/hon#air-purifier) [BETA]
## Installation
**Method 1:** [![Open your Home Assistant instance and open a repository inside the Home Assistant Community Store.](https://my.home-assistant.io/badges/hacs_repository.svg)](https://my.home-assistant.io/redirect/hacs_repository/?owner=Andre0512&repository=hon&category=integration)
@@ -37,18 +38,18 @@ _If the integration is not in the list, you need to clear the browser cache._
## Supported Models
Support has been confirmed for these models, but many more will work. Please add already supported devices [with this form to complete the list](https://forms.gle/bTSD8qFotdZFytbf8).
-| | **Haier** | **Hoover** | **Candy** |
-|---------------------|------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------|
-| **Washing Machine** | HW90-B14TEAM5
HW100-B14959U1 | H-WASH 500
H7W4 48MBC-S | RO441286DWMC4-07
HW 68AMC/1-80
HWPD 69AMBC/1-S |
-| **Tumble Dryer** | HD80-A3959 | H-DRY 500
H9A3TCBEXS-S
HLE C10DCE-80
NDE H10A2TCE-80
NDE H9A2TSBEXS-S
NDPHY10A2TCBEXSS | BCTDH7A1TE
CSOE C10DE-80
ROE H9A3TCEX-S |
-| **Washer Dryer** | HWD100-B14979 | HWPS4954DAMR-11 | RPW41066BWMR/1-S |
-| **Oven** | HWO60SM2F3XH | HSOT3161WG | |
-| **Dish Washer** | XIB 3B2SFS-80
XIB 6B2D3FB | HFB 6B2S3FX | |
-| **Air conditioner** | AD105S2SM3FA
AS20HPL1HRA
AS25PBAHRA
AS25S2SF1FA-WH
AS25TADHRA-2
AS35TADHRA-2
| | |
-| **Fridge** | HFW7720ENMB | | CCE4T620EWU |
-| **Hob** | HA2MTSJ68MC | | CIS633SCTTWIFI |
-| **Hood** | HADG6DS46BWIFI | | |
-| **Wine Cellar** | HWS247FDU1 | | |
+| | **Haier** | **Hoover** | **Candy** |
+|---------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------|
+| **Washing Machine** | HW90-B14TEAM5
HW100-B14959U1 | H-WASH 500
H7W4 48MBC-S | CO4 107T1/2-07
CBWO49TWME-S
RO44 1286DWMC4-07
HW 68AMC/1-80
HWPD 69AMBC/1-S |
+| **Tumble Dryer** | HD80-A3959 | H-DRY 500
H9A3TCBEXS-S
HLE C10DCE-80
NDE H10A2TCE-80
NDE H9A2TSBEXS-S
NDPHY10A2TCBEXSS | BCTDH7A1TE
CSOE C10DE-80
ROE H9A3TCEX-S |
+| **Washer Dryer** | HWD100-B14979 | HWPS4954DAMR-11 | RPW41066BWMR/1-S |
+| **Oven** | HWO60SM2F3XH | HSOT3161WG | |
+| **Dish Washer** | XIB 3B2SFS-80
XIB 6B2D3FB | HFB 6B2S3FX | |
+| **Air Conditioner** | AD105S2SM3FA
AS20HPL1HRA
AS25PBAHRA
AS25S2SF1FA-WH
AS25TADHRA-2
AS35S2SF2FA-3
AS35TADHRA-2
AS35TAMHRA-C | | |
+| **Fridge** | HFW7720ENMB | | CCE4T620EWU |
+| **Hob** | HA2MTSJ68MC | | CIS633SCTTWIFI |
+| **Hood** | HADG6DS46BWIFI | | |
+| **Wine Cellar** | HWS247FDU1 | | |
## Supported Languages
Translation of internal names like programs are available for all languages which are official supported by the hOn app:
@@ -137,7 +138,7 @@ For every device exists a hidden button which can be used to log all infos of yo
## Appliance Features
-### Air conditioner
+### Air Conditioner
#### Controls
| Name | Icon | Entity | Key |
| --- | --- | --- | --- |
@@ -171,7 +172,36 @@ For every device exists a hidden button which can be used to log all infos of yo
| Program | `play` | `sensor` | `programName` |
| Selected Temperature | `thermometer` | `sensor` | `tempSel` |
-### Dish washer
+### Air Purifier
+#### Controls
+| Name | Icon | Entity | Key |
+| --- | --- | --- | --- |
+| Aroma Time Off | `thermometer` | `number` | `settings.aromaTimeOff` |
+| Aroma Time On | `thermometer` | `number` | `settings.aromaTimeOn` |
+| Diffuser Level | | `select` | `settings.aromaStatus` |
+| Light status | `lightbulb` | `number` | `settings.lightStatus` |
+| Lock Status | | `switch` | `lockStatus` |
+| Mode | `run` | `select` | `settings.machMode` |
+| Pollen Level | | `number` | `settings.pollenLevel` |
+| Touch Tone | | `switch` | `touchToneStatus` |
+#### Sensors
+| Name | Icon | Entity | Key |
+| --- | --- | --- | --- |
+| Air Quality | | `sensor` | `airQuality` |
+| CO Level | | `sensor` | `coLevel` |
+| Error | `math-log` | `sensor` | `errors` |
+| Humidity | | `sensor` | `humidityIndoor` |
+| Main Filter Status | | `sensor` | `mainFilterStatus` |
+| On | `power-cycle` | `binary_sensor` | `attributes.parameters.onOffStatus` |
+| Pre Filter Status | | `sensor` | `preFilterStatus` |
+| Temperature | | `sensor` | `temp` |
+| Total Work Time | | `sensor` | `totalWorkTime` |
+| VOC | | `sensor` | `vocValueIndoor` |
+| Wind Speed | | `sensor` | `windSpeed` |
+| pm10 | | `sensor` | `pm10ValueIndoor` |
+| pm2p5 | | `sensor` | `pm2p5ValueIndoor` |
+
+### Dish Washer
#### Controls
| Name | Icon | Entity | Key |
| --- | --- | --- | --- |
@@ -217,10 +247,6 @@ For every device exists a hidden button which can be used to log all infos of yo
| Start Program | `hvac` | `button` | `startProgram` |
| Stop Program | `hvac-off` | `button` | `stopProgram` |
| Wind Speed | | `fan` | `settings.windSpeed` |
-#### Configs
-| Name | Icon | Entity | Key |
-| --- | --- | --- | --- |
-| Light status | `lightbulb` | `number` | `startProgram.lightStatus` |
#### Sensors
| Name | Icon | Entity | Key |
| --- | --- | --- | --- |
@@ -231,13 +257,14 @@ For every device exists a hidden button which can be used to log all infos of yo
| Filter Cleaning Status | | `sensor` | `filterCleaningStatus` |
| Last Work Time | `clock-start` | `sensor` | `lastWorkTime` |
| Light Status | `lightbulb` | `sensor` | `lightStatus` |
+| Light status | `lightbulb` | `number` | `startProgram.lightStatus` |
| Mach Mode | | `sensor` | `machMode` |
| On / Off Status | `lightbulb` | `sensor` | `onOffStatus` |
| Quick Delay Time Status | | `sensor` | `quickDelayTimeStatus` |
| RGB Light Color | `lightbulb` | `sensor` | `rgbLightColors` |
| RGB Light Status | `lightbulb` | `sensor` | `rgbLightStatus` |
-### Hob
+### Induction Hob
#### Controls
| Name | Icon | Entity | Key |
| --- | --- | --- | --- |
@@ -321,7 +348,7 @@ For every device exists a hidden button which can be used to log all infos of yo
| Temperature Freezer | `snowflake-thermometer` | `sensor` | `tempZ2` |
| Temperature Fridge | `thermometer` | `sensor` | `tempZ1` |
-### Tumble dryer
+### Tumble Dryer
#### Controls
| Name | Icon | Entity | Key |
| --- | --- | --- | --- |
@@ -380,7 +407,7 @@ For every device exists a hidden button which can be used to log all infos of yo
| Temperature | `thermometer` | `sensor` | `temp` |
| Temperature 2 | `thermometer` | `sensor` | `tempZ2` |
-### Washer dryer
+### Washer Dryer
#### Controls
| Name | Icon | Entity | Key |
| --- | --- | --- | --- |
@@ -455,7 +482,7 @@ For every device exists a hidden button which can be used to log all infos of yo
| Total Wash Cycle | `counter` | `sensor` | `totalWashCycle` |
| Total Water | | `sensor` | `totalWaterUsed` |
-### Washing machine
+### Washing Machine
#### Controls
| Name | Icon | Entity | Key |
| --- | --- | --- | --- |
diff --git a/custom_components/hon/binary_sensor.py b/custom_components/hon/binary_sensor.py
index 8a29705..af9bcac 100644
--- a/custom_components/hon/binary_sensor.py
+++ b/custom_components/hon/binary_sensor.py
@@ -242,6 +242,16 @@ BINARY_SENSORS: dict[str, tuple[HonBinarySensorEntityDescription, ...]] = {
translation_key="holiday_mode",
),
),
+ "AP": (
+ HonBinarySensorEntityDescription(
+ key="attributes.parameters.onOffStatus",
+ name="On",
+ device_class=BinarySensorDeviceClass.RUNNING,
+ on_value="1",
+ icon="mdi:power-cycle",
+ translation_key="on",
+ ),
+ ),
}
BINARY_SENSORS["WD"] = unique_entities(BINARY_SENSORS["WM"], BINARY_SENSORS["TD"])
diff --git a/custom_components/hon/button.py b/custom_components/hon/button.py
index f503c21..55f2747 100644
--- a/custom_components/hon/button.py
+++ b/custom_components/hon/button.py
@@ -4,7 +4,7 @@ import pkg_resources
from homeassistant.components import persistent_notification
from homeassistant.components.button import ButtonEntityDescription, ButtonEntity
from homeassistant.config_entries import ConfigEntry
-from homeassistant.const import EntityCategory
+from homeassistant.helpers.entity import EntityCategory
from pyhon.appliance import HonAppliance
from .const import DOMAIN
diff --git a/custom_components/hon/climate.py b/custom_components/hon/climate.py
index fb8a62a..ede5e0e 100644
--- a/custom_components/hon/climate.py
+++ b/custom_components/hon/climate.py
@@ -22,7 +22,7 @@ from homeassistant.const import (
from homeassistant.core import callback
from pyhon.appliance import HonAppliance
-from .const import HON_HVAC_MODE, HON_FAN, HON_HVAC_PROGRAM, DOMAIN
+from .const import HON_HVAC_MODE, HON_FAN, DOMAIN
from .hon import HonEntity
_LOGGER = logging.getLogger(__name__)
@@ -115,13 +115,14 @@ class HonACClimateEntity(HonEntity, ClimateEntity):
super().__init__(hass, entry, device, description)
self._attr_temperature_unit = TEMP_CELSIUS
- self._attr_target_temperature_step = device.settings["settings.tempSel"].step
- self._attr_max_temp = device.settings["settings.tempSel"].max
- self._attr_min_temp = device.settings["settings.tempSel"].min
+ self._set_temperature_bound()
self._attr_hvac_modes = [HVACMode.OFF]
for mode in device.settings["settings.machMode"].values:
self._attr_hvac_modes.append(HON_HVAC_MODE[int(mode)])
+ self._attr_preset_modes = []
+ for mode in device.settings["startProgram.program"].values:
+ self._attr_preset_modes.append(mode)
self._attr_fan_modes = [FAN_OFF]
for mode in device.settings["settings.windSpeed"].values:
self._attr_fan_modes.append(HON_FAN[int(mode)])
@@ -135,10 +136,18 @@ class HonACClimateEntity(HonEntity, ClimateEntity):
ClimateEntityFeature.TARGET_TEMPERATURE
| ClimateEntityFeature.FAN_MODE
| ClimateEntityFeature.SWING_MODE
+ | ClimateEntityFeature.PRESET_MODE
)
self._handle_coordinator_update(update=False)
+ def _set_temperature_bound(self) -> None:
+ self._attr_target_temperature_step = self._device.settings[
+ "settings.tempSel"
+ ].step
+ self._attr_max_temp = self._device.settings["settings.tempSel"].max
+ self._attr_min_temp = self._device.settings["settings.tempSel"].min
+
@property
def target_temperature(self) -> int | None:
"""Return the temperature we try to reach."""
@@ -166,13 +175,31 @@ class HonACClimateEntity(HonEntity, ClimateEntity):
async def async_set_hvac_mode(self, hvac_mode):
self._attr_hvac_mode = hvac_mode
if hvac_mode == HVACMode.OFF:
- command = "stopProgram"
+ await self._device.commands["stopProgram"].send()
+ self._device.sync_command("stopProgram", "settings")
else:
- mode = HON_HVAC_PROGRAM[hvac_mode]
- self._device.settings["startProgram.program"].value = mode
- command = "startProgram"
- await self._device.commands[command].send()
- self._device.sync_command(command, "settings")
+ self._device.settings["settings.onOffStatus"].value = "1"
+ setting = self._device.settings["settings.machMode"]
+ modes = {HON_HVAC_MODE[int(number)]: number for number in setting.values}
+ setting.value = modes[hvac_mode]
+ await self._device.commands["settings"].send()
+ self.async_write_ha_state()
+
+ @property
+ def preset_mode(self) -> str | None:
+ """Return the current Preset for this channel."""
+ return None
+
+ async def async_set_preset_mode(self, preset_mode: str) -> None:
+ """Set the new preset mode."""
+ if program := self._device.settings.get(f"startProgram.program"):
+ program.value = preset_mode
+ self._device.sync_command("startProgram", "settings")
+ self._set_temperature_bound()
+ self._handle_coordinator_update(update=False)
+ await self.coordinator.async_refresh()
+ self._attr_preset_mode = preset_mode
+ await self._device.commands["startProgram"].send()
self.async_write_ha_state()
@property
diff --git a/custom_components/hon/const.py b/custom_components/hon/const.py
index a4d2dbd..48f7fba 100644
--- a/custom_components/hon/const.py
+++ b/custom_components/hon/const.py
@@ -188,3 +188,18 @@ AC_HUMAN_SENSE = {
2: "follow_touch",
3: "unknown",
}
+
+AP_MACH_MODE = {
+ 0: "standby",
+ 1: "sleep",
+ 2: "auto",
+ 3: "allergens",
+ 4: "max",
+}
+
+AP_DIFFUSER_LEVEL = {
+ 1: "soft",
+ 2: "mid",
+ 3: "h_biotics",
+ 4: "custom",
+}
diff --git a/custom_components/hon/hon.py b/custom_components/hon/hon.py
index 81f6eb0..40007aa 100644
--- a/custom_components/hon/hon.py
+++ b/custom_components/hon/hon.py
@@ -85,5 +85,7 @@ def get_coordinator(hass, appliance):
def get_readable(description, value):
- with suppress(ValueError):
- return description.option_list.get(int(value), value)
+ if description.option_list is not None:
+ with suppress(ValueError):
+ return description.option_list.get(int(value), value)
+ return value
diff --git a/custom_components/hon/manifest.json b/custom_components/hon/manifest.json
index d39f53b..2175a14 100644
--- a/custom_components/hon/manifest.json
+++ b/custom_components/hon/manifest.json
@@ -9,7 +9,7 @@
"iot_class": "cloud_polling",
"issue_tracker": "https://github.com/Andre0512/hon/issues",
"requirements": [
- "pyhOn==0.13.0"
+ "pyhOn==0.13.1"
],
- "version": "0.9.0-beta.2"
+ "version": "0.9.0-beta.4"
}
diff --git a/custom_components/hon/number.py b/custom_components/hon/number.py
index 7aeb518..3bbad56 100644
--- a/custom_components/hon/number.py
+++ b/custom_components/hon/number.py
@@ -167,7 +167,29 @@ NUMBERS: dict[str, tuple[NumberEntityDescription, ...]] = {
key="startProgram.lightStatus",
name="Light status",
icon="mdi:lightbulb",
- entity_category=EntityCategory.CONFIG,
+ ),
+ ),
+ "AP": (
+ HonNumberEntityDescription(
+ key="settings.aromaTimeOn",
+ name="Aroma Time On",
+ icon="mdi:thermometer",
+ native_unit_of_measurement=UnitOfTime.SECONDS,
+ ),
+ HonNumberEntityDescription(
+ key="settings.aromaTimeOff",
+ name="Aroma Time Off",
+ icon="mdi:thermometer",
+ native_unit_of_measurement=UnitOfTime.SECONDS,
+ ),
+ HonNumberEntityDescription(
+ key="settings.lightStatus",
+ name="Light status",
+ icon="mdi:lightbulb",
+ ),
+ HonNumberEntityDescription(
+ key="settings.pollenLevel",
+ name="Pollen Level",
),
),
}
@@ -206,7 +228,7 @@ class HonNumberEntity(HonEntity, NumberEntity):
@property
def native_value(self) -> float | None:
- return self._device.get(self.entity_description.key)
+ return self._device.get(self.entity_description.key.split(".")[-1])
async def async_set_native_value(self, value: float) -> None:
setting = self._device.settings[self.entity_description.key]
@@ -214,6 +236,8 @@ class HonNumberEntity(HonEntity, NumberEntity):
setting.value = value
command = self.entity_description.key.split(".")[0]
await self._device.commands[command].send()
+ if command != "settings":
+ self._device.sync_command(command, "settings")
await self.coordinator.async_refresh()
@callback
@@ -223,7 +247,7 @@ class HonNumberEntity(HonEntity, NumberEntity):
self._attr_native_max_value = setting.max
self._attr_native_min_value = setting.min
self._attr_native_step = setting.step
- self._attr_native_value = setting.value
+ self._attr_native_value = self.native_value
if update:
self.async_write_ha_state()
diff --git a/custom_components/hon/select.py b/custom_components/hon/select.py
index 72c5afa..f238b68 100644
--- a/custom_components/hon/select.py
+++ b/custom_components/hon/select.py
@@ -1,7 +1,6 @@
from __future__ import annotations
import logging
-from contextlib import suppress
from dataclasses import dataclass
from typing import Dict, List
@@ -10,7 +9,6 @@ from homeassistant.config_entries import ConfigEntry
from homeassistant.const import UnitOfTemperature, UnitOfTime, REVOLUTIONS_PER_MINUTE
from homeassistant.core import callback
from homeassistant.helpers.entity import EntityCategory
-from pyhon.appliance import HonAppliance
from . import const
from .const import DOMAIN
@@ -135,6 +133,19 @@ SELECTS = {
translation_key="ref_zones",
),
),
+ "AP": (
+ HonSelectEntityDescription(
+ key="settings.aromaStatus",
+ name="Diffuser Level",
+ option_list=const.AP_DIFFUSER_LEVEL,
+ ),
+ HonSelectEntityDescription(
+ key="settings.machMode",
+ name="Mode",
+ icon="mdi:run",
+ option_list=const.AP_MACH_MODE,
+ ),
+ ),
}
SELECTS["WD"] = unique_entities(SELECTS["WM"], SELECTS["TD"])
@@ -157,46 +168,64 @@ async def async_setup_entry(hass, entry: ConfigEntry, async_add_entities) -> Non
async_add_entities(entities)
-class HonSelectEntity(HonEntity, SelectEntity):
- entity_description: HonSelectEntityDescription
-
- def __init__(self, hass, entry, device: HonAppliance, description) -> None:
- super().__init__(hass, entry, device, description)
+class HonConfigSelectEntity(HonEntity, SelectEntity):
+ entity_description: HonConfigSelectEntityDescription
@property
def current_option(self) -> str | None:
- value = self._device.settings.get(self.entity_description.key)
- if value is None or value.value not in self._attr_options:
+ if not (setting := self._device.settings.get(self.entity_description.key)):
return None
- return value.value
+ value = get_readable(self.entity_description, setting.value)
+ if value not in self._attr_options:
+ return None
+ return value
+
+ @property
+ def options(self) -> list[str]:
+ setting = self._device.settings.get(self.entity_description.key)
+ if setting is None:
+ return []
+ return [get_readable(self.entity_description, key) for key in setting.values]
+
+ def _option_to_number(self, option: str, values: List[str]):
+ if (options := self.entity_description.option_list) is not None:
+ return next(
+ (k for k, v in options.items() if str(k) in values and v == option),
+ option,
+ )
+ return option
async def async_select_option(self, option: str) -> None:
- self._device.settings[self.entity_description.key].value = option
- command = self.entity_description.key.split(".")[0]
- await self._device.commands[command].send()
+ setting = self._device.settings[self.entity_description.key]
+ setting.value = self._option_to_number(option, setting.values)
await self.coordinator.async_refresh()
@callback
def _handle_coordinator_update(self, update=True) -> None:
- setting = self._device.settings.get(self.entity_description.key)
- if setting is None:
- self._attr_available = False
- options = []
- value = None
- else:
- self._attr_available = True
- options = setting.values
- value = setting.value
- if self.entity_description.option_list is not None:
- with suppress(ValueError):
- options = [get_readable(self.entity_description, k) for k in options]
- if value is not None:
- value = get_readable(self.entity_description, value)
- self._attr_options: List[str] = options
- self._attr_native_value = value
+ self._attr_available = self.available
+ self._attr_options = self.options
+ self._attr_current_option = self.current_option
if update:
self.async_write_ha_state()
+ @property
+ def available(self) -> bool:
+ """Return True if entity is available."""
+ return self._device.settings.get(self.entity_description.key) is not None
+
+
+class HonSelectEntity(HonConfigSelectEntity):
+ entity_description: HonSelectEntityDescription
+
+ async def async_select_option(self, option: str) -> None:
+ setting = self._device.settings[self.entity_description.key]
+ setting.value = self._option_to_number(option, setting.values)
+ command = self.entity_description.key.split(".")[0]
+ await self._device.commands[command].send()
+ if command != "settings":
+ self._device.sync_command(command, "settings")
+ await self.coordinator.async_refresh()
+
@property
def available(self) -> bool:
"""Return True if entity is available."""
@@ -205,16 +234,3 @@ class HonSelectEntity(HonEntity, SelectEntity):
and int(self._device.get("remoteCtrValid", 1)) == 1
and self._device.get("attributes.lastConnEvent.category") != "DISCONNECTED"
)
-
-
-class HonConfigSelectEntity(HonSelectEntity):
- entity_description: HonConfigSelectEntityDescription
-
- async def async_select_option(self, option: str) -> None:
- self._device.settings[self.entity_description.key].value = option
- await self.coordinator.async_refresh()
-
- @property
- def available(self) -> bool:
- """Return True if entity is available."""
- return super(SelectEntity, self).available
diff --git a/custom_components/hon/sensor.py b/custom_components/hon/sensor.py
index 735a860..68886fe 100644
--- a/custom_components/hon/sensor.py
+++ b/custom_components/hon/sensor.py
@@ -9,7 +9,12 @@ from homeassistant.components.sensor import (
SensorEntityDescription,
)
from homeassistant.config_entries import ConfigEntry
-from homeassistant.const import PERCENTAGE
+from homeassistant.const import (
+ PERCENTAGE,
+ CONCENTRATION_MICROGRAMS_PER_CUBIC_METER,
+ CONCENTRATION_PARTS_PER_BILLION,
+ CONCENTRATION_PARTS_PER_MILLION,
+)
from homeassistant.const import (
REVOLUTIONS_PER_MINUTE,
UnitOfEnergy,
@@ -637,6 +642,7 @@ SENSORS: dict[str, tuple[SensorEntityDescription, ...]] = {
name="Temperature",
icon="mdi:thermometer",
state_class=SensorStateClass.MEASUREMENT,
+ device_class=SensorDeviceClass.TEMPERATURE,
native_unit_of_measurement=UnitOfTemperature.CELSIUS,
translation_key="temperature",
),
@@ -673,6 +679,7 @@ SENSORS: dict[str, tuple[SensorEntityDescription, ...]] = {
icon="mdi:thermometer",
state_class=SensorStateClass.MEASUREMENT,
native_unit_of_measurement=UnitOfTemperature.CELSIUS,
+ device_class=SensorDeviceClass.TEMPERATURE,
translation_key="temperature",
),
HonSensorEntityDescription(
@@ -683,6 +690,76 @@ SENSORS: dict[str, tuple[SensorEntityDescription, ...]] = {
translation_key="programs_wc",
),
),
+ "AP": (
+ HonSensorEntityDescription(
+ key="errors", name="Error", icon="mdi:math-log", translation_key="errors"
+ ),
+ HonSensorEntityDescription(
+ key="mainFilterStatus",
+ name="Main Filter Status",
+ native_unit_of_measurement=PERCENTAGE,
+ ),
+ HonSensorEntityDescription(
+ key="preFilterStatus",
+ name="Pre Filter Status",
+ native_unit_of_measurement=PERCENTAGE,
+ ),
+ HonSensorEntityDescription(
+ key="totalWorkTime",
+ name="Total Work Time",
+ native_unit_of_measurement=UnitOfTime.MINUTES,
+ device_class=SensorDeviceClass.DURATION,
+ ),
+ HonSensorEntityDescription(
+ key="coLevel",
+ name="CO Level",
+ state_class=SensorStateClass.MEASUREMENT,
+ device_class=SensorDeviceClass.CO,
+ native_unit_of_measurement=CONCENTRATION_PARTS_PER_MILLION,
+ ),
+ HonSensorEntityDescription(
+ key="pm10ValueIndoor",
+ name="pm10",
+ state_class=SensorStateClass.MEASUREMENT,
+ device_class=SensorDeviceClass.PM10,
+ native_unit_of_measurement=CONCENTRATION_MICROGRAMS_PER_CUBIC_METER,
+ ),
+ HonSensorEntityDescription(
+ key="pm2p5ValueIndoor",
+ name="pm2p5",
+ state_class=SensorStateClass.MEASUREMENT,
+ device_class=SensorDeviceClass.PM25,
+ native_unit_of_measurement=CONCENTRATION_MICROGRAMS_PER_CUBIC_METER,
+ ),
+ HonSensorEntityDescription(
+ key="vocValueIndoor",
+ name="VOC",
+ state_class=SensorStateClass.MEASUREMENT,
+ device_class=SensorDeviceClass.VOLATILE_ORGANIC_COMPOUNDS,
+ native_unit_of_measurement=CONCENTRATION_PARTS_PER_BILLION,
+ ),
+ HonSensorEntityDescription(
+ key="humidityIndoor",
+ name="Humidity",
+ state_class=SensorStateClass.MEASUREMENT,
+ device_class=SensorDeviceClass.HUMIDITY,
+ native_unit_of_measurement=PERCENTAGE,
+ translation_key="humidity",
+ ),
+ HonSensorEntityDescription(
+ key="temp",
+ name="Temperature",
+ state_class=SensorStateClass.MEASUREMENT,
+ device_class=SensorDeviceClass.TEMPERATURE,
+ native_unit_of_measurement=UnitOfTemperature.CELSIUS,
+ translation_key="temperature",
+ ),
+ HonSensorEntityDescription(key="windSpeed", name="Wind Speed"),
+ HonSensorEntityDescription(
+ key="airQuality",
+ name="Air Quality",
+ ),
+ ),
}
SENSORS["WD"] = unique_entities(SENSORS["WM"], SENSORS["TD"])
diff --git a/custom_components/hon/switch.py b/custom_components/hon/switch.py
index 3cc71b0..e69eaa5 100644
--- a/custom_components/hon/switch.py
+++ b/custom_components/hon/switch.py
@@ -5,7 +5,7 @@ from typing import Any
from homeassistant.components.switch import SwitchEntityDescription, SwitchEntity
from homeassistant.config_entries import ConfigEntry
-from homeassistant.const import EntityCategory
+from homeassistant.helpers.entity import EntityCategory
from homeassistant.core import callback
from pyhon.parameter.base import HonParameter
from pyhon.parameter.range import HonParameterRange
@@ -333,6 +333,16 @@ SWITCHES: dict[str, tuple[HonSwitchEntityDescription, ...]] = {
key="lightStatus", name="Light", icon="mdi:lightbulb"
),
),
+ "AP": (
+ HonSwitchEntityDescription(
+ key="touchToneStatus",
+ name="Touch Tone",
+ ),
+ HonSwitchEntityDescription(
+ key="lockStatus",
+ name="Lock Status",
+ ),
+ ),
}
SWITCHES["WD"] = unique_entities(SWITCHES["WD"], SWITCHES["WM"])
diff --git a/custom_components/hon/translations/cs.json b/custom_components/hon/translations/cs.json
index 2d66d47..f801b0d 100644
--- a/custom_components/hon/translations/cs.json
+++ b/custom_components/hon/translations/cs.json
@@ -1839,7 +1839,31 @@
},
"climate": {
"air_conditioner": {
- "name": "Klimatizační jednotka"
+ "name": "Klimatizační jednotka",
+ "state_attributes": {
+ "preset_mode": {
+ "name": "Programy",
+ "state": {
+ "iot_10_heating": "Funkce Vytápění 10 °C",
+ "iot_auto": "Auto",
+ "iot_cool": "Chlazení",
+ "iot_dry": "Odvlhčování",
+ "iot_fan": "Ventilátor",
+ "iot_heat": "Vytápění",
+ "iot_nano_aqua": "Nano Aqua",
+ "iot_purify": "Automatické čištění",
+ "iot_self_clean": "Samočištění zamrazením",
+ "iot_self_clean_56": "Samočištění 56°C sterilizace ",
+ "iot_simple_start": "Spustit nyní",
+ "iot_uv": "UV",
+ "iot_uv_and_auto": "UV + auto",
+ "iot_uv_and_cool": "UV + zchlazení",
+ "iot_uv_and_dry": "UV + odstranění vlhkosti",
+ "iot_uv_and_fan": "UV + ventilátor",
+ "iot_uv_and_heat": "UV + ohřev"
+ }
+ }
+ }
},
"fridge": {
"name": "Chladnička",
diff --git a/custom_components/hon/translations/de.json b/custom_components/hon/translations/de.json
index 7cf3cf3..d2df5ef 100644
--- a/custom_components/hon/translations/de.json
+++ b/custom_components/hon/translations/de.json
@@ -1839,7 +1839,31 @@
},
"climate": {
"air_conditioner": {
- "name": "Klimaanlage"
+ "name": "Klimaanlage",
+ "state_attributes": {
+ "preset_mode": {
+ "name": "Programme",
+ "state": {
+ "iot_10_heating": "10°C Heizfunktion",
+ "iot_auto": "Auto",
+ "iot_cool": "Kühl",
+ "iot_dry": "Trocken",
+ "iot_fan": "Ventilator",
+ "iot_heat": "Heizen",
+ "iot_nano_aqua": "Nano Aqua",
+ "iot_purify": "Selbst reinigen",
+ "iot_self_clean": "Self-Clean",
+ "iot_self_clean_56": "Steri-Clean 56°C",
+ "iot_simple_start": "Jetzt beginnen",
+ "iot_uv": "UV",
+ "iot_uv_and_auto": "UV + Auto",
+ "iot_uv_and_cool": "UV + Kalt",
+ "iot_uv_and_dry": "UV + Entfeuchter",
+ "iot_uv_and_fan": "UV + Gebläse",
+ "iot_uv_and_heat": "UV + Heizen"
+ }
+ }
+ }
},
"fridge": {
"name": "Kühlschrank",
diff --git a/custom_components/hon/translations/el.json b/custom_components/hon/translations/el.json
index 93d4665..8fe6ba1 100644
--- a/custom_components/hon/translations/el.json
+++ b/custom_components/hon/translations/el.json
@@ -1839,7 +1839,31 @@
},
"climate": {
"air_conditioner": {
- "name": "Κλιματιστικό"
+ "name": "Κλιματιστικό",
+ "state_attributes": {
+ "preset_mode": {
+ "name": "Προγράμματα",
+ "state": {
+ "iot_10_heating": "10° C Λειτουργία θέρμανσης",
+ "iot_auto": "Αυτόματο",
+ "iot_cool": "Ψύξη",
+ "iot_dry": "Στέγνωμα",
+ "iot_fan": "Ανεμιστήρας",
+ "iot_heat": "Ζέστη",
+ "iot_nano_aqua": "Nano Aqua",
+ "iot_purify": "Αυτοκαθαρισμός",
+ "iot_self_clean": "Αυτοκαθαρισμός",
+ "iot_self_clean_56": "Steri-Clean 56°C",
+ "iot_simple_start": "Εκκίνηση τώρα",
+ "iot_uv": "UV",
+ "iot_uv_and_auto": "UV + Auto",
+ "iot_uv_and_cool": "UV + Ψύξη",
+ "iot_uv_and_dry": "UV + Αφυγραντήρας",
+ "iot_uv_and_fan": "UV + Ανεμιστήρας",
+ "iot_uv_and_heat": "UV + Θέρμανση"
+ }
+ }
+ }
},
"fridge": {
"name": "Ψυγείο",
diff --git a/custom_components/hon/translations/en.json b/custom_components/hon/translations/en.json
index f14fa71..514c214 100644
--- a/custom_components/hon/translations/en.json
+++ b/custom_components/hon/translations/en.json
@@ -1868,7 +1868,31 @@
},
"climate": {
"air_conditioner": {
- "name": "Air conditioner"
+ "name": "Air conditioner",
+ "state_attributes": {
+ "preset_mode": {
+ "name": "Programs",
+ "state": {
+ "iot_10_heating": "10°C Heating function",
+ "iot_auto": "Auto",
+ "iot_cool": "Cool",
+ "iot_dry": "Dry",
+ "iot_fan": "Fan",
+ "iot_heat": "Heat",
+ "iot_nano_aqua": "Nano Aqua",
+ "iot_purify": "Self-purify",
+ "iot_self_clean": "Self-clean",
+ "iot_self_clean_56": "Steri-Clean 56°C",
+ "iot_simple_start": "Start now",
+ "iot_uv": "UV",
+ "iot_uv_and_auto": "UV + Auto",
+ "iot_uv_and_cool": "UV + Cold",
+ "iot_uv_and_dry": "UV + Dehumidifier",
+ "iot_uv_and_fan": "UV + Fan",
+ "iot_uv_and_heat": "UV + Heat"
+ }
+ }
+ }
},
"fridge": {
"name": "Fridge",
diff --git a/custom_components/hon/translations/es.json b/custom_components/hon/translations/es.json
index 02dd717..cc3d0b6 100644
--- a/custom_components/hon/translations/es.json
+++ b/custom_components/hon/translations/es.json
@@ -1839,7 +1839,31 @@
},
"climate": {
"air_conditioner": {
- "name": "Aire acondicionado"
+ "name": "Aire acondicionado",
+ "state_attributes": {
+ "preset_mode": {
+ "name": "Programas",
+ "state": {
+ "iot_10_heating": "Función de calentamiento de 10° C",
+ "iot_auto": "Automático",
+ "iot_cool": "Frío",
+ "iot_dry": "Deshumidificar",
+ "iot_fan": "Ventilador",
+ "iot_heat": "Calor",
+ "iot_nano_aqua": "Nano Aqua",
+ "iot_purify": "Autopurificar",
+ "iot_self_clean": "Autolimpieza",
+ "iot_self_clean_56": "Limpieza desinfectante 56°",
+ "iot_simple_start": "Iniciar ahora",
+ "iot_uv": "UV",
+ "iot_uv_and_auto": "UV + Automático",
+ "iot_uv_and_cool": "UV + Frío",
+ "iot_uv_and_dry": "UV + Deshumidificador",
+ "iot_uv_and_fan": "UV + Ventilador",
+ "iot_uv_and_heat": "UV + Calor"
+ }
+ }
+ }
},
"fridge": {
"name": "Frigorífico",
diff --git a/custom_components/hon/translations/fr.json b/custom_components/hon/translations/fr.json
index fe78f66..2478178 100644
--- a/custom_components/hon/translations/fr.json
+++ b/custom_components/hon/translations/fr.json
@@ -1839,7 +1839,31 @@
},
"climate": {
"air_conditioner": {
- "name": "Climatiseur"
+ "name": "Climatiseur",
+ "state_attributes": {
+ "preset_mode": {
+ "name": "Programmes",
+ "state": {
+ "iot_10_heating": "Fonction Chauffage 10 °C",
+ "iot_auto": "Automatique",
+ "iot_cool": "Frais",
+ "iot_dry": "Sec",
+ "iot_fan": "Ventilateur",
+ "iot_heat": "Chaleur",
+ "iot_nano_aqua": "Nano Aqua",
+ "iot_purify": "Auto-purification",
+ "iot_self_clean": "Auto-nettoyage",
+ "iot_self_clean_56": "Steri-Clean 56°C",
+ "iot_simple_start": "Démarrez maintenant",
+ "iot_uv": "UV",
+ "iot_uv_and_auto": "UV + Auto",
+ "iot_uv_and_cool": "UV + Froid",
+ "iot_uv_and_dry": "UV + Déshumidificateur",
+ "iot_uv_and_fan": "UV + ventilateur",
+ "iot_uv_and_heat": "UV + Chaleur"
+ }
+ }
+ }
},
"fridge": {
"name": "Réfrigérateur",
diff --git a/custom_components/hon/translations/he.json b/custom_components/hon/translations/he.json
index 7a0ff87..a68d88c 100644
--- a/custom_components/hon/translations/he.json
+++ b/custom_components/hon/translations/he.json
@@ -964,7 +964,15 @@
},
"climate": {
"air_conditioner": {
- "name": "Air conditioner"
+ "name": "Air conditioner",
+ "state_attributes": {
+ "preset_mode": {
+ "name": "Programs",
+ "state": {
+ "iot_simple_start": "התחל עכשיו"
+ }
+ }
+ }
},
"fridge": {
"name": "Fridge",
diff --git a/custom_components/hon/translations/hr.json b/custom_components/hon/translations/hr.json
index 385085f..2c66312 100644
--- a/custom_components/hon/translations/hr.json
+++ b/custom_components/hon/translations/hr.json
@@ -1839,7 +1839,31 @@
},
"climate": {
"air_conditioner": {
- "name": "Klimatizacijski uređaj"
+ "name": "Klimatizacijski uređaj",
+ "state_attributes": {
+ "preset_mode": {
+ "name": "Programi",
+ "state": {
+ "iot_10_heating": "Funkcija grijanja na 10 °C",
+ "iot_auto": "Automatski",
+ "iot_cool": "Hlađenje",
+ "iot_dry": "Sušenje",
+ "iot_fan": "Ventilator",
+ "iot_heat": "Zagrijavanje",
+ "iot_nano_aqua": "Nano Aqua",
+ "iot_purify": "Sampročišćavanje",
+ "iot_self_clean": "Samočišćenje",
+ "iot_self_clean_56": "Sterilno čišćenje 56°C",
+ "iot_simple_start": "Pokreni sada",
+ "iot_uv": "UV",
+ "iot_uv_and_auto": "UV + automatski",
+ "iot_uv_and_cool": "UV + hladno",
+ "iot_uv_and_dry": "UV + odvlaživač",
+ "iot_uv_and_fan": "UV + ventilator",
+ "iot_uv_and_heat": "UV + grijanje"
+ }
+ }
+ }
},
"fridge": {
"name": "Hladnjak",
diff --git a/custom_components/hon/translations/it.json b/custom_components/hon/translations/it.json
index dcad47c..fe02131 100644
--- a/custom_components/hon/translations/it.json
+++ b/custom_components/hon/translations/it.json
@@ -1844,7 +1844,31 @@
},
"climate": {
"air_conditioner": {
- "name": "Condizionatore"
+ "name": "Condizionatore",
+ "state_attributes": {
+ "preset_mode": {
+ "name": "Programmi",
+ "state": {
+ "iot_10_heating": "Funzione 10°C Heating ",
+ "iot_auto": "Auto",
+ "iot_cool": "Freddo",
+ "iot_dry": "Deumidificazione",
+ "iot_fan": "Ventilatore",
+ "iot_heat": "Caldo",
+ "iot_nano_aqua": "Nano Aqua",
+ "iot_purify": "Self purify",
+ "iot_self_clean": "Self clean",
+ "iot_self_clean_56": "Steri-Clean 56°C",
+ "iot_simple_start": "Avvia ora",
+ "iot_uv": "UV",
+ "iot_uv_and_auto": "UV + Auto",
+ "iot_uv_and_cool": "UV + Freddo",
+ "iot_uv_and_dry": "UV + Deumidificatore",
+ "iot_uv_and_fan": "UV + Ventola",
+ "iot_uv_and_heat": "UV + Caldo"
+ }
+ }
+ }
},
"fridge": {
"name": "Frigorifero",
diff --git a/custom_components/hon/translations/nl.json b/custom_components/hon/translations/nl.json
index ba5c686..524522a 100644
--- a/custom_components/hon/translations/nl.json
+++ b/custom_components/hon/translations/nl.json
@@ -1839,7 +1839,31 @@
},
"climate": {
"air_conditioner": {
- "name": "Airconditioner"
+ "name": "Airconditioner",
+ "state_attributes": {
+ "preset_mode": {
+ "name": "Programma's",
+ "state": {
+ "iot_10_heating": "10°C-verwarmingsfunctie",
+ "iot_auto": "Automatisch",
+ "iot_cool": "Koelen",
+ "iot_dry": "Drogen",
+ "iot_fan": "Ventilator",
+ "iot_heat": "Verwarming",
+ "iot_nano_aqua": "Nano Aqua",
+ "iot_purify": "Zelfzuivering",
+ "iot_self_clean": "Zelfreiniging",
+ "iot_self_clean_56": "Sterilisatie reiniging 56°C",
+ "iot_simple_start": "Start nu",
+ "iot_uv": "UV",
+ "iot_uv_and_auto": "UV + Auto",
+ "iot_uv_and_cool": "UV + Koud",
+ "iot_uv_and_dry": "UV + Ontvochtiger",
+ "iot_uv_and_fan": "UV + Hetelucht",
+ "iot_uv_and_heat": "UV + Warmte"
+ }
+ }
+ }
},
"fridge": {
"name": "Koelkast",
diff --git a/custom_components/hon/translations/pl.json b/custom_components/hon/translations/pl.json
index a9a0096..9a9513b 100644
--- a/custom_components/hon/translations/pl.json
+++ b/custom_components/hon/translations/pl.json
@@ -1839,7 +1839,31 @@
},
"climate": {
"air_conditioner": {
- "name": "Klimatyzator"
+ "name": "Klimatyzator",
+ "state_attributes": {
+ "preset_mode": {
+ "name": "Programy",
+ "state": {
+ "iot_10_heating": "Funkcja grzania 10°C",
+ "iot_auto": "Auto",
+ "iot_cool": "Chłodzenie",
+ "iot_dry": "Osuszanie",
+ "iot_fan": "Wentylator",
+ "iot_heat": "Grzanie",
+ "iot_nano_aqua": "Nano Aqua",
+ "iot_purify": "Self Purify",
+ "iot_self_clean": "Self Clean",
+ "iot_self_clean_56": "Steri Clean 56°C",
+ "iot_simple_start": "Uruchom teraz",
+ "iot_uv": "Sterylizacja UVC",
+ "iot_uv_and_auto": "UV + automat",
+ "iot_uv_and_cool": "UV + chłodzenie",
+ "iot_uv_and_dry": "UV + osuszacz powietrza",
+ "iot_uv_and_fan": "UV + wentylator",
+ "iot_uv_and_heat": "UV + podgrzewanie"
+ }
+ }
+ }
},
"fridge": {
"name": "Lodówka",
diff --git a/custom_components/hon/translations/pt.json b/custom_components/hon/translations/pt.json
index 44ad0e8..1ad5fe1 100644
--- a/custom_components/hon/translations/pt.json
+++ b/custom_components/hon/translations/pt.json
@@ -1839,7 +1839,31 @@
},
"climate": {
"air_conditioner": {
- "name": "Ar Condicionado"
+ "name": "Ar Condicionado",
+ "state_attributes": {
+ "preset_mode": {
+ "name": "Programas",
+ "state": {
+ "iot_10_heating": "Função de aquecimento de 10 °C",
+ "iot_auto": "Auto",
+ "iot_cool": "Frio",
+ "iot_dry": "Secar",
+ "iot_fan": "Ventilador",
+ "iot_heat": "Calor",
+ "iot_nano_aqua": "Nano Aqua",
+ "iot_purify": "Autopurificação",
+ "iot_self_clean": "Autolimpeza",
+ "iot_self_clean_56": "Steri-Clean 56°C",
+ "iot_simple_start": "Iniciar agora",
+ "iot_uv": "UV",
+ "iot_uv_and_auto": "UV + Auto",
+ "iot_uv_and_cool": "UV + Frio",
+ "iot_uv_and_dry": "UV + Desumidificador",
+ "iot_uv_and_fan": "UV + Ventilação",
+ "iot_uv_and_heat": "UV + Calor"
+ }
+ }
+ }
},
"fridge": {
"name": "Frigorífico",
diff --git a/custom_components/hon/translations/ro.json b/custom_components/hon/translations/ro.json
index d750b22..820a2d7 100644
--- a/custom_components/hon/translations/ro.json
+++ b/custom_components/hon/translations/ro.json
@@ -1839,7 +1839,31 @@
},
"climate": {
"air_conditioner": {
- "name": "Aer condiționat"
+ "name": "Aer condiționat",
+ "state_attributes": {
+ "preset_mode": {
+ "name": "Programe",
+ "state": {
+ "iot_10_heating": "Funcția de încălzire la 10 °C",
+ "iot_auto": "Automat",
+ "iot_cool": "Răcire",
+ "iot_dry": "Uscare",
+ "iot_fan": "Ventilare",
+ "iot_heat": "Încălzire",
+ "iot_nano_aqua": "Nano Aqua",
+ "iot_purify": "Auto-purificare",
+ "iot_self_clean": "Autocurățare",
+ "iot_self_clean_56": "Curățare-sterilizare la 56°C",
+ "iot_simple_start": "Începeți acum",
+ "iot_uv": "UV",
+ "iot_uv_and_auto": "UV + automat",
+ "iot_uv_and_cool": "UV + răcire",
+ "iot_uv_and_dry": "UV + dezumidificator",
+ "iot_uv_and_fan": "UV + ventilator",
+ "iot_uv_and_heat": "UV + încălzire"
+ }
+ }
+ }
},
"fridge": {
"name": "Frigider",
diff --git a/custom_components/hon/translations/ru.json b/custom_components/hon/translations/ru.json
index ffecc52..7c8eb0e 100644
--- a/custom_components/hon/translations/ru.json
+++ b/custom_components/hon/translations/ru.json
@@ -1839,7 +1839,31 @@
},
"climate": {
"air_conditioner": {
- "name": "Кондиционер воздуха"
+ "name": "Кондиционер воздуха",
+ "state_attributes": {
+ "preset_mode": {
+ "name": "Программы",
+ "state": {
+ "iot_10_heating": "Функция нагрева до 10°C",
+ "iot_auto": "Авто",
+ "iot_cool": "Охлаждение",
+ "iot_dry": "Сушка",
+ "iot_fan": "Вентилятор",
+ "iot_heat": "Нагрев",
+ "iot_nano_aqua": "Nano Aqua",
+ "iot_purify": "Самоочищение",
+ "iot_self_clean": "Самоочистка",
+ "iot_self_clean_56": "Steri-Clean 56°C",
+ "iot_simple_start": "Пуск сейчас",
+ "iot_uv": "Ультрафиолет",
+ "iot_uv_and_auto": "УФ + Авто",
+ "iot_uv_and_cool": "УФ + Охлаждение",
+ "iot_uv_and_dry": "УФ + Осушитель",
+ "iot_uv_and_fan": "УФ + Вентилятор",
+ "iot_uv_and_heat": "УФ + Нагрев"
+ }
+ }
+ }
},
"fridge": {
"name": "Холодильник",
diff --git a/custom_components/hon/translations/sk.json b/custom_components/hon/translations/sk.json
index 1d84748..1967d9f 100644
--- a/custom_components/hon/translations/sk.json
+++ b/custom_components/hon/translations/sk.json
@@ -1839,7 +1839,31 @@
},
"climate": {
"air_conditioner": {
- "name": "Klimatizácia"
+ "name": "Klimatizácia",
+ "state_attributes": {
+ "preset_mode": {
+ "name": "Programy",
+ "state": {
+ "iot_10_heating": "Funkcia vykurovania na 10 °C",
+ "iot_auto": "Automatika",
+ "iot_cool": "Chladiť",
+ "iot_dry": "Sušiť",
+ "iot_fan": "Ventilátor",
+ "iot_heat": "Ohrev",
+ "iot_nano_aqua": "Nano Aqua",
+ "iot_purify": "Samoprečisťovanie",
+ "iot_self_clean": "Samočistenie",
+ "iot_self_clean_56": "Sterilné čistenie 56°C",
+ "iot_simple_start": "Spustiť teraz",
+ "iot_uv": "UV",
+ "iot_uv_and_auto": "UV + Auto",
+ "iot_uv_and_cool": "UV + Studené",
+ "iot_uv_and_dry": "UV + Odvlhčovač",
+ "iot_uv_and_fan": "UV + Ventilátor",
+ "iot_uv_and_heat": "UV + Ohrev"
+ }
+ }
+ }
},
"fridge": {
"name": "Chladnička",
diff --git a/custom_components/hon/translations/sl.json b/custom_components/hon/translations/sl.json
index cedf8f8..5c22857 100644
--- a/custom_components/hon/translations/sl.json
+++ b/custom_components/hon/translations/sl.json
@@ -1839,7 +1839,31 @@
},
"climate": {
"air_conditioner": {
- "name": "Klimatska naprava"
+ "name": "Klimatska naprava",
+ "state_attributes": {
+ "preset_mode": {
+ "name": "Programi",
+ "state": {
+ "iot_10_heating": "Funkcija ogrevanja pri 10 °C",
+ "iot_auto": "Samodejno",
+ "iot_cool": "Hlajenje",
+ "iot_dry": "Sušenje",
+ "iot_fan": "Ventilator",
+ "iot_heat": "Segrevanje",
+ "iot_nano_aqua": "Nano Aqua",
+ "iot_purify": "Samoočiščevanje",
+ "iot_self_clean": "Samodejno čiščenje",
+ "iot_self_clean_56": "Sterilno čiščenje 56°C",
+ "iot_simple_start": "Zaženi zdaj",
+ "iot_uv": "UV",
+ "iot_uv_and_auto": "UV + samodejno",
+ "iot_uv_and_cool": "UV + hlajenje",
+ "iot_uv_and_dry": "UV + razvlaževanje",
+ "iot_uv_and_fan": "UV + ventilator",
+ "iot_uv_and_heat": "UV + gretje"
+ }
+ }
+ }
},
"fridge": {
"name": "Hladilnik",
diff --git a/custom_components/hon/translations/sr.json b/custom_components/hon/translations/sr.json
index aaa157e..f86e6de 100644
--- a/custom_components/hon/translations/sr.json
+++ b/custom_components/hon/translations/sr.json
@@ -1839,7 +1839,31 @@
},
"climate": {
"air_conditioner": {
- "name": "Klima uređaj"
+ "name": "Klima uređaj",
+ "state_attributes": {
+ "preset_mode": {
+ "name": "Programi",
+ "state": {
+ "iot_10_heating": "Funkcija grejanja – 10° C",
+ "iot_auto": "Automatski",
+ "iot_cool": "Hlađenje",
+ "iot_dry": "Sušenje",
+ "iot_fan": "Ventilator",
+ "iot_heat": "Toplota",
+ "iot_nano_aqua": "Nano Aqua",
+ "iot_purify": "Samopročišćavanje",
+ "iot_self_clean": "Samočišćenje",
+ "iot_self_clean_56": "Sterilno čišćenje 56°C",
+ "iot_simple_start": "Pokrenuti sada",
+ "iot_uv": "UV",
+ "iot_uv_and_auto": "UV + automatsko",
+ "iot_uv_and_cool": "UV+ hladno",
+ "iot_uv_and_dry": "UV + odvlaživač",
+ "iot_uv_and_fan": "UV + ventilator",
+ "iot_uv_and_heat": "UV + toplota"
+ }
+ }
+ }
},
"fridge": {
"name": "Frižider",
diff --git a/custom_components/hon/translations/tr.json b/custom_components/hon/translations/tr.json
index 562fd7f..c32c931 100644
--- a/custom_components/hon/translations/tr.json
+++ b/custom_components/hon/translations/tr.json
@@ -1839,7 +1839,31 @@
},
"climate": {
"air_conditioner": {
- "name": "Klima"
+ "name": "Klima",
+ "state_attributes": {
+ "preset_mode": {
+ "name": "Programlar",
+ "state": {
+ "iot_10_heating": "10°C Isıtma fonksiyonu",
+ "iot_auto": "Otomatik",
+ "iot_cool": "Soğuk",
+ "iot_dry": "Kuru",
+ "iot_fan": "Fan",
+ "iot_heat": "Isı",
+ "iot_nano_aqua": "Nano Aqua",
+ "iot_purify": "Kendi kendini arındırma",
+ "iot_self_clean": "Kendi kendini temizleme",
+ "iot_self_clean_56": "Steril Temizleme 56°C",
+ "iot_simple_start": "Şimdi başlat",
+ "iot_uv": "UV",
+ "iot_uv_and_auto": "UV + Otomatik",
+ "iot_uv_and_cool": "UV + Soğuk",
+ "iot_uv_and_dry": "UV + Nem giderici",
+ "iot_uv_and_fan": "UV + Fan",
+ "iot_uv_and_heat": "UV + Isıtma"
+ }
+ }
+ }
},
"fridge": {
"name": "Buzdolabı",
diff --git a/custom_components/hon/translations/zh.json b/custom_components/hon/translations/zh.json
index 0c2111e..c6a628c 100644
--- a/custom_components/hon/translations/zh.json
+++ b/custom_components/hon/translations/zh.json
@@ -1839,7 +1839,31 @@
},
"climate": {
"air_conditioner": {
- "name": "空调"
+ "name": "空调",
+ "state_attributes": {
+ "preset_mode": {
+ "name": "程序",
+ "state": {
+ "iot_10_heating": "10°C 加热功能",
+ "iot_auto": "自动",
+ "iot_cool": "冷却",
+ "iot_dry": "烘干",
+ "iot_fan": "风扇",
+ "iot_heat": "加热",
+ "iot_nano_aqua": "Nano Aqua",
+ "iot_purify": "自净",
+ "iot_self_clean": "自洁",
+ "iot_self_clean_56": "无菌清洁 56°C",
+ "iot_simple_start": "立即启动",
+ "iot_uv": "UV",
+ "iot_uv_and_auto": "UV + 自动",
+ "iot_uv_and_cool": "UV + 制冷",
+ "iot_uv_and_dry": "UV + 减湿器",
+ "iot_uv_and_fan": "UV + 风扇",
+ "iot_uv_and_heat": "UV + 加热"
+ }
+ }
+ }
},
"fridge": {
"name": "冰箱",
diff --git a/info.md b/info.md
index 1dafd95..26f76b2 100644
--- a/info.md
+++ b/info.md
@@ -10,11 +10,12 @@ Support for home appliances of [Haier's mobile app hOn](https://hon-smarthome.co
- [Washer Dryer](https://github.com/Andre0512/hon#washer-dryer)
- [Oven](https://github.com/Andre0512/hon#oven)
- [Dish Washer](https://github.com/Andre0512/hon#dish-washer)
-- [Air conditioner](https://github.com/Andre0512/hon#air-conditioner)
+- [Air Conditioner](https://github.com/Andre0512/hon#air-conditioner)
- [Fridge](https://github.com/Andre0512/hon#fridge)
-- [Hob](https://github.com/Andre0512/hon#hob) [BETA]
+- [Induction Hob](https://github.com/Andre0512/hon#induction-hob) [BETA]
- [Hood](https://github.com/Andre0512/hon#hood) [BETA]
- [Wine Cellar](https://github.com/Andre0512/hon#wine-cellar) [BETA]
+- [Air Purifier](https://github.com/Andre0512/hon#air-purifier) [BETA]
## Configuration
@@ -26,18 +27,18 @@ _If the integration is not in the list, you need to clear the browser cache._
## Supported Models
Support has been confirmed for these models, but many more will work. Please add already supported devices [with this form to complete the list](https://forms.gle/bTSD8qFotdZFytbf8).
-| | **Haier** | **Hoover** | **Candy** |
-|---------------------|------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------|
-| **Washing Machine** | HW90-B14TEAM5
HW100-B14959U1 | H-WASH 500
H7W4 48MBC-S | RO441286DWMC4-07
HW 68AMC/1-80
HWPD 69AMBC/1-S |
-| **Tumble Dryer** | HD80-A3959 | H-DRY 500
H9A3TCBEXS-S
HLE C10DCE-80
NDE H10A2TCE-80
NDE H9A2TSBEXS-S
NDPHY10A2TCBEXSS | BCTDH7A1TE
CSOE C10DE-80
ROE H9A3TCEX-S |
-| **Washer Dryer** | HWD100-B14979 | HWPS4954DAMR-11 | RPW41066BWMR/1-S |
-| **Oven** | HWO60SM2F3XH | HSOT3161WG | |
-| **Dish Washer** | XIB 3B2SFS-80
XIB 6B2D3FB | HFB 6B2S3FX | |
-| **Air conditioner** | AD105S2SM3FA
AS20HPL1HRA
AS25PBAHRA
AS25S2SF1FA-WH
AS25TADHRA-2
AS35TADHRA-2
| | |
-| **Fridge** | HFW7720ENMB | | CCE4T620EWU |
-| **Hob** | HA2MTSJ68MC | | CIS633SCTTWIFI |
-| **Hood** | HADG6DS46BWIFI | | |
-| **Wine Cellar** | HWS247FDU1 | | |
+| | **Haier** | **Hoover** | **Candy** |
+|---------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------|
+| **Washing Machine** | HW90-B14TEAM5
HW100-B14959U1 | H-WASH 500
H7W4 48MBC-S | CO4 107T1/2-07
CBWO49TWME-S
RO44 1286DWMC4-07
HW 68AMC/1-80
HWPD 69AMBC/1-S |
+| **Tumble Dryer** | HD80-A3959 | H-DRY 500
H9A3TCBEXS-S
HLE C10DCE-80
NDE H10A2TCE-80
NDE H9A2TSBEXS-S
NDPHY10A2TCBEXSS | BCTDH7A1TE
CSOE C10DE-80
ROE H9A3TCEX-S |
+| **Washer Dryer** | HWD100-B14979 | HWPS4954DAMR-11 | RPW41066BWMR/1-S |
+| **Oven** | HWO60SM2F3XH | HSOT3161WG | |
+| **Dish Washer** | XIB 3B2SFS-80
XIB 6B2D3FB | HFB 6B2S3FX | |
+| **Air Conditioner** | AD105S2SM3FA
AS20HPL1HRA
AS25PBAHRA
AS25S2SF1FA-WH
AS25TADHRA-2
AS35S2SF2FA-3
AS35TADHRA-2
AS35TAMHRA-C | | |
+| **Fridge** | HFW7720ENMB | | CCE4T620EWU |
+| **Hob** | HA2MTSJ68MC | | CIS633SCTTWIFI |
+| **Hood** | HADG6DS46BWIFI | | |
+| **Wine Cellar** | HWS247FDU1 | | |
## Supported Languages
Translation of internal names like programs are available for all languages which are official supported by the hOn app:
diff --git a/scripts/sensor_docs.py b/scripts/sensor_docs.py
index e009186..ddc32b8 100755
--- a/scripts/sensor_docs.py
+++ b/scripts/sensor_docs.py
@@ -22,21 +22,21 @@ from custom_components.hon.switch import (
)
APPLIANCES = {
- "AC": "Air conditioner",
- "AP": "Air purifier",
- "AS": "Air scanner",
- "DW": "Dish washer",
+ "AC": "Air Conditioner",
+ "AP": "Air Purifier",
+ "AS": "Air Scanner",
+ "DW": "Dish Washer",
"HO": "Hood",
- "IH": "Hob",
+ "IH": "Induction Hob",
"MW": "Microwave",
"OV": "Oven",
"REF": "Fridge",
- "RVC": "Robot vacuum cleaner",
- "TD": "Tumble dryer",
+ "RVC": "Robot Vacuum Cleaner",
+ "TD": "Tumble Dryer",
"WC": "Wine Cellar",
- "WD": "Washer dryer",
+ "WD": "Washer Dryer",
"WH": "Water Heater",
- "WM": "Washing machine",
+ "WM": "Washing Machine",
}
ENTITY_CATEGORY_SORT = ["control", "config", "sensor"]
diff --git a/scripts/translation_keys.py b/scripts/translation_keys.py
index 57b5364..3f45cb1 100644
--- a/scripts/translation_keys.py
+++ b/scripts/translation_keys.py
@@ -159,6 +159,12 @@ CLIMATE = {
"state": "PROGRAMS.OV",
}
},
+ "air_conditioner": {
+ "preset_mode": {
+ "name": "OV.TABS.PROGRAMS_TITLE",
+ "state": "PROGRAMS.AC",
+ }
+ },
"wine": {
"preset_mode": {
"name": "WC.NAME",