Compare commits
20 Commits
v0.8.0-bet
...
v0.9.0-bet
Author | SHA1 | Date | |
---|---|---|---|
2c3217ff95 | |||
fbd1bdf5ba | |||
78727e89cd | |||
a181359faa | |||
d83179a9fa | |||
11a3d39f2c | |||
ae985cb0d9 | |||
c1e6f9547c | |||
b1448ddfd8 | |||
dfa5735bc2 | |||
52c3a861de | |||
d3503af158 | |||
d81b1ae712 | |||
eb5ba43707 | |||
efcac321b8 | |||
79b43b8695 | |||
5bc3120000 | |||
0f9f0dee4c | |||
80b3741f2f | |||
c433714a94 |
39
.github/ISSUE_TEMPLATE/bug_report.md
vendored
Normal file
39
.github/ISSUE_TEMPLATE/bug_report.md
vendored
Normal file
@ -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)
|
26
.github/ISSUE_TEMPLATE/feature_request.md
vendored
Normal file
26
.github/ISSUE_TEMPLATE/feature_request.md
vendored
Normal file
@ -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.
|
135
README.md
135
README.md
@ -4,7 +4,7 @@
|
|||||||
[](https://github.com/Andre0512/pyhOn)
|
[](https://github.com/Andre0512/pyhOn)
|
||||||
[](https://github.com/Andre0512/hon/blob/main/LICENSE)
|
[](https://github.com/Andre0512/hon/blob/main/LICENSE)
|
||||||
[](https://tooomm.github.io/github-release-stats/?username=Andre0512&repository=hon)
|
[](https://tooomm.github.io/github-release-stats/?username=Andre0512&repository=hon)
|
||||||
Home Assistant integration for [Haier's mobile app hOn](https://hon-smarthome.com/).
|
Home Assistant integration for [Haier's mobile app hOn](https://hon-smarthome.com/) based on [pyhOn](https://github.com/Andre0512/pyhon).
|
||||||
|
|
||||||
## Supported Appliances
|
## Supported Appliances
|
||||||
- [Washing Machine](https://github.com/Andre0512/hon#washing-machine)
|
- [Washing Machine](https://github.com/Andre0512/hon#washing-machine)
|
||||||
@ -12,10 +12,12 @@ Home Assistant integration for [Haier's mobile app hOn](https://hon-smarthome.co
|
|||||||
- [Washer Dryer](https://github.com/Andre0512/hon#washer-dryer)
|
- [Washer Dryer](https://github.com/Andre0512/hon#washer-dryer)
|
||||||
- [Oven](https://github.com/Andre0512/hon#oven)
|
- [Oven](https://github.com/Andre0512/hon#oven)
|
||||||
- [Dish Washer](https://github.com/Andre0512/hon#dish-washer)
|
- [Dish Washer](https://github.com/Andre0512/hon#dish-washer)
|
||||||
- [Hob](https://github.com/Andre0512/hon#hob) [BETA]
|
- [Air conditioner](https://github.com/Andre0512/hon#air-conditioner)
|
||||||
- [Air conditioner](https://github.com/Andre0512/hon#air-conditioner) [BETA]
|
- [Fridge](https://github.com/Andre0512/hon#fridge)
|
||||||
- [Fridge](https://github.com/Andre0512/hon#fridge) [BETA]
|
- [Induction Hob](https://github.com/Andre0512/hon#induction-hob) [BETA]
|
||||||
- [Hood](https://github.com/Andre0512/hon#hood) [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
|
## Installation
|
||||||
**Method 1:** [](https://my.home-assistant.io/redirect/hacs_repository/?owner=Andre0512&repository=hon&category=integration)
|
**Method 1:** [](https://my.home-assistant.io/redirect/hacs_repository/?owner=Andre0512&repository=hon&category=integration)
|
||||||
@ -33,6 +35,22 @@ _Restart Home Assistant_
|
|||||||
**Method 2**: Settings > Devices & Services > Add Integration > **Haier hOn**
|
**Method 2**: Settings > Devices & Services > Add Integration > **Haier hOn**
|
||||||
_If the integration is not in the list, you need to clear the browser cache._
|
_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 <br/> HW100-B14959U1 | H-WASH 500 <br/> H7W4 48MBC-S | CO4 107T1/2-07 <br/> CBWO49TWME-S <br/> RO44 1286DWMC4-07 <br/> HW 68AMC/1-80 <br/> HWPD 69AMBC/1-S |
|
||||||
|
| **Tumble Dryer** | HD80-A3959 | H-DRY 500 <br/> H9A3TCBEXS-S <br/> HLE C10DCE-80 <br/> NDE H10A2TCE-80 <br/> NDE H9A2TSBEXS-S <br/> NDPHY10A2TCBEXSS | BCTDH7A1TE <br/> CSOE C10DE-80 <br/> ROE H9A3TCEX-S |
|
||||||
|
| **Washer Dryer** | HWD100-B14979 | HWPS4954DAMR-11 | RPW41066BWMR/1-S |
|
||||||
|
| **Oven** | HWO60SM2F3XH | HSOT3161WG | |
|
||||||
|
| **Dish Washer** | XIB 3B2SFS-80 <br/> XIB 6B2D3FB | HFB 6B2S3FX | |
|
||||||
|
| **Air Conditioner** | AD105S2SM3FA <br/> AS20HPL1HRA <br/> AS25PBAHRA <br/> AS25S2SF1FA-WH <br/> AS25TADHRA-2 <br/> AS35S2SF2FA-3 <br/> AS35TADHRA-2 <br/> AS35TAMHRA-C | | |
|
||||||
|
| **Fridge** | HFW7720ENMB | | CCE4T620EWU |
|
||||||
|
| **Hob** | HA2MTSJ68MC | | CIS633SCTTWIFI |
|
||||||
|
| **Hood** | HADG6DS46BWIFI | | |
|
||||||
|
| **Wine Cellar** | HWS247FDU1 | | |
|
||||||
|
|
||||||
## Supported Languages
|
## Supported Languages
|
||||||
Translation of internal names like programs are available for all languages which are official supported by the hOn app:
|
Translation of internal names like programs are available for all languages which are official supported by the hOn app:
|
||||||
* 🇨🇳 Chinese
|
* 🇨🇳 Chinese
|
||||||
@ -59,44 +77,6 @@ Translation of internal names like programs are available for all languages whic
|
|||||||
### Washing Machine
|
### Washing Machine
|
||||||

|

|
||||||
|
|
||||||
## 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 AD105S2SM3FA
|
|
||||||
- Haier AS25PBAHRA
|
|
||||||
- Haier AS25S2SF1FA-WH
|
|
||||||
- Haier AS25TADHRA-2
|
|
||||||
- Haier AS35TADHRA-2
|
|
||||||
- Haier EG9012B19SU1JD
|
|
||||||
- Haier HA2MTSJ68MC
|
|
||||||
- Haier HADG6DS46BWIFI
|
|
||||||
- Haier HD80-A3959
|
|
||||||
- Haier HW90-B14TEAM5
|
|
||||||
- Haier HW100-B14959U1
|
|
||||||
- Haier HWD100-B14979
|
|
||||||
- Haier HWO60SM2F3XH
|
|
||||||
- Haier XIB 3B2SFS-80
|
|
||||||
- Haier XIB 6B2D3FB
|
|
||||||
- Candy BCTDH7A1TE
|
|
||||||
- Candy CCE4T620EWU
|
|
||||||
- Candy CIS633SCTTWIFI
|
|
||||||
- Candy CSOE C10DE-80
|
|
||||||
- Candy RO44 1286DWMC4-07
|
|
||||||
- Candy ROE H9A3TCEX-S
|
|
||||||
- Candy RPW41066BWMR/1-S
|
|
||||||
- Hoover H-WASH 500
|
|
||||||
- Hoover H-DRY 500
|
|
||||||
- Hoover H7W4 48MBC-S
|
|
||||||
- Hoover H9A3TCBEXS-S
|
|
||||||
- Hoover HFB 6B2S3FX
|
|
||||||
- Hoover HLE C10DCE-80
|
|
||||||
- Hoover HSOT3161WG
|
|
||||||
- Hoover HW 68AMC/1-80
|
|
||||||
- Hoover HWPD 69AMBC/1-S
|
|
||||||
- Hoover HWPS4954DAMR-11
|
|
||||||
- Hoover NDE H10A2TCE-80
|
|
||||||
- Hoover NDE H9A2TSBEXS-S
|
|
||||||
- Hoover NDPHY10A2TCBEXSS
|
|
||||||
|
|
||||||
## Contribute
|
## Contribute
|
||||||
Any kind of contribution is welcome!
|
Any kind of contribution is welcome!
|
||||||
### Read out device data
|
### Read out device data
|
||||||
@ -158,7 +138,7 @@ For every device exists a hidden button which can be used to log all infos of yo
|
|||||||
|
|
||||||
## Appliance Features
|
## Appliance Features
|
||||||
|
|
||||||
### Air conditioner
|
### Air Conditioner
|
||||||
#### Controls
|
#### Controls
|
||||||
| Name | Icon | Entity | Key |
|
| Name | Icon | Entity | Key |
|
||||||
| --- | --- | --- | --- |
|
| --- | --- | --- | --- |
|
||||||
@ -186,12 +166,42 @@ For every device exists a hidden button which can be used to log all infos of yo
|
|||||||
| Filter Replacement | | `binary_sensor` | `filterChangeStatusLocal` |
|
| Filter Replacement | | `binary_sensor` | `filterChangeStatusLocal` |
|
||||||
| In Air Temperature Outdoor | `thermometer` | `sensor` | `tempInAirOutdoor` |
|
| In Air Temperature Outdoor | `thermometer` | `sensor` | `tempInAirOutdoor` |
|
||||||
| Indoor Temperature | `thermometer` | `sensor` | `tempIndoor` |
|
| Indoor Temperature | `thermometer` | `sensor` | `tempIndoor` |
|
||||||
|
| Machine Status | `information` | `sensor` | `machMode` |
|
||||||
| Outdoor Temperature | `thermometer` | `sensor` | `tempOutdoor` |
|
| Outdoor Temperature | `thermometer` | `sensor` | `tempOutdoor` |
|
||||||
| Program | | `select` | `startProgram.program` |
|
| Program | | `select` | `startProgram.program` |
|
||||||
| Program | `play` | `sensor` | `programName` |
|
| Program | `play` | `sensor` | `programName` |
|
||||||
| Selected Temperature | `thermometer` | `sensor` | `tempSel` |
|
| 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
|
#### Controls
|
||||||
| Name | Icon | Entity | Key |
|
| Name | Icon | Entity | Key |
|
||||||
| --- | --- | --- | --- |
|
| --- | --- | --- | --- |
|
||||||
@ -236,11 +246,7 @@ For every device exists a hidden button which can be used to log all infos of yo
|
|||||||
| --- | --- | --- | --- |
|
| --- | --- | --- | --- |
|
||||||
| Start Program | `hvac` | `button` | `startProgram` |
|
| Start Program | `hvac` | `button` | `startProgram` |
|
||||||
| Stop Program | `hvac-off` | `button` | `stopProgram` |
|
| Stop Program | `hvac-off` | `button` | `stopProgram` |
|
||||||
#### Configs
|
| Wind Speed | | `fan` | `settings.windSpeed` |
|
||||||
| Name | Icon | Entity | Key |
|
|
||||||
| --- | --- | --- | --- |
|
|
||||||
| Light status | `lightbulb` | `number` | `startProgram.lightStatus` |
|
|
||||||
| Wind speed | `fan` | `number` | `startProgram.windSpeed` |
|
|
||||||
#### Sensors
|
#### Sensors
|
||||||
| Name | Icon | Entity | Key |
|
| Name | Icon | Entity | Key |
|
||||||
| --- | --- | --- | --- |
|
| --- | --- | --- | --- |
|
||||||
@ -251,14 +257,14 @@ For every device exists a hidden button which can be used to log all infos of yo
|
|||||||
| Filter Cleaning Status | | `sensor` | `filterCleaningStatus` |
|
| Filter Cleaning Status | | `sensor` | `filterCleaningStatus` |
|
||||||
| Last Work Time | `clock-start` | `sensor` | `lastWorkTime` |
|
| Last Work Time | `clock-start` | `sensor` | `lastWorkTime` |
|
||||||
| Light Status | `lightbulb` | `sensor` | `lightStatus` |
|
| Light Status | `lightbulb` | `sensor` | `lightStatus` |
|
||||||
|
| Light status | `lightbulb` | `number` | `startProgram.lightStatus` |
|
||||||
| Mach Mode | | `sensor` | `machMode` |
|
| Mach Mode | | `sensor` | `machMode` |
|
||||||
| On / Off Status | `lightbulb` | `sensor` | `onOffStatus` |
|
| On / Off Status | `lightbulb` | `sensor` | `onOffStatus` |
|
||||||
| Quick Delay Time Status | | `sensor` | `quickDelayTimeStatus` |
|
| Quick Delay Time Status | | `sensor` | `quickDelayTimeStatus` |
|
||||||
| RGB Light Color | `lightbulb` | `sensor` | `rgbLightColors` |
|
| RGB Light Color | `lightbulb` | `sensor` | `rgbLightColors` |
|
||||||
| RGB Light Status | `lightbulb` | `sensor` | `rgbLightStatus` |
|
| RGB Light Status | `lightbulb` | `sensor` | `rgbLightStatus` |
|
||||||
| Wind Speed | `fan` | `sensor` | `windSpeed` |
|
|
||||||
|
|
||||||
### Hob
|
### Induction Hob
|
||||||
#### Controls
|
#### Controls
|
||||||
| Name | Icon | Entity | Key |
|
| Name | Icon | Entity | Key |
|
||||||
| --- | --- | --- | --- |
|
| --- | --- | --- | --- |
|
||||||
@ -342,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 Freezer | `snowflake-thermometer` | `sensor` | `tempZ2` |
|
||||||
| Temperature Fridge | `thermometer` | `sensor` | `tempZ1` |
|
| Temperature Fridge | `thermometer` | `sensor` | `tempZ1` |
|
||||||
|
|
||||||
### Tumble dryer
|
### Tumble Dryer
|
||||||
#### Controls
|
#### Controls
|
||||||
| Name | Icon | Entity | Key |
|
| Name | Icon | Entity | Key |
|
||||||
| --- | --- | --- | --- |
|
| --- | --- | --- | --- |
|
||||||
@ -380,7 +386,28 @@ For every device exists a hidden button which can be used to log all infos of yo
|
|||||||
| Steam level | `smoke` | `sensor` | `steamLevel` |
|
| Steam level | `smoke` | `sensor` | `steamLevel` |
|
||||||
| Temperature level | `thermometer` | `sensor` | `tempLevel` |
|
| Temperature level | `thermometer` | `sensor` | `tempLevel` |
|
||||||
|
|
||||||
### Washer dryer
|
### Wine Cellar
|
||||||
|
#### Controls
|
||||||
|
| Name | Icon | Entity | Key |
|
||||||
|
| --- | --- | --- | --- |
|
||||||
|
| Light | `lightbulb` | `switch` | `lightStatus` |
|
||||||
|
| Sabbath Mode | `palm-tree` | `switch` | `sabbathStatus` |
|
||||||
|
| Wine Cellar | `thermometer` | `climate` | `settings.tempSel` |
|
||||||
|
| Wine Cellar | `thermometer` | `climate` | `settings.tempSelZ2` |
|
||||||
|
#### Sensors
|
||||||
|
| Name | Icon | Entity | Key |
|
||||||
|
| --- | --- | --- | --- |
|
||||||
|
| Error | `math-log` | `sensor` | `errors` |
|
||||||
|
| Humidity | `water-percent` | `sensor` | `humidityZ1` |
|
||||||
|
| Humidity 2 | `water-percent` | `sensor` | `humidityZ2` |
|
||||||
|
| Program | `play` | `sensor` | `programName` |
|
||||||
|
| Room Temperature | `home-thermometer-outline` | `sensor` | `tempEnv` |
|
||||||
|
| Selected Temperature | `thermometer` | `sensor` | `tempSel` |
|
||||||
|
| Selected Temperature 2 | `thermometer` | `sensor` | `tempSelZ2` |
|
||||||
|
| Temperature | `thermometer` | `sensor` | `temp` |
|
||||||
|
| Temperature 2 | `thermometer` | `sensor` | `tempZ2` |
|
||||||
|
|
||||||
|
### Washer Dryer
|
||||||
#### Controls
|
#### Controls
|
||||||
| Name | Icon | Entity | Key |
|
| 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 Wash Cycle | `counter` | `sensor` | `totalWashCycle` |
|
||||||
| Total Water | | `sensor` | `totalWaterUsed` |
|
| Total Water | | `sensor` | `totalWaterUsed` |
|
||||||
|
|
||||||
### Washing machine
|
### Washing Machine
|
||||||
#### Controls
|
#### Controls
|
||||||
| Name | Icon | Entity | Key |
|
| Name | Icon | Entity | Key |
|
||||||
| --- | --- | --- | --- |
|
| --- | --- | --- | --- |
|
||||||
|
@ -242,6 +242,16 @@ BINARY_SENSORS: dict[str, tuple[HonBinarySensorEntityDescription, ...]] = {
|
|||||||
translation_key="holiday_mode",
|
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",
|
||||||
|
),
|
||||||
|
),
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -271,9 +281,10 @@ class HonBinarySensorEntity(HonEntity, BinarySensorEntity):
|
|||||||
)
|
)
|
||||||
|
|
||||||
@callback
|
@callback
|
||||||
def _handle_coordinator_update(self):
|
def _handle_coordinator_update(self, update=True) -> None:
|
||||||
self._attr_native_value = (
|
self._attr_native_value = (
|
||||||
self._device.get(self.entity_description.key, "")
|
self._device.get(self.entity_description.key, "")
|
||||||
== self.entity_description.on_value
|
== self.entity_description.on_value
|
||||||
)
|
)
|
||||||
self.async_write_ha_state()
|
if update:
|
||||||
|
self.async_write_ha_state()
|
||||||
|
@ -4,7 +4,7 @@ import pkg_resources
|
|||||||
from homeassistant.components import persistent_notification
|
from homeassistant.components import persistent_notification
|
||||||
from homeassistant.components.button import ButtonEntityDescription, ButtonEntity
|
from homeassistant.components.button import ButtonEntityDescription, ButtonEntity
|
||||||
from homeassistant.config_entries import ConfigEntry
|
from homeassistant.config_entries import ConfigEntry
|
||||||
from homeassistant.const import EntityCategory
|
from homeassistant.helpers.entity import EntityCategory
|
||||||
from pyhon.appliance import HonAppliance
|
from pyhon.appliance import HonAppliance
|
||||||
|
|
||||||
from .const import DOMAIN
|
from .const import DOMAIN
|
||||||
|
@ -1,8 +1,6 @@
|
|||||||
import logging
|
import logging
|
||||||
from dataclasses import dataclass
|
from dataclasses import dataclass
|
||||||
|
|
||||||
from pyhon.appliance import HonAppliance
|
|
||||||
|
|
||||||
from homeassistant.components.climate import (
|
from homeassistant.components.climate import (
|
||||||
ClimateEntity,
|
ClimateEntity,
|
||||||
ClimateEntityDescription,
|
ClimateEntityDescription,
|
||||||
@ -22,7 +20,9 @@ from homeassistant.const import (
|
|||||||
TEMP_CELSIUS,
|
TEMP_CELSIUS,
|
||||||
)
|
)
|
||||||
from homeassistant.core import callback
|
from homeassistant.core import callback
|
||||||
from .const import HON_HVAC_MODE, HON_FAN, HON_HVAC_PROGRAM, DOMAIN
|
from pyhon.appliance import HonAppliance
|
||||||
|
|
||||||
|
from .const import HON_HVAC_MODE, HON_FAN, DOMAIN
|
||||||
from .hon import HonEntity
|
from .hon import HonEntity
|
||||||
|
|
||||||
_LOGGER = logging.getLogger(__name__)
|
_LOGGER = logging.getLogger(__name__)
|
||||||
@ -72,6 +72,22 @@ CLIMATES = {
|
|||||||
translation_key="oven",
|
translation_key="oven",
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
|
"WC": (
|
||||||
|
HonClimateEntityDescription(
|
||||||
|
key="settings.tempSel",
|
||||||
|
mode=HVACMode.COOL,
|
||||||
|
name="Wine Cellar",
|
||||||
|
icon="mdi:thermometer",
|
||||||
|
translation_key="wine",
|
||||||
|
),
|
||||||
|
HonClimateEntityDescription(
|
||||||
|
key="settings.tempSelZ2",
|
||||||
|
mode=HVACMode.COOL,
|
||||||
|
name="Wine Cellar",
|
||||||
|
icon="mdi:thermometer",
|
||||||
|
translation_key="wine",
|
||||||
|
),
|
||||||
|
),
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -99,16 +115,17 @@ class HonACClimateEntity(HonEntity, ClimateEntity):
|
|||||||
super().__init__(hass, entry, device, description)
|
super().__init__(hass, entry, device, description)
|
||||||
|
|
||||||
self._attr_temperature_unit = TEMP_CELSIUS
|
self._attr_temperature_unit = TEMP_CELSIUS
|
||||||
self._attr_target_temperature_step = device.settings["settings.tempSel"].step
|
self._set_temperature_bound()
|
||||||
self._attr_max_temp = device.settings["settings.tempSel"].max
|
|
||||||
self._attr_min_temp = device.settings["settings.tempSel"].min
|
|
||||||
|
|
||||||
self._attr_hvac_modes = [HVACMode.OFF] + [
|
self._attr_hvac_modes = [HVACMode.OFF]
|
||||||
HON_HVAC_MODE[mode] for mode in device.settings["settings.machMode"].values
|
for mode in device.settings["settings.machMode"].values:
|
||||||
]
|
self._attr_hvac_modes.append(HON_HVAC_MODE[mode])
|
||||||
self._attr_fan_modes = [FAN_OFF] + [
|
self._attr_preset_modes = []
|
||||||
HON_FAN[mode] for mode in device.settings["settings.windSpeed"].values
|
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[mode])
|
||||||
self._attr_swing_modes = [
|
self._attr_swing_modes = [
|
||||||
SWING_OFF,
|
SWING_OFF,
|
||||||
SWING_VERTICAL,
|
SWING_VERTICAL,
|
||||||
@ -119,10 +136,35 @@ class HonACClimateEntity(HonEntity, ClimateEntity):
|
|||||||
ClimateEntityFeature.TARGET_TEMPERATURE
|
ClimateEntityFeature.TARGET_TEMPERATURE
|
||||||
| ClimateEntityFeature.FAN_MODE
|
| ClimateEntityFeature.FAN_MODE
|
||||||
| ClimateEntityFeature.SWING_MODE
|
| ClimateEntityFeature.SWING_MODE
|
||||||
|
| ClimateEntityFeature.PRESET_MODE
|
||||||
)
|
)
|
||||||
|
|
||||||
self._handle_coordinator_update(update=False)
|
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."""
|
||||||
|
return int(float(self._device.get("tempSel")))
|
||||||
|
|
||||||
|
@property
|
||||||
|
def current_temperature(self) -> float | None:
|
||||||
|
"""Return the current temperature."""
|
||||||
|
return float(self._device.get("tempIndoor"))
|
||||||
|
|
||||||
|
async def async_set_temperature(self, **kwargs):
|
||||||
|
if (temperature := kwargs.get(ATTR_TEMPERATURE)) is None:
|
||||||
|
return False
|
||||||
|
self._device.settings["settings.tempSel"].value = str(int(temperature))
|
||||||
|
await self._device.commands["settings"].send()
|
||||||
|
self.async_write_ha_state()
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def hvac_mode(self) -> HVACMode | str | None:
|
def hvac_mode(self) -> HVACMode | str | None:
|
||||||
if self._device.get("onOffStatus") == "0":
|
if self._device.get("onOffStatus") == "0":
|
||||||
@ -131,24 +173,62 @@ class HonACClimateEntity(HonEntity, ClimateEntity):
|
|||||||
return HON_HVAC_MODE[self._device.get("machMode")]
|
return HON_HVAC_MODE[self._device.get("machMode")]
|
||||||
|
|
||||||
async def async_set_hvac_mode(self, hvac_mode):
|
async def async_set_hvac_mode(self, hvac_mode):
|
||||||
|
self._attr_hvac_mode = hvac_mode
|
||||||
if hvac_mode == HVACMode.OFF:
|
if hvac_mode == HVACMode.OFF:
|
||||||
await self._device.commands["stopProgram"].send()
|
await self._device.commands["stopProgram"].send()
|
||||||
|
self._device.sync_command("stopProgram", "settings")
|
||||||
else:
|
else:
|
||||||
self._device.settings["startProgram.program"].value = HON_HVAC_PROGRAM[
|
self._device.settings["settings.onOffStatus"].value = "1"
|
||||||
hvac_mode
|
setting = self._device.settings["settings.machMode"]
|
||||||
]
|
modes = {HON_HVAC_MODE[number]: number for number in setting.values}
|
||||||
await self._device.commands["startProgram"].send()
|
setting.value = modes[hvac_mode]
|
||||||
self._attr_hvac_mode = hvac_mode
|
await self._device.commands["settings"].send()
|
||||||
self.async_write_ha_state()
|
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
|
||||||
|
def fan_mode(self) -> str | None:
|
||||||
|
"""Return the fan setting."""
|
||||||
|
return HON_FAN[self._device.get("windSpeed")]
|
||||||
|
|
||||||
async def async_set_fan_mode(self, fan_mode):
|
async def async_set_fan_mode(self, fan_mode):
|
||||||
mode_number = list(HON_FAN.values()).index(fan_mode)
|
mode_number = list(HON_FAN.values()).index(fan_mode)
|
||||||
self._device.settings["settings.windSpeed"].value = list(HON_FAN.keys())[
|
mode = list(HON_FAN.keys())[mode_number]
|
||||||
mode_number
|
self._device.settings["settings.windSpeed"].value = mode
|
||||||
]
|
self._attr_fan_mode = fan_mode
|
||||||
await self._device.commands["settings"].send()
|
await self._device.commands["settings"].send()
|
||||||
self.async_write_ha_state()
|
self.async_write_ha_state()
|
||||||
|
|
||||||
|
@property
|
||||||
|
def swing_mode(self) -> str | None:
|
||||||
|
"""Return the swing setting."""
|
||||||
|
horizontal = self._device.get("windDirectionHorizontal")
|
||||||
|
vertical = self._device.get("windDirectionVertical")
|
||||||
|
if horizontal == "7" and vertical == "8":
|
||||||
|
return SWING_BOTH
|
||||||
|
elif horizontal == "7":
|
||||||
|
return SWING_HORIZONTAL
|
||||||
|
elif vertical == "8":
|
||||||
|
return SWING_VERTICAL
|
||||||
|
else:
|
||||||
|
return SWING_OFF
|
||||||
|
|
||||||
async def async_set_swing_mode(self, swing_mode):
|
async def async_set_swing_mode(self, swing_mode):
|
||||||
horizontal = self._device.settings["settings.windDirectionHorizontal"]
|
horizontal = self._device.settings["settings.windDirectionHorizontal"]
|
||||||
vertical = self._device.settings["settings.windDirectionVertical"]
|
vertical = self._device.settings["settings.windDirectionVertical"]
|
||||||
@ -164,41 +244,19 @@ class HonACClimateEntity(HonEntity, ClimateEntity):
|
|||||||
await self._device.commands["settings"].send()
|
await self._device.commands["settings"].send()
|
||||||
self.async_write_ha_state()
|
self.async_write_ha_state()
|
||||||
|
|
||||||
async def async_set_temperature(self, **kwargs):
|
|
||||||
if (temperature := kwargs.get(ATTR_TEMPERATURE)) is None:
|
|
||||||
return False
|
|
||||||
self._device.settings["settings.tempSel"].value = str(int(temperature))
|
|
||||||
await self._device.commands["settings"].send()
|
|
||||||
self.async_write_ha_state()
|
|
||||||
|
|
||||||
@callback
|
@callback
|
||||||
def _handle_coordinator_update(self, update=True) -> None:
|
def _handle_coordinator_update(self, update=True) -> None:
|
||||||
self._attr_target_temperature = int(float(self._device.get("tempSel")))
|
self._attr_target_temperature = self.target_temperature
|
||||||
self._attr_current_temperature = float(self._device.get("tempIndoor"))
|
self._attr_current_temperature = self.current_temperature
|
||||||
|
self._attr_hvac_mode = self.hvac_mode
|
||||||
if self._device.get("onOffStatus") == "0":
|
self._attr_fan_mode = self.fan_mode
|
||||||
self._attr_hvac_mode = HVACMode.OFF
|
self._attr_swing_mode = self.swing_mode
|
||||||
else:
|
|
||||||
self._attr_hvac_mode = HON_HVAC_MODE[self._device.get("machMode")]
|
|
||||||
|
|
||||||
self._attr_fan_mode = HON_FAN[self._device.get("windSpeed")]
|
|
||||||
|
|
||||||
horizontal = self._device.get("windDirectionHorizontal")
|
|
||||||
vertical = self._device.get("windDirectionVertical")
|
|
||||||
if horizontal == "7" and vertical == "8":
|
|
||||||
self._attr_swing_mode = SWING_BOTH
|
|
||||||
elif horizontal == "7":
|
|
||||||
self._attr_swing_mode = SWING_HORIZONTAL
|
|
||||||
elif vertical == "8":
|
|
||||||
self._attr_swing_mode = SWING_VERTICAL
|
|
||||||
else:
|
|
||||||
self._attr_swing_mode = SWING_OFF
|
|
||||||
if update:
|
if update:
|
||||||
self.async_write_ha_state()
|
self.async_write_ha_state()
|
||||||
|
|
||||||
|
|
||||||
class HonClimateEntity(HonEntity, ClimateEntity):
|
class HonClimateEntity(HonEntity, ClimateEntity):
|
||||||
entity_description = HonClimateEntityDescription
|
entity_description: HonClimateEntityDescription
|
||||||
|
|
||||||
def __init__(self, hass, entry, device: HonAppliance, description) -> None:
|
def __init__(self, hass, entry, device: HonAppliance, description) -> None:
|
||||||
super().__init__(hass, entry, device, description)
|
super().__init__(hass, entry, device, description)
|
||||||
@ -211,7 +269,7 @@ class HonClimateEntity(HonEntity, ClimateEntity):
|
|||||||
)
|
)
|
||||||
|
|
||||||
self._attr_hvac_modes = [description.mode]
|
self._attr_hvac_modes = [description.mode]
|
||||||
if device.get("onOffStatus"):
|
if "stopProgram" in device.commands:
|
||||||
self._attr_hvac_modes += [HVACMode.OFF]
|
self._attr_hvac_modes += [HVACMode.OFF]
|
||||||
modes = []
|
modes = []
|
||||||
else:
|
else:
|
||||||
@ -230,15 +288,15 @@ class HonClimateEntity(HonEntity, ClimateEntity):
|
|||||||
self._handle_coordinator_update(update=False)
|
self._handle_coordinator_update(update=False)
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def target_temperature(self) -> int | None:
|
def target_temperature(self) -> float | None:
|
||||||
"""Return the temperature we try to reach."""
|
"""Return the temperature we try to reach."""
|
||||||
return int(self._device.get(self.entity_description.key))
|
return float(self._device.get(self.entity_description.key))
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def current_temperature(self) -> int | None:
|
def current_temperature(self) -> float | None:
|
||||||
"""Return the current temperature."""
|
"""Return the current temperature."""
|
||||||
temp_key = self.entity_description.key.split(".")[-1].replace("Sel", "")
|
temp_key = self.entity_description.key.split(".")[-1].replace("Sel", "")
|
||||||
return int(self._device.get(temp_key))
|
return float(self._device.get(temp_key))
|
||||||
|
|
||||||
async def async_set_temperature(self, **kwargs):
|
async def async_set_temperature(self, **kwargs):
|
||||||
if (temperature := kwargs.get(ATTR_TEMPERATURE)) is None:
|
if (temperature := kwargs.get(ATTR_TEMPERATURE)) is None:
|
||||||
|
@ -7,6 +7,7 @@ from homeassistant.components.climate import (
|
|||||||
)
|
)
|
||||||
|
|
||||||
DOMAIN = "hon"
|
DOMAIN = "hon"
|
||||||
|
UPDATE_INTERVAL = 10
|
||||||
|
|
||||||
PLATFORMS = [
|
PLATFORMS = [
|
||||||
"sensor",
|
"sensor",
|
||||||
@ -16,6 +17,7 @@ PLATFORMS = [
|
|||||||
"button",
|
"button",
|
||||||
"binary_sensor",
|
"binary_sensor",
|
||||||
"climate",
|
"climate",
|
||||||
|
"fan",
|
||||||
]
|
]
|
||||||
|
|
||||||
HON_HVAC_MODE = {
|
HON_HVAC_MODE = {
|
||||||
@ -68,122 +70,136 @@ LANGUAGES = [
|
|||||||
]
|
]
|
||||||
|
|
||||||
WASHING_PR_PHASE = {
|
WASHING_PR_PHASE = {
|
||||||
"0": "WASHING_CMD&CTRL.PHASE_READY.TITLE",
|
"0": "ready",
|
||||||
"1": "WASHING_CMD&CTRL.PHASE_WASHING.TITLE",
|
"1": "washing",
|
||||||
"2": "WASHING_CMD&CTRL.PHASE_WASHING.TITLE",
|
"2": "washing",
|
||||||
"3": "WASHING_CMD&CTRL.PHASE_SPIN.TITLE",
|
"3": "spin",
|
||||||
"4": "WASHING_CMD&CTRL.PHASE_RINSE.TITLE",
|
"4": "rinse",
|
||||||
"5": "WASHING_CMD&CTRL.PHASE_RINSE.TITLE",
|
"5": "rinse",
|
||||||
"6": "WASHING_CMD&CTRL.PHASE_RINSE.TITLE",
|
"6": "rinse",
|
||||||
"7": "WASHING_CMD&CTRL.PHASE_DRYING.TITLE",
|
"7": "drying",
|
||||||
"9": "WASHING_CMD&CTRL.PHASE_STEAM.TITLE",
|
"9": "steam",
|
||||||
"10": "WASHING_CMD&CTRL.PHASE_READY.TITLE",
|
"10": "ready",
|
||||||
"11": "WASHING_CMD&CTRL.PHASE_SPIN.TITLE",
|
"11": "spin",
|
||||||
"12": "WASHING_CMD&CTRL.PHASE_WEIGHTING.TITLE",
|
"12": "weighting",
|
||||||
"13": "WASHING_CMD&CTRL.PHASE_WEIGHTING.TITLE",
|
"13": "weighting",
|
||||||
"14": "WASHING_CMD&CTRL.PHASE_WASHING.TITLE",
|
"14": "washing",
|
||||||
"15": "WASHING_CMD&CTRL.PHASE_WASHING.TITLE",
|
"15": "washing",
|
||||||
"16": "WASHING_CMD&CTRL.PHASE_WASHING.TITLE",
|
"16": "washing",
|
||||||
"17": "WASHING_CMD&CTRL.PHASE_RINSE.TITLE",
|
"17": "rinse",
|
||||||
"18": "WASHING_CMD&CTRL.PHASE_RINSE.TITLE",
|
"18": "rinse",
|
||||||
"19": "WASHING_CMD&CTRL.PHASE_SCHEDULED.TITLE",
|
"19": "scheduled",
|
||||||
"20": "WASHING_CMD&CTRL.PHASE_TUMBLING.TITLE",
|
"20": "tumbling",
|
||||||
"24": "WASHING_CMD&CTRL.PHASE_REFRESH.TITLE",
|
"24": "refresh",
|
||||||
"25": "WASHING_CMD&CTRL.PHASE_WASHING.TITLE",
|
"25": "washing",
|
||||||
"26": "WASHING_CMD&CTRL.PHASE_HEATING.TITLE",
|
"26": "heating",
|
||||||
"27": "WASHING_CMD&CTRL.PHASE_WASHING.TITLE",
|
"27": "washing",
|
||||||
}
|
}
|
||||||
|
|
||||||
MACH_MODE = {
|
MACH_MODE = {
|
||||||
"0": "WASHING_CMD&CTRL.PHASE_READY.TITLE", # NO_STATE
|
"0": "ready", # NO_STATE
|
||||||
"1": "WASHING_CMD&CTRL.PHASE_READY.TITLE", # SELECTION_MODE
|
"1": "ready", # SELECTION_MODE
|
||||||
"2": "WASHING_CMD&CTRL.PHASE_RUNNING.TITLE", # EXECUTION_MODE
|
"2": "running", # EXECUTION_MODE
|
||||||
"3": "WASHING_CMD&CTRL.PHASE_PAUSE.TITLE", # PAUSE_MODE
|
"3": "pause", # PAUSE_MODE
|
||||||
"4": "WASHING_CMD&CTRL.PHASE_SCHEDULED.TITLE", # DELAY_START_SELECTION_MODE
|
"4": "scheduled", # DELAY_START_SELECTION_MODE
|
||||||
"5": "WASHING_CMD&CTRL.PHASE_SCHEDULED.TITLE", # DELAY_START_EXECUTION_MODE
|
"5": "scheduled", # DELAY_START_EXECUTION_MODE
|
||||||
"6": "WASHING_CMD&CTRL.PHASE_ERROR.TITLE", # ERROR_MODE
|
"6": "error", # ERROR_MODE
|
||||||
"7": "WASHING_CMD&CTRL.PHASE_READY.TITLE", # END_MODE
|
"7": "ready", # END_MODE
|
||||||
"8": "Test", # TEST_MODE
|
"8": "test", # TEST_MODE
|
||||||
"9": "GLOBALS.APPLIANCE_STATUS.ENDING_PROGRAM", # STOP_MODE
|
"9": "ending", # STOP_MODE
|
||||||
}
|
}
|
||||||
|
|
||||||
TUMBLE_DRYER_PR_PHASE = {
|
TUMBLE_DRYER_PR_PHASE = {
|
||||||
"0": "WASHING_CMD&CTRL.PHASE_READY.TITLE",
|
"0": "ready",
|
||||||
"1": "TD_CMD&CTRL.STATUS_PHASE.PHASE_HEAT_STROKE",
|
"1": "heat_stroke",
|
||||||
"2": "WASHING_CMD&CTRL.PHASE_DRYING.TITLE",
|
"2": "drying",
|
||||||
"3": "TD_CMD&CTRL.STATUS_PHASE.PHASE_COOLDOWN",
|
"3": "cooldown",
|
||||||
"11": "WASHING_CMD&CTRL.PHASE_READY.TITLE",
|
"8": "unknown",
|
||||||
|
"11": "ready",
|
||||||
"12": "unknown",
|
"12": "unknown",
|
||||||
"13": "TD_CMD&CTRL.STATUS_PHASE.PHASE_COOLDOWN",
|
"13": "cooldown",
|
||||||
"14": "TD_CMD&CTRL.STATUS_PHASE.PHASE_HEAT_STROKE",
|
"14": "heat_stroke",
|
||||||
"15": "TD_CMD&CTRL.STATUS_PHASE.PHASE_HEAT_STROKE",
|
"15": "heat_stroke",
|
||||||
"16": "TD_CMD&CTRL.STATUS_PHASE.PHASE_COOLDOWN",
|
"16": "cooldown",
|
||||||
"17": "unknown",
|
"17": "unknown",
|
||||||
"18": "WASHING_CMD&CTRL.PHASE_TUMBLING.DASHBOARD_TITLE",
|
"18": "tumbling",
|
||||||
"19": "WASHING_CMD&CTRL.PHASE_DRYING.TITLE",
|
"19": "drying",
|
||||||
"20": "WASHING_CMD&CTRL.PHASE_DRYING.TITLE",
|
"20": "drying",
|
||||||
}
|
}
|
||||||
|
|
||||||
DIRTY_LEVEL = {
|
DIRTY_LEVEL = {
|
||||||
"1": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OPTIONS_VALUES_DESCRIPTION.LITTLE",
|
"0": "unknown",
|
||||||
"2": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OPTIONS_VALUES_DESCRIPTION.NORMAL",
|
"1": "little",
|
||||||
"3": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OPTIONS_VALUES_DESCRIPTION.VERY",
|
"2": "normal",
|
||||||
|
"3": "very",
|
||||||
}
|
}
|
||||||
|
|
||||||
STEAM_LEVEL = {
|
STEAM_LEVEL = {
|
||||||
"0": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OPTIONS_VALUES_DESCRIPTION.NO_STEAM",
|
"0": "no_steam",
|
||||||
"1": "WASHING_CMD&CTRL.GUIDED_WASHING_SYMBOLS_FABRICS.COTTON_TITLE",
|
"1": "cotton",
|
||||||
"2": "WASHING_CMD&CTRL.GUIDED_WASHING_SYMBOLS_FABRICS.DELICATE_TITLE",
|
"2": "delicate",
|
||||||
"3": "WASHING_CMD&CTRL.GUIDED_WASHING_SYMBOLS_FABRICS.SYNTHETIC_TITLE",
|
"3": "synthetic",
|
||||||
}
|
}
|
||||||
|
|
||||||
DISHWASHER_PR_PHASE = {
|
DISHWASHER_PR_PHASE = {
|
||||||
"0": "WASHING_CMD&CTRL.PHASE_READY.TITLE",
|
"0": "ready",
|
||||||
"1": "WASHING_CMD&CTRL.PHASE_PREWASH.TITLE",
|
"1": "prewash",
|
||||||
"2": "WASHING_CMD&CTRL.PHASE_WASHING.TITLE",
|
"2": "washing",
|
||||||
"3": "WASHING_CMD&CTRL.PHASE_RINSE.TITLE",
|
"3": "rinse",
|
||||||
"4": "WASHING_CMD&CTRL.PHASE_DRYING.TITLE",
|
"4": "drying",
|
||||||
"5": "WASHING_CMD&CTRL.PHASE_READY.TITLE",
|
"5": "ready",
|
||||||
"6": "WASHING_CMD&CTRL.PHASE_HOT_RINSE.TITLE",
|
"6": "hot_rinse",
|
||||||
}
|
}
|
||||||
|
|
||||||
TUMBLE_DRYER_DRY_LEVEL = {
|
TUMBLE_DRYER_DRY_LEVEL = {
|
||||||
"0": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_MAIN_OPTIONS.NO_DRY",
|
"0": "no_dry",
|
||||||
"1": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OPTIONS_VALUES_DESCRIPTION.IRON_DRY",
|
"1": "iron_dry",
|
||||||
"2": "WASHING_CMD&CTRL.GUIDED_WASHING_SYMBOLS_DRYING.NO_DRY_IRON_TITLE",
|
"2": "no_dry_iron",
|
||||||
"3": "WASHING_CMD&CTRL.GUIDED_WASHING_SYMBOLS_DRYING.CUPBOARD_DRY_TITLE",
|
"3": "cupboard_dry",
|
||||||
"4": "WASHING_CMD&CTRL.GUIDED_WASHING_SYMBOLS_DRYING.EXTRA_DRY_TITLE",
|
"4": "extra_dry",
|
||||||
"11": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_MAIN_OPTIONS.NO_DRY",
|
"11": "no_dry",
|
||||||
"12": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OPTIONS_VALUES_DESCRIPTION.IRON_DRY",
|
"12": "iron_dry",
|
||||||
"13": "WASHING_CMD&CTRL.GUIDED_WASHING_SYMBOLS_DRYING.CUPBOARD_DRY_TITLE",
|
"13": "cupboard_dry",
|
||||||
"14": "WASHING_CMD&CTRL.GUIDED_WASHING_SYMBOLS_DRYING.READY_TO_WEAR_TITLE",
|
"14": "ready_to_wear",
|
||||||
"15": "WASHING_CMD&CTRL.GUIDED_WASHING_SYMBOLS_DRYING.EXTRA_DRY_TITLE",
|
"15": "extra_dry",
|
||||||
}
|
}
|
||||||
|
|
||||||
AC_MACH_MODE = {
|
AC_MACH_MODE = {
|
||||||
"0": "PROGRAMS.AC.IOT_AUTO",
|
"0": "auto",
|
||||||
"1": "PROGRAMS.AC.IOT_COOL",
|
"1": "cool",
|
||||||
"2": "PROGRAMS.AC.IOT_COOL",
|
"2": "cool",
|
||||||
"3": "PROGRAMS.AC.IOT_DRY",
|
"3": "dry",
|
||||||
"4": "PROGRAMS.AC.IOT_HEAT",
|
"4": "heat",
|
||||||
"5": "PROGRAMS.AC.IOT_FAN",
|
"5": "fan",
|
||||||
"6": "PROGRAMS.AC.IOT_FAN",
|
"6": "fan",
|
||||||
}
|
}
|
||||||
|
|
||||||
AC_FAN_MODE = {
|
AC_FAN_MODE = {
|
||||||
"1": "AC.PROGRAM_CARD.WIND_SPEED_HIGH",
|
"1": "high",
|
||||||
"2": "AC.PROGRAM_CARD.WIND_SPEED_MID",
|
"2": "mid",
|
||||||
"3": "AC.PROGRAM_CARD.WIND_SPEED_LOW",
|
"3": "low",
|
||||||
"4": "AC.PROGRAM_CARD.WIND_SPEED_AUTO",
|
"4": "auto",
|
||||||
"5": "AC.PROGRAM_CARD.WIND_SPEED_AUTO",
|
"5": "auto",
|
||||||
}
|
}
|
||||||
|
|
||||||
AC_HUMAN_SENSE = {
|
AC_HUMAN_SENSE = {
|
||||||
"0": "AC.PROGRAM_DETAIL.TOUCH_OFF",
|
"0": "touch_off",
|
||||||
"1": "AC.PROGRAM_DETAIL.AVOID_TOUCH",
|
"1": "avoid_touch",
|
||||||
"2": "AC.PROGRAM_DETAIL.FOLLOW_TOUCH",
|
"2": "follow_touch",
|
||||||
|
"3": "unknown",
|
||||||
}
|
}
|
||||||
|
|
||||||
REF_ZONES = {
|
AP_MACH_MODE = {
|
||||||
"fridge": "REF.ZONES.FRIDGE",
|
"0": "standby",
|
||||||
"freezer": "REF.ZONES.FREEZER",
|
"1": "sleep",
|
||||||
"vtroom1": "REF.ZONES.MY_ZONE_1",
|
"2": "auto",
|
||||||
"fridge_freezer": ["REF.ZONES.FRIDGE", " & ", "REF.ZONES.FREEZER"],
|
"3": "allergens",
|
||||||
|
"4": "max",
|
||||||
|
}
|
||||||
|
|
||||||
|
AP_DIFFUSER_LEVEL = {
|
||||||
|
"1": "soft",
|
||||||
|
"2": "mid",
|
||||||
|
"3": "h_biotics",
|
||||||
|
"4": "custom",
|
||||||
}
|
}
|
||||||
|
122
custom_components/hon/fan.py
Normal file
122
custom_components/hon/fan.py
Normal file
@ -0,0 +1,122 @@
|
|||||||
|
import logging
|
||||||
|
import math
|
||||||
|
from dataclasses import dataclass
|
||||||
|
from typing import Any
|
||||||
|
|
||||||
|
from homeassistant.components.fan import (
|
||||||
|
FanEntityDescription,
|
||||||
|
FanEntity,
|
||||||
|
FanEntityFeature,
|
||||||
|
)
|
||||||
|
from homeassistant.config_entries import ConfigEntry
|
||||||
|
from homeassistant.core import callback
|
||||||
|
from homeassistant.util.percentage import (
|
||||||
|
percentage_to_ranged_value,
|
||||||
|
ranged_value_to_percentage,
|
||||||
|
)
|
||||||
|
from pyhon.appliance import HonAppliance
|
||||||
|
from pyhon.parameter.range import HonParameterRange
|
||||||
|
|
||||||
|
from .const import DOMAIN
|
||||||
|
from .hon import HonEntity
|
||||||
|
|
||||||
|
_LOGGER = logging.getLogger(__name__)
|
||||||
|
|
||||||
|
|
||||||
|
@dataclass
|
||||||
|
class HonFanEntityDescription(FanEntityDescription):
|
||||||
|
pass
|
||||||
|
|
||||||
|
|
||||||
|
FANS = {
|
||||||
|
"HO": (
|
||||||
|
HonFanEntityDescription(
|
||||||
|
key="settings.windSpeed",
|
||||||
|
name="Wind Speed",
|
||||||
|
translation_key="air_extraction",
|
||||||
|
),
|
||||||
|
),
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
async def async_setup_entry(hass, entry: ConfigEntry, async_add_entities) -> None:
|
||||||
|
entities = []
|
||||||
|
for device in hass.data[DOMAIN][entry.unique_id].appliances:
|
||||||
|
for description in FANS.get(device.appliance_type, []):
|
||||||
|
if isinstance(description, HonFanEntityDescription):
|
||||||
|
if description.key not in device.available_settings or not device.get(
|
||||||
|
description.key.split(".")[-1]
|
||||||
|
):
|
||||||
|
continue
|
||||||
|
entity = HonFanEntity(hass, entry, device, description)
|
||||||
|
else:
|
||||||
|
continue
|
||||||
|
await entity.coordinator.async_config_entry_first_refresh()
|
||||||
|
entities.append(entity)
|
||||||
|
async_add_entities(entities)
|
||||||
|
|
||||||
|
|
||||||
|
class HonFanEntity(HonEntity, FanEntity):
|
||||||
|
entity_description: HonFanEntityDescription
|
||||||
|
|
||||||
|
def __init__(self, hass, entry, device: HonAppliance, description) -> None:
|
||||||
|
self._attr_supported_features = FanEntityFeature.SET_SPEED
|
||||||
|
self._wind_speed: HonParameterRange = device.settings.get(description.key)
|
||||||
|
self._speed_range = (
|
||||||
|
int(self._wind_speed.values[1]),
|
||||||
|
int(self._wind_speed.values[-1]),
|
||||||
|
)
|
||||||
|
self._command, self._parameter = description.key.split(".")
|
||||||
|
|
||||||
|
super().__init__(hass, entry, device, description)
|
||||||
|
self._handle_coordinator_update(update=False)
|
||||||
|
|
||||||
|
@property
|
||||||
|
def percentage(self) -> int | None:
|
||||||
|
"""Return the current speed."""
|
||||||
|
value = int(self._device.get(self._parameter, "0"))
|
||||||
|
return ranged_value_to_percentage(self._speed_range, value)
|
||||||
|
|
||||||
|
@property
|
||||||
|
def speed_count(self) -> int:
|
||||||
|
"""Return the number of speeds the fan supports."""
|
||||||
|
return len(self._wind_speed.values[1:])
|
||||||
|
|
||||||
|
async def async_set_percentage(self, percentage: int) -> None:
|
||||||
|
"""Set the speed percentage of the fan."""
|
||||||
|
mode = math.ceil(percentage_to_ranged_value(self._speed_range, percentage))
|
||||||
|
self._device.settings[self.entity_description.key].value = mode
|
||||||
|
await self._device.commands[self._command].send()
|
||||||
|
self.async_write_ha_state()
|
||||||
|
|
||||||
|
@property
|
||||||
|
def is_on(self) -> bool | None:
|
||||||
|
"""Return true if device is on."""
|
||||||
|
mode = math.ceil(percentage_to_ranged_value(self._speed_range, self.percentage))
|
||||||
|
return mode > self._wind_speed.min
|
||||||
|
|
||||||
|
async def async_turn_on(
|
||||||
|
self,
|
||||||
|
percentage: int | None = None,
|
||||||
|
preset_mode: str | None = None,
|
||||||
|
**kwargs: Any,
|
||||||
|
) -> None:
|
||||||
|
"""Turn the entity on."""
|
||||||
|
if percentage is None:
|
||||||
|
percentage = ranged_value_to_percentage(
|
||||||
|
self._speed_range, int(self._wind_speed.values[1])
|
||||||
|
)
|
||||||
|
await self.async_set_percentage(percentage)
|
||||||
|
|
||||||
|
async def async_turn_off(self, **kwargs: Any) -> None:
|
||||||
|
"""Turn the entity off."""
|
||||||
|
self._device.settings[self.entity_description.key].value = 0
|
||||||
|
await self._device.commands[self._command].send()
|
||||||
|
self.async_write_ha_state()
|
||||||
|
|
||||||
|
@callback
|
||||||
|
def _handle_coordinator_update(self, update=True) -> None:
|
||||||
|
self._wind_speed = self._device.settings.get(self.entity_description.key)
|
||||||
|
self._attr_percentage = self.percentage
|
||||||
|
if update:
|
||||||
|
self.async_write_ha_state()
|
@ -1,12 +1,13 @@
|
|||||||
import logging
|
import logging
|
||||||
from datetime import timedelta
|
from datetime import timedelta
|
||||||
|
|
||||||
|
from homeassistant.core import callback
|
||||||
from homeassistant.helpers.entity import DeviceInfo
|
from homeassistant.helpers.entity import DeviceInfo
|
||||||
from homeassistant.helpers.update_coordinator import CoordinatorEntity
|
from homeassistant.helpers.update_coordinator import CoordinatorEntity
|
||||||
from homeassistant.helpers.update_coordinator import DataUpdateCoordinator
|
from homeassistant.helpers.update_coordinator import DataUpdateCoordinator
|
||||||
from pyhon.appliance import HonAppliance
|
from pyhon.appliance import HonAppliance
|
||||||
|
|
||||||
from .const import DOMAIN
|
from .const import DOMAIN, UPDATE_INTERVAL
|
||||||
|
|
||||||
_LOGGER = logging.getLogger(__name__)
|
_LOGGER = logging.getLogger(__name__)
|
||||||
|
|
||||||
@ -21,13 +22,14 @@ class HonEntity(CoordinatorEntity):
|
|||||||
self._hon = hass.data[DOMAIN][entry.unique_id]
|
self._hon = hass.data[DOMAIN][entry.unique_id]
|
||||||
self._hass = hass
|
self._hass = hass
|
||||||
self._coordinator = coordinator
|
self._coordinator = coordinator
|
||||||
self._device = device
|
self._device: HonAppliance = device
|
||||||
|
|
||||||
if description is not None:
|
if description is not None:
|
||||||
self.entity_description = description
|
self.entity_description = description
|
||||||
self._attr_unique_id = f"{self._device.unique_id}{description.key}"
|
self._attr_unique_id = f"{self._device.unique_id}{description.key}"
|
||||||
else:
|
else:
|
||||||
self._attr_unique_id = self._device.unique_id
|
self._attr_unique_id = self._device.unique_id
|
||||||
|
self._handle_coordinator_update(update=False)
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def device_info(self):
|
def device_info(self):
|
||||||
@ -41,6 +43,11 @@ class HonEntity(CoordinatorEntity):
|
|||||||
sw_version=self._device.get("fwVersion", ""),
|
sw_version=self._device.get("fwVersion", ""),
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@callback
|
||||||
|
def _handle_coordinator_update(self, update: bool = True) -> None:
|
||||||
|
if update:
|
||||||
|
self.async_write_ha_state()
|
||||||
|
|
||||||
|
|
||||||
class HonCoordinator(DataUpdateCoordinator):
|
class HonCoordinator(DataUpdateCoordinator):
|
||||||
def __init__(self, hass, device: HonAppliance):
|
def __init__(self, hass, device: HonAppliance):
|
||||||
@ -49,7 +56,7 @@ class HonCoordinator(DataUpdateCoordinator):
|
|||||||
hass,
|
hass,
|
||||||
_LOGGER,
|
_LOGGER,
|
||||||
name=device.unique_id,
|
name=device.unique_id,
|
||||||
update_interval=timedelta(seconds=30),
|
update_interval=timedelta(seconds=UPDATE_INTERVAL),
|
||||||
)
|
)
|
||||||
self._device = device
|
self._device = device
|
||||||
|
|
||||||
|
@ -9,7 +9,7 @@
|
|||||||
"iot_class": "cloud_polling",
|
"iot_class": "cloud_polling",
|
||||||
"issue_tracker": "https://github.com/Andre0512/hon/issues",
|
"issue_tracker": "https://github.com/Andre0512/hon/issues",
|
||||||
"requirements": [
|
"requirements": [
|
||||||
"pyhOn==0.12.1"
|
"pyhOn==0.13.1"
|
||||||
],
|
],
|
||||||
"version": "0.8.0-beta.9"
|
"version": "0.9.0-beta.4"
|
||||||
}
|
}
|
||||||
|
@ -9,7 +9,7 @@ from homeassistant.components.number import (
|
|||||||
from homeassistant.config_entries import ConfigEntry
|
from homeassistant.config_entries import ConfigEntry
|
||||||
from homeassistant.const import UnitOfTime, UnitOfTemperature
|
from homeassistant.const import UnitOfTime, UnitOfTemperature
|
||||||
from homeassistant.core import callback
|
from homeassistant.core import callback
|
||||||
from homeassistant.helpers.entity import EntityCategory, Entity
|
from homeassistant.helpers.entity import EntityCategory
|
||||||
from pyhon.parameter.range import HonParameterRange
|
from pyhon.parameter.range import HonParameterRange
|
||||||
|
|
||||||
from .const import DOMAIN
|
from .const import DOMAIN
|
||||||
@ -163,17 +163,33 @@ NUMBERS: dict[str, tuple[NumberEntityDescription, ...]] = {
|
|||||||
),
|
),
|
||||||
),
|
),
|
||||||
"HO": (
|
"HO": (
|
||||||
HonNumberEntityDescription(
|
|
||||||
key="startProgram.windSpeed",
|
|
||||||
name="Wind speed",
|
|
||||||
icon="mdi:fan",
|
|
||||||
entity_category=EntityCategory.CONFIG,
|
|
||||||
),
|
|
||||||
HonNumberEntityDescription(
|
HonNumberEntityDescription(
|
||||||
key="startProgram.lightStatus",
|
key="startProgram.lightStatus",
|
||||||
name="Light status",
|
name="Light status",
|
||||||
icon="mdi:lightbulb",
|
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",
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
}
|
}
|
||||||
@ -212,7 +228,7 @@ class HonNumberEntity(HonEntity, NumberEntity):
|
|||||||
|
|
||||||
@property
|
@property
|
||||||
def native_value(self) -> float | None:
|
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:
|
async def async_set_native_value(self, value: float) -> None:
|
||||||
setting = self._device.settings[self.entity_description.key]
|
setting = self._device.settings[self.entity_description.key]
|
||||||
@ -220,17 +236,20 @@ class HonNumberEntity(HonEntity, NumberEntity):
|
|||||||
setting.value = value
|
setting.value = value
|
||||||
command = self.entity_description.key.split(".")[0]
|
command = self.entity_description.key.split(".")[0]
|
||||||
await self._device.commands[command].send()
|
await self._device.commands[command].send()
|
||||||
|
if command != "settings":
|
||||||
|
self._device.sync_command(command, "settings")
|
||||||
await self.coordinator.async_refresh()
|
await self.coordinator.async_refresh()
|
||||||
|
|
||||||
@callback
|
@callback
|
||||||
def _handle_coordinator_update(self):
|
def _handle_coordinator_update(self, update=True) -> None:
|
||||||
setting = self._device.settings[self.entity_description.key]
|
setting = self._device.settings[self.entity_description.key]
|
||||||
if isinstance(setting, HonParameterRange):
|
if isinstance(setting, HonParameterRange):
|
||||||
self._attr_native_max_value = setting.max
|
self._attr_native_max_value = setting.max
|
||||||
self._attr_native_min_value = setting.min
|
self._attr_native_min_value = setting.min
|
||||||
self._attr_native_step = setting.step
|
self._attr_native_step = setting.step
|
||||||
self._attr_native_value = setting.value
|
self._attr_native_value = self.native_value
|
||||||
self.async_write_ha_state()
|
if update:
|
||||||
|
self.async_write_ha_state()
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def available(self) -> bool:
|
def available(self) -> bool:
|
||||||
|
@ -2,15 +2,15 @@ from __future__ import annotations
|
|||||||
|
|
||||||
import logging
|
import logging
|
||||||
from dataclasses import dataclass
|
from dataclasses import dataclass
|
||||||
|
from typing import Dict, List
|
||||||
|
|
||||||
from homeassistant.components.select import SelectEntity, SelectEntityDescription
|
from homeassistant.components.select import SelectEntity, SelectEntityDescription
|
||||||
from homeassistant.config_entries import ConfigEntry
|
from homeassistant.config_entries import ConfigEntry
|
||||||
from homeassistant.const import UnitOfTemperature, UnitOfTime, REVOLUTIONS_PER_MINUTE
|
from homeassistant.const import UnitOfTemperature, UnitOfTime, REVOLUTIONS_PER_MINUTE
|
||||||
from homeassistant.core import callback
|
from homeassistant.core import callback
|
||||||
from homeassistant.helpers.entity import EntityCategory, Entity
|
from homeassistant.helpers.entity import EntityCategory
|
||||||
from pyhon.appliance import HonAppliance
|
|
||||||
from pyhon.parameter.fixed import HonParameterFixed
|
|
||||||
|
|
||||||
|
from . import const
|
||||||
from .const import DOMAIN
|
from .const import DOMAIN
|
||||||
from .hon import HonEntity, unique_entities
|
from .hon import HonEntity, unique_entities
|
||||||
|
|
||||||
@ -19,12 +19,13 @@ _LOGGER = logging.getLogger(__name__)
|
|||||||
|
|
||||||
@dataclass
|
@dataclass
|
||||||
class HonSelectEntityDescription(SelectEntityDescription):
|
class HonSelectEntityDescription(SelectEntityDescription):
|
||||||
pass
|
option_list: Dict[str, str] = None
|
||||||
|
|
||||||
|
|
||||||
@dataclass
|
@dataclass
|
||||||
class HonConfigSelectEntityDescription(SelectEntityDescription):
|
class HonConfigSelectEntityDescription(SelectEntityDescription):
|
||||||
entity_category: EntityCategory = EntityCategory.CONFIG
|
entity_category: EntityCategory = EntityCategory.CONFIG
|
||||||
|
option_list: Dict[str, str] = None
|
||||||
|
|
||||||
|
|
||||||
SELECTS = {
|
SELECTS = {
|
||||||
@ -67,6 +68,7 @@ SELECTS = {
|
|||||||
name="Dry level",
|
name="Dry level",
|
||||||
icon="mdi:hair-dryer",
|
icon="mdi:hair-dryer",
|
||||||
translation_key="dry_levels",
|
translation_key="dry_levels",
|
||||||
|
option_list=const.TUMBLE_DRYER_DRY_LEVEL,
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
"OV": (
|
"OV": (
|
||||||
@ -115,6 +117,7 @@ SELECTS = {
|
|||||||
name="Eco Pilot",
|
name="Eco Pilot",
|
||||||
icon="mdi:run",
|
icon="mdi:run",
|
||||||
translation_key="eco_pilot",
|
translation_key="eco_pilot",
|
||||||
|
option_list=const.AC_HUMAN_SENSE,
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
"REF": (
|
"REF": (
|
||||||
@ -130,6 +133,19 @@ SELECTS = {
|
|||||||
translation_key="ref_zones",
|
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"])
|
SELECTS["WD"] = unique_entities(SELECTS["WM"], SELECTS["TD"])
|
||||||
@ -152,44 +168,65 @@ async def async_setup_entry(hass, entry: ConfigEntry, async_add_entities) -> Non
|
|||||||
async_add_entities(entities)
|
async_add_entities(entities)
|
||||||
|
|
||||||
|
|
||||||
class HonSelectEntity(HonEntity, SelectEntity):
|
class HonConfigSelectEntity(HonEntity, SelectEntity):
|
||||||
entity_description: HonSelectEntityDescription
|
entity_description: HonConfigSelectEntityDescription
|
||||||
|
|
||||||
def __init__(self, hass, entry, device: HonAppliance, description) -> None:
|
|
||||||
super().__init__(hass, entry, device, description)
|
|
||||||
|
|
||||||
if not (setting := self._device.settings.get(description.key)):
|
|
||||||
self._attr_options: list[str] = []
|
|
||||||
elif not isinstance(setting, HonParameterFixed):
|
|
||||||
self._attr_options: list[str] = setting.values
|
|
||||||
else:
|
|
||||||
self._attr_options: list[str] = [setting.value]
|
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def current_option(self) -> str | None:
|
def current_option(self) -> str | None:
|
||||||
value = self._device.settings.get(self.entity_description.key)
|
if not (setting := self._device.settings.get(self.entity_description.key)):
|
||||||
if value is None or value.value not in self._attr_options:
|
|
||||||
return None
|
return None
|
||||||
return value.value
|
value = setting.value
|
||||||
|
if self.entity_description.option_list:
|
||||||
|
value = self.entity_description.option_list.get(str(value), 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 []
|
||||||
|
options = self.entity_description.option_list or {}
|
||||||
|
return [options.get(str(key), 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 k in values and v == option),
|
||||||
|
option,
|
||||||
|
)
|
||||||
|
return option
|
||||||
|
|
||||||
async def async_select_option(self, option: str) -> None:
|
async def async_select_option(self, option: str) -> None:
|
||||||
self._device.settings[self.entity_description.key].value = option
|
setting = self._device.settings[self.entity_description.key]
|
||||||
command = self.entity_description.key.split(".")[0]
|
setting.value = self._option_to_number(option, setting.values)
|
||||||
await self._device.commands[command].send()
|
|
||||||
await self.coordinator.async_refresh()
|
await self.coordinator.async_refresh()
|
||||||
|
|
||||||
@callback
|
@callback
|
||||||
def _handle_coordinator_update(self):
|
def _handle_coordinator_update(self, update=True) -> None:
|
||||||
setting = self._device.settings.get(self.entity_description.key)
|
self._attr_available = self.available
|
||||||
if setting is None:
|
self._attr_options = self.options
|
||||||
self._attr_available = False
|
self._attr_current_option = self.current_option
|
||||||
self._attr_options: list[str] = []
|
if update:
|
||||||
self._attr_native_value = None
|
self.async_write_ha_state()
|
||||||
else:
|
|
||||||
self._attr_available = True
|
@property
|
||||||
self._attr_options: list[str] = setting.values
|
def available(self) -> bool:
|
||||||
self._attr_native_value = setting.value
|
return self._device.settings.get(self.entity_description.key) is not None
|
||||||
self.async_write_ha_state()
|
|
||||||
|
|
||||||
|
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
|
@property
|
||||||
def available(self) -> bool:
|
def available(self) -> bool:
|
||||||
@ -199,16 +236,3 @@ class HonSelectEntity(HonEntity, SelectEntity):
|
|||||||
and self._device.get("remoteCtrValid", "1") == "1"
|
and self._device.get("remoteCtrValid", "1") == "1"
|
||||||
and self._device.get("attributes.lastConnEvent.category") != "DISCONNECTED"
|
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
|
|
||||||
|
@ -1,7 +1,6 @@
|
|||||||
import logging
|
import logging
|
||||||
from dataclasses import dataclass
|
from dataclasses import dataclass
|
||||||
|
from typing import Dict
|
||||||
from pyhon.appliance import HonAppliance
|
|
||||||
|
|
||||||
from homeassistant.components.sensor import (
|
from homeassistant.components.sensor import (
|
||||||
SensorEntity,
|
SensorEntity,
|
||||||
@ -10,7 +9,12 @@ from homeassistant.components.sensor import (
|
|||||||
SensorEntityDescription,
|
SensorEntityDescription,
|
||||||
)
|
)
|
||||||
from homeassistant.config_entries import ConfigEntry
|
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 (
|
from homeassistant.const import (
|
||||||
REVOLUTIONS_PER_MINUTE,
|
REVOLUTIONS_PER_MINUTE,
|
||||||
UnitOfEnergy,
|
UnitOfEnergy,
|
||||||
@ -22,7 +26,7 @@ from homeassistant.const import (
|
|||||||
)
|
)
|
||||||
from homeassistant.core import callback
|
from homeassistant.core import callback
|
||||||
from homeassistant.helpers.entity import EntityCategory
|
from homeassistant.helpers.entity import EntityCategory
|
||||||
from homeassistant.helpers.typing import StateType
|
|
||||||
from . import const
|
from . import const
|
||||||
from .const import DOMAIN
|
from .const import DOMAIN
|
||||||
from .hon import HonEntity, unique_entities
|
from .hon import HonEntity, unique_entities
|
||||||
@ -33,11 +37,12 @@ _LOGGER = logging.getLogger(__name__)
|
|||||||
@dataclass
|
@dataclass
|
||||||
class HonConfigSensorEntityDescription(SensorEntityDescription):
|
class HonConfigSensorEntityDescription(SensorEntityDescription):
|
||||||
entity_category: EntityCategory = EntityCategory.CONFIG
|
entity_category: EntityCategory = EntityCategory.CONFIG
|
||||||
|
option_list: Dict[str, str] = None
|
||||||
|
|
||||||
|
|
||||||
@dataclass
|
@dataclass
|
||||||
class HonSensorEntityDescription(SensorEntityDescription):
|
class HonSensorEntityDescription(SensorEntityDescription):
|
||||||
pass
|
option_list: Dict[str, str] = None
|
||||||
|
|
||||||
|
|
||||||
SENSORS: dict[str, tuple[SensorEntityDescription, ...]] = {
|
SENSORS: dict[str, tuple[SensorEntityDescription, ...]] = {
|
||||||
@ -48,7 +53,7 @@ SENSORS: dict[str, tuple[SensorEntityDescription, ...]] = {
|
|||||||
icon="mdi:washing-machine",
|
icon="mdi:washing-machine",
|
||||||
device_class=SensorDeviceClass.ENUM,
|
device_class=SensorDeviceClass.ENUM,
|
||||||
translation_key="program_phases_wm",
|
translation_key="program_phases_wm",
|
||||||
options=list(const.WASHING_PR_PHASE),
|
option_list=const.WASHING_PR_PHASE,
|
||||||
),
|
),
|
||||||
HonSensorEntityDescription(
|
HonSensorEntityDescription(
|
||||||
key="totalElectricityUsed",
|
key="totalElectricityUsed",
|
||||||
@ -103,7 +108,7 @@ SENSORS: dict[str, tuple[SensorEntityDescription, ...]] = {
|
|||||||
icon="mdi:information",
|
icon="mdi:information",
|
||||||
device_class=SensorDeviceClass.ENUM,
|
device_class=SensorDeviceClass.ENUM,
|
||||||
translation_key="washing_modes",
|
translation_key="washing_modes",
|
||||||
options=list(const.MACH_MODE),
|
option_list=const.MACH_MODE,
|
||||||
),
|
),
|
||||||
HonSensorEntityDescription(
|
HonSensorEntityDescription(
|
||||||
key="errors", name="Error", icon="mdi:math-log", translation_key="errors"
|
key="errors", name="Error", icon="mdi:math-log", translation_key="errors"
|
||||||
@ -155,7 +160,9 @@ SENSORS: dict[str, tuple[SensorEntityDescription, ...]] = {
|
|||||||
key="dirtyLevel",
|
key="dirtyLevel",
|
||||||
name="Dirt level",
|
name="Dirt level",
|
||||||
icon="mdi:liquid-spot",
|
icon="mdi:liquid-spot",
|
||||||
|
device_class=SensorDeviceClass.ENUM,
|
||||||
translation_key="dirt_level",
|
translation_key="dirt_level",
|
||||||
|
option_list=const.DIRTY_LEVEL,
|
||||||
),
|
),
|
||||||
HonConfigSensorEntityDescription(
|
HonConfigSensorEntityDescription(
|
||||||
key="startProgram.suggestedLoadW",
|
key="startProgram.suggestedLoadW",
|
||||||
@ -188,7 +195,7 @@ SENSORS: dict[str, tuple[SensorEntityDescription, ...]] = {
|
|||||||
icon="mdi:information",
|
icon="mdi:information",
|
||||||
device_class=SensorDeviceClass.ENUM,
|
device_class=SensorDeviceClass.ENUM,
|
||||||
translation_key="washing_modes",
|
translation_key="washing_modes",
|
||||||
options=list(const.MACH_MODE),
|
option_list=const.MACH_MODE,
|
||||||
),
|
),
|
||||||
HonSensorEntityDescription(
|
HonSensorEntityDescription(
|
||||||
key="errors", name="Error", icon="mdi:math-log", translation_key="errors"
|
key="errors", name="Error", icon="mdi:math-log", translation_key="errors"
|
||||||
@ -222,7 +229,7 @@ SENSORS: dict[str, tuple[SensorEntityDescription, ...]] = {
|
|||||||
icon="mdi:washing-machine",
|
icon="mdi:washing-machine",
|
||||||
device_class=SensorDeviceClass.ENUM,
|
device_class=SensorDeviceClass.ENUM,
|
||||||
translation_key="program_phases_td",
|
translation_key="program_phases_td",
|
||||||
options=list(const.TUMBLE_DRYER_PR_PHASE),
|
option_list=const.TUMBLE_DRYER_PR_PHASE,
|
||||||
),
|
),
|
||||||
HonSensorEntityDescription(
|
HonSensorEntityDescription(
|
||||||
key="dryLevel",
|
key="dryLevel",
|
||||||
@ -230,7 +237,7 @@ SENSORS: dict[str, tuple[SensorEntityDescription, ...]] = {
|
|||||||
icon="mdi:hair-dryer",
|
icon="mdi:hair-dryer",
|
||||||
device_class=SensorDeviceClass.ENUM,
|
device_class=SensorDeviceClass.ENUM,
|
||||||
translation_key="dry_levels",
|
translation_key="dry_levels",
|
||||||
options=list(const.TUMBLE_DRYER_DRY_LEVEL),
|
option_list=const.TUMBLE_DRYER_DRY_LEVEL,
|
||||||
),
|
),
|
||||||
HonSensorEntityDescription(
|
HonSensorEntityDescription(
|
||||||
key="tempLevel",
|
key="tempLevel",
|
||||||
@ -256,14 +263,18 @@ SENSORS: dict[str, tuple[SensorEntityDescription, ...]] = {
|
|||||||
HonConfigSensorEntityDescription(
|
HonConfigSensorEntityDescription(
|
||||||
key="startProgram.steamLevel",
|
key="startProgram.steamLevel",
|
||||||
name="Steam level",
|
name="Steam level",
|
||||||
|
device_class=SensorDeviceClass.ENUM,
|
||||||
icon="mdi:smoke",
|
icon="mdi:smoke",
|
||||||
translation_key="steam_level",
|
translation_key="steam_level",
|
||||||
|
option_list=const.STEAM_LEVEL,
|
||||||
),
|
),
|
||||||
HonSensorEntityDescription(
|
HonSensorEntityDescription(
|
||||||
key="steamLevel",
|
key="steamLevel",
|
||||||
name="Steam level",
|
name="Steam level",
|
||||||
icon="mdi:smoke",
|
icon="mdi:smoke",
|
||||||
|
device_class=SensorDeviceClass.ENUM,
|
||||||
translation_key="steam_level",
|
translation_key="steam_level",
|
||||||
|
option_list=const.STEAM_LEVEL,
|
||||||
),
|
),
|
||||||
HonConfigSensorEntityDescription(
|
HonConfigSensorEntityDescription(
|
||||||
key="steamType",
|
key="steamType",
|
||||||
@ -392,7 +403,7 @@ SENSORS: dict[str, tuple[SensorEntityDescription, ...]] = {
|
|||||||
icon="mdi:information",
|
icon="mdi:information",
|
||||||
device_class=SensorDeviceClass.ENUM,
|
device_class=SensorDeviceClass.ENUM,
|
||||||
translation_key="washing_modes",
|
translation_key="washing_modes",
|
||||||
options=list(const.MACH_MODE),
|
option_list=const.MACH_MODE,
|
||||||
),
|
),
|
||||||
HonSensorEntityDescription(
|
HonSensorEntityDescription(
|
||||||
key="errors", name="Error", icon="mdi:math-log", translation_key="errors"
|
key="errors", name="Error", icon="mdi:math-log", translation_key="errors"
|
||||||
@ -411,7 +422,7 @@ SENSORS: dict[str, tuple[SensorEntityDescription, ...]] = {
|
|||||||
icon="mdi:washing-machine",
|
icon="mdi:washing-machine",
|
||||||
device_class=SensorDeviceClass.ENUM,
|
device_class=SensorDeviceClass.ENUM,
|
||||||
translation_key="program_phases_dw",
|
translation_key="program_phases_dw",
|
||||||
options=list(const.DISHWASHER_PR_PHASE),
|
option_list=const.DISHWASHER_PR_PHASE,
|
||||||
),
|
),
|
||||||
HonSensorEntityDescription(
|
HonSensorEntityDescription(
|
||||||
key="programName",
|
key="programName",
|
||||||
@ -485,6 +496,7 @@ SENSORS: dict[str, tuple[SensorEntityDescription, ...]] = {
|
|||||||
state_class=SensorStateClass.MEASUREMENT,
|
state_class=SensorStateClass.MEASUREMENT,
|
||||||
device_class=SensorDeviceClass.TEMPERATURE,
|
device_class=SensorDeviceClass.TEMPERATURE,
|
||||||
native_unit_of_measurement=UnitOfTemperature.CELSIUS,
|
native_unit_of_measurement=UnitOfTemperature.CELSIUS,
|
||||||
|
translation_key="target_temperature",
|
||||||
),
|
),
|
||||||
HonSensorEntityDescription(
|
HonSensorEntityDescription(
|
||||||
key="programName",
|
key="programName",
|
||||||
@ -493,6 +505,14 @@ SENSORS: dict[str, tuple[SensorEntityDescription, ...]] = {
|
|||||||
device_class=SensorDeviceClass.ENUM,
|
device_class=SensorDeviceClass.ENUM,
|
||||||
translation_key="programs_ac",
|
translation_key="programs_ac",
|
||||||
),
|
),
|
||||||
|
HonSensorEntityDescription(
|
||||||
|
key="machMode",
|
||||||
|
name="Machine Status",
|
||||||
|
icon="mdi:information",
|
||||||
|
device_class=SensorDeviceClass.ENUM,
|
||||||
|
translation_key="mach_modes_ac",
|
||||||
|
option_list=const.AC_MACH_MODE,
|
||||||
|
),
|
||||||
),
|
),
|
||||||
"REF": (
|
"REF": (
|
||||||
HonSensorEntityDescription(
|
HonSensorEntityDescription(
|
||||||
@ -594,10 +614,150 @@ SENSORS: dict[str, tuple[SensorEntityDescription, ...]] = {
|
|||||||
name="RGB Light Status",
|
name="RGB Light Status",
|
||||||
icon="mdi:lightbulb",
|
icon="mdi:lightbulb",
|
||||||
),
|
),
|
||||||
|
),
|
||||||
|
"WC": (
|
||||||
HonSensorEntityDescription(
|
HonSensorEntityDescription(
|
||||||
key="windSpeed",
|
key="errors", name="Error", icon="mdi:math-log", translation_key="errors"
|
||||||
name="Wind Speed",
|
),
|
||||||
icon="mdi:fan",
|
HonSensorEntityDescription(
|
||||||
|
key="humidityZ1",
|
||||||
|
name="Humidity",
|
||||||
|
icon="mdi:water-percent",
|
||||||
|
device_class=SensorDeviceClass.HUMIDITY,
|
||||||
|
native_unit_of_measurement=PERCENTAGE,
|
||||||
|
state_class=SensorStateClass.MEASUREMENT,
|
||||||
|
translation_key="humidity",
|
||||||
|
),
|
||||||
|
HonSensorEntityDescription(
|
||||||
|
key="humidityZ2",
|
||||||
|
name="Humidity 2",
|
||||||
|
icon="mdi:water-percent",
|
||||||
|
device_class=SensorDeviceClass.HUMIDITY,
|
||||||
|
native_unit_of_measurement=PERCENTAGE,
|
||||||
|
state_class=SensorStateClass.MEASUREMENT,
|
||||||
|
translation_key="humidity",
|
||||||
|
),
|
||||||
|
HonSensorEntityDescription(
|
||||||
|
key="temp",
|
||||||
|
name="Temperature",
|
||||||
|
icon="mdi:thermometer",
|
||||||
|
state_class=SensorStateClass.MEASUREMENT,
|
||||||
|
device_class=SensorDeviceClass.TEMPERATURE,
|
||||||
|
native_unit_of_measurement=UnitOfTemperature.CELSIUS,
|
||||||
|
translation_key="temperature",
|
||||||
|
),
|
||||||
|
HonSensorEntityDescription(
|
||||||
|
key="tempEnv",
|
||||||
|
name="Room Temperature",
|
||||||
|
icon="mdi:home-thermometer-outline",
|
||||||
|
state_class=SensorStateClass.MEASUREMENT,
|
||||||
|
device_class=SensorDeviceClass.TEMPERATURE,
|
||||||
|
native_unit_of_measurement=UnitOfTemperature.CELSIUS,
|
||||||
|
translation_key="room_temperature",
|
||||||
|
),
|
||||||
|
HonSensorEntityDescription(
|
||||||
|
key="tempSel",
|
||||||
|
name="Selected Temperature",
|
||||||
|
icon="mdi:thermometer",
|
||||||
|
state_class=SensorStateClass.MEASUREMENT,
|
||||||
|
device_class=SensorDeviceClass.TEMPERATURE,
|
||||||
|
native_unit_of_measurement=UnitOfTemperature.CELSIUS,
|
||||||
|
translation_key="target_temperature",
|
||||||
|
),
|
||||||
|
HonSensorEntityDescription(
|
||||||
|
key="tempSelZ2",
|
||||||
|
name="Selected Temperature 2",
|
||||||
|
icon="mdi:thermometer",
|
||||||
|
state_class=SensorStateClass.MEASUREMENT,
|
||||||
|
device_class=SensorDeviceClass.TEMPERATURE,
|
||||||
|
native_unit_of_measurement=UnitOfTemperature.CELSIUS,
|
||||||
|
translation_key="target_temperature",
|
||||||
|
),
|
||||||
|
HonSensorEntityDescription(
|
||||||
|
key="tempZ2",
|
||||||
|
name="Temperature 2",
|
||||||
|
icon="mdi:thermometer",
|
||||||
|
state_class=SensorStateClass.MEASUREMENT,
|
||||||
|
native_unit_of_measurement=UnitOfTemperature.CELSIUS,
|
||||||
|
device_class=SensorDeviceClass.TEMPERATURE,
|
||||||
|
translation_key="temperature",
|
||||||
|
),
|
||||||
|
HonSensorEntityDescription(
|
||||||
|
key="programName",
|
||||||
|
name="Program",
|
||||||
|
icon="mdi:play",
|
||||||
|
device_class=SensorDeviceClass.ENUM,
|
||||||
|
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",
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
}
|
}
|
||||||
@ -627,35 +787,41 @@ async def async_setup_entry(hass, entry: ConfigEntry, async_add_entities) -> Non
|
|||||||
class HonSensorEntity(HonEntity, SensorEntity):
|
class HonSensorEntity(HonEntity, SensorEntity):
|
||||||
entity_description: HonSensorEntityDescription
|
entity_description: HonSensorEntityDescription
|
||||||
|
|
||||||
def __init__(self, hass, entry, device: HonAppliance, description):
|
@callback
|
||||||
super().__init__(hass, entry, device, description)
|
def _handle_coordinator_update(self, update=True) -> None:
|
||||||
|
value = self._device.get(self.entity_description.key, "")
|
||||||
if self.entity_description.key == "programName":
|
if self.entity_description.key == "programName":
|
||||||
self._attr_options = self._device.settings.get(
|
self._attr_options = self._device.settings.get(
|
||||||
"startProgram.program"
|
"startProgram.program"
|
||||||
).values + ["No Program"]
|
).values + ["No Program"]
|
||||||
|
elif self.entity_description.option_list is not None:
|
||||||
@callback
|
self._attr_options = list(self.entity_description.option_list.values())
|
||||||
def _handle_coordinator_update(self):
|
value = self.entity_description.option_list.get(value, value)
|
||||||
value = self._device.get(self.entity_description.key, "")
|
|
||||||
if not value and self.entity_description.state_class is not None:
|
if not value and self.entity_description.state_class is not None:
|
||||||
self._attr_native_value = 0
|
self._attr_native_value = 0
|
||||||
self._attr_native_value = value
|
self._attr_native_value = value
|
||||||
self.async_write_ha_state()
|
if update:
|
||||||
|
self.async_write_ha_state()
|
||||||
|
|
||||||
|
|
||||||
class HonConfigSensorEntity(HonEntity, SensorEntity):
|
class HonConfigSensorEntity(HonEntity, SensorEntity):
|
||||||
entity_description: HonConfigSensorEntityDescription
|
entity_description: HonConfigSensorEntityDescription
|
||||||
|
|
||||||
@callback
|
@callback
|
||||||
def _handle_coordinator_update(self):
|
def _handle_coordinator_update(self, update=True) -> None:
|
||||||
value = self._device.settings.get(self.entity_description.key, None)
|
value = self._device.settings.get(self.entity_description.key, None)
|
||||||
if self.entity_description.state_class is not None:
|
if self.entity_description.state_class is not None:
|
||||||
if value and value.value:
|
if value and value.value:
|
||||||
self._attr_native_value = (
|
value = (
|
||||||
float(value.value) if "." in str(value.value) else int(value.value)
|
float(value.value) if "." in str(value.value) else int(value.value)
|
||||||
)
|
)
|
||||||
else:
|
else:
|
||||||
self._attr_native_value = 0
|
value = 0
|
||||||
else:
|
else:
|
||||||
self._attr_native_value = value.value
|
value = value.value
|
||||||
self.async_write_ha_state()
|
if self.entity_description.option_list is not None and not value == 0:
|
||||||
|
self._attr_options = list(self.entity_description.option_list.values())
|
||||||
|
value = self.entity_description.option_list.get(value, value)
|
||||||
|
self._attr_native_value = value
|
||||||
|
if update:
|
||||||
|
self.async_write_ha_state()
|
||||||
|
@ -1,10 +1,11 @@
|
|||||||
import logging
|
import logging
|
||||||
from dataclasses import dataclass
|
from dataclasses import dataclass
|
||||||
|
from datetime import datetime, timedelta
|
||||||
from typing import Any
|
from typing import Any
|
||||||
|
|
||||||
from homeassistant.components.switch import SwitchEntityDescription, SwitchEntity
|
from homeassistant.components.switch import SwitchEntityDescription, SwitchEntity
|
||||||
from homeassistant.config_entries import ConfigEntry
|
from homeassistant.config_entries import ConfigEntry
|
||||||
from homeassistant.const import EntityCategory
|
from homeassistant.helpers.entity import EntityCategory
|
||||||
from homeassistant.core import callback
|
from homeassistant.core import callback
|
||||||
from pyhon.parameter.base import HonParameter
|
from pyhon.parameter.base import HonParameter
|
||||||
from pyhon.parameter.range import HonParameterRange
|
from pyhon.parameter.range import HonParameterRange
|
||||||
@ -321,6 +322,27 @@ SWITCHES: dict[str, tuple[HonSwitchEntityDescription, ...]] = {
|
|||||||
translation_key="holiday_mode",
|
translation_key="holiday_mode",
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
|
"WC": (
|
||||||
|
HonSwitchEntityDescription(
|
||||||
|
key="sabbathStatus",
|
||||||
|
name="Sabbath Mode",
|
||||||
|
icon="mdi:palm-tree",
|
||||||
|
translation_key="holiday_mode",
|
||||||
|
),
|
||||||
|
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"])
|
SWITCHES["WD"] = unique_entities(SWITCHES["WD"], SWITCHES["WM"])
|
||||||
@ -394,10 +416,11 @@ class HonSwitchEntity(HonEntity, SwitchEntity):
|
|||||||
)
|
)
|
||||||
|
|
||||||
@callback
|
@callback
|
||||||
def _handle_coordinator_update(self):
|
def _handle_coordinator_update(self, update=True) -> None:
|
||||||
value = self._device.get(self.entity_description.key, "0")
|
value = self._device.get(self.entity_description.key, "0")
|
||||||
self._attr_state = value == "1"
|
self._attr_state = value == "1"
|
||||||
self.async_write_ha_state()
|
if update:
|
||||||
|
self.async_write_ha_state()
|
||||||
|
|
||||||
|
|
||||||
class HonControlSwitchEntity(HonEntity, SwitchEntity):
|
class HonControlSwitchEntity(HonEntity, SwitchEntity):
|
||||||
@ -410,9 +433,13 @@ class HonControlSwitchEntity(HonEntity, SwitchEntity):
|
|||||||
|
|
||||||
async def async_turn_on(self, **kwargs: Any) -> None:
|
async def async_turn_on(self, **kwargs: Any) -> None:
|
||||||
await self._device.commands[self.entity_description.turn_on_key].send()
|
await self._device.commands[self.entity_description.turn_on_key].send()
|
||||||
|
self._device.attributes[self.entity_description.key] = True
|
||||||
|
self.async_write_ha_state()
|
||||||
|
|
||||||
async def async_turn_off(self, **kwargs: Any) -> None:
|
async def async_turn_off(self, **kwargs: Any) -> None:
|
||||||
await self._device.commands[self.entity_description.turn_off_key].send()
|
await self._device.commands[self.entity_description.turn_off_key].send()
|
||||||
|
self._device.attributes[self.entity_description.key] = False
|
||||||
|
self.async_write_ha_state()
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def available(self) -> bool:
|
def available(self) -> bool:
|
||||||
@ -423,6 +450,18 @@ class HonControlSwitchEntity(HonEntity, SwitchEntity):
|
|||||||
and self._device.get("attributes.lastConnEvent.category") != "DISCONNECTED"
|
and self._device.get("attributes.lastConnEvent.category") != "DISCONNECTED"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@property
|
||||||
|
def extra_state_attributes(self) -> dict[str, Any]:
|
||||||
|
"""Return the optional state attributes."""
|
||||||
|
result = {}
|
||||||
|
if remaining_time := int(self._device.get("remainingTimeMM", 0)):
|
||||||
|
delay_time = int(self._device.get("delayTime", 0))
|
||||||
|
result["start_time"] = datetime.now() + timedelta(minutes=delay_time)
|
||||||
|
result["end_time"] = datetime.now() + timedelta(
|
||||||
|
minutes=delay_time + remaining_time
|
||||||
|
)
|
||||||
|
return result
|
||||||
|
|
||||||
|
|
||||||
class HonConfigSwitchEntity(HonEntity, SwitchEntity):
|
class HonConfigSwitchEntity(HonEntity, SwitchEntity):
|
||||||
entity_description: HonConfigSwitchEntityDescription
|
entity_description: HonConfigSwitchEntityDescription
|
||||||
@ -454,7 +493,8 @@ class HonConfigSwitchEntity(HonEntity, SwitchEntity):
|
|||||||
await self.coordinator.async_refresh()
|
await self.coordinator.async_refresh()
|
||||||
|
|
||||||
@callback
|
@callback
|
||||||
def _handle_coordinator_update(self):
|
def _handle_coordinator_update(self, update=True) -> None:
|
||||||
value = self._device.settings.get(self.entity_description.key, "0")
|
value = self._device.settings.get(self.entity_description.key, "0")
|
||||||
self._attr_state = value == "1"
|
self._attr_state = value == "1"
|
||||||
self.async_write_ha_state()
|
if update:
|
||||||
|
self.async_write_ha_state()
|
||||||
|
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
64
info.md
64
info.md
@ -2,7 +2,7 @@
|
|||||||
[](https://github.com/Andre0512/hon/releases/latest)
|
[](https://github.com/Andre0512/hon/releases/latest)
|
||||||
[](https://github.com/Andre0512/hon/blob/main/LICENSE)
|
[](https://github.com/Andre0512/hon/blob/main/LICENSE)
|
||||||
[](https://tooomm.github.io/github-release-stats/?username=Andre0512&repository=hon)
|
[](https://tooomm.github.io/github-release-stats/?username=Andre0512&repository=hon)
|
||||||
Support for home appliances of Haier's mobile app hOn.
|
Support for home appliances of [Haier's mobile app hOn](https://hon-smarthome.com/) based on [pyhOn](https://github.com/Andre0512/pyhon).
|
||||||
|
|
||||||
## Supported Appliances
|
## Supported Appliances
|
||||||
- [Washing Machine](https://github.com/Andre0512/hon#washing-machine)
|
- [Washing Machine](https://github.com/Andre0512/hon#washing-machine)
|
||||||
@ -10,10 +10,12 @@ Support for home appliances of Haier's mobile app hOn.
|
|||||||
- [Washer Dryer](https://github.com/Andre0512/hon#washer-dryer)
|
- [Washer Dryer](https://github.com/Andre0512/hon#washer-dryer)
|
||||||
- [Oven](https://github.com/Andre0512/hon#oven)
|
- [Oven](https://github.com/Andre0512/hon#oven)
|
||||||
- [Dish Washer](https://github.com/Andre0512/hon#dish-washer)
|
- [Dish Washer](https://github.com/Andre0512/hon#dish-washer)
|
||||||
- [Hob](https://github.com/Andre0512/hon#hob) [BETA]
|
- [Air Conditioner](https://github.com/Andre0512/hon#air-conditioner)
|
||||||
- [Air conditioner](https://github.com/Andre0512/hon#air-conditioner) [BETA]
|
- [Fridge](https://github.com/Andre0512/hon#fridge)
|
||||||
- [Fridge](https://github.com/Andre0512/hon#fridge) [BETA]
|
- [Induction Hob](https://github.com/Andre0512/hon#induction-hob) [BETA]
|
||||||
- [Hood](https://github.com/Andre0512/hon#hood) [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
|
## Configuration
|
||||||
|
|
||||||
@ -22,6 +24,22 @@ Support for home appliances of Haier's mobile app hOn.
|
|||||||
**Method 2**: Settings > Devices & Services > Add Integration > **Haier hOn**
|
**Method 2**: Settings > Devices & Services > Add Integration > **Haier hOn**
|
||||||
_If the integration is not in the list, you need to clear the browser cache._
|
_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 <br/> HW100-B14959U1 | H-WASH 500 <br/> H7W4 48MBC-S | CO4 107T1/2-07 <br/> CBWO49TWME-S <br/> RO44 1286DWMC4-07 <br/> HW 68AMC/1-80 <br/> HWPD 69AMBC/1-S |
|
||||||
|
| **Tumble Dryer** | HD80-A3959 | H-DRY 500 <br/> H9A3TCBEXS-S <br/> HLE C10DCE-80 <br/> NDE H10A2TCE-80 <br/> NDE H9A2TSBEXS-S <br/> NDPHY10A2TCBEXSS | BCTDH7A1TE <br/> CSOE C10DE-80 <br/> ROE H9A3TCEX-S |
|
||||||
|
| **Washer Dryer** | HWD100-B14979 | HWPS4954DAMR-11 | RPW41066BWMR/1-S |
|
||||||
|
| **Oven** | HWO60SM2F3XH | HSOT3161WG | |
|
||||||
|
| **Dish Washer** | XIB 3B2SFS-80 <br/> XIB 6B2D3FB | HFB 6B2S3FX | |
|
||||||
|
| **Air Conditioner** | AD105S2SM3FA <br/> AS20HPL1HRA <br/> AS25PBAHRA <br/> AS25S2SF1FA-WH <br/> AS25TADHRA-2 <br/> AS35S2SF2FA-3 <br/> AS35TADHRA-2 <br/> AS35TAMHRA-C | | |
|
||||||
|
| **Fridge** | HFW7720ENMB | | CCE4T620EWU |
|
||||||
|
| **Hob** | HA2MTSJ68MC | | CIS633SCTTWIFI |
|
||||||
|
| **Hood** | HADG6DS46BWIFI | | |
|
||||||
|
| **Wine Cellar** | HWS247FDU1 | | |
|
||||||
|
|
||||||
## Supported Languages
|
## Supported Languages
|
||||||
Translation of internal names like programs are available for all languages which are official supported by the hOn app:
|
Translation of internal names like programs are available for all languages which are official supported by the hOn app:
|
||||||
* 🇨🇳 Chinese
|
* 🇨🇳 Chinese
|
||||||
@ -48,44 +66,6 @@ Translation of internal names like programs are available for all languages whic
|
|||||||
### Washing Machine
|
### Washing Machine
|
||||||

|

|
||||||
|
|
||||||
## 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 AD105S2SM3FA
|
|
||||||
- Haier AS25PBAHRA
|
|
||||||
- Haier AS25S2SF1FA-WH
|
|
||||||
- Haier AS25TADHRA-2
|
|
||||||
- Haier AS35TADHRA-2
|
|
||||||
- Haier EG9012B19SU1JD
|
|
||||||
- Haier HA2MTSJ68MC
|
|
||||||
- Haier HADG6DS46BWIFI
|
|
||||||
- Haier HD80-A3959
|
|
||||||
- Haier HW90-B14TEAM5
|
|
||||||
- Haier HW100-B14959U1
|
|
||||||
- Haier HWD100-B14979
|
|
||||||
- Haier HWO60SM2F3XH
|
|
||||||
- Haier XIB 3B2SFS-80
|
|
||||||
- Haier XIB 6B2D3FB
|
|
||||||
- Candy BCTDH7A1TE
|
|
||||||
- Candy CCE4T620EWU
|
|
||||||
- Candy CIS633SCTTWIFI
|
|
||||||
- Candy CSOE C10DE-80
|
|
||||||
- Candy RO44 1286DWMC4-07
|
|
||||||
- Candy ROE H9A3TCEX-S
|
|
||||||
- Candy RPW41066BWMR/1-S
|
|
||||||
- Hoover H-WASH 500
|
|
||||||
- Hoover H-DRY 500
|
|
||||||
- Hoover H7W4 48MBC-S
|
|
||||||
- Hoover H9A3TCBEXS-S
|
|
||||||
- Hoover HFB 6B2S3FX
|
|
||||||
- Hoover HLE C10DCE-80
|
|
||||||
- Hoover HSOT3161WG
|
|
||||||
- Hoover HW 68AMC/1-80
|
|
||||||
- Hoover HWPD 69AMBC/1-S
|
|
||||||
- Hoover HWPS4954DAMR-11
|
|
||||||
- Hoover NDE H10A2TCE-80
|
|
||||||
- Hoover NDE H9A2TSBEXS-S
|
|
||||||
- Hoover NDPHY10A2TCBEXSS
|
|
||||||
|
|
||||||
## Contribute
|
## Contribute
|
||||||
Want to help us to support more appliances? Or add more sensors? Or help with translating? Or beautify some icons or captions?
|
Want to help us to support more appliances? Or add more sensors? Or help with translating? Or beautify some icons or captions?
|
||||||
Check out the [project on GitHub](https://github.com/Andre0512/hon), every contribution is welcome!
|
Check out the [project on GitHub](https://github.com/Andre0512/hon), every contribution is welcome!
|
||||||
|
@ -8,248 +8,13 @@ from pathlib import Path
|
|||||||
|
|
||||||
from pyhon import HonAPI
|
from pyhon import HonAPI
|
||||||
|
|
||||||
|
|
||||||
if __name__ == "__main__":
|
if __name__ == "__main__":
|
||||||
sys.path.insert(0, str(Path(__file__).parent.parent))
|
sys.path.insert(0, str(Path(__file__).parent.parent))
|
||||||
|
|
||||||
|
from scripts.translation_keys import SENSOR, SELECT, PROGRAMS, NAMES, CLIMATE
|
||||||
from custom_components.hon import const
|
from custom_components.hon import const
|
||||||
|
|
||||||
SENSOR = {
|
|
||||||
"washing_modes": const.MACH_MODE,
|
|
||||||
"mach_modes_ac": const.AC_MACH_MODE,
|
|
||||||
"program_phases_wm": const.WASHING_PR_PHASE,
|
|
||||||
"program_phases_td": const.TUMBLE_DRYER_PR_PHASE,
|
|
||||||
"program_phases_dw": const.DISHWASHER_PR_PHASE,
|
|
||||||
"dry_levels": const.TUMBLE_DRYER_DRY_LEVEL,
|
|
||||||
}
|
|
||||||
|
|
||||||
SELECT = {
|
|
||||||
"dry_levels": const.TUMBLE_DRYER_DRY_LEVEL,
|
|
||||||
"eco_pilot": const.AC_HUMAN_SENSE,
|
|
||||||
"fan_mode": const.AC_FAN_MODE,
|
|
||||||
"ref_zones": const.REF_ZONES,
|
|
||||||
}
|
|
||||||
|
|
||||||
PROGRAMS = {
|
|
||||||
"select": {
|
|
||||||
"programs_ac": "PROGRAMS.AC",
|
|
||||||
"programs_dw": "PROGRAMS.DW",
|
|
||||||
"programs_ih": "PROGRAMS.IH",
|
|
||||||
"programs_ov": "PROGRAMS.OV",
|
|
||||||
"programs_td": "PROGRAMS.TD",
|
|
||||||
"programs_wm": "PROGRAMS.WM_WD",
|
|
||||||
"programs_ref": "PROGRAMS.REF",
|
|
||||||
},
|
|
||||||
"sensor": {
|
|
||||||
"programs_ac": "PROGRAMS.AC",
|
|
||||||
"programs_dw": "PROGRAMS.DW",
|
|
||||||
"programs_ih": "PROGRAMS.IH",
|
|
||||||
"programs_ov": "PROGRAMS.OV",
|
|
||||||
"programs_td": "PROGRAMS.TD",
|
|
||||||
"programs_wm": "PROGRAMS.WM_WD",
|
|
||||||
"programs_ref": "PROGRAMS.REF",
|
|
||||||
},
|
|
||||||
}
|
|
||||||
|
|
||||||
CLIMATE = {
|
|
||||||
"fridge": {
|
|
||||||
"preset_mode": {
|
|
||||||
"name": "REF_CMD&CTRL.MODE_SELECTION_DRAWER_FRIDGE.FRIDGE_MODE_TITLE",
|
|
||||||
"state": {
|
|
||||||
"auto_set": "REF_CMD&CTRL.MODALITIES.ECO",
|
|
||||||
"super_cool": "REF_CMD&CTRL.MODALITIES.SUPER_COOL",
|
|
||||||
"holiday": "REF_CMD&CTRL.MODALITIES.BACK_FROM_HOLIDAY",
|
|
||||||
"no_mode": "REF_CMD&CTRL.MODALITIES.NO_MODE_SELECTED",
|
|
||||||
},
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"freezer": {
|
|
||||||
"preset_mode": {
|
|
||||||
"name": "REF_CMD&CTRL.MODE_SELECTION_DRAWER_FREEZER.FREEZER_MODE_TITLE",
|
|
||||||
"state": {
|
|
||||||
"auto_set": "REF_CMD&CTRL.MODALITIES.ECO",
|
|
||||||
"super_freeze": "REF_CMD&CTRL.MODALITIES.SHOCK_FREEZE",
|
|
||||||
"no_mode": "REF_CMD&CTRL.MODALITIES.NO_MODE_SELECTED",
|
|
||||||
},
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"oven": {
|
|
||||||
"preset_mode": {
|
|
||||||
"name": "OV.TABS.PROGRAMS_TITLE",
|
|
||||||
"state": "PROGRAMS.OV",
|
|
||||||
}
|
|
||||||
},
|
|
||||||
}
|
|
||||||
|
|
||||||
NAMES = {
|
|
||||||
"switch": {
|
|
||||||
"anti_crease": "HDRY_CMD&CTRL.PROGRAM_CYCLE_DETAIL.ANTICREASE_TITLE",
|
|
||||||
"add_dish": "DW.ADD_DISH",
|
|
||||||
"eco_express": "DW_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OTHER_OPTIONS.ECO",
|
|
||||||
"extra_dry": "DW_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OTHER_OPTIONS.EXTRA_DRY",
|
|
||||||
"half_load": "DW_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OTHER_OPTIONS.HALF_LOAD",
|
|
||||||
"open_door": "DW_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OTHER_OPTIONS.OPEN_DOOR",
|
|
||||||
"three_in_one": "DW_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OTHER_OPTIONS.THREE_IN_ONE",
|
|
||||||
"preheat": "OV.PROGRAM_DETAIL.PREHEAT",
|
|
||||||
"dish_washer": "GLOBALS.APPLIANCES_NAME.DW",
|
|
||||||
"tumble_dryer": "GLOBALS.APPLIANCES_NAME.TD",
|
|
||||||
"washing_machine": "GLOBALS.APPLIANCES_NAME.WM",
|
|
||||||
"washer_dryer": "GLOBALS.APPLIANCES_NAME.WD",
|
|
||||||
"oven": "GLOBALS.APPLIANCES_NAME.OV",
|
|
||||||
"prewash": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OTHER_OPTIONS.PREWASH",
|
|
||||||
"pause": "GENERAL.PAUSE_PROGRAM",
|
|
||||||
"keep_fresh": "GLOBALS.APPLIANCE_STATUS.TUMBLING",
|
|
||||||
"delay_time": "HINTS.TIPS_TIME_ENERGY_SAVING.TIPS_USE_AT_NIGHT_TITLE",
|
|
||||||
"rapid_mode": "AC.PROGRAM_CARD.RAPID",
|
|
||||||
"eco_mode": "AC.PROGRAM_CARD.ECO_MODE",
|
|
||||||
"10_degree_heating": "PROGRAMS.AC.IOT_10_HEATING",
|
|
||||||
"self_clean": "PROGRAMS.AC.IOT_SELF_CLEAN",
|
|
||||||
"self_clean_56": "PROGRAMS.AC.IOT_SELF_CLEAN_56",
|
|
||||||
"silent_mode": "AC.PROGRAM_DETAIL.SILENT_MODE",
|
|
||||||
"mute_mode": "AC.PROGRAM_DETAIL.MUTE_MODE",
|
|
||||||
"extra_rinse_1": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OTHER_OPTIONS.EXTRARINSE1",
|
|
||||||
"extra_rinse_2": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OTHER_OPTIONS.EXTRARINSE2",
|
|
||||||
"extra_rinse_3": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OTHER_OPTIONS.EXTRARINSE3",
|
|
||||||
"acqua_plus": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OTHER_OPTIONS.ACQUAPLUS",
|
|
||||||
"auto_dose_softener": [
|
|
||||||
"WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OTHER_OPTIONS.AUTODOSE",
|
|
||||||
"WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OTHER_OPTIONS.SOFTENER",
|
|
||||||
],
|
|
||||||
"auto_dose_detergent": [
|
|
||||||
"WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OTHER_OPTIONS.AUTODOSE",
|
|
||||||
"WASHING_CMD&CTRL.DASHBOARD_MENU_MORE_SETTINGS_WATER.DETERGENT",
|
|
||||||
],
|
|
||||||
"good_night": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OTHER_OPTIONS.GOODNIGHT",
|
|
||||||
"auto_set": "REF_CMD&CTRL.MODALITIES.ECO",
|
|
||||||
"super_cool": "REF_CMD&CTRL.MODALITIES.SUPER_COOL",
|
|
||||||
"super_freeze": "REF_CMD&CTRL.MODALITIES.SUPER_FREEZE",
|
|
||||||
"refrigerator": "REF.NAME",
|
|
||||||
},
|
|
||||||
"binary_sensor": {
|
|
||||||
"door_lock": "WASHING_CMD&CTRL.CHECK_UP_RESULTS.DOOR_LOCK",
|
|
||||||
"extra_rinse_1": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OTHER_OPTIONS.EXTRARINSE1",
|
|
||||||
"extra_rinse_2": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OTHER_OPTIONS.EXTRARINSE2",
|
|
||||||
"extra_rinse_3": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OTHER_OPTIONS.EXTRARINSE3",
|
|
||||||
"good_night": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OTHER_OPTIONS.GOODNIGHT",
|
|
||||||
"anti_crease": "HDRY_CMD&CTRL.PROGRAM_CYCLE_DETAIL.ANTICREASE_TITLE",
|
|
||||||
"acqua_plus": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OTHER_OPTIONS.ACQUAPLUS",
|
|
||||||
"spin_speed": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_MAIN_OPTIONS.SPINSPEED",
|
|
||||||
"still_hot": "IH.COILS_STATUS.STILL_HOT",
|
|
||||||
"pan_status": "IH.COILS_STATUS.PAN",
|
|
||||||
"remote_control": "OV.SUPPORT.REMOTE_CONTROL",
|
|
||||||
"rinse_aid": "DW_CMD&CTRL.MAINTENANCE.CONSUMABLE_LEVELS_ICON_RINSE_AID",
|
|
||||||
"salt_level": "DW_CMD&CTRL.MAINTENANCE.CONSUMABLE_LEVELS_ICON_SALT",
|
|
||||||
"door_open": "GLOBALS.APPLIANCE_STATUS.DOOR_OPEN",
|
|
||||||
"connection": "ENROLLMENT_COMMON.HEADER_NAME.STEP_APPLIANCE_CONNECTION",
|
|
||||||
"child_lock": "AP.FOOTER_MENU_MORE.SECURITY_LOCK_TITLE",
|
|
||||||
"on": "GLOBALS.GENERAL.ON",
|
|
||||||
"prewash": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OTHER_OPTIONS.PREWASH",
|
|
||||||
"buzzer": "DW_CMD&CTRL.SETTINGS.END_CYCLE_BUZZER",
|
|
||||||
"holiday_mode": "REF.DASHBOARD_MENU_MORE_NOTIFICATIONS.HOLIDAY_MODE",
|
|
||||||
"auto_set": "REF_CMD&CTRL.MODALITIES.ECO",
|
|
||||||
"super_cool": "REF_CMD&CTRL.MODALITIES.SUPER_COOL",
|
|
||||||
"super_freeze": "REF_CMD&CTRL.MODALITIES.SUPER_FREEZE",
|
|
||||||
"freezer_door": ["GLOBALS.APPLIANCE_STATUS.DOOR_OPEN", "REF.ZONES.FREEZER"],
|
|
||||||
"fridge_door": ["GLOBALS.APPLIANCE_STATUS.DOOR_OPEN", "REF.ZONES.FRIDGE"],
|
|
||||||
"filter_replacement": "AP.MAINTENANCE.FILTER_REPLACEMENT",
|
|
||||||
},
|
|
||||||
"button": {
|
|
||||||
"induction_hob": "GLOBALS.APPLIANCES_NAME.IH",
|
|
||||||
"start_program": ["WC.SET_PROGRAM.PROGRAM", "GLOBALS.GENERAL.START_ON"],
|
|
||||||
"stop_program": ["WC.SET_PROGRAM.PROGRAM", "GLOBALS.GENERAL.STOP"],
|
|
||||||
},
|
|
||||||
"select": {
|
|
||||||
"dry_levels": "WASHING_CMD&CTRL.DRAWER_CYCLE_DRYING.TAB_LEVEL",
|
|
||||||
"dry_time": "WASHING_CMD&CTRL.DRAWER_CYCLE_DRYING.TAB_TIME",
|
|
||||||
"spin_speed": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_MAIN_OPTIONS.SPINSPEED",
|
|
||||||
"temperature": "IH.COMMON.TEMPERATURE",
|
|
||||||
"programs_dw": "WC.SET_PROGRAM.PROGRAM",
|
|
||||||
"programs_ih": "WC.SET_PROGRAM.PROGRAM",
|
|
||||||
"programs_ov": "WC.SET_PROGRAM.PROGRAM",
|
|
||||||
"programs_td": "WC.SET_PROGRAM.PROGRAM",
|
|
||||||
"programs_wm": "WC.SET_PROGRAM.PROGRAM",
|
|
||||||
"programs_ac": "WC.SET_PROGRAM.PROGRAM",
|
|
||||||
"programs_ref": "WC.SET_PROGRAM.PROGRAM",
|
|
||||||
"eco_pilot": "AC.PROGRAM_DETAIL.ECO_PILOT",
|
|
||||||
"remaining_time": "ENROLLMENT_COMMON.GENERAL.REMAINING_TIME",
|
|
||||||
"ref_zones": "IH.COMMON.COIL",
|
|
||||||
},
|
|
||||||
"sensor": {
|
|
||||||
"dry_levels": "WASHING_CMD&CTRL.DRAWER_CYCLE_DRYING.TAB_LEVEL",
|
|
||||||
"dry_time": "WASHING_CMD&CTRL.DRAWER_CYCLE_DRYING.TAB_TIME",
|
|
||||||
"power": "OV.RECIPE_DETAIL.POWER_LEVEL",
|
|
||||||
"remaining_time": "ENROLLMENT_COMMON.GENERAL.REMAINING_TIME",
|
|
||||||
"temperature": "IH.COMMON.TEMPERATURE",
|
|
||||||
"water_efficiency": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_RESULT.WATER_EFFICIENCY",
|
|
||||||
"water_saving": "STATISTICS.SMART_AI_CYCLE.WATER_SAVING",
|
|
||||||
"duration": "WASHING_CMD&CTRL.DRAWER_PROGRAM_FILTERS.DURATION",
|
|
||||||
"target_temperature": "IH.COOKING_DETAIL.TEMPERATURE_TARGETING",
|
|
||||||
"spin_speed": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_MAIN_OPTIONS.SPINSPEED",
|
|
||||||
"steam_leve": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_MAIN_OPTIONS.STEAM_LEVEL",
|
|
||||||
"dirt_level": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_MAIN_OPTIONS.DIRTY_LEVEL",
|
|
||||||
"program_phases_wm": "WASHING_CMD&CTRL.STATISTICS_GRAPHIC_INSTANT_CONSUMPTION.PHASE",
|
|
||||||
"program_phases_td": "WASHING_CMD&CTRL.STATISTICS_GRAPHIC_INSTANT_CONSUMPTION.PHASE",
|
|
||||||
"program_phases_dw": "WASHING_CMD&CTRL.STATISTICS_GRAPHIC_INSTANT_CONSUMPTION.PHASE",
|
|
||||||
"delay_time": "HINTS.TIPS_TIME_ENERGY_SAVING.TIPS_USE_AT_NIGHT_TITLE",
|
|
||||||
"suggested_load": "WASHING_CMD&CTRL.DRAWER_PROGRAM_FILTERS.LOAD_CAPACITY",
|
|
||||||
"energy_label": "WASHING_CMD&CTRL.DRAWER_PROGRAM_FILTERS.ENERGY_EFFICIENCY",
|
|
||||||
"det_dust": "HUBS.WIDGET.STAINS_WIDGET.STAINS.SUGGESTED_DET_DUST",
|
|
||||||
"det_liquid": "HUBS.WIDGET.STAINS_WIDGET.STAINS.SUGGESTED_DET_LIQUID",
|
|
||||||
"errors": "ROBOT_CMD&CTRL.PHASE_ERROR.TITLE",
|
|
||||||
"programs": "OV.TABS.CURRENT_PROGRAM",
|
|
||||||
"room_temperature": "REF.SMART_DRINK_ASSISTANT.AMBIENT",
|
|
||||||
"humidity": "AP.TITLES.HUMIDITY",
|
|
||||||
"cycles_total": [
|
|
||||||
"WASHING_CMD&CTRL.GENERAL.CYCLES",
|
|
||||||
"WC.VIRTUAL_WINE_STATS_COUNTRY.TOTAL",
|
|
||||||
],
|
|
||||||
"energy_total": [
|
|
||||||
"MISE.ENERGY_CONSUMPTION.TITLE",
|
|
||||||
"WC.VIRTUAL_WINE_STATS_COUNTRY.TOTAL",
|
|
||||||
],
|
|
||||||
"water_total": [
|
|
||||||
"WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_RESULT.WATER_EFFICIENCY",
|
|
||||||
"WC.VIRTUAL_WINE_STATS_COUNTRY.TOTAL",
|
|
||||||
],
|
|
||||||
"energy_current": [
|
|
||||||
"MISE.ENERGY_CONSUMPTION.TITLE",
|
|
||||||
"CUBE90_GLOBAL.GENERAL.CURRENT",
|
|
||||||
],
|
|
||||||
"water_current": [
|
|
||||||
"WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_RESULT.WATER_EFFICIENCY",
|
|
||||||
"CUBE90_GLOBAL.GENERAL.CURRENT",
|
|
||||||
],
|
|
||||||
"freezer_temp": "REF_CMD&CTRL.TEMPERATURE_DRAWER_FREEZER.FREEZER_TEMPERATURE_TITLE",
|
|
||||||
"fridge_temp": "REF_CMD&CTRL.TEMPERATURE_DRAWER_FRIDGE.FRIDGE_TEMPERATURE_TITLE",
|
|
||||||
"programs_dw": "WC.SET_PROGRAM.PROGRAM",
|
|
||||||
"programs_ih": "WC.SET_PROGRAM.PROGRAM",
|
|
||||||
"programs_ov": "WC.SET_PROGRAM.PROGRAM",
|
|
||||||
"programs_td": "WC.SET_PROGRAM.PROGRAM",
|
|
||||||
"programs_wm": "WC.SET_PROGRAM.PROGRAM",
|
|
||||||
"programs_ac": "WC.SET_PROGRAM.PROGRAM",
|
|
||||||
"programs_ref": "WC.SET_PROGRAM.PROGRAM",
|
|
||||||
},
|
|
||||||
"number": {
|
|
||||||
"power_management": "HINTS.COOKING_WITH_INDUCTION.POWER_MANAGEMENT",
|
|
||||||
"temperature": "IH.COMMON.TEMPERATURE",
|
|
||||||
"delay_time": "HINTS.TIPS_TIME_ENERGY_SAVING.TIPS_USE_AT_NIGHT_TITLE",
|
|
||||||
"water_hard": "WASHING_CMD&CTRL.DASHBOARD_MENU_MORE_SETTINGS_WATER.TITLE",
|
|
||||||
"program_duration": "OV.PROGRAM_DETAIL.PROGRAM_DURATION",
|
|
||||||
"target_temperature": "IH.COOKING_DETAIL.TEMPERATURE_TARGETING",
|
|
||||||
"rinse_iterations": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL.DRAWER_HEADER_RINSE",
|
|
||||||
"wash_time": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL.WASHING_TIME",
|
|
||||||
"dry_time": "WASHING_CMD&CTRL.DRAWER_CYCLE_DRYING.TAB_TIME",
|
|
||||||
"steam_level": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_MAIN_OPTIONS.STEAM_LEVEL",
|
|
||||||
"freezer_temp_sel": ["OV.COMMON.GOAL_TEMPERATURE", "REF.ZONES.FREEZER"],
|
|
||||||
"fridge_temp_sel": ["OV.COMMON.GOAL_TEMPERATURE", "REF.ZONES.FRIDGE"],
|
|
||||||
},
|
|
||||||
"climate": {
|
|
||||||
"air_conditioner": "GLOBALS.APPLIANCES_NAME.AC",
|
|
||||||
"fridge": "REF.ZONES.FRIDGE",
|
|
||||||
"freezer": "REF.ZONES.FREEZER",
|
|
||||||
"oven": "GLOBALS.APPLIANCES_NAME.OV",
|
|
||||||
},
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
async def check_translation_files(translations):
|
async def check_translation_files(translations):
|
||||||
for language in const.LANGUAGES:
|
for language in const.LANGUAGES:
|
||||||
|
@ -14,6 +14,7 @@ from custom_components.hon.climate import CLIMATES
|
|||||||
from custom_components.hon.number import NUMBERS
|
from custom_components.hon.number import NUMBERS
|
||||||
from custom_components.hon.select import SELECTS
|
from custom_components.hon.select import SELECTS
|
||||||
from custom_components.hon.sensor import SENSORS
|
from custom_components.hon.sensor import SENSORS
|
||||||
|
from custom_components.hon.fan import FANS
|
||||||
from custom_components.hon.switch import (
|
from custom_components.hon.switch import (
|
||||||
SWITCHES,
|
SWITCHES,
|
||||||
HonControlSwitchEntityDescription,
|
HonControlSwitchEntityDescription,
|
||||||
@ -21,21 +22,21 @@ from custom_components.hon.switch import (
|
|||||||
)
|
)
|
||||||
|
|
||||||
APPLIANCES = {
|
APPLIANCES = {
|
||||||
"AC": "Air conditioner",
|
"AC": "Air Conditioner",
|
||||||
"AP": "Air purifier",
|
"AP": "Air Purifier",
|
||||||
"AS": "Air scanner",
|
"AS": "Air Scanner",
|
||||||
"DW": "Dish washer",
|
"DW": "Dish Washer",
|
||||||
"HO": "Hood",
|
"HO": "Hood",
|
||||||
"IH": "Hob",
|
"IH": "Induction Hob",
|
||||||
"MW": "Microwave",
|
"MW": "Microwave",
|
||||||
"OV": "Oven",
|
"OV": "Oven",
|
||||||
"REF": "Fridge",
|
"REF": "Fridge",
|
||||||
"RVC": "Robot vacuum cleaner",
|
"RVC": "Robot Vacuum Cleaner",
|
||||||
"TD": "Tumble dryer",
|
"TD": "Tumble Dryer",
|
||||||
"WC": "Wine Cellar",
|
"WC": "Wine Cellar",
|
||||||
"WD": "Washer dryer",
|
"WD": "Washer Dryer",
|
||||||
"WH": "Water Heater",
|
"WH": "Water Heater",
|
||||||
"WM": "Washing machine",
|
"WM": "Washing Machine",
|
||||||
}
|
}
|
||||||
|
|
||||||
ENTITY_CATEGORY_SORT = ["control", "config", "sensor"]
|
ENTITY_CATEGORY_SORT = ["control", "config", "sensor"]
|
||||||
@ -48,6 +49,7 @@ entities = {
|
|||||||
"sensor": SENSORS,
|
"sensor": SENSORS,
|
||||||
"switch": SWITCHES,
|
"switch": SWITCHES,
|
||||||
"climate": CLIMATES,
|
"climate": CLIMATES,
|
||||||
|
"fan": FANS,
|
||||||
}
|
}
|
||||||
|
|
||||||
result = {}
|
result = {}
|
||||||
|
345
scripts/translation_keys.py
Normal file
345
scripts/translation_keys.py
Normal file
@ -0,0 +1,345 @@
|
|||||||
|
WASHING_PR_PHASE = {
|
||||||
|
"ready": "WASHING_CMD&CTRL.PHASE_READY.TITLE",
|
||||||
|
"spin": "WASHING_CMD&CTRL.PHASE_SPIN.TITLE",
|
||||||
|
"rinse": "WASHING_CMD&CTRL.PHASE_RINSE.TITLE",
|
||||||
|
"drying": "WASHING_CMD&CTRL.PHASE_DRYING.TITLE",
|
||||||
|
"steam": "WASHING_CMD&CTRL.PHASE_STEAM.TITLE",
|
||||||
|
"weighting": "WASHING_CMD&CTRL.PHASE_WEIGHTING.TITLE",
|
||||||
|
"scheduled": "WASHING_CMD&CTRL.PHASE_SCHEDULED.TITLE",
|
||||||
|
"tumbling": "WASHING_CMD&CTRL.PHASE_TUMBLING.TITLE",
|
||||||
|
"refresh": "WASHING_CMD&CTRL.PHASE_REFRESH.TITLE",
|
||||||
|
"heating": "WASHING_CMD&CTRL.PHASE_HEATING.TITLE",
|
||||||
|
"washing": "WASHING_CMD&CTRL.PHASE_WASHING.TITLE",
|
||||||
|
}
|
||||||
|
|
||||||
|
MACH_MODE = {
|
||||||
|
"ready": "WASHING_CMD&CTRL.PHASE_READY.TITLE",
|
||||||
|
"running": "WASHING_CMD&CTRL.PHASE_RUNNING.TITLE",
|
||||||
|
"pause": "WASHING_CMD&CTRL.PHASE_PAUSE.TITLE",
|
||||||
|
"scheduled": "WASHING_CMD&CTRL.PHASE_SCHEDULED.TITLE",
|
||||||
|
"error": "WASHING_CMD&CTRL.PHASE_ERROR.TITLE",
|
||||||
|
"test": "Test",
|
||||||
|
"ending": "GLOBALS.APPLIANCE_STATUS.ENDING_PROGRAM",
|
||||||
|
}
|
||||||
|
|
||||||
|
TUMBLE_DRYER_PR_PHASE = {
|
||||||
|
"ready": "WASHING_CMD&CTRL.PHASE_READY.TITLE",
|
||||||
|
"heat_stroke": "TD_CMD&CTRL.STATUS_PHASE.PHASE_HEAT_STROKE",
|
||||||
|
"drying": "WASHING_CMD&CTRL.PHASE_DRYING.TITLE",
|
||||||
|
"cooldown": "TD_CMD&CTRL.STATUS_PHASE.PHASE_COOLDOWN",
|
||||||
|
"unknown": "unknown",
|
||||||
|
"tumbling": "WASHING_CMD&CTRL.PHASE_TUMBLING.DASHBOARD_TITLE",
|
||||||
|
}
|
||||||
|
|
||||||
|
DIRTY_LEVEL = {
|
||||||
|
"little": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OPTIONS_VALUES_DESCRIPTION.LITTLE",
|
||||||
|
"normal": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OPTIONS_VALUES_DESCRIPTION.NORMAL",
|
||||||
|
"very": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OPTIONS_VALUES_DESCRIPTION.VERY",
|
||||||
|
"unknown": "unknown",
|
||||||
|
}
|
||||||
|
|
||||||
|
STEAM_LEVEL = {
|
||||||
|
"no_steam": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OPTIONS_VALUES_DESCRIPTION.NO_STEAM",
|
||||||
|
"cotton": "WASHING_CMD&CTRL.GUIDED_WASHING_SYMBOLS_FABRICS.COTTON_TITLE",
|
||||||
|
"delicate": "WASHING_CMD&CTRL.GUIDED_WASHING_SYMBOLS_FABRICS.DELICATE_TITLE",
|
||||||
|
"synthetic": "WASHING_CMD&CTRL.GUIDED_WASHING_SYMBOLS_FABRICS.SYNTHETIC_TITLE",
|
||||||
|
}
|
||||||
|
|
||||||
|
DISHWASHER_PR_PHASE = {
|
||||||
|
"ready": "WASHING_CMD&CTRL.PHASE_READY.TITLE",
|
||||||
|
"prewash": "WASHING_CMD&CTRL.PHASE_PREWASH.TITLE",
|
||||||
|
"washing": "WASHING_CMD&CTRL.PHASE_WASHING.TITLE",
|
||||||
|
"rinse": "WASHING_CMD&CTRL.PHASE_RINSE.TITLE",
|
||||||
|
"drying": "WASHING_CMD&CTRL.PHASE_DRYING.TITLE",
|
||||||
|
"hot_rinse": "WASHING_CMD&CTRL.PHASE_HOT_RINSE.TITLE",
|
||||||
|
}
|
||||||
|
|
||||||
|
TUMBLE_DRYER_DRY_LEVEL = {
|
||||||
|
"no_dry": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_MAIN_OPTIONS.NO_DRY",
|
||||||
|
"iron_dry": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OPTIONS_VALUES_DESCRIPTION.IRON_DRY",
|
||||||
|
"no_dry_iron": "WASHING_CMD&CTRL.GUIDED_WASHING_SYMBOLS_DRYING.NO_DRY_IRON_TITLE",
|
||||||
|
"cupboard_dry": "WASHING_CMD&CTRL.GUIDED_WASHING_SYMBOLS_DRYING.CUPBOARD_DRY_TITLE",
|
||||||
|
"extra_dry": "WASHING_CMD&CTRL.GUIDED_WASHING_SYMBOLS_DRYING.EXTRA_DRY_TITLE",
|
||||||
|
"ready_to_wear": "WASHING_CMD&CTRL.GUIDED_WASHING_SYMBOLS_DRYING.READY_TO_WEAR_TITLE",
|
||||||
|
}
|
||||||
|
|
||||||
|
AC_MACH_MODE = {
|
||||||
|
"auto": "PROGRAMS.AC.IOT_AUTO",
|
||||||
|
"cool": "PROGRAMS.AC.IOT_COOL",
|
||||||
|
"dry": "PROGRAMS.AC.IOT_DRY",
|
||||||
|
"heat": "PROGRAMS.AC.IOT_HEAT",
|
||||||
|
"fan": "PROGRAMS.AC.IOT_FAN",
|
||||||
|
}
|
||||||
|
|
||||||
|
AC_FAN_MODE = {
|
||||||
|
"high": "AC.PROGRAM_CARD.WIND_SPEED_HIGH",
|
||||||
|
"mid": "AC.PROGRAM_CARD.WIND_SPEED_MID",
|
||||||
|
"low": "AC.PROGRAM_CARD.WIND_SPEED_LOW",
|
||||||
|
"auto": "AC.PROGRAM_CARD.WIND_SPEED_AUTO",
|
||||||
|
}
|
||||||
|
|
||||||
|
AC_HUMAN_SENSE = {
|
||||||
|
"touch_off": "AC.PROGRAM_DETAIL.TOUCH_OFF",
|
||||||
|
"avoid_touch": "AC.PROGRAM_DETAIL.AVOID_TOUCH",
|
||||||
|
"follow_touch": "AC.PROGRAM_DETAIL.FOLLOW_TOUCH",
|
||||||
|
"unknown": "unknown",
|
||||||
|
}
|
||||||
|
|
||||||
|
REF_ZONES = {
|
||||||
|
"fridge": "REF.ZONES.FRIDGE",
|
||||||
|
"freezer": "REF.ZONES.FREEZER",
|
||||||
|
"vtroom1": "REF.ZONES.MY_ZONE_1",
|
||||||
|
"fridge_freezer": ["REF.ZONES.FRIDGE", " & ", "REF.ZONES.FREEZER"],
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
SENSOR = {
|
||||||
|
"washing_modes": MACH_MODE,
|
||||||
|
"mach_modes_ac": AC_MACH_MODE,
|
||||||
|
"program_phases_wm": WASHING_PR_PHASE,
|
||||||
|
"program_phases_td": TUMBLE_DRYER_PR_PHASE,
|
||||||
|
"program_phases_dw": DISHWASHER_PR_PHASE,
|
||||||
|
"dry_levels": TUMBLE_DRYER_DRY_LEVEL,
|
||||||
|
}
|
||||||
|
|
||||||
|
SELECT = {
|
||||||
|
"dry_levels": TUMBLE_DRYER_DRY_LEVEL,
|
||||||
|
"eco_pilot": AC_HUMAN_SENSE,
|
||||||
|
"fan_mode": AC_FAN_MODE,
|
||||||
|
"ref_zones": REF_ZONES,
|
||||||
|
}
|
||||||
|
|
||||||
|
PROGRAMS = {
|
||||||
|
"select": {
|
||||||
|
"programs_ac": "PROGRAMS.AC",
|
||||||
|
"programs_dw": "PROGRAMS.DW",
|
||||||
|
"programs_ih": "PROGRAMS.IH",
|
||||||
|
"programs_ov": "PROGRAMS.OV",
|
||||||
|
"programs_td": "PROGRAMS.TD",
|
||||||
|
"programs_wm": "PROGRAMS.WM_WD",
|
||||||
|
"programs_ref": "PROGRAMS.REF",
|
||||||
|
},
|
||||||
|
"sensor": {
|
||||||
|
"programs_ac": "PROGRAMS.AC",
|
||||||
|
"programs_dw": "PROGRAMS.DW",
|
||||||
|
"programs_ih": "PROGRAMS.IH",
|
||||||
|
"programs_ov": "PROGRAMS.OV",
|
||||||
|
"programs_td": "PROGRAMS.TD",
|
||||||
|
"programs_wm": "PROGRAMS.WM_WD",
|
||||||
|
"programs_ref": "PROGRAMS.REF",
|
||||||
|
"programs_wc": "PROGRAMS.WC",
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
CLIMATE = {
|
||||||
|
"fridge": {
|
||||||
|
"preset_mode": {
|
||||||
|
"name": "REF_CMD&CTRL.MODE_SELECTION_DRAWER_FRIDGE.FRIDGE_MODE_TITLE",
|
||||||
|
"state": {
|
||||||
|
"auto_set": "REF_CMD&CTRL.MODALITIES.ECO",
|
||||||
|
"super_cool": "REF_CMD&CTRL.MODALITIES.SUPER_COOL",
|
||||||
|
"holiday": "REF_CMD&CTRL.MODALITIES.BACK_FROM_HOLIDAY",
|
||||||
|
"no_mode": "REF_CMD&CTRL.MODALITIES.NO_MODE_SELECTED",
|
||||||
|
},
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"freezer": {
|
||||||
|
"preset_mode": {
|
||||||
|
"name": "REF_CMD&CTRL.MODE_SELECTION_DRAWER_FREEZER.FREEZER_MODE_TITLE",
|
||||||
|
"state": {
|
||||||
|
"auto_set": "REF_CMD&CTRL.MODALITIES.ECO",
|
||||||
|
"super_freeze": "REF_CMD&CTRL.MODALITIES.SHOCK_FREEZE",
|
||||||
|
"no_mode": "REF_CMD&CTRL.MODALITIES.NO_MODE_SELECTED",
|
||||||
|
},
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"oven": {
|
||||||
|
"preset_mode": {
|
||||||
|
"name": "OV.TABS.PROGRAMS_TITLE",
|
||||||
|
"state": "PROGRAMS.OV",
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"air_conditioner": {
|
||||||
|
"preset_mode": {
|
||||||
|
"name": "OV.TABS.PROGRAMS_TITLE",
|
||||||
|
"state": "PROGRAMS.AC",
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"wine": {
|
||||||
|
"preset_mode": {
|
||||||
|
"name": "WC.NAME",
|
||||||
|
"state": "PROGRAMS.WC",
|
||||||
|
}
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
NAMES = {
|
||||||
|
"switch": {
|
||||||
|
"anti_crease": "HDRY_CMD&CTRL.PROGRAM_CYCLE_DETAIL.ANTICREASE_TITLE",
|
||||||
|
"add_dish": "DW.ADD_DISH",
|
||||||
|
"eco_express": "DW_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OTHER_OPTIONS.ECO",
|
||||||
|
"extra_dry": "DW_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OTHER_OPTIONS.EXTRA_DRY",
|
||||||
|
"half_load": "DW_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OTHER_OPTIONS.HALF_LOAD",
|
||||||
|
"open_door": "DW_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OTHER_OPTIONS.OPEN_DOOR",
|
||||||
|
"three_in_one": "DW_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OTHER_OPTIONS.THREE_IN_ONE",
|
||||||
|
"preheat": "OV.PROGRAM_DETAIL.PREHEAT",
|
||||||
|
"dish_washer": "GLOBALS.APPLIANCES_NAME.DW",
|
||||||
|
"tumble_dryer": "GLOBALS.APPLIANCES_NAME.TD",
|
||||||
|
"washing_machine": "GLOBALS.APPLIANCES_NAME.WM",
|
||||||
|
"washer_dryer": "GLOBALS.APPLIANCES_NAME.WD",
|
||||||
|
"oven": "GLOBALS.APPLIANCES_NAME.OV",
|
||||||
|
"prewash": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OTHER_OPTIONS.PREWASH",
|
||||||
|
"pause": "GENERAL.PAUSE_PROGRAM",
|
||||||
|
"keep_fresh": "GLOBALS.APPLIANCE_STATUS.TUMBLING",
|
||||||
|
"delay_time": "HINTS.TIPS_TIME_ENERGY_SAVING.TIPS_USE_AT_NIGHT_TITLE",
|
||||||
|
"rapid_mode": "AC.PROGRAM_CARD.RAPID",
|
||||||
|
"eco_mode": "AC.PROGRAM_CARD.ECO_MODE",
|
||||||
|
"10_degree_heating": "PROGRAMS.AC.IOT_10_HEATING",
|
||||||
|
"self_clean": "PROGRAMS.AC.IOT_SELF_CLEAN",
|
||||||
|
"self_clean_56": "PROGRAMS.AC.IOT_SELF_CLEAN_56",
|
||||||
|
"silent_mode": "AC.PROGRAM_DETAIL.SILENT_MODE",
|
||||||
|
"mute_mode": "AC.PROGRAM_DETAIL.MUTE_MODE",
|
||||||
|
"extra_rinse_1": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OTHER_OPTIONS.EXTRARINSE1",
|
||||||
|
"extra_rinse_2": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OTHER_OPTIONS.EXTRARINSE2",
|
||||||
|
"extra_rinse_3": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OTHER_OPTIONS.EXTRARINSE3",
|
||||||
|
"acqua_plus": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OTHER_OPTIONS.ACQUAPLUS",
|
||||||
|
"auto_dose_softener": [
|
||||||
|
"WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OTHER_OPTIONS.AUTODOSE",
|
||||||
|
"WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OTHER_OPTIONS.SOFTENER",
|
||||||
|
],
|
||||||
|
"auto_dose_detergent": [
|
||||||
|
"WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OTHER_OPTIONS.AUTODOSE",
|
||||||
|
"WASHING_CMD&CTRL.DASHBOARD_MENU_MORE_SETTINGS_WATER.DETERGENT",
|
||||||
|
],
|
||||||
|
"good_night": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OTHER_OPTIONS.GOODNIGHT",
|
||||||
|
"auto_set": "REF_CMD&CTRL.MODALITIES.ECO",
|
||||||
|
"super_cool": "REF_CMD&CTRL.MODALITIES.SUPER_COOL",
|
||||||
|
"super_freeze": "REF_CMD&CTRL.MODALITIES.SUPER_FREEZE",
|
||||||
|
"refrigerator": "REF.NAME",
|
||||||
|
},
|
||||||
|
"binary_sensor": {
|
||||||
|
"door_lock": "WASHING_CMD&CTRL.CHECK_UP_RESULTS.DOOR_LOCK",
|
||||||
|
"extra_rinse_1": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OTHER_OPTIONS.EXTRARINSE1",
|
||||||
|
"extra_rinse_2": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OTHER_OPTIONS.EXTRARINSE2",
|
||||||
|
"extra_rinse_3": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OTHER_OPTIONS.EXTRARINSE3",
|
||||||
|
"good_night": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OTHER_OPTIONS.GOODNIGHT",
|
||||||
|
"anti_crease": "HDRY_CMD&CTRL.PROGRAM_CYCLE_DETAIL.ANTICREASE_TITLE",
|
||||||
|
"acqua_plus": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OTHER_OPTIONS.ACQUAPLUS",
|
||||||
|
"spin_speed": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_MAIN_OPTIONS.SPINSPEED",
|
||||||
|
"still_hot": "IH.COILS_STATUS.STILL_HOT",
|
||||||
|
"pan_status": "IH.COILS_STATUS.PAN",
|
||||||
|
"remote_control": "OV.SUPPORT.REMOTE_CONTROL",
|
||||||
|
"rinse_aid": "DW_CMD&CTRL.MAINTENANCE.CONSUMABLE_LEVELS_ICON_RINSE_AID",
|
||||||
|
"salt_level": "DW_CMD&CTRL.MAINTENANCE.CONSUMABLE_LEVELS_ICON_SALT",
|
||||||
|
"door_open": "GLOBALS.APPLIANCE_STATUS.DOOR_OPEN",
|
||||||
|
"connection": "ENROLLMENT_COMMON.HEADER_NAME.STEP_APPLIANCE_CONNECTION",
|
||||||
|
"child_lock": "AP.FOOTER_MENU_MORE.SECURITY_LOCK_TITLE",
|
||||||
|
"on": "GLOBALS.GENERAL.ON",
|
||||||
|
"prewash": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OTHER_OPTIONS.PREWASH",
|
||||||
|
"buzzer": "DW_CMD&CTRL.SETTINGS.END_CYCLE_BUZZER",
|
||||||
|
"holiday_mode": "REF.DASHBOARD_MENU_MORE_NOTIFICATIONS.HOLIDAY_MODE",
|
||||||
|
"auto_set": "REF_CMD&CTRL.MODALITIES.ECO",
|
||||||
|
"super_cool": "REF_CMD&CTRL.MODALITIES.SUPER_COOL",
|
||||||
|
"super_freeze": "REF_CMD&CTRL.MODALITIES.SUPER_FREEZE",
|
||||||
|
"freezer_door": ["GLOBALS.APPLIANCE_STATUS.DOOR_OPEN", "REF.ZONES.FREEZER"],
|
||||||
|
"fridge_door": ["GLOBALS.APPLIANCE_STATUS.DOOR_OPEN", "REF.ZONES.FRIDGE"],
|
||||||
|
"filter_replacement": "AP.MAINTENANCE.FILTER_REPLACEMENT",
|
||||||
|
},
|
||||||
|
"button": {
|
||||||
|
"induction_hob": "GLOBALS.APPLIANCES_NAME.IH",
|
||||||
|
"start_program": ["WC.SET_PROGRAM.PROGRAM", "GLOBALS.GENERAL.START_ON"],
|
||||||
|
"stop_program": ["WC.SET_PROGRAM.PROGRAM", "GLOBALS.GENERAL.STOP"],
|
||||||
|
},
|
||||||
|
"select": {
|
||||||
|
"dry_levels": "WASHING_CMD&CTRL.DRAWER_CYCLE_DRYING.TAB_LEVEL",
|
||||||
|
"dry_time": "WASHING_CMD&CTRL.DRAWER_CYCLE_DRYING.TAB_TIME",
|
||||||
|
"spin_speed": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_MAIN_OPTIONS.SPINSPEED",
|
||||||
|
"temperature": "IH.COMMON.TEMPERATURE",
|
||||||
|
"programs_dw": "WC.SET_PROGRAM.PROGRAM",
|
||||||
|
"programs_ih": "WC.SET_PROGRAM.PROGRAM",
|
||||||
|
"programs_ov": "WC.SET_PROGRAM.PROGRAM",
|
||||||
|
"programs_td": "WC.SET_PROGRAM.PROGRAM",
|
||||||
|
"programs_wm": "WC.SET_PROGRAM.PROGRAM",
|
||||||
|
"programs_ac": "WC.SET_PROGRAM.PROGRAM",
|
||||||
|
"programs_ref": "WC.SET_PROGRAM.PROGRAM",
|
||||||
|
"eco_pilot": "AC.PROGRAM_DETAIL.ECO_PILOT",
|
||||||
|
"remaining_time": "ENROLLMENT_COMMON.GENERAL.REMAINING_TIME",
|
||||||
|
"ref_zones": "IH.COMMON.COIL",
|
||||||
|
},
|
||||||
|
"sensor": {
|
||||||
|
"dry_levels": "WASHING_CMD&CTRL.DRAWER_CYCLE_DRYING.TAB_LEVEL",
|
||||||
|
"dry_time": "WASHING_CMD&CTRL.DRAWER_CYCLE_DRYING.TAB_TIME",
|
||||||
|
"power": "OV.RECIPE_DETAIL.POWER_LEVEL",
|
||||||
|
"remaining_time": "ENROLLMENT_COMMON.GENERAL.REMAINING_TIME",
|
||||||
|
"temperature": "IH.COMMON.TEMPERATURE",
|
||||||
|
"water_efficiency": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_RESULT.WATER_EFFICIENCY",
|
||||||
|
"water_saving": "STATISTICS.SMART_AI_CYCLE.WATER_SAVING",
|
||||||
|
"duration": "WASHING_CMD&CTRL.DRAWER_PROGRAM_FILTERS.DURATION",
|
||||||
|
"target_temperature": "IH.COOKING_DETAIL.TEMPERATURE_TARGETING",
|
||||||
|
"spin_speed": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_MAIN_OPTIONS.SPINSPEED",
|
||||||
|
"steam_leve": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_MAIN_OPTIONS.STEAM_LEVEL",
|
||||||
|
"dirt_level": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_MAIN_OPTIONS.DIRTY_LEVEL",
|
||||||
|
"program_phases_wm": "WASHING_CMD&CTRL.STATISTICS_GRAPHIC_INSTANT_CONSUMPTION.PHASE",
|
||||||
|
"program_phases_td": "WASHING_CMD&CTRL.STATISTICS_GRAPHIC_INSTANT_CONSUMPTION.PHASE",
|
||||||
|
"program_phases_dw": "WASHING_CMD&CTRL.STATISTICS_GRAPHIC_INSTANT_CONSUMPTION.PHASE",
|
||||||
|
"delay_time": "HINTS.TIPS_TIME_ENERGY_SAVING.TIPS_USE_AT_NIGHT_TITLE",
|
||||||
|
"suggested_load": "WASHING_CMD&CTRL.DRAWER_PROGRAM_FILTERS.LOAD_CAPACITY",
|
||||||
|
"energy_label": "WASHING_CMD&CTRL.DRAWER_PROGRAM_FILTERS.ENERGY_EFFICIENCY",
|
||||||
|
"det_dust": "HUBS.WIDGET.STAINS_WIDGET.STAINS.SUGGESTED_DET_DUST",
|
||||||
|
"det_liquid": "HUBS.WIDGET.STAINS_WIDGET.STAINS.SUGGESTED_DET_LIQUID",
|
||||||
|
"errors": "ROBOT_CMD&CTRL.PHASE_ERROR.TITLE",
|
||||||
|
"programs": "OV.TABS.CURRENT_PROGRAM",
|
||||||
|
"room_temperature": "REF.SMART_DRINK_ASSISTANT.AMBIENT",
|
||||||
|
"humidity": "AP.TITLES.HUMIDITY",
|
||||||
|
"cycles_total": [
|
||||||
|
"WASHING_CMD&CTRL.GENERAL.CYCLES",
|
||||||
|
"WC.VIRTUAL_WINE_STATS_COUNTRY.TOTAL",
|
||||||
|
],
|
||||||
|
"energy_total": [
|
||||||
|
"MISE.ENERGY_CONSUMPTION.TITLE",
|
||||||
|
"WC.VIRTUAL_WINE_STATS_COUNTRY.TOTAL",
|
||||||
|
],
|
||||||
|
"water_total": [
|
||||||
|
"WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_RESULT.WATER_EFFICIENCY",
|
||||||
|
"WC.VIRTUAL_WINE_STATS_COUNTRY.TOTAL",
|
||||||
|
],
|
||||||
|
"energy_current": [
|
||||||
|
"MISE.ENERGY_CONSUMPTION.TITLE",
|
||||||
|
"CUBE90_GLOBAL.GENERAL.CURRENT",
|
||||||
|
],
|
||||||
|
"water_current": [
|
||||||
|
"WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_RESULT.WATER_EFFICIENCY",
|
||||||
|
"CUBE90_GLOBAL.GENERAL.CURRENT",
|
||||||
|
],
|
||||||
|
"freezer_temp": "REF_CMD&CTRL.TEMPERATURE_DRAWER_FREEZER.FREEZER_TEMPERATURE_TITLE",
|
||||||
|
"fridge_temp": "REF_CMD&CTRL.TEMPERATURE_DRAWER_FRIDGE.FRIDGE_TEMPERATURE_TITLE",
|
||||||
|
"programs_dw": "WC.SET_PROGRAM.PROGRAM",
|
||||||
|
"programs_ih": "WC.SET_PROGRAM.PROGRAM",
|
||||||
|
"programs_ov": "WC.SET_PROGRAM.PROGRAM",
|
||||||
|
"programs_td": "WC.SET_PROGRAM.PROGRAM",
|
||||||
|
"programs_wm": "WC.SET_PROGRAM.PROGRAM",
|
||||||
|
"programs_ac": "WC.SET_PROGRAM.PROGRAM",
|
||||||
|
"programs_ref": "WC.SET_PROGRAM.PROGRAM",
|
||||||
|
},
|
||||||
|
"number": {
|
||||||
|
"power_management": "HINTS.COOKING_WITH_INDUCTION.POWER_MANAGEMENT",
|
||||||
|
"temperature": "IH.COMMON.TEMPERATURE",
|
||||||
|
"delay_time": "HINTS.TIPS_TIME_ENERGY_SAVING.TIPS_USE_AT_NIGHT_TITLE",
|
||||||
|
"water_hard": "WASHING_CMD&CTRL.DASHBOARD_MENU_MORE_SETTINGS_WATER.TITLE",
|
||||||
|
"program_duration": "OV.PROGRAM_DETAIL.PROGRAM_DURATION",
|
||||||
|
"target_temperature": "IH.COOKING_DETAIL.TEMPERATURE_TARGETING",
|
||||||
|
"rinse_iterations": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL.DRAWER_HEADER_RINSE",
|
||||||
|
"wash_time": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL.WASHING_TIME",
|
||||||
|
"dry_time": "WASHING_CMD&CTRL.DRAWER_CYCLE_DRYING.TAB_TIME",
|
||||||
|
"steam_level": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_MAIN_OPTIONS.STEAM_LEVEL",
|
||||||
|
"freezer_temp_sel": ["OV.COMMON.GOAL_TEMPERATURE", "REF.ZONES.FREEZER"],
|
||||||
|
"fridge_temp_sel": ["OV.COMMON.GOAL_TEMPERATURE", "REF.ZONES.FRIDGE"],
|
||||||
|
},
|
||||||
|
"climate": {
|
||||||
|
"air_conditioner": "GLOBALS.APPLIANCES_NAME.AC",
|
||||||
|
"fridge": "REF.ZONES.FRIDGE",
|
||||||
|
"freezer": "REF.ZONES.FREEZER",
|
||||||
|
"oven": "GLOBALS.APPLIANCES_NAME.OV",
|
||||||
|
},
|
||||||
|
"fan": {"air_extraction": "HO.DASHBOARD.AIR_EXTRACTION_TITLE"},
|
||||||
|
}
|
Reference in New Issue
Block a user