mirror of
https://github.com/Andre0512/hon.git
synced 2026-06-20 22:41:16 +02:00
Compare commits
21 Commits
v0.8
...
v0.9.0-beta.5
| Author | SHA1 | Date | |
|---|---|---|---|
| a25510184e | |||
| e5e351272b | |||
| 4b1f500f90 | |||
| 0d43eeff3d | |||
| 2c3217ff95 | |||
| fbd1bdf5ba | |||
| 78727e89cd | |||
| a181359faa | |||
| d83179a9fa | |||
| 11a3d39f2c | |||
| ae985cb0d9 | |||
| 1ea9153c2e | |||
| c1e6f9547c | |||
| b1448ddfd8 | |||
| dfa5735bc2 | |||
| 52c3a861de | |||
| d3503af158 | |||
| d81b1ae712 | |||
| eb5ba43707 | |||
| efcac321b8 | |||
| 79b43b8695 |
@@ -0,0 +1,47 @@
|
|||||||
|
---
|
||||||
|
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)
|
||||||
|
|
||||||
|
**Data Archive**
|
||||||
|
For further analysis, please add your appliance data archive here.
|
||||||
|
Navigate to `Settings` -> `Device & Services` -> `Haier hOn` -> _your device_ and press the _Create Data Archive_ button.
|
||||||
|
Then open notifications to download the data zip archive.
|
||||||
|
To attach the file:
|
||||||
|
* GitHub Web: Use the "Attach files by dragging & dropping, selecting or pasting them." function
|
||||||
|
* GitHub Mobile: Upload the zip archive as image
|
||||||
@@ -0,0 +1,34 @@
|
|||||||
|
---
|
||||||
|
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.
|
||||||
|
|
||||||
|
**Data Archive**
|
||||||
|
For further analysis, please add your appliance data archive here.
|
||||||
|
Navigate to `Settings` -> `Device & Services` -> `Haier hOn` -> _your device_ and press the _Create Data Archive_ button.
|
||||||
|
Then open notifications to download the data zip archive.
|
||||||
|
To attach the file:
|
||||||
|
* GitHub Web: Use the "Attach files by dragging & dropping, selecting or pasting them." function
|
||||||
|
* GitHub Mobile: Upload the zip archive as image
|
||||||
@@ -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)
|
||||||
@@ -14,8 +14,10 @@ Home Assistant integration for [Haier's mobile app hOn](https://hon-smarthome.co
|
|||||||
- [Dish Washer](https://github.com/Andre0512/hon#dish-washer)
|
- [Dish Washer](https://github.com/Andre0512/hon#dish-washer)
|
||||||
- [Air conditioner](https://github.com/Andre0512/hon#air-conditioner)
|
- [Air conditioner](https://github.com/Andre0512/hon#air-conditioner)
|
||||||
- [Fridge](https://github.com/Andre0512/hon#fridge)
|
- [Fridge](https://github.com/Andre0512/hon#fridge)
|
||||||
- [Hob](https://github.com/Andre0512/hon#hob) [BETA]
|
- [Induction Hob](https://github.com/Andre0512/hon#induction-hob) [BETA]
|
||||||
- [Hood](https://github.com/Andre0512/hon#hood) [BETA]
|
- [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,25 @@ _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 | | |
|
||||||
|
|
||||||
|
| Please add your appliances data to our [hon-test-data collection](https://github.com/Andre0512/hon-test-data). <br/>This helps us to develop new features and not to break compatibility in newer versions. |
|
||||||
|
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|
||||||
|
|
||||||
## 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,54 +80,13 @@ 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 AS20HPL1HRA
|
|
||||||
- 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
|
||||||
If you want to make a request for adding new appliances or additional attributes and don't want to use the command line, here is how you can read out your device data.
|
If you want to make a request for adding new appliances or additional attributes and don't want to use the command line, here is how you can read out your device data.
|
||||||
For every device exists a hidden button which can be used to log all infos of your appliance.
|
For every device exists a button under diagnostics which can be used to log all info of your appliance.
|
||||||
1. Enable the "Show Device Info" button
|
1. Press the button to create a notification
|
||||||
_This button can be found in the diagnostic section of your device or in the entity overview if "show disabled entities" is enabled._
|
2. Open home assistant notifications and copy the message (Crtl+A, Ctrl+C)
|
||||||
2. Press the button to create a notification
|
|
||||||
3. Open home assistant notifications and copy the message (Crtl+A, Ctrl+C)
|
|
||||||
### Add appliances or additional attributes
|
### Add appliances or additional attributes
|
||||||
1. Install [pyhOn](https://github.com/Andre0512/pyhOn)
|
1. Install [pyhOn](https://github.com/Andre0512/pyhOn)
|
||||||
```commandline
|
```commandline
|
||||||
@@ -159,7 +139,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 |
|
||||||
| --- | --- | --- | --- |
|
| --- | --- | --- | --- |
|
||||||
@@ -169,12 +149,12 @@ For every device exists a hidden button which can be used to log all infos of yo
|
|||||||
| Eco Mode | | `switch` | `ecoMode` |
|
| Eco Mode | | `switch` | `ecoMode` |
|
||||||
| Eco Pilot | `run` | `select` | `settings.humanSensingStatus` |
|
| Eco Pilot | `run` | `select` | `settings.humanSensingStatus` |
|
||||||
| Health Mode | `medication-outline` | `switch` | `healthMode` |
|
| Health Mode | `medication-outline` | `switch` | `healthMode` |
|
||||||
| Mute | `volume-off` | `switch` | `muteStatus` |
|
| Night Mode | `bed` | `switch` | `silentSleepStatus` |
|
||||||
| Rapid Mode | `run-fast` | `switch` | `rapidMode` |
|
| Rapid Mode | `run-fast` | `switch` | `rapidMode` |
|
||||||
| Screen Display | `monitor-small` | `switch` | `screenDisplayStatus` |
|
| Screen Display | `monitor-small` | `switch` | `screenDisplayStatus` |
|
||||||
| Self Cleaning | `air-filter` | `switch` | `selfCleaningStatus` |
|
| Self Cleaning | `air-filter` | `switch` | `selfCleaningStatus` |
|
||||||
| Self Cleaning 56 | `air-filter` | `switch` | `selfCleaning56Status` |
|
| Self Cleaning 56 | `air-filter` | `switch` | `selfCleaning56Status` |
|
||||||
| Silent Sleep | `bed` | `switch` | `silentSleepStatus` |
|
| Silent Mode | `volume-off` | `switch` | `muteStatus` |
|
||||||
| Target Temperature | `thermometer` | `number` | `settings.tempSel` |
|
| Target Temperature | `thermometer` | `number` | `settings.tempSel` |
|
||||||
#### Sensors
|
#### Sensors
|
||||||
| Name | Icon | Entity | Key |
|
| Name | Icon | Entity | Key |
|
||||||
@@ -187,12 +167,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 |
|
||||||
| --- | --- | --- | --- |
|
| --- | --- | --- | --- |
|
||||||
@@ -237,11 +247,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 |
|
||||||
| --- | --- | --- | --- |
|
| --- | --- | --- | --- |
|
||||||
@@ -252,14 +258,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 |
|
||||||
| --- | --- | --- | --- |
|
| --- | --- | --- | --- |
|
||||||
@@ -343,7 +349,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 |
|
||||||
| --- | --- | --- | --- |
|
| --- | --- | --- | --- |
|
||||||
@@ -381,7 +387,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 |
|
||||||
| --- | --- | --- | --- |
|
| --- | --- | --- | --- |
|
||||||
@@ -456,7 +483,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 |
|
||||||
| --- | --- | --- | --- |
|
| --- | --- | --- | --- |
|
||||||
|
|||||||
@@ -1,18 +1,17 @@
|
|||||||
import logging
|
import logging
|
||||||
|
from pathlib import Path
|
||||||
|
|
||||||
import voluptuous as vol
|
import voluptuous as vol
|
||||||
from pyhon import Hon
|
|
||||||
|
|
||||||
from homeassistant.config_entries import ConfigEntry
|
from homeassistant.config_entries import ConfigEntry
|
||||||
from homeassistant.const import CONF_EMAIL, CONF_PASSWORD
|
from homeassistant.const import CONF_EMAIL, CONF_PASSWORD
|
||||||
from homeassistant.helpers import config_validation as cv, aiohttp_client
|
from homeassistant.helpers import config_validation as cv, aiohttp_client
|
||||||
from homeassistant.helpers.typing import HomeAssistantType
|
from homeassistant.helpers.typing import HomeAssistantType
|
||||||
|
from pyhon import Hon
|
||||||
|
|
||||||
from .const import DOMAIN, PLATFORMS
|
from .const import DOMAIN, PLATFORMS
|
||||||
|
|
||||||
_LOGGER = logging.getLogger(__name__)
|
_LOGGER = logging.getLogger(__name__)
|
||||||
|
|
||||||
|
|
||||||
HON_SCHEMA = vol.Schema(
|
HON_SCHEMA = vol.Schema(
|
||||||
{
|
{
|
||||||
vol.Required(CONF_EMAIL): cv.string,
|
vol.Required(CONF_EMAIL): cv.string,
|
||||||
@@ -29,7 +28,10 @@ CONFIG_SCHEMA = vol.Schema(
|
|||||||
async def async_setup_entry(hass: HomeAssistantType, entry: ConfigEntry):
|
async def async_setup_entry(hass: HomeAssistantType, entry: ConfigEntry):
|
||||||
session = aiohttp_client.async_get_clientsession(hass)
|
session = aiohttp_client.async_get_clientsession(hass)
|
||||||
hon = await Hon(
|
hon = await Hon(
|
||||||
entry.data["email"], entry.data["password"], session=session
|
entry.data["email"],
|
||||||
|
entry.data["password"],
|
||||||
|
session=session,
|
||||||
|
test_data_path=Path(hass.config.config_dir),
|
||||||
).create()
|
).create()
|
||||||
hass.data.setdefault(DOMAIN, {})
|
hass.data.setdefault(DOMAIN, {})
|
||||||
hass.data[DOMAIN][entry.unique_id] = hon
|
hass.data[DOMAIN][entry.unique_id] = hon
|
||||||
|
|||||||
@@ -17,7 +17,7 @@ _LOGGER = logging.getLogger(__name__)
|
|||||||
|
|
||||||
@dataclass
|
@dataclass
|
||||||
class HonBinarySensorEntityDescriptionMixin:
|
class HonBinarySensorEntityDescriptionMixin:
|
||||||
on_value: str = ""
|
on_value: str | float = ""
|
||||||
|
|
||||||
|
|
||||||
@dataclass
|
@dataclass
|
||||||
@@ -41,14 +41,14 @@ BINARY_SENSORS: dict[str, tuple[HonBinarySensorEntityDescription, ...]] = {
|
|||||||
key="doorLockStatus",
|
key="doorLockStatus",
|
||||||
name="Door Lock",
|
name="Door Lock",
|
||||||
device_class=BinarySensorDeviceClass.LOCK,
|
device_class=BinarySensorDeviceClass.LOCK,
|
||||||
on_value="0",
|
on_value=0,
|
||||||
translation_key="door_lock",
|
translation_key="door_lock",
|
||||||
),
|
),
|
||||||
HonBinarySensorEntityDescription(
|
HonBinarySensorEntityDescription(
|
||||||
key="doorStatus",
|
key="doorStatus",
|
||||||
name="Door",
|
name="Door",
|
||||||
device_class=BinarySensorDeviceClass.DOOR,
|
device_class=BinarySensorDeviceClass.DOOR,
|
||||||
on_value="1",
|
on_value=1,
|
||||||
translation_key="door_open",
|
translation_key="door_open",
|
||||||
),
|
),
|
||||||
HonBinarySensorEntityDescription(
|
HonBinarySensorEntityDescription(
|
||||||
@@ -82,7 +82,7 @@ BINARY_SENSORS: dict[str, tuple[HonBinarySensorEntityDescription, ...]] = {
|
|||||||
key="doorStatus",
|
key="doorStatus",
|
||||||
name="Door",
|
name="Door",
|
||||||
device_class=BinarySensorDeviceClass.DOOR,
|
device_class=BinarySensorDeviceClass.DOOR,
|
||||||
on_value="1",
|
on_value=1,
|
||||||
translation_key="door_open",
|
translation_key="door_open",
|
||||||
),
|
),
|
||||||
HonBinarySensorEntityDescription(
|
HonBinarySensorEntityDescription(
|
||||||
@@ -102,7 +102,7 @@ BINARY_SENSORS: dict[str, tuple[HonBinarySensorEntityDescription, ...]] = {
|
|||||||
key="attributes.parameters.onOffStatus",
|
key="attributes.parameters.onOffStatus",
|
||||||
name="On",
|
name="On",
|
||||||
device_class=BinarySensorDeviceClass.RUNNING,
|
device_class=BinarySensorDeviceClass.RUNNING,
|
||||||
on_value="1",
|
on_value=1,
|
||||||
icon="mdi:power-cycle",
|
icon="mdi:power-cycle",
|
||||||
translation_key="on",
|
translation_key="on",
|
||||||
),
|
),
|
||||||
@@ -120,7 +120,7 @@ BINARY_SENSORS: dict[str, tuple[HonBinarySensorEntityDescription, ...]] = {
|
|||||||
key="attributes.parameters.onOffStatus",
|
key="attributes.parameters.onOffStatus",
|
||||||
name="On",
|
name="On",
|
||||||
device_class=BinarySensorDeviceClass.RUNNING,
|
device_class=BinarySensorDeviceClass.RUNNING,
|
||||||
on_value="1",
|
on_value=1,
|
||||||
icon="mdi:power-cycle",
|
icon="mdi:power-cycle",
|
||||||
translation_key="on",
|
translation_key="on",
|
||||||
),
|
),
|
||||||
@@ -128,13 +128,13 @@ BINARY_SENSORS: dict[str, tuple[HonBinarySensorEntityDescription, ...]] = {
|
|||||||
key="hotStatus",
|
key="hotStatus",
|
||||||
name="Hot Status",
|
name="Hot Status",
|
||||||
device_class=BinarySensorDeviceClass.HEAT,
|
device_class=BinarySensorDeviceClass.HEAT,
|
||||||
on_value="1",
|
on_value=1,
|
||||||
translation_key="still_hot",
|
translation_key="still_hot",
|
||||||
),
|
),
|
||||||
HonBinarySensorEntityDescription(
|
HonBinarySensorEntityDescription(
|
||||||
key="panStatus",
|
key="panStatus",
|
||||||
name="Pan Status",
|
name="Pan Status",
|
||||||
on_value="1",
|
on_value=1,
|
||||||
icon="mdi:pot-mix",
|
icon="mdi:pot-mix",
|
||||||
translation_key="pan_status",
|
translation_key="pan_status",
|
||||||
),
|
),
|
||||||
@@ -142,7 +142,7 @@ BINARY_SENSORS: dict[str, tuple[HonBinarySensorEntityDescription, ...]] = {
|
|||||||
key="hobLockStatus",
|
key="hobLockStatus",
|
||||||
name="Hob Lock",
|
name="Hob Lock",
|
||||||
device_class=BinarySensorDeviceClass.LOCK,
|
device_class=BinarySensorDeviceClass.LOCK,
|
||||||
on_value="0",
|
on_value=0,
|
||||||
translation_key="child_lock",
|
translation_key="child_lock",
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
@@ -151,7 +151,7 @@ BINARY_SENSORS: dict[str, tuple[HonBinarySensorEntityDescription, ...]] = {
|
|||||||
key="saltStatus",
|
key="saltStatus",
|
||||||
name="Salt",
|
name="Salt",
|
||||||
device_class=BinarySensorDeviceClass.PROBLEM,
|
device_class=BinarySensorDeviceClass.PROBLEM,
|
||||||
on_value="1",
|
on_value=1,
|
||||||
icon="mdi:shaker-outline",
|
icon="mdi:shaker-outline",
|
||||||
translation_key="salt_level",
|
translation_key="salt_level",
|
||||||
),
|
),
|
||||||
@@ -159,7 +159,7 @@ BINARY_SENSORS: dict[str, tuple[HonBinarySensorEntityDescription, ...]] = {
|
|||||||
key="rinseAidStatus",
|
key="rinseAidStatus",
|
||||||
name="Rinse Aid",
|
name="Rinse Aid",
|
||||||
device_class=BinarySensorDeviceClass.PROBLEM,
|
device_class=BinarySensorDeviceClass.PROBLEM,
|
||||||
on_value="1",
|
on_value=1,
|
||||||
icon="mdi:spray-bottle",
|
icon="mdi:spray-bottle",
|
||||||
translation_key="rinse_aid",
|
translation_key="rinse_aid",
|
||||||
),
|
),
|
||||||
@@ -174,7 +174,7 @@ BINARY_SENSORS: dict[str, tuple[HonBinarySensorEntityDescription, ...]] = {
|
|||||||
key="doorStatus",
|
key="doorStatus",
|
||||||
name="Door",
|
name="Door",
|
||||||
device_class=BinarySensorDeviceClass.DOOR,
|
device_class=BinarySensorDeviceClass.DOOR,
|
||||||
on_value="1",
|
on_value=1,
|
||||||
translation_key="door_open",
|
translation_key="door_open",
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
@@ -183,13 +183,13 @@ BINARY_SENSORS: dict[str, tuple[HonBinarySensorEntityDescription, ...]] = {
|
|||||||
key="filterChangeStatusLocal",
|
key="filterChangeStatusLocal",
|
||||||
name="Filter Replacement",
|
name="Filter Replacement",
|
||||||
device_class=BinarySensorDeviceClass.PROBLEM,
|
device_class=BinarySensorDeviceClass.PROBLEM,
|
||||||
on_value="1",
|
on_value=1,
|
||||||
translation_key="filter_replacement",
|
translation_key="filter_replacement",
|
||||||
),
|
),
|
||||||
HonBinarySensorEntityDescription(
|
HonBinarySensorEntityDescription(
|
||||||
key="ch2oCleaningStatus",
|
key="ch2oCleaningStatus",
|
||||||
name="Ch2O Cleaning",
|
name="Ch2O Cleaning",
|
||||||
on_value="1",
|
on_value=1,
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
"REF": (
|
"REF": (
|
||||||
@@ -198,7 +198,7 @@ BINARY_SENSORS: dict[str, tuple[HonBinarySensorEntityDescription, ...]] = {
|
|||||||
name="Super Cool",
|
name="Super Cool",
|
||||||
icon="mdi:snowflake",
|
icon="mdi:snowflake",
|
||||||
device_class=BinarySensorDeviceClass.RUNNING,
|
device_class=BinarySensorDeviceClass.RUNNING,
|
||||||
on_value="1",
|
on_value=1,
|
||||||
translation_key="super_cool",
|
translation_key="super_cool",
|
||||||
),
|
),
|
||||||
HonBinarySensorEntityDescription(
|
HonBinarySensorEntityDescription(
|
||||||
@@ -206,7 +206,7 @@ BINARY_SENSORS: dict[str, tuple[HonBinarySensorEntityDescription, ...]] = {
|
|||||||
name="Super Freeze",
|
name="Super Freeze",
|
||||||
icon="mdi:snowflake-variant",
|
icon="mdi:snowflake-variant",
|
||||||
device_class=BinarySensorDeviceClass.RUNNING,
|
device_class=BinarySensorDeviceClass.RUNNING,
|
||||||
on_value="1",
|
on_value=1,
|
||||||
translation_key="super_freeze",
|
translation_key="super_freeze",
|
||||||
),
|
),
|
||||||
HonBinarySensorEntityDescription(
|
HonBinarySensorEntityDescription(
|
||||||
@@ -214,7 +214,7 @@ BINARY_SENSORS: dict[str, tuple[HonBinarySensorEntityDescription, ...]] = {
|
|||||||
name="Door Status Freezer",
|
name="Door Status Freezer",
|
||||||
device_class=BinarySensorDeviceClass.DOOR,
|
device_class=BinarySensorDeviceClass.DOOR,
|
||||||
icon="mdi:fridge-top",
|
icon="mdi:fridge-top",
|
||||||
on_value="1",
|
on_value=1,
|
||||||
translation_key="freezer_door",
|
translation_key="freezer_door",
|
||||||
),
|
),
|
||||||
HonBinarySensorEntityDescription(
|
HonBinarySensorEntityDescription(
|
||||||
@@ -222,7 +222,7 @@ BINARY_SENSORS: dict[str, tuple[HonBinarySensorEntityDescription, ...]] = {
|
|||||||
name="Door Status Fridge",
|
name="Door Status Fridge",
|
||||||
icon="mdi:fridge-bottom",
|
icon="mdi:fridge-bottom",
|
||||||
device_class=BinarySensorDeviceClass.DOOR,
|
device_class=BinarySensorDeviceClass.DOOR,
|
||||||
on_value="1",
|
on_value=1,
|
||||||
translation_key="fridge_door",
|
translation_key="fridge_door",
|
||||||
),
|
),
|
||||||
HonBinarySensorEntityDescription(
|
HonBinarySensorEntityDescription(
|
||||||
@@ -230,7 +230,7 @@ BINARY_SENSORS: dict[str, tuple[HonBinarySensorEntityDescription, ...]] = {
|
|||||||
name="Auto-Set Mode",
|
name="Auto-Set Mode",
|
||||||
icon="mdi:thermometer-auto",
|
icon="mdi:thermometer-auto",
|
||||||
device_class=BinarySensorDeviceClass.RUNNING,
|
device_class=BinarySensorDeviceClass.RUNNING,
|
||||||
on_value="1",
|
on_value=1,
|
||||||
translation_key="auto_set",
|
translation_key="auto_set",
|
||||||
),
|
),
|
||||||
HonBinarySensorEntityDescription(
|
HonBinarySensorEntityDescription(
|
||||||
@@ -238,13 +238,22 @@ BINARY_SENSORS: dict[str, tuple[HonBinarySensorEntityDescription, ...]] = {
|
|||||||
name="Holiday Mode",
|
name="Holiday Mode",
|
||||||
icon="mdi:palm-tree",
|
icon="mdi:palm-tree",
|
||||||
device_class=BinarySensorDeviceClass.RUNNING,
|
device_class=BinarySensorDeviceClass.RUNNING,
|
||||||
on_value="1",
|
on_value=1,
|
||||||
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",
|
||||||
|
),
|
||||||
|
),
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
BINARY_SENSORS["WD"] = unique_entities(BINARY_SENSORS["WM"], BINARY_SENSORS["TD"])
|
BINARY_SENSORS["WD"] = unique_entities(BINARY_SENSORS["WM"], BINARY_SENSORS["TD"])
|
||||||
|
|
||||||
|
|
||||||
@@ -252,7 +261,7 @@ async def async_setup_entry(hass, entry: ConfigEntry, async_add_entities) -> Non
|
|||||||
entities = []
|
entities = []
|
||||||
for device in hass.data[DOMAIN][entry.unique_id].appliances:
|
for device in hass.data[DOMAIN][entry.unique_id].appliances:
|
||||||
for description in BINARY_SENSORS.get(device.appliance_type, []):
|
for description in BINARY_SENSORS.get(device.appliance_type, []):
|
||||||
if not device.get(description.key):
|
if device.get(description.key) is None:
|
||||||
continue
|
continue
|
||||||
entity = HonBinarySensorEntity(hass, entry, device, description)
|
entity = HonBinarySensorEntity(hass, entry, device, description)
|
||||||
await entity.coordinator.async_config_entry_first_refresh()
|
await entity.coordinator.async_config_entry_first_refresh()
|
||||||
|
|||||||
@@ -1,10 +1,11 @@
|
|||||||
import logging
|
import logging
|
||||||
|
from pathlib import Path
|
||||||
|
|
||||||
import pkg_resources
|
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
|
||||||
@@ -61,7 +62,8 @@ async def async_setup_entry(hass, entry: ConfigEntry, async_add_entities) -> Non
|
|||||||
entity = HonButtonEntity(hass, entry, device, description)
|
entity = HonButtonEntity(hass, entry, device, description)
|
||||||
await entity.coordinator.async_config_entry_first_refresh()
|
await entity.coordinator.async_config_entry_first_refresh()
|
||||||
entities.append(entity)
|
entities.append(entity)
|
||||||
entities.append(HonFeatureRequestButton(hass, entry, device))
|
entities.append(HonDeviceInfo(hass, entry, device))
|
||||||
|
entities.append(HonDataArchive(hass, entry, device))
|
||||||
await entities[-1].coordinator.async_config_entry_first_refresh()
|
await entities[-1].coordinator.async_config_entry_first_refresh()
|
||||||
async_add_entities(entities)
|
async_add_entities(entities)
|
||||||
|
|
||||||
@@ -77,26 +79,46 @@ class HonButtonEntity(HonEntity, ButtonEntity):
|
|||||||
"""Return True if entity is available."""
|
"""Return True if entity is available."""
|
||||||
return (
|
return (
|
||||||
super().available
|
super().available
|
||||||
and self._device.get("remoteCtrValid", "1") == "1"
|
and int(self._device.get("remoteCtrValid", "1")) == 1
|
||||||
and self._device.get("attributes.lastConnEvent.category") != "DISCONNECTED"
|
and self._device.get("attributes.lastConnEvent.category") != "DISCONNECTED"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
class HonFeatureRequestButton(HonEntity, ButtonEntity):
|
class HonDeviceInfo(HonEntity, ButtonEntity):
|
||||||
def __init__(self, hass, entry, device: HonAppliance) -> None:
|
def __init__(self, hass, entry, device: HonAppliance) -> None:
|
||||||
super().__init__(hass, entry, device)
|
super().__init__(hass, entry, device)
|
||||||
|
|
||||||
self._attr_unique_id = f"{super().unique_id}_log_device_info"
|
self._attr_unique_id = f"{super().unique_id}_show_device_info"
|
||||||
self._attr_icon = "mdi:information"
|
self._attr_icon = "mdi:information"
|
||||||
self._attr_name = "Show Device Info"
|
self._attr_name = "Show Device Info"
|
||||||
self._attr_entity_category = EntityCategory.DIAGNOSTIC
|
self._attr_entity_category = EntityCategory.DIAGNOSTIC
|
||||||
self._attr_entity_registry_enabled_default = False
|
|
||||||
|
|
||||||
async def async_press(self) -> None:
|
async def async_press(self) -> None:
|
||||||
pyhon_version = pkg_resources.get_distribution("pyhon").version
|
pyhon_version = pkg_resources.get_distribution("pyhon").version
|
||||||
info = f"{self._device.diagnose()}pyhOnVersion: {pyhon_version}"
|
info = f"{self._device.diagnose}pyhOnVersion: {pyhon_version}"
|
||||||
title = f"{self._device.nick_name} Device Info"
|
title = f"{self._device.nick_name} Device Info"
|
||||||
persistent_notification.create(
|
persistent_notification.create(
|
||||||
self._hass, f"````\n```\n{info}\n```\n````", title
|
self._hass, f"````\n```\n{info}\n```\n````", title
|
||||||
)
|
)
|
||||||
_LOGGER.info(info.replace(" ", "\u200B "))
|
_LOGGER.info(info.replace(" ", "\u200B "))
|
||||||
|
|
||||||
|
|
||||||
|
class HonDataArchive(HonEntity, ButtonEntity):
|
||||||
|
def __init__(self, hass, entry, device: HonAppliance) -> None:
|
||||||
|
super().__init__(hass, entry, device)
|
||||||
|
|
||||||
|
self._attr_unique_id = f"{super().unique_id}_create_data_archive"
|
||||||
|
self._attr_icon = "mdi:archive-arrow-down"
|
||||||
|
self._attr_name = "Create Data Archive"
|
||||||
|
self._attr_entity_category = EntityCategory.DIAGNOSTIC
|
||||||
|
|
||||||
|
async def async_press(self) -> None:
|
||||||
|
path = Path(self._hass.config.config_dir) / "www"
|
||||||
|
data = await self._device.data_archive(path)
|
||||||
|
title = f"{self._device.nick_name} Data Archive"
|
||||||
|
text = (
|
||||||
|
f'<a href="/local/{data}" target="_blank">{data}</a> <br/><br/> '
|
||||||
|
f"Use this data for [GitHub Issues of Haier hOn](https://github.com/Andre0512/hon).<br/>"
|
||||||
|
f"Or add it to the [hon-test-data collection](https://github.com/Andre0512/hon-test-data)."
|
||||||
|
)
|
||||||
|
persistent_notification.create(self._hass, text, title)
|
||||||
|
|||||||
@@ -22,7 +22,7 @@ from homeassistant.const import (
|
|||||||
from homeassistant.core import callback
|
from homeassistant.core import callback
|
||||||
from pyhon.appliance import HonAppliance
|
from pyhon.appliance import HonAppliance
|
||||||
|
|
||||||
from .const import HON_HVAC_MODE, HON_FAN, HON_HVAC_PROGRAM, DOMAIN
|
from .const import HON_HVAC_MODE, HON_FAN, DOMAIN
|
||||||
from .hon import HonEntity
|
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]
|
||||||
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_hvac_modes.append(HON_HVAC_MODE[int(mode)])
|
||||||
|
self._attr_preset_modes = []
|
||||||
|
for mode in device.settings["startProgram.program"].values:
|
||||||
|
self._attr_preset_modes.append(mode)
|
||||||
self._attr_fan_modes = [FAN_OFF]
|
self._attr_fan_modes = [FAN_OFF]
|
||||||
for mode in device.settings["settings.windSpeed"].values:
|
for mode in device.settings["settings.windSpeed"].values:
|
||||||
self._attr_fan_modes.append(HON_FAN[mode])
|
self._attr_fan_modes.append(HON_FAN[int(mode)])
|
||||||
self._attr_swing_modes = [
|
self._attr_swing_modes = [
|
||||||
SWING_OFF,
|
SWING_OFF,
|
||||||
SWING_VERTICAL,
|
SWING_VERTICAL,
|
||||||
@@ -119,19 +136,27 @@ 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
|
@property
|
||||||
def target_temperature(self) -> int | None:
|
def target_temperature(self) -> int | None:
|
||||||
"""Return the temperature we try to reach."""
|
"""Return the temperature we try to reach."""
|
||||||
return int(float(self._device.get("tempSel")))
|
return self._device.get("tempSel")
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def current_temperature(self) -> float | None:
|
def current_temperature(self) -> float | None:
|
||||||
"""Return the current temperature."""
|
"""Return the current temperature."""
|
||||||
return float(self._device.get("tempIndoor"))
|
return self._device.get("tempIndoor")
|
||||||
|
|
||||||
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:
|
||||||
@@ -142,7 +167,7 @@ class HonACClimateEntity(HonEntity, ClimateEntity):
|
|||||||
|
|
||||||
@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:
|
||||||
return HVACMode.OFF
|
return HVACMode.OFF
|
||||||
else:
|
else:
|
||||||
return HON_HVAC_MODE[self._device.get("machMode")]
|
return HON_HVAC_MODE[self._device.get("machMode")]
|
||||||
@@ -150,13 +175,31 @@ class HonACClimateEntity(HonEntity, ClimateEntity):
|
|||||||
async def async_set_hvac_mode(self, hvac_mode):
|
async def async_set_hvac_mode(self, hvac_mode):
|
||||||
self._attr_hvac_mode = hvac_mode
|
self._attr_hvac_mode = hvac_mode
|
||||||
if hvac_mode == HVACMode.OFF:
|
if hvac_mode == HVACMode.OFF:
|
||||||
command = "stopProgram"
|
await self._device.commands["stopProgram"].send()
|
||||||
|
self._device.sync_command("stopProgram", "settings")
|
||||||
else:
|
else:
|
||||||
mode = HON_HVAC_PROGRAM[hvac_mode]
|
self._device.settings["settings.onOffStatus"].value = "1"
|
||||||
self._device.settings["startProgram.program"].value = mode
|
setting = self._device.settings["settings.machMode"]
|
||||||
command = "startProgram"
|
modes = {HON_HVAC_MODE[int(number)]: number for number in setting.values}
|
||||||
await self._device.commands[command].send()
|
setting.value = modes[hvac_mode]
|
||||||
self._device.sync_command(command, "settings")
|
await self._device.commands["settings"].send()
|
||||||
|
self.async_write_ha_state()
|
||||||
|
|
||||||
|
@property
|
||||||
|
def preset_mode(self) -> str | None:
|
||||||
|
"""Return the current Preset for this channel."""
|
||||||
|
return None
|
||||||
|
|
||||||
|
async def async_set_preset_mode(self, preset_mode: str) -> None:
|
||||||
|
"""Set the new preset mode."""
|
||||||
|
if program := self._device.settings.get(f"startProgram.program"):
|
||||||
|
program.value = preset_mode
|
||||||
|
self._device.sync_command("startProgram", "settings")
|
||||||
|
self._set_temperature_bound()
|
||||||
|
self._handle_coordinator_update(update=False)
|
||||||
|
await self.coordinator.async_refresh()
|
||||||
|
self._attr_preset_mode = preset_mode
|
||||||
|
await self._device.commands["startProgram"].send()
|
||||||
self.async_write_ha_state()
|
self.async_write_ha_state()
|
||||||
|
|
||||||
@property
|
@property
|
||||||
@@ -177,11 +220,11 @@ class HonACClimateEntity(HonEntity, ClimateEntity):
|
|||||||
"""Return the swing setting."""
|
"""Return the swing setting."""
|
||||||
horizontal = self._device.get("windDirectionHorizontal")
|
horizontal = self._device.get("windDirectionHorizontal")
|
||||||
vertical = self._device.get("windDirectionVertical")
|
vertical = self._device.get("windDirectionVertical")
|
||||||
if horizontal == "7" and vertical == "8":
|
if horizontal == 7 and vertical == 8:
|
||||||
return SWING_BOTH
|
return SWING_BOTH
|
||||||
elif horizontal == "7":
|
elif horizontal == 7:
|
||||||
return SWING_HORIZONTAL
|
return SWING_HORIZONTAL
|
||||||
elif vertical == "8":
|
elif vertical == 8:
|
||||||
return SWING_VERTICAL
|
return SWING_VERTICAL
|
||||||
else:
|
else:
|
||||||
return SWING_OFF
|
return SWING_OFF
|
||||||
@@ -213,7 +256,7 @@ class HonACClimateEntity(HonEntity, ClimateEntity):
|
|||||||
|
|
||||||
|
|
||||||
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)
|
||||||
@@ -226,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:
|
||||||
@@ -245,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 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 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:
|
||||||
@@ -264,7 +307,7 @@ class HonClimateEntity(HonEntity, ClimateEntity):
|
|||||||
|
|
||||||
@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:
|
||||||
return HVACMode.OFF
|
return HVACMode.OFF
|
||||||
else:
|
else:
|
||||||
return self.entity_description.mode
|
return self.entity_description.mode
|
||||||
|
|||||||
+119
-104
@@ -17,16 +17,17 @@ PLATFORMS = [
|
|||||||
"button",
|
"button",
|
||||||
"binary_sensor",
|
"binary_sensor",
|
||||||
"climate",
|
"climate",
|
||||||
|
"fan",
|
||||||
]
|
]
|
||||||
|
|
||||||
HON_HVAC_MODE = {
|
HON_HVAC_MODE = {
|
||||||
"0": HVACMode.AUTO,
|
0: HVACMode.AUTO,
|
||||||
"1": HVACMode.COOL,
|
1: HVACMode.COOL,
|
||||||
"2": HVACMode.DRY,
|
2: HVACMode.DRY,
|
||||||
"3": HVACMode.DRY,
|
3: HVACMode.DRY,
|
||||||
"4": HVACMode.HEAT,
|
4: HVACMode.HEAT,
|
||||||
"5": HVACMode.FAN_ONLY,
|
5: HVACMode.FAN_ONLY,
|
||||||
"6": HVACMode.FAN_ONLY,
|
6: HVACMode.FAN_ONLY,
|
||||||
}
|
}
|
||||||
|
|
||||||
HON_HVAC_PROGRAM = {
|
HON_HVAC_PROGRAM = {
|
||||||
@@ -38,11 +39,11 @@ HON_HVAC_PROGRAM = {
|
|||||||
}
|
}
|
||||||
|
|
||||||
HON_FAN = {
|
HON_FAN = {
|
||||||
"1": FAN_HIGH,
|
1: FAN_HIGH,
|
||||||
"2": FAN_MEDIUM,
|
2: FAN_MEDIUM,
|
||||||
"3": FAN_LOW,
|
3: FAN_LOW,
|
||||||
"4": FAN_AUTO,
|
4: FAN_AUTO,
|
||||||
"5": FAN_AUTO,
|
5: FAN_AUTO,
|
||||||
}
|
}
|
||||||
|
|
||||||
# These languages are official supported by hOn
|
# These languages are official supported by hOn
|
||||||
@@ -69,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",
|
||||||
"12": "unknown",
|
11: "ready",
|
||||||
"13": "TD_CMD&CTRL.STATUS_PHASE.PHASE_COOLDOWN",
|
12: "unknown",
|
||||||
"14": "TD_CMD&CTRL.STATUS_PHASE.PHASE_HEAT_STROKE",
|
13: "cooldown",
|
||||||
"15": "TD_CMD&CTRL.STATUS_PHASE.PHASE_HEAT_STROKE",
|
14: "heat_stroke",
|
||||||
"16": "TD_CMD&CTRL.STATUS_PHASE.PHASE_COOLDOWN",
|
15: "heat_stroke",
|
||||||
"17": "unknown",
|
16: "cooldown",
|
||||||
"18": "WASHING_CMD&CTRL.PHASE_TUMBLING.DASHBOARD_TITLE",
|
17: "unknown",
|
||||||
"19": "WASHING_CMD&CTRL.PHASE_DRYING.TITLE",
|
18: "tumbling",
|
||||||
"20": "WASHING_CMD&CTRL.PHASE_DRYING.TITLE",
|
19: "drying",
|
||||||
|
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",
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -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 device.get(
|
||||||
|
description.key.split(".")[-1] is None
|
||||||
|
):
|
||||||
|
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 = 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,4 +1,5 @@
|
|||||||
import logging
|
import logging
|
||||||
|
from contextlib import suppress
|
||||||
from datetime import timedelta
|
from datetime import timedelta
|
||||||
|
|
||||||
from homeassistant.core import callback
|
from homeassistant.core import callback
|
||||||
@@ -81,3 +82,10 @@ def get_coordinator(hass, appliance):
|
|||||||
coordinator = HonCoordinator(hass, appliance)
|
coordinator = HonCoordinator(hass, appliance)
|
||||||
hass.data[DOMAIN]["coordinators"][appliance.unique_id] = coordinator
|
hass.data[DOMAIN]["coordinators"][appliance.unique_id] = coordinator
|
||||||
return coordinator
|
return coordinator
|
||||||
|
|
||||||
|
|
||||||
|
def get_readable(description, value):
|
||||||
|
if description.option_list is not None:
|
||||||
|
with suppress(ValueError):
|
||||||
|
return description.option_list.get(int(value), value)
|
||||||
|
return value
|
||||||
|
|||||||
@@ -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.2"
|
"pyhOn==0.14.1"
|
||||||
],
|
],
|
||||||
"version": "0.8.0"
|
"version": "0.9.0-beta.5"
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -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,6 +236,8 @@ 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
|
||||||
@@ -229,7 +247,7 @@ class HonNumberEntity(HonEntity, NumberEntity):
|
|||||||
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
|
||||||
if update:
|
if update:
|
||||||
self.async_write_ha_state()
|
self.async_write_ha_state()
|
||||||
|
|
||||||
@@ -238,7 +256,7 @@ class HonNumberEntity(HonEntity, NumberEntity):
|
|||||||
"""Return True if entity is available."""
|
"""Return True if entity is available."""
|
||||||
return (
|
return (
|
||||||
super().available
|
super().available
|
||||||
and self._device.get("remoteCtrValid", "1") == "1"
|
and int(self._device.get("remoteCtrValid", 1)) == 1
|
||||||
and self._device.get("attributes.lastConnEvent.category") != "DISCONNECTED"
|
and self._device.get("attributes.lastConnEvent.category") != "DISCONNECTED"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|||||||
@@ -2,29 +2,30 @@ 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
|
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, get_readable
|
||||||
|
|
||||||
_LOGGER = logging.getLogger(__name__)
|
_LOGGER = logging.getLogger(__name__)
|
||||||
|
|
||||||
|
|
||||||
@dataclass
|
@dataclass
|
||||||
class HonSelectEntityDescription(SelectEntityDescription):
|
class HonSelectEntityDescription(SelectEntityDescription):
|
||||||
pass
|
option_list: Dict[int, str] = None
|
||||||
|
|
||||||
|
|
||||||
@dataclass
|
@dataclass
|
||||||
class HonConfigSelectEntityDescription(SelectEntityDescription):
|
class HonConfigSelectEntityDescription(SelectEntityDescription):
|
||||||
entity_category: EntityCategory = EntityCategory.CONFIG
|
entity_category: EntityCategory = EntityCategory.CONFIG
|
||||||
|
option_list: Dict[int, 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,64 +168,69 @@ 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 = get_readable(self.entity_description, setting.value)
|
||||||
|
if value not in self._attr_options:
|
||||||
|
return None
|
||||||
|
return value
|
||||||
|
|
||||||
|
@property
|
||||||
|
def options(self) -> list[str]:
|
||||||
|
setting = self._device.settings.get(self.entity_description.key)
|
||||||
|
if setting is None:
|
||||||
|
return []
|
||||||
|
return [get_readable(self.entity_description, key) for key in setting.values]
|
||||||
|
|
||||||
|
def _option_to_number(self, option: str, values: List[str]):
|
||||||
|
if (options := self.entity_description.option_list) is not None:
|
||||||
|
return next(
|
||||||
|
(k for k, v in options.items() if str(k) in values and v == option),
|
||||||
|
option,
|
||||||
|
)
|
||||||
|
return option
|
||||||
|
|
||||||
async def async_select_option(self, option: str) -> None:
|
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, update=True) -> None:
|
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] = []
|
|
||||||
self._attr_native_value = None
|
|
||||||
else:
|
|
||||||
self._attr_available = True
|
|
||||||
self._attr_options: list[str] = setting.values
|
|
||||||
self._attr_native_value = setting.value
|
|
||||||
if update:
|
if update:
|
||||||
self.async_write_ha_state()
|
self.async_write_ha_state()
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def available(self) -> bool:
|
def available(self) -> bool:
|
||||||
"""Return True if entity is available."""
|
"""Return True if entity is available."""
|
||||||
return (
|
return self._device.settings.get(self.entity_description.key) is not None
|
||||||
super().available
|
|
||||||
and self._device.get("remoteCtrValid", "1") == "1"
|
|
||||||
and self._device.get("attributes.lastConnEvent.category") != "DISCONNECTED"
|
|
||||||
)
|
|
||||||
|
|
||||||
|
|
||||||
class HonConfigSelectEntity(HonSelectEntity):
|
class HonSelectEntity(HonConfigSelectEntity):
|
||||||
entity_description: HonConfigSelectEntityDescription
|
entity_description: HonSelectEntityDescription
|
||||||
|
|
||||||
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]
|
||||||
|
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()
|
await self.coordinator.async_refresh()
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def available(self) -> bool:
|
def available(self) -> bool:
|
||||||
"""Return True if entity is available."""
|
"""Return True if entity is available."""
|
||||||
return super(SelectEntity, self).available
|
return (
|
||||||
|
super().available
|
||||||
|
and int(self._device.get("remoteCtrValid", 1)) == 1
|
||||||
|
and self._device.get("attributes.lastConnEvent.category") != "DISCONNECTED"
|
||||||
|
)
|
||||||
|
|||||||
+189
-24
@@ -1,5 +1,6 @@
|
|||||||
import logging
|
import logging
|
||||||
from dataclasses import dataclass
|
from dataclasses import dataclass
|
||||||
|
from typing import Dict
|
||||||
|
|
||||||
from homeassistant.components.sensor import (
|
from homeassistant.components.sensor import (
|
||||||
SensorEntity,
|
SensorEntity,
|
||||||
@@ -8,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,
|
||||||
@@ -20,11 +26,10 @@ 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 pyhon.appliance import HonAppliance
|
|
||||||
|
|
||||||
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, get_readable
|
||||||
|
|
||||||
_LOGGER = logging.getLogger(__name__)
|
_LOGGER = logging.getLogger(__name__)
|
||||||
|
|
||||||
@@ -32,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[int, str] = None
|
||||||
|
|
||||||
|
|
||||||
@dataclass
|
@dataclass
|
||||||
class HonSensorEntityDescription(SensorEntityDescription):
|
class HonSensorEntityDescription(SensorEntityDescription):
|
||||||
pass
|
option_list: Dict[int, str] = None
|
||||||
|
|
||||||
|
|
||||||
SENSORS: dict[str, tuple[SensorEntityDescription, ...]] = {
|
SENSORS: dict[str, tuple[SensorEntityDescription, ...]] = {
|
||||||
@@ -47,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",
|
||||||
@@ -102,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"
|
||||||
@@ -154,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",
|
||||||
@@ -187,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"
|
||||||
@@ -221,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",
|
||||||
@@ -229,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",
|
||||||
@@ -255,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",
|
||||||
@@ -391,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"
|
||||||
@@ -410,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",
|
||||||
@@ -484,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",
|
||||||
@@ -492,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(
|
||||||
@@ -593,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",
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
}
|
}
|
||||||
@@ -608,7 +769,7 @@ async def async_setup_entry(hass, entry: ConfigEntry, async_add_entities) -> Non
|
|||||||
for device in hass.data[DOMAIN][entry.unique_id].appliances:
|
for device in hass.data[DOMAIN][entry.unique_id].appliances:
|
||||||
for description in SENSORS.get(device.appliance_type, []):
|
for description in SENSORS.get(device.appliance_type, []):
|
||||||
if isinstance(description, HonSensorEntityDescription):
|
if isinstance(description, HonSensorEntityDescription):
|
||||||
if not device.get(description.key):
|
if device.get(description.key) is None:
|
||||||
continue
|
continue
|
||||||
entity = HonSensorEntity(hass, entry, device, description)
|
entity = HonSensorEntity(hass, entry, device, description)
|
||||||
elif isinstance(description, HonConfigSensorEntityDescription):
|
elif isinstance(description, HonConfigSensorEntityDescription):
|
||||||
@@ -626,16 +787,16 @@ 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, update=True) -> None:
|
value = get_readable(self.entity_description, 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
|
||||||
@@ -651,12 +812,16 @@ class HonConfigSensorEntity(HonEntity, SensorEntity):
|
|||||||
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
|
||||||
|
if self.entity_description.option_list is not None and not value == 0:
|
||||||
|
self._attr_options = list(self.entity_description.option_list.values())
|
||||||
|
value = get_readable(self.entity_description, value)
|
||||||
|
self._attr_native_value = value
|
||||||
if update:
|
if update:
|
||||||
self.async_write_ha_state()
|
self.async_write_ha_state()
|
||||||
|
|||||||
@@ -5,8 +5,8 @@ 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.core import callback
|
from homeassistant.core import callback
|
||||||
|
from homeassistant.helpers.entity import EntityCategory
|
||||||
from pyhon.parameter.base import HonParameter
|
from pyhon.parameter.base import HonParameter
|
||||||
from pyhon.parameter.range import HonParameterRange
|
from pyhon.parameter.range import HonParameterRange
|
||||||
|
|
||||||
@@ -262,9 +262,9 @@ SWITCHES: dict[str, tuple[HonSwitchEntityDescription, ...]] = {
|
|||||||
),
|
),
|
||||||
HonSwitchEntityDescription(
|
HonSwitchEntityDescription(
|
||||||
key="muteStatus",
|
key="muteStatus",
|
||||||
name="Mute",
|
name="Silent Mode",
|
||||||
icon="mdi:volume-off",
|
icon="mdi:volume-off",
|
||||||
translation_key="mute_mode",
|
translation_key="silent_mode",
|
||||||
),
|
),
|
||||||
HonSwitchEntityDescription(
|
HonSwitchEntityDescription(
|
||||||
key="rapidMode",
|
key="rapidMode",
|
||||||
@@ -291,9 +291,9 @@ SWITCHES: dict[str, tuple[HonSwitchEntityDescription, ...]] = {
|
|||||||
),
|
),
|
||||||
HonSwitchEntityDescription(
|
HonSwitchEntityDescription(
|
||||||
key="silentSleepStatus",
|
key="silentSleepStatus",
|
||||||
name="Silent Sleep",
|
name="Night Mode",
|
||||||
icon="mdi:bed",
|
icon="mdi:bed",
|
||||||
translation_key="silent_mode",
|
translation_key="night_mode",
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
"REF": (
|
"REF": (
|
||||||
@@ -322,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"])
|
||||||
@@ -347,7 +368,7 @@ async def async_setup_entry(hass, entry: ConfigEntry, async_add_entities) -> Non
|
|||||||
elif isinstance(description, HonSwitchEntityDescription):
|
elif isinstance(description, HonSwitchEntityDescription):
|
||||||
if (
|
if (
|
||||||
f"settings.{description.key}" not in device.available_settings
|
f"settings.{description.key}" not in device.available_settings
|
||||||
or not device.get(description.key)
|
or device.get(description.key) is None
|
||||||
):
|
):
|
||||||
continue
|
continue
|
||||||
entity = HonSwitchEntity(hass, entry, device, description)
|
entity = HonSwitchEntity(hass, entry, device, description)
|
||||||
@@ -365,7 +386,7 @@ class HonSwitchEntity(HonEntity, SwitchEntity):
|
|||||||
@property
|
@property
|
||||||
def is_on(self) -> bool | None:
|
def is_on(self) -> bool | None:
|
||||||
"""Return True if entity is on."""
|
"""Return True if entity is on."""
|
||||||
return self._device.get(self.entity_description.key, "0") == "1"
|
return self._device.get(self.entity_description.key, 0) == 1
|
||||||
|
|
||||||
async def async_turn_on(self, **kwargs: Any) -> None:
|
async def async_turn_on(self, **kwargs: Any) -> None:
|
||||||
setting = self._device.settings[f"settings.{self.entity_description.key}"]
|
setting = self._device.settings[f"settings.{self.entity_description.key}"]
|
||||||
@@ -390,14 +411,14 @@ class HonSwitchEntity(HonEntity, SwitchEntity):
|
|||||||
"""Return True if entity is available."""
|
"""Return True if entity is available."""
|
||||||
return (
|
return (
|
||||||
super().available
|
super().available
|
||||||
and self._device.get("remoteCtrValid", "1") == "1"
|
and int(self._device.get("remoteCtrValid", 1)) == 1
|
||||||
and self._device.get("attributes.lastConnEvent.category") != "DISCONNECTED"
|
and self._device.get("attributes.lastConnEvent.category") != "DISCONNECTED"
|
||||||
)
|
)
|
||||||
|
|
||||||
@callback
|
@callback
|
||||||
def _handle_coordinator_update(self, update=True) -> None:
|
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
|
||||||
if update:
|
if update:
|
||||||
self.async_write_ha_state()
|
self.async_write_ha_state()
|
||||||
|
|
||||||
@@ -425,7 +446,7 @@ class HonControlSwitchEntity(HonEntity, SwitchEntity):
|
|||||||
"""Return True if entity is available."""
|
"""Return True if entity is available."""
|
||||||
return (
|
return (
|
||||||
super().available
|
super().available
|
||||||
and self._device.get("remoteCtrValid", "1") == "1"
|
and int(self._device.get("remoteCtrValid", 1)) == 1
|
||||||
and self._device.get("attributes.lastConnEvent.category") != "DISCONNECTED"
|
and self._device.get("attributes.lastConnEvent.category") != "DISCONNECTED"
|
||||||
)
|
)
|
||||||
|
|
||||||
@@ -433,8 +454,8 @@ class HonControlSwitchEntity(HonEntity, SwitchEntity):
|
|||||||
def extra_state_attributes(self) -> dict[str, Any]:
|
def extra_state_attributes(self) -> dict[str, Any]:
|
||||||
"""Return the optional state attributes."""
|
"""Return the optional state attributes."""
|
||||||
result = {}
|
result = {}
|
||||||
if remaining_time := int(self._device.get("remainingTimeMM", 0)):
|
if remaining_time := self._device.get("remainingTimeMM", 0):
|
||||||
delay_time = int(self._device.get("delayTime", 0))
|
delay_time = self._device.get("delayTime", 0)
|
||||||
result["start_time"] = datetime.now() + timedelta(minutes=delay_time)
|
result["start_time"] = datetime.now() + timedelta(minutes=delay_time)
|
||||||
result["end_time"] = datetime.now() + timedelta(
|
result["end_time"] = datetime.now() + timedelta(
|
||||||
minutes=delay_time + remaining_time
|
minutes=delay_time + remaining_time
|
||||||
|
|||||||
+1542
-1543
File diff suppressed because it is too large
Load Diff
+1542
-1543
File diff suppressed because it is too large
Load Diff
+1542
-1543
File diff suppressed because it is too large
Load Diff
+1109
-1145
File diff suppressed because it is too large
Load Diff
+1542
-1543
File diff suppressed because it is too large
Load Diff
+1542
-1543
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
+1542
-1543
File diff suppressed because it is too large
Load Diff
+1564
-1601
File diff suppressed because it is too large
Load Diff
+1542
-1543
File diff suppressed because it is too large
Load Diff
+1542
-1543
File diff suppressed because it is too large
Load Diff
+1542
-1543
File diff suppressed because it is too large
Load Diff
+1542
-1543
File diff suppressed because it is too large
Load Diff
+1542
-1543
File diff suppressed because it is too large
Load Diff
+1542
-1543
File diff suppressed because it is too large
Load Diff
+1542
-1543
File diff suppressed because it is too large
Load Diff
+1542
-1543
File diff suppressed because it is too large
Load Diff
+1542
-1543
File diff suppressed because it is too large
Load Diff
+1542
-1543
File diff suppressed because it is too large
Load Diff
@@ -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)
|
||||||
- [Air conditioner](https://github.com/Andre0512/hon#air-conditioner)
|
- [Air Conditioner](https://github.com/Andre0512/hon#air-conditioner)
|
||||||
- [Fridge](https://github.com/Andre0512/hon#fridge)
|
- [Fridge](https://github.com/Andre0512/hon#fridge)
|
||||||
- [Hob](https://github.com/Andre0512/hon#hob) [BETA]
|
- [Induction Hob](https://github.com/Andre0512/hon#induction-hob) [BETA]
|
||||||
- [Hood](https://github.com/Andre0512/hon#hood) [BETA]
|
- [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,25 @@ 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 | | |
|
||||||
|
|
||||||
|
| Please add your appliances data to our [hon-test-data collection](https://github.com/Andre0512/hon-test-data). <br/>This helps us to develop new features and not to break compatibility in newer versions. |
|
||||||
|
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|
||||||
|
|
||||||
## 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,46 +69,9 @@ 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 AS20HPL1HRA
|
|
||||||
- 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:
|
||||||
|
|||||||
+11
-9
@@ -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 = {}
|
||||||
|
|||||||
@@ -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",
|
||||||
|
"night_mode": "AC.PROGRAM_CARD.NIGHT",
|
||||||
|
"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