Compare commits

..

50 Commits

Author SHA1 Message Date
6e9981c9ab Add climate entity for oven 2023-05-28 17:38:56 +02:00
cb660fa9e0 Add climate entites for fridge #41 2023-05-28 07:50:59 +02:00
a8762367ed Refactor hon entities 2023-05-28 00:30:40 +02:00
696dc136eb Refactor entry setup 2023-05-25 01:30:33 +02:00
e9d1bb2056 Refactor get coordinator 2023-05-25 00:52:54 +02:00
9518031f24 Fix problematic char in translation keys 2023-05-22 01:12:51 +02:00
bf1a6e8fe2 Improve fridge support #41 2023-05-21 20:52:27 +02:00
833c395c97 Bump pyhon 2023-05-20 13:28:18 +02:00
d963086dbf Fix climate not available #52 2023-05-19 01:27:44 +02:00
29238d3d08 Add supported devices 2023-05-18 23:48:19 +02:00
a4ec3290ba Many air conditioner fixes for #52 2023-05-17 00:01:33 +02:00
d39deba973 Bump version 2023-05-16 20:52:17 +02:00
fae4c4c879 Check remote control only if available, fix #50 2023-05-16 20:34:05 +02:00
617ea0f99a Fix wrong ac attribute #49 2023-05-16 00:06:55 +02:00
81676771c7 Add some fridge sensors, change some configs to controls 2023-05-15 19:27:41 +02:00
604cf1b3c6 Add more fridge sensor #41 2023-05-15 00:38:41 +02:00
9a65eaba77 Fix errors in changing settings 2023-05-14 22:39:34 +02:00
e777fe1ec9 Add more dw conifgs 2023-05-14 03:17:58 +02:00
845adc75c9 Instant send settings 2023-05-14 03:16:21 +02:00
17d4d14ead Show controls always unavailable when diconnected #43 2023-05-13 22:09:48 +02:00
593d3912af Fix wrong wm keep fresh key 2023-05-13 01:20:02 +02:00
aefe2cf88d Add supported models 2023-05-12 18:15:28 +02:00
146e710881 Add first fridge sensors #41 2023-05-10 18:23:06 +02:00
0afbfe997d Fix log device info #40 2023-05-09 12:41:41 +02:00
6828f3e9a8 Fix missing switches again 2023-05-08 21:30:49 +02:00
a56d3e5f88 Fix missing temperature #38 2023-05-08 19:41:25 +02:00
240dc85ff3 Small fixes, fix KeyError for switches #38 2023-05-08 19:26:10 +02:00
44794c35ca Fix missing entities #34 2023-05-08 02:35:54 +02:00
a5c7b99569 Improve air conditioner support 2023-05-08 02:05:04 +02:00
6935f5f07f Deactivate contols when remotectrl disabled, fixes #28 2023-05-07 19:13:50 +02:00
74f5887bb2 Bump pyhon to fix #36 2023-05-07 17:42:28 +02:00
155b1ff91a Add all wm and td sensors to wd 2023-05-07 16:39:45 +02:00
7b80acb6b9 Update readme 2023-05-07 15:10:09 +02:00
0e9bd97c7b Remove useless warning, bump version 2023-05-07 13:53:05 +02:00
dae8b48075 Use names for some td entities, fix #36 2023-05-07 13:47:43 +02:00
7e40afae68 Flag enums as enums with option list #35 2023-05-07 02:34:41 +02:00
c0fda4cd1b Add more control for hoover washing machine #34 2023-05-07 02:10:30 +02:00
2802bcad25 Fix errors, bump pyhon 2023-05-07 01:22:53 +02:00
8aa8563b9b Control air conditioners 2023-04-26 23:57:44 +02:00
8e4e491c33 Output pyhon version 2023-04-25 23:39:18 +02:00
28a8ad1672 Translate login 2023-04-24 22:40:20 +02:00
e56f2c99c0 Don't escape unicode in json files 2023-04-24 22:07:58 +02:00
e35a6ce751 Bump pyhon version 2023-04-24 21:53:37 +02:00
5bff5d2143 Add more translation keys 2023-04-24 21:38:05 +02:00
f1e16312ff Fix some bugs for hoover appliances, fix #31 2023-04-24 04:36:14 +02:00
8c1bba2468 Bump pyhon version 2023-04-23 20:18:00 +02:00
616f7babdb Faster refresh when changing configs 2023-04-23 20:04:19 +02:00
1143c47fd3 Bump pyhon version 2023-04-23 19:29:50 +02:00
c60d94a170 Improve translations and sensors for td and wm 2023-04-23 16:30:57 +02:00
c89521f169 Bump pyhon version 2023-04-23 14:42:55 +02:00
37 changed files with 18649 additions and 7899 deletions

579
README.md
View File

@ -1,17 +1,20 @@
# Haier hOn # Haier hOn
[![hacs_badge](https://img.shields.io/badge/HACS-Default-41BDF5.svg)](https://hacs.xyz) [![hacs_badge](https://img.shields.io/badge/HACS-Default-41BDF5.svg)](https://hacs.xyz)
[![GitHub release (latest by date)](https://img.shields.io/github/v/release/Andre0512/hon?color=green)](https://github.com/Andre0512/hon/releases/latest) [![GitHub release (latest by date)](https://img.shields.io/github/v/release/Andre0512/hon?color=green)](https://github.com/Andre0512/hon/releases/latest)
[![PyPI](https://img.shields.io/pypi/v/pyhon?label=pyhOn)](https://github.com/Andre0512/pyhOn)
[![GitHub](https://img.shields.io/github/license/Andre0512/hon?color=red)](https://github.com/Andre0512/hon/blob/main/LICENSE) [![GitHub](https://img.shields.io/github/license/Andre0512/hon?color=red)](https://github.com/Andre0512/hon/blob/main/LICENSE)
[![GitHub all releases](https://img.shields.io/github/downloads/Andre0512/hon/total?color=blue)](https://tooomm.github.io/github-release-stats/?username=Andre0512&repository=hon) [![GitHub all releases](https://img.shields.io/github/downloads/Andre0512/hon/total?color=blue)](https://tooomm.github.io/github-release-stats/?username=Andre0512&repository=hon)
Home Assistant integration for Haier hOn: support for Haier/Candy/Hoover home appliances like washing machines. Home Assistant integration for [Haier's mobile app hOn](https://hon-smarthome.com/).
## Supported Appliances ## Supported Appliances
- [Washing Machine](https://github.com/Andre0512/hon#washing-machine) - [Washing Machine](https://github.com/Andre0512/hon#washing-machine)
- [Tumble Dryer](https://github.com/Andre0512/hon#tumble-dryer) - [Tumble Dryer](https://github.com/Andre0512/hon#tumble-dryer)
- [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)
- [Hob](https://github.com/Andre0512/hon#hob)
- [Dish Washer](https://github.com/Andre0512/hon#dish-washer) - [Dish Washer](https://github.com/Andre0512/hon#dish-washer)
- [Hob](https://github.com/Andre0512/hon#hob) [BETA]
- [Air conditioner](https://github.com/Andre0512/hon#air-conditioner) [BETA]
- [Fridge](https://github.com/Andre0512/hon#fridge) [BETA]
## Installation ## Installation
**Method 1:** [![Open your Home Assistant instance and open a repository inside the Home Assistant Community Store.](https://my.home-assistant.io/badges/hacs_repository.svg)](https://my.home-assistant.io/redirect/hacs_repository/?owner=Andre0512&repository=hon&category=integration) **Method 1:** [![Open your Home Assistant instance and open a repository inside the Home Assistant Community Store.](https://my.home-assistant.io/badges/hacs_repository.svg)](https://my.home-assistant.io/redirect/hacs_repository/?owner=Andre0512&repository=hon&category=integration)
@ -29,26 +32,74 @@ _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 Languages
Translation of internal names like programs are available for all languages which are official supported by the hOn app:
* 🇨🇳 Chinese
* 🇭🇷 Croatian
* 🇨🇿 Czech
* 🇳🇱 Dutch
* 🇬🇧 English
* 🇫🇷 French
* 🇩🇪 German
* 🇬🇷 Greek
* 🇮🇱 Hebrew
* 🇮🇹 Italian
* 🇵🇱 Polish
* 🇵🇹 Portuguese
* 🇷🇴 Romanian
* 🇷🇺 Russian
* 🇷🇸 Serbian
* 🇸🇰 Slovak
* 🇸🇮 Slovenian
* 🇪🇸 Spanish
* 🇹🇷 Turkish
## Examples
### Washing Machine
![washing_machine.png](assets/washing_machine.png)
## Supported Models
Support has been confirmed for these models, but many more will work. Please add already supported devices [with this form to complete the list](https://forms.gle/bTSD8qFotdZFytbf8).
- Haier AD105S2SM3FA
- Haier AS25PBAHRA
- Haier AS25TADHRA-2
- Haier AS35TADHRA-2
- Haier EG9012B19SU1JD
- Haier HD80-A3959
- Haier HW90-B14TEAM5
- Haier HW100-B14959U1
- Haier HWD100-B14979
- Haier HWO60SM2F3XH
- Haier XIB 3B2SFS-80
- Haier XIB 6B2D3FB
- Candy BCTDH7A1TE
- Candy CIS633SCTTWIFI
- Candy CSOE C10DE-80
- 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 info of your appliance. For every device exists a hidden button which can be used to log all infos of your appliance.
1. Enable the "Log Device Info" button 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._ _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 2. Press the button to create a notification
3. Go to Settings > System > Logs, click _load full logs_ and scroll down 3. Open home assistant notifications and copy the message (Crtl+A, Ctrl+C)
_The formatting is messy if you not load full logs_
4. Here you can find all data which can be read out via the api
```yaml
data:
appliance:
applianceId: 12-34-56-78-90-ab#2022-10-25T19:47:11Z
applianceModelId: 1569
...
```
5. Copy this data and create a [new issue](https://github.com/Andre0512/hon/issues/new) with your request
### 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
@ -91,230 +142,336 @@ For every device exists a hidden button which can be used to log all info of you
#### Tips and Tricks #### Tips and Tricks
- If you want to have some states humanreadable, have a look at the `translation_key` parameter of the `EntityDescription`. - If you want to have some states humanreadable, have a look at the `translation_key` parameter of the `EntityDescription`.
- If you need to implement some more logic, create a pull request to the underlying library. There we collect special requirements in the `appliances` directory. - If you need to implement some more logic, create a pull request to the underlying library. There we collect special requirements in the `appliances` directory.
- Use [pyhOn's translate command](https://github.com/Andre0512/pyhOn#translation) to read out the official translations - Use [pyhOn's translate command](https://github.com/Andre0512/pyhOn#translation) to read out the official translations
## Tested Devices ## Special Thanks
- Haier WD90-B14TEAM5 - to [@alexandre-leites](https://github.com/alexandre-leites), [@MiguelAngelLV](https://github.com/MiguelAngelLV) and [@drudgebg](https://github.com/drudgebg) for contributing early to this project and adding new integrations.
- Haier HD80-A3959 - to [gvigroux/hon](https://github.com/gvigroux/hon), [signalize/hon-app-research](https://github.com/signalize/hon-app-research) and [slegars56/hon](https://github.com/slegars56/hon) for inspiring me to do this integration and for doing pioneer work on the hOn api.
- Haier HWO60SM2F3XH - to everyone who contributed, created an issue, gave this repo a star, and used this integration.
- Hoover H-WASH 500 - to the patience of my girlfriend as I work on this integration.
- Candy CIS633SCTTWIFI
- Haier XIB 3B2SFS-80
- Haier XIB 6B2D3FB
## Supported Languages
Translation of internal names like programs are available for all languages which are official supported by the hOn app:
* 🇨🇳 Chinese
* 🇭🇷 Croatian
* 🇨🇿 Czech
* 🇳🇱 Dutch
* 🇬🇧 English
* 🇫🇷 French
* 🇩🇪 German
* 🇬🇷 Greek
* 🇮🇱 Hebrew
* 🇮🇹 Italian
* 🇵🇱 Polish
* 🇵🇹 Portuguese
* 🇷🇴 Romanian
* 🇷🇺 Russian
* 🇷🇸 Serbian
* 🇸🇰 Slovak
* 🇸🇮 Slovenian
* 🇪🇸 Spanish
* 🇹🇷 Turkish
## About this Repo
The existing integrations missed some features from the app I liked to have in HomeAssistant.
I tried to create a pull request, but in the structures of these existing repos, I find it hard to fit in my needs, so I basically rewrote everything.
I moved the api related stuff into the package [pyhOn](https://github.com/Andre0512/pyhOn).
## Appliance Features ## Appliance Features
### Air conditioner
#### Controls
| Name | Icon | Entity | Key |
| --- | --- | --- | --- |
| 10° Heating | `heat-wave` | `switch` | `10degreeHeatingStatus` |
| Air Conditioner | `air-conditioner` | `climate` | `settings` |
| Echo | `account-voice` | `switch` | `echoStatus` |
| Eco Mode | | `switch` | `ecoMode` |
| Eco Pilot | `run` | `select` | `settings.humanSensingStatus` |
| Health Mode | `medication-outline` | `switch` | `healthMode` |
| Mute | `volume-off` | `switch` | `muteStatus` |
| Rapid Mode | `run-fast` | `switch` | `rapidMode` |
| Screen Display | `monitor-small` | `switch` | `screenDisplayStatus` |
| Self Cleaning | `air-filter` | `switch` | `selfCleaningStatus` |
| Self Cleaning 56 | `air-filter` | `switch` | `selfCleaning56Status` |
| Silent Sleep | `bed` | `switch` | `silentSleepStatus` |
| Target Temperature | `thermometer` | `number` | `settings.tempSel` |
#### Sensors
| Name | Icon | Entity | Key |
| --- | --- | --- | --- |
| Air Temperature Outdoor | `thermometer` | `sensor` | `tempAirOutdoor` |
| Ch2O Cleaning | | `binary_sensor` | `ch2oCleaningStatus` |
| Coiler Temperature Indoor | `thermometer` | `sensor` | `tempCoilerIndoor` |
| Coiler Temperature Outside | `thermometer` | `sensor` | `tempCoilerOutdoor` |
| Defrost Temperature Outdoor | `thermometer` | `sensor` | `tempDefrostOutdoor` |
| Filter Replacement | | `binary_sensor` | `filterChangeStatusLocal` |
| In Air Temperature Outdoor | `thermometer` | `sensor` | `tempInAirOutdoor` |
| Indoor Temperature | `thermometer` | `sensor` | `tempIndoor` |
| Outdoor Temperature | `thermometer` | `sensor` | `tempOutdoor` |
| Program | | `select` | `startProgram.program` |
| Selected Temperature | `thermometer` | `sensor` | `tempSel` |
### Dish washer ### Dish washer
#### Controls #### Controls
| Name | Icon | Entity | Key | Auto-Translation | | Name | Icon | Entity | Key |
| --- | --- | --- | --- | --- | | --- | --- | --- | --- |
| Dish Washer | `dishwasher` | `switch` | `startProgram` / `stopProgram` | ✔ | | Buzzer Disabled | `volume-off` | `switch` | `buzzerDisabled` |
| Dish Washer | `dishwasher` | `switch` | `startProgram` / `stopProgram` |
#### Configs #### Configs
| Name | Icon | Entity | Key | Auto-Translation | | Name | Icon | Entity | Key |
| --- | --- | --- | --- | --- | | --- | --- | --- | --- |
| Add Dish | `silverware-fork-knife` | `switch` | `startProgram.addDish` | ✔ | | Add Dish | `silverware-fork-knife` | `switch` | `startProgram.addDish` |
| Delay time | `timer-plus` | `number` | `startProgram.delayTime` | ✔ | | Delay time | `timer-plus` | `number` | `startProgram.delayTime` |
| Eco Express | `sprout` | `switch` | `startProgram.ecoExpress` | ✔ | | Eco Express | `sprout` | `switch` | `startProgram.ecoExpress` |
| Eco Index | `sprout` | `sensor` | `startProgram.ecoIndex` | ❌ | | Eco Index | `sprout` | `sensor` | `startProgram.ecoIndex` |
| Energy Label | `lightning-bolt-circle` | `sensor` | `startProgram.energyLabel` | ❌ | | Energy Label | `lightning-bolt-circle` | `sensor` | `startProgram.energyLabel` |
| Extra Dry | `hair-dryer` | `switch` | `startProgram.extraDry` | ✔ | | Extra Dry | `hair-dryer` | `switch` | `startProgram.extraDry` |
| Half Load | `fraction-one-half` | `switch` | `startProgram.halfLoad` | ✔ | | Half Load | `fraction-one-half` | `switch` | `startProgram.halfLoad` |
| Open Door | `door-open` | `switch` | `startProgram.openDoor` | ✔ | | Open Door | `door-open` | `switch` | `startProgram.openDoor` |
| Program | | `select` | `startProgram.program` | ✔ | | Program | | `select` | `startProgram.program` |
| Temperature | `thermometer` | `sensor` | `startProgram.temp` | ✔ | | Remaining Time | `timer` | `select` | `startProgram.remainingTime` |
| Three in One | `numeric-3-box-outline` | `switch` | `startProgram.threeInOne` | ✔ | | Temperature | `thermometer` | `select` | `startProgram.temp` |
| Time | `timer` | `sensor` | `startProgram.remainingTime` | ✔ | | Temperature | `thermometer` | `sensor` | `startProgram.temp` |
| Water Efficiency | `water` | `sensor` | `startProgram.waterEfficiency` | ✔ | | Three in One | `numeric-3-box-outline` | `switch` | `startProgram.threeInOne` |
| Water Saving | `water-percent` | `sensor` | `startProgram.waterSaving` | ✔ | | Time | `timer` | `sensor` | `startProgram.remainingTime` |
| Water hard | `water` | `number` | `startProgram.waterHard` | ✔ | | Water Efficiency | `water` | `sensor` | `startProgram.waterEfficiency` |
| Water Saving | `water-percent` | `sensor` | `startProgram.waterSaving` |
| Water hard | `water` | `number` | `startProgram.waterHard` |
#### Sensors #### Sensors
| Name | Icon | Entity | Key | Auto-Translation | | Name | Icon | Entity | Key |
| --- | --- | --- | --- | --- | | --- | --- | --- | --- |
| Connection | | `binary_sensor` | `attributes.lastConnEvent.category` | ✔ | | Connection | | `binary_sensor` | `attributes.lastConnEvent.category` |
| Door | | `binary_sensor` | `doorStatus` | ✔ | | Door | | `binary_sensor` | `doorStatus` |
| Error | `math-log` | `sensor` | `errors` | ✔ | | Error | `math-log` | `sensor` | `errors` |
| Machine Status | `information` | `sensor` | `machMode` | ✔ | | Machine Status | `information` | `sensor` | `machMode` |
| Program Phase | `washing-machine` | `sensor` | `prPhase` | ✔ | | Program Phase | `washing-machine` | `sensor` | `prPhase` |
| Remaining Time | `timer` | `sensor` | `remainingTimeMM` | ✔ | | Remaining Time | `timer` | `sensor` | `remainingTimeMM` |
| Rinse Aid | `spray-bottle` | `binary_sensor` | `rinseAidStatus` | ✔ | | Rinse Aid | `spray-bottle` | `binary_sensor` | `rinseAidStatus` |
| Salt | `shaker-outline` | `binary_sensor` | `saltStatus` | ✔ | | Salt | `shaker-outline` | `binary_sensor` | `saltStatus` |
### Hob ### Hob
#### Controls #### Controls
| Name | Icon | Entity | Key | Auto-Translation | | Name | Icon | Entity | Key |
| --- | --- | --- | --- | --- | | --- | --- | --- | --- |
| Start Program | `pot-steam` | `button` | `startProgram` | ✔ | | Start Program | `pot-steam` | `button` | `startProgram` |
#### Configs #### Configs
| Name | Icon | Entity | Key | Auto-Translation | | Name | Icon | Entity | Key |
| --- | --- | --- | --- | --- | | --- | --- | --- | --- |
| Power Management | `timelapse` | `number` | `startProgram.powerManagement` | ✔ | | Power Management | `timelapse` | `number` | `startProgram.powerManagement` |
| Program | | `select` | `startProgram.program` | ✔ | | Program | | `select` | `startProgram.program` |
| Temperature | `thermometer` | `number` | `startProgram.temp` | ✔ | | Temperature | `thermometer` | `number` | `startProgram.temp` |
#### Sensors #### Sensors
| Name | Icon | Entity | Key | Auto-Translation | | Name | Icon | Entity | Key |
| --- | --- | --- | --- | --- | | --- | --- | --- | --- |
| Connection | `wifi` | `binary_sensor` | `attributes.lastConnEvent.category` | ✔ | | Connection | `wifi` | `binary_sensor` | `attributes.lastConnEvent.category` |
| Error | `math-log` | `sensor` | `errors` | ❌ | | Error | `math-log` | `sensor` | `errors` |
| Hob Lock | | `binary_sensor` | `hobLockStatus` | ❌ | | Hob Lock | | `binary_sensor` | `hobLockStatus` |
| Hot Status | | `binary_sensor` | `hotStatus` | ✔ | | Hot Status | | `binary_sensor` | `hotStatus` |
| On | `power-cycle` | `binary_sensor` | `attributes.parameters.onOffStatus` | ❌ | | On | `power-cycle` | `binary_sensor` | `attributes.parameters.onOffStatus` |
| Pan Status | `pot-mix` | `binary_sensor` | `panStatus` | ✔ | | Pan Status | `pot-mix` | `binary_sensor` | `panStatus` |
| Power | `lightning-bolt` | `sensor` | `power` | ✔ | | Power | `lightning-bolt` | `sensor` | `power` |
| Remaining Time | `timer` | `sensor` | `remainingTimeMM` | ✔ | | Remaining Time | `timer` | `sensor` | `remainingTimeMM` |
| Remote Control | `remote` | `binary_sensor` | `attributes.parameters.remoteCtrValid` | ✔ | | Temperature | `thermometer` | `sensor` | `temp` |
| Temperature | `thermometer` | `sensor` | `temp` | ✔ |
### Oven ### Oven
#### Controls #### Controls
| Name | Icon | Entity | Key | Auto-Translation | | Name | Icon | Entity | Key |
| --- | --- | --- | --- | --- | | --- | --- | --- | --- |
| Oven | `toaster-oven` | `switch` | `startProgram` / `stopProgram` | ✔ | | Oven | `toaster-oven` | `switch` | `startProgram` / `stopProgram` |
| Oven | `thermometer` | `climate` | `settings.tempSel` |
#### Configs #### Configs
| Name | Icon | Entity | Key | Auto-Translation | | Name | Icon | Entity | Key |
| --- | --- | --- | --- | --- | | --- | --- | --- | --- |
| Delay time | `timer-plus` | `number` | `startProgram.delayTime` | ✔ | | Delay time | `timer-plus` | `number` | `startProgram.delayTime` |
| Preheat | `thermometer-chevron-up` | `switch` | `startProgram.preheatStatus` | ✔ | | Preheat | `thermometer-chevron-up` | `switch` | `startProgram.preheatStatus` |
| Program | | `select` | `startProgram.program` | ✔ | | Program | | `select` | `startProgram.program` |
| Program Duration | `timelapse` | `number` | `startProgram.prTime` | ✔ | | Program Duration | `timelapse` | `number` | `startProgram.prTime` |
| Target Temperature | `thermometer` | `number` | `startProgram.tempSel` | ✔ | | Target Temperature | `thermometer` | `number` | `startProgram.tempSel` |
#### Sensors #### Sensors
| Name | Icon | Entity | Key | Auto-Translation | | Name | Icon | Entity | Key |
| --- | --- | --- | --- | --- | | --- | --- | --- | --- |
| Connection | `wifi` | `binary_sensor` | `attributes.lastConnEvent.category` | ✔ | | Connection | `wifi` | `binary_sensor` | `attributes.lastConnEvent.category` |
| On | `power-cycle` | `binary_sensor` | `attributes.parameters.onOffStatus` | ❌ | | On | `power-cycle` | `binary_sensor` | `attributes.parameters.onOffStatus` |
| Remaining Time | `timer` | `sensor` | `remainingTimeMM` | ✔ | | Remaining Time | `timer` | `sensor` | `remainingTimeMM` |
| Remote Control | `remote` | `binary_sensor` | `attributes.parameters.remoteCtrValid` | ✔ | | Start Time | `clock-start` | `sensor` | `delayTime` |
| Start Time | `clock-start` | `sensor` | `delayTime` | ✔ | | Temperature | `thermometer` | `sensor` | `temp` |
| Temperature | `thermometer` | `sensor` | `temp` | ✔ | | Temperature Selected | `thermometer` | `sensor` | `tempSel` |
| Temperature Selected | `thermometer` | `sensor` | `tempSel` | ✔ |
### Fridge
#### Controls
| Name | Icon | Entity | Key |
| --- | --- | --- | --- |
| Auto-Set Mode | `thermometer-auto` | `switch` | `intelligenceMode` |
| Freezer | `snowflake-thermometer` | `climate` | `settings.tempSelZ2` |
| Freezer Temperature | `thermometer` | `number` | `settings.tempSelZ2` |
| Fridge | `thermometer` | `climate` | `settings.tempSelZ1` |
| Fridge Temperature | `thermometer` | `number` | `settings.tempSelZ1` |
| Holiday Mode | `palm-tree` | `switch` | `holidayMode` |
| Program Start | `play` | `button` | `startProgram` |
| Program Stop | `stop` | `button` | `stopProgram` |
| Super Cool | `snowflake` | `switch` | `quickModeZ2` |
| Super Freeze | `snowflake-variant` | `switch` | `quickModeZ1` |
#### Configs
| Name | Icon | Entity | Key |
| --- | --- | --- | --- |
| Program | | `select` | `startProgram.program` |
| Zone | `radiobox-marked` | `select` | `startProgram.zone` |
#### Sensors
| Name | Icon | Entity | Key |
| --- | --- | --- | --- |
| Auto-Set Mode | `thermometer-auto` | `binary_sensor` | `intelligenceMode` |
| Door Status Freezer | `fridge-top` | `binary_sensor` | `doorStatusZ1` |
| Door Status Fridge | `fridge-bottom` | `binary_sensor` | `door2StatusZ1` |
| Error | `math-log` | `sensor` | `errors` |
| Holiday Mode | `palm-tree` | `binary_sensor` | `holidayMode` |
| Room Humidity | `water-percent` | `sensor` | `humidityEnv` |
| Room Temperature | `home-thermometer-outline` | `sensor` | `tempEnv` |
| Super Cool | `snowflake` | `binary_sensor` | `quickModeZ2` |
| Super Freeze | `snowflake-variant` | `binary_sensor` | `quickModeZ1` |
| Temperature Freezer | `snowflake-thermometer` | `sensor` | `tempZ2` |
| Temperature Fridge | `thermometer` | `sensor` | `tempZ1` |
### Tumble dryer ### Tumble dryer
#### Controls #### Controls
| Name | Icon | Entity | Key | Auto-Translation | | Name | Icon | Entity | Key |
| --- | --- | --- | --- | --- | | --- | --- | --- | --- |
| Pause Tumble Dryer | `pause` | `switch` | `pauseProgram` / `resumeProgram` | ✔ | | Pause Tumble Dryer | `pause` | `switch` | `pauseProgram` / `resumeProgram` |
| Tumble Dryer | `tumble-dryer` | `switch` | `startProgram` / `stopProgram` | ✔ | | Tumble Dryer | `tumble-dryer` | `switch` | `startProgram` / `stopProgram` |
#### Configs #### Configs
| Name | Icon | Entity | Key | Auto-Translation | | Name | Icon | Entity | Key |
| --- | --- | --- | --- | --- | | --- | --- | --- | --- |
| Anti-Crease | `timer` | `switch` | `startProgram.antiCreaseTime` | ✔ | | Anti-Crease | `timer` | `switch` | `startProgram.antiCreaseTime` |
| Delay time | `timer-plus` | `number` | `startProgram.delayTime` | ✔ | | Anti-Crease | `timer` | `switch` | `startProgram.anticrease` |
| Dry level | `hair-dryer` | `select` | `startProgram.dryLevel` | ✔ | | Delay time | `timer-plus` | `number` | `startProgram.delayTime` |
| Program | | `select` | `startProgram.program` | ✔ | | Dry Time | | `number` | `startProgram.dryTime` |
| Sterilization | `clock-start` | `switch` | `startProgram.sterilizationStatus` | ❌ | | Dry Time | `timer` | `select` | `startProgram.dryTimeMM` |
| Temperature level | `thermometer` | `number` | `startProgram.tempLevel` | ✔ | | Dry level | `hair-dryer` | `select` | `startProgram.dryLevel` |
| Time | `timer` | `select` | `startProgram.dryTimeMM` | ❌ | | Energy Label | `lightning-bolt-circle` | `sensor` | `startProgram.energyLabel` |
| Program | | `select` | `startProgram.program` |
| Steam Type | `weather-dust` | `sensor` | `steamType` |
| Steam level | `smoke` | `sensor` | `startProgram.steamLevel` |
| Sterilization | `clock-start` | `switch` | `startProgram.sterilizationStatus` |
| Suggested Load | `weight-kilogram` | `sensor` | `startProgram.suggestedLoadD` |
| Temperature level | `thermometer` | `number` | `startProgram.tempLevel` |
#### Sensors #### Sensors
| Name | Icon | Entity | Key | Auto-Translation | | Name | Icon | Entity | Key |
| --- | --- | --- | --- | --- | | --- | --- | --- | --- |
| Connection | | `binary_sensor` | `attributes.lastConnEvent.category` | ✔ | | Anti-Crease | | `binary_sensor` | `anticrease` |
| Door | | `binary_sensor` | `doorStatus` | ❌ | | Connection | | `binary_sensor` | `attributes.lastConnEvent.category` |
| Dry level | `hair-dryer` | `sensor` | `dryLevel` | ✔ | | Door | | `binary_sensor` | `doorStatus` |
| Error | `math-log` | `sensor` | `errors` | ✔ | | Dry level | `hair-dryer` | `sensor` | `dryLevel` |
| Machine Status | `information` | `sensor` | `machMode` | ✔ | | Error | `math-log` | `sensor` | `errors` |
| Program | `tumble-dryer` | `sensor` | `prCode` | ✔ | | Machine Status | `information` | `sensor` | `machMode` |
| Program Phase | `washing-machine` | `sensor` | `prPhase` | ✔ | | Program | `tumble-dryer` | `sensor` | `programName` |
| Remaining Time | `timer` | `sensor` | `remainingTimeMM` | ✔ | | Program Phase | `washing-machine` | `sensor` | `prPhase` |
| Start Time | `clock-start` | `sensor` | `delayTime` | ✔ | | Remaining Time | `timer` | `sensor` | `remainingTimeMM` |
| Temperature level | `thermometer` | `sensor` | `tempLevel` | ✔ | | Start Time | `clock-start` | `sensor` | `delayTime` |
| Steam level | `smoke` | `sensor` | `steamLevel` |
| Temperature level | `thermometer` | `sensor` | `tempLevel` |
### Washer dryer ### Washer dryer
#### Controls #### Controls
| Name | Icon | Entity | Key | Auto-Translation | | Name | Icon | Entity | Key |
| --- | --- | --- | --- | --- | | --- | --- | --- | --- |
| Pause Washing Machine | `pause` | `switch` | `pauseProgram` / `resumeProgram` | ✔ | | Pause Washer Dryer | `pause` | `switch` | `pauseProgram` / `resumeProgram` |
| Washing Machine | `washing-machine` | `switch` | `startProgram` / `stopProgram` | ✔ | | Washer Dryer | `washing-machine` | `switch` | `startProgram` / `stopProgram` |
#### Configs #### Configs
| Name | Icon | Entity | Key | Auto-Translation | | Name | Icon | Entity | Key |
| --- | --- | --- | --- | --- | | --- | --- | --- | --- |
| Delay Time | `timer-plus` | `number` | `startProgram.delayTime` | ✔ | | Acqua Plus | `water-plus` | `switch` | `startProgram.acquaplus` |
| Program | | `select` | `startProgram.program` | ✔ | | Anti-Crease | `timer` | `switch` | `startProgram.antiCreaseTime` |
| Suggested weight | `weight-kilogram` | `sensor` | `startProgram.weight` | ❌ | | Anti-Crease | `timer` | `switch` | `startProgram.anticrease` |
| Auto Dose Detergent | `cup` | `switch` | `startProgram.autoDetergentStatus` |
| Auto Dose Softener | `teddy-bear` | `switch` | `startProgram.autoSoftenerStatus` |
| Delay Status | `timer-check` | `switch` | `startProgram.delayStatus` |
| Delay Time | `timer-plus` | `number` | `startProgram.delayTime` |
| Dry Time | | `number` | `startProgram.dryTime` |
| Dry Time | `timer` | `select` | `startProgram.dryTimeMM` |
| Dry level | `hair-dryer` | `select` | `startProgram.dryLevel` |
| Energy Label | `lightning-bolt-circle` | `sensor` | `startProgram.energyLabel` |
| Extra Rinse 1 | `numeric-1-box-multiple-outline` | `switch` | `startProgram.extraRinse1` |
| Extra Rinse 2 | `numeric-2-box-multiple-outline` | `switch` | `startProgram.extraRinse2` |
| Extra Rinse 3 | `numeric-3-box-multiple-outline` | `switch` | `startProgram.extraRinse3` |
| Good Night | `weather-night` | `switch` | `startProgram.goodNight` |
| Keep Fresh | `refresh-circle` | `switch` | `startProgram.permanentPressStatus` |
| Liquid Detergent Dose | `cup-water` | `sensor` | `startProgram.liquidDetergentDose` |
| Main Wash Time | `clock-start` | `number` | `startProgram.mainWashTime` |
| Powder Detergent Dose | `cup` | `sensor` | `startProgram.powderDetergentDose` |
| Program | | `select` | `startProgram.program` |
| Remaining Time | `timer` | `sensor` | `startProgram.remainingTime` |
| Rinse Iterations | `rotate-right` | `number` | `startProgram.rinseIterations` |
| Soak Prewash Selection | `tshirt-crew` | `switch` | `startProgram.haier_SoakPrewashSelection` |
| Spin speed | `numeric` | `select` | `startProgram.spinSpeed` |
| Steam Level | `weather-dust` | `number` | `startProgram.steamLevel` |
| Steam Type | `weather-dust` | `sensor` | `steamType` |
| Steam level | `smoke` | `sensor` | `startProgram.steamLevel` |
| Sterilization | `clock-start` | `switch` | `startProgram.sterilizationStatus` |
| Suggested Load | `weight-kilogram` | `sensor` | `startProgram.suggestedLoadW` |
| Suggested Load | `weight-kilogram` | `sensor` | `startProgram.suggestedLoadD` |
| Suggested weight | `weight-kilogram` | `sensor` | `startProgram.weight` |
| Temperature | `thermometer` | `select` | `startProgram.temp` |
| Temperature level | `thermometer` | `number` | `startProgram.tempLevel` |
| Water hard | `water` | `number` | `startProgram.waterHard` |
| lang | | `number` | `startProgram.lang` |
#### Sensors #### Sensors
| Name | Icon | Entity | Key | Auto-Translation | | Name | Icon | Entity | Key |
| --- | --- | --- | --- | --- | | --- | --- | --- | --- |
| Acqua Plus | | `binary_sensor` | `acquaplus` | ✔ | | Acqua Plus | | `binary_sensor` | `acquaplus` |
| Anti-Crease | | `binary_sensor` | `anticrease` | ✔ | | Anti-Crease | | `binary_sensor` | `anticrease` |
| Current Electricity Used | `lightning-bolt` | `sensor` | `currentElectricityUsed` | ❌ | | Current Electricity Used | `lightning-bolt` | `sensor` | `currentElectricityUsed` |
| Current Program | `tumble-dryer` | `sensor` | `prCode` | ❌ | | Current Temperature | `thermometer` | `sensor` | `temp` |
| Current Temperature | `thermometer` | `sensor` | `temp` | ✔ | | Current Water Used | `water` | `sensor` | `currentWaterUsed` |
| Current Water Used | `water` | `sensor` | `currentWaterUsed` | ❌ | | Dirt level | `liquid-spot` | `sensor` | `dirtyLevel` |
| Dirt level | `liquid-spot` | `sensor` | `dirtyLevel` | ✔ | | Door | | `binary_sensor` | `doorStatus` |
| Dry level | `hair-dryer` | `sensor` | `dryLevel` | ✔ | | Door Lock | | `binary_sensor` | `doorLockStatus` |
| Extra Rinse 1 | | `binary_sensor` | `extraRinse1` | ✔ | | Dry level | `hair-dryer` | `sensor` | `dryLevel` |
| Extra Rinse 2 | | `binary_sensor` | `extraRinse2` | ✔ | | Error | `math-log` | `sensor` | `errors` |
| Extra Rinse 3 | | `binary_sensor` | `extraRinse3` | ✔ | | Extra Rinse 1 | | `binary_sensor` | `extraRinse1` |
| Good Night Mode | | `binary_sensor` | `goodNight` | ✔ | | Extra Rinse 2 | | `binary_sensor` | `extraRinse2` |
| Machine Status | `information` | `sensor` | `machMode` | ✔ | | Extra Rinse 3 | | `binary_sensor` | `extraRinse3` |
| Pre Wash | | `binary_sensor` | `startProgram.prewash` | ❌ | | Good Night Mode | | `binary_sensor` | `goodNight` |
| Program Phase | `washing-machine` | `sensor` | `prPhase` | ✔ | | Machine Status | `information` | `sensor` | `machMode` |
| Remaining Time | `timer` | `sensor` | `remainingTimeMM` | ✔ | | Pre Wash | | `binary_sensor` | `startProgram.prewash` |
| Remote Control | `remote` | `binary_sensor` | `attributes.lastConnEvent.category` | ✔ | | Program | `tumble-dryer` | `sensor` | `programName` |
| Spin Speed | `fast-forward-outline` | `sensor` | `spinSpeed` | ✔ | | Program Phase | `washing-machine` | `sensor` | `prPhase` |
| Steam level | `smoke` | `sensor` | `steamLevel` | ✔ | | Remaining Time | `timer` | `sensor` | `remainingTimeMM` |
| Total Power | | `sensor` | `totalElectricityUsed` | ❌ | | Remote Control | `remote` | `binary_sensor` | `attributes.lastConnEvent.category` |
| Total Wash Cycle | `counter` | `sensor` | `totalWashCycle` | ❌ | | Spin Speed | `speedometer` | `sensor` | `spinSpeed` |
| Total Water | | `sensor` | `totalWaterUsed` | ❌ | | Start Time | `clock-start` | `sensor` | `delayTime` |
| Steam level | `smoke` | `sensor` | `steamLevel` |
| Temperature level | `thermometer` | `sensor` | `tempLevel` |
| Total Power | | `sensor` | `totalElectricityUsed` |
| Total Wash Cycle | `counter` | `sensor` | `totalWashCycle` |
| Total Water | | `sensor` | `totalWaterUsed` |
### Washing machine ### Washing machine
#### Controls #### Controls
| Name | Icon | Entity | Key | Auto-Translation | | Name | Icon | Entity | Key |
| --- | --- | --- | --- | --- | | --- | --- | --- | --- |
| Pause Washing Machine | `pause` | `switch` | `pauseProgram` / `resumeProgram` | ✔ | | Pause Washing Machine | `pause` | `switch` | `pauseProgram` / `resumeProgram` |
| Washing Machine | `washing-machine` | `switch` | `startProgram` / `stopProgram` | ✔ | | Washing Machine | `washing-machine` | `switch` | `startProgram` / `stopProgram` |
#### Configs #### Configs
| Name | Icon | Entity | Key | Auto-Translation | | Name | Icon | Entity | Key |
| --- | --- | --- | --- | --- | | --- | --- | --- | --- |
| Delay Status | `timer-check` | `switch` | `startProgram.delayStatus` | ❌ | | Acqua Plus | `water-plus` | `switch` | `startProgram.acquaplus` |
| Delay Time | `timer-plus` | `number` | `startProgram.delayTime` | ✔ | | Auto Dose Detergent | `cup` | `switch` | `startProgram.autoDetergentStatus` |
| Main Wash Time | `clock-start` | `number` | `startProgram.mainWashTime` | ✔ | | Auto Dose Softener | `teddy-bear` | `switch` | `startProgram.autoSoftenerStatus` |
| Program | | `select` | `startProgram.program` | ✔ | | Delay Status | `timer-check` | `switch` | `startProgram.delayStatus` |
| Rinse Iterations | `rotate-right` | `number` | `startProgram.rinseIterations` | ✔ | | Delay Time | `timer-plus` | `number` | `startProgram.delayTime` |
| Soak Prewash Selection | `tshirt-crew` | `switch` | `startProgram.haier_SoakPrewashSelection` | ✔ | | Energy Label | `lightning-bolt-circle` | `sensor` | `startProgram.energyLabel` |
| Spin speed | `numeric` | `select` | `startProgram.spinSpeed` | ✔ | | Extra Rinse 1 | `numeric-1-box-multiple-outline` | `switch` | `startProgram.extraRinse1` |
| Suggested weight | `weight-kilogram` | `sensor` | `startProgram.weight` | ❌ | | Extra Rinse 2 | `numeric-2-box-multiple-outline` | `switch` | `startProgram.extraRinse2` |
| Temperature | `thermometer` | `select` | `startProgram.temp` | ✔ | | Extra Rinse 3 | `numeric-3-box-multiple-outline` | `switch` | `startProgram.extraRinse3` |
| Good Night | `weather-night` | `switch` | `startProgram.goodNight` |
| Keep Fresh | `refresh-circle` | `switch` | `startProgram.permanentPressStatus` |
| Liquid Detergent Dose | `cup-water` | `sensor` | `startProgram.liquidDetergentDose` |
| Main Wash Time | `clock-start` | `number` | `startProgram.mainWashTime` |
| Powder Detergent Dose | `cup` | `sensor` | `startProgram.powderDetergentDose` |
| Program | | `select` | `startProgram.program` |
| Remaining Time | `timer` | `sensor` | `startProgram.remainingTime` |
| Rinse Iterations | `rotate-right` | `number` | `startProgram.rinseIterations` |
| Soak Prewash Selection | `tshirt-crew` | `switch` | `startProgram.haier_SoakPrewashSelection` |
| Spin speed | `numeric` | `select` | `startProgram.spinSpeed` |
| Steam Level | `weather-dust` | `number` | `startProgram.steamLevel` |
| Suggested Load | `weight-kilogram` | `sensor` | `startProgram.suggestedLoadW` |
| Suggested weight | `weight-kilogram` | `sensor` | `startProgram.weight` |
| Temperature | `thermometer` | `select` | `startProgram.temp` |
| Water hard | `water` | `number` | `startProgram.waterHard` |
| lang | | `number` | `startProgram.lang` |
#### Sensors #### Sensors
| Name | Icon | Entity | Key | Auto-Translation | | Name | Icon | Entity | Key |
| --- | --- | --- | --- | --- | | --- | --- | --- | --- |
| Current Electricity Used | `lightning-bolt` | `sensor` | `currentElectricityUsed` | ❌ | | Acqua Plus | | `binary_sensor` | `acquaplus` |
| Current Water Used | `water` | `sensor` | `currentWaterUsed` | ❌ | | Current Electricity Used | `lightning-bolt` | `sensor` | `currentElectricityUsed` |
| Door | | `binary_sensor` | `doorStatus` | ❌ | | Current Temperature | `thermometer` | `sensor` | `temp` |
| Door Lock | | `binary_sensor` | `doorLockStatus` | ✔ | | Current Water Used | `water` | `sensor` | `currentWaterUsed` |
| Error | `math-log` | `sensor` | `errors` | ✔ | | Dirt level | `liquid-spot` | `sensor` | `dirtyLevel` |
| Machine Status | `information` | `sensor` | `machMode` | ✔ | | Door | | `binary_sensor` | `doorStatus` |
| Program Phase | `washing-machine` | `sensor` | `prPhase` | ✔ | | Door Lock | | `binary_sensor` | `doorLockStatus` |
| Remaining Time | `timer` | `sensor` | `remainingTimeMM` | ✔ | | Error | `math-log` | `sensor` | `errors` |
| Remote Control | `remote` | `binary_sensor` | `attributes.lastConnEvent.category` | ✔ | | Extra Rinse 1 | | `binary_sensor` | `extraRinse1` |
| Spin Speed | `speedometer` | `sensor` | `spinSpeed` | ✔ | | Extra Rinse 2 | | `binary_sensor` | `extraRinse2` |
| Total Power | | `sensor` | `totalElectricityUsed` | ❌ | | Extra Rinse 3 | | `binary_sensor` | `extraRinse3` |
| Total Wash Cycle | `counter` | `sensor` | `totalWashCycle` | ❌ | | Good Night Mode | | `binary_sensor` | `goodNight` |
| Total Water | | `sensor` | `totalWaterUsed` | ❌ | | Machine Status | `information` | `sensor` | `machMode` |
| Pre Wash | | `binary_sensor` | `startProgram.prewash` |
| Program Phase | `washing-machine` | `sensor` | `prPhase` |
| Remaining Time | `timer` | `sensor` | `remainingTimeMM` |
| Remote Control | `remote` | `binary_sensor` | `attributes.lastConnEvent.category` |
| Spin Speed | `speedometer` | `sensor` | `spinSpeed` |
| Total Power | | `sensor` | `totalElectricityUsed` |
| Total Wash Cycle | `counter` | `sensor` | `totalWashCycle` |
| Total Water | | `sensor` | `totalWaterUsed` |

BIN
assets/washing_machine.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 202 KiB

View File

@ -1,8 +1,6 @@
import logging import logging
from dataclasses import dataclass from dataclasses import dataclass
from pyhon import Hon
from homeassistant.components.binary_sensor import ( from homeassistant.components.binary_sensor import (
BinarySensorEntityDescription, BinarySensorEntityDescription,
BinarySensorDeviceClass, BinarySensorDeviceClass,
@ -10,8 +8,9 @@ from homeassistant.components.binary_sensor import (
) )
from homeassistant.config_entries import ConfigEntry from homeassistant.config_entries import ConfigEntry
from homeassistant.core import callback from homeassistant.core import callback
from .const import DOMAIN from .const import DOMAIN
from .hon import HonCoordinator, HonEntity from .hon import HonEntity, unique_entities
_LOGGER = logging.getLogger(__name__) _LOGGER = logging.getLogger(__name__)
@ -50,6 +49,25 @@ BINARY_SENSORS: dict[str, tuple[HonBinarySensorEntityDescription, ...]] = {
name="Door", name="Door",
device_class=BinarySensorDeviceClass.DOOR, device_class=BinarySensorDeviceClass.DOOR,
on_value="1", on_value="1",
translation_key="door_open",
),
HonBinarySensorEntityDescription(
key="startProgram.prewash", name="Pre Wash", translation_key="prewash"
),
HonBinarySensorEntityDescription(
key="extraRinse1", name="Extra Rinse 1", translation_key="extra_rinse_1"
),
HonBinarySensorEntityDescription(
key="extraRinse2", name="Extra Rinse 2", translation_key="extra_rinse_2"
),
HonBinarySensorEntityDescription(
key="extraRinse3", name="Extra Rinse 3", translation_key="extra_rinse_3"
),
HonBinarySensorEntityDescription(
key="goodNight", name="Good Night Mode", translation_key="good_night"
),
HonBinarySensorEntityDescription(
key="acquaplus", name="Acqua Plus", translation_key="acqua_plus"
), ),
), ),
"TD": ( "TD": (
@ -65,35 +83,7 @@ BINARY_SENSORS: dict[str, tuple[HonBinarySensorEntityDescription, ...]] = {
name="Door", name="Door",
device_class=BinarySensorDeviceClass.DOOR, device_class=BinarySensorDeviceClass.DOOR,
on_value="1", on_value="1",
), translation_key="door_open",
),
"WD": (
HonBinarySensorEntityDescription(
key="attributes.lastConnEvent.category",
name="Remote Control",
device_class=BinarySensorDeviceClass.CONNECTIVITY,
on_value="CONNECTED",
icon="mdi:remote",
translation_key="remote_control",
),
HonBinarySensorEntityDescription(
key="startProgram.prewash",
name="Pre Wash",
),
HonBinarySensorEntityDescription(
key="extraRinse1", name="Extra Rinse 1", translation_key="extra_rinse_1"
),
HonBinarySensorEntityDescription(
key="extraRinse2", name="Extra Rinse 2", translation_key="extra_rinse_2"
),
HonBinarySensorEntityDescription(
key="extraRinse3", name="Extra Rinse 3", translation_key="extra_rinse_3"
),
HonBinarySensorEntityDescription(
key="goodNight", name="Good Night Mode", translation_key="good_night"
),
HonBinarySensorEntityDescription(
key="acquaplus", name="Acqua Plus", translation_key="aqua_plus"
), ),
HonBinarySensorEntityDescription( HonBinarySensorEntityDescription(
key="anticrease", name="Anti-Crease", translation_key="anti_crease" key="anticrease", name="Anti-Crease", translation_key="anti_crease"
@ -108,20 +98,13 @@ BINARY_SENSORS: dict[str, tuple[HonBinarySensorEntityDescription, ...]] = {
icon="mdi:wifi", icon="mdi:wifi",
translation_key="connection", translation_key="connection",
), ),
HonBinarySensorEntityDescription(
key="attributes.parameters.remoteCtrValid",
name="Remote Control",
device_class=BinarySensorDeviceClass.CONNECTIVITY,
on_value="1",
icon="mdi:remote",
translation_key="remote_control",
),
HonBinarySensorEntityDescription( 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",
), ),
), ),
"IH": ( "IH": (
@ -133,20 +116,13 @@ BINARY_SENSORS: dict[str, tuple[HonBinarySensorEntityDescription, ...]] = {
icon="mdi:wifi", icon="mdi:wifi",
translation_key="connection", translation_key="connection",
), ),
HonBinarySensorEntityDescription(
key="attributes.parameters.remoteCtrValid",
name="Remote Control",
device_class=BinarySensorDeviceClass.CONNECTIVITY,
on_value="1",
icon="mdi:remote",
translation_key="remote_control",
),
HonBinarySensorEntityDescription( 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",
), ),
HonBinarySensorEntityDescription( HonBinarySensorEntityDescription(
key="hotStatus", key="hotStatus",
@ -167,6 +143,7 @@ BINARY_SENSORS: dict[str, tuple[HonBinarySensorEntityDescription, ...]] = {
name="Hob Lock", name="Hob Lock",
device_class=BinarySensorDeviceClass.LOCK, device_class=BinarySensorDeviceClass.LOCK,
on_value="0", on_value="0",
translation_key="child_lock",
), ),
), ),
"DW": ( "DW": (
@ -201,50 +178,91 @@ BINARY_SENSORS: dict[str, tuple[HonBinarySensorEntityDescription, ...]] = {
translation_key="door_open", translation_key="door_open",
), ),
), ),
"AC": (
HonBinarySensorEntityDescription(
key="filterChangeStatusLocal",
name="Filter Replacement",
device_class=BinarySensorDeviceClass.PROBLEM,
on_value="1",
translation_key="filter_replacement",
),
HonBinarySensorEntityDescription(
key="ch2oCleaningStatus",
name="Ch2O Cleaning",
on_value="1",
),
),
"REF": (
HonBinarySensorEntityDescription(
key="quickModeZ2",
name="Super Cool",
icon="mdi:snowflake",
device_class=BinarySensorDeviceClass.RUNNING,
on_value="1",
translation_key="super_cool",
),
HonBinarySensorEntityDescription(
key="quickModeZ1",
name="Super Freeze",
icon="mdi:snowflake-variant",
device_class=BinarySensorDeviceClass.RUNNING,
on_value="1",
translation_key="super_freeze",
),
HonBinarySensorEntityDescription(
key="doorStatusZ1",
name="Door Status Freezer",
device_class=BinarySensorDeviceClass.DOOR,
icon="mdi:fridge-top",
on_value="1",
translation_key="freezer_door",
),
HonBinarySensorEntityDescription(
key="door2StatusZ1",
name="Door Status Fridge",
icon="mdi:fridge-bottom",
device_class=BinarySensorDeviceClass.DOOR,
on_value="1",
translation_key="fridge_door",
),
HonBinarySensorEntityDescription(
key="intelligenceMode",
name="Auto-Set Mode",
icon="mdi:thermometer-auto",
device_class=BinarySensorDeviceClass.RUNNING,
on_value="1",
translation_key="auto_set",
),
HonBinarySensorEntityDescription(
key="holidayMode",
name="Holiday Mode",
icon="mdi:palm-tree",
device_class=BinarySensorDeviceClass.RUNNING,
on_value="1",
translation_key="holiday_mode",
),
),
} }
BINARY_SENSORS["WD"] = unique_entities(BINARY_SENSORS["WM"], BINARY_SENSORS["TD"])
async def async_setup_entry(hass, entry: ConfigEntry, async_add_entities) -> None: async def async_setup_entry(hass, entry: ConfigEntry, async_add_entities) -> None:
hon: Hon = hass.data[DOMAIN][entry.unique_id] entities = []
coordinators = hass.data[DOMAIN]["coordinators"] for device in hass.data[DOMAIN][entry.unique_id].appliances:
appliances = [] for description in BINARY_SENSORS.get(device.appliance_type, []):
for device in hon.appliances: if not device.get(description.key):
if device.unique_id in coordinators: continue
coordinator = hass.data[DOMAIN]["coordinators"][device.unique_id] entity = HonBinarySensorEntity(hass, entry, device, description)
else: await entity.coordinator.async_config_entry_first_refresh()
coordinator = HonCoordinator(hass, device) entities.append(entity)
hass.data[DOMAIN]["coordinators"][device.unique_id] = coordinator async_add_entities(entities)
await coordinator.async_config_entry_first_refresh()
if descriptions := BINARY_SENSORS.get(device.appliance_type):
for description in descriptions:
if not device.get(description.key):
_LOGGER.warning(
"[%s] Can't setup %s", device.appliance_type, description.key
)
continue
appliances.extend(
[
HonBinarySensorEntity(
hass, coordinator, entry, device, description
)
]
)
async_add_entities(appliances)
class HonBinarySensorEntity(HonEntity, BinarySensorEntity): class HonBinarySensorEntity(HonEntity, BinarySensorEntity):
entity_description: HonBinarySensorEntityDescription entity_description: HonBinarySensorEntityDescription
def __init__(self, hass, coordinator, entry, device, description) -> None:
super().__init__(hass, entry, coordinator, device)
self._coordinator = coordinator
self.entity_description = description
self._attr_unique_id = f"{super().unique_id}{description.key}"
@property @property
def is_on(self) -> bool: def is_on(self) -> bool:
return ( return (

View File

@ -1,15 +1,14 @@
import logging import logging
import urllib
from urllib.parse import quote
import pkg_resources
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 pyhon import Hon from homeassistant.const import EntityCategory
from pyhon.appliance import HonAppliance from pyhon.appliance import HonAppliance
from homeassistant.const import EntityCategory
from .const import DOMAIN from .const import DOMAIN
from .hon import HonCoordinator, HonEntity from .hon import HonEntity
_LOGGER = logging.getLogger(__name__) _LOGGER = logging.getLogger(__name__)
@ -22,58 +21,68 @@ BUTTONS: dict[str, tuple[ButtonEntityDescription, ...]] = {
translation_key="induction_hob", translation_key="induction_hob",
), ),
), ),
"REF": (
ButtonEntityDescription(
key="startProgram",
name="Program Start",
icon="mdi:play",
translation_key="start_program",
),
ButtonEntityDescription(
key="stopProgram",
name="Program Stop",
icon="mdi:stop",
translation_key="stop_program",
),
),
} }
async def async_setup_entry(hass, entry: ConfigEntry, async_add_entities) -> None: async def async_setup_entry(hass, entry: ConfigEntry, async_add_entities) -> None:
hon: Hon = hass.data[DOMAIN][entry.unique_id] entities = []
coordinators = hass.data[DOMAIN]["coordinators"] for device in hass.data[DOMAIN][entry.unique_id].appliances:
appliances = [] for description in BUTTONS.get(device.appliance_type, []):
for device in hon.appliances: if not device.commands.get(description.key):
if device.unique_id in coordinators: continue
coordinator = hass.data[DOMAIN]["coordinators"][device.unique_id] entity = HonButtonEntity(hass, entry, device, description)
else: await entity.coordinator.async_config_entry_first_refresh()
coordinator = HonCoordinator(hass, device) entities.append(entity)
hass.data[DOMAIN]["coordinators"][device.unique_id] = coordinator entities.append(HonFeatureRequestButton(hass, entry, device))
await coordinator.async_config_entry_first_refresh() await entities[-1].coordinator.async_config_entry_first_refresh()
async_add_entities(entities)
if descriptions := BUTTONS.get(device.appliance_type):
for description in descriptions:
if not device.commands.get(description.key):
continue
appliances.extend(
[HonButtonEntity(hass, coordinator, entry, device, description)]
)
appliances.extend([HonFeatureRequestButton(hass, coordinator, entry, device)])
async_add_entities(appliances)
class HonButtonEntity(HonEntity, ButtonEntity): class HonButtonEntity(HonEntity, ButtonEntity):
def __init__( entity_description: ButtonEntityDescription
self, hass, coordinator, entry, device: HonAppliance, description
) -> None:
super().__init__(hass, entry, coordinator, device)
self._coordinator = coordinator
self._device = device
self.entity_description = description
self._attr_unique_id = f"{super().unique_id}{description.key}"
async def async_press(self) -> None: async def async_press(self) -> None:
await self._device.commands[self.entity_description.key].send() await self._device.commands[self.entity_description.key].send()
@property
def available(self) -> bool:
"""Return True if entity is available."""
return (
super().available
and self._device.get("remoteCtrValid", "1") == "1"
and self._device.get("attributes.lastConnEvent.category") != "DISCONNECTED"
)
class HonFeatureRequestButton(HonEntity, ButtonEntity): class HonFeatureRequestButton(HonEntity, ButtonEntity):
def __init__(self, hass, coordinator, entry, device: HonAppliance) -> None: def __init__(self, hass, entry, device: HonAppliance) -> None:
super().__init__(hass, entry, coordinator, device) super().__init__(hass, entry, device)
self._device = device
self._attr_unique_id = f"{super().unique_id}_log_device_info" self._attr_unique_id = f"{super().unique_id}_log_device_info"
self._attr_icon = "mdi:information" self._attr_icon = "mdi:information"
self._attr_name = "Log 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 self._attr_entity_registry_enabled_default = False
async def async_press(self) -> None: async def async_press(self) -> None:
_LOGGER.error("Device Info:\n" + self._device.diagnose) pyhon_version = pkg_resources.get_distribution("pyhon").version
info = f"{self._device.diagnose()}pyhOnVersion: {pyhon_version}"
title = f"{self._device.nick_name} Device Info"
persistent_notification.create(
self._hass, f"````\n```\n{info}\n```\n````", title
)
_LOGGER.info(info.replace(" ", "\u200B "))

View File

@ -0,0 +1,305 @@
import logging
from dataclasses import dataclass
from pyhon.appliance import HonAppliance
from homeassistant.components.climate import (
ClimateEntity,
ClimateEntityDescription,
)
from homeassistant.components.climate.const import (
FAN_OFF,
SWING_OFF,
SWING_BOTH,
SWING_VERTICAL,
SWING_HORIZONTAL,
ClimateEntityFeature,
HVACMode,
)
from homeassistant.config_entries import ConfigEntry
from homeassistant.const import (
ATTR_TEMPERATURE,
TEMP_CELSIUS,
)
from homeassistant.core import callback
from .const import HON_HVAC_MODE, HON_FAN, HON_HVAC_PROGRAM, DOMAIN
from .hon import HonEntity
_LOGGER = logging.getLogger(__name__)
@dataclass
class HonACClimateEntityDescription(ClimateEntityDescription):
pass
@dataclass
class HonClimateEntityDescription(ClimateEntityDescription):
mode: HVACMode = "auto"
CLIMATES = {
"AC": (
HonACClimateEntityDescription(
key="settings",
name="Air Conditioner",
icon="mdi:air-conditioner",
translation_key="air_conditioner",
),
),
"REF": (
HonClimateEntityDescription(
key="settings.tempSelZ1",
mode=HVACMode.COOL,
name="Fridge",
icon="mdi:thermometer",
translation_key="fridge",
),
HonClimateEntityDescription(
key="settings.tempSelZ2",
mode=HVACMode.COOL,
name="Freezer",
icon="mdi:snowflake-thermometer",
translation_key="freezer",
),
),
"OV": (
HonClimateEntityDescription(
key="settings.tempSel",
mode=HVACMode.HEAT,
name="Oven",
icon="mdi:thermometer",
translation_key="oven",
),
),
}
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 CLIMATES.get(device.appliance_type, []):
if isinstance(description, HonACClimateEntityDescription):
if description.key not in list(device.commands):
continue
entity = HonACClimateEntity(hass, entry, device, description)
elif isinstance(description, HonClimateEntityDescription):
if description.key not in device.available_settings:
continue
entity = HonClimateEntity(hass, entry, device, description)
else:
continue
await entity.coordinator.async_config_entry_first_refresh()
entities.append(entity)
async_add_entities(entities)
class HonACClimateEntity(HonEntity, ClimateEntity):
def __init__(self, hass, entry, device: HonAppliance, description) -> None:
super().__init__(hass, entry, device, description)
self._attr_temperature_unit = TEMP_CELSIUS
self._attr_target_temperature_step = device.settings["settings.tempSel"].step
self._attr_max_temp = device.settings["settings.tempSel"].max
self._attr_min_temp = device.settings["settings.tempSel"].min
self._attr_hvac_modes = [HVACMode.OFF] + [
HON_HVAC_MODE[mode] for mode in device.settings["settings.machMode"].values
]
self._attr_fan_modes = [FAN_OFF] + [
HON_FAN[mode] for mode in device.settings["settings.windSpeed"].values
]
self._attr_swing_modes = [
SWING_OFF,
SWING_VERTICAL,
SWING_HORIZONTAL,
SWING_BOTH,
]
self._attr_supported_features = (
ClimateEntityFeature.TARGET_TEMPERATURE
| ClimateEntityFeature.FAN_MODE
| ClimateEntityFeature.SWING_MODE
)
self._handle_coordinator_update(update=False)
@property
def hvac_mode(self) -> HVACMode | str | None:
if self._device.get("onOffStatus") == "0":
return HVACMode.OFF
else:
return HON_HVAC_MODE[self._device.get("machMode")]
async def async_set_hvac_mode(self, hvac_mode):
if hvac_mode == HVACMode.OFF:
await self._device.commands["stopProgram"].send()
else:
self._device.settings["startProgram.program"].value = HON_HVAC_PROGRAM[
hvac_mode
]
await self._device.commands["startProgram"].send()
self._attr_hvac_mode = hvac_mode
self.async_write_ha_state()
async def async_set_fan_mode(self, fan_mode):
mode_number = list(HON_FAN.values()).index(fan_mode)
self._device.settings["settings.windSpeed"].value = list(HON_FAN.keys())[
mode_number
]
await self._device.commands["settings"].send()
self.async_write_ha_state()
async def async_set_swing_mode(self, swing_mode):
horizontal = self._device.settings["settings.windDirectionHorizontal"]
vertical = self._device.settings["settings.windDirectionVertical"]
if swing_mode in [SWING_BOTH, SWING_HORIZONTAL]:
horizontal.value = "7"
if swing_mode in [SWING_BOTH, SWING_VERTICAL]:
vertical.value = "8"
if swing_mode in [SWING_OFF, SWING_HORIZONTAL] and vertical.value == "8":
vertical.value = "5"
if swing_mode in [SWING_OFF, SWING_VERTICAL] and horizontal.value == "7":
horizontal.value = "0"
self._attr_swing_mode = swing_mode
await self._device.commands["settings"].send()
self.async_write_ha_state()
async def async_set_temperature(self, **kwargs):
if (temperature := kwargs.get(ATTR_TEMPERATURE)) is None:
return False
self._device.settings["settings.tempSel"].value = str(int(temperature))
await self._device.commands["settings"].send()
self.async_write_ha_state()
@callback
def _handle_coordinator_update(self, update=True) -> None:
self._attr_target_temperature = int(float(self._device.get("tempSel")))
self._attr_current_temperature = float(self._device.get("tempIndoor"))
if self._device.get("onOffStatus") == "0":
self._attr_hvac_mode = HVACMode.OFF
else:
self._attr_hvac_mode = HON_HVAC_MODE[self._device.get("machMode")]
self._attr_fan_mode = HON_FAN[self._device.get("windSpeed")]
horizontal = self._device.get("windDirectionHorizontal")
vertical = self._device.get("windDirectionVertical")
if horizontal == "7" and vertical == "8":
self._attr_swing_mode = SWING_BOTH
elif horizontal == "7":
self._attr_swing_mode = SWING_HORIZONTAL
elif vertical == "8":
self._attr_swing_mode = SWING_VERTICAL
else:
self._attr_swing_mode = SWING_OFF
if update:
self.async_write_ha_state()
class HonClimateEntity(HonEntity, ClimateEntity):
entity_description = HonClimateEntityDescription
def __init__(self, hass, entry, device: HonAppliance, description) -> None:
super().__init__(hass, entry, device, description)
self._attr_temperature_unit = TEMP_CELSIUS
self._set_temperature_bound()
self._attr_supported_features = (
ClimateEntityFeature.TARGET_TEMPERATURE | ClimateEntityFeature.PRESET_MODE
)
self._attr_hvac_modes = [description.mode]
if device.get("onOffStatus"):
self._attr_hvac_modes += [HVACMode.OFF]
modes = []
else:
modes = ["no_mode"]
for mode, data in device.commands["startProgram"].categories.items():
if mode not in data.parameters["program"].values:
continue
if zone := data.parameters.get("zone"):
if self.entity_description.name.lower() in zone.values:
modes.append(mode)
else:
modes.append(mode)
self._attr_preset_modes = modes
self._handle_coordinator_update(update=False)
@property
def target_temperature(self) -> int | None:
"""Return the temperature we try to reach."""
return int(self._device.get(self.entity_description.key))
@property
def current_temperature(self) -> int | None:
"""Return the current temperature."""
temp_key = self.entity_description.key.split(".")[-1].replace("Sel", "")
return int(self._device.get(temp_key))
async def async_set_temperature(self, **kwargs):
if (temperature := kwargs.get(ATTR_TEMPERATURE)) is None:
return False
self._device.settings[self.entity_description.key].value = str(int(temperature))
await self._device.commands["settings"].send()
self.async_write_ha_state()
@property
def hvac_mode(self) -> HVACMode | str | None:
if self._device.get("onOffStatus") == "0":
return HVACMode.OFF
else:
return self.entity_description.mode
async def async_set_hvac_mode(self, hvac_mode):
if len(self.hvac_modes) <= 1:
return
if hvac_mode == HVACMode.OFF:
await self._device.commands["stopProgram"].send()
else:
await self._device.commands["startProgram"].send()
self._attr_hvac_mode = hvac_mode
self.async_write_ha_state()
@property
def preset_mode(self) -> str | None:
"""Return the current Preset for this channel."""
if self._device.get("onOffStatus") is not None:
return self._device.get("programName", "")
else:
return self._device.get(
f"mode{self.entity_description.key[-2:]}", "no_mode"
)
async def async_set_preset_mode(self, preset_mode: str) -> None:
"""Set the new preset mode."""
command = "stopProgram" if preset_mode == "no_mode" else "startProgram"
if program := self._device.settings.get(f"{command}.program"):
program.value = preset_mode
if zone := self._device.settings.get(f"{command}.zone"):
zone.value = self.entity_description.name.lower()
self._device.sync_command(command, "settings")
self._set_temperature_bound()
await self.coordinator.async_refresh()
await self._device.commands[command].send()
self._attr_preset_mode = preset_mode
self.async_write_ha_state()
def _set_temperature_bound(self):
self._attr_target_temperature_step = self._device.settings[
self.entity_description.key
].step
self._attr_max_temp = self._device.settings[self.entity_description.key].max
self._attr_min_temp = self._device.settings[self.entity_description.key].min
@callback
def _handle_coordinator_update(self, update=True) -> None:
self._attr_target_temperature = self.target_temperature
self._attr_current_temperature = self.current_temperature
self._attr_hvac_mode = self.hvac_mode
self._attr_preset_mode = self.preset_mode
if update:
self.async_write_ha_state()

View File

@ -1,7 +1,6 @@
import logging import logging
import voluptuous as vol import voluptuous as vol
from homeassistant import config_entries from homeassistant import config_entries
from homeassistant.const import CONF_EMAIL, CONF_PASSWORD from homeassistant.const import CONF_EMAIL, CONF_PASSWORD

View File

@ -1,3 +1,11 @@
from homeassistant.components.climate import (
HVACMode,
FAN_LOW,
FAN_MEDIUM,
FAN_HIGH,
FAN_AUTO,
)
DOMAIN = "hon" DOMAIN = "hon"
PLATFORMS = [ PLATFORMS = [
@ -7,4 +15,309 @@ PLATFORMS = [
"switch", "switch",
"button", "button",
"binary_sensor", "binary_sensor",
"climate",
]
HON_HVAC_MODE = {
"0": HVACMode.AUTO,
"1": HVACMode.COOL,
"2": HVACMode.DRY,
"3": HVACMode.DRY,
"4": HVACMode.HEAT,
"5": HVACMode.FAN_ONLY,
"6": HVACMode.FAN_ONLY,
}
HON_HVAC_PROGRAM = {
HVACMode.AUTO: "iot_auto",
HVACMode.COOL: "iot_cool",
HVACMode.DRY: "iot_dry",
HVACMode.HEAT: "iot_heat",
HVACMode.FAN_ONLY: "iot_fan",
}
HON_FAN = {
"1": FAN_HIGH,
"2": FAN_MEDIUM,
"3": FAN_LOW,
"4": FAN_AUTO,
"5": FAN_AUTO,
}
# These languages are official supported by hOn
LANGUAGES = [
"cs", # Czech
"de", # German
"el", # Greek
"en", # English
"es", # Spanish
"fr", # French
"he", # Hebrew
"hr", # Croatian
"it", # Italian
"nl", # Dutch
"pl", # Polish
"pt", # Portuguese
"ro", # Romanian
"ru", # Russian
"sk", # Slovak
"sl", # Slovenian
"sr", # Serbian
"tr", # Turkish
"zh", # Chinese
]
WASHING_PR_PHASE = {
"0": "WASHING_CMD&CTRL.PHASE_READY.TITLE",
"1": "WASHING_CMD&CTRL.PHASE_WASHING.TITLE",
"2": "WASHING_CMD&CTRL.PHASE_WASHING.TITLE",
"3": "WASHING_CMD&CTRL.PHASE_SPIN.TITLE",
"4": "WASHING_CMD&CTRL.PHASE_RINSE.TITLE",
"5": "WASHING_CMD&CTRL.PHASE_RINSE.TITLE",
"6": "WASHING_CMD&CTRL.PHASE_RINSE.TITLE",
"7": "WASHING_CMD&CTRL.PHASE_DRYING.TITLE",
"9": "WASHING_CMD&CTRL.PHASE_STEAM.TITLE",
"10": "WASHING_CMD&CTRL.PHASE_READY.TITLE",
"11": "WASHING_CMD&CTRL.PHASE_SPIN.TITLE",
"12": "WASHING_CMD&CTRL.PHASE_WEIGHTING.TITLE",
"13": "WASHING_CMD&CTRL.PHASE_WEIGHTING.TITLE",
"14": "WASHING_CMD&CTRL.PHASE_WASHING.TITLE",
"15": "WASHING_CMD&CTRL.PHASE_WASHING.TITLE",
"16": "WASHING_CMD&CTRL.PHASE_WASHING.TITLE",
"17": "WASHING_CMD&CTRL.PHASE_RINSE.TITLE",
"18": "WASHING_CMD&CTRL.PHASE_RINSE.TITLE",
"19": "WASHING_CMD&CTRL.PHASE_SCHEDULED.TITLE",
"20": "WASHING_CMD&CTRL.PHASE_TUMBLING.TITLE",
"24": "WASHING_CMD&CTRL.PHASE_REFRESH.TITLE",
"25": "WASHING_CMD&CTRL.PHASE_WASHING.TITLE",
"26": "WASHING_CMD&CTRL.PHASE_HEATING.TITLE",
"27": "WASHING_CMD&CTRL.PHASE_WASHING.TITLE",
}
MACH_MODE = {
"0": "WASHING_CMD&CTRL.PHASE_READY.TITLE", # NO_STATE
"1": "WASHING_CMD&CTRL.PHASE_READY.TITLE", # SELECTION_MODE
"2": "WASHING_CMD&CTRL.PHASE_RUNNING.TITLE", # EXECUTION_MODE
"3": "WASHING_CMD&CTRL.PHASE_PAUSE.TITLE", # PAUSE_MODE
"4": "WASHING_CMD&CTRL.PHASE_SCHEDULED.TITLE", # DELAY_START_SELECTION_MODE
"5": "WASHING_CMD&CTRL.PHASE_SCHEDULED.TITLE", # DELAY_START_EXECUTION_MODE
"6": "WASHING_CMD&CTRL.PHASE_ERROR.TITLE", # ERROR_MODE
"7": "WASHING_CMD&CTRL.PHASE_READY.TITLE", # END_MODE
"8": "Test", # TEST_MODE
"9": "GLOBALS.APPLIANCE_STATUS.ENDING_PROGRAM", # STOP_MODE
}
TUMBLE_DRYER_PR_PHASE = {
"0": "WASHING_CMD&CTRL.PHASE_READY.TITLE",
"1": "TD_CMD&CTRL.STATUS_PHASE.PHASE_HEAT_STROKE",
"2": "WASHING_CMD&CTRL.PHASE_DRYING.TITLE",
"3": "TD_CMD&CTRL.STATUS_PHASE.PHASE_COOLDOWN",
"11": "WASHING_CMD&CTRL.PHASE_READY.TITLE",
"13": "TD_CMD&CTRL.STATUS_PHASE.PHASE_COOLDOWN",
"14": "TD_CMD&CTRL.STATUS_PHASE.PHASE_HEAT_STROKE",
"15": "TD_CMD&CTRL.STATUS_PHASE.PHASE_HEAT_STROKE",
"16": "TD_CMD&CTRL.STATUS_PHASE.PHASE_COOLDOWN",
"17": "unknown",
"18": "WASHING_CMD&CTRL.PHASE_TUMBLING.DASHBOARD_TITLE",
"19": "WASHING_CMD&CTRL.PHASE_DRYING.TITLE",
"20": "WASHING_CMD&CTRL.PHASE_DRYING.TITLE",
}
DIRTY_LEVEL = {
"1": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OPTIONS_VALUES_DESCRIPTION.LITTLE",
"2": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OPTIONS_VALUES_DESCRIPTION.NORMAL",
"3": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OPTIONS_VALUES_DESCRIPTION.VERY",
}
STEAM_LEVEL = {
"0": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OPTIONS_VALUES_DESCRIPTION.NO_STEAM",
"1": "WASHING_CMD&CTRL.GUIDED_WASHING_SYMBOLS_FABRICS.COTTON_TITLE",
"2": "WASHING_CMD&CTRL.GUIDED_WASHING_SYMBOLS_FABRICS.DELICATE_TITLE",
"3": "WASHING_CMD&CTRL.GUIDED_WASHING_SYMBOLS_FABRICS.SYNTHETIC_TITLE",
}
DISHWASHER_PR_PHASE = {
"0": "WASHING_CMD&CTRL.PHASE_READY.TITLE",
"1": "WASHING_CMD&CTRL.PHASE_PREWASH.TITLE",
"2": "WASHING_CMD&CTRL.PHASE_WASHING.TITLE",
"3": "WASHING_CMD&CTRL.PHASE_RINSE.TITLE",
"4": "WASHING_CMD&CTRL.PHASE_DRYING.TITLE",
"5": "WASHING_CMD&CTRL.PHASE_READY.TITLE",
"6": "WASHING_CMD&CTRL.PHASE_HOT_RINSE.TITLE",
}
TUMBLE_DRYER_DRY_LEVEL = {
"0": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_MAIN_OPTIONS.NO_DRY",
"1": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OPTIONS_VALUES_DESCRIPTION.IRON_DRY",
"2": "WASHING_CMD&CTRL.GUIDED_WASHING_SYMBOLS_DRYING.NO_DRY_IRON_TITLE",
"3": "WASHING_CMD&CTRL.GUIDED_WASHING_SYMBOLS_DRYING.CUPBOARD_DRY_TITLE",
"4": "WASHING_CMD&CTRL.GUIDED_WASHING_SYMBOLS_DRYING.EXTRA_DRY_TITLE",
"11": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_MAIN_OPTIONS.NO_DRY",
"12": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OPTIONS_VALUES_DESCRIPTION.IRON_DRY",
"13": "WASHING_CMD&CTRL.GUIDED_WASHING_SYMBOLS_DRYING.CUPBOARD_DRY_TITLE",
"14": "WASHING_CMD&CTRL.GUIDED_WASHING_SYMBOLS_DRYING.READY_TO_WEAR_TITLE",
"15": "WASHING_CMD&CTRL.GUIDED_WASHING_SYMBOLS_DRYING.EXTRA_DRY_TITLE",
}
AC_MACH_MODE = {
"0": "PROGRAMS.AC.IOT_AUTO",
"1": "PROGRAMS.AC.IOT_COOL",
"2": "PROGRAMS.AC.IOT_COOL",
"3": "PROGRAMS.AC.IOT_DRY",
"4": "PROGRAMS.AC.IOT_HEAT",
"5": "PROGRAMS.AC.IOT_FAN",
"6": "PROGRAMS.AC.IOT_FAN",
}
AC_FAN_MODE = {
"1": "AC.PROGRAM_CARD.WIND_SPEED_HIGH",
"2": "AC.PROGRAM_CARD.WIND_SPEED_MID",
"3": "AC.PROGRAM_CARD.WIND_SPEED_LOW",
"4": "AC.PROGRAM_CARD.WIND_SPEED_AUTO",
"5": "AC.PROGRAM_CARD.WIND_SPEED_AUTO",
}
AC_HUMAN_SENSE = {
"0": "AC.PROGRAM_DETAIL.TOUCH_OFF",
"1": "AC.PROGRAM_DETAIL.AVOID_TOUCH",
"2": "AC.PROGRAM_DETAIL.FOLLOW_TOUCH",
}
REF_ZONES = {
"fridge": "REF.ZONES.FRIDGE",
"freezer": "REF.ZONES.FREEZER",
"vtroom1": "REF.ZONES.MY_ZONE_1",
"fridge_freezer": ["REF.ZONES.FRIDGE", " & ", "REF.ZONES.FREEZER"],
}
PROGRAMS_TD = [
"active_dry",
"allergy_care",
"all_in_one",
"antiallergy",
"anti_odours",
"auto_care",
"baby",
"bed_quilt",
"care_30",
"care_45",
"care_59",
"coloured",
"daily_45_min",
"daily_perfect_59_min",
"darks_and_coloured",
"delicates",
"duvet",
"eco",
"ecospeed_cottons",
"ecospeed_delicates",
"ecospeed_mixed",
"extra_hygiene",
"fitness",
"fresh_care",
"genius",
"hqd_baby_care",
"hqd_bath_towel",
"hqd_bed_sheets",
"hqd_bulky",
"hqd_casual",
"hqd_cold_wind_30",
"hqd_cold_wind_timing",
"hqd_cotton",
"hqd_curtain",
"hqd_delicate",
"hqd_diaper",
"hqd_duvet",
"hqd_feather",
"hqd_hot_wind_timing",
"hqd_hygienic",
"hqd_i_refresh",
"hqd_i_refresh_pro",
"hqd_jacket",
"hqd_jeans",
"hqd_luxury",
"hqd_mix",
"hqd_night_dry",
"hqd_outdoor",
"hqd_precious_cure",
"hqd_quick_20",
"hqd_quick_30",
"hqd_quick_dry",
"hqd_quilt",
"hqd_refresh",
"hqd_school_uniform",
"hqd_shirt",
"hqd_shoes",
"hqd_silk",
"hqd_sports",
"hqd_synthetics",
"hqd_timer",
"hqd_towel",
"hqd_underwear",
"hqd_warm_up",
"hqd_wool",
"hqd_working_suit",
"hygiene",
"iot_checkup",
"iot_dry_anti_mites",
"iot_dry_baby",
"iot_dry_backpacks",
"iot_dry_bathrobe",
"iot_dry_bed_linen",
"iot_dry_bed_quilt",
"iot_dry_cotton",
"iot_dry_cuddly_toys",
"iot_dry_curtains",
"iot_dry_dehumidifier",
"iot_dry_delicates",
"iot_dry_delicate_tablecloths",
"iot_dry_denim_jeans",
"iot_dry_down_jacket",
"iot_dry_duvet",
"iot_dry_easy_iron_cotton",
"iot_dry_easy_iron_synthetics",
"iot_dry_gym_fit",
"iot_dry_lingerie",
"iot_dry_mixed",
"iot_dry_playsuits",
"iot_dry_rapid_30",
"iot_dry_rapid_59",
"iot_dry_refresh",
"iot_dry_regenerates_waterproof",
"iot_dry_relax_creases",
"iot_dry_shirts",
"iot_dry_small_load",
"iot_dry_swimsuits_and_bikinis",
"iot_dry_synthetics",
"iot_dry_synthetic_dry",
"iot_dry_tablecloths",
"iot_dry_technical_fabrics",
"iot_dry_warm_embrace",
"iot_dry_wool",
"jeans",
"mix_and_dry",
"pets",
"pre_iron",
"rapid_30",
"rapid_45",
"rapid_59",
"refresh",
"relax_creases",
"saving_30_min",
"shirts",
"shoes",
"small_load",
"soft_care",
"sport_plus",
"super_easy_iron_misti",
"super_easy_iron_xxl",
"super_fast_cottons",
"super_fast_delicates",
"synthetics",
"total_care",
"trainers",
"ultra_care",
"waterproof_revitalize",
"whites",
"wool",
"woolmark",
"xxl_load",
"zoom_59",
] ]

View File

@ -1,11 +1,10 @@
import logging import logging
from datetime import timedelta from datetime import timedelta
from pyhon.appliance import HonAppliance
from homeassistant.helpers.entity import DeviceInfo from homeassistant.helpers.entity import DeviceInfo
from homeassistant.helpers.update_coordinator import CoordinatorEntity from homeassistant.helpers.update_coordinator import CoordinatorEntity
from homeassistant.helpers.update_coordinator import DataUpdateCoordinator from homeassistant.helpers.update_coordinator import DataUpdateCoordinator
from pyhon.appliance import HonAppliance
from .const import DOMAIN from .const import DOMAIN
@ -15,14 +14,20 @@ _LOGGER = logging.getLogger(__name__)
class HonEntity(CoordinatorEntity): class HonEntity(CoordinatorEntity):
_attr_has_entity_name = True _attr_has_entity_name = True
def __init__(self, hass, entry, coordinator, device: HonAppliance) -> None: def __init__(self, hass, entry, device: HonAppliance, description=None) -> None:
coordinator = get_coordinator(hass, device)
super().__init__(coordinator) super().__init__(coordinator)
self._hon = hass.data[DOMAIN][entry.unique_id] self._hon = hass.data[DOMAIN][entry.unique_id]
self._hass = hass self._hass = hass
self._coordinator = coordinator
self._device = device self._device = device
self._attr_unique_id = self._device.unique_id if description is not None:
self.entity_description = description
self._attr_unique_id = f"{self._device.unique_id}{description.key}"
else:
self._attr_unique_id = self._device.unique_id
@property @property
def device_info(self): def device_info(self):
@ -50,3 +55,22 @@ class HonCoordinator(DataUpdateCoordinator):
async def _async_update_data(self): async def _async_update_data(self):
await self._device.update() await self._device.update()
def unique_entities(base_entities, new_entities):
result = list(base_entities)
existing_entities = [entity.key for entity in base_entities]
for entity in new_entities:
if entity.key not in existing_entities:
result.append(entity)
return tuple(result)
def get_coordinator(hass, appliance):
coordinators = hass.data[DOMAIN]["coordinators"]
if appliance.unique_id in coordinators:
coordinator = hass.data[DOMAIN]["coordinators"][appliance.unique_id]
else:
coordinator = HonCoordinator(hass, appliance)
hass.data[DOMAIN]["coordinators"][appliance.unique_id] = coordinator
return coordinator

View File

@ -1,11 +1,15 @@
{ {
"domain": "hon", "domain": "hon",
"name": "Haier hOn", "name": "Haier hOn",
"codeowners": ["@Andre0512"], "codeowners": [
"@Andre0512"
],
"config_flow": true, "config_flow": true,
"documentation": "https://github.com/Andre0512/hon/", "documentation": "https://github.com/Andre0512/hon/",
"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": ["pyhOn==0.8.2"], "requirements": [
"version": "0.7.0-beta.1" "pyhOn==0.11.3"
],
"version": "0.8.0-beta.7"
} }

View File

@ -1,7 +1,6 @@
from __future__ import annotations from __future__ import annotations
from pyhon import Hon from dataclasses import dataclass
from pyhon.parameter.range import HonParameterRange
from homeassistant.components.number import ( from homeassistant.components.number import (
NumberEntity, NumberEntity,
@ -10,159 +9,188 @@ from homeassistant.components.number import (
from homeassistant.config_entries import ConfigEntry from homeassistant.config_entries import ConfigEntry
from homeassistant.const import UnitOfTime, UnitOfTemperature from homeassistant.const import UnitOfTime, UnitOfTemperature
from homeassistant.core import callback from homeassistant.core import callback
from homeassistant.helpers.entity import EntityCategory from homeassistant.helpers.entity import EntityCategory, Entity
from pyhon.parameter.range import HonParameterRange
from .const import DOMAIN from .const import DOMAIN
from .hon import HonEntity, HonCoordinator from .hon import HonEntity, unique_entities
@dataclass
class HonConfigNumberEntityDescription(NumberEntityDescription):
entity_category: EntityCategory = EntityCategory.CONFIG
@dataclass
class HonNumberEntityDescription(NumberEntityDescription):
pass
NUMBERS: dict[str, tuple[NumberEntityDescription, ...]] = { NUMBERS: dict[str, tuple[NumberEntityDescription, ...]] = {
"WM": ( "WM": (
NumberEntityDescription( HonConfigNumberEntityDescription(
key="startProgram.delayTime", key="startProgram.delayTime",
name="Delay Time", name="Delay Time",
icon="mdi:timer-plus", icon="mdi:timer-plus",
entity_category=EntityCategory.CONFIG,
native_unit_of_measurement=UnitOfTime.MINUTES, native_unit_of_measurement=UnitOfTime.MINUTES,
translation_key="delay_time", translation_key="delay_time",
), ),
NumberEntityDescription( HonConfigNumberEntityDescription(
key="startProgram.rinseIterations", key="startProgram.rinseIterations",
name="Rinse Iterations", name="Rinse Iterations",
icon="mdi:rotate-right", icon="mdi:rotate-right",
entity_category=EntityCategory.CONFIG,
translation_key="rinse_iterations", translation_key="rinse_iterations",
), ),
NumberEntityDescription( HonConfigNumberEntityDescription(
key="startProgram.mainWashTime", key="startProgram.mainWashTime",
name="Main Wash Time", name="Main Wash Time",
icon="mdi:clock-start", icon="mdi:clock-start",
entity_category=EntityCategory.CONFIG,
native_unit_of_measurement=UnitOfTime.MINUTES, native_unit_of_measurement=UnitOfTime.MINUTES,
translation_key="wash_time", translation_key="wash_time",
), ),
HonConfigNumberEntityDescription(
key="startProgram.steamLevel",
name="Steam Level",
icon="mdi:weather-dust",
translation_key="steam_level",
),
HonConfigNumberEntityDescription(
key="startProgram.waterHard",
name="Water hard",
icon="mdi:water",
translation_key="water_hard",
),
HonConfigNumberEntityDescription(
key="startProgram.lang",
name="lang",
),
), ),
"TD": ( "TD": (
NumberEntityDescription( HonConfigNumberEntityDescription(
key="startProgram.delayTime", key="startProgram.delayTime",
name="Delay time", name="Delay time",
icon="mdi:timer-plus", icon="mdi:timer-plus",
entity_category=EntityCategory.CONFIG,
native_unit_of_measurement=UnitOfTime.MINUTES, native_unit_of_measurement=UnitOfTime.MINUTES,
translation_key="delay_time", translation_key="delay_time",
), ),
NumberEntityDescription( HonConfigNumberEntityDescription(
key="startProgram.tempLevel", key="startProgram.tempLevel",
name="Temperature level", name="Temperature level",
entity_category=EntityCategory.CONFIG,
icon="mdi:thermometer", icon="mdi:thermometer",
translation_key="tumbledryertemplevel", translation_key="tumbledryertemplevel",
), ),
), HonConfigNumberEntityDescription(
"WD": ( key="startProgram.dryTime",
NumberEntityDescription( name="Dry Time",
key="startProgram.delayTime", translation_key="dry_time",
name="Delay Time",
icon="mdi:timer-plus",
entity_category=EntityCategory.CONFIG,
native_unit_of_measurement=UnitOfTime.MINUTES,
translation_key="delay_time",
), ),
), ),
"OV": ( "OV": (
NumberEntityDescription( HonConfigNumberEntityDescription(
key="startProgram.delayTime", key="startProgram.delayTime",
name="Delay time", name="Delay time",
icon="mdi:timer-plus", icon="mdi:timer-plus",
entity_category=EntityCategory.CONFIG,
native_unit_of_measurement=UnitOfTime.MINUTES, native_unit_of_measurement=UnitOfTime.MINUTES,
translation_key="delay_time", translation_key="delay_time",
), ),
NumberEntityDescription( HonConfigNumberEntityDescription(
key="startProgram.tempSel", key="startProgram.tempSel",
name="Target Temperature", name="Target Temperature",
entity_category=EntityCategory.CONFIG,
icon="mdi:thermometer", icon="mdi:thermometer",
native_unit_of_measurement=UnitOfTemperature.CELSIUS, native_unit_of_measurement=UnitOfTemperature.CELSIUS,
translation_key="target_temperature", translation_key="target_temperature",
), ),
NumberEntityDescription( HonConfigNumberEntityDescription(
key="startProgram.prTime", key="startProgram.prTime",
name="Program Duration", name="Program Duration",
entity_category=EntityCategory.CONFIG,
icon="mdi:timelapse", icon="mdi:timelapse",
native_unit_of_measurement=UnitOfTime.MINUTES, native_unit_of_measurement=UnitOfTime.MINUTES,
translation_key="program_duration", translation_key="program_duration",
), ),
), ),
"IH": ( "IH": (
NumberEntityDescription( HonConfigNumberEntityDescription(
key="startProgram.temp", key="startProgram.temp",
name="Temperature", name="Temperature",
entity_category=EntityCategory.CONFIG,
icon="mdi:thermometer", icon="mdi:thermometer",
translation_key="temperature", translation_key="temperature",
), ),
NumberEntityDescription( HonConfigNumberEntityDescription(
key="startProgram.powerManagement", key="startProgram.powerManagement",
name="Power Management", name="Power Management",
entity_category=EntityCategory.CONFIG,
icon="mdi:timelapse", icon="mdi:timelapse",
translation_key="power_management", translation_key="power_management",
), ),
), ),
"DW": ( "DW": (
NumberEntityDescription( HonConfigNumberEntityDescription(
key="startProgram.delayTime", key="startProgram.delayTime",
name="Delay time", name="Delay time",
icon="mdi:timer-plus", icon="mdi:timer-plus",
entity_category=EntityCategory.CONFIG,
native_unit_of_measurement=UnitOfTime.MINUTES, native_unit_of_measurement=UnitOfTime.MINUTES,
translation_key="delay_time", translation_key="delay_time",
), ),
NumberEntityDescription( HonConfigNumberEntityDescription(
key="startProgram.waterHard", key="startProgram.waterHard",
name="Water hard", name="Water hard",
icon="mdi:water", icon="mdi:water",
entity_category=EntityCategory.CONFIG,
translation_key="water_hard", translation_key="water_hard",
), ),
), ),
"AC": (
HonNumberEntityDescription(
key="settings.tempSel",
name="Target Temperature",
icon="mdi:thermometer",
native_unit_of_measurement=UnitOfTemperature.CELSIUS,
translation_key="target_temperature",
),
),
"REF": (
HonNumberEntityDescription(
key="settings.tempSelZ1",
name="Fridge Temperature",
icon="mdi:thermometer",
native_unit_of_measurement=UnitOfTemperature.CELSIUS,
translation_key="fridge_temp_sel",
),
HonNumberEntityDescription(
key="settings.tempSelZ2",
name="Freezer Temperature",
icon="mdi:thermometer",
native_unit_of_measurement=UnitOfTemperature.CELSIUS,
translation_key="freezer_temp_sel",
),
),
} }
NUMBERS["WD"] = unique_entities(NUMBERS["WM"], NUMBERS["TD"])
async def async_setup_entry(hass, entry: ConfigEntry, async_add_entities) -> None: async def async_setup_entry(hass, entry: ConfigEntry, async_add_entities) -> None:
hon: Hon = hass.data[DOMAIN][entry.unique_id] entities = []
coordinators = hass.data[DOMAIN]["coordinators"] for device in hass.data[DOMAIN][entry.unique_id].appliances:
appliances = [] for description in NUMBERS.get(device.appliance_type, []):
for device in hon.appliances: if description.key not in device.available_settings:
if device.unique_id in coordinators: continue
coordinator = hass.data[DOMAIN]["coordinators"][device.unique_id] if isinstance(description, HonNumberEntityDescription):
else: entity = HonNumberEntity(hass, entry, device, description)
coordinator = HonCoordinator(hass, device) elif isinstance(description, HonConfigNumberEntityDescription):
hass.data[DOMAIN]["coordinators"][device.unique_id] = coordinator entity = HonConfigNumberEntity(hass, entry, device, description)
await coordinator.async_config_entry_first_refresh() else:
continue
if descriptions := NUMBERS.get(device.appliance_type): await entity.coordinator.async_config_entry_first_refresh()
for description in descriptions: entities.append(entity)
if not device.settings.get(description.key): async_add_entities(entities)
continue
appliances.extend(
[HonNumberEntity(hass, coordinator, entry, device, description)]
)
async_add_entities(appliances)
class HonNumberEntity(HonEntity, NumberEntity): class HonNumberEntity(HonEntity, NumberEntity):
def __init__(self, hass, coordinator, entry, device, description) -> None: entity_description: HonNumberEntityDescription
super().__init__(hass, entry, coordinator, device)
def __init__(self, hass, entry, device, description) -> None:
super().__init__(hass, entry, device, description)
self._coordinator = coordinator
self._device = device
self._data = device.settings[description.key] self._data = device.settings[description.key]
self.entity_description = description
self._attr_unique_id = f"{super().unique_id}{description.key}"
if isinstance(self._data, HonParameterRange): if isinstance(self._data, HonParameterRange):
self._attr_native_max_value = self._data.max self._attr_native_max_value = self._data.max
self._attr_native_min_value = self._data.min self._attr_native_min_value = self._data.min
@ -173,8 +201,12 @@ class HonNumberEntity(HonEntity, NumberEntity):
return self._device.get(self.entity_description.key) return self._device.get(self.entity_description.key)
async def async_set_native_value(self, value: float) -> None: async def async_set_native_value(self, value: float) -> None:
self._device.settings[self.entity_description.key].value = value setting = self._device.settings[self.entity_description.key]
await self.coordinator.async_request_refresh() if isinstance(setting, HonParameterRange):
setting.value = value
command = self.entity_description.key.split(".")[0]
await self._device.commands[command].send()
await self.coordinator.async_refresh()
@callback @callback
def _handle_coordinator_update(self): def _handle_coordinator_update(self):
@ -185,3 +217,27 @@ class HonNumberEntity(HonEntity, NumberEntity):
self._attr_native_step = setting.step self._attr_native_step = setting.step
self._attr_native_value = setting.value self._attr_native_value = setting.value
self.async_write_ha_state() self.async_write_ha_state()
@property
def available(self) -> bool:
"""Return True if entity is available."""
return (
super().available
and self._device.get("remoteCtrValid", "1") == "1"
and self._device.get("attributes.lastConnEvent.category") != "DISCONNECTED"
)
class HonConfigNumberEntity(HonNumberEntity):
entity_description: HonConfigNumberEntityDescription
async def async_set_native_value(self, value: str) -> None:
setting = self._device.settings[self.entity_description.key]
if isinstance(setting, HonParameterRange):
setting.value = value
await self.coordinator.async_refresh()
@property
def available(self) -> bool:
"""Return True if entity is available."""
return super(NumberEntity, self).available

View File

@ -1,141 +1,169 @@
from __future__ import annotations from __future__ import annotations
import logging import logging
from dataclasses import dataclass
from pyhon import Hon
from pyhon.appliance import HonAppliance
from pyhon.parameter.fixed import HonParameterFixed
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, Entity
from pyhon.appliance import HonAppliance
from pyhon.parameter.fixed import HonParameterFixed
from .const import DOMAIN from .const import DOMAIN
from .hon import HonEntity, HonCoordinator from .hon import HonEntity, unique_entities
_LOGGER = logging.getLogger(__name__) _LOGGER = logging.getLogger(__name__)
@dataclass
class HonSelectEntityDescription(SelectEntityDescription):
pass
@dataclass
class HonConfigSelectEntityDescription(SelectEntityDescription):
entity_category: EntityCategory = EntityCategory.CONFIG
SELECTS = { SELECTS = {
"WM": ( "WM": (
SelectEntityDescription( HonConfigSelectEntityDescription(
key="startProgram.spinSpeed", key="startProgram.spinSpeed",
name="Spin speed", name="Spin speed",
entity_category=EntityCategory.CONFIG,
icon="mdi:numeric", icon="mdi:numeric",
unit_of_measurement=REVOLUTIONS_PER_MINUTE, unit_of_measurement=REVOLUTIONS_PER_MINUTE,
translation_key="spin_speed", translation_key="spin_speed",
), ),
SelectEntityDescription( HonConfigSelectEntityDescription(
key="startProgram.temp", key="startProgram.temp",
name="Temperature", name="Temperature",
entity_category=EntityCategory.CONFIG,
icon="mdi:thermometer", icon="mdi:thermometer",
unit_of_measurement=UnitOfTemperature.CELSIUS, unit_of_measurement=UnitOfTemperature.CELSIUS,
translation_key="temperature", translation_key="temperature",
), ),
SelectEntityDescription( HonConfigSelectEntityDescription(
key="startProgram.program", key="startProgram.program",
name="Program", name="Program",
entity_category=EntityCategory.CONFIG,
translation_key="programs_wm", translation_key="programs_wm",
), ),
), ),
"TD": ( "TD": (
SelectEntityDescription( HonConfigSelectEntityDescription(
key="startProgram.program", key="startProgram.program",
name="Program", name="Program",
entity_category=EntityCategory.CONFIG,
translation_key="programs_td", translation_key="programs_td",
), ),
SelectEntityDescription( HonConfigSelectEntityDescription(
key="startProgram.dryTimeMM", key="startProgram.dryTimeMM",
name="Time", name="Dry Time",
entity_category=EntityCategory.CONFIG,
icon="mdi:timer", icon="mdi:timer",
unit_of_measurement=UnitOfTime.MINUTES, unit_of_measurement=UnitOfTime.MINUTES,
translation_key="dry_time",
), ),
SelectEntityDescription( HonConfigSelectEntityDescription(
key="startProgram.dryLevel", key="startProgram.dryLevel",
name="Dry level", name="Dry level",
entity_category=EntityCategory.CONFIG,
icon="mdi:hair-dryer", icon="mdi:hair-dryer",
translation_key="dry_levels", translation_key="dry_levels",
), ),
), ),
"WD": (
SelectEntityDescription(
key="startProgram.program",
name="Program",
entity_category=EntityCategory.CONFIG,
translation_key="programs_wm",
),
),
"OV": ( "OV": (
SelectEntityDescription( HonConfigSelectEntityDescription(
key="startProgram.program", key="startProgram.program",
name="Program", name="Program",
entity_category=EntityCategory.CONFIG,
translation_key="programs_ov", translation_key="programs_ov",
), ),
), ),
"IH": ( "IH": (
SelectEntityDescription( HonConfigSelectEntityDescription(
key="startProgram.program", key="startProgram.program",
name="Program", name="Program",
entity_category=EntityCategory.CONFIG,
translation_key="programs_ih", translation_key="programs_ih",
), ),
), ),
"DW": ( "DW": (
SelectEntityDescription( HonConfigSelectEntityDescription(
key="startProgram.program", key="startProgram.program",
name="Program", name="Program",
entity_category=EntityCategory.CONFIG,
translation_key="programs_dw", translation_key="programs_dw",
), ),
HonConfigSelectEntityDescription(
key="startProgram.temp",
name="Temperature",
icon="mdi:thermometer",
unit_of_measurement=UnitOfTemperature.CELSIUS,
translation_key="temperature",
),
HonConfigSelectEntityDescription(
key="startProgram.remainingTime",
name="Remaining Time",
icon="mdi:timer",
unit_of_measurement=UnitOfTime.MINUTES,
translation_key="remaining_time",
),
),
"AC": (
HonSelectEntityDescription(
key="startProgram.program",
name="Program",
translation_key="programs_ac",
),
HonSelectEntityDescription(
key="settings.humanSensingStatus",
name="Eco Pilot",
icon="mdi:run",
translation_key="eco_pilot",
),
),
"REF": (
HonConfigSelectEntityDescription(
key="startProgram.program",
name="Program",
translation_key="programs_ref",
),
HonConfigSelectEntityDescription(
key="startProgram.zone",
name="Zone",
icon="mdi:radiobox-marked",
translation_key="ref_zones",
),
), ),
} }
SELECTS["WD"] = unique_entities(SELECTS["WM"], SELECTS["TD"])
async def async_setup_entry(hass, entry: ConfigEntry, async_add_entities) -> None: async def async_setup_entry(hass, entry: ConfigEntry, async_add_entities) -> None:
hon: Hon = hass.data[DOMAIN][entry.unique_id] entities = []
coordinators = hass.data[DOMAIN]["coordinators"] for device in hass.data[DOMAIN][entry.unique_id].appliances:
appliances = [] for description in SELECTS.get(device.appliance_type, []):
for device in hon.appliances: if description.key not in device.available_settings:
if device.unique_id in coordinators: continue
coordinator = hass.data[DOMAIN]["coordinators"][device.unique_id] if isinstance(description, HonSelectEntityDescription):
else: entity = HonSelectEntity(hass, entry, device, description)
coordinator = HonCoordinator(hass, device) elif isinstance(description, HonConfigSelectEntityDescription):
hass.data[DOMAIN]["coordinators"][device.unique_id] = coordinator entity = HonConfigSelectEntity(hass, entry, device, description)
await coordinator.async_config_entry_first_refresh() else:
continue
if descriptions := SELECTS.get(device.appliance_type): await entity.coordinator.async_config_entry_first_refresh()
for description in descriptions: entities.append(entity)
if not device.settings.get(description.key): async_add_entities(entities)
continue
appliances.extend(
[HonSelectEntity(hass, coordinator, entry, device, description)]
)
async_add_entities(appliances)
class HonSelectEntity(HonEntity, SelectEntity): class HonSelectEntity(HonEntity, SelectEntity):
def __init__( entity_description: HonSelectEntityDescription
self, hass, coordinator, entry, device: HonAppliance, description
) -> None:
super().__init__(hass, entry, coordinator, device)
self._coordinator = coordinator def __init__(self, hass, entry, device: HonAppliance, description) -> None:
self._device = device super().__init__(hass, entry, device, description)
self.entity_description = description
self._attr_unique_id = f"{super().unique_id}{description.key}"
if not isinstance(self._device.settings[description.key], HonParameterFixed): if not (setting := self._device.settings.get(description.key)):
self._attr_options: list[str] = device.settings[description.key].values self._attr_options: list[str] = []
elif not isinstance(setting, HonParameterFixed):
self._attr_options: list[str] = setting.values
else: else:
self._attr_options: list[str] = [device.settings[description.key].value] self._attr_options: list[str] = [setting.value]
@property @property
def current_option(self) -> str | None: def current_option(self) -> str | None:
@ -146,7 +174,9 @@ class HonSelectEntity(HonEntity, SelectEntity):
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 self._device.settings[self.entity_description.key].value = option
await self.coordinator.async_request_refresh() command = self.entity_description.key.split(".")[0]
await self._device.commands[command].send()
await self.coordinator.async_refresh()
@callback @callback
def _handle_coordinator_update(self): def _handle_coordinator_update(self):
@ -160,3 +190,25 @@ class HonSelectEntity(HonEntity, SelectEntity):
self._attr_options: list[str] = setting.values self._attr_options: list[str] = setting.values
self._attr_native_value = setting.value self._attr_native_value = setting.value
self.async_write_ha_state() self.async_write_ha_state()
@property
def available(self) -> bool:
"""Return True if entity is available."""
return (
super().available
and self._device.get("remoteCtrValid", "1") == "1"
and self._device.get("attributes.lastConnEvent.category") != "DISCONNECTED"
)
class HonConfigSelectEntity(HonSelectEntity):
entity_description: HonConfigSelectEntityDescription
async def async_select_option(self, option: str) -> None:
self._device.settings[self.entity_description.key].value = option
await self.coordinator.async_refresh()
@property
def available(self) -> bool:
"""Return True if entity is available."""
return super(SelectEntity, self).available

View File

@ -1,6 +1,5 @@
import logging import logging
from dataclasses import dataclass
from pyhon import Hon
from homeassistant.components.sensor import ( from homeassistant.components.sensor import (
SensorEntity, SensorEntity,
@ -9,6 +8,7 @@ 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 ( from homeassistant.const import (
REVOLUTIONS_PER_MINUTE, REVOLUTIONS_PER_MINUTE,
UnitOfEnergy, UnitOfEnergy,
@ -21,73 +21,92 @@ from homeassistant.const import (
from homeassistant.core import callback from homeassistant.core import callback
from homeassistant.helpers.entity import EntityCategory from homeassistant.helpers.entity import EntityCategory
from homeassistant.helpers.typing import StateType from homeassistant.helpers.typing import StateType
from homeassistant.const import PERCENTAGE from . import const
from .const import DOMAIN from .const import DOMAIN
from .hon import HonCoordinator, HonEntity from .hon import HonEntity, unique_entities
_LOGGER = logging.getLogger(__name__) _LOGGER = logging.getLogger(__name__)
@dataclass
class HonConfigSensorEntityDescription(SensorEntityDescription):
entity_category: EntityCategory = EntityCategory.CONFIG
@dataclass
class HonSensorEntityDescription(SensorEntityDescription):
pass
SENSORS: dict[str, tuple[SensorEntityDescription, ...]] = { SENSORS: dict[str, tuple[SensorEntityDescription, ...]] = {
"WM": ( "WM": (
SensorEntityDescription( HonSensorEntityDescription(
key="prPhase", key="prPhase",
name="Program Phase", name="Program Phase",
icon="mdi:washing-machine", icon="mdi:washing-machine",
device_class=SensorDeviceClass.ENUM,
translation_key="program_phases_wm", translation_key="program_phases_wm",
options=list(const.WASHING_PR_PHASE),
), ),
SensorEntityDescription( HonSensorEntityDescription(
key="totalElectricityUsed", key="totalElectricityUsed",
name="Total Power", name="Total Power",
device_class=SensorDeviceClass.ENERGY, device_class=SensorDeviceClass.ENERGY,
state_class=SensorStateClass.TOTAL_INCREASING, state_class=SensorStateClass.TOTAL_INCREASING,
native_unit_of_measurement=UnitOfEnergy.KILO_WATT_HOUR, native_unit_of_measurement=UnitOfEnergy.KILO_WATT_HOUR,
translation_key="energy_total",
), ),
SensorEntityDescription( HonSensorEntityDescription(
key="totalWaterUsed", key="totalWaterUsed",
name="Total Water", name="Total Water",
device_class=SensorDeviceClass.WATER, device_class=SensorDeviceClass.WATER,
state_class=SensorStateClass.TOTAL_INCREASING, state_class=SensorStateClass.TOTAL_INCREASING,
native_unit_of_measurement=UnitOfVolume.LITERS, native_unit_of_measurement=UnitOfVolume.LITERS,
translation_key="water_total",
), ),
SensorEntityDescription( HonSensorEntityDescription(
key="totalWashCycle", key="totalWashCycle",
name="Total Wash Cycle", name="Total Wash Cycle",
state_class=SensorStateClass.TOTAL_INCREASING, state_class=SensorStateClass.TOTAL_INCREASING,
icon="mdi:counter", icon="mdi:counter",
translation_key="cycles_total",
), ),
SensorEntityDescription( HonSensorEntityDescription(
key="currentElectricityUsed", key="currentElectricityUsed",
name="Current Electricity Used", name="Current Electricity Used",
state_class=SensorStateClass.MEASUREMENT, state_class=SensorStateClass.MEASUREMENT,
device_class=SensorDeviceClass.POWER, device_class=SensorDeviceClass.POWER,
native_unit_of_measurement=UnitOfPower.KILO_WATT, native_unit_of_measurement=UnitOfPower.KILO_WATT,
icon="mdi:lightning-bolt", icon="mdi:lightning-bolt",
translation_key="energy_current",
), ),
SensorEntityDescription( HonSensorEntityDescription(
key="currentWaterUsed", key="currentWaterUsed",
name="Current Water Used", name="Current Water Used",
state_class=SensorStateClass.MEASUREMENT, state_class=SensorStateClass.MEASUREMENT,
icon="mdi:water", icon="mdi:water",
translation_key="water_current",
), ),
SensorEntityDescription( HonConfigSensorEntityDescription(
key="startProgram.weight", key="startProgram.weight",
name="Suggested weight", name="Suggested weight",
state_class=SensorStateClass.MEASUREMENT, state_class=SensorStateClass.MEASUREMENT,
entity_category=EntityCategory.CONFIG,
native_unit_of_measurement=UnitOfMass.KILOGRAMS, native_unit_of_measurement=UnitOfMass.KILOGRAMS,
icon="mdi:weight-kilogram", icon="mdi:weight-kilogram",
translation_key="suggested_load",
), ),
SensorEntityDescription( HonSensorEntityDescription(
key="machMode", key="machMode",
name="Machine Status", name="Machine Status",
icon="mdi:information", icon="mdi:information",
device_class=SensorDeviceClass.ENUM,
translation_key="washing_modes", translation_key="washing_modes",
options=list(const.MACH_MODE),
), ),
SensorEntityDescription( HonSensorEntityDescription(
key="errors", name="Error", icon="mdi:math-log", translation_key="errors" key="errors", name="Error", icon="mdi:math-log", translation_key="errors"
), ),
SensorEntityDescription( HonSensorEntityDescription(
key="remainingTimeMM", key="remainingTimeMM",
name="Remaining Time", name="Remaining Time",
icon="mdi:timer", icon="mdi:timer",
@ -95,161 +114,56 @@ SENSORS: dict[str, tuple[SensorEntityDescription, ...]] = {
native_unit_of_measurement=UnitOfTime.MINUTES, native_unit_of_measurement=UnitOfTime.MINUTES,
translation_key="remaining_time", translation_key="remaining_time",
), ),
SensorEntityDescription( HonSensorEntityDescription(
key="spinSpeed", key="spinSpeed",
name="Spin Speed", name="Spin Speed",
icon="mdi:speedometer", icon="mdi:speedometer",
state_class=SensorStateClass.MEASUREMENT, state_class=SensorStateClass.MEASUREMENT,
native_unit_of_measurement=UnitOfTime.MINUTES,
translation_key="spin_speed",
),
),
"TD": (
SensorEntityDescription(
key="machMode",
name="Machine Status",
icon="mdi:information",
translation_key="washing_modes",
),
SensorEntityDescription(
key="errors", name="Error", icon="mdi:math-log", translation_key="errors"
),
SensorEntityDescription(
key="remainingTimeMM",
name="Remaining Time",
icon="mdi:timer",
state_class=SensorStateClass.MEASUREMENT,
native_unit_of_measurement=UnitOfTime.MINUTES,
translation_key="remaining_time",
),
SensorEntityDescription(
key="delayTime",
name="Start Time",
icon="mdi:clock-start",
state_class=SensorStateClass.MEASUREMENT,
native_unit_of_measurement=UnitOfTime.MINUTES,
translation_key="delay_time",
),
SensorEntityDescription(
key="prCode",
name="Program",
icon="mdi:tumble-dryer",
translation_key="tumbledryerprogram",
),
SensorEntityDescription(
key="prPhase",
name="Program Phase",
icon="mdi:washing-machine",
translation_key="program_phases_td",
),
SensorEntityDescription(
key="dryLevel",
name="Dry level",
icon="mdi:hair-dryer",
translation_key="dry_levels",
),
SensorEntityDescription(
key="tempLevel",
name="Temperature level",
icon="mdi:thermometer",
translation_key="tumbledryertemplevel",
),
),
"WD": (
SensorEntityDescription(
key="totalElectricityUsed",
name="Total Power",
device_class=SensorDeviceClass.ENERGY,
state_class=SensorStateClass.TOTAL_INCREASING,
native_unit_of_measurement=UnitOfEnergy.KILO_WATT_HOUR,
),
SensorEntityDescription(
key="totalWaterUsed",
name="Total Water",
device_class=SensorDeviceClass.WATER,
state_class=SensorStateClass.TOTAL_INCREASING,
native_unit_of_measurement=UnitOfVolume.LITERS,
),
SensorEntityDescription(
key="totalWashCycle",
name="Total Wash Cycle",
state_class=SensorStateClass.TOTAL_INCREASING,
icon="mdi:counter",
),
SensorEntityDescription(
key="currentElectricityUsed",
name="Current Electricity Used",
state_class=SensorStateClass.MEASUREMENT,
device_class=SensorDeviceClass.POWER,
native_unit_of_measurement=UnitOfPower.KILO_WATT,
icon="mdi:lightning-bolt",
),
SensorEntityDescription(
key="currentWaterUsed",
name="Current Water Used",
state_class=SensorStateClass.MEASUREMENT,
icon="mdi:water",
),
SensorEntityDescription(
key="startProgram.weight",
name="Suggested weight",
state_class=SensorStateClass.MEASUREMENT,
entity_category=EntityCategory.CONFIG,
native_unit_of_measurement=UnitOfMass.KILOGRAMS,
icon="mdi:weight-kilogram",
),
SensorEntityDescription(
key="machMode",
name="Machine Status",
icon="mdi:information",
translation_key="washing_modes",
),
SensorEntityDescription(
key="spinSpeed",
name="Spin Speed",
icon="mdi:fast-forward-outline",
state_class=SensorStateClass.MEASUREMENT,
native_unit_of_measurement=REVOLUTIONS_PER_MINUTE, native_unit_of_measurement=REVOLUTIONS_PER_MINUTE,
translation_key="spin_speed", translation_key="spin_speed",
), ),
SensorEntityDescription( HonConfigSensorEntityDescription(
key="remainingTimeMM", key="startProgram.energyLabel",
name="Energy Label",
icon="mdi:lightning-bolt-circle",
state_class=SensorStateClass.MEASUREMENT,
translation_key="energy_label",
),
HonConfigSensorEntityDescription(
key="startProgram.liquidDetergentDose",
name="Liquid Detergent Dose",
icon="mdi:cup-water",
translation_key="det_liquid",
),
HonConfigSensorEntityDescription(
key="startProgram.powderDetergentDose",
name="Powder Detergent Dose",
icon="mdi:cup",
translation_key="det_dust",
),
HonConfigSensorEntityDescription(
key="startProgram.remainingTime",
name="Remaining Time", name="Remaining Time",
icon="mdi:timer", icon="mdi:timer",
state_class=SensorStateClass.MEASUREMENT, state_class=SensorStateClass.MEASUREMENT,
native_unit_of_measurement=UnitOfTime.MINUTES, native_unit_of_measurement=UnitOfTime.MINUTES,
translation_key="remaining_time", translation_key="remaining_time",
), ),
SensorEntityDescription( HonSensorEntityDescription(
key="prCode",
name="Current Program",
icon="mdi:tumble-dryer",
),
SensorEntityDescription(
key="prPhase",
name="Program Phase",
icon="mdi:washing-machine",
translation_key="program_phases_wm",
),
SensorEntityDescription(
key="dryLevel",
name="Dry level",
icon="mdi:hair-dryer",
translation_key="dry_levels",
),
SensorEntityDescription(
key="dirtyLevel", key="dirtyLevel",
name="Dirt level", name="Dirt level",
icon="mdi:liquid-spot", icon="mdi:liquid-spot",
translation_key="dirt_level", translation_key="dirt_level",
), ),
SensorEntityDescription( HonConfigSensorEntityDescription(
key="steamLevel", key="startProgram.suggestedLoadW",
name="Steam level", name="Suggested Load",
icon="mdi:smoke", icon="mdi:weight-kilogram",
translation_key="steam_level", state_class=SensorStateClass.MEASUREMENT,
native_unit_of_measurement=UnitOfMass.KILOGRAMS,
translation_key="suggested_load",
), ),
SensorEntityDescription( HonSensorEntityDescription(
key="temp", key="temp",
name="Current Temperature", name="Current Temperature",
icon="mdi:thermometer", icon="mdi:thermometer",
@ -258,15 +172,27 @@ SENSORS: dict[str, tuple[SensorEntityDescription, ...]] = {
translation_key="temperature", translation_key="temperature",
), ),
), ),
"OV": ( "TD": (
SensorEntityDescription( HonSensorEntityDescription(
key="machMode",
name="Machine Status",
icon="mdi:information",
device_class=SensorDeviceClass.ENUM,
translation_key="washing_modes",
options=list(const.MACH_MODE),
),
HonSensorEntityDescription(
key="errors", name="Error", icon="mdi:math-log", translation_key="errors"
),
HonSensorEntityDescription(
key="remainingTimeMM", key="remainingTimeMM",
name="Remaining Time", name="Remaining Time",
icon="mdi:timer", icon="mdi:timer",
state_class=SensorStateClass.MEASUREMENT,
native_unit_of_measurement=UnitOfTime.MINUTES, native_unit_of_measurement=UnitOfTime.MINUTES,
translation_key="remaining_time", translation_key="remaining_time",
), ),
SensorEntityDescription( HonSensorEntityDescription(
key="delayTime", key="delayTime",
name="Start Time", name="Start Time",
icon="mdi:clock-start", icon="mdi:clock-start",
@ -274,13 +200,92 @@ SENSORS: dict[str, tuple[SensorEntityDescription, ...]] = {
native_unit_of_measurement=UnitOfTime.MINUTES, native_unit_of_measurement=UnitOfTime.MINUTES,
translation_key="delay_time", translation_key="delay_time",
), ),
SensorEntityDescription( HonSensorEntityDescription(
key="programName",
name="Program",
icon="mdi:tumble-dryer",
device_class=SensorDeviceClass.ENUM,
translation_key="programs_td",
options=const.PROGRAMS_TD,
),
HonSensorEntityDescription(
key="prPhase",
name="Program Phase",
icon="mdi:washing-machine",
device_class=SensorDeviceClass.ENUM,
translation_key="program_phases_td",
options=list(const.TUMBLE_DRYER_PR_PHASE),
),
HonSensorEntityDescription(
key="dryLevel",
name="Dry level",
icon="mdi:hair-dryer",
device_class=SensorDeviceClass.ENUM,
translation_key="dry_levels",
options=list(const.TUMBLE_DRYER_DRY_LEVEL),
),
HonSensorEntityDescription(
key="tempLevel",
name="Temperature level",
icon="mdi:thermometer",
translation_key="tumbledryertemplevel",
),
HonConfigSensorEntityDescription(
key="startProgram.suggestedLoadD",
name="Suggested Load",
icon="mdi:weight-kilogram",
state_class=SensorStateClass.MEASUREMENT,
native_unit_of_measurement=UnitOfMass.KILOGRAMS,
translation_key="suggested_load",
),
HonConfigSensorEntityDescription(
key="startProgram.energyLabel",
name="Energy Label",
icon="mdi:lightning-bolt-circle",
state_class=SensorStateClass.MEASUREMENT,
translation_key="energy_label",
),
HonConfigSensorEntityDescription(
key="startProgram.steamLevel",
name="Steam level",
icon="mdi:smoke",
translation_key="steam_level",
),
HonSensorEntityDescription(
key="steamLevel",
name="Steam level",
icon="mdi:smoke",
translation_key="steam_level",
),
HonConfigSensorEntityDescription(
key="steamType",
name="Steam Type",
icon="mdi:weather-dust",
),
),
"OV": (
HonSensorEntityDescription(
key="remainingTimeMM",
name="Remaining Time",
icon="mdi:timer",
native_unit_of_measurement=UnitOfTime.MINUTES,
translation_key="remaining_time",
),
HonSensorEntityDescription(
key="delayTime",
name="Start Time",
icon="mdi:clock-start",
state_class=SensorStateClass.MEASUREMENT,
native_unit_of_measurement=UnitOfTime.MINUTES,
translation_key="delay_time",
),
HonSensorEntityDescription(
key="temp", key="temp",
name="Temperature", name="Temperature",
icon="mdi:thermometer", icon="mdi:thermometer",
translation_key="temperature", translation_key="temperature",
), ),
SensorEntityDescription( HonSensorEntityDescription(
key="tempSel", key="tempSel",
name="Temperature Selected", name="Temperature Selected",
icon="mdi:thermometer", icon="mdi:thermometer",
@ -288,14 +293,14 @@ SENSORS: dict[str, tuple[SensorEntityDescription, ...]] = {
), ),
), ),
"IH": ( "IH": (
SensorEntityDescription( HonSensorEntityDescription(
key="remainingTimeMM", key="remainingTimeMM",
name="Remaining Time", name="Remaining Time",
icon="mdi:timer", icon="mdi:timer",
native_unit_of_measurement=UnitOfTime.MINUTES, native_unit_of_measurement=UnitOfTime.MINUTES,
translation_key="remaining_time", translation_key="remaining_time",
), ),
SensorEntityDescription( HonSensorEntityDescription(
key="temp", key="temp",
name="Temperature", name="Temperature",
icon="mdi:thermometer", icon="mdi:thermometer",
@ -303,8 +308,10 @@ SENSORS: dict[str, tuple[SensorEntityDescription, ...]] = {
native_unit_of_measurement=UnitOfTemperature.CELSIUS, native_unit_of_measurement=UnitOfTemperature.CELSIUS,
translation_key="temperature", translation_key="temperature",
), ),
SensorEntityDescription(key="errors", name="Error", icon="mdi:math-log"), HonSensorEntityDescription(
SensorEntityDescription( key="errors", name="Error", icon="mdi:math-log", translation_key="errors"
),
HonSensorEntityDescription(
key="power", key="power",
name="Power", name="Power",
icon="mdi:lightning-bolt", icon="mdi:lightning-bolt",
@ -313,65 +320,62 @@ SENSORS: dict[str, tuple[SensorEntityDescription, ...]] = {
), ),
), ),
"DW": ( "DW": (
SensorEntityDescription( HonConfigSensorEntityDescription(
key="startProgram.ecoIndex", key="startProgram.ecoIndex",
name="Eco Index", name="Eco Index",
icon="mdi:sprout", icon="mdi:sprout",
state_class=SensorStateClass.MEASUREMENT, state_class=SensorStateClass.MEASUREMENT,
entity_category=EntityCategory.CONFIG,
), ),
SensorEntityDescription( HonConfigSensorEntityDescription(
key="startProgram.waterEfficiency", key="startProgram.waterEfficiency",
name="Water Efficiency", name="Water Efficiency",
icon="mdi:water", icon="mdi:water",
state_class=SensorStateClass.MEASUREMENT, state_class=SensorStateClass.MEASUREMENT,
entity_category=EntityCategory.CONFIG,
translation_key="water_efficiency", translation_key="water_efficiency",
), ),
SensorEntityDescription( HonConfigSensorEntityDescription(
key="startProgram.waterSaving", key="startProgram.waterSaving",
name="Water Saving", name="Water Saving",
icon="mdi:water-percent", icon="mdi:water-percent",
state_class=SensorStateClass.MEASUREMENT, state_class=SensorStateClass.MEASUREMENT,
native_unit_of_measurement=PERCENTAGE, native_unit_of_measurement=PERCENTAGE,
entity_category=EntityCategory.CONFIG,
translation_key="water_saving", translation_key="water_saving",
), ),
SensorEntityDescription( HonConfigSensorEntityDescription(
key="startProgram.temp", key="startProgram.temp",
name="Temperature", name="Temperature",
icon="mdi:thermometer", icon="mdi:thermometer",
state_class=SensorStateClass.MEASUREMENT, state_class=SensorStateClass.MEASUREMENT,
native_unit_of_measurement=UnitOfTemperature.CELSIUS, native_unit_of_measurement=UnitOfTemperature.CELSIUS,
entity_category=EntityCategory.CONFIG,
translation_key="temperature", translation_key="temperature",
), ),
SensorEntityDescription( HonConfigSensorEntityDescription(
key="startProgram.energyLabel", key="startProgram.energyLabel",
name="Energy Label", name="Energy Label",
icon="mdi:lightning-bolt-circle", icon="mdi:lightning-bolt-circle",
state_class=SensorStateClass.MEASUREMENT, state_class=SensorStateClass.MEASUREMENT,
entity_category=EntityCategory.CONFIG, translation_key="energy_label",
), ),
SensorEntityDescription( HonConfigSensorEntityDescription(
key="startProgram.remainingTime", key="startProgram.remainingTime",
name="Time", name="Time",
icon="mdi:timer", icon="mdi:timer",
state_class=SensorStateClass.MEASUREMENT, state_class=SensorStateClass.MEASUREMENT,
native_unit_of_measurement=UnitOfTime.MINUTES, native_unit_of_measurement=UnitOfTime.MINUTES,
entity_category=EntityCategory.CONFIG,
translation_key="duration", translation_key="duration",
), ),
SensorEntityDescription( HonSensorEntityDescription(
key="machMode", key="machMode",
name="Machine Status", name="Machine Status",
icon="mdi:information", icon="mdi:information",
device_class=SensorDeviceClass.ENUM,
translation_key="washing_modes", translation_key="washing_modes",
options=list(const.MACH_MODE),
), ),
SensorEntityDescription( HonSensorEntityDescription(
key="errors", name="Error", icon="mdi:math-log", translation_key="errors" key="errors", name="Error", icon="mdi:math-log", translation_key="errors"
), ),
SensorEntityDescription( HonSensorEntityDescription(
key="remainingTimeMM", key="remainingTimeMM",
name="Remaining Time", name="Remaining Time",
icon="mdi:timer", icon="mdi:timer",
@ -379,56 +383,171 @@ SENSORS: dict[str, tuple[SensorEntityDescription, ...]] = {
native_unit_of_measurement=UnitOfTime.MINUTES, native_unit_of_measurement=UnitOfTime.MINUTES,
translation_key="remaining_time", translation_key="remaining_time",
), ),
SensorEntityDescription( HonSensorEntityDescription(
key="prPhase", key="prPhase",
name="Program Phase", name="Program Phase",
icon="mdi:washing-machine", icon="mdi:washing-machine",
device_class=SensorDeviceClass.ENUM,
translation_key="program_phases_dw", translation_key="program_phases_dw",
options=list(const.DISHWASHER_PR_PHASE),
),
),
"AC": (
HonSensorEntityDescription(
key="tempAirOutdoor",
name="Air Temperature Outdoor",
icon="mdi:thermometer",
state_class=SensorStateClass.MEASUREMENT,
device_class=SensorDeviceClass.TEMPERATURE,
native_unit_of_measurement=UnitOfTemperature.CELSIUS,
),
HonSensorEntityDescription(
key="tempCoilerIndoor",
name="Coiler Temperature Indoor",
icon="mdi:thermometer",
state_class=SensorStateClass.MEASUREMENT,
device_class=SensorDeviceClass.TEMPERATURE,
native_unit_of_measurement=UnitOfTemperature.CELSIUS,
),
HonSensorEntityDescription(
key="tempCoilerOutdoor",
name="Coiler Temperature Outside",
icon="mdi:thermometer",
state_class=SensorStateClass.MEASUREMENT,
device_class=SensorDeviceClass.TEMPERATURE,
native_unit_of_measurement=UnitOfTemperature.CELSIUS,
),
HonSensorEntityDescription(
key="tempDefrostOutdoor",
name="Defrost Temperature Outdoor",
icon="mdi:thermometer",
state_class=SensorStateClass.MEASUREMENT,
device_class=SensorDeviceClass.TEMPERATURE,
native_unit_of_measurement=UnitOfTemperature.CELSIUS,
),
HonSensorEntityDescription(
key="tempInAirOutdoor",
name="In Air Temperature Outdoor",
icon="mdi:thermometer",
state_class=SensorStateClass.MEASUREMENT,
device_class=SensorDeviceClass.TEMPERATURE,
native_unit_of_measurement=UnitOfTemperature.CELSIUS,
),
HonSensorEntityDescription(
key="tempIndoor",
name="Indoor Temperature",
icon="mdi:thermometer",
state_class=SensorStateClass.MEASUREMENT,
device_class=SensorDeviceClass.TEMPERATURE,
native_unit_of_measurement=UnitOfTemperature.CELSIUS,
),
HonSensorEntityDescription(
key="tempOutdoor",
name="Outdoor Temperature",
icon="mdi:thermometer",
state_class=SensorStateClass.MEASUREMENT,
device_class=SensorDeviceClass.TEMPERATURE,
native_unit_of_measurement=UnitOfTemperature.CELSIUS,
),
HonSensorEntityDescription(
key="tempSel",
name="Selected Temperature",
icon="mdi:thermometer",
state_class=SensorStateClass.MEASUREMENT,
device_class=SensorDeviceClass.TEMPERATURE,
native_unit_of_measurement=UnitOfTemperature.CELSIUS,
),
),
"REF": (
HonSensorEntityDescription(
key="humidityEnv",
name="Room Humidity",
icon="mdi:water-percent",
device_class=SensorDeviceClass.HUMIDITY,
native_unit_of_measurement=PERCENTAGE,
state_class=SensorStateClass.MEASUREMENT,
translation_key="humidity",
),
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="tempZ1",
name="Temperature Fridge",
icon="mdi:thermometer",
state_class=SensorStateClass.MEASUREMENT,
device_class=SensorDeviceClass.TEMPERATURE,
native_unit_of_measurement=UnitOfTemperature.CELSIUS,
translation_key="fridge_temp",
),
HonSensorEntityDescription(
key="tempZ2",
name="Temperature Freezer",
icon="mdi:snowflake-thermometer",
state_class=SensorStateClass.MEASUREMENT,
device_class=SensorDeviceClass.TEMPERATURE,
native_unit_of_measurement=UnitOfTemperature.CELSIUS,
translation_key="freezer_temp",
),
HonSensorEntityDescription(
key="errors", name="Error", icon="mdi:math-log", translation_key="errors"
), ),
), ),
} }
SENSORS["WD"] = unique_entities(SENSORS["WM"], SENSORS["TD"])
async def async_setup_entry(hass, entry: ConfigEntry, async_add_entities) -> None: async def async_setup_entry(hass, entry: ConfigEntry, async_add_entities) -> None:
hon: Hon = hass.data[DOMAIN][entry.unique_id] entities = []
coordinators = hass.data[DOMAIN]["coordinators"] for device in hass.data[DOMAIN][entry.unique_id].appliances:
appliances = [] for description in SENSORS.get(device.appliance_type, []):
for device in hon.appliances: if isinstance(description, HonSensorEntityDescription):
if device.unique_id in coordinators:
coordinator = hass.data[DOMAIN]["coordinators"][device.unique_id]
else:
coordinator = HonCoordinator(hass, device)
hass.data[DOMAIN]["coordinators"][device.unique_id] = coordinator
await coordinator.async_config_entry_first_refresh()
if descriptions := SENSORS.get(device.appliance_type):
for description in descriptions:
if not device.get(description.key): if not device.get(description.key):
_LOGGER.warning(
"[%s] Can't setup %s", device.appliance_type, description.key
)
continue continue
appliances.extend( entity = HonSensorEntity(hass, entry, device, description)
[HonSensorEntity(hass, coordinator, entry, device, description)] elif isinstance(description, HonConfigSensorEntityDescription):
) if description.key not in device.available_settings:
continue
entity = HonConfigSensorEntity(hass, entry, device, description)
else:
continue
await entity.coordinator.async_config_entry_first_refresh()
entities.append(entity)
async_add_entities(appliances) async_add_entities(entities)
class HonSensorEntity(HonEntity, SensorEntity): class HonSensorEntity(HonEntity, SensorEntity):
def __init__(self, hass, coordinator, entry, device, description) -> None: entity_description: HonSensorEntityDescription
super().__init__(hass, entry, coordinator, device)
self._coordinator = coordinator
self.entity_description = description
self._attr_unique_id = f"{super().unique_id}{description.key}"
@property
def native_value(self) -> StateType:
return self._device.get(self.entity_description.key, "")
@callback @callback
def _handle_coordinator_update(self): def _handle_coordinator_update(self):
self._attr_native_value = self._device.get(self.entity_description.key, "") value = self._device.get(self.entity_description.key, "")
if not value and self.entity_description.state_class is not None:
self._attr_native_value = 0
self._attr_native_value = value
self.async_write_ha_state()
class HonConfigSensorEntity(HonEntity, SensorEntity):
entity_description: HonConfigSensorEntityDescription
@callback
def _handle_coordinator_update(self):
value = self._device.settings.get(self.entity_description.key, None)
if self.entity_description.state_class is not None:
if value and value.value:
self._attr_native_value = (
float(value.value) if "." in str(value.value) else int(value.value)
)
else:
self._attr_native_value = 0
else:
self._attr_native_value = value.value
self.async_write_ha_state() self.async_write_ha_state()

View File

@ -5,12 +5,12 @@ 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.const import EntityCategory
from pyhon import Hon from homeassistant.core import callback
from pyhon.appliance import HonAppliance from pyhon.parameter.base import HonParameter
from pyhon.parameter.range import HonParameterRange from pyhon.parameter.range import HonParameterRange
from .const import DOMAIN from .const import DOMAIN
from .hon import HonCoordinator, HonEntity from .hon import HonEntity, unique_entities
_LOGGER = logging.getLogger(__name__) _LOGGER = logging.getLogger(__name__)
@ -22,15 +22,24 @@ class HonSwitchEntityDescriptionMixin:
@dataclass @dataclass
class HonSwitchEntityDescription( class HonControlSwitchEntityDescription(
HonSwitchEntityDescriptionMixin, SwitchEntityDescription HonSwitchEntityDescriptionMixin, SwitchEntityDescription
): ):
pass pass
class HonSwitchEntityDescription(SwitchEntityDescription):
pass
@dataclass
class HonConfigSwitchEntityDescription(SwitchEntityDescription):
entity_category: EntityCategory = EntityCategory.CONFIG
SWITCHES: dict[str, tuple[HonSwitchEntityDescription, ...]] = { SWITCHES: dict[str, tuple[HonSwitchEntityDescription, ...]] = {
"WM": ( "WM": (
HonSwitchEntityDescription( HonControlSwitchEntityDescription(
key="active", key="active",
name="Washing Machine", name="Washing Machine",
icon="mdi:washing-machine", icon="mdi:washing-machine",
@ -38,7 +47,7 @@ SWITCHES: dict[str, tuple[HonSwitchEntityDescription, ...]] = {
turn_off_key="stopProgram", turn_off_key="stopProgram",
translation_key="washing_machine", translation_key="washing_machine",
), ),
HonSwitchEntityDescription( HonControlSwitchEntityDescription(
key="pause", key="pause",
name="Pause Washing Machine", name="Pause Washing Machine",
icon="mdi:pause", icon="mdi:pause",
@ -46,22 +55,69 @@ SWITCHES: dict[str, tuple[HonSwitchEntityDescription, ...]] = {
turn_off_key="resumeProgram", turn_off_key="resumeProgram",
translation_key="pause", translation_key="pause",
), ),
HonSwitchEntityDescription( HonConfigSwitchEntityDescription(
key="startProgram.delayStatus", key="startProgram.delayStatus",
name="Delay Status", name="Delay Status",
icon="mdi:timer-check", icon="mdi:timer-check",
entity_category=EntityCategory.CONFIG, translation_key="delay_time",
), ),
HonSwitchEntityDescription( HonConfigSwitchEntityDescription(
key="startProgram.haier_SoakPrewashSelection", key="startProgram.haier_SoakPrewashSelection",
name="Soak Prewash Selection", name="Soak Prewash Selection",
icon="mdi:tshirt-crew", icon="mdi:tshirt-crew",
entity_category=EntityCategory.CONFIG,
translation_key="prewash", translation_key="prewash",
), ),
HonConfigSwitchEntityDescription(
key="startProgram.permanentPressStatus",
name="Keep Fresh",
icon="mdi:refresh-circle",
translation_key="keep_fresh",
),
HonConfigSwitchEntityDescription(
key="startProgram.autoSoftenerStatus",
name="Auto Dose Softener",
icon="mdi:teddy-bear",
translation_key="auto_dose_softener",
),
HonConfigSwitchEntityDescription(
key="startProgram.autoDetergentStatus",
name="Auto Dose Detergent",
icon="mdi:cup",
translation_key="auto_dose_detergent",
),
HonConfigSwitchEntityDescription(
key="startProgram.acquaplus",
name="Acqua Plus",
icon="mdi:water-plus",
translation_key="acqua_plus",
),
HonConfigSwitchEntityDescription(
key="startProgram.extraRinse1",
name="Extra Rinse 1",
icon="mdi:numeric-1-box-multiple-outline",
translation_key="extra_rinse_1",
),
HonConfigSwitchEntityDescription(
key="startProgram.extraRinse2",
name="Extra Rinse 2",
icon="mdi:numeric-2-box-multiple-outline",
translation_key="extra_rinse_2",
),
HonConfigSwitchEntityDescription(
key="startProgram.extraRinse3",
name="Extra Rinse 3",
icon="mdi:numeric-3-box-multiple-outline",
translation_key="extra_rinse_3",
),
HonConfigSwitchEntityDescription(
key="startProgram.goodNight",
name="Good Night",
icon="mdi:weather-night",
translation_key="good_night",
),
), ),
"TD": ( "TD": (
HonSwitchEntityDescription( HonControlSwitchEntityDescription(
key="active", key="active",
name="Tumble Dryer", name="Tumble Dryer",
icon="mdi:tumble-dryer", icon="mdi:tumble-dryer",
@ -69,7 +125,7 @@ SWITCHES: dict[str, tuple[HonSwitchEntityDescription, ...]] = {
turn_off_key="stopProgram", turn_off_key="stopProgram",
translation_key="tumble_dryer", translation_key="tumble_dryer",
), ),
HonSwitchEntityDescription( HonControlSwitchEntityDescription(
key="pause", key="pause",
name="Pause Tumble Dryer", name="Pause Tumble Dryer",
icon="mdi:pause", icon="mdi:pause",
@ -77,22 +133,26 @@ SWITCHES: dict[str, tuple[HonSwitchEntityDescription, ...]] = {
turn_off_key="resumeProgram", turn_off_key="resumeProgram",
translation_key="pause", translation_key="pause",
), ),
HonSwitchEntityDescription( HonConfigSwitchEntityDescription(
key="startProgram.sterilizationStatus", key="startProgram.sterilizationStatus",
name="Sterilization", name="Sterilization",
icon="mdi:clock-start", icon="mdi:clock-start",
entity_category=EntityCategory.CONFIG,
), ),
HonSwitchEntityDescription( HonConfigSwitchEntityDescription(
key="startProgram.antiCreaseTime", key="startProgram.antiCreaseTime",
name="Anti-Crease", name="Anti-Crease",
entity_category=EntityCategory.CONFIG, icon="mdi:timer",
translation_key="anti_crease",
),
HonConfigSwitchEntityDescription(
key="startProgram.anticrease",
name="Anti-Crease",
icon="mdi:timer", icon="mdi:timer",
translation_key="anti_crease", translation_key="anti_crease",
), ),
), ),
"OV": ( "OV": (
HonSwitchEntityDescription( HonControlSwitchEntityDescription(
key="active", key="active",
name="Oven", name="Oven",
icon="mdi:toaster-oven", icon="mdi:toaster-oven",
@ -100,26 +160,25 @@ SWITCHES: dict[str, tuple[HonSwitchEntityDescription, ...]] = {
turn_off_key="stopProgram", turn_off_key="stopProgram",
translation_key="oven", translation_key="oven",
), ),
HonSwitchEntityDescription( HonConfigSwitchEntityDescription(
key="startProgram.preheatStatus", key="startProgram.preheatStatus",
name="Preheat", name="Preheat",
icon="mdi:thermometer-chevron-up", icon="mdi:thermometer-chevron-up",
entity_category=EntityCategory.CONFIG,
translation_key="preheat", translation_key="preheat",
), ),
), ),
"WD": ( "WD": (
HonSwitchEntityDescription( HonControlSwitchEntityDescription(
key="active", key="active",
name="Washing Machine", name="Washer Dryer",
icon="mdi:washing-machine", icon="mdi:washing-machine",
turn_on_key="startProgram", turn_on_key="startProgram",
turn_off_key="stopProgram", turn_off_key="stopProgram",
translation_key="washer_dryer", translation_key="washer_dryer",
), ),
HonSwitchEntityDescription( HonControlSwitchEntityDescription(
key="pause", key="pause",
name="Pause Washing Machine", name="Pause Washer Dryer",
icon="mdi:pause", icon="mdi:pause",
turn_on_key="pauseProgram", turn_on_key="pauseProgram",
turn_off_key="resumeProgram", turn_off_key="resumeProgram",
@ -127,7 +186,7 @@ SWITCHES: dict[str, tuple[HonSwitchEntityDescription, ...]] = {
), ),
), ),
"DW": ( "DW": (
HonSwitchEntityDescription( HonControlSwitchEntityDescription(
key="active", key="active",
name="Dish Washer", name="Dish Washer",
icon="mdi:dishwasher", icon="mdi:dishwasher",
@ -135,126 +194,267 @@ SWITCHES: dict[str, tuple[HonSwitchEntityDescription, ...]] = {
turn_off_key="stopProgram", turn_off_key="stopProgram",
translation_key="dish_washer", translation_key="dish_washer",
), ),
HonSwitchEntityDescription( HonConfigSwitchEntityDescription(
key="startProgram.extraDry", key="startProgram.extraDry",
name="Extra Dry", name="Extra Dry",
icon="mdi:hair-dryer", icon="mdi:hair-dryer",
entity_category=EntityCategory.CONFIG,
translation_key="extra_dry", translation_key="extra_dry",
), ),
HonSwitchEntityDescription( HonConfigSwitchEntityDescription(
key="startProgram.halfLoad", key="startProgram.halfLoad",
name="Half Load", name="Half Load",
icon="mdi:fraction-one-half", icon="mdi:fraction-one-half",
entity_category=EntityCategory.CONFIG,
translation_key="half_load", translation_key="half_load",
), ),
HonSwitchEntityDescription( HonConfigSwitchEntityDescription(
key="startProgram.openDoor", key="startProgram.openDoor",
name="Open Door", name="Open Door",
icon="mdi:door-open", icon="mdi:door-open",
entity_category=EntityCategory.CONFIG,
translation_key="open_door", translation_key="open_door",
), ),
HonSwitchEntityDescription( HonConfigSwitchEntityDescription(
key="startProgram.threeInOne", key="startProgram.threeInOne",
name="Three in One", name="Three in One",
icon="mdi:numeric-3-box-outline", icon="mdi:numeric-3-box-outline",
entity_category=EntityCategory.CONFIG,
translation_key="three_in_one", translation_key="three_in_one",
), ),
HonSwitchEntityDescription( HonConfigSwitchEntityDescription(
key="startProgram.ecoExpress", key="startProgram.ecoExpress",
name="Eco Express", name="Eco Express",
icon="mdi:sprout", icon="mdi:sprout",
entity_category=EntityCategory.CONFIG,
translation_key="eco", translation_key="eco",
), ),
HonSwitchEntityDescription( HonConfigSwitchEntityDescription(
key="startProgram.addDish", key="startProgram.addDish",
name="Add Dish", name="Add Dish",
icon="mdi:silverware-fork-knife", icon="mdi:silverware-fork-knife",
entity_category=EntityCategory.CONFIG,
translation_key="add_dish", translation_key="add_dish",
), ),
HonSwitchEntityDescription(
key="buzzerDisabled",
name="Buzzer Disabled",
icon="mdi:volume-off",
translation_key="buzzer",
),
),
"AC": (
HonSwitchEntityDescription(
key="10degreeHeatingStatus",
name="10° Heating",
icon="mdi:heat-wave",
translation_key="10_degree_heating",
),
HonSwitchEntityDescription(
key="echoStatus",
name="Echo",
icon="mdi:account-voice",
),
HonSwitchEntityDescription(
key="ecoMode",
name="Eco Mode",
translation_key="eco_mode",
),
HonSwitchEntityDescription(
key="healthMode",
name="Health Mode",
icon="mdi:medication-outline",
),
HonSwitchEntityDescription(
key="muteStatus",
name="Mute",
icon="mdi:volume-off",
translation_key="mute_mode",
),
HonSwitchEntityDescription(
key="rapidMode",
name="Rapid Mode",
icon="mdi:run-fast",
translation_key="rapid_mode",
),
HonSwitchEntityDescription(
key="screenDisplayStatus",
name="Screen Display",
icon="mdi:monitor-small",
),
HonSwitchEntityDescription(
key="selfCleaning56Status",
name="Self Cleaning 56",
icon="mdi:air-filter",
translation_key="self_clean_56",
),
HonSwitchEntityDescription(
key="selfCleaningStatus",
name="Self Cleaning",
icon="mdi:air-filter",
translation_key="self_clean",
),
HonSwitchEntityDescription(
key="silentSleepStatus",
name="Silent Sleep",
icon="mdi:bed",
translation_key="silent_mode",
),
),
"REF": (
HonSwitchEntityDescription(
key="intelligenceMode",
name="Auto-Set Mode",
icon="mdi:thermometer-auto",
translation_key="auto_set",
),
HonSwitchEntityDescription(
key="quickModeZ1",
name="Super Freeze",
icon="mdi:snowflake-variant",
translation_key="super_freeze",
),
HonSwitchEntityDescription(
key="quickModeZ2",
name="Super Cool",
icon="mdi:snowflake",
translation_key="super_cool",
),
HonSwitchEntityDescription(
key="holidayMode",
name="Holiday Mode",
icon="mdi:palm-tree",
translation_key="holiday_mode",
),
), ),
} }
SWITCHES["WD"] = unique_entities(SWITCHES["WD"], SWITCHES["WM"])
SWITCHES["WD"] = unique_entities(SWITCHES["WD"], SWITCHES["TD"])
async def async_setup_entry(hass, entry: ConfigEntry, async_add_entities) -> None: async def async_setup_entry(hass, entry: ConfigEntry, async_add_entities) -> None:
hon: Hon = hass.data[DOMAIN][entry.unique_id] entities = []
coordinators = hass.data[DOMAIN]["coordinators"] for device in hass.data[DOMAIN][entry.unique_id].appliances:
appliances = [] for description in SWITCHES.get(device.appliance_type, []):
for device in hon.appliances: if isinstance(description, HonConfigSwitchEntityDescription):
if device.unique_id in coordinators: if description.key not in device.available_settings:
coordinator = hass.data[DOMAIN]["coordinators"][device.unique_id] continue
else: entity = HonConfigSwitchEntity(hass, entry, device, description)
coordinator = HonCoordinator(hass, device) elif isinstance(description, HonControlSwitchEntityDescription):
hass.data[DOMAIN]["coordinators"][device.unique_id] = coordinator if not (
await coordinator.async_config_entry_first_refresh()
if descriptions := SWITCHES.get(device.appliance_type):
for description in descriptions:
if (
device.get(description.key) is not None device.get(description.key) is not None
or device.commands.get(description.key) is not None or description.turn_on_key in list(device.commands)
or description.turn_off_key in list(device.commands)
): ):
appliances.extend( continue
[HonSwitchEntity(hass, coordinator, entry, device, description)] entity = HonControlSwitchEntity(hass, entry, device, description)
) elif isinstance(description, HonSwitchEntityDescription):
else: if (
_LOGGER.warning( f"settings.{description.key}" not in device.available_settings
"[%s] Can't setup %s", device.appliance_type, description.key or not device.get(description.key)
) ):
continue
entity = HonSwitchEntity(hass, entry, device, description)
else:
continue
await entity.coordinator.async_config_entry_first_refresh()
entities.append(entity)
async_add_entities(appliances) async_add_entities(entities)
class HonSwitchEntity(HonEntity, SwitchEntity): class HonSwitchEntity(HonEntity, SwitchEntity):
entity_description: HonSwitchEntityDescription entity_description: HonSwitchEntityDescription
def __init__( @property
self, def is_on(self) -> bool | None:
hass, """Return True if entity is on."""
coordinator, return self._device.get(self.entity_description.key, "0") == "1"
entry,
device: HonAppliance, async def async_turn_on(self, **kwargs: Any) -> None:
description: HonSwitchEntityDescription, setting = self._device.settings[f"settings.{self.entity_description.key}"]
) -> None: if type(setting) == HonParameter:
super().__init__(hass, entry, coordinator, device) return
self._coordinator = coordinator setting.value = setting.max if isinstance(setting, HonParameterRange) else "1"
self._device = device self.async_write_ha_state()
self.entity_description = description await self._device.commands["settings"].send()
self._attr_unique_id = f"{super().unique_id}{description.key}" await self.coordinator.async_refresh()
async def async_turn_off(self, **kwargs: Any) -> None:
setting = self._device.settings[f"settings.{self.entity_description.key}"]
if type(setting) == HonParameter:
return
setting.value = setting.min if isinstance(setting, HonParameterRange) else "0"
self.async_write_ha_state()
await self._device.commands["settings"].send()
await self.coordinator.async_refresh()
@property
def available(self) -> bool:
"""Return True if entity is available."""
return (
super().available
and self._device.get("remoteCtrValid", "1") == "1"
and self._device.get("attributes.lastConnEvent.category") != "DISCONNECTED"
)
@callback
def _handle_coordinator_update(self):
value = self._device.get(self.entity_description.key, "0")
self._attr_state = value == "1"
self.async_write_ha_state()
class HonControlSwitchEntity(HonEntity, SwitchEntity):
entity_description: HonControlSwitchEntityDescription
@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."""
if self.entity_category == EntityCategory.CONFIG:
setting = self._device.settings[self.entity_description.key]
return (
setting.value == "1"
or hasattr(setting, "min")
and setting.value != setting.min
)
return self._device.get(self.entity_description.key, False) return self._device.get(self.entity_description.key, False)
async def async_turn_on(self, **kwargs: Any) -> None: async def async_turn_on(self, **kwargs: Any) -> None:
if self.entity_category == EntityCategory.CONFIG: await self._device.commands[self.entity_description.turn_on_key].send()
setting = self._device.settings[self.entity_description.key]
setting.value = (
setting.max if isinstance(setting, HonParameterRange) else "1"
)
self.async_write_ha_state()
else:
await self._device.commands[self.entity_description.turn_on_key].send()
async def async_turn_off(self, **kwargs: Any) -> None: async def async_turn_off(self, **kwargs: Any) -> None:
if self.entity_category == EntityCategory.CONFIG: await self._device.commands[self.entity_description.turn_off_key].send()
setting = self._device.settings[self.entity_description.key]
setting.value = ( @property
setting.min if isinstance(setting, HonParameterRange) else "0" def available(self) -> bool:
) """Return True if entity is available."""
self.async_write_ha_state() return (
else: super().available
await self._device.commands[self.entity_description.turn_off_key].send() and self._device.get("remoteCtrValid", "1") == "1"
and self._device.get("attributes.lastConnEvent.category") != "DISCONNECTED"
)
class HonConfigSwitchEntity(HonEntity, SwitchEntity):
entity_description: HonConfigSwitchEntityDescription
@property
def is_on(self) -> bool | None:
"""Return True if entity is on."""
setting = self._device.settings[self.entity_description.key]
return (
setting.value != setting.min
if hasattr(setting, "min")
else setting.value == "1"
)
async def async_turn_on(self, **kwargs: Any) -> None:
setting = self._device.settings[self.entity_description.key]
if type(setting) == HonParameter:
return
setting.value = setting.max if isinstance(setting, HonParameterRange) else "1"
self.async_write_ha_state()
await self.coordinator.async_refresh()
async def async_turn_off(self, **kwargs: Any) -> None:
setting = self._device.settings[self.entity_description.key]
if type(setting) == HonParameter:
return
setting.value = setting.min if isinstance(setting, HonParameterRange) else "0"
self.async_write_ha_state()
await self.coordinator.async_refresh()
@callback
def _handle_coordinator_update(self):
value = self._device.settings.get(self.entity_description.key, "0")
self._attr_state = value == "1"
self.async_write_ha_state()

View File

@ -30,7 +30,7 @@
"8000000000000": "E4: Провери подаването на вода" "8000000000000": "E4: Провери подаването на вода"
} }
}, },
"tumbledryerprogram": { "programs": {
"state": { "state": {
"0": "Стандартна", "0": "Стандартна",
"62": "Памук", "62": "Памук",

File diff suppressed because it is too large Load Diff

File diff suppressed because it is too large Load Diff

File diff suppressed because it is too large Load Diff

View File

@ -2,9 +2,9 @@
"config": { "config": {
"step": { "step": {
"user": { "user": {
"description": "Please enters your hOn credentials", "description": "Do the login",
"data": { "data": {
"email": "Email Address", "email": "Email",
"password": "Password" "password": "Password"
} }
} }
@ -28,9 +28,10 @@
"00": "No error", "00": "No error",
"100000000000": "E2: Check if the door is closed", "100000000000": "E2: Check if the door is closed",
"8000000000000": "E4: Check the water supply" "8000000000000": "E4: Check the water supply"
} },
"name": "Error"
}, },
"tumbledryerprogram": { "programs": {
"state": { "state": {
"0": "Default", "0": "Default",
"62": "Cotton", "62": "Cotton",
@ -47,7 +48,8 @@
"85": "Quick Dry", "85": "Quick Dry",
"92": "Delicate", "92": "Delicate",
"103": "Remote" "103": "Remote"
} },
"name": "Current program"
}, },
"tumbledryertemplevel": { "tumbledryertemplevel": {
"state": { "state": {
@ -75,7 +77,10 @@
"4": "Scheduled", "4": "Scheduled",
"5": "Scheduled", "5": "Scheduled",
"6": "Error", "6": "Error",
"7": "Ready" "7": "Ready",
"2": "Program running",
"8": "Test",
"9": "Stopping cycle…"
} }
}, },
"program_phases_wm": { "program_phases_wm": {
@ -119,7 +124,9 @@
"16": "Cooldown", "16": "Cooldown",
"18": "Keep Fresh", "18": "Keep Fresh",
"19": "Drying", "19": "Drying",
"20": "Drying" "20": "Drying",
"11": "Ready",
"17": "unknown"
}, },
"name": "Phase" "name": "Phase"
}, },
@ -145,9 +152,10 @@
"12": "Iron dry", "12": "Iron dry",
"13": "Cupboard Dry", "13": "Cupboard Dry",
"14": "Ready to wear", "14": "Ready to wear",
"15": "Extra dry" "15": "Extra dry",
"11": "No drying"
}, },
"name": "Drying Type" "name": "Drying level"
}, },
"power": { "power": {
"name": "Power level" "name": "Power level"
@ -180,7 +188,196 @@
"name": "Dirt level" "name": "Dirt level"
}, },
"delay_time": { "delay_time": {
"name": "Delay start" "name": "Delay Start"
},
"dry_time": {
"name": "Drying time"
},
"suggested_load": {
"name": "Load capacity"
},
"energy_label": {
"name": "Energy efficiency"
},
"det_dust": {
"name": "Powder detergent"
},
"det_liquid": {
"name": "Liquid detergent"
},
"cycles_total": {
"name": "Cycles Total"
},
"energy_total": {
"name": "Energy Consumption Total"
},
"water_total": {
"name": "Water efficiency Total"
},
"energy_current": {
"name": "Energy Consumption Current"
},
"water_current": {
"name": "Water efficiency Current"
},
"mach_modes_ac": {
"state": {
"0": "Auto",
"1": "Cool",
"2": "Cool",
"3": "Dry",
"4": "Heat",
"5": "Fan",
"6": "Fan"
}
},
"programs_td": {
"state": {
"active_dry": "Active Dry",
"allergy_care": "Anti-allergy",
"all_in_one": "All in One",
"antiallergy": "Anti-allergy",
"anti_odours": "Anti-odours",
"auto_care": "Auto Care",
"baby": "Baby",
"bed_quilt": "Bed Quilt",
"care_30": "Care 30",
"care_45": "Care 45",
"care_59": "Care 59",
"coloured": "Colored",
"daily_45_min": "Daily 45'",
"daily_perfect_59_min": "Daily Perfect 59'",
"darks_and_coloured": "Darks & Colored",
"delicates": "Delicates",
"duvet": "Duvet",
"eco": "Eco Cotton",
"ecospeed_cottons": "Ecospeed Cottons",
"ecospeed_delicates": "Ecospeed Delicates",
"ecospeed_mixed": "Ecospeed Mixed",
"extra_hygiene": "Extra Hygiene",
"fitness": "Fitness",
"fresh_care": "Fresh Care",
"genius": "Genius",
"hqd_baby_care": "Baby Care",
"hqd_bath_towel": "Towels",
"hqd_bed_sheets": "Bed Sheets",
"hqd_bulky": "Bulky Items",
"hqd_casual": "Casual",
"hqd_cold_wind_30": "Cool Breeze 30m",
"hqd_cold_wind_timing": "Cool Breeze ",
"hqd_cotton": "Cotton",
"hqd_curtain": "Curtains",
"hqd_delicate": "Delicates",
"hqd_diaper": "Diapers",
"hqd_duvet": "Duvet",
"hqd_feather": "Down Jackets",
"hqd_hot_wind_timing": "Hot Air",
"hqd_hygienic": "Hygienising",
"hqd_i_refresh": "I-Refresh",
"hqd_i_refresh_pro": "I-Refresh Pro",
"hqd_jacket": "Jackets",
"hqd_jeans": "Jeans",
"hqd_luxury": "Luxury",
"hqd_mix": "Mixed",
"hqd_night_dry": "Overnight drying",
"hqd_outdoor": "Outdoor",
"hqd_precious_cure": "Precious Cure",
"hqd_quick_20": "Quick 20m",
"hqd_quick_30": "Quick 30m",
"hqd_quick_dry": "Quick dry (30 min)",
"hqd_quilt": "Quilts",
"hqd_refresh": "Refresh",
"hqd_school_uniform": "School Uniform",
"hqd_shirt": "Shirts",
"hqd_shoes": "Shoes",
"hqd_silk": "Silk",
"hqd_sports": "Sports",
"hqd_synthetics": "Synthetics",
"hqd_timer": "Timed",
"hqd_towel": "Towels",
"hqd_underwear": "Underwear",
"hqd_warm_up": "Warm up",
"hqd_wool": "Wool",
"hqd_working_suit": "Workwear",
"hygiene": "Hygiene",
"iot_checkup": "Check-Up",
"iot_dry_anti_mites": "Anti-mites",
"iot_dry_baby": "Baby",
"iot_dry_backpacks": "Backpacks",
"iot_dry_bathrobe": "Bathrobe",
"iot_dry_bed_linen": "Bed Linen",
"iot_dry_bed_quilt": "Bed Quilt",
"iot_dry_cotton": "Cotton",
"iot_dry_cuddly_toys": "Cuddly Toys",
"iot_dry_curtains": "Curtains",
"iot_dry_dehumidifier": "Humidity Remover",
"iot_dry_delicates": "Delicates",
"iot_dry_delicate_tablecloths": "Delicate Tablecloths",
"iot_dry_denim_jeans": "Denim - Jeans",
"iot_dry_down_jacket": "Jacket",
"iot_dry_duvet": "Duvet",
"iot_dry_easy_iron_cotton": "Super Easy Iron",
"iot_dry_easy_iron_synthetics": "Super Easy Iron Synthetics",
"iot_dry_gym_fit": "Gym fit - Fitness",
"iot_dry_lingerie": "Lingerie",
"iot_dry_mixed": "Mixed",
"iot_dry_playsuits": "Playsuits",
"iot_dry_rapid_30": "Rapid 30m",
"iot_dry_rapid_59": "Rapid 59'",
"iot_dry_refresh": "Refresh",
"iot_dry_regenerates_waterproof": "Regenerates Waterproof",
"iot_dry_relax_creases": "Relax Creases",
"iot_dry_shirts": "Shirts",
"iot_dry_small_load": "Small Load",
"iot_dry_swimsuits_and_bikinis": "Swimsuits and Bikinis",
"iot_dry_synthetics": "Synthetics",
"iot_dry_synthetic_dry": "Synthetic Dry",
"iot_dry_tablecloths": "Tablecloths",
"iot_dry_technical_fabrics": "Technical Fabrics",
"iot_dry_warm_embrace": "Warm Embrace",
"iot_dry_wool": "Wool",
"jeans": "Jeans",
"mix_and_dry": "Mix&Dry",
"pets": "Pets",
"pre_iron": "Pre-Iron",
"rapid_30": "Rapid 30",
"rapid_45": "Rapid 45 min",
"rapid_59": "Perfect Rapid 59 Min",
"refresh": "Refresh",
"relax_creases": "Relax Creases",
"saving_30_min": "Saving 30'",
"shirts": "Shirts",
"shoes": "Shoes",
"small_load": "Small Load",
"soft_care": "Soft Care",
"sport_plus": "Sport Plus",
"super_easy_iron_misti": "Super Easy Iron Mixed",
"super_easy_iron_xxl": "Super Easy Iron XXL",
"super_fast_cottons": "Super Fast Cottons",
"super_fast_delicates": "Super Fast Delicates",
"synthetics": "Syntethics",
"total_care": "Total Care",
"trainers": "Trainers",
"ultra_care": "Ultra Care",
"waterproof_revitalize": "Waterproof Revitalize",
"whites": "Whites",
"wool": "Dry Wool",
"woolmark": "Wool",
"xxl_load": "XXL Load",
"zoom_59": "Zoom 59"
}
},
"room_temperature": {
"name": "Room temperature"
},
"humidity": {
"name": "Humidity"
},
"freezer_temp": {
"name": "Freezer temperature"
},
"fridge_temp": {
"name": "Fridge temperature"
} }
}, },
"switch": { "switch": {
@ -188,7 +385,7 @@
"name": "Anticrease" "name": "Anticrease"
}, },
"add_dish": { "add_dish": {
"name": "" "name": "Add dishes"
}, },
"eco_express": { "eco_express": {
"name": "Eco" "name": "Eco"
@ -228,6 +425,69 @@
}, },
"pause": { "pause": {
"name": "Pause" "name": "Pause"
},
"keep_fresh": {
"name": "Keep Fresh"
},
"delay_time": {
"name": "Delay Start"
},
"rapid_mode": {
"name": "Rapid mode"
},
"eco_mode": {
"name": "ECO mode"
},
"10_degree_heating": {
"name": "10°C Heating function"
},
"self_clean": {
"name": "Self-clean"
},
"self_clean_56": {
"name": "Steri-Clean 56°C"
},
"silent_mode": {
"name": "Silent mode"
},
"mute_mode": {
"name": "Mute mode"
},
"extra_rinse_1": {
"name": "+1 Rinse"
},
"extra_rinse_2": {
"name": "+2 Rinses"
},
"extra_rinse_3": {
"name": "+3 Rinses"
},
"acqua_plus": {
"name": "Acquaplus"
},
"auto_dose": {
"name": "Autodose"
},
"good_night": {
"name": "Good Night"
},
"auto_dose_softener": {
"name": "Autodose Softener"
},
"auto_dose_detergent": {
"name": "Autodose Detergent"
},
"auto_set": {
"name": "Auto-Set"
},
"super_cool": {
"name": "Super Cool"
},
"super_freeze": {
"name": "Super Freeze"
},
"refrigerator": {
"name": "Refrigerator"
} }
}, },
"select": { "select": {
@ -241,43 +501,44 @@
"12": "Iron dry", "12": "Iron dry",
"13": "Cupboard Dry", "13": "Cupboard Dry",
"14": "Ready to wear", "14": "Ready to wear",
"15": "Extra dry" "15": "Extra dry",
"11": "No drying"
}, },
"name": "Drying Type" "name": "Drying level"
}, },
"programs_dw": { "programs_dw": {
"state": { "state": {
"59_min": "Rapid 59'", "59_min": "Rapid 59'",
"auto_care": "Auto Care", "auto_care": "Auto Care",
"auto_care_soil": "Auto Care", "auto_care_soil": "Auto Care",
"auto_hygiene": "Auto Hygiene",
"auto_plus": "AutoPlus", "auto_plus": "AutoPlus",
"auto_rapid": "Auto Rapid", "auto_plus_soil": "Auto Plus Soil",
"auto_rapid_soil": "Auto rapid Soil",
"auto_sensor": "Auto Sensor", "auto_sensor": "Auto Sensor",
"auto_sensor_soil": "Auto Sensor", "auto_sensor_soil": "Auto Sensor",
"auto_universal": "Auto Universal 50 - 60\u00b0C", "auto_universal": "Auto Universal 50 - 60°C",
"auto_universal_plus": "Auto Universal+ 65 - 75\u00b0C", "auto_universal_plus": "Auto Universal+ 65 - 75°C",
"auto_universal_plus_soil": "Auto Universal+ 65 - 75\u00b0C", "auto_universal_plus_soil": "Auto Universal+ 65 - 75°C",
"auto_universal_soil": "Auto Universal 50 - 60\u00b0C", "auto_universal_soil": "Auto Universal 50 - 60°C",
"auto_wash": "Auto Wash", "auto_wash": "Auto Wash",
"auto_wash_soil": "Auto Wash", "auto_wash_soil": "Auto Wash",
"classe_a_59": "A Wash 59' 65\u00b0C", "classe_a_59": "A Wash 59' 65°C",
"delicate": "Delicate 45\u00b0C", "delicate": "Delicate 45°C",
"dishwasher_care": "Limescale cleaning", "dishwasher_care": "Limescale cleaning",
"eco": "Eco", "eco": "Eco",
"eco_asynch": "Eco 45\u00b0C", "eco_asynch": "Eco 45°C",
"eco_bldc": "Eco 45\u00b0C", "eco_bldc": "Eco 45°C",
"eco_synch": "Eco 45\u00b0C", "eco_synch": "Eco 45°C",
"gentle_wash": "Gentle wash", "gentle_wash": "Gentle wash",
"glass": "Glass", "glass": "Glass",
"glassware": "Glassware 45\u00b0C", "glassware": "Glassware 45°C",
"glass_care": "Glass Care", "glass_care": "Glass Care",
"hygiene": "Hygiene", "hygiene": "Hygiene",
"hygiene_plus": "Hygiene+ 75\u00b0C", "hygiene_plus": "Hygiene+ 75°C",
"intensive": "Intensive ", "intensive": "Intensive ",
"intensive_rapid": "Intensive Rapid", "intensive_rapid": "Intensive Rapid",
"iot_auto_sensor": "Auto Sensor", "iot_auto_sensor": "Auto Sensor",
"iot_auto_universal_soil": "Auto Universal 50 - 60\u00b0C", "iot_auto_universal_soil": "Auto Universal 50 - 60°C",
"iot_auto_wash_soil": "Auto Wash", "iot_auto_wash_soil": "Auto Wash",
"iot_baby_care": "Baby Care", "iot_baby_care": "Baby Care",
"iot_breakfast": "Breakfast", "iot_breakfast": "Breakfast",
@ -288,15 +549,15 @@
"iot_cocktail_glasses_soil": "Coktail Glasses", "iot_cocktail_glasses_soil": "Coktail Glasses",
"iot_daily_care": "Daily Care", "iot_daily_care": "Daily Care",
"iot_daily_care_soil": "Daily Care", "iot_daily_care_soil": "Daily Care",
"iot_delicate": "Delicate 45\u00b0C", "iot_delicate": "Delicate 45°C",
"iot_dinner_for_two": "Dinner for 2", "iot_dinner_for_two": "Dinner for 2",
"iot_dinner_for_two_soil": "Dinner for 2", "iot_dinner_for_two_soil": "Dinner for 2",
"iot_dreft_quick_cycle": "Dreft Quick", "iot_dreft_quick_cycle": "Dreft Quick",
"iot_eco_asynch": "Eco 45\u00b0C", "iot_eco_asynch": "Eco 45°C",
"iot_eco_bldc": "Eco 45\u00b0C", "iot_eco_bldc": "Eco 45°C",
"iot_eco_synch": "Eco 45\u00b0C", "iot_eco_synch": "Eco 45°C",
"iot_extra_hygiene": "Extra Hygiene", "iot_extra_hygiene": "Extra Hygiene",
"iot_fairy_quick_cycle": "Fairy Short", "iot_fairy_quick_cycle": "Fairy Quick",
"iot_happy_hour": "Happy Hour", "iot_happy_hour": "Happy Hour",
"iot_jar_quick_cycle": "Jar Quick", "iot_jar_quick_cycle": "Jar Quick",
"iot_party": "Party", "iot_party": "Party",
@ -310,23 +571,23 @@
"iot_prewash": "Pre-wash ", "iot_prewash": "Pre-wash ",
"iot_pyrex_and_glassware": "Pyrex & Glassware", "iot_pyrex_and_glassware": "Pyrex & Glassware",
"iot_rapid_29": "Rapid 29'", "iot_rapid_29": "Rapid 29'",
"iot_rapid_39": "Rapid 39' 60\u00b0C", "iot_rapid_39": "Rapid 39' 60°C",
"iot_single": "Single", "iot_single": "Single",
"iot_steam": "Steam 75\u00b0C", "iot_steam": "Steam 75°C",
"iot_super_flash": "Super Flash", "iot_super_flash": "Super Flash",
"iot_super_wash": "Super Wash", "iot_super_wash": "Super Wash",
"iot_turbopower": "TurboPower", "iot_turbopower": "TurboPower",
"iot_universal": "Universal 60\u00b0C", "iot_universal": "Universal 60°C",
"iot_wok_grids_maxi_pans": "Special Pans (Wok, Grids & Maxi Pans)", "iot_wok_grids_maxi_pans": "Special Pans (Wok, Grids & Maxi Pans)",
"iot_wok_grids_maxi_pans_soil": "Special Pans (Wok, Grids & Maxi Pans)", "iot_wok_grids_maxi_pans_soil": "Special Pans (Wok, Grids & Maxi Pans)",
"iot_yes_quick_cycle": "Yes Quick", "iot_yes_quick_cycle": "Yes Quick",
"night": "Night 55\u00b0C", "night": "Night 55°C",
"prewash": "Pre-wash ", "prewash": "Pre-wash ",
"rapid_20": "Rapid 20'", "rapid_20": "Rapid 20'",
"rapid_24": "Rapid 24'", "rapid_24": "Rapid 24'",
"rapid_29": "Rapid 29' 50\u00b0C", "rapid_29": "Rapid 29' 50°C",
"rapid_35": "Wash&Dry 35'", "rapid_35": "Wash&Dry 35'",
"rapid_39": "Rapid 39' 60\u00b0C", "rapid_39": "Rapid 39' 60°C",
"rapid_49": "Rapid 49'", "rapid_49": "Rapid 49'",
"rapid_59": "Rapid 59'", "rapid_59": "Rapid 59'",
"sanitising": "Sanitising", "sanitising": "Sanitising",
@ -335,16 +596,19 @@
"silent_care": "Silent Care", "silent_care": "Silent Care",
"smart_ai": "Smart AI", "smart_ai": "Smart AI",
"smart_ai_pro": "Smart AI Pro", "smart_ai_pro": "Smart AI Pro",
"smart_ai_pro_soil": "Smart AI Pro",
"smart_ai_rapid": "Smart AI Rapid", "smart_ai_rapid": "Smart AI Rapid",
"smart_ai_rapid_soil": "Smart AI Rapid",
"smart_ai_soil": "Smart AI",
"special": "Special", "special": "Special",
"special_pw_prz": "Special", "special_pw_prz": "Special",
"steam": "Steam 75\u00b0C", "steam": "Steam 75°C",
"steam_plus": "Steam Plus 75\u00b0C", "steam_plus": "Steam Plus 75°C",
"total_care": "Total Care 50\u00b0C", "total_care": "Total Care 50°C",
"ultra_silence": "Ultra Silence 55\u00b0C", "ultra_silence": "Ultra Silence 55°C",
"ultra_silent": "Ultra Silent 55\u00b0C", "ultra_silent": "Ultra Silent 55°C",
"universal": "Universal 60\u00b0C", "universal": "Universal 60°C",
"universal_plus": "Universal Plus 70\u00b0C", "universal_plus": "Universal Plus 70°C",
"zone_wash": "Flex Zone Wash", "zone_wash": "Flex Zone Wash",
"zoom_39": "Zoom 39 min" "zoom_39": "Zoom 39 min"
}, },
@ -392,21 +656,21 @@
}, },
"programs_ov": { "programs_ov": {
"state": { "state": {
"bakery": "Pasta and Pastries", "bakery": "Pasta and Bakery",
"bakery_steam": "Steam-baked bread", "bakery_steam": "Steam oven",
"bottom_heating": "Bottom Heating", "bottom_heating": "Bottom Heating",
"bottom_heating_fan": "Bottom Heating + Fan", "bottom_heating_fan": "Bottom Heating + Fan",
"bread": "Bread", "bread": "Bread",
"bread_steam": "Steam-baked pastries", "bread_steam": "Steam baked bread",
"combi": "Combi", "combi": "Combi",
"convection_fan": "Convection + Fan", "convection_fan": "Convection + Fan",
"convection_fan_turnspit": "Convection + Fan + Turnspit", "convection_fan_turnspit": "Convection + Fan + Turnspit",
"conventional": "Conventional", "conventional": "Conventional",
"conventional_turnspit": "Convection + Turnspit", "conventional_turnspit": "Convection + Turnspit",
"defrost": "Defrost", "defrost": "Defrosting",
"descaling": "Descaling", "descaling": "Descaling",
"fish": "Fish", "fish": "Fish",
"fish_steam": "Steam-cooked fish", "fish_steam": "Steamed fish",
"grill_cata": "Grill", "grill_cata": "Grill",
"grill_fan_cata": "Grill fan", "grill_fan_cata": "Grill fan",
"grill_fan_pyro": "Grill + Fan", "grill_fan_pyro": "Grill + Fan",
@ -415,16 +679,15 @@
"iot_bread": "Bread", "iot_bread": "Bread",
"iot_h20_clean": "h2O clean", "iot_h20_clean": "h2O clean",
"leavening": "Leavening", "leavening": "Leavening",
"light_fan": "Light Fan",
"light_fan\n": "Light Fan", "light_fan\n": "Light Fan",
"low_temp_cooking": "Low Temperature Cooking", "low_temp_cooking": "Low Temperature Cooking",
"low_temp_cooking_fish": "Low Temperature Cooking - Fish", "low_temp_cooking_fish": "Low Temperature Cooking - Fish",
"low_temp_cooking_fish_steam": "Low Temperature Steam Cooking - Fish", "low_temp_cooking_fish_steam": "Low Temperature Cooking - Steamed fish",
"low_temp_cooking_meat": "Low Temperature Cooking - Meat", "low_temp_cooking_meat": "Low Temperature Cooking - Meat",
"low_temp_cooking_meat_steam": "Low Temperature Steam Cooking - Meat", "low_temp_cooking_meat_steam": "Low Temperature Cooking - Steamed meat",
"low_temp_cooking_steam": "Low Temperature Steam Cooking", "low_temp_cooking_steam": "Low Temperature Steam Cooking",
"meat": "Meat", "meat": "Meat",
"meat_steam": "Steam-cooked meat", "meat_steam": "Steamed meat",
"multi_level": "Multi-Level", "multi_level": "Multi-Level",
"paella": "Paella", "paella": "Paella",
"pasta_and_bakery": "Pasta and Bakery", "pasta_and_bakery": "Pasta and Bakery",
@ -432,20 +695,19 @@
"pyrolysis": "Pyrolysis", "pyrolysis": "Pyrolysis",
"pyrolysis_plus": "Pyrolysis +", "pyrolysis_plus": "Pyrolysis +",
"red_meat": "Red Meat", "red_meat": "Red Meat",
"red_meat_steam": "Steam-cooked red meat", "red_meat_steam": "Steamed red meat",
"regenerate": "Regeneration", "regenerate": "Regenerate",
"soft_plus": "Soft+", "soft_plus": "Soft+",
"super_grill": "Super Grill", "super_grill": "Super Grill",
"tailor_bake": "Tailor bake", "tailor_bake": "Tailor bake",
"tailor_bake_cata": "Tailor Bake", "tailor_bake_cata": "Tailor Bake",
"tailor_bake_desctiption": "This function is ideal to keep food soft inside and crunchy outside. This function reduces the amount of fat or oil required, for a healthy diet. The combination of heating elements with a pulsating cycle of air ensures even baking results.",
"tailor_bake_pyro": "Tailor Bake", "tailor_bake_pyro": "Tailor Bake",
"vegetables": "Vegetables", "vegetables": "Vegetables",
"vegetables_cata": "Vegetables", "vegetables_cata": "Vegetables",
"vegetables_pyro": "Vegetables", "vegetables_pyro": "Vegetables",
"water_discharge": "Water Drain", "water_discharge": "Water Discharge",
"white_meat": "White Meat", "white_meat": "White Meat",
"white_meat_steam": "Steam-cooked white meat" "white_meat_steam": "Steamed white meat"
}, },
"name": "Program" "name": "Program"
}, },
@ -481,7 +743,7 @@
"hqd_bed_sheets": "Bed Sheets", "hqd_bed_sheets": "Bed Sheets",
"hqd_bulky": "Bulky Items", "hqd_bulky": "Bulky Items",
"hqd_casual": "Casual", "hqd_casual": "Casual",
"hqd_cold_wind_30": "Cool Breeze 30 minutes", "hqd_cold_wind_30": "Cool Breeze 30m",
"hqd_cold_wind_timing": "Cool Breeze ", "hqd_cold_wind_timing": "Cool Breeze ",
"hqd_cotton": "Cotton", "hqd_cotton": "Cotton",
"hqd_curtain": "Curtains", "hqd_curtain": "Curtains",
@ -500,9 +762,9 @@
"hqd_night_dry": "Overnight drying", "hqd_night_dry": "Overnight drying",
"hqd_outdoor": "Outdoor", "hqd_outdoor": "Outdoor",
"hqd_precious_cure": "Precious Cure", "hqd_precious_cure": "Precious Cure",
"hqd_quick_20": "Quick 20", "hqd_quick_20": "Quick 20m",
"hqd_quick_30": "Quick 30", "hqd_quick_30": "Quick 30m",
"hqd_quick_dry": "Quick dry", "hqd_quick_dry": "Quick dry (30 min)",
"hqd_quilt": "Quilts", "hqd_quilt": "Quilts",
"hqd_refresh": "Refresh", "hqd_refresh": "Refresh",
"hqd_school_uniform": "School Uniform", "hqd_school_uniform": "School Uniform",
@ -540,7 +802,7 @@
"iot_dry_lingerie": "Lingerie", "iot_dry_lingerie": "Lingerie",
"iot_dry_mixed": "Mixed", "iot_dry_mixed": "Mixed",
"iot_dry_playsuits": "Playsuits", "iot_dry_playsuits": "Playsuits",
"iot_dry_rapid_30": "Rapid 30", "iot_dry_rapid_30": "Rapid 30m",
"iot_dry_rapid_59": "Rapid 59'", "iot_dry_rapid_59": "Rapid 59'",
"iot_dry_refresh": "Refresh", "iot_dry_refresh": "Refresh",
"iot_dry_regenerates_waterproof": "Regenerates Waterproof", "iot_dry_regenerates_waterproof": "Regenerates Waterproof",
@ -588,8 +850,8 @@
}, },
"programs_wm": { "programs_wm": {
"state": { "state": {
"20_degrees_coloured_cottons": "20\u00b0 Colored and Cottons", "20_degrees_coloured_cottons": "20° Colored and Cottons",
"20_degrees_new_energy_label": "20\u00b0C", "20_degrees_new_energy_label": "20°C",
"active_steam": "Steam", "active_steam": "Steam",
"active_wash": "Active Wash", "active_wash": "Active Wash",
"active_wash_steam": "Active Wash + Steam", "active_wash_steam": "Active Wash + Steam",
@ -599,8 +861,8 @@
"all_in_one_59": "All in One 59'", "all_in_one_59": "All in One 59'",
"all_in_one_59_steam": "Active Wash + Steam", "all_in_one_59_steam": "Active Wash + Steam",
"autocare": "Autocare", "autocare": "Autocare",
"autoclean": "Drum Cleaning", "autoclean": "Drum cleaning and descaling ",
"baby_60": "All Baby 60\u00b0C", "baby_60": "All Baby 60°C",
"care_14": "Rapid Care 14'", "care_14": "Rapid Care 14'",
"care_30": "Rapid Care 30'", "care_30": "Rapid Care 30'",
"care_44": "Rapid Care 44'", "care_44": "Rapid Care 44'",
@ -626,7 +888,7 @@
"fresh_care_steam": "Fresh Care + Steam", "fresh_care_steam": "Fresh Care + Steam",
"handwash_wool": "Hand Wash + Wool", "handwash_wool": "Hand Wash + Wool",
"high_dry": "High Heat Dry", "high_dry": "High Heat Dry",
"hqd_20_degrees": "Cotton 20\u2103", "hqd_20_degrees": "Cotton 20",
"hqd_allergy": "Allergy Care", "hqd_allergy": "Allergy Care",
"hqd_autoclean": "Drum Cleaning", "hqd_autoclean": "Drum Cleaning",
"hqd_babycare": "Baby Care", "hqd_babycare": "Baby Care",
@ -653,13 +915,13 @@
"hqd_super_fast": "Super Fast 39'", "hqd_super_fast": "Super Fast 39'",
"hqd_synthetic_and_coloured": "Synthetics", "hqd_synthetic_and_coloured": "Synthetics",
"hygiene_59": "Hygiene Plus 59'", "hygiene_59": "Hygiene Plus 59'",
"hygiene_60": "Hygiene 60\u00b0C", "hygiene_60": "Hygiene 60°C",
"hygiene_plus_59": "Hygiene Plus 59'", "hygiene_plus_59": "Hygiene Plus 59'",
"hygiene_plus_59_min": "Hygiene Plus 59'", "hygiene_plus_59_min": "Hygiene Plus 59'",
"hygiene_pro_49_min": "Hygiene Pro 49'", "hygiene_pro_49_min": "Hygiene Pro 49'",
"hygiene_pro_steam": "Hygiene Pro + Steam", "hygiene_pro_steam": "Hygiene Pro + Steam",
"intensive_40": "Intensive 40\u00b0C", "intensive_40": "Intensive 40°C",
"intensive_40_steam": "Intensive 40\u00b0C + Steam", "intensive_40_steam": "Intensive 40°C + Steam",
"iot_active_steam": "Steam", "iot_active_steam": "Steam",
"iot_active_wash_steam": "Active Wash + Steam", "iot_active_wash_steam": "Active Wash + Steam",
"iot_allergy_care_pro": "Allergy Care Pro", "iot_allergy_care_pro": "Allergy Care Pro",
@ -699,7 +961,7 @@
"iot_easy_iron": "Easy Iron", "iot_easy_iron": "Easy Iron",
"iot_fresh_care_steam": "Fresh Care + Steam", "iot_fresh_care_steam": "Fresh Care + Steam",
"iot_hygiene_pro_steam": "Hygiene Pro + Steam", "iot_hygiene_pro_steam": "Hygiene Pro + Steam",
"iot_intensive_40_steam": "Intensive 40\u00b0C + Steam", "iot_intensive_40_steam": "Intensive 40°C + Steam",
"iot_mixed_steam": "Mixed + Steam", "iot_mixed_steam": "Mixed + Steam",
"iot_mix_and_colour_59_steam": "Mixed and Coloured 59' + Steam", "iot_mix_and_colour_59_steam": "Mixed and Coloured 59' + Steam",
"iot_perfect_cotton_59_steam": "Perfect Cotton 59' + Steam", "iot_perfect_cotton_59_steam": "Perfect Cotton 59' + Steam",
@ -802,8 +1064,8 @@
"iot_wash_playsuits": "Playsuits", "iot_wash_playsuits": "Playsuits",
"iot_wash_playsuits_steam": "Playsuits + Steam", "iot_wash_playsuits_steam": "Playsuits + Steam",
"iot_wash_quick_drum_cleaner": "Quick drum cleaner", "iot_wash_quick_drum_cleaner": "Quick drum cleaner",
"iot_wash_rapid_14": "Rapid 14\u2019", "iot_wash_rapid_14": "Rapid 14",
"iot_wash_rapid_30": "Rapid 30\u2019", "iot_wash_rapid_30": "Rapid 30",
"iot_wash_rapid_44": "Rapid 44'", "iot_wash_rapid_44": "Rapid 44'",
"iot_wash_rapid_59": "Rapid 59'", "iot_wash_rapid_59": "Rapid 59'",
"iot_wash_rapid_59_steam": "Rapid 59' + Steam", "iot_wash_rapid_59_steam": "Rapid 59' + Steam",
@ -901,6 +1163,82 @@
}, },
"temperature": { "temperature": {
"name": "Temperature" "name": "Temperature"
},
"dry_time": {
"name": "Drying time"
},
"eco_pilot": {
"state": {
"0": "Off",
"1": "Avoid touch",
"2": "Follow"
},
"name": "Eco pilot"
},
"fan_mode": {
"state": {
"1": "High",
"2": "Medium ",
"3": "Low",
"4": "Auto",
"5": "Auto"
}
},
"programs_ac": {
"state": {
"iot_10_heating": "10°C Heating function",
"iot_auto": "Auto",
"iot_cool": "Cool",
"iot_dry": "Dry",
"iot_fan": "Fan",
"iot_heat": "Heat",
"iot_nano_aqua": "Nano Aqua",
"iot_purify": "Self-purify",
"iot_self_clean": "Self-clean",
"iot_self_clean_56": "Steri-Clean 56°C",
"iot_simple_start": "Start now",
"iot_uv": "UV",
"iot_uv_and_auto": "UV + Auto",
"iot_uv_and_cool": "UV + Cold",
"iot_uv_and_dry": "UV + Dehumidifier",
"iot_uv_and_fan": "UV + Fan",
"iot_uv_and_heat": "UV + Heat"
}
},
"programs_ref": {
"state": {
"auto_set": "AUTO-SET",
"cheese": "Cheese",
"chiller": "Quick cool",
"cold_drinks": "Soft chill",
"eco": "Eco",
"eco_mode": "Eco mode",
"fruits_and_veg": "Fruit&Veg",
"fruit_and_veg": "Fruit&Veg",
"holiday": "HOLIDAY",
"keep_fresh": "0° Fresh",
"no_mode_selected": "No mode selected",
"quick_cool": "QUICK COOL",
"sea_food": "Ready to cook meal",
"soft_frozen": "Soft freezing",
"soft_frozen\n": "Soft freezing",
"super_cool": "SUPER COOL",
"super_freeze": "SUPER FREEZE",
"tea": "Cold drinks or Beverages",
"zero_fresh": "0° Fresh"
}
},
"remaining_time": {
"name": "Time remaining"
},
"ref_zones": {
"state": {
"fridge": "Fridge",
"freezer": "Freezer",
"vtroom1": "My Zone",
"fridge_freezer": "Fridge & Freezer"
},
"name": "Zone"
} }
}, },
"binary_sensor": { "binary_sensor": {
@ -962,7 +1300,46 @@
"name": "Door open" "name": "Door open"
}, },
"connection": { "connection": {
"name": "Connection" "name": "Appliance connection"
},
"child_lock": {
"name": "Child Lock"
},
"on": {
"name": "On"
},
"prewash": {
"name": "Pre-wash "
},
"acqua_plus": {
"name": "Acquaplus"
},
"auto_dose": {
"name": "Autodose"
},
"buzzer": {
"name": "Cycle end chime"
},
"holiday_mode": {
"name": "Holiday Mode"
},
"auto_set": {
"name": "Auto-Set"
},
"super_cool": {
"name": "Super Cool"
},
"super_freeze": {
"name": "Super Freeze"
},
"freezer_door": {
"name": "Door open Freezer"
},
"fridge_door": {
"name": "Door open Fridge"
},
"filter_replacement": {
"name": "Filter replacement"
} }
}, },
"number": { "number": {
@ -973,7 +1350,7 @@
"name": "Temperature" "name": "Temperature"
}, },
"delay_time": { "delay_time": {
"name": "Delay start" "name": "Delay Start"
}, },
"water_hard": { "water_hard": {
"name": "Water hardness" "name": "Water hardness"
@ -989,11 +1366,123 @@
}, },
"wash_time": { "wash_time": {
"name": "Washing intensity" "name": "Washing intensity"
},
"dry_time": {
"name": "Drying time"
},
"steam_level": {
"name": "Steam Level"
},
"freezer_temp_sel": {
"name": "Target temperature Freezer"
},
"fridge_temp_sel": {
"name": "Target temperature Fridge"
} }
}, },
"button": { "button": {
"induction_hob": { "induction_hob": {
"name": "Induction Hob" "name": "Induction Hob"
},
"start_program": {
"name": "Program Start"
},
"stop_program": {
"name": "Program Stop"
}
},
"climate": {
"air_conditioner": {
"name": "Air conditioner"
},
"fridge": {
"name": "Fridge",
"state_attributes": {
"preset_mode": {
"name": "Fridge modes",
"state": {
"auto_set": "Auto-Set",
"super_cool": "Super Cool",
"holiday": "Holiday",
"no_mode": "No mode selected"
}
}
}
},
"freezer": {
"name": "Freezer",
"state_attributes": {
"preset_mode": {
"name": "Freezer modes",
"state": {
"auto_set": "Auto-Set",
"super_freeze": "Super Freeze",
"no_mode": "No mode selected"
}
}
}
},
"oven": {
"name": "Oven",
"state_attributes": {
"preset_mode": {
"name": "Programs",
"state": {
"bakery": "Pasta and Bakery",
"bakery_steam": "Steam oven",
"bottom_heating": "Bottom Heating",
"bottom_heating_fan": "Bottom Heating + Fan",
"bread": "Bread",
"bread_steam": "Steam baked bread",
"combi": "Combi",
"convection_fan": "Convection + Fan",
"convection_fan_turnspit": "Convection + Fan + Turnspit",
"conventional": "Conventional",
"conventional_turnspit": "Convection + Turnspit",
"defrost": "Defrosting",
"descaling": "Descaling",
"fish": "Fish",
"fish_steam": "Steamed fish",
"grill_cata": "Grill",
"grill_fan_cata": "Grill fan",
"grill_fan_pyro": "Grill + Fan",
"grill_pyro": "Grill",
"h20_clean": "H2O-Clean",
"iot_bread": "Bread",
"iot_h20_clean": "h2O clean",
"leavening": "Leavening",
"light_fan\n": "Light Fan",
"low_temp_cooking": "Low Temperature Cooking",
"low_temp_cooking_fish": "Low Temperature Cooking - Fish",
"low_temp_cooking_fish_steam": "Low Temperature Cooking - Steamed fish",
"low_temp_cooking_meat": "Low Temperature Cooking - Meat",
"low_temp_cooking_meat_steam": "Low Temperature Cooking - Steamed meat",
"low_temp_cooking_steam": "Low Temperature Steam Cooking",
"meat": "Meat",
"meat_steam": "Steamed meat",
"multi_level": "Multi-Level",
"paella": "Paella",
"pasta_and_bakery": "Pasta and Bakery",
"pizza": "Pizza",
"pyrolysis": "Pyrolysis",
"pyrolysis_plus": "Pyrolysis +",
"red_meat": "Red Meat",
"red_meat_steam": "Steamed red meat",
"regenerate": "Regenerate",
"soft_plus": "Soft+",
"super_grill": "Super Grill",
"tailor_bake": "Tailor bake",
"tailor_bake_cata": "Tailor Bake",
"tailor_bake_pyro": "Tailor Bake",
"vegetables": "Vegetables",
"vegetables_cata": "Vegetables",
"vegetables_pyro": "Vegetables",
"water_discharge": "Water Discharge",
"white_meat": "White Meat",
"white_meat_steam": "Steamed white meat"
}
}
}
} }
} }
} }

File diff suppressed because it is too large Load Diff

File diff suppressed because it is too large Load Diff

View File

@ -3,85 +3,91 @@
"sensor": { "sensor": {
"washing_modes": { "washing_modes": {
"state": { "state": {
"0": "\u05de\u05d5\u05bc\u05db\u05b8\u05df", "0": "מוּכָן",
"1": "\u05de\u05d5\u05bc\u05db\u05b8\u05df", "1": "מוּכָן",
"3": "\u05d4\u05b7\u05e4\u05e1\u05b8\u05e7\u05b8\u05d4", "3": "הַפסָקָה",
"4": "\u05de\u05ea\u05d5\u05d6\u05de\u05df", "4": "מתוזמן",
"5": "\u05de\u05ea\u05d5\u05d6\u05de\u05df", "5": "מתוזמן",
"6": "\u05e9\u05c1\u05b0\u05d2\u05b4\u05d9\u05d0\u05b8\u05d4", "6": "שְׁגִיאָה",
"7": "\u05de\u05d5\u05bc\u05db\u05b8\u05df" "7": "מוּכָן",
"2": "התוכנית פועלת",
"8": "Test",
"9": "Stopping cycle…"
} }
}, },
"program_phases_wm": { "program_phases_wm": {
"state": { "state": {
"0": "\u05de\u05d5\u05bc\u05db\u05b8\u05df", "0": "מוּכָן",
"1": "\u05dc\u05b4\u05e9\u05c1\u05b0\u05d8\u05d5\u05b9\u05e3", "1": "לִשְׁטוֹף",
"2": "\u05dc\u05b4\u05e9\u05c1\u05b0\u05d8\u05d5\u05b9\u05e3", "2": "לִשְׁטוֹף",
"3": "Spin", "3": "Spin",
"4": "\u05dc\u05b4\u05e9\u05c1\u05b0\u05d8\u05d5\u05b9\u05e3", "4": "לִשְׁטוֹף",
"5": "\u05dc\u05b4\u05e9\u05c1\u05b0\u05d8\u05d5\u05b9\u05e3", "5": "לִשְׁטוֹף",
"6": "\u05dc\u05b4\u05e9\u05c1\u05b0\u05d8\u05d5\u05b9\u05e3", "6": "לִשְׁטוֹף",
"7": "\u05d9\u05b4\u05d1\u05bc\u05d5\u05bc\u05e9\u05c1", "7": "יִבּוּשׁ",
"9": "\u05e7\u05b4\u05d9\u05d8\u05d5\u05b9\u05e8", "9": "קִיטוֹר",
"10": "\u05de\u05d5\u05bc\u05db\u05b8\u05df", "10": "מוּכָן",
"11": "Spin", "11": "Spin",
"12": "Weighing ", "12": "Weighing ",
"13": "Weighing ", "13": "Weighing ",
"14": "\u05dc\u05b4\u05e9\u05c1\u05b0\u05d8\u05d5\u05b9\u05e3", "14": "לִשְׁטוֹף",
"15": "\u05dc\u05b4\u05e9\u05c1\u05b0\u05d8\u05d5\u05b9\u05e3", "15": "לִשְׁטוֹף",
"16": "\u05dc\u05b4\u05e9\u05c1\u05b0\u05d8\u05d5\u05b9\u05e3", "16": "לִשְׁטוֹף",
"17": "\u05dc\u05b4\u05e9\u05c1\u05b0\u05d8\u05d5\u05b9\u05e3", "17": "לִשְׁטוֹף",
"18": "\u05dc\u05b4\u05e9\u05c1\u05b0\u05d8\u05d5\u05b9\u05e3", "18": "לִשְׁטוֹף",
"19": "\u05de\u05ea\u05d5\u05d6\u05de\u05df", "19": "מתוזמן",
"20": "\u05e9\u05de\u05d5\u05e8 \u05e2\u05dc \u05d8\u05e8\u05d9\u05d5\u05ea", "20": "שמור על טריות",
"24": "Refresh", "24": "Refresh",
"25": "\u05dc\u05b4\u05e9\u05c1\u05b0\u05d8\u05d5\u05b9\u05e3", "25": "לִשְׁטוֹף",
"26": "Heating", "26": "Heating",
"27": "\u05dc\u05b4\u05e9\u05c1\u05b0\u05d8\u05d5\u05b9\u05e3" "27": "לִשְׁטוֹף"
}, },
"name": "\u05e9\u05dc\u05d1" "name": "שלב"
}, },
"program_phases_td": { "program_phases_td": {
"state": { "state": {
"0": "\u05de\u05d5\u05bc\u05db\u05b8\u05df", "0": "מוּכָן",
"1": "Drying", "1": "Drying",
"2": "\u05d9\u05b4\u05d1\u05bc\u05d5\u05bc\u05e9\u05c1", "2": "יִבּוּשׁ",
"3": "Cooldown", "3": "Cooldown",
"13": "Cooldown", "13": "Cooldown",
"14": "Drying", "14": "Drying",
"15": "Drying", "15": "Drying",
"16": "Cooldown", "16": "Cooldown",
"18": "Keep Fresh", "18": "Keep Fresh",
"19": "\u05d9\u05b4\u05d1\u05bc\u05d5\u05bc\u05e9\u05c1", "19": "יִבּוּשׁ",
"20": "\u05d9\u05b4\u05d1\u05bc\u05d5\u05bc\u05e9\u05c1" "20": "יִבּוּשׁ",
"11": "מוּכָן",
"17": "unknown"
}, },
"name": "\u05e9\u05dc\u05d1" "name": "שלב"
}, },
"program_phases_dw": { "program_phases_dw": {
"state": { "state": {
"0": "\u05de\u05d5\u05bc\u05db\u05b8\u05df", "0": "מוּכָן",
"1": "Prewash", "1": "Prewash",
"2": "\u05dc\u05b4\u05e9\u05c1\u05b0\u05d8\u05d5\u05b9\u05e3", "2": "לִשְׁטוֹף",
"3": "\u05dc\u05b4\u05e9\u05c1\u05b0\u05d8\u05d5\u05b9\u05e3", "3": "לִשְׁטוֹף",
"4": "\u05d9\u05b4\u05d1\u05bc\u05d5\u05bc\u05e9\u05c1", "4": "יִבּוּשׁ",
"5": "\u05de\u05d5\u05bc\u05db\u05b8\u05df", "5": "מוּכָן",
"6": "Hot rinse" "6": "Hot rinse"
}, },
"name": "\u05e9\u05dc\u05d1" "name": "שלב"
}, },
"dry_levels": { "dry_levels": {
"state": { "state": {
"0": "\u05dc\u05dc\u05d0 \u05d9\u05d9\u05d1\u05d5\u05e9", "0": "ללא ייבוש",
"1": "\u05d1\u05bc\u05b7\u05e8\u05d6\u05b6\u05dc", "1": "בַּרזֶל",
"2": "\u05dc\u05d0 \u05dc\u05d9\u05d9\u05d1\u05e9 \u05d1\u05e8\u05d6\u05dc", "2": "לא לייבש ברזל",
"3": "\u05d0\u05e8\u05d5\u05df \u05d9\u05d1\u05e9", "3": "ארון יבש",
"4": "\u05d9\u05d1\u05e9 \u05d1\u05de\u05d9\u05d5\u05d7\u05d3", "4": "יבש במיוחד",
"12": "\u05d1\u05bc\u05b7\u05e8\u05d6\u05b6\u05dc", "12": "בַּרזֶל",
"13": "\u05d0\u05e8\u05d5\u05df \u05d9\u05d1\u05e9", "13": "ארון יבש",
"14": "Ready to wear", "14": "Ready to wear",
"15": "\u05d9\u05d1\u05e9 \u05d1\u05de\u05d9\u05d5\u05d7\u05d3" "15": "יבש במיוחד",
"11": "ללא ייבוש"
}, },
"name": "\u05d9\u05b4\u05d1\u05bc\u05d5\u05bc\u05e9\u05c1" "name": "רמת ייבוש"
}, },
"anti_crease": { "anti_crease": {
"name": "Anticrease" "name": "Anticrease"
@ -90,7 +96,7 @@
"name": "Power level" "name": "Power level"
}, },
"remaining_time": { "remaining_time": {
"name": "\u05d6\u05de\u05df \u05e9\u05e0\u05d5\u05ea\u05e8" "name": "זמן שנותר"
}, },
"temperature": { "temperature": {
"name": "Temperature" "name": "Temperature"
@ -102,34 +108,111 @@
"name": "Water savings" "name": "Water savings"
}, },
"duration": { "duration": {
"name": "\u05de\u05b6\u05e9\u05c1\u05b6\u05da" "name": "מֶשֶׁך"
}, },
"target_temperature": { "target_temperature": {
"name": "Target temperature" "name": "Target temperature"
}, },
"spin_speed": { "spin_speed": {
"name": "\u05e1\u05d9\u05d1\u05d5\u05d1" "name": "סיבוב"
}, },
"steam_leve": { "steam_leve": {
"name": "\u05de\u05e4\u05dc\u05e1 \u05e7\u05d9\u05d8\u05d5\u05e8" "name": "מפלס קיטור"
}, },
"dirt_level": { "dirt_level": {
"name": "\u05e8\u05de\u05ea \u05e2\u05e4\u05e8" "name": "רמת עפר"
}, },
"delay_time": { "delay_time": {
"name": "\u05dc\u05d5\u05d7 \u05d6\u05de\u05e0\u05d9\u05dd" "name": "Delay Start"
},
"dry_time": {
"name": "זמן ייבוש"
},
"suggested_load": {
"name": "יכולת עומס"
},
"energy_label": {
"name": "חסכון באנרגיה"
},
"det_dust": {
"name": "Powder detergent"
},
"det_liquid": {
"name": "Liquid detergent"
},
"errors": {
"name": "Error"
},
"programs": {
"name": "Current program"
},
"cycles_total": {
"name": "מחזורים Total"
},
"energy_total": {
"name": "Energy Consumption Total"
},
"water_total": {
"name": "Water efficiency Total"
},
"energy_current": {
"name": "Energy Consumption Current"
},
"water_current": {
"name": "Water efficiency Current"
},
"mach_modes_ac": {
"state": {
"0": "Auto",
"1": "Cool",
"2": "Cool",
"3": "Dry",
"4": "Heat",
"5": "Fan",
"6": "Fan"
}
},
"programs_td": {
"state": {
"genius": "Genius",
"hqd_bath_towel": "Bath towel",
"hqd_bulky": "Bulky",
"hqd_cold_wind_30": "Cold wind 30 minutes",
"hqd_cold_wind_timing": "Cold wind",
"hqd_hot_wind_timing": "Hot wind",
"hqd_luxury": "Luxury",
"hqd_night_dry": "Night dry",
"hqd_refresh": "Refresh",
"hqd_timer": "תוזמן",
"hqd_warm_up": "Warm up",
"hqd_working_suit": "Working suit",
"iot_dry_synthetic_dry": "סינתטי יבש"
}
},
"room_temperature": {
"name": "Room temperature"
},
"humidity": {
"name": "Humidity"
},
"freezer_temp": {
"name": "Freezer temperature"
},
"fridge_temp": {
"name": "Fridge temperature"
} }
}, },
"select": { "select": {
"programs_dw": { "programs_dw": {
"state": { "state": {
"gentle_wash": "Gentle wash", "gentle_wash": "Gentle wash",
"iot_checkup": "\u05d1\u05bc\u05b0\u05d3\u05b4\u05d9\u05e7\u05b8\u05d4", "iot_checkup": "בְּדִיקָה",
"iot_dreft_quick_cycle": "Dreft Quick", "iot_dreft_quick_cycle": "Dreft Quick",
"iot_fairy_quick_cycle": "Fairy Quick", "iot_fairy_quick_cycle": "Fairy Quick",
"iot_jar_quick_cycle": "Jar Quick", "iot_jar_quick_cycle": "Jar Quick",
"iot_yes_quick_cycle": "Yes Quick", "iot_yes_quick_cycle": "Yes Quick",
"smart_ai": "Smart AI" "smart_ai": "Smart AI",
"smart_ai_soil": "Smart AI"
}, },
"name": "Program" "name": "Program"
}, },
@ -158,229 +241,278 @@
"hqd_luxury": "Luxury", "hqd_luxury": "Luxury",
"hqd_night_dry": "Night dry", "hqd_night_dry": "Night dry",
"hqd_refresh": "Refresh", "hqd_refresh": "Refresh",
"hqd_timer": "\u05ea\u05d5\u05d6\u05de\u05df", "hqd_timer": "תוזמן",
"hqd_warm_up": "Warm up", "hqd_warm_up": "Warm up",
"hqd_working_suit": "Working suit", "hqd_working_suit": "Working suit",
"iot_dry_synthetic_dry": "\u05e1\u05d9\u05e0\u05ea\u05d8\u05d9 \u05d9\u05d1\u05e9" "iot_dry_synthetic_dry": "סינתטי יבש"
}, },
"name": "Program" "name": "Program"
}, },
"programs_wm": { "programs_wm": {
"state": { "state": {
"20_degrees_new_energy_label": "20 \u05de\u05e2\u05dc\u05d5\u05ea \u05e6\u05dc\u05d6\u05d9\u05d5\u05e1", "20_degrees_new_energy_label": "20 מעלות צלזיוס",
"active_steam": "\u05e7\u05b4\u05d9\u05d8\u05d5\u05b9\u05e8", "active_steam": "קִיטוֹר",
"active_wash": "\u05e9\u05d8\u05d9\u05e4\u05d4 \u05e4\u05e2\u05d9\u05dc\u05d4", "active_wash": "שטיפה פעילה",
"active_wash_steam": "\u05e9\u05d8\u05d9\u05e4\u05d4 \u05e4\u05e2\u05d9\u05dc\u05d4", "active_wash_steam": "שטיפה פעילה",
"allergy_care": "\u05d8\u05d9\u05e4\u05d5\u05dc \u05d1\u05d0\u05dc\u05e8\u05d2\u05d9\u05d4", "allergy_care": "טיפול באלרגיה",
"allergy_care_pro": "Allergy Care Pro", "allergy_care_pro": "Allergy Care Pro",
"all_in_one_49": "All in One 49 '", "all_in_one_49": "All in One 49 '",
"all_in_one_59": "All in One 59 '", "all_in_one_59": "All in One 59 '",
"all_in_one_59_steam": "\u05e9\u05d8\u05d9\u05e4\u05d4 \u05e4\u05e2\u05d9\u05dc\u05d4", "all_in_one_59_steam": "שטיפה פעילה",
"autocare": "\u05d8\u05d9\u05e4\u05d5\u05dc \u05d0\u05d5\u05d8\u05d5\u05de\u05d8\u05d9", "autocare": "טיפול אוטומטי",
"autoclean": "\u05e0\u05d9\u05e7\u05d5\u05d9 \u05d0\u05d5\u05d8\u05d5\u05de\u05d8\u05d9", "autoclean": "ניקוי אוטומטי",
"baby_60": "BABY_60", "baby_60": "BABY_60",
"care_14": "\u05d8\u05d9\u05e4\u05d5\u05dc \u05de\u05d4\u05d9\u05e8 14 '", "care_14": "טיפול מהיר 14 '",
"care_30": "\u05d8\u05d9\u05e4\u05d5\u05dc \u05de\u05d4\u05d9\u05e8 30 '", "care_30": "טיפול מהיר 30 '",
"care_44": "\u05d8\u05d9\u05e4\u05d5\u05dc \u05de\u05d4\u05d9\u05e8 44 '", "care_44": "טיפול מהיר 44 '",
"checkup": "\u05d1\u05bc\u05b0\u05d3\u05b4\u05d9\u05e7\u05b8\u05d4", "checkup": "בְּדִיקָה",
"cottons": "\u05db\u05d5\u05ea\u05e0\u05d4", "cottons": "כותנה",
"cottons_prewash": "\u05db\u05d5\u05ea\u05e0\u05d4 + \u05db\u05d1\u05d9\u05e1\u05d4 \u05de\u05d5\u05e7\u05d3\u05de\u05ea", "cottons_prewash": "כותנה + כביסה מוקדמת",
"cotton_care_59": "Cotton Care 59 Min", "cotton_care_59": "Cotton Care 59 Min",
"delicate_59": "\u05e2\u05d3\u05d9\u05df 59 '", "delicate_59": "עדין 59 '",
"delicati_59": "DELICATI_59", "delicati_59": "DELICATI_59",
"delicati_59_steam": "DELICATI_59", "delicati_59_steam": "DELICATI_59",
"drain_spin": "\u05e0\u05d9\u05e7\u05d5\u05d6 + \u05e1\u05d9\u05d1\u05d5\u05d1", "drain_spin": "ניקוז + סיבוב",
"easy_iron": "\u05d2\u05d9\u05d4\u05d5\u05e5 \u05e7\u05dc", "easy_iron": "גיהוץ קל",
"eco_40_60_new_energy_label": "\u05d0\u05e7\u05d5 40-60", "eco_40_60_new_energy_label": "אקו 40-60",
"extra_care": "\u05d0\u05db\u05e4\u05ea\u05d9\u05d5\u05ea \u05de\u05d5\u05d2\u05d1\u05e8\u05ea", "extra_care": "אכפתיות מוגברת",
"fitness": "\u05d8\u05d9\u05e4\u05d5\u05dc \u05d1\u05db\u05d5\u05e9\u05e8", "fitness": "טיפול בכושר",
"fitness_care": "\u05d8\u05d9\u05e4\u05d5\u05dc \u05d1\u05db\u05d5\u05e9\u05e8", "fitness_care": "טיפול בכושר",
"fresh_care": "\u05d8\u05d9\u05e4\u05d5\u05dc \u05d8\u05e8\u05d9", "fresh_care": "טיפול טרי",
"fresh_care_steam": "\u05d8\u05d9\u05e4\u05d5\u05dc \u05d8\u05e8\u05d9", "fresh_care_steam": "טיפול טרי",
"handwash_wool": "\u05e9\u05d8\u05d9\u05e4\u05ea \u05d9\u05d3\u05d9\u05d9\u05dd + \u05e6\u05de\u05e8", "handwash_wool": "שטיפת ידיים + צמר",
"high_dry": "\u05d9\u05d1\u05e9 \u05d1\u05d7\u05d5\u05dd \u05d2\u05d1\u05d5\u05d4", "high_dry": "יבש בחום גבוה",
"hqd_dry_synthetics": "\u05d9\u05d1\u05e9 \u05d1\u05d7\u05d5\u05dd \u05e0\u05de\u05d5\u05da", "hqd_dry_synthetics": "יבש בחום נמוך",
"hygiene_60": "\u05d4\u05d9\u05d2\u05d9\u05d9\u05e0\u05d4 60 \u05de\u05e2\u05dc\u05d5\u05ea \u05e6\u05dc\u05d6\u05d9\u05d5\u05e1", "hygiene_60": "היגיינה 60 מעלות צלזיוס",
"intensive_40": "40\u00b0C \u05d0\u05d9\u05e0\u05d8\u05e0\u05e1\u05d9\u05d1\u05d9\u05d9\u05dd", "intensive_40": "40°C אינטנסיביים",
"iot_active_steam": "\u05e7\u05b4\u05d9\u05d8\u05d5\u05b9\u05e8", "iot_active_steam": "קִיטוֹר",
"iot_active_wash_steam": "\u05e9\u05d8\u05d9\u05e4\u05d4 \u05e4\u05e2\u05d9\u05dc\u05d4", "iot_active_wash_steam": "שטיפה פעילה",
"iot_allergy_care_pro": "Allergy Care Pro", "iot_allergy_care_pro": "Allergy Care Pro",
"iot_all_in_one_59_steam": "\u05e9\u05d8\u05d9\u05e4\u05d4 \u05e4\u05e2\u05d9\u05dc\u05d4", "iot_all_in_one_59_steam": "שטיפה פעילה",
"iot_checkup": "\u05d1\u05bc\u05b0\u05d3\u05b4\u05d9\u05e7\u05b8\u05d4", "iot_checkup": "בְּדִיקָה",
"iot_delicati_59_steam": "DELICATI_59", "iot_delicati_59_steam": "DELICATI_59",
"iot_dry_air_refresh": "\u05e8\u05e2\u05e0\u05d5\u05df \u05d0\u05d5\u05d5\u05d9\u05e8", "iot_dry_air_refresh": "רענון אוויר",
"iot_dry_anti_mites": "\u05e0\u05d2\u05d3 \u05e7\u05e8\u05d3\u05d9\u05ea", "iot_dry_anti_mites": "נגד קרדית",
"iot_dry_baby": "\u05ea\u05b4\u05d9\u05e0\u05d5\u05b9\u05e7", "iot_dry_baby": "תִינוֹק",
"iot_dry_backpacks": "\u05ea\u05d9\u05e7\u05d9 \u05d2\u05d1", "iot_dry_backpacks": "תיקי גב",
"iot_dry_bathrobe": "\u05d7\u05dc\u05d5\u05e7\u05d9 \u05e8\u05d7\u05e6\u05d4", "iot_dry_bathrobe": "חלוקי רחצה",
"iot_dry_bed_linen": "\u05de\u05e6\u05e2\u05d9\u05dd", "iot_dry_bed_linen": "מצעים",
"iot_dry_cotton_dry": "\u05db\u05d5\u05ea\u05e0\u05d4 \u05d9\u05d1\u05e9\u05d4", "iot_dry_cotton_dry": "כותנה יבשה",
"iot_dry_cuddly_toys": "\u05e6\u05e2\u05e6\u05d5\u05e2\u05d9 \u05d7\u05d9\u05d1\u05d5\u05e7", "iot_dry_cuddly_toys": "צעצועי חיבוק",
"iot_dry_curtains": "\u05d5\u05d9\u05dc\u05d5\u05e0\u05d5\u05ea", "iot_dry_curtains": "וילונות",
"iot_dry_dehumidifier": "\u05de\u05e1\u05d9\u05e8 \u05dc\u05d7\u05d5\u05ea", "iot_dry_dehumidifier": "מסיר לחות",
"iot_dry_delicates_antiallergy": "\u05e2\u05d3\u05d9\u05df \u05e0\u05d2\u05d3 \u05d0\u05dc\u05e8\u05d2\u05d9\u05d4", "iot_dry_delicates_antiallergy": "עדין נגד אלרגיה",
"iot_dry_delicate_tablecloths": "\u05de\u05e4\u05d5\u05ea \u05e2\u05d3\u05d9\u05e0\u05d5\u05ea", "iot_dry_delicate_tablecloths": "מפות עדינות",
"iot_dry_denim_jeans": "\u05d2'\u05d9\u05e0\u05e1", "iot_dry_denim_jeans": "ג'ינס",
"iot_dry_easy_iron_cotton": "\u05d1\u05e8\u05d6\u05dc \u05e7\u05dc - \u05db\u05d5\u05ea\u05e0\u05d4", "iot_dry_easy_iron_cotton": "ברזל קל - כותנה",
"iot_dry_easy_iron_synthetics": "\u05e7\u05dc \u05d1\u05e8\u05d6\u05dc - \u05e1\u05d9\u05e0\u05ea\u05d8\u05d9\u05d9\u05dd", "iot_dry_easy_iron_synthetics": "קל ברזל - סינתטיים",
"iot_dry_gym_fit": "\u05db\u05d5\u05e9\u05e8 \u05db\u05d5\u05e9\u05e8 - \u05db\u05d5\u05e9\u05e8", "iot_dry_gym_fit": "כושר כושר - כושר",
"iot_dry_lingerie": "\u05dc\u05b4\u05d1\u05e0\u05b5\u05d9 \u05e0\u05b8\u05e9\u05c1\u05b4\u05d9\u05dd", "iot_dry_lingerie": "לִבנֵי נָשִׁים",
"iot_dry_mixed_dry": "\u05de\u05e2\u05d5\u05e8\u05d1\u05d1 \u05d9\u05d1\u05e9", "iot_dry_mixed_dry": "מעורבב יבש",
"iot_dry_rapid_60_min_delicates": "\u05de\u05d4\u05d9\u05e8 60 '- \u05e2\u05d3\u05d9\u05e0\u05d9\u05dd", "iot_dry_rapid_60_min_delicates": "מהיר 60 '- עדינים",
"iot_dry_shirts": "\u05d7\u05d5\u05dc\u05e6\u05d5\u05ea", "iot_dry_shirts": "חולצות",
"iot_dry_swimsuits_and_bikinis": "\u05d1\u05d2\u05d3\u05d9 \u05d9\u05dd \u05d5\u05d1\u05d9\u05e7\u05d9\u05e0\u05d9", "iot_dry_swimsuits_and_bikinis": "בגדי ים וביקיני",
"iot_dry_synthetics": "\u05e1\u05d9\u05e0\u05ea\u05d8\u05d9 \u05d9\u05d1\u05e9", "iot_dry_synthetics": "סינתטי יבש",
"iot_dry_synthetic_dry": "\u05e1\u05d9\u05e0\u05ea\u05d8\u05d9 \u05d9\u05d1\u05e9", "iot_dry_synthetic_dry": "סינתטי יבש",
"iot_dry_tablecloths": "\u05de\u05e4\u05d5\u05ea \u05e9\u05d5\u05dc\u05d7\u05df", "iot_dry_tablecloths": "מפות שולחן",
"iot_dry_technical_fabrics": "\u05d1\u05d3\u05d9\u05dd \u05d8\u05db\u05e0\u05d9\u05d9\u05dd", "iot_dry_technical_fabrics": "בדים טכניים",
"iot_dry_warm_embrace": "\u05d7\u05d9\u05d1\u05d5\u05e7 \u05d7\u05dd", "iot_dry_warm_embrace": "חיבוק חם",
"iot_dry_wool_dry": "\u05e6\u05de\u05e8 \u05d9\u05d1\u05e9", "iot_dry_wool_dry": "צמר יבש",
"iot_easy_iron": "\u05d2\u05d9\u05d4\u05d5\u05e5 \u05e7\u05dc", "iot_easy_iron": "גיהוץ קל",
"iot_fresh_care_steam": "\u05d8\u05d9\u05e4\u05d5\u05dc \u05d8\u05e8\u05d9", "iot_fresh_care_steam": "טיפול טרי",
"iot_synthetic_and_coloured_steam": "\u05e1\u05d9\u05e0\u05d8\u05d8\u05d9 \u05d5\u05e6\u05d1\u05e2\u05d5\u05e0\u05d9", "iot_synthetic_and_coloured_steam": "סינטטי וצבעוני",
"iot_wash_anti_mites": "\u05e0\u05d2\u05d3 \u05e7\u05e8\u05d3\u05d9\u05ea", "iot_wash_anti_mites": "נגד קרדית",
"iot_wash_anti_odor": "\u05e0\u05d2\u05d3 \u05e8\u05d9\u05d7", "iot_wash_anti_odor": "נגד ריח",
"iot_wash_ariel_clean_cycle": "Ariel Ultimate Clean", "iot_wash_ariel_clean_cycle": "Ariel Ultimate Clean",
"iot_wash_ariel_cold_cycle": "Ariel Cold Clean", "iot_wash_ariel_cold_cycle": "Ariel Cold Clean",
"iot_wash_ariel_fresh_cycle": "Ariel Fresh Clean", "iot_wash_ariel_fresh_cycle": "Ariel Fresh Clean",
"iot_wash_baby_sanitizer": "\u05d7\u05d9\u05d8\u05d5\u05d9 \u05dc\u05ea\u05d9\u05e0\u05d5\u05e7\u05d5\u05ea", "iot_wash_baby_sanitizer": "חיטוי לתינוקות",
"iot_wash_backpacks": "\u05ea\u05d9\u05e7\u05d9 \u05d2\u05d1", "iot_wash_backpacks": "תיקי גב",
"iot_wash_bathrobe": "\u05d7\u05dc\u05d5\u05e7\u05d9 \u05e8\u05d7\u05e6\u05d4 \u05d5\u05d1\u05d3\u05d9\u05dd \u05e0\u05e7\u05d1\u05d5\u05d1\u05d9\u05d9\u05dd", "iot_wash_bathrobe": "חלוקי רחצה ובדים נקבוביים",
"iot_wash_bed_linen": "\u05de\u05e6\u05e2\u05d9\u05dd", "iot_wash_bed_linen": "מצעים",
"iot_wash_bed_linen_zelig": "\u05de\u05e6\u05e2\u05d9\u05dd", "iot_wash_bed_linen_zelig": "מצעים",
"iot_wash_bleaching": "\u05d4\u05b7\u05dc\u05d1\u05bc\u05b8\u05e0\u05b8\u05d4", "iot_wash_bleaching": "הַלבָּנָה",
"iot_wash_blood_stains": "\u05db\u05ea\u05de\u05d9 \u05d3\u05dd", "iot_wash_blood_stains": "כתמי דם",
"iot_wash_cashmere": "\u05e7\u05e9\u05de\u05d9\u05e8", "iot_wash_cashmere": "קשמיר",
"iot_wash_chocolate_stains": "\u05db\u05ea\u05de\u05d9 \u05e9\u05d5\u05e7\u05d5\u05dc\u05d3", "iot_wash_chocolate_stains": "כתמי שוקולד",
"iot_wash_cold_wash": "\u05e9\u05d8\u05d9\u05e4\u05d4 \u05e7\u05e8\u05d4", "iot_wash_cold_wash": "שטיפה קרה",
"iot_wash_colored": "\u05e6\u05d1\u05e2\u05d5\u05e0\u05d9", "iot_wash_colored": "צבעוני",
"iot_wash_colored_anti_stain": "\u05e0\u05d2\u05d3 \u05db\u05ea\u05dd \u05e6\u05d1\u05e2\u05d5\u05e0\u05d9", "iot_wash_colored_anti_stain": "נגד כתם צבעוני",
"iot_wash_colored_delicate": "\u05e6\u05d1\u05e2\u05d5\u05e0\u05d9 \u05e2\u05d3\u05d9\u05df", "iot_wash_colored_delicate": "צבעוני עדין",
"iot_wash_coloured": "\u05e6\u05d1\u05e2\u05d5\u05e0\u05d9", "iot_wash_coloured": "צבעוני",
"iot_wash_cotton": "\u05db\u05d5\u05ea\u05e0\u05d4", "iot_wash_cotton": "כותנה",
"iot_wash_cuddly_toys": "\u05e6\u05e2\u05e6\u05d5\u05e2\u05d9 \u05d7\u05d9\u05d1\u05d5\u05e7", "iot_wash_cuddly_toys": "צעצועי חיבוק",
"iot_wash_curtains": "\u05d5\u05d9\u05dc\u05d5\u05e0\u05d5\u05ea", "iot_wash_curtains": "וילונות",
"iot_wash_curtains_zelig": "\u05d5\u05d9\u05dc\u05d5\u05e0\u05d5\u05ea", "iot_wash_curtains_zelig": "וילונות",
"iot_wash_dark": "\u05d0\u05e4\u05dc", "iot_wash_dark": "אפל",
"iot_wash_darks_and_coloured_44": "\u05d7\u05d1\u05d9\u05d1\u05d9\u05dd \u05d5\u05e6\u05d1\u05e2\u05d5\u05e0\u05d9\u05d9\u05dd 44 '", "iot_wash_darks_and_coloured_44": "חביבים וצבעוניים 44 '",
"iot_wash_darks_and_coloured_59": "\u05d7\u05d1\u05d9\u05d1\u05d9\u05dd \u05d5\u05e6\u05d1\u05e2\u05d5\u05e0\u05d9 59 '", "iot_wash_darks_and_coloured_59": "חביבים וצבעוני 59 '",
"iot_wash_darks_and_coloured_xl": "\u05d7\u05e4\u05e6\u05d9\u05dd \u05d5\u05e6\u05d1\u05e2 XL", "iot_wash_darks_and_coloured_xl": "חפצים וצבע XL",
"iot_wash_dash_clean_cycle": "Dash Ultimate Clean", "iot_wash_dash_clean_cycle": "Dash Ultimate Clean",
"iot_wash_dash_cold_cycle": "Dash Cold Clean", "iot_wash_dash_cold_cycle": "Dash Cold Clean",
"iot_wash_dash_fresh_cycle": "Dash Fresh Clean", "iot_wash_dash_fresh_cycle": "Dash Fresh Clean",
"iot_wash_delicate": "\u05e2\u05d3\u05d9\u05e0\u05d9\u05dd", "iot_wash_delicate": "עדינים",
"iot_wash_delicate_antiallergy": "\u05d0\u05e0\u05d8\u05d9 \u05d0\u05dc\u05e8\u05d2\u05d9\u05d4 \u05e2\u05d3\u05d9\u05df", "iot_wash_delicate_antiallergy": "אנטי אלרגיה עדין",
"iot_wash_delicate_antiallergy_zelig": "\u05d0\u05e0\u05d8\u05d9 \u05d0\u05dc\u05e8\u05d2\u05d9\u05d4 \u05e2\u05d3\u05d9\u05df", "iot_wash_delicate_antiallergy_zelig": "אנטי אלרגיה עדין",
"iot_wash_delicate_colors": "\u05e6\u05d1\u05e2\u05d5\u05e0\u05d9 \u05e2\u05d3\u05d9\u05df", "iot_wash_delicate_colors": "צבעוני עדין",
"iot_wash_delicate_dark": "\u05db\u05d4\u05d4 \u05e2\u05d3\u05d9\u05df", "iot_wash_delicate_dark": "כהה עדין",
"iot_wash_delicate_tablecloths": "\u05de\u05e4\u05d5\u05ea \u05e2\u05d3\u05d9\u05e0\u05d5\u05ea", "iot_wash_delicate_tablecloths": "מפות עדינות",
"iot_wash_delicate_whites": "\u05dc\u05d1\u05e0\u05d9\u05dd \u05e2\u05d3\u05d9\u05e0\u05d9\u05dd", "iot_wash_delicate_whites": "לבנים עדינים",
"iot_wash_denim_jeans": "\u05d2'\u05d9\u05e0\u05e1", "iot_wash_denim_jeans": "ג'ינס",
"iot_wash_diving_suits": "\u05d7\u05dc\u05d9\u05e4\u05d5\u05ea \u05e6\u05dc\u05d9\u05dc\u05d4", "iot_wash_diving_suits": "חליפות צלילה",
"iot_wash_diving_suits_zelig": "\u05d7\u05dc\u05d9\u05e4\u05d5\u05ea \u05e6\u05dc\u05d9\u05dc\u05d4", "iot_wash_diving_suits_zelig": "חליפות צלילה",
"iot_wash_down_jackets": "\u05de\u05e2\u05d9\u05dc\u05d9 \u05e4\u05d5\u05da", "iot_wash_down_jackets": "מעילי פוך",
"iot_wash_down_jackets_zelig": "\u05de\u05e2\u05d9\u05dc\u05d9 \u05e4\u05d5\u05da", "iot_wash_down_jackets_zelig": "מעילי פוך",
"iot_wash_fruit_stains": "\u05db\u05ea\u05de\u05d9 \u05e4\u05e8\u05d9", "iot_wash_fruit_stains": "כתמי פרי",
"iot_wash_gym_fit": "\u05db\u05d5\u05e9\u05e8 \u05db\u05d5\u05e9\u05e8 - \u05db\u05d5\u05e9\u05e8", "iot_wash_gym_fit": "כושר כושר - כושר",
"iot_wash_handwash": "\u05e9\u05d8\u05d9\u05e4\u05ea \u05d9\u05d3\u05d9\u05d9\u05dd", "iot_wash_handwash": "שטיפת ידיים",
"iot_wash_handwash_colored": "\u05e9\u05d8\u05d9\u05e4\u05ea \u05d9\u05d3\u05d9\u05d9\u05dd \u05d1\u05e6\u05d1\u05e2", "iot_wash_handwash_colored": "שטיפת ידיים בצבע",
"iot_wash_handwash_dark": "\u05e9\u05d8\u05d9\u05e4\u05ea \u05d9\u05d3\u05d9\u05d9\u05dd \u05db\u05d4\u05d4", "iot_wash_handwash_dark": "שטיפת ידיים כהה",
"iot_wash_lingerie": "\u05dc\u05b4\u05d1\u05e0\u05b5\u05d9 \u05e0\u05b8\u05e9\u05c1\u05b4\u05d9\u05dd", "iot_wash_lingerie": "לִבנֵי נָשִׁים",
"iot_wash_masks_refresh": "\u05de\u05e1\u05db\u05d5\u05ea \u05e8\u05e2\u05e0\u05df", "iot_wash_masks_refresh": "מסכות רענן",
"iot_wash_masks_sanification": "\u05d7\u05d9\u05d8\u05d5\u05d9 \u05de\u05e1\u05db\u05d5\u05ea", "iot_wash_masks_sanification": "חיטוי מסכות",
"iot_wash_mats": "\u05de\u05d7\u05e6\u05dc\u05d5\u05ea", "iot_wash_mats": "מחצלות",
"iot_wash_men_s_trousers": "\u05de\u05db\u05e0\u05e1\u05d9 \u05d2\u05d1\u05e8\u05d9\u05dd", "iot_wash_men_s_trousers": "מכנסי גברים",
"iot_wash_mixed": "\u05de\u05e2\u05d5\u05e8\u05d1", "iot_wash_mixed": "מעורב",
"iot_wash_mix_and_coloured_44": "\u05dc\u05e2\u05e8\u05d1\u05d1 \u05d5\u05e6\u05d1\u05e2\u05d5\u05e0\u05d9 44 '", "iot_wash_mix_and_coloured_44": "לערבב וצבעוני 44 '",
"iot_wash_mix_and_coloured_59": "\u05de\u05d9\u05e7\u05e1 \u05d5\u05e6\u05d1\u05e2\u05d5\u05e0\u05d9 59 '", "iot_wash_mix_and_coloured_59": "מיקס וצבעוני 59 '",
"iot_wash_mix_and_coloured_xl": "\u05de\u05e2\u05e8\u05d1\u05d1\u05d9\u05dd \u05d5\u05e6\u05d1\u05e2\u05d9\u05dd XL", "iot_wash_mix_and_coloured_xl": "מערבבים וצבעים XL",
"iot_wash_new_clothes": "\u05d1\u05d2\u05d3\u05d9\u05dd \u05d7\u05d3\u05e9\u05d9\u05dd", "iot_wash_new_clothes": "בגדים חדשים",
"iot_wash_perfect_white": "\u05dc\u05d1\u05df \u05de\u05d5\u05e9\u05dc\u05dd", "iot_wash_perfect_white": "לבן מושלם",
"iot_wash_pets": "\u05d7\u05d9\u05d5\u05ea \u05de\u05d7\u05de\u05d3", "iot_wash_pets": "חיות מחמד",
"iot_wash_pets_steam": "\u05d7\u05d9\u05d5\u05ea \u05de\u05d7\u05de\u05d3", "iot_wash_pets_steam": "חיות מחמד",
"iot_wash_playsuits": "\u05d7\u05dc\u05d9\u05e4\u05d5\u05ea \u05de\u05e9\u05d7\u05e7", "iot_wash_playsuits": "חליפות משחק",
"iot_wash_rapid_14": "\u05de\u05d4\u05d9\u05e8 14 '", "iot_wash_rapid_14": "מהיר 14 '",
"iot_wash_rapid_30": "\u05de\u05d4\u05d9\u05e8 30 '", "iot_wash_rapid_30": "מהיר 30 '",
"iot_wash_rapid_44": "\u05de\u05d4\u05d9\u05e8 44 '", "iot_wash_rapid_44": "מהיר 44 '",
"iot_wash_rapid_59": "\u05de\u05d4\u05d9\u05e8 59 '", "iot_wash_rapid_59": "מהיר 59 '",
"iot_wash_refresh_14_min": "\u05e8\u05e2\u05e0\u05df 14 \u05d3\u05e7\u05d5\u05ea", "iot_wash_refresh_14_min": "רענן 14 דקות",
"iot_wash_resistant_colored": "\u05e6\u05d1\u05e2\u05d5\u05e0\u05d9 \u05e2\u05de\u05d9\u05d3", "iot_wash_resistant_colored": "צבעוני עמיד",
"iot_wash_resistant_dark": "\u05db\u05d4\u05d4 \u05e2\u05de\u05d9\u05d3", "iot_wash_resistant_dark": "כהה עמיד",
"iot_wash_resistant_whites": "\u05dc\u05d1\u05e0\u05d9\u05dd \u05e2\u05de\u05d9\u05d3\u05d9\u05dd", "iot_wash_resistant_whites": "לבנים עמידים",
"iot_wash_rinse": "\u05dc\u05b4\u05e9\u05c1\u05b0\u05d8\u05d5\u05b9\u05e3", "iot_wash_rinse": "לִשְׁטוֹף",
"iot_wash_shirts": "\u05d7\u05d5\u05dc\u05e6\u05d5\u05ea", "iot_wash_shirts": "חולצות",
"iot_wash_silk": "\u05de\u05e9\u05d9", "iot_wash_silk": "משי",
"iot_wash_ski_suit": "\u05d7\u05dc\u05d9\u05e4\u05ea \u05e1\u05e7\u05d9", "iot_wash_ski_suit": "חליפת סקי",
"iot_wash_ski_suit_zelig": "\u05d7\u05dc\u05d9\u05e4\u05ea \u05e1\u05e7\u05d9", "iot_wash_ski_suit_zelig": "חליפת סקי",
"iot_wash_spin": "\u05e1\u05d9\u05d1\u05d5\u05d1", "iot_wash_spin": "סיבוב",
"iot_wash_sport": "\u05e1\u05e4\u05bc\u05d5\u05b9\u05e8\u05d8", "iot_wash_sport": "ספּוֹרט",
"iot_wash_stains_remover": "\u05de\u05e1\u05d9\u05e8 \u05db\u05ea\u05de\u05d9\u05dd", "iot_wash_stains_remover": "מסיר כתמים",
"iot_wash_swimsuits_and_bikinis": "\u05d1\u05d2\u05d3\u05d9 \u05d9\u05dd \u05d5\u05d1\u05d9\u05e7\u05d9\u05e0\u05d9", "iot_wash_swimsuits_and_bikinis": "בגדי ים וביקיני",
"iot_wash_synthetic": "\u05e1\u05d9\u05e0\u05ea\u05d8\u05d9\u05d9\u05dd", "iot_wash_synthetic": "סינתטיים",
"iot_wash_tablecloths": "\u05de\u05e4\u05d5\u05ea \u05e9\u05d5\u05dc\u05d7\u05df", "iot_wash_tablecloths": "מפות שולחן",
"iot_wash_technical_fabrics": "\u05d1\u05d3\u05d9\u05dd \u05d8\u05db\u05e0\u05d9\u05d9\u05dd", "iot_wash_technical_fabrics": "בדים טכניים",
"iot_wash_technical_fabrics_zelig": "\u05d1\u05d3\u05d9\u05dd \u05d8\u05db\u05e0\u05d9\u05d9\u05dd", "iot_wash_technical_fabrics_zelig": "בדים טכניים",
"iot_wash_technical_jackets": "\u05d6'\u05e7\u05d8\u05d9\u05dd \u05d8\u05db\u05e0\u05d9\u05d9\u05dd", "iot_wash_technical_jackets": "ז'קטים טכניים",
"iot_wash_technical_jackets_zelig": "\u05d6'\u05e7\u05d8\u05d9\u05dd \u05d8\u05db\u05e0\u05d9\u05d9\u05dd", "iot_wash_technical_jackets_zelig": "ז'קטים טכניים",
"iot_wash_trainers": "\u05de\u05d0\u05de\u05e0\u05d9\u05dd", "iot_wash_trainers": "מאמנים",
"iot_wash_whites": "\u05dc\u05b0\u05d1\u05b8\u05e0\u05b4\u05d9\u05dd", "iot_wash_whites": "לְבָנִים",
"iot_wash_whites_44": "\u05dc\u05d1\u05e0\u05d9\u05dd 44 '", "iot_wash_whites_44": "לבנים 44 '",
"iot_wash_whites_59": "\u05dc\u05d1\u05e0\u05d9\u05dd 59 '", "iot_wash_whites_59": "לבנים 59 '",
"iot_wash_whites_xl": "\u05dc\u05d1\u05e0\u05d9\u05dd XL", "iot_wash_whites_xl": "לבנים XL",
"iot_wash_wine_stains": "\u05db\u05ea\u05de\u05d9 \u05d9\u05d9\u05df", "iot_wash_wine_stains": "כתמי יין",
"iot_wash_wool": "\u05e6\u05b6\u05de\u05b6\u05e8", "iot_wash_wool": "צֶמֶר",
"jeans": "\u05d2\u05b4'\u05d9\u05e0\u05e1", "jeans": "גִ'ינס",
"low_dry": "\u05d9\u05d1\u05e9 \u05d1\u05d7\u05d5\u05dd \u05e0\u05de\u05d5\u05da", "low_dry": "יבש בחום נמוך",
"mixed_and_colored_59": "\u05de\u05e2\u05d5\u05e8\u05d1 \u05d5\u05e6\u05d1\u05e2\u05d5\u05e0\u05d9 59 '", "mixed_and_colored_59": "מעורב וצבעוני 59 '",
"night_and_day": "\u05dc\u05d9\u05dc\u05d4 \u05d5\u05d9\u05d5\u05dd", "night_and_day": "לילה ויום",
"night_wash": "Night Wash", "night_wash": "Night Wash",
"perfect_59": "\u05de\u05d5\u05e9\u05dc\u05dd 59 '", "perfect_59": "מושלם 59 '",
"perfect_whites_59": "\u05dc\u05d1\u05df \u05de\u05d5\u05e9\u05dc\u05dd", "perfect_whites_59": "לבן מושלם",
"rapid_wash_and_dry_59_min": "\u05dc\u05e9\u05d8\u05d5\u05e3 \u05d5\u05dc\u05d9\u05d9\u05d1\u05e9 59 '", "rapid_wash_and_dry_59_min": "לשטוף ולייבש 59 '",
"resistant_cotton": "\u05db\u05d5\u05ea\u05e0\u05d4", "resistant_cotton": "כותנה",
"rinse": "\u05dc\u05b4\u05e9\u05c1\u05b0\u05d8\u05d5\u05b9\u05e3", "rinse": "לִשְׁטוֹף",
"silent_night": "Night Wash", "silent_night": "Night Wash",
"soft_care": "\u05d8\u05d9\u05e4\u05d5\u05dc \u05e8\u05da", "soft_care": "טיפול רך",
"special_49": "\u05de\u05d9\u05d5\u05d7\u05d3 49 '", "special_49": "מיוחד 49 '",
"sport_39": "\u05e1\u05e4\u05d5\u05e8\u05d8 39 '", "sport_39": "ספורט 39 '",
"sport_plus_29": "\u05e1\u05e4\u05d5\u05e8\u05d8 \u05e4\u05dc\u05d5\u05e1 29 \"", "sport_plus_29": "ספורט פלוס 29 \"",
"steam_39": "\u05e7\u05d9\u05d8\u05d5\u05e8 39 '", "steam_39": "קיטור 39 '",
"steam_care_pro": "Steam Care Pro", "steam_care_pro": "Steam Care Pro",
"steam_care_pro_cotton": "Steam Care Pro", "steam_care_pro_cotton": "Steam Care Pro",
"steam_care_pro_delicates": "Steam Care Pro", "steam_care_pro_delicates": "Steam Care Pro",
"steam_care_pro_synthetic": "Steam Care Pro", "steam_care_pro_synthetic": "Steam Care Pro",
"synthetics": "\u05e1\u05d9\u05e0\u05ea\u05d8\u05d9\u05d9\u05dd", "synthetics": "סינתטיים",
"synthetic_and_coloured": "\u05e1\u05d9\u05e0\u05d8\u05d8\u05d9 \u05d5\u05e6\u05d1\u05e2\u05d5\u05e0\u05d9", "synthetic_and_coloured": "סינטטי וצבעוני",
"synthetic_and_coloured_steam": "\u05e1\u05d9\u05e0\u05d8\u05d8\u05d9 \u05d5\u05e6\u05d1\u05e2\u05d5\u05e0\u05d9", "synthetic_and_coloured_steam": "סינטטי וצבעוני",
"tailored_resistant_cotton": "Tailored Resistant Cotton", "tailored_resistant_cotton": "Tailored Resistant Cotton",
"tailored_synthetic_and_coloured": "Tailored Synthetic Colored", "tailored_synthetic_and_coloured": "Tailored Synthetic Colored",
"total_care": "\u05d8\u05d9\u05e4\u05d5\u05dc \u05d8\u05d5\u05d8\u05d0\u05dc\u05d9", "total_care": "טיפול טוטאלי",
"tumbling": "\u05e0\u05d5\u05e4\u05dc\u05d9\u05dd", "tumbling": "נופלים",
"wool_and_delicates_49": "Wool/Delicates 49'", "wool_and_delicates_49": "Wool/Delicates 49'",
"wool_dry": "\u05e6\u05de\u05e8 \u05d9\u05d1\u05e9", "wool_dry": "צמר יבש",
"wool_soft_care": "Wool & Soft Care" "wool_soft_care": "Wool & Soft Care"
}, },
"name": "Program" "name": "Program"
}, },
"dry_levels": { "dry_levels": {
"state": { "state": {
"0": "\u05dc\u05dc\u05d0 \u05d9\u05d9\u05d1\u05d5\u05e9", "0": "ללא ייבוש",
"1": "\u05d1\u05bc\u05b7\u05e8\u05d6\u05b6\u05dc", "1": "בַּרזֶל",
"2": "\u05dc\u05d0 \u05dc\u05d9\u05d9\u05d1\u05e9 \u05d1\u05e8\u05d6\u05dc", "2": "לא לייבש ברזל",
"3": "\u05d0\u05e8\u05d5\u05df \u05d9\u05d1\u05e9", "3": "ארון יבש",
"4": "\u05d9\u05d1\u05e9 \u05d1\u05de\u05d9\u05d5\u05d7\u05d3", "4": "יבש במיוחד",
"12": "\u05d1\u05bc\u05b7\u05e8\u05d6\u05b6\u05dc", "12": "בַּרזֶל",
"13": "\u05d0\u05e8\u05d5\u05df \u05d9\u05d1\u05e9", "13": "ארון יבש",
"14": "Ready to wear", "14": "Ready to wear",
"15": "\u05d9\u05d1\u05e9 \u05d1\u05de\u05d9\u05d5\u05d7\u05d3" "15": "יבש במיוחד",
"11": "ללא ייבוש"
}, },
"name": "\u05d9\u05b4\u05d1\u05bc\u05d5\u05bc\u05e9\u05c1" "name": "רמת ייבוש"
}, },
"spin_speed": { "spin_speed": {
"name": "\u05e1\u05d9\u05d1\u05d5\u05d1" "name": "סיבוב"
}, },
"temperature": { "temperature": {
"name": "Temperature" "name": "Temperature"
},
"dry_time": {
"name": "זמן ייבוש"
},
"eco_pilot": {
"state": {
"0": "Off",
"1": "Avoid touch",
"2": "Follow"
},
"name": "Eco pilot"
},
"fan_mode": {
"state": {
"1": "High",
"2": "Medium ",
"3": "Low",
"4": "Auto",
"5": "Auto"
}
},
"programs_ac": {
"state": {
"iot_simple_start": "התחל עכשיו"
}
},
"programs_ref": {
"state": {
"chiller": "Quick cool",
"cold_drinks": "Soft chill",
"fruit_and_veg": "Fruit & Veg",
"keep_fresh": "0° Fresh",
"sea_food": "Ready to cook meal",
"soft_frozen": "Soft freezing",
"tea": "Cold drinks or Beverages"
}
},
"remaining_time": {
"name": "זמן שנותר"
},
"ref_zones": {
"state": {
"fridge": "Fridge",
"freezer": "Freezer",
"vtroom1": "My Zone",
"fridge_freezer": "Fridge & Freezer"
},
"name": "Zone"
} }
}, },
"switch": { "switch": {
@ -388,7 +520,7 @@
"name": "Anticrease" "name": "Anticrease"
}, },
"add_dish": { "add_dish": {
"name": "" "name": "Add dishes"
}, },
"eco_express": { "eco_express": {
"name": "Eco" "name": "Eco"
@ -424,27 +556,90 @@
"name": "Oven" "name": "Oven"
}, },
"prewash": { "prewash": {
"name": "\u05e9\u05d8\u05d9\u05e4\u05d4 \u05de\u05e8\u05d0\u05e9" "name": "שטיפה מראש"
}, },
"pause": { "pause": {
"name": "Pause" "name": "Pause"
},
"keep_fresh": {
"name": "Keep Fresh"
},
"delay_time": {
"name": "Delay Start"
},
"rapid_mode": {
"name": "Rapid mode"
},
"eco_mode": {
"name": "ECO mode"
},
"10_degree_heating": {
"name": "10°C Heating function"
},
"self_clean": {
"name": "Self-clean"
},
"self_clean_56": {
"name": "Steri-Clean 56°C"
},
"silent_mode": {
"name": "Silent mode"
},
"mute_mode": {
"name": "Mute mode"
},
"extra_rinse_1": {
"name": "+1 שטיפה"
},
"extra_rinse_2": {
"name": "+2 שטיפות"
},
"extra_rinse_3": {
"name": "+3 שטיפות"
},
"acqua_plus": {
"name": "Acquaplus"
},
"auto_dose": {
"name": "מינון אוטומטי"
},
"good_night": {
"name": "לילה טוב"
},
"auto_dose_softener": {
"name": "מינון אוטומטי מרכך"
},
"auto_dose_detergent": {
"name": "מינון אוטומטי חומר ניקוי"
},
"auto_set": {
"name": "Auto-Set"
},
"super_cool": {
"name": "Super Cool"
},
"super_freeze": {
"name": "Super Freeze"
},
"refrigerator": {
"name": "Refrigerator"
} }
}, },
"binary_sensor": { "binary_sensor": {
"door_lock": { "door_lock": {
"name": "\u05de\u05e0\u05e2\u05d5\u05dc \u05d3\u05dc\u05ea" "name": "מנעול דלת"
}, },
"extra_rinse_1": { "extra_rinse_1": {
"name": "+1 \u05e9\u05d8\u05d9\u05e4\u05d4" "name": "+1 שטיפה"
}, },
"extra_rinse_2": { "extra_rinse_2": {
"name": "+2 \u05e9\u05d8\u05d9\u05e4\u05d5\u05ea" "name": "+2 שטיפות"
}, },
"extra_rinse_3": { "extra_rinse_3": {
"name": "+3 \u05e9\u05d8\u05d9\u05e4\u05d5\u05ea" "name": "+3 שטיפות"
}, },
"good_night": { "good_night": {
"name": "\u05dc\u05d9\u05dc\u05d4 \u05d8\u05d5\u05d1" "name": "לילה טוב"
}, },
"anti_crease": { "anti_crease": {
"name": "Anticrease" "name": "Anticrease"
@ -453,7 +648,7 @@
"name": "Acquaplus" "name": "Acquaplus"
}, },
"spin_speed": { "spin_speed": {
"name": "\u05e1\u05d9\u05d1\u05d5\u05d1" "name": "סיבוב"
}, },
"programs_dw": { "programs_dw": {
"name": "Program" "name": "Program"
@ -489,7 +684,46 @@
"name": "Door open" "name": "Door open"
}, },
"connection": { "connection": {
"name": "\u05d7\u05d9\u05d1\u05d5\u05e8" "name": "Appliance connection"
},
"child_lock": {
"name": "Child Lock"
},
"on": {
"name": "עַל"
},
"prewash": {
"name": "שטיפה מראש"
},
"acqua_plus": {
"name": "Acquaplus"
},
"auto_dose": {
"name": "מינון אוטומטי"
},
"buzzer": {
"name": "Cycle end chime"
},
"holiday_mode": {
"name": "Holiday Mode"
},
"auto_set": {
"name": "Auto-Set"
},
"super_cool": {
"name": "Super Cool"
},
"super_freeze": {
"name": "Super Freeze"
},
"freezer_door": {
"name": "Door open Freezer"
},
"fridge_door": {
"name": "Door open Fridge"
},
"filter_replacement": {
"name": "Filter replacement"
} }
}, },
"number": { "number": {
@ -500,10 +734,10 @@
"name": "Temperature" "name": "Temperature"
}, },
"delay_time": { "delay_time": {
"name": "\u05dc\u05d5\u05d7 \u05d6\u05de\u05e0\u05d9\u05dd" "name": "Delay Start"
}, },
"water_hard": { "water_hard": {
"name": "\u05e7\u05e9\u05d9\u05d5\u05ea \u05de\u05d9\u05dd" "name": "קשיות מים"
}, },
"program_duration": { "program_duration": {
"name": "Program duration" "name": "Program duration"
@ -516,11 +750,85 @@
}, },
"wash_time": { "wash_time": {
"name": "Washing intensity" "name": "Washing intensity"
},
"dry_time": {
"name": "זמן ייבוש"
},
"steam_level": {
"name": "מפלס קיטור"
},
"freezer_temp_sel": {
"name": "Target temperature Freezer"
},
"fridge_temp_sel": {
"name": "Target temperature Fridge"
} }
}, },
"button": { "button": {
"induction_hob": { "induction_hob": {
"name": "Induction Hob" "name": "Induction Hob"
},
"start_program": {
"name": "Program Start"
},
"stop_program": {
"name": "Program Stop"
}
},
"climate": {
"air_conditioner": {
"name": "Air conditioner"
},
"fridge": {
"name": "Fridge",
"state_attributes": {
"preset_mode": {
"name": "Fridge modes",
"state": {
"auto_set": "Auto-Set",
"super_cool": "Super Cool",
"holiday": "Holiday",
"no_mode": "No mode selected"
}
}
}
},
"freezer": {
"name": "Freezer",
"state_attributes": {
"preset_mode": {
"name": "Freezer modes",
"state": {
"auto_set": "Auto-Set",
"super_freeze": "Super Freeze",
"no_mode": "No mode selected"
}
}
}
},
"oven": {
"name": "Oven",
"state_attributes": {
"preset_mode": {
"name": "Programs",
"state": {
"iot_h20_clean": "h2O clean",
"pizza": "Pizza",
"tailor_bake": "Tailor bake"
}
}
}
}
}
},
"config": {
"step": {
"user": {
"description": "Do the login",
"data": {
"email": "Email",
"password": "Password"
}
} }
} }
} }

File diff suppressed because it is too large Load Diff

View File

@ -2,9 +2,9 @@
"config": { "config": {
"step": { "step": {
"user": { "user": {
"description": "Inserisci le credenziali dell'app hOn", "description": "Fai il login",
"data": { "data": {
"email": "Indirizzo Email", "email": "Email",
"password": "Password" "password": "Password"
} }
} }
@ -26,11 +26,12 @@
"errors": { "errors": {
"state": { "state": {
"00": "Nessun Errore", "00": "Nessun Errore",
"100000000000": "E2: Controllare se la porta \u00e8 chiusa correttamente", "100000000000": "E2: Controllare se la porta è chiusa correttamente",
"8000000000000": "E4: Controllare l'approvvigionamento idrico" "8000000000000": "E4: Controllare l'approvvigionamento idrico"
} },
"name": "Errore"
}, },
"tumbledryerprogram": { "programs": {
"state": { "state": {
"0": "Default", "0": "Default",
"62": "Cotone", "62": "Cotone",
@ -47,7 +48,8 @@
"85": "Asciugatura Rapida", "85": "Asciugatura Rapida",
"92": "Delicati", "92": "Delicati",
"103": "Controllo Remoto" "103": "Controllo Remoto"
} },
"name": "Programma attuale"
}, },
"tumbledryertemplevel": { "tumbledryertemplevel": {
"state": { "state": {
@ -65,7 +67,10 @@
"4": "Pianificato", "4": "Pianificato",
"5": "Pianificato", "5": "Pianificato",
"6": "Errore", "6": "Errore",
"7": "Pronta" "7": "Pronta",
"2": "Programma in esecuzione",
"8": "Test",
"9": "Arresto il ciclo..."
} }
}, },
"program_phases_wm": { "program_phases_wm": {
@ -109,7 +114,9 @@
"16": "Raffreddamento", "16": "Raffreddamento",
"18": "Keep Fresh", "18": "Keep Fresh",
"19": "Asciugatura", "19": "Asciugatura",
"20": "Asciugatura" "20": "Asciugatura",
"11": "Pronta",
"17": "unknown"
}, },
"name": "Fase" "name": "Fase"
}, },
@ -135,9 +142,10 @@
"12": "Stiro facile", "12": "Stiro facile",
"13": "Armadio", "13": "Armadio",
"14": "Pronto da indossare", "14": "Pronto da indossare",
"15": "Extra asciutto" "15": "Extra asciutto",
"11": "Nessuna asciugatura"
}, },
"name": "Tipo Asciugatura" "name": "Livello Asciugatura"
}, },
"anti_crease": { "anti_crease": {
"name": "Antipieghe " "name": "Antipieghe "
@ -173,7 +181,196 @@
"name": "Livello di sporco" "name": "Livello di sporco"
}, },
"delay_time": { "delay_time": {
"name": "Ritarda avvio" "name": "Utilizzo nelle ore notturne"
},
"dry_time": {
"name": "Tempo asciugatura"
},
"suggested_load": {
"name": "Capacità di carico"
},
"energy_label": {
"name": "Efficienza energetica"
},
"det_dust": {
"name": "Detersivo in polvere"
},
"det_liquid": {
"name": "Detersivo liquido"
},
"cycles_total": {
"name": "Cicli Totale"
},
"energy_total": {
"name": "Consumo energetico Totale"
},
"water_total": {
"name": "Efficienza idrica Totale"
},
"energy_current": {
"name": "Consumo energetico Odierna"
},
"water_current": {
"name": "Efficienza idrica Odierna"
},
"mach_modes_ac": {
"state": {
"0": "Auto",
"1": "Freddo",
"2": "Freddo",
"3": "Deumidificazione",
"4": "Caldo",
"5": "Ventilatore",
"6": "Ventilatore"
}
},
"programs_td": {
"state": {
"active_dry": "Active Dry",
"allergy_care": "Anti-allergie",
"all_in_one": "Tutto in Uno",
"antiallergy": "Anti-allergie",
"anti_odours": "Anti-odori",
"auto_care": "Auto Care",
"baby": "Baby",
"bed_quilt": "Trapunte-Piumoni",
"care_30": "Care 30",
"care_45": "Care 45",
"care_59": "Care 59",
"coloured": "Colorati",
"daily_45_min": "Quotidiano 45'",
"daily_perfect_59_min": "Daily Perfect 59'",
"darks_and_coloured": "Scuri e Colorati",
"delicates": "Delicati",
"duvet": "Piumone",
"eco": "Eco Cotton",
"ecospeed_cottons": "Ecospeed Cotone",
"ecospeed_delicates": "Ecospeed Delicati",
"ecospeed_mixed": "Ecospeed Misti",
"extra_hygiene": "Igiene Extra",
"fitness": "Fitness",
"fresh_care": "Fresh Care",
"genius": "Genius",
"hqd_baby_care": "Baby Care",
"hqd_bath_towel": "Asciugamani",
"hqd_bed_sheets": "Lenzuola",
"hqd_bulky": "Vestiti voluminosi",
"hqd_casual": "Casual",
"hqd_cold_wind_30": "Brezza rinfrescante 30m",
"hqd_cold_wind_timing": "Brezza rinfrescante",
"hqd_cotton": "Cotone",
"hqd_curtain": "Tende",
"hqd_delicate": "Delicati",
"hqd_diaper": "Pannolini",
"hqd_duvet": "Piumone",
"hqd_feather": "Piumini",
"hqd_hot_wind_timing": "Aria calda",
"hqd_hygienic": "Igienizzante",
"hqd_i_refresh": "I-Refresh",
"hqd_i_refresh_pro": "I-Refresh Pro",
"hqd_jacket": "Giacche",
"hqd_jeans": "Jeans",
"hqd_luxury": "Capi Pregiati",
"hqd_mix": "Misti",
"hqd_night_dry": "Asciugatura notturna",
"hqd_outdoor": "Outdoor",
"hqd_precious_cure": "Precious cure",
"hqd_quick_20": "Rapido 20m",
"hqd_quick_30": "Rapido 30m",
"hqd_quick_dry": "Asciugatura veloce (30 min)",
"hqd_quilt": "Trapunte",
"hqd_refresh": "Refresh",
"hqd_school_uniform": "Uniforme scolastica",
"hqd_shirt": "Camicie",
"hqd_shoes": "Scarpe",
"hqd_silk": "Seta",
"hqd_sports": "Sport",
"hqd_synthetics": "Sintetici",
"hqd_timer": "A tempo",
"hqd_towel": "Asciugamani",
"hqd_underwear": "Intimo",
"hqd_warm_up": "Riscaldamento",
"hqd_wool": "Lana",
"hqd_working_suit": "Abbigliamento da lavoro",
"hygiene": "Igiene",
"iot_checkup": "Check-Up",
"iot_dry_anti_mites": "Anti-Acari",
"iot_dry_baby": "Baby",
"iot_dry_backpacks": "Zaini",
"iot_dry_bathrobe": "Accappatoi e Spugne",
"iot_dry_bed_linen": "Lenzuola",
"iot_dry_bed_quilt": "Trapunte-Piumoni",
"iot_dry_cotton": "Cotone",
"iot_dry_cuddly_toys": "Peluches",
"iot_dry_curtains": "Tende",
"iot_dry_dehumidifier": "Rimuovi umidità",
"iot_dry_delicates": "Delicati",
"iot_dry_delicate_tablecloths": "Tovaglie delicate",
"iot_dry_denim_jeans": "Denim - jeans",
"iot_dry_down_jacket": "Giacche",
"iot_dry_duvet": "Piumone",
"iot_dry_easy_iron_cotton": "Stira facile",
"iot_dry_easy_iron_synthetics": "Stira facile Sintetici",
"iot_dry_gym_fit": "Gym fit - Fitness",
"iot_dry_lingerie": "Lingerie",
"iot_dry_mixed": "Misti",
"iot_dry_playsuits": "Tutine",
"iot_dry_rapid_30": "Rapido 30m",
"iot_dry_rapid_59": "Rapido 59'.",
"iot_dry_refresh": "Rinfresca",
"iot_dry_regenerates_waterproof": "Rigenera Tessuti Impermeabili",
"iot_dry_relax_creases": "Meno Pieghe",
"iot_dry_shirts": "Camicie",
"iot_dry_small_load": "Carico Small",
"iot_dry_swimsuits_and_bikinis": "Costumi e Bikini",
"iot_dry_synthetics": "Sintetici",
"iot_dry_synthetic_dry": "Asciugatura Sintetici",
"iot_dry_tablecloths": "Tovaglie",
"iot_dry_technical_fabrics": "Tessuti Tecnici",
"iot_dry_warm_embrace": "Caldo abbraccio",
"iot_dry_wool": "Lana",
"jeans": "Jeans",
"mix_and_dry": "Mix&Dry",
"pets": "Pets",
"pre_iron": "Pre-Stiro",
"rapid_30": "Rapido 30",
"rapid_45": "Rapido 45 min",
"rapid_59": "Perfect Rapid 59 Min",
"refresh": "Rinfresca",
"relax_creases": "Meno Pieghe",
"saving_30_min": "Risparmio 30'",
"shirts": "Camicie",
"shoes": "Scarpe",
"small_load": "Carico Small",
"soft_care": "Soft Care",
"sport_plus": "Sport Plus",
"super_easy_iron_misti": "Super Easy Iron misti",
"super_easy_iron_xxl": "Super Easy Iron XXL",
"super_fast_cottons": "Super Fast Cotone",
"super_fast_delicates": "Super Fast Delicati",
"synthetics": "Sintetici",
"total_care": "Total Care",
"trainers": "Scarpe da ginnastica",
"ultra_care": "Ultra Care",
"waterproof_revitalize": "Impermeabilizzazione",
"whites": "Bianchi",
"wool": "Asciugatura Lana",
"woolmark": "Lana",
"xxl_load": "Carico XXL",
"zoom_59": "Zoom 59"
}
},
"room_temperature": {
"name": "Temperatura ambiente"
},
"humidity": {
"name": "Umidità"
},
"freezer_temp": {
"name": "Temperatura del congelatore"
},
"fridge_temp": {
"name": "Temperatura del frigorifero"
} }
}, },
"select": { "select": {
@ -185,29 +382,29 @@
"auto_plus": "AutoPlus", "auto_plus": "AutoPlus",
"auto_sensor": "Auto Sensor", "auto_sensor": "Auto Sensor",
"auto_sensor_soil": "Auto Sensor", "auto_sensor_soil": "Auto Sensor",
"auto_universal": "Auto Universale 50 - 60\u00b0C", "auto_universal": "Auto Universale 50 - 60°C",
"auto_universal_plus": "Auto Universale Plus 65 - 75\u00b0C", "auto_universal_plus": "Auto Universale Plus 65 - 75°C",
"auto_universal_plus_soil": "Auto Universale Plus 65 - 75\u00b0C", "auto_universal_plus_soil": "Auto Universale Plus 65 - 75°C",
"auto_universal_soil": "Auto Universale 50 - 60\u00b0C", "auto_universal_soil": "Auto Universale 50 - 60°C",
"auto_wash": "Auto Wash", "auto_wash": "Auto Wash",
"auto_wash_soil": "Auto Wash", "auto_wash_soil": "Auto Wash",
"classe_a_59": "Classe A 59' 65\u00b0C", "classe_a_59": "Classe A 59' 65°C",
"delicate": "Delicato 45\u00b0C", "delicate": "Delicato 45°C",
"dishwasher_care": "Ciclo anticalcare", "dishwasher_care": "Ciclo anticalcare",
"eco": "Eco", "eco": "Eco",
"eco_asynch": "Eco 45\u00b0C", "eco_asynch": "Eco 45°C",
"eco_bldc": "Eco 45\u00b0C", "eco_bldc": "Eco 45°C",
"eco_synch": "Eco 45\u00b0C", "eco_synch": "Eco 45°C",
"gentle_wash": "Gentle wash", "gentle_wash": "Gentle wash",
"glass": "Calici", "glass": "Calici",
"glassware": "Cristalli 45\u00b0C", "glassware": "Cristalli 45°C",
"glass_care": "Glass Care", "glass_care": "Glass Care",
"hygiene": "Igiene", "hygiene": "Igiene",
"hygiene_plus": "Igiene 75\u00b0C", "hygiene_plus": "Igiene 75°C",
"intensive": "Intensivo ", "intensive": "Intensivo ",
"intensive_rapid": "Forte Veloce", "intensive_rapid": "Forte Veloce",
"iot_auto_sensor": "Auto Sensor", "iot_auto_sensor": "Auto Sensor",
"iot_auto_universal_soil": "Auto Universale 50 - 60\u00b0C", "iot_auto_universal_soil": "Auto Universale 50 - 60°C",
"iot_auto_wash_soil": "Auto Wash", "iot_auto_wash_soil": "Auto Wash",
"iot_baby_care": "Baby Care", "iot_baby_care": "Baby Care",
"iot_breakfast": "Colazione", "iot_breakfast": "Colazione",
@ -218,13 +415,13 @@
"iot_cocktail_glasses_soil": "Cocktail Glasses", "iot_cocktail_glasses_soil": "Cocktail Glasses",
"iot_daily_care": "Quotidiano", "iot_daily_care": "Quotidiano",
"iot_daily_care_soil": "Quotidiano", "iot_daily_care_soil": "Quotidiano",
"iot_delicate": "Delicato 45\u00b0C", "iot_delicate": "Delicato 45°C",
"iot_dinner_for_two": "Cena di coppia", "iot_dinner_for_two": "Cena di coppia",
"iot_dinner_for_two_soil": "Cena di coppia", "iot_dinner_for_two_soil": "Cena di coppia",
"iot_dreft_quick_cycle": "Dreft Rapido", "iot_dreft_quick_cycle": "Dreft Rapido",
"iot_eco_asynch": "Eco 45\u00b0C", "iot_eco_asynch": "Eco 45°C",
"iot_eco_bldc": "Eco 45\u00b0C", "iot_eco_bldc": "Eco 45°C",
"iot_eco_synch": "Eco 45\u00b0C", "iot_eco_synch": "Eco 45°C",
"iot_extra_hygiene": "Ciclo Vapore", "iot_extra_hygiene": "Ciclo Vapore",
"iot_fairy_quick_cycle": "Fairy Rapido", "iot_fairy_quick_cycle": "Fairy Rapido",
"iot_happy_hour": "Happy Hour", "iot_happy_hour": "Happy Hour",
@ -240,23 +437,23 @@
"iot_prewash": "Prelavaggio", "iot_prewash": "Prelavaggio",
"iot_pyrex_and_glassware": "Pyrex & Glassware", "iot_pyrex_and_glassware": "Pyrex & Glassware",
"iot_rapid_29": "Rapido 29'", "iot_rapid_29": "Rapido 29'",
"iot_rapid_39": "Rapido 39' 60\u00b0C", "iot_rapid_39": "Rapido 39' 60°C",
"iot_single": "Single", "iot_single": "Single",
"iot_steam": "Vapore 75\u00b0C", "iot_steam": "Vapore 75°C",
"iot_super_flash": "Super Flash", "iot_super_flash": "Super Flash",
"iot_super_wash": "Super Wash", "iot_super_wash": "Super Wash",
"iot_turbopower": "Turbo Power", "iot_turbopower": "Turbo Power",
"iot_universal": "Universale 60\u00b0C", "iot_universal": "Universale 60°C",
"iot_wok_grids_maxi_pans": "Maxi Stoviglie e Griglie", "iot_wok_grids_maxi_pans": "Maxi Stoviglie e Griglie",
"iot_wok_grids_maxi_pans_soil": "Maxi Stoviglie e Griglie", "iot_wok_grids_maxi_pans_soil": "Maxi Stoviglie e Griglie",
"iot_yes_quick_cycle": "Yes Rapido", "iot_yes_quick_cycle": "Yes Rapido",
"night": "Notte 55\u00b0C", "night": "Notte 55°C",
"prewash": "Prelavaggio", "prewash": "Prelavaggio",
"rapid_20": "Rapido 20'", "rapid_20": "Rapido 20'",
"rapid_24": "Rapido 24'", "rapid_24": "Rapido 24'",
"rapid_29": "Rapido 29' 50\u00b0C", "rapid_29": "Rapido 29' 50°C",
"rapid_35": "Wash&Dry 35'", "rapid_35": "Wash&Dry 35'",
"rapid_39": "Rapido 39' 60\u00b0C", "rapid_39": "Rapido 39' 60°C",
"rapid_49": "Rapido 49'", "rapid_49": "Rapido 49'",
"rapid_59": "Rapido 59'", "rapid_59": "Rapido 59'",
"sanitising": "Igienizzazione", "sanitising": "Igienizzazione",
@ -264,15 +461,20 @@
"silent": "Notte", "silent": "Notte",
"silent_care": "Silent Care", "silent_care": "Silent Care",
"smart_ai": "Smart AI", "smart_ai": "Smart AI",
"smart_ai_pro": "Smart AI Pro",
"smart_ai_pro_soil": "Smart AI Pro",
"smart_ai_rapid": "Smart AI Rapid",
"smart_ai_rapid_soil": "Smart AI Rapid",
"smart_ai_soil": "Smart AI",
"special": "Speciale", "special": "Speciale",
"special_pw_prz": "Speciale", "special_pw_prz": "Speciale",
"steam": "Vapore 75\u00b0C", "steam": "Vapore 75°C",
"steam_plus": "Vapore Plus 75\u00b0C", "steam_plus": "Vapore Plus 75°C",
"total_care": "Total Care 50\u00b0C", "total_care": "Total Care 50°C",
"ultra_silence": "Ultra Silenzioso 55\u00b0C", "ultra_silence": "Ultra Silenzioso 55°C",
"ultra_silent": "Ultra Silenzioso 55\u00b0C", "ultra_silent": "Ultra Silenzioso 55°C",
"universal": "Universale 60\u00b0C", "universal": "Universale 60°C",
"universal_plus": "Universale Plus 70\u00b0C", "universal_plus": "Universale Plus 70°C",
"zoom_39": "Zoom 39 min" "zoom_39": "Zoom 39 min"
}, },
"name": "Programma" "name": "Programma"
@ -320,19 +522,20 @@
"programs_ov": { "programs_ov": {
"state": { "state": {
"bakery": "Pasta e Pasticceria", "bakery": "Pasta e Pasticceria",
"bakery_steam": "Pane a vapore", "bakery_steam": "Vapore da forno",
"bottom_heating": "Resistenza Inferiore", "bottom_heating": "Resistenza Inferiore",
"bottom_heating_fan": "Resistenza Inferiore Ventilata", "bottom_heating_fan": "Resistenza Inferiore Ventilata",
"bread": "Pane", "bread": "Pane",
"bread_steam": "Pasticceria a vapore", "bread_steam": "Pane al vapore",
"combi": "Combi",
"convection_fan": "Cottura Ventilata", "convection_fan": "Cottura Ventilata",
"convection_fan_turnspit": "Girarrosto + statico ventilato", "convection_fan_turnspit": "Girarrosto a convenzione ventilata",
"conventional": "Statico", "conventional": "Statico",
"conventional_turnspit": "Girarrosto + statico", "conventional_turnspit": "Girarrosto a convenzione",
"defrost": "Decongelamento", "defrost": "Decongelamento",
"descaling": "Disincrostazione", "descaling": "Decalcificazione",
"fish": "Pesce", "fish": "Pesce",
"fish_steam": "Pesce a vapore", "fish_steam": "Pesce al vapore",
"grill_cata": "Grill", "grill_cata": "Grill",
"grill_fan_cata": "Grill fan", "grill_fan_cata": "Grill fan",
"grill_fan_pyro": "Grill Ventilato", "grill_fan_pyro": "Grill Ventilato",
@ -342,13 +545,13 @@
"iot_h20_clean": "h2O clean", "iot_h20_clean": "h2O clean",
"leavening": "Lievitazione", "leavening": "Lievitazione",
"low_temp_cooking": "Cottura a bassa temperatura", "low_temp_cooking": "Cottura a bassa temperatura",
"low_temp_cooking_fish": "Cottura a bassa temperatura del pesce", "low_temp_cooking_fish": "Cottura a bassa temperatura Pesce",
"low_temp_cooking_fish_steam": "Cottura a bassa temperatura del pesce a vapore", "low_temp_cooking_fish_steam": "Cottura a bassa temperatura Pesce al vapore",
"low_temp_cooking_meat": "Cottura a bassa temperatura della carne", "low_temp_cooking_meat": "Cottura a bassa temperatura Carne",
"low_temp_cooking_meat_steam": "Cottura a vapore a bassa temperatura di carne", "low_temp_cooking_meat_steam": "Cottura a bassa temperatura Carne al vapore",
"low_temp_cooking_steam": "Cottura a vapore a bassa temperatura", "low_temp_cooking_steam": "Cottura a bassa temperatura al vapore",
"meat": "Carne", "meat": "Carne",
"meat_steam": "Carne a vapore", "meat_steam": "Carne al vapore",
"multi_level": "Cottura Multilivello", "multi_level": "Cottura Multilivello",
"paella": "Paella", "paella": "Paella",
"pasta_and_bakery": "Pasta e Pasticceria", "pasta_and_bakery": "Pasta e Pasticceria",
@ -356,20 +559,19 @@
"pyrolysis": "Pirolisi", "pyrolysis": "Pirolisi",
"pyrolysis_plus": "Pirolisi +", "pyrolysis_plus": "Pirolisi +",
"red_meat": "Carne rossa", "red_meat": "Carne rossa",
"red_meat_steam": "Carne rossa a vapore", "red_meat_steam": "Carne rossa al vapore",
"regenerate": "Rigenerazione", "regenerate": "Rigenerare",
"soft_plus": "Soft+", "soft_plus": "Soft+",
"super_grill": "Supergriglia", "super_grill": "Supergriglia",
"tailor_bake": "Tailor bake", "tailor_bake": "Tailor bake",
"tailor_bake_cata": "Tailor Bake", "tailor_bake_cata": "Tailor Bake",
"tailor_bake_desctiption": "Questa funzione \u00e8 ideale per mantenere il cibo morbido all'interno e croccante all'esterno. Per una cucina sana, questa funzione riduce la quantit\u00e0 di grasso o olio necessaria.\r\r\nLa combinazione di elementi riscaldanti con un ciclo pulsante di aria garantisce risultati di cottura uniformi.",
"tailor_bake_pyro": "Tailor Bake", "tailor_bake_pyro": "Tailor Bake",
"vegetables": "Verdure", "vegetables": "Verdure",
"vegetables_cata": "Verdure", "vegetables_cata": "Verdure",
"vegetables_pyro": "Verdure", "vegetables_pyro": "Verdure",
"water_discharge": "Scarico d'acqua", "water_discharge": "Scarico dell'acqua",
"white_meat": "Carne bianca", "white_meat": "Carne Bianca",
"white_meat_steam": "Carne bianca a vapore" "white_meat_steam": "Carne bianca al vapore"
}, },
"name": "Programma" "name": "Programma"
}, },
@ -405,7 +607,7 @@
"hqd_bed_sheets": "Lenzuola", "hqd_bed_sheets": "Lenzuola",
"hqd_bulky": "Vestiti voluminosi", "hqd_bulky": "Vestiti voluminosi",
"hqd_casual": "Casual", "hqd_casual": "Casual",
"hqd_cold_wind_30": "Brezza rinfrescante 30 minuti", "hqd_cold_wind_30": "Brezza rinfrescante 30m",
"hqd_cold_wind_timing": "Brezza rinfrescante", "hqd_cold_wind_timing": "Brezza rinfrescante",
"hqd_cotton": "Cotone", "hqd_cotton": "Cotone",
"hqd_curtain": "Tende", "hqd_curtain": "Tende",
@ -419,14 +621,14 @@
"hqd_i_refresh_pro": "I-Refresh Pro", "hqd_i_refresh_pro": "I-Refresh Pro",
"hqd_jacket": "Giacche", "hqd_jacket": "Giacche",
"hqd_jeans": "Jeans", "hqd_jeans": "Jeans",
"hqd_luxury": "Vestiti preziosi", "hqd_luxury": "Capi Pregiati",
"hqd_mix": "Misti", "hqd_mix": "Misti",
"hqd_night_dry": "Asciugatura notturna", "hqd_night_dry": "Asciugatura notturna",
"hqd_outdoor": "Outdoor", "hqd_outdoor": "Outdoor",
"hqd_precious_cure": "Precious cure", "hqd_precious_cure": "Precious cure",
"hqd_quick_20": "Rapido 20", "hqd_quick_20": "Rapido 20m",
"hqd_quick_30": "Rapido 30", "hqd_quick_30": "Rapido 30m",
"hqd_quick_dry": "Asciugatura veloce", "hqd_quick_dry": "Asciugatura veloce (30 min)",
"hqd_quilt": "Trapunte", "hqd_quilt": "Trapunte",
"hqd_refresh": "Refresh", "hqd_refresh": "Refresh",
"hqd_school_uniform": "Uniforme scolastica", "hqd_school_uniform": "Uniforme scolastica",
@ -440,7 +642,7 @@
"hqd_underwear": "Intimo", "hqd_underwear": "Intimo",
"hqd_warm_up": "Riscaldamento", "hqd_warm_up": "Riscaldamento",
"hqd_wool": "Lana", "hqd_wool": "Lana",
"hqd_working_suit": "Completo da lavoro", "hqd_working_suit": "Abbigliamento da lavoro",
"hygiene": "Igiene", "hygiene": "Igiene",
"iot_checkup": "Check-Up", "iot_checkup": "Check-Up",
"iot_dry_anti_mites": "Anti-Acari", "iot_dry_anti_mites": "Anti-Acari",
@ -452,7 +654,7 @@
"iot_dry_cotton": "Cotone", "iot_dry_cotton": "Cotone",
"iot_dry_cuddly_toys": "Peluches", "iot_dry_cuddly_toys": "Peluches",
"iot_dry_curtains": "Tende", "iot_dry_curtains": "Tende",
"iot_dry_dehumidifier": "Rimuovi umidit\u00e0", "iot_dry_dehumidifier": "Rimuovi umidità",
"iot_dry_delicates": "Delicati", "iot_dry_delicates": "Delicati",
"iot_dry_delicate_tablecloths": "Tovaglie delicate", "iot_dry_delicate_tablecloths": "Tovaglie delicate",
"iot_dry_denim_jeans": "Denim - jeans", "iot_dry_denim_jeans": "Denim - jeans",
@ -464,7 +666,7 @@
"iot_dry_lingerie": "Lingerie", "iot_dry_lingerie": "Lingerie",
"iot_dry_mixed": "Misti", "iot_dry_mixed": "Misti",
"iot_dry_playsuits": "Tutine", "iot_dry_playsuits": "Tutine",
"iot_dry_rapid_30": "Rapido 30", "iot_dry_rapid_30": "Rapido 30m",
"iot_dry_rapid_59": "Rapido 59'.", "iot_dry_rapid_59": "Rapido 59'.",
"iot_dry_refresh": "Rinfresca", "iot_dry_refresh": "Rinfresca",
"iot_dry_regenerates_waterproof": "Rigenera Tessuti Impermeabili", "iot_dry_regenerates_waterproof": "Rigenera Tessuti Impermeabili",
@ -512,8 +714,8 @@
}, },
"programs_wm": { "programs_wm": {
"state": { "state": {
"20_degrees_coloured_cottons": "Cotone e Colorati 20\u00b0", "20_degrees_coloured_cottons": "Cotone e Colorati 20°",
"20_degrees_new_energy_label": "20\u00b0C", "20_degrees_new_energy_label": "20°C",
"active_steam": "Vapore", "active_steam": "Vapore",
"active_wash": "Active Wash", "active_wash": "Active Wash",
"active_wash_steam": "Active Wash + Vapore", "active_wash_steam": "Active Wash + Vapore",
@ -524,7 +726,7 @@
"all_in_one_59_steam": "Active Wash + Vapore", "all_in_one_59_steam": "Active Wash + Vapore",
"autocare": "Autocare", "autocare": "Autocare",
"autoclean": "Pulizia cesto e decalcifiazione", "autoclean": "Pulizia cesto e decalcifiazione",
"baby_60": "Tutto Beb\u00e8 60\u00b0C", "baby_60": "Tutto Bebè 60°C",
"care_14": "Rapid Care 14'", "care_14": "Rapid Care 14'",
"care_30": "Rapid Care 30'", "care_30": "Rapid Care 30'",
"care_44": "Rapid Care 44'", "care_44": "Rapid Care 44'",
@ -550,7 +752,7 @@
"fresh_care_steam": "Fresh Care + Vapore", "fresh_care_steam": "Fresh Care + Vapore",
"handwash_wool": "Mano e Lana", "handwash_wool": "Mano e Lana",
"high_dry": "Asciugatura Cotone", "high_dry": "Asciugatura Cotone",
"hqd_20_degrees": "Cotone 20\u00b0C", "hqd_20_degrees": "Cotone 20°C",
"hqd_allergy": "Allergy Care", "hqd_allergy": "Allergy Care",
"hqd_autoclean": "Pulizia del cesto", "hqd_autoclean": "Pulizia del cesto",
"hqd_babycare": "Baby Care", "hqd_babycare": "Baby Care",
@ -577,13 +779,13 @@
"hqd_super_fast": "Rapido 39'", "hqd_super_fast": "Rapido 39'",
"hqd_synthetic_and_coloured": "Sintetici", "hqd_synthetic_and_coloured": "Sintetici",
"hygiene_59": "Igiene Plus 59'", "hygiene_59": "Igiene Plus 59'",
"hygiene_60": "Igiene 60\u00b0C", "hygiene_60": "Igiene 60°C",
"hygiene_plus_59": "Igiene Plus 59'", "hygiene_plus_59": "Igiene Plus 59'",
"hygiene_plus_59_min": "Igiene Plus 59'", "hygiene_plus_59_min": "Igiene Plus 59'",
"hygiene_pro_49_min": "Igiene Pro 49'", "hygiene_pro_49_min": "Igiene Pro 49'",
"hygiene_pro_steam": "Hygiene Pro + Vapore", "hygiene_pro_steam": "Hygiene Pro + Vapore",
"intensive_40": "Intensivo 40\u00b0C", "intensive_40": "Intensivo 40°C",
"intensive_40_steam": "Intensivo 40\u00b0C + Vapore", "intensive_40_steam": "Intensivo 40°C + Vapore",
"iot_active_steam": "Vapore", "iot_active_steam": "Vapore",
"iot_active_wash_steam": "Active Wash + Vapore", "iot_active_wash_steam": "Active Wash + Vapore",
"iot_allergy_care_pro": "Allergy Care Pro", "iot_allergy_care_pro": "Allergy Care Pro",
@ -602,7 +804,7 @@
"iot_dry_cotton_dry": "Asciugatura cotone", "iot_dry_cotton_dry": "Asciugatura cotone",
"iot_dry_cuddly_toys": "Peluches", "iot_dry_cuddly_toys": "Peluches",
"iot_dry_curtains": "Tende", "iot_dry_curtains": "Tende",
"iot_dry_dehumidifier": "Rimuovi umidit\u00e0", "iot_dry_dehumidifier": "Rimuovi umidità",
"iot_dry_delicates_antiallergy": "Antiallergia Delicati", "iot_dry_delicates_antiallergy": "Antiallergia Delicati",
"iot_dry_delicate_tablecloths": "Tovaglie delicate", "iot_dry_delicate_tablecloths": "Tovaglie delicate",
"iot_dry_denim_jeans": "Denim - Jeans", "iot_dry_denim_jeans": "Denim - Jeans",
@ -623,7 +825,7 @@
"iot_easy_iron": "Stiro Facile", "iot_easy_iron": "Stiro Facile",
"iot_fresh_care_steam": "Fresh Care + Vapore", "iot_fresh_care_steam": "Fresh Care + Vapore",
"iot_hygiene_pro_steam": "Hygiene Pro + Vapore", "iot_hygiene_pro_steam": "Hygiene Pro + Vapore",
"iot_intensive_40_steam": "Intensivo 40\u00b0C + Vapore", "iot_intensive_40_steam": "Intensivo 40°C + Vapore",
"iot_mixed_steam": "Misti + Vapore", "iot_mixed_steam": "Misti + Vapore",
"iot_mix_and_colour_59_steam": "Misti e Colorati 59' + Vapore ", "iot_mix_and_colour_59_steam": "Misti e Colorati 59' + Vapore ",
"iot_perfect_cotton_59_steam": "Cotone Perfetto 59' + Vapore", "iot_perfect_cotton_59_steam": "Cotone Perfetto 59' + Vapore",
@ -830,15 +1032,91 @@
"12": "Stiro facile", "12": "Stiro facile",
"13": "Armadio", "13": "Armadio",
"14": "Pronto da indossare", "14": "Pronto da indossare",
"15": "Extra asciutto" "15": "Extra asciutto",
"11": "Nessuna asciugatura"
}, },
"name": "Tipo Asciugatura" "name": "Livello Asciugatura"
}, },
"spin_speed": { "spin_speed": {
"name": "Centrifuga" "name": "Centrifuga"
}, },
"temperature": { "temperature": {
"name": "Temperatura" "name": "Temperatura"
},
"dry_time": {
"name": "Tempo asciugatura"
},
"eco_pilot": {
"state": {
"0": "Spento",
"1": "Avoid touch",
"2": "Segui"
},
"name": "Eco pilot"
},
"fan_mode": {
"state": {
"1": "Alto",
"2": "Medio",
"3": "Basso",
"4": "Auto",
"5": "Auto"
}
},
"programs_ac": {
"state": {
"iot_10_heating": "Funzione 10°C Heating ",
"iot_auto": "Auto",
"iot_cool": "Freddo",
"iot_dry": "Deumidificazione",
"iot_fan": "Ventilatore",
"iot_heat": "Caldo",
"iot_nano_aqua": "Nano Aqua",
"iot_purify": "Self purify",
"iot_self_clean": "Self clean",
"iot_self_clean_56": "Steri-Clean 56°C",
"iot_simple_start": "Avvia ora",
"iot_uv": "UV",
"iot_uv_and_auto": "UV + Auto",
"iot_uv_and_cool": "UV + Freddo",
"iot_uv_and_dry": "UV + Deumidificatore",
"iot_uv_and_fan": "UV + Ventola",
"iot_uv_and_heat": "UV + Caldo"
}
},
"programs_ref": {
"state": {
"auto_set": "AUTO-SET",
"cheese": "Formaggio",
"chiller": "Quick cool",
"cold_drinks": "Soft chill",
"eco": "Eco",
"eco_mode": "Modalità Eco",
"fruits_and_veg": "Fruit&Veg",
"fruit_and_veg": "Fruit & Veg",
"holiday": "HOLIDAY",
"keep_fresh": "0° Fresh",
"no_mode_selected": "Nessuna modalità selezionata",
"quick_cool": " QUICK COOL",
"sea_food": "Ready to cook meal",
"soft_frozen": "Soft freezing",
"super_cool": "SUPER COOL",
"super_freeze": "SUPER FREEZE",
"tea": "Cold drinks or Beverages",
"zero_fresh": "0° Fresh"
}
},
"remaining_time": {
"name": "Tempo rimanente"
},
"ref_zones": {
"state": {
"fridge": "Frigorifero",
"freezer": "Congelatore",
"vtroom1": "My Zone",
"fridge_freezer": "Frigorifero & Congelatore"
},
"name": "Zona"
} }
}, },
"switch": { "switch": {
@ -846,7 +1124,7 @@
"name": "Antipieghe " "name": "Antipieghe "
}, },
"add_dish": { "add_dish": {
"name": "" "name": "Aggiungi stoviglie"
}, },
"eco_express": { "eco_express": {
"name": "Eco" "name": "Eco"
@ -886,6 +1164,69 @@
}, },
"pause": { "pause": {
"name": "Pausa" "name": "Pausa"
},
"keep_fresh": {
"name": "Keep Fresh"
},
"delay_time": {
"name": "Utilizzo nelle ore notturne"
},
"rapid_mode": {
"name": "Modalità rapida"
},
"eco_mode": {
"name": "Modalità ECO"
},
"10_degree_heating": {
"name": "Funzione 10°C Heating "
},
"self_clean": {
"name": "Self clean"
},
"self_clean_56": {
"name": "Steri-Clean 56°C"
},
"silent_mode": {
"name": "Modalità silenziosa"
},
"mute_mode": {
"name": "Modalità tacita"
},
"extra_rinse_1": {
"name": "+1 Risciacquo"
},
"extra_rinse_2": {
"name": "+2 Risciacqui"
},
"extra_rinse_3": {
"name": "+3 Risciacqui"
},
"acqua_plus": {
"name": "Acquaplus"
},
"auto_dose": {
"name": "Autodose"
},
"good_night": {
"name": "Buona notte"
},
"auto_dose_softener": {
"name": "Autodose Ammorbidente"
},
"auto_dose_detergent": {
"name": "Autodose Detergente"
},
"auto_set": {
"name": "Impostazione automatica"
},
"super_cool": {
"name": "Super Cool"
},
"super_freeze": {
"name": "Super Freeze"
},
"refrigerator": {
"name": "Frigo"
} }
}, },
"binary_sensor": { "binary_sensor": {
@ -935,7 +1276,7 @@
"name": "Pentola" "name": "Pentola"
}, },
"remote_control": { "remote_control": {
"name": "Controllo remoto" "name": "远程控制"
}, },
"rinse_aid": { "rinse_aid": {
"name": "Livello Brillantante" "name": "Livello Brillantante"
@ -947,7 +1288,46 @@
"name": "Porta aperta" "name": "Porta aperta"
}, },
"connection": { "connection": {
"name": "Connessione" "name": "Connessione dell'elettrodomestico"
},
"child_lock": {
"name": "Child Lock"
},
"on": {
"name": "On"
},
"prewash": {
"name": "Prelavaggio"
},
"acqua_plus": {
"name": "Acquaplus"
},
"auto_dose": {
"name": "Autodose"
},
"buzzer": {
"name": "Avviso di fine ciclo"
},
"holiday_mode": {
"name": "Modalità Holiday"
},
"auto_set": {
"name": "Impostazione automatica"
},
"super_cool": {
"name": "Super Cool"
},
"super_freeze": {
"name": "Super Freeze"
},
"freezer_door": {
"name": "Porta aperta Congelatore"
},
"fridge_door": {
"name": "Porta aperta Frigorifero"
},
"filter_replacement": {
"name": "Sostituzione filtro"
} }
}, },
"number": { "number": {
@ -958,7 +1338,7 @@
"name": "Temperatura" "name": "Temperatura"
}, },
"delay_time": { "delay_time": {
"name": "Ritarda avvio" "name": "Utilizzo nelle ore notturne"
}, },
"water_hard": { "water_hard": {
"name": "Durezza acqua" "name": "Durezza acqua"
@ -973,12 +1353,123 @@
"name": "Numero risciacqui" "name": "Numero risciacqui"
}, },
"wash_time": { "wash_time": {
"name": "Intensit\u00e0 di lavaggio" "name": "Intensità di lavaggio"
},
"dry_time": {
"name": "Tempo asciugatura"
},
"steam_level": {
"name": "Livello vapore"
},
"freezer_temp_sel": {
"name": "Temperatura target Congelatore"
},
"fridge_temp_sel": {
"name": "Temperatura target Frigorifero"
} }
}, },
"button": { "button": {
"induction_hob": { "induction_hob": {
"name": "Piano cottura a induzione" "name": "Piano cottura a induzione"
},
"start_program": {
"name": "Programma Inizia"
},
"stop_program": {
"name": "Programma Stop"
}
},
"climate": {
"air_conditioner": {
"name": "Condizionatore"
},
"fridge": {
"name": "Frigorifero",
"state_attributes": {
"preset_mode": {
"name": "Modalità del frigorifero",
"state": {
"auto_set": "Impostazione automatica",
"super_cool": "Super Cool",
"holiday": "Holiday",
"no_mode": "Nessuna modalità selezionata"
}
}
}
},
"freezer": {
"name": "Congelatore",
"state_attributes": {
"preset_mode": {
"name": "Modalità del congelatore",
"state": {
"auto_set": "Impostazione automatica",
"super_freeze": "Super Freeze",
"no_mode": "Nessuna modalità selezionata"
}
}
}
},
"oven": {
"name": "Forno",
"state_attributes": {
"preset_mode": {
"name": "Programmi",
"state": {
"bakery": "Pasta e Pasticceria",
"bakery_steam": "Vapore da forno",
"bottom_heating": "Resistenza Inferiore",
"bottom_heating_fan": "Resistenza Inferiore Ventilata",
"bread": "Pane",
"bread_steam": "Pane al vapore",
"combi": "Combi",
"convection_fan": "Cottura Ventilata",
"convection_fan_turnspit": "Girarrosto a convenzione ventilata",
"conventional": "Statico",
"conventional_turnspit": "Girarrosto a convenzione",
"defrost": "Decongelamento",
"descaling": "Decalcificazione",
"fish": "Pesce",
"fish_steam": "Pesce al vapore",
"grill_cata": "Grill",
"grill_fan_cata": "Grill fan",
"grill_fan_pyro": "Grill Ventilato",
"grill_pyro": "Grill",
"h20_clean": "H2O-Clean",
"iot_bread": "Pane",
"iot_h20_clean": "h2O clean",
"leavening": "Lievitazione",
"low_temp_cooking": "Cottura a bassa temperatura",
"low_temp_cooking_fish": "Cottura a bassa temperatura Pesce",
"low_temp_cooking_fish_steam": "Cottura a bassa temperatura Pesce al vapore",
"low_temp_cooking_meat": "Cottura a bassa temperatura Carne",
"low_temp_cooking_meat_steam": "Cottura a bassa temperatura Carne al vapore",
"low_temp_cooking_steam": "Cottura a bassa temperatura al vapore",
"meat": "Carne",
"meat_steam": "Carne al vapore",
"multi_level": "Cottura Multilivello",
"paella": "Paella",
"pasta_and_bakery": "Pasta e Pasticceria",
"pizza": "Pizza",
"pyrolysis": "Pirolisi",
"pyrolysis_plus": "Pirolisi +",
"red_meat": "Carne rossa",
"red_meat_steam": "Carne rossa al vapore",
"regenerate": "Rigenerare",
"soft_plus": "Soft+",
"super_grill": "Supergriglia",
"tailor_bake": "Tailor bake",
"tailor_bake_cata": "Tailor Bake",
"tailor_bake_pyro": "Tailor Bake",
"vegetables": "Verdure",
"vegetables_cata": "Verdure",
"vegetables_pyro": "Verdure",
"water_discharge": "Scarico dell'acqua",
"white_meat": "Carne Bianca",
"white_meat_steam": "Carne bianca al vapore"
}
}
}
} }
} }
} }

View File

@ -9,7 +9,10 @@
"4": "Gepland", "4": "Gepland",
"5": "Gepland", "5": "Gepland",
"6": "Fout", "6": "Fout",
"7": "Klaar" "7": "Klaar",
"2": "Programma draait",
"8": "Test",
"9": "Programma stoppen…"
} }
}, },
"program_phases_wm": { "program_phases_wm": {
@ -53,7 +56,9 @@
"16": "Afkoelen", "16": "Afkoelen",
"18": "Fris houden", "18": "Fris houden",
"19": "Drogen", "19": "Drogen",
"20": "Drogen" "20": "Drogen",
"11": "Klaar",
"17": "unknown"
}, },
"name": "Fase" "name": "Fase"
}, },
@ -79,9 +84,10 @@
"12": "Strijken", "12": "Strijken",
"13": "Kastdroog", "13": "Kastdroog",
"14": "Klaar om te dragen", "14": "Klaar om te dragen",
"15": "Extra droog" "15": "Extra droog",
"11": "Niet drogen"
}, },
"name": "Drogen" "name": "Droogniveau"
}, },
"anti_crease": { "anti_crease": {
"name": "Kreukherstellend" "name": "Kreukherstellend"
@ -96,7 +102,7 @@
"name": "Temperatuur" "name": "Temperatuur"
}, },
"water_efficiency": { "water_efficiency": {
"name": "Effici\u00ebnt waterverbruik" "name": "Efficiënt waterverbruik"
}, },
"water_saving": { "water_saving": {
"name": "Waterbesparing" "name": "Waterbesparing"
@ -117,7 +123,202 @@
"name": "Vuilheid" "name": "Vuilheid"
}, },
"delay_time": { "delay_time": {
"name": "Plannen" "name": "Vertraag Start"
},
"dry_time": {
"name": "Droogtijd"
},
"suggested_load": {
"name": "Laadvermogen"
},
"energy_label": {
"name": "Energie-efficiëntie"
},
"det_dust": {
"name": "Poeder"
},
"det_liquid": {
"name": "Vloeibaar"
},
"errors": {
"name": "Fout"
},
"programs": {
"name": "Huidig programma"
},
"cycles_total": {
"name": "Programma's Totaal"
},
"energy_total": {
"name": "Energieverbruik Totaal"
},
"water_total": {
"name": "Efficiënt waterverbruik Totaal"
},
"energy_current": {
"name": "Energieverbruik Huidige"
},
"water_current": {
"name": "Efficiënt waterverbruik Huidige"
},
"mach_modes_ac": {
"state": {
"0": "Automatisch",
"1": "Koelen",
"2": "Koelen",
"3": "Drogen",
"4": "Verwarming",
"5": "Ventilator",
"6": "Ventilator"
}
},
"programs_td": {
"state": {
"active_dry": "Actief drogen",
"allergy_care": "Anti-allergie",
"all_in_one": "All in One",
"antiallergy": "Anti-allergie",
"anti_odours": "Anti geuren",
"auto_care": "Automatische verzorging",
"baby": "Baby",
"bed_quilt": "Dekbed",
"care_30": "Verzorging 30'",
"care_45": "Verzorging 45'",
"care_59": "Verzorging 59'",
"coloured": "Gekleurd",
"daily_45_min": "DAILY 45'",
"daily_perfect_59_min": "DAILY PERFECT 59'",
"darks_and_coloured": "Donker & Gekleurd",
"delicates": "Fijne was",
"duvet": "Dekbed",
"eco": "Eco katoen",
"ecospeed_cottons": "Ecospeed Katoen",
"ecospeed_delicates": "Ecospeed fijne was",
"ecospeed_mixed": "Ecospeed Gemengd",
"extra_hygiene": "Extra Hygiene",
"fitness": "Fitness",
"fresh_care": "Opfrisverzorging",
"genius": "Genius",
"hqd_baby_care": "Baby Care",
"hqd_bath_towel": "Handdoeken",
"hqd_bed_sheets": "Beddengoed",
"hqd_bulky": "Grote artikelen",
"hqd_casual": "Casual",
"hqd_cold_wind_30": "30 minuten koel briesje",
"hqd_cold_wind_timing": "Koel briesje ",
"hqd_cotton": "Katoen",
"hqd_curtain": "Gordijnen",
"hqd_delicate": "Fijne was",
"hqd_diaper": "Luiers",
"hqd_duvet": "Dekbed",
"hqd_feather": "Donsjassen",
"hqd_hot_wind_timing": "Hete lucht",
"hqd_hygienic": "Ontsmetten",
"hqd_i_refresh": "I-Refresh",
"hqd_i_refresh_pro": "I-Refresh Pro",
"hqd_jacket": "Jassen",
"hqd_jeans": "Jeans",
"hqd_luxury": "Luxury",
"hqd_mix": "Gemengde vezels",
"hqd_night_dry": "Nachtelijk droogprogramma",
"hqd_outdoor": "Outdoor",
"hqd_precious_cure": "Precious cure",
"hqd_quick_20": "Quick 20",
"hqd_quick_30": "Quick 30",
"hqd_quick_dry": "Quick dry 30",
"hqd_quilt": "Quilts",
"hqd_refresh": "Opfrissen",
"hqd_school_uniform": "Schooluniform",
"hqd_shirt": "Overhemden",
"hqd_shoes": "Schoenen",
"hqd_silk": "Zijde",
"hqd_sports": "Sport",
"hqd_synthetics": "Synthetische stoffen",
"hqd_timer": "Getimed",
"hqd_towel": "Handdoeken",
"hqd_underwear": "Ondergoed",
"hqd_warm_up": "Opwarmen",
"hqd_wool": "Wol",
"hqd_working_suit": "Werkkleding",
"hygiene": "Hygiëne",
"iot_checkup": "Controle",
"iot_dry_anti_mites": "Anti-mijten",
"iot_dry_baby": "Baby",
"iot_dry_backpacks": "Rugzakken",
"iot_dry_bathrobe": "Badjas",
"iot_dry_bed_linen": "Bed Linnen",
"iot_dry_bed_quilt": "Dekbed",
"iot_dry_cotton": "Katoen",
"iot_dry_cuddly_toys": "Knufflels",
"iot_dry_curtains": "Gordijnen",
"iot_dry_dehumidifier": "Vochtigheidsverwijderaar",
"iot_dry_delicates": "Delicate was",
"iot_dry_delicate_tablecloths": "Delicate tafelkleden",
"iot_dry_denim_jeans": "Denim Jeans",
"iot_dry_down_jacket": "Jacket",
"iot_dry_duvet": "Dekbed",
"iot_dry_easy_iron_cotton": "Super Gemakkelijk strijken",
"iot_dry_easy_iron_synthetics": "Synthetische stoffen gemakkelijk strijken",
"iot_dry_gym_fit": "Gym fit - Fitness",
"iot_dry_lingerie": "Lingerie",
"iot_dry_mixed": "Gemengde vezels",
"iot_dry_playsuits": "Jumpsuits",
"iot_dry_rapid_30": "Rapid 30",
"iot_dry_rapid_59": "Snel 59'",
"iot_dry_refresh": "Opfrissen",
"iot_dry_regenerates_waterproof": "Regenereert Waterproof",
"iot_dry_relax_creases": "Ontkreuken",
"iot_dry_shirts": "Overhemden",
"iot_dry_small_load": "Kleine lading",
"iot_dry_swimsuits_and_bikinis": "Badkleding",
"iot_dry_synthetics": "Synthetisch",
"iot_dry_synthetic_dry": "Synthetische stoffen drogen",
"iot_dry_tablecloths": "Tafelkleden",
"iot_dry_technical_fabrics": "Technische Vezels",
"iot_dry_warm_embrace": "Warme Knuffel",
"iot_dry_wool": "Wol",
"jeans": "Jeans",
"mix_and_dry": "Gemengd&Droog",
"pets": "Huisdieren",
"pre_iron": "Gemakkelijk strijken",
"rapid_30": "Rapid 30",
"rapid_45": "Snel 45 min",
"rapid_59": "Perfect Rapid 59 Min",
"refresh": "Opfrissen",
"relax_creases": "Ontkreuken",
"saving_30_min": "ECO 30'",
"shirts": "Overhemden",
"shoes": "Schoenen",
"small_load": "Kleine lading",
"soft_care": "Zachte verzorging",
"sport_plus": "Sports",
"super_easy_iron_misti": "Super eenvoudig strijken gemengd",
"super_easy_iron_xxl": "Super eenvoudig strijken XXL",
"super_fast_cottons": "Super Snel Katoen",
"super_fast_delicates": "Super Snel Delicaat",
"synthetics": "Synthetisch",
"total_care": "Total Care",
"trainers": "Trainers",
"ultra_care": "Ultra Care",
"waterproof_revitalize": "Waterproof Revitaliseren",
"whites": "Witte was",
"wool": "Droge Wol",
"woolmark": "Wol",
"xxl_load": "XXL Lading",
"zoom_59": "Zoom 59"
}
},
"room_temperature": {
"name": "Omgevingstemperatuur"
},
"humidity": {
"name": "Luchtvochtigheid"
},
"freezer_temp": {
"name": "Vriezertemperatuur"
},
"fridge_temp": {
"name": "Koelkasttemperatuur"
} }
}, },
"select": { "select": {
@ -129,29 +330,29 @@
"auto_plus": "AutoPlus", "auto_plus": "AutoPlus",
"auto_sensor": "Auto Sensor", "auto_sensor": "Auto Sensor",
"auto_sensor_soil": "Auto Sensor", "auto_sensor_soil": "Auto Sensor",
"auto_universal": "Auto universeel 50 - 60\u00b0C", "auto_universal": "Auto universeel 50 - 60°C",
"auto_universal_plus": "Auto universeel plus 65 - 75\u00b0C", "auto_universal_plus": "Auto universeel plus 65 - 75°C",
"auto_universal_plus_soil": "Auto universeel plus 65 - 75\u00b0C", "auto_universal_plus_soil": "Auto universeel plus 65 - 75°C",
"auto_universal_soil": "Auto universeel 50 - 60\u00b0C", "auto_universal_soil": "Auto universeel 50 - 60°C",
"auto_wash": "Automatisch wassen", "auto_wash": "Automatisch wassen",
"auto_wash_soil": "Automatisch wassen", "auto_wash_soil": "Automatisch wassen",
"classe_a_59": "A klasse 59' 65\u00b0C", "classe_a_59": "A klasse 59' 65°C",
"delicate": "Delicaat 45\u00b0C", "delicate": "Delicaat 45°C",
"dishwasher_care": "Ontkalkingsprogramma", "dishwasher_care": "Ontkalkingsprogramma",
"eco": "Eco", "eco": "Eco",
"eco_asynch": "Eco 45\u00b0C", "eco_asynch": "Eco 45°C",
"eco_bldc": "Eco 45\u00b0C", "eco_bldc": "Eco 45°C",
"eco_synch": "Eco 45\u00b0C", "eco_synch": "Eco 45°C",
"gentle_wash": "Gentle wash", "gentle_wash": "Gentle wash",
"glass": "Glas", "glass": "Glas",
"glassware": "Glaswerk 45\u00b0C", "glassware": "Glaswerk 45°C",
"glass_care": "Glass Care", "glass_care": "Glass Care",
"hygiene": "Hygi\u00ebne", "hygiene": "Hygiëne",
"hygiene_plus": "Hygi\u00ebne+ 75\u00b0C", "hygiene_plus": "Hygiëne+ 75°C",
"intensive": "Intensief", "intensive": "Intensief",
"intensive_rapid": "Intensief snel", "intensive_rapid": "Intensief snel",
"iot_auto_sensor": "Auto Sensor", "iot_auto_sensor": "Auto Sensor",
"iot_auto_universal_soil": "Auto universeel 50 - 60\u00b0C", "iot_auto_universal_soil": "Auto universeel 50 - 60°C",
"iot_auto_wash_soil": "Automatisch wassen", "iot_auto_wash_soil": "Automatisch wassen",
"iot_baby_care": "Baby Care", "iot_baby_care": "Baby Care",
"iot_breakfast": "Onbtijt", "iot_breakfast": "Onbtijt",
@ -162,13 +363,13 @@
"iot_cocktail_glasses_soil": "CocktailGlazen", "iot_cocktail_glasses_soil": "CocktailGlazen",
"iot_daily_care": "Dagelijkse Zorg", "iot_daily_care": "Dagelijkse Zorg",
"iot_daily_care_soil": "Dagelijkse Zorg", "iot_daily_care_soil": "Dagelijkse Zorg",
"iot_delicate": "Delicaat 45\u00b0C", "iot_delicate": "Delicaat 45°C",
"iot_dinner_for_two": "Dinner for 2", "iot_dinner_for_two": "Dinner for 2",
"iot_dinner_for_two_soil": "Dinner for 2", "iot_dinner_for_two_soil": "Dinner for 2",
"iot_dreft_quick_cycle": "Dreft Quick", "iot_dreft_quick_cycle": "Dreft Quick",
"iot_eco_asynch": "Eco 45\u00b0C", "iot_eco_asynch": "Eco 45°C",
"iot_eco_bldc": "Eco 45\u00b0C", "iot_eco_bldc": "Eco 45°C",
"iot_eco_synch": "Eco 45\u00b0C", "iot_eco_synch": "Eco 45°C",
"iot_extra_hygiene": "Extra Hygiene", "iot_extra_hygiene": "Extra Hygiene",
"iot_fairy_quick_cycle": "Fairy Quick", "iot_fairy_quick_cycle": "Fairy Quick",
"iot_happy_hour": "Happy Hour", "iot_happy_hour": "Happy Hour",
@ -184,23 +385,23 @@
"iot_prewash": "Voorwas", "iot_prewash": "Voorwas",
"iot_pyrex_and_glassware": "Pyrex & Glazen", "iot_pyrex_and_glassware": "Pyrex & Glazen",
"iot_rapid_29": "Snel 29'", "iot_rapid_29": "Snel 29'",
"iot_rapid_39": "Snel 39' 60\u00b0C", "iot_rapid_39": "Snel 39' 60°C",
"iot_single": "Single", "iot_single": "Single",
"iot_steam": "Stoom 75\u00b0C", "iot_steam": "Stoom 75°C",
"iot_super_flash": "Super Flash", "iot_super_flash": "Super Flash",
"iot_super_wash": "Super Was", "iot_super_wash": "Super Was",
"iot_turbopower": "TurboPower", "iot_turbopower": "TurboPower",
"iot_universal": "Universeel 60\u00b0C", "iot_universal": "Universeel 60°C",
"iot_wok_grids_maxi_pans": "Speciale Pannen (Wokpannen - Roosters & Maxi Pannen)", "iot_wok_grids_maxi_pans": "Speciale Pannen (Wokpannen - Roosters & Maxi Pannen)",
"iot_wok_grids_maxi_pans_soil": "Speciale Pannen (Wokpannen - Roosters & Maxi Pannen)", "iot_wok_grids_maxi_pans_soil": "Speciale Pannen (Wokpannen - Roosters & Maxi Pannen)",
"iot_yes_quick_cycle": "Yes Quick", "iot_yes_quick_cycle": "Yes Quick",
"night": "Zeer stil 55\u00b0C", "night": "Zeer stil 55°C",
"prewash": "Voorwas", "prewash": "Voorwas",
"rapid_20": "Snel 20'", "rapid_20": "Snel 20'",
"rapid_24": "Snel 24'", "rapid_24": "Snel 24'",
"rapid_29": "Snel 29' 50\u00b0C", "rapid_29": "Snel 29' 50°C",
"rapid_35": "Wash&Dry 35'", "rapid_35": "Wash&Dry 35'",
"rapid_39": "Snel 39' 60\u00b0C", "rapid_39": "Snel 39' 60°C",
"rapid_49": "Snel 49'", "rapid_49": "Snel 49'",
"rapid_59": "Snel 59'", "rapid_59": "Snel 59'",
"sanitising": "Ontsmetten", "sanitising": "Ontsmetten",
@ -208,15 +409,20 @@
"silent": "Nacht", "silent": "Nacht",
"silent_care": "Silent Care", "silent_care": "Silent Care",
"smart_ai": "Smart AI", "smart_ai": "Smart AI",
"smart_ai_pro": "Smart AI Pro",
"smart_ai_pro_soil": "Smart AI Pro",
"smart_ai_rapid": "Smart AI Rapid",
"smart_ai_rapid_soil": "Smart AI Rapid",
"smart_ai_soil": "Smart AI",
"special": "speciaal", "special": "speciaal",
"special_pw_prz": "speciaal", "special_pw_prz": "speciaal",
"steam": "Stoom 75\u00b0C", "steam": "Stoom 75°C",
"steam_plus": "Stoom Plus 75\u00b0C", "steam_plus": "Stoom Plus 75°C",
"total_care": "Total Care 50\u00b0C", "total_care": "Total Care 50°C",
"ultra_silence": "Zeer stil 55\u00b0C", "ultra_silence": "Zeer stil 55°C",
"ultra_silent": "Zeer stil 55\u00b0C", "ultra_silent": "Zeer stil 55°C",
"universal": "Universeel 60\u00b0C", "universal": "Universeel 60°C",
"universal_plus": "Universeel Plus 70\u00b0C", "universal_plus": "Universeel Plus 70°C",
"zoom_39": "Zoom 39 min" "zoom_39": "Zoom 39 min"
}, },
"name": "Programma" "name": "Programma"
@ -264,11 +470,12 @@
"programs_ov": { "programs_ov": {
"state": { "state": {
"bakery": "Pasta en bakkersproducten", "bakery": "Pasta en bakkersproducten",
"bakery_steam": "Stoomgebakken brood", "bakery_steam": "Oven stomen",
"bottom_heating": "Bodemverwarming", "bottom_heating": "Bodemverwarming",
"bottom_heating_fan": "Bodemverwarming + Ventilator", "bottom_heating_fan": "Bodemverwarming + Ventilator",
"bread": "Brood", "bread": "Brood",
"bread_steam": "Stoomgebakken pasteien", "bread_steam": "Stoomgebakken brood",
"combi": "Combi",
"convection_fan": "Met ventilator", "convection_fan": "Met ventilator",
"convection_fan_turnspit": "Convectie + ventilator + draaispit", "convection_fan_turnspit": "Convectie + ventilator + draaispit",
"conventional": "Conventioneel", "conventional": "Conventioneel",
@ -286,13 +493,13 @@
"iot_h20_clean": "h2O clean", "iot_h20_clean": "h2O clean",
"leavening": "Gisting", "leavening": "Gisting",
"low_temp_cooking": "Bereiding op lage temperatuur", "low_temp_cooking": "Bereiding op lage temperatuur",
"low_temp_cooking_fish": "Bereiding op lage temperatuur \u2013 Vis", "low_temp_cooking_fish": "Bereiding op lage temperatuur Vis",
"low_temp_cooking_fish_steam": "Stomen bij lage temperatuur \u2013 Vis", "low_temp_cooking_fish_steam": "Bereiding op lage temperatuur Gestoomde vis",
"low_temp_cooking_meat": "Bereiding op lage temperatuur \u2013 Vlees", "low_temp_cooking_meat": "Bereiding op lage temperatuur Vlees",
"low_temp_cooking_meat_steam": "Stomen bij lage temperatuur \u2013 Vlees", "low_temp_cooking_meat_steam": "Bereiding op lage temperatuur Gestoomd vlees",
"low_temp_cooking_steam": "Stomen bij lage temperatuur", "low_temp_cooking_steam": "Stomen bij lage temperatuur",
"meat": "Vlees", "meat": "Vlees",
"meat_steam": "Gestoomd vlees", "meat_steam": "Vlees stomen",
"multi_level": "Multi-level", "multi_level": "Multi-level",
"paella": "Paella", "paella": "Paella",
"pasta_and_bakery": "Pasta en bakkersproducten", "pasta_and_bakery": "Pasta en bakkersproducten",
@ -301,17 +508,16 @@
"pyrolysis_plus": "Pyrolyse +", "pyrolysis_plus": "Pyrolyse +",
"red_meat": "Rood vlees", "red_meat": "Rood vlees",
"red_meat_steam": "Gestoomd rood vlees", "red_meat_steam": "Gestoomd rood vlees",
"regenerate": "Regeneratie", "regenerate": "Regenereren",
"soft_plus": "Soft+", "soft_plus": "Soft+",
"super_grill": "Super grill", "super_grill": "Super grill",
"tailor_bake": "Tailor bake", "tailor_bake": "Tailor bake",
"tailor_bake_cata": "Tailor Bake", "tailor_bake_cata": "Tailor Bake",
"tailor_bake_desctiption": "Deze functie is ideaal om voedsel zacht van binnen te houden en knapperig van buiten.\r\r\r\r\r\r\r\r\r\r\r\r\nDeze functie vermindert de benodigde hoeveelheid vet of olie, voor een gezonde bereiding.\r\r\r\r\r\r\r\r\r\r\r\r\nDe combinatie van verwarmingselementen met een pulserende luchtcyclus\r\r\r\r\r\r\r\r\r\r\r\r\nzorgt voor gelijkmatige bereidingsresultaten.",
"tailor_bake_pyro": "Tailor Bake", "tailor_bake_pyro": "Tailor Bake",
"vegetables": "Groenten", "vegetables": "Groenten",
"vegetables_cata": "Groenten", "vegetables_cata": "Groenten",
"vegetables_pyro": "Groenten", "vegetables_pyro": "Groenten",
"water_discharge": "Waterafvoer", "water_discharge": "Afvoer van water",
"white_meat": "Wit vlees", "white_meat": "Wit vlees",
"white_meat_steam": "Gestoomd wit vlees" "white_meat_steam": "Gestoomd wit vlees"
}, },
@ -349,7 +555,7 @@
"hqd_bed_sheets": "Beddengoed", "hqd_bed_sheets": "Beddengoed",
"hqd_bulky": "Grote artikelen", "hqd_bulky": "Grote artikelen",
"hqd_casual": "Casual", "hqd_casual": "Casual",
"hqd_cold_wind_30": "30\u00a0minuten koel briesje", "hqd_cold_wind_30": "30 minuten koel briesje",
"hqd_cold_wind_timing": "Koel briesje ", "hqd_cold_wind_timing": "Koel briesje ",
"hqd_cotton": "Katoen", "hqd_cotton": "Katoen",
"hqd_curtain": "Gordijnen", "hqd_curtain": "Gordijnen",
@ -370,7 +576,7 @@
"hqd_precious_cure": "Precious cure", "hqd_precious_cure": "Precious cure",
"hqd_quick_20": "Quick 20", "hqd_quick_20": "Quick 20",
"hqd_quick_30": "Quick 30", "hqd_quick_30": "Quick 30",
"hqd_quick_dry": "Quick dry", "hqd_quick_dry": "Quick dry 30",
"hqd_quilt": "Quilts", "hqd_quilt": "Quilts",
"hqd_refresh": "Opfrissen", "hqd_refresh": "Opfrissen",
"hqd_school_uniform": "Schooluniform", "hqd_school_uniform": "Schooluniform",
@ -385,7 +591,7 @@
"hqd_warm_up": "Opwarmen", "hqd_warm_up": "Opwarmen",
"hqd_wool": "Wol", "hqd_wool": "Wol",
"hqd_working_suit": "Werkkleding", "hqd_working_suit": "Werkkleding",
"hygiene": "Hygi\u00ebne", "hygiene": "Hygiëne",
"iot_checkup": "Controle", "iot_checkup": "Controle",
"iot_dry_anti_mites": "Anti-mijten", "iot_dry_anti_mites": "Anti-mijten",
"iot_dry_baby": "Baby", "iot_dry_baby": "Baby",
@ -399,7 +605,7 @@
"iot_dry_dehumidifier": "Vochtigheidsverwijderaar", "iot_dry_dehumidifier": "Vochtigheidsverwijderaar",
"iot_dry_delicates": "Delicate was", "iot_dry_delicates": "Delicate was",
"iot_dry_delicate_tablecloths": "Delicate tafelkleden", "iot_dry_delicate_tablecloths": "Delicate tafelkleden",
"iot_dry_denim_jeans": "Denim \u2013 Jeans", "iot_dry_denim_jeans": "Denim Jeans",
"iot_dry_down_jacket": "Jacket", "iot_dry_down_jacket": "Jacket",
"iot_dry_duvet": "Dekbed", "iot_dry_duvet": "Dekbed",
"iot_dry_easy_iron_cotton": "Super Gemakkelijk strijken", "iot_dry_easy_iron_cotton": "Super Gemakkelijk strijken",
@ -444,31 +650,31 @@
"synthetics": "Synthetisch", "synthetics": "Synthetisch",
"total_care": "Total Care", "total_care": "Total Care",
"trainers": "Trainers", "trainers": "Trainers",
"ultra_care": "Ultra\u00a0Care", "ultra_care": "Ultra Care",
"waterproof_revitalize": "Waterproof Revitaliseren", "waterproof_revitalize": "Waterproof Revitaliseren",
"whites": "Witte was", "whites": "Witte was",
"wool": "Droge Wol", "wool": "Droge Wol",
"woolmark": "Wol", "woolmark": "Wol",
"xxl_load": "XXL Lading", "xxl_load": "XXL Lading",
"zoom_59": "Zoom\u00a059" "zoom_59": "Zoom 59"
}, },
"name": "Programma" "name": "Programma"
}, },
"programs_wm": { "programs_wm": {
"state": { "state": {
"20_degrees_coloured_cottons": "20\u00b0 gekleurd en katoen", "20_degrees_coloured_cottons": "20° gekleurd en katoen",
"20_degrees_new_energy_label": "20 \u00b0C", "20_degrees_new_energy_label": "20 °C",
"active_steam": "Stoom", "active_steam": "Stoom",
"active_wash": "Actieve was", "active_wash": "Actieve was",
"active_wash_steam": "Actieve was", "active_wash_steam": "Actieve was",
"allergy_care": "Allergiezorg", "allergy_care": "Allergiezorg",
"allergy_care_pro": "Allergy Care Pro", "allergy_care_pro": "Allergy Care Pro",
"all_in_one_49": "Alles-in-\u00e9\u00e9n 49'.", "all_in_one_49": "Alles-in-één 49'.",
"all_in_one_59": "Alles-in-\u00e9\u00e9n 59'.", "all_in_one_59": "Alles-in-één 59'.",
"all_in_one_59_steam": "Actieve was + Stoom", "all_in_one_59_steam": "Actieve was + Stoom",
"autocare": "Automatische verzorging", "autocare": "Automatische verzorging",
"autoclean": "Trommelreiniging", "autoclean": "Trommelreiniging",
"baby_60": "All baby 60 \u00b0 C", "baby_60": "All baby 60 ° C",
"care_14": "Rapid care 14'", "care_14": "Rapid care 14'",
"care_30": "Rapid care 30'", "care_30": "Rapid care 30'",
"care_44": "Rapid Care 44'", "care_44": "Rapid Care 44'",
@ -494,7 +700,7 @@
"fresh_care_steam": "Fresh Care + Stoom", "fresh_care_steam": "Fresh Care + Stoom",
"handwash_wool": "Handwas en wol", "handwash_wool": "Handwas en wol",
"high_dry": "Katoen drogen", "high_dry": "Katoen drogen",
"hqd_20_degrees": "Katoen 20\u2103", "hqd_20_degrees": "Katoen 20",
"hqd_allergy": "Allergiezorg", "hqd_allergy": "Allergiezorg",
"hqd_autoclean": "Het reinigen van de trommel", "hqd_autoclean": "Het reinigen van de trommel",
"hqd_babycare": "Baby Care", "hqd_babycare": "Baby Care",
@ -510,7 +716,7 @@
"hqd_i_refresh": "i-Refresh", "hqd_i_refresh": "i-Refresh",
"hqd_mix": "Gemengde was", "hqd_mix": "Gemengde was",
"hqd_quick_15": "Snel 15'", "hqd_quick_15": "Snel 15'",
"hqd_quick_wash_57": "Snel wassen 57\u00a0min", "hqd_quick_wash_57": "Snel wassen 57 min",
"hqd_rapid_wash_and_dry": "Wassen en drogen", "hqd_rapid_wash_and_dry": "Wassen en drogen",
"hqd_refresh": "Opfrissen", "hqd_refresh": "Opfrissen",
"hqd_rinse": "Spoelen", "hqd_rinse": "Spoelen",
@ -521,13 +727,13 @@
"hqd_super_fast": "Snel 39'", "hqd_super_fast": "Snel 39'",
"hqd_synthetic_and_coloured": "Synthetische stoffen", "hqd_synthetic_and_coloured": "Synthetische stoffen",
"hygiene_59": "Hygiene Plus 59'", "hygiene_59": "Hygiene Plus 59'",
"hygiene_60": "Hygi\u00ebne 60 \u00b0C", "hygiene_60": "Hygiëne 60 °C",
"hygiene_plus_59": "Hygiene Plus 59'", "hygiene_plus_59": "Hygiene Plus 59'",
"hygiene_plus_59_min": "Hygiene Plus 59'", "hygiene_plus_59_min": "Hygiene Plus 59'",
"hygiene_pro_49_min": "Hygiene Pro 49 min", "hygiene_pro_49_min": "Hygiene Pro 49 min",
"hygiene_pro_steam": "Hygiene Pro + stoom", "hygiene_pro_steam": "Hygiene Pro + stoom",
"intensive_40": "Intensief 40\u00b0C", "intensive_40": "Intensief 40°C",
"intensive_40_steam": "Intensief 40\u00b0C + Stoom", "intensive_40_steam": "Intensief 40°C + Stoom",
"iot_active_steam": "Stoom", "iot_active_steam": "Stoom",
"iot_active_wash_steam": "Actieve was", "iot_active_wash_steam": "Actieve was",
"iot_allergy_care_pro": "Allergy Care Pro", "iot_allergy_care_pro": "Allergy Care Pro",
@ -547,15 +753,15 @@
"iot_dry_cuddly_toys": "Knuffeldieren", "iot_dry_cuddly_toys": "Knuffeldieren",
"iot_dry_curtains": "Gordijnen", "iot_dry_curtains": "Gordijnen",
"iot_dry_dehumidifier": "Vochtigheidsverwijderaar", "iot_dry_dehumidifier": "Vochtigheidsverwijderaar",
"iot_dry_delicates_antiallergy": "Fijne was \u2013 anti-allergie", "iot_dry_delicates_antiallergy": "Fijne was anti-allergie",
"iot_dry_delicate_tablecloths": "Delicate tafellakens", "iot_dry_delicate_tablecloths": "Delicate tafellakens",
"iot_dry_denim_jeans": "Denim \u2013 Jeans", "iot_dry_denim_jeans": "Denim Jeans",
"iot_dry_easy_iron_cotton": "Gemakkelijk strijken \u2013 Katoen", "iot_dry_easy_iron_cotton": "Gemakkelijk strijken Katoen",
"iot_dry_easy_iron_synthetics": "Gemakkelijk strijken \u2013 Synthetische stoffen", "iot_dry_easy_iron_synthetics": "Gemakkelijk strijken Synthetische stoffen",
"iot_dry_gym_fit": "Sportkleding", "iot_dry_gym_fit": "Sportkleding",
"iot_dry_lingerie": "Lingerie", "iot_dry_lingerie": "Lingerie",
"iot_dry_mixed_dry": "Gemengde vezels drogen", "iot_dry_mixed_dry": "Gemengde vezels drogen",
"iot_dry_rapid_60_min_delicates": "Snel 60' \u2013 Fijne was", "iot_dry_rapid_60_min_delicates": "Snel 60' Fijne was",
"iot_dry_shirts": "Overhemden", "iot_dry_shirts": "Overhemden",
"iot_dry_swimsuits_and_bikinis": "Badkleding", "iot_dry_swimsuits_and_bikinis": "Badkleding",
"iot_dry_synthetics": "Synthetische stoffen drogen", "iot_dry_synthetics": "Synthetische stoffen drogen",
@ -567,18 +773,18 @@
"iot_easy_iron": "Makkelijk Strijkbaar", "iot_easy_iron": "Makkelijk Strijkbaar",
"iot_fresh_care_steam": "Fresh Care + Stoom", "iot_fresh_care_steam": "Fresh Care + Stoom",
"iot_hygiene_pro_steam": "Hygiene Pro + stoom", "iot_hygiene_pro_steam": "Hygiene Pro + stoom",
"iot_intensive_40_steam": "Intensief 40\u00b0C + Stoom", "iot_intensive_40_steam": "Intensief 40°C + Stoom",
"iot_mixed_steam": "Gemengde vezels + Stoom", "iot_mixed_steam": "Gemengde vezels + Stoom",
"iot_mix_and_colour_59_steam": "Gemengd en Gekleurd 59' + Stoom", "iot_mix_and_colour_59_steam": "Gemengd en Gekleurd 59' + Stoom",
"iot_perfect_cotton_59_steam": "Perfecte Katoen 59'", "iot_perfect_cotton_59_steam": "Perfecte Katoen 59'",
"iot_rapid_a_class_60_steam": "Snel klasse A 60 + Stoom", "iot_rapid_a_class_60_steam": "Snel klasse A 60 + Stoom",
"iot_resistant_cotton_steam": "Katoen + Stoom", "iot_resistant_cotton_steam": "Katoen + Stoom",
"iot_shirts_steam": "Shirts + stoom", "iot_shirts_steam": "Shirts + stoom",
"iot_single_item_steam": "E\u00e9n artikel + Stoom", "iot_single_item_steam": "Eén artikel + Stoom",
"iot_smart_wash": "Smart Wash", "iot_smart_wash": "Smart Wash",
"iot_soft_care_steam": "Soft Care + Steam", "iot_soft_care_steam": "Soft Care + Steam",
"iot_special_39_full_load_steam": "Speciaal 39' + Stoom", "iot_special_39_full_load_steam": "Speciaal 39' + Stoom",
"iot_steam_hygiene_plus": "Hygi\u00ebne Plus Stoom ", "iot_steam_hygiene_plus": "Hygiëne Plus Stoom ",
"iot_synthetic_and_coloured_steam": "Synthetisch en gekleurd + Stoom", "iot_synthetic_and_coloured_steam": "Synthetisch en gekleurd + Stoom",
"iot_wash_and_dry": "Wassen en drogen", "iot_wash_and_dry": "Wassen en drogen",
"iot_wash_anti_mites": "Antimijt", "iot_wash_anti_mites": "Antimijt",
@ -638,7 +844,7 @@
"iot_wash_delicate_tablecloths": "Delicate tafellakens", "iot_wash_delicate_tablecloths": "Delicate tafellakens",
"iot_wash_delicate_tablecloths_steam": "Delicate tafellakens + Stoom", "iot_wash_delicate_tablecloths_steam": "Delicate tafellakens + Stoom",
"iot_wash_delicate_whites": "Witte fijne was", "iot_wash_delicate_whites": "Witte fijne was",
"iot_wash_denim_jeans": "Denim \u2013 Jeans", "iot_wash_denim_jeans": "Denim Jeans",
"iot_wash_diving_suits": "Duikpakken", "iot_wash_diving_suits": "Duikpakken",
"iot_wash_diving_suits_zelig": "Duikpakken", "iot_wash_diving_suits_zelig": "Duikpakken",
"iot_wash_down_jackets": "Donsjassen", "iot_wash_down_jackets": "Donsjassen",
@ -731,8 +937,8 @@
"rinse": "Spoelen", "rinse": "Spoelen",
"shirts_steam": "Shirts + stoom", "shirts_steam": "Shirts + stoom",
"silent_night": "Nachtprogramma", "silent_night": "Nachtprogramma",
"single_item": "E\u00e9n artikel", "single_item": "Eén artikel",
"single_item_steam": "E\u00e9n artikel + Stoom", "single_item_steam": "Eén artikel + Stoom",
"smart_wash": "Smart Wash", "smart_wash": "Smart Wash",
"soft_care": "Zachte verzorging", "soft_care": "Zachte verzorging",
"soft_care_steam": "Soft Care + Steam", "soft_care_steam": "Soft Care + Steam",
@ -749,7 +955,7 @@
"steam_care_pro_cotton": "Steam Care Pro - Katoen", "steam_care_pro_cotton": "Steam Care Pro - Katoen",
"steam_care_pro_delicates": "Steam Care Pro - Fijne was", "steam_care_pro_delicates": "Steam Care Pro - Fijne was",
"steam_care_pro_synthetic": "Steam Care Pro - Synthetisch", "steam_care_pro_synthetic": "Steam Care Pro - Synthetisch",
"steam_hygiene_plus": "Hygi\u00ebne Plus Stoom ", "steam_hygiene_plus": "Hygiëne Plus Stoom ",
"synthetics": "Synthetische stoffen", "synthetics": "Synthetische stoffen",
"synthetic_and_coloured": "Synthetische vezels en kleuren", "synthetic_and_coloured": "Synthetische vezels en kleuren",
"synthetic_and_coloured_steam": "Synthetisch en gekleurd + Stoom", "synthetic_and_coloured_steam": "Synthetisch en gekleurd + Stoom",
@ -774,15 +980,91 @@
"12": "Strijken", "12": "Strijken",
"13": "Kastdroog", "13": "Kastdroog",
"14": "Klaar om te dragen", "14": "Klaar om te dragen",
"15": "Extra droog" "15": "Extra droog",
"11": "Niet drogen"
}, },
"name": "Drogen" "name": "Droogniveau"
}, },
"spin_speed": { "spin_speed": {
"name": "Centrifugeren" "name": "Centrifugeren"
}, },
"temperature": { "temperature": {
"name": "Temperatuur" "name": "Temperatuur"
},
"dry_time": {
"name": "Droogtijd"
},
"eco_pilot": {
"state": {
"0": "Uit",
"1": "Voorkom aanraking",
"2": "Volgen"
},
"name": "Eco pilot"
},
"fan_mode": {
"state": {
"1": "Hoog",
"2": "Gemiddeld ",
"3": "Laag",
"4": "Automatisch",
"5": "Automatisch"
}
},
"programs_ac": {
"state": {
"iot_10_heating": "10°C-verwarmingsfunctie",
"iot_auto": "Automatisch",
"iot_cool": "Koelen",
"iot_dry": "Drogen",
"iot_fan": "Ventilator",
"iot_heat": "Verwarming",
"iot_nano_aqua": "Nano Aqua",
"iot_purify": "Zelfzuivering",
"iot_self_clean": "Zelfreiniging",
"iot_self_clean_56": "Sterilisatie reiniging 56°C",
"iot_simple_start": "Start nu",
"iot_uv": "UV",
"iot_uv_and_auto": "UV + Auto",
"iot_uv_and_cool": "UV + Koud",
"iot_uv_and_dry": "UV + Ontvochtiger",
"iot_uv_and_fan": "UV + Hetelucht",
"iot_uv_and_heat": "UV + Warmte"
}
},
"programs_ref": {
"state": {
"auto_set": "AUTO-SET",
"cheese": "Kaas",
"chiller": "Quick cool",
"cold_drinks": "Soft chill",
"eco": "Eco",
"eco_mode": "Eco-modus",
"fruits_and_veg": "Fruit&Veg",
"fruit_and_veg": "Fruit & Veg",
"holiday": "HOLIDAY",
"keep_fresh": "0° Fresh",
"no_mode_selected": "Geen modus geselecteerd",
"quick_cool": "QUICK KOEL",
"sea_food": "Ready to cook meal",
"soft_frozen": "Soft freezing",
"super_cool": "SUPER COOL",
"super_freeze": "SUPER FREEZE",
"tea": "Cold drinks or Beverages",
"zero_fresh": "0° Fresh"
}
},
"remaining_time": {
"name": "Resterende tijd"
},
"ref_zones": {
"state": {
"fridge": "Koelkast",
"freezer": "Vriezer",
"vtroom1": "My Zone",
"fridge_freezer": "Koelkast & Vriezer"
},
"name": "Zone"
} }
}, },
"switch": { "switch": {
@ -790,7 +1072,7 @@
"name": "Kreukherstellend" "name": "Kreukherstellend"
}, },
"add_dish": { "add_dish": {
"name": "" "name": "Vaatwerk toevoegen"
}, },
"eco_express": { "eco_express": {
"name": "Eco" "name": "Eco"
@ -830,6 +1112,69 @@
}, },
"pause": { "pause": {
"name": "Pauze" "name": "Pauze"
},
"keep_fresh": {
"name": "Keep Fresh"
},
"delay_time": {
"name": "Vertraag Start"
},
"rapid_mode": {
"name": "Snelle modus"
},
"eco_mode": {
"name": "ECO-modus"
},
"10_degree_heating": {
"name": "10°C-verwarmingsfunctie"
},
"self_clean": {
"name": "Zelfreiniging"
},
"self_clean_56": {
"name": "Sterilisatie reiniging 56°C"
},
"silent_mode": {
"name": "Stille modus"
},
"mute_mode": {
"name": "Dempmodus"
},
"extra_rinse_1": {
"name": "+1 keer spoelen"
},
"extra_rinse_2": {
"name": "+2 keer spoelen"
},
"extra_rinse_3": {
"name": "+3 keer spoelen"
},
"acqua_plus": {
"name": "Acquaplus"
},
"auto_dose": {
"name": "Automatisch doseren"
},
"good_night": {
"name": "Goede nacht"
},
"auto_dose_softener": {
"name": "Automatisch doseren Wasverzachter"
},
"auto_dose_detergent": {
"name": "Automatisch doseren Wasmiddel"
},
"auto_set": {
"name": "Automatisch instellen"
},
"super_cool": {
"name": "Super Cool"
},
"super_freeze": {
"name": "Super Freeze"
},
"refrigerator": {
"name": "Koelkast"
} }
}, },
"binary_sensor": { "binary_sensor": {
@ -891,7 +1236,46 @@
"name": "Deur open" "name": "Deur open"
}, },
"connection": { "connection": {
"name": "Verbinding" "name": "Het apparaat verbinden"
},
"child_lock": {
"name": "Kinderslot"
},
"on": {
"name": "Aan"
},
"prewash": {
"name": "Voorwas"
},
"acqua_plus": {
"name": "Acquaplus"
},
"auto_dose": {
"name": "Automatisch doseren"
},
"buzzer": {
"name": "Bel voor einde cyclus"
},
"holiday_mode": {
"name": "Holiday-modus (Vakantie)"
},
"auto_set": {
"name": "Automatisch instellen"
},
"super_cool": {
"name": "Super Cool"
},
"super_freeze": {
"name": "Super Freeze"
},
"freezer_door": {
"name": "Deur open Vriezer"
},
"fridge_door": {
"name": "Deur open Koelkast"
},
"filter_replacement": {
"name": "Filter vervangen"
} }
}, },
"number": { "number": {
@ -902,7 +1286,7 @@
"name": "Temperatuur" "name": "Temperatuur"
}, },
"delay_time": { "delay_time": {
"name": "Plannen" "name": "Vertraag Start"
}, },
"water_hard": { "water_hard": {
"name": "Waterhardheid" "name": "Waterhardheid"
@ -918,11 +1302,133 @@
}, },
"wash_time": { "wash_time": {
"name": "Wastijd" "name": "Wastijd"
},
"dry_time": {
"name": "Droogtijd"
},
"steam_level": {
"name": "Stoomniveau"
},
"freezer_temp_sel": {
"name": "Doeltemperatuur Vriezer"
},
"fridge_temp_sel": {
"name": "Doeltemperatuur Koelkast"
} }
}, },
"button": { "button": {
"induction_hob": { "induction_hob": {
"name": "Inductiekookplaat" "name": "Inductiekookplaat"
},
"start_program": {
"name": "Programma Start"
},
"stop_program": {
"name": "Programma Stoppen"
}
},
"climate": {
"air_conditioner": {
"name": "Airconditioner"
},
"fridge": {
"name": "Koelkast",
"state_attributes": {
"preset_mode": {
"name": "Koelkastmodi",
"state": {
"auto_set": "Automatisch instellen",
"super_cool": "Super Cool",
"holiday": "Holiday",
"no_mode": "Geen modus geselecteerd"
}
}
}
},
"freezer": {
"name": "Vriezer",
"state_attributes": {
"preset_mode": {
"name": "Vriezermodi",
"state": {
"auto_set": "Automatisch instellen",
"super_freeze": "Super Freeze",
"no_mode": "Geen modus geselecteerd"
}
}
}
},
"oven": {
"name": "Oven",
"state_attributes": {
"preset_mode": {
"name": "Programma's",
"state": {
"bakery": "Pasta en bakkersproducten",
"bakery_steam": "Oven stomen",
"bottom_heating": "Bodemverwarming",
"bottom_heating_fan": "Bodemverwarming + Ventilator",
"bread": "Brood",
"bread_steam": "Stoomgebakken brood",
"combi": "Combi",
"convection_fan": "Met ventilator",
"convection_fan_turnspit": "Convectie + ventilator + draaispit",
"conventional": "Conventioneel",
"conventional_turnspit": "Convectie + draaispit",
"defrost": "Ontdooien",
"descaling": "Ontkalken",
"fish": "Vis",
"fish_steam": "Gestoomde vis",
"grill_cata": "Grill",
"grill_fan_cata": "Grill + ventilator",
"grill_fan_pyro": "Grill + ventilator",
"grill_pyro": "Grill",
"h20_clean": "H2O-Clean",
"iot_bread": "Brood",
"iot_h20_clean": "h2O clean",
"leavening": "Gisting",
"low_temp_cooking": "Bereiding op lage temperatuur",
"low_temp_cooking_fish": "Bereiding op lage temperatuur Vis",
"low_temp_cooking_fish_steam": "Bereiding op lage temperatuur Gestoomde vis",
"low_temp_cooking_meat": "Bereiding op lage temperatuur Vlees",
"low_temp_cooking_meat_steam": "Bereiding op lage temperatuur Gestoomd vlees",
"low_temp_cooking_steam": "Stomen bij lage temperatuur",
"meat": "Vlees",
"meat_steam": "Vlees stomen",
"multi_level": "Multi-level",
"paella": "Paella",
"pasta_and_bakery": "Pasta en bakkersproducten",
"pizza": "Pizza",
"pyrolysis": "Pyrolyse",
"pyrolysis_plus": "Pyrolyse +",
"red_meat": "Rood vlees",
"red_meat_steam": "Gestoomd rood vlees",
"regenerate": "Regenereren",
"soft_plus": "Soft+",
"super_grill": "Super grill",
"tailor_bake": "Tailor bake",
"tailor_bake_cata": "Tailor Bake",
"tailor_bake_pyro": "Tailor Bake",
"vegetables": "Groenten",
"vegetables_cata": "Groenten",
"vegetables_pyro": "Groenten",
"water_discharge": "Afvoer van water",
"white_meat": "Wit vlees",
"white_meat_steam": "Gestoomd wit vlees"
}
}
}
}
}
},
"config": {
"step": {
"user": {
"description": "Log in",
"data": {
"email": "E-mail",
"password": "Wachtwoord"
}
} }
} }
} }

File diff suppressed because it is too large Load Diff

File diff suppressed because it is too large Load Diff

File diff suppressed because it is too large Load Diff

File diff suppressed because it is too large Load Diff

File diff suppressed because it is too large Load Diff

File diff suppressed because it is too large Load Diff

File diff suppressed because it is too large Load Diff

File diff suppressed because it is too large Load Diff

File diff suppressed because it is too large Load Diff

54
info.md
View File

@ -11,12 +11,8 @@ Support for home appliances of Haier's mobile app hOn.
- [Oven](https://github.com/Andre0512/hon#oven) - [Oven](https://github.com/Andre0512/hon#oven)
- [Hob](https://github.com/Andre0512/hon#hob) - [Hob](https://github.com/Andre0512/hon#hob)
- [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) [BETA]
## Tested Appliances - [Fridge](https://github.com/Andre0512/hon#fridge) [BETA]
- Haier WD90-B14TEAM5
- Haier HD80-A3959
- Haier HWO60SM2F3XH
- Hoover H-WASH 500
## Configuration ## Configuration
@ -25,10 +21,6 @@ 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._
## Contribute
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!
## 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
@ -51,10 +43,50 @@ Translation of internal names like programs are available for all languages whic
* 🇪🇸 Spanish * 🇪🇸 Spanish
* 🇹🇷 Turkish * 🇹🇷 Turkish
## Examples
### Washing Machine
![washing_machine.png](assets/washing_machine.png)
## Supported Models
Support has been confirmed for these models, but many more will work. Please add already supported devices [with this form to complete the list](https://forms.gle/bTSD8qFotdZFytbf8).
- Haier AD105S2SM3FA
- Haier AS25PBAHRA
- Haier AS25TADHRA-2
- Haier AS35TADHRA-2
- Haier EG9012B19SU1JD
- Haier HD80-A3959
- Haier HW90-B14TEAM5
- Haier HW100-B14959U1
- Haier HWD100-B14979
- Haier HWO60SM2F3XH
- Haier XIB 3B2SFS-80
- Haier XIB 6B2D3FB
- Candy BCTDH7A1TE
- Candy CIS633SCTTWIFI
- Candy CSOE C10DE-80
- 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
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!
## Useful Links ## Useful Links
* [GitHub repository](https://github.com/Andre0512/hon) (please add a star if you like this integration!) * [GitHub repository](https://github.com/Andre0512/hon) (please add a star if you like this integration!)
* [pyhOn library](https://github.com/Andre0512/pyhOn) * [pyhOn library](https://github.com/Andre0512/pyhOn)
* [Release notes](https://github.com/Andre0512/hon/releases) * [Release notes](https://github.com/Andre0512/hon/releases)
* [Discussion and help](https://github.com/Andre0512/hon/discussions) * [Discussion and help](https://github.com/Andre0512/hon/discussions)
* [Issues](https://github.com/Andre0512/hon/issues) * [Issues](https://github.com/Andre0512/hon/issues)

3
requirements_dev.txt Normal file
View File

@ -0,0 +1,3 @@
pyhOn
black
homeassistant

View File

@ -3,125 +3,81 @@
import asyncio import asyncio
import json import json
import re import re
import sys
from pathlib import Path from pathlib import Path
from pyhon import HonAPI from pyhon import HonAPI
# These languages are official supported by hOn if __name__ == "__main__":
LANGUAGES = [ sys.path.insert(0, str(Path(__file__).parent.parent))
"cs", # Czech
"de", # German
"el", # Greek
"en", # English
"es", # Spanish
"fr", # French
"he", # Hebrew
"hr", # Croatian
"it", # Italian
"nl", # Dutch
"pl", # Polish
"pt", # Portuguese
"ro", # Romanian
"ru", # Russian
"sk", # Slovak
"sl", # Slovenian
"sr", # Serbian
"tr", # Turkish
"zh", # Chinese
]
WASHING_PR_PHASE = { from custom_components.hon import const
0: "WASHING_CMD&CTRL.PHASE_READY.TITLE",
1: "WASHING_CMD&CTRL.PHASE_WASHING.TITLE",
2: "WASHING_CMD&CTRL.PHASE_WASHING.TITLE",
3: "WASHING_CMD&CTRL.PHASE_SPIN.TITLE",
4: "WASHING_CMD&CTRL.PHASE_RINSE.TITLE",
5: "WASHING_CMD&CTRL.PHASE_RINSE.TITLE",
6: "WASHING_CMD&CTRL.PHASE_RINSE.TITLE",
7: "WASHING_CMD&CTRL.PHASE_DRYING.TITLE",
9: "WASHING_CMD&CTRL.PHASE_STEAM.TITLE",
10: "WASHING_CMD&CTRL.PHASE_READY.TITLE",
11: "WASHING_CMD&CTRL.PHASE_SPIN.TITLE",
12: "WASHING_CMD&CTRL.PHASE_WEIGHTING.TITLE",
13: "WASHING_CMD&CTRL.PHASE_WEIGHTING.TITLE",
14: "WASHING_CMD&CTRL.PHASE_WASHING.TITLE",
15: "WASHING_CMD&CTRL.PHASE_WASHING.TITLE",
16: "WASHING_CMD&CTRL.PHASE_WASHING.TITLE",
17: "WASHING_CMD&CTRL.PHASE_RINSE.TITLE",
18: "WASHING_CMD&CTRL.PHASE_RINSE.TITLE",
19: "WASHING_CMD&CTRL.PHASE_SCHEDULED.TITLE",
20: "WASHING_CMD&CTRL.PHASE_TUMBLING.TITLE",
24: "WASHING_CMD&CTRL.PHASE_REFRESH.TITLE",
25: "WASHING_CMD&CTRL.PHASE_WASHING.TITLE",
26: "WASHING_CMD&CTRL.PHASE_HEATING.TITLE",
27: "WASHING_CMD&CTRL.PHASE_WASHING.TITLE",
}
MACH_MODE = {
0: "WASHING_CMD&CTRL.PHASE_READY.TITLE",
1: "WASHING_CMD&CTRL.PHASE_READY.TITLE",
3: "WASHING_CMD&CTRL.PHASE_PAUSE.TITLE",
4: "WASHING_CMD&CTRL.PHASE_SCHEDULED.TITLE",
5: "WASHING_CMD&CTRL.PHASE_SCHEDULED.TITLE",
6: "WASHING_CMD&CTRL.PHASE_ERROR.TITLE",
7: "WASHING_CMD&CTRL.PHASE_READY.TITLE",
}
TUMBLE_DRYER_PR_PHASE = {
0: "WASHING_CMD&CTRL.PHASE_READY.TITLE",
1: "TD_CMD&CTRL.STATUS_PHASE.PHASE_HEAT_STROKE",
2: "WASHING_CMD&CTRL.PHASE_DRYING.TITLE",
3: "TD_CMD&CTRL.STATUS_PHASE.PHASE_COOLDOWN",
13: "TD_CMD&CTRL.STATUS_PHASE.PHASE_COOLDOWN",
14: "TD_CMD&CTRL.STATUS_PHASE.PHASE_HEAT_STROKE",
15: "TD_CMD&CTRL.STATUS_PHASE.PHASE_HEAT_STROKE",
16: "TD_CMD&CTRL.STATUS_PHASE.PHASE_COOLDOWN",
18: "WASHING_CMD&CTRL.PHASE_TUMBLING.DASHBOARD_TITLE",
19: "WASHING_CMD&CTRL.PHASE_DRYING.TITLE",
20: "WASHING_CMD&CTRL.PHASE_DRYING.TITLE",
}
DISHWASHER_PR_PHASE = {
0: "WASHING_CMD&CTRL.PHASE_READY.TITLE",
1: "WASHING_CMD&CTRL.PHASE_PREWASH.TITLE",
2: "WASHING_CMD&CTRL.PHASE_WASHING.TITLE",
3: "WASHING_CMD&CTRL.PHASE_RINSE.TITLE",
4: "WASHING_CMD&CTRL.PHASE_DRYING.TITLE",
5: "WASHING_CMD&CTRL.PHASE_READY.TITLE",
6: "WASHING_CMD&CTRL.PHASE_HOT_RINSE.TITLE",
}
TUMBLE_DRYER_DRY_LEVEL = {
0: "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_MAIN_OPTIONS.NO_DRY",
1: "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OPTIONS_VALUES_DESCRIPTION.IRON_DRY",
2: "WASHING_CMD&CTRL.GUIDED_WASHING_SYMBOLS_DRYING.NO_DRY_IRON_TITLE",
3: "WASHING_CMD&CTRL.GUIDED_WASHING_SYMBOLS_DRYING.CUPBOARD_DRY_TITLE",
4: "WASHING_CMD&CTRL.GUIDED_WASHING_SYMBOLS_DRYING.EXTRA_DRY_TITLE",
12: "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OPTIONS_VALUES_DESCRIPTION.IRON_DRY",
13: "WASHING_CMD&CTRL.GUIDED_WASHING_SYMBOLS_DRYING.CUPBOARD_DRY_TITLE",
14: "WASHING_CMD&CTRL.GUIDED_WASHING_SYMBOLS_DRYING.READY_TO_WEAR_TITLE",
15: "WASHING_CMD&CTRL.GUIDED_WASHING_SYMBOLS_DRYING.EXTRA_DRY_TITLE",
}
SENSOR = { SENSOR = {
"washing_modes": MACH_MODE, "washing_modes": const.MACH_MODE,
"program_phases_wm": WASHING_PR_PHASE, "mach_modes_ac": const.AC_MACH_MODE,
"program_phases_td": TUMBLE_DRYER_PR_PHASE, "program_phases_wm": const.WASHING_PR_PHASE,
"program_phases_dw": DISHWASHER_PR_PHASE, "program_phases_td": const.TUMBLE_DRYER_PR_PHASE,
"dry_levels": TUMBLE_DRYER_DRY_LEVEL, "program_phases_dw": const.DISHWASHER_PR_PHASE,
"dry_levels": const.TUMBLE_DRYER_DRY_LEVEL,
} }
SELECT = {"dry_levels": 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 = { PROGRAMS = {
"programs_dw": "PROGRAMS.DW", "select": {
"programs_ih": "PROGRAMS.IH", "programs_ac": "PROGRAMS.AC",
"programs_ov": "PROGRAMS.OV", "programs_dw": "PROGRAMS.DW",
"programs_td": "PROGRAMS.TD", "programs_ih": "PROGRAMS.IH",
"programs_wm": "PROGRAMS.WM_WD", "programs_ov": "PROGRAMS.OV",
"programs_td": "PROGRAMS.TD",
"programs_wm": "PROGRAMS.WM_WD",
"programs_ref": "PROGRAMS.REF",
},
"sensor": {
"programs_td": "PROGRAMS.TD",
},
}
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 = { NAMES = {
"switch": { "switch": {
"anti_crease": "HDRY_CMD&CTRL.PROGRAM_CYCLE_DETAIL.ANTICREASE_TITLE", "anti_crease": "HDRY_CMD&CTRL.PROGRAM_CYCLE_DETAIL.ANTICREASE_TITLE",
"add_dish": "DW_CMD&CTRL.c.ADD_DISH", "add_dish": "DW.ADD_DISH",
"eco_express": "DW_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OTHER_OPTIONS.ECO", "eco_express": "DW_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OTHER_OPTIONS.ECO",
"extra_dry": "DW_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OTHER_OPTIONS.EXTRA_DRY", "extra_dry": "DW_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OTHER_OPTIONS.EXTRA_DRY",
"half_load": "DW_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OTHER_OPTIONS.HALF_LOAD", "half_load": "DW_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OTHER_OPTIONS.HALF_LOAD",
@ -135,6 +91,32 @@ NAMES = {
"oven": "GLOBALS.APPLIANCES_NAME.OV", "oven": "GLOBALS.APPLIANCES_NAME.OV",
"prewash": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OTHER_OPTIONS.PREWASH", "prewash": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OTHER_OPTIONS.PREWASH",
"pause": "GENERAL.PAUSE_PROGRAM", "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": { "binary_sensor": {
"door_lock": "WASHING_CMD&CTRL.CHECK_UP_RESULTS.DOOR_LOCK", "door_lock": "WASHING_CMD&CTRL.CHECK_UP_RESULTS.DOOR_LOCK",
@ -143,7 +125,7 @@ NAMES = {
"extra_rinse_3": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OTHER_OPTIONS.EXTRARINSE3", "extra_rinse_3": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OTHER_OPTIONS.EXTRARINSE3",
"good_night": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OTHER_OPTIONS.GOODNIGHT", "good_night": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OTHER_OPTIONS.GOODNIGHT",
"anti_crease": "HDRY_CMD&CTRL.PROGRAM_CYCLE_DETAIL.ANTICREASE_TITLE", "anti_crease": "HDRY_CMD&CTRL.PROGRAM_CYCLE_DETAIL.ANTICREASE_TITLE",
"aqua_plus": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OTHER_OPTIONS.ACQUAPLUS", "acqua_plus": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OTHER_OPTIONS.ACQUAPLUS",
"spin_speed": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_MAIN_OPTIONS.SPINSPEED", "spin_speed": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_MAIN_OPTIONS.SPINSPEED",
"still_hot": "IH.COILS_STATUS.STILL_HOT", "still_hot": "IH.COILS_STATUS.STILL_HOT",
"pan_status": "IH.COILS_STATUS.PAN", "pan_status": "IH.COILS_STATUS.PAN",
@ -151,13 +133,27 @@ NAMES = {
"rinse_aid": "DW_CMD&CTRL.MAINTENANCE.CONSUMABLE_LEVELS_ICON_RINSE_AID", "rinse_aid": "DW_CMD&CTRL.MAINTENANCE.CONSUMABLE_LEVELS_ICON_RINSE_AID",
"salt_level": "DW_CMD&CTRL.MAINTENANCE.CONSUMABLE_LEVELS_ICON_SALT", "salt_level": "DW_CMD&CTRL.MAINTENANCE.CONSUMABLE_LEVELS_ICON_SALT",
"door_open": "GLOBALS.APPLIANCE_STATUS.DOOR_OPEN", "door_open": "GLOBALS.APPLIANCE_STATUS.DOOR_OPEN",
"connection": "GLOBALS.GENERAL.CONNECT", "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": { "button": {
"induction_hob": "GLOBALS.APPLIANCES_NAME.IH", "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": { "select": {
"dry_levels": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_MAIN_OPTIONS.DRYING", "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", "spin_speed": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_MAIN_OPTIONS.SPINSPEED",
"temperature": "IH.COMMON.TEMPERATURE", "temperature": "IH.COMMON.TEMPERATURE",
"programs_dw": "WC.SET_PROGRAM.PROGRAM", "programs_dw": "WC.SET_PROGRAM.PROGRAM",
@ -165,9 +161,13 @@ NAMES = {
"programs_ov": "WC.SET_PROGRAM.PROGRAM", "programs_ov": "WC.SET_PROGRAM.PROGRAM",
"programs_td": "WC.SET_PROGRAM.PROGRAM", "programs_td": "WC.SET_PROGRAM.PROGRAM",
"programs_wm": "WC.SET_PROGRAM.PROGRAM", "programs_wm": "WC.SET_PROGRAM.PROGRAM",
"eco_pilot": "AC.PROGRAM_DETAIL.ECO_PILOT",
"remaining_time": "ENROLLMENT_COMMON.GENERAL.REMAINING_TIME",
"ref_zones": "IH.COMMON.COIL",
}, },
"sensor": { "sensor": {
"dry_levels": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_MAIN_OPTIONS.DRYING", "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", "power": "OV.RECIPE_DETAIL.POWER_LEVEL",
"remaining_time": "ENROLLMENT_COMMON.GENERAL.REMAINING_TIME", "remaining_time": "ENROLLMENT_COMMON.GENERAL.REMAINING_TIME",
"temperature": "IH.COMMON.TEMPERATURE", "temperature": "IH.COMMON.TEMPERATURE",
@ -181,23 +181,63 @@ NAMES = {
"program_phases_wm": "WASHING_CMD&CTRL.STATISTICS_GRAPHIC_INSTANT_CONSUMPTION.PHASE", "program_phases_wm": "WASHING_CMD&CTRL.STATISTICS_GRAPHIC_INSTANT_CONSUMPTION.PHASE",
"program_phases_td": "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", "program_phases_dw": "WASHING_CMD&CTRL.STATISTICS_GRAPHIC_INSTANT_CONSUMPTION.PHASE",
"delay_time": "WASHING_CMD&CTRL.COMMANDS.SCHEDULE", "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",
}, },
"number": { "number": {
"power_management": "HINTS.COOKING_WITH_INDUCTION.POWER_MANAGEMENT", "power_management": "HINTS.COOKING_WITH_INDUCTION.POWER_MANAGEMENT",
"temperature": "IH.COMMON.TEMPERATURE", "temperature": "IH.COMMON.TEMPERATURE",
"delay_time": "WASHING_CMD&CTRL.COMMANDS.SCHEDULE", "delay_time": "HINTS.TIPS_TIME_ENERGY_SAVING.TIPS_USE_AT_NIGHT_TITLE",
"water_hard": "WASHING_CMD&CTRL.DASHBOARD_MENU_MORE_SETTINGS_WATER.TITLE", "water_hard": "WASHING_CMD&CTRL.DASHBOARD_MENU_MORE_SETTINGS_WATER.TITLE",
"program_duration": "OV.PROGRAM_DETAIL.PROGRAM_DURATION", "program_duration": "OV.PROGRAM_DETAIL.PROGRAM_DURATION",
"target_temperature": "IH.COOKING_DETAIL.TEMPERATURE_TARGETING", "target_temperature": "IH.COOKING_DETAIL.TEMPERATURE_TARGETING",
"rinse_iterations": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL.DRAWER_HEADER_RINSE", "rinse_iterations": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL.DRAWER_HEADER_RINSE",
"wash_time": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL.WASHING_TIME", "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 LANGUAGES: for language in const.LANGUAGES:
path = translations / f"{language}.json" path = translations / f"{language}.json"
if not path.is_file(): if not path.is_file():
async with HonAPI(anonymous=True) as hon: async with HonAPI(anonymous=True) as hon:
@ -228,20 +268,24 @@ def load_json(path):
def save_json(path, keys): def save_json(path, keys):
with open(path, "w") as json_file: with open(path, "w") as json_file:
json_file.write(json.dumps(keys, indent=4)) json_file.write(json.dumps(keys, indent=4, ensure_ascii=False))
def load_key(full_key, json_data, fallback=None): def load_key(full_key, json_data, fallback=None):
if isinstance(full_key, list):
return " ".join(
[load_key(item, json_data, fallback).strip() for item in full_key]
)
result = json_data.copy() result = json_data.copy()
for key in full_key.split("."): for key in full_key.split("."):
result = result.get(key, {}) result = result.get(key, {})
if not result and fallback: if not result and fallback:
return load_key(full_key, fallback) return load_key(full_key, fallback)
return result or "" return result or full_key
def load_keys(full_key, json_data): def load_keys(full_key, json_data):
blacklist = ["description", "_recipe_", "_guided_"] blacklist = ["description", "desctiption", "_recipe_", "_guided_"]
first, last = full_key.split(".") first, last = full_key.split(".")
data = json_data.get(first, {}).get(last, {}) data = json_data.get(first, {}).get(last, {})
return { return {
@ -260,25 +304,49 @@ def add_data(old, original, fallback, data, name, entity="sensor"):
state[str(number)] = key state[str(number)] = key
def translate_login(old, *args):
login = old.setdefault("config", {}).setdefault("step", {}).setdefault("user", {})
login["description"] = load_key("CUBE90_ALEXA.HAIER_SMART_SKILLS.STEP_2", *args)
login.setdefault("data", {})["email"] = load_key(
"PET.EDIT_PET_PROFESSIONALS.EMAIL", *args
)
login["data"]["password"] = load_key("CUBE90_GLOBAL.GENERAL.PASSWORD", *args)
def main(): def main():
hass = load_hass_translations() hass = load_hass_translations()
hon = load_hon_translations() hon = load_hon_translations()
base_path = Path(__file__).parent.parent / "custom_components/hon/translations" base_path = Path(__file__).parent.parent / "custom_components/hon/translations"
fallback = load_json(hon.get("en", "")) fallback = load_json(hon.get("en", ""))
for language in LANGUAGES: for language in const.LANGUAGES:
original = load_json(hon.get(language, "")) original = load_json(hon.get(language, ""))
old = load_json(hass.get(language, "")) old = load_json(hass.get(language, ""))
for name, data in SENSOR.items(): for name, data in SENSOR.items():
add_data(old, original, fallback, data, name) add_data(old, original, fallback, data, name)
for name, data in SELECT.items(): for name, data in SELECT.items():
add_data(old, original, fallback, data, name, "select") add_data(old, original, fallback, data, name, "select")
for name, program in PROGRAMS.items(): for entity, data in PROGRAMS.items():
select = old.setdefault("entity", {}).setdefault("select", {}) for name, program in data.items():
select.setdefault(name, {})["state"] = load_keys(program, original) select = old.setdefault("entity", {}).setdefault(entity, {})
select.setdefault(name, {})["state"] = load_keys(program, original)
for entity, data in NAMES.items(): for entity, data in NAMES.items():
for name, key in data.items(): for name, key in data.items():
select = old.setdefault("entity", {}).setdefault(entity, {}) select = old.setdefault("entity", {}).setdefault(entity, {})
select.setdefault(name, {})["name"] = load_key(key, original, fallback) select.setdefault(name, {})["name"] = load_key(key, original, fallback)
for name, modes in CLIMATE.items():
climate = old.setdefault("entity", {}).setdefault("climate", {})
attr = climate.setdefault(name, {}).setdefault("state_attributes", {})
for mode, data in modes.items():
mode_name = load_key(data["name"], original, fallback)
attr.setdefault(mode, {})["name"] = mode_name
if isinstance(data["state"], dict):
for state, key in data["state"].items():
mode_state = load_key(key, original, fallback)
attr[mode].setdefault("state", {})[state] = mode_state
else:
attr[mode]["state"] = load_keys(data["state"], original)
translate_login(old, original, fallback)
save_json(base_path / f"{language}.json", old) save_json(base_path / f"{language}.json", old)

View File

@ -4,15 +4,21 @@ import re
import sys import sys
from pathlib import Path from pathlib import Path
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 custom_components.hon.binary_sensor import BINARY_SENSORS from custom_components.hon.binary_sensor import BINARY_SENSORS
from custom_components.hon.button import BUTTONS from custom_components.hon.button import BUTTONS
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.switch import SWITCHES, HonSwitchEntityDescription from custom_components.hon.switch import (
SWITCHES,
HonControlSwitchEntityDescription,
HonSwitchEntityDescription,
)
APPLIANCES = { APPLIANCES = {
"AC": "Air conditioner", "AC": "Air conditioner",
@ -41,22 +47,26 @@ entities = {
"select": SELECTS, "select": SELECTS,
"sensor": SENSORS, "sensor": SENSORS,
"switch": SWITCHES, "switch": SWITCHES,
"climate": CLIMATES,
} }
result = {} result = {}
for entity_type, appliances in entities.items(): for entity_type, appliances in entities.items():
for appliance, data in appliances.items(): for appliance, data in appliances.items():
for entity in data: for entity in data:
if ( if isinstance(entity, HonControlSwitchEntityDescription):
isinstance(entity, HonSwitchEntityDescription)
and entity.entity_category != "config"
):
key = f"{entity.turn_on_key}` / `{entity.turn_off_key}" key = f"{entity.turn_on_key}` / `{entity.turn_off_key}"
else: else:
key = entity.key key = entity.key
translation = bool(entity.translation_key) attributes = (key, entity.name, entity.icon, entity_type)
attributes = (key, entity.name, entity.icon, entity_type, translation) category = (
category = "control" if entity_type in ["switch", "button"] else "sensor" "control"
if entity.key.startswith("settings")
or isinstance(entity, HonSwitchEntityDescription)
or isinstance(entity, HonControlSwitchEntityDescription)
or entity_type in ["button", "climate"]
else "sensor"
)
result.setdefault(appliance, {}).setdefault( result.setdefault(appliance, {}).setdefault(
entity.entity_category or category, [] entity.entity_category or category, []
).append(attributes) ).append(attributes)
@ -66,14 +76,11 @@ for appliance, categories in sorted(result.items()):
categories = {k: categories[k] for k in ENTITY_CATEGORY_SORT if k in categories} categories = {k: categories[k] for k in ENTITY_CATEGORY_SORT if k in categories}
for category, data in categories.items(): for category, data in categories.items():
text += f"#### {str(category).capitalize()}s\n" text += f"#### {str(category).capitalize()}s\n"
text += "| Name | Icon | Entity | Key | Auto-Translation |\n" text += "| Name | Icon | Entity | Key |\n"
text += "| --- | --- | --- | --- | --- |\n" text += "| --- | --- | --- | --- |\n"
for key, name, icon, entity_type, translation in sorted( for key, name, icon, entity_type in sorted(data, key=lambda d: d[1]):
data, key=lambda d: d[1]
):
icon = f"`{icon.replace('mdi:', '')}`" if icon else "" icon = f"`{icon.replace('mdi:', '')}`" if icon else ""
translation = "" if translation else "" text += f"| {name} | {icon} | `{entity_type}` | `{key}` |\n"
text += f"| {name} | {icon} | `{entity_type}` | `{key}` | {translation} |\n"
with open(Path(__file__).parent.parent / "README.md", "r") as file: with open(Path(__file__).parent.parent / "README.md", "r") as file:
readme = file.read() readme = file.read()