Compare commits
1 Commits
v0.8.0-bet
...
v0.6.0-bet
Author | SHA1 | Date | |
---|---|---|---|
28e23c7f3c |
3
.gitignore
vendored
3
.gitignore
vendored
@ -1,4 +1,3 @@
|
|||||||
__pycache__/
|
__pycache__/
|
||||||
|
test.py
|
||||||
.idea/
|
.idea/
|
||||||
scripts/translations/
|
|
||||||
scripts/test*
|
|
||||||
|
426
README.md
426
README.md
@ -1,20 +1,15 @@
|
|||||||
# Haier hOn
|
# Haier hOn
|
||||||
[](https://hacs.xyz)
|
[](https://hacs.xyz)
|
||||||
[](https://github.com/Andre0512/hon/releases/latest)
|
[](https://github.com/Andre0512/hon/releases/latest)
|
||||||
[](https://github.com/Andre0512/pyhOn)
|

|
||||||
[](https://github.com/Andre0512/hon/blob/main/LICENSE)
|
[](https://analytics.home-assistant.io/)
|
||||||
[](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)
|
- Tumble Dryer
|
||||||
- [Tumble Dryer](https://github.com/Andre0512/hon#tumble-dryer)
|
- Washer Dryer
|
||||||
- [Washer Dryer](https://github.com/Andre0512/hon#washer-dryer)
|
- Washing Machine
|
||||||
- [Oven](https://github.com/Andre0512/hon#oven)
|
- Oven
|
||||||
- [Dish Washer](https://github.com/Andre0512/hon#dish-washer)
|
- Hob
|
||||||
- [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:** [](https://my.home-assistant.io/redirect/hacs_repository/?owner=Andre0512&repository=hon&category=integration)
|
**Method 1:** [](https://my.home-assistant.io/redirect/hacs_repository/?owner=Andre0512&repository=hon&category=integration)
|
||||||
@ -32,72 +27,28 @@ _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
|
|
||||||

|
|
||||||
|
|
||||||
## 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 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 HWPD 69AMBC/1-S
|
|
||||||
- Hoover HWPS4954DAMR-11
|
|
||||||
- Hoover NDE H10A2TCE-80
|
|
||||||
- Hoover NDE H9A2TSBEXS-S
|
|
||||||
- Hoover NDPHY10A2TCBEXSS
|
|
||||||
|
|
||||||
## Contribute
|
## Contribute
|
||||||
Any kind of contribution is welcome!
|
Any kind of contribution is welcome!
|
||||||
### Read out device data
|
### Read out device data
|
||||||
If you want to make a request for adding new appliances or additional attributes and don't want to use the command line, here is how you can read out your device data.
|
If you want to make a request for adding new appliances or additional attributes and don't want to use the command line, here is how you can read out your device data.
|
||||||
For every device exists a hidden button which can be used to log all infos of your appliance.
|
For every device exists a hidden button which can be used to log all info of your appliance.
|
||||||
1. Enable the "Show Device Info" button
|
1. Enable the "Log 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 to create a notification
|
2. Press the button
|
||||||
3. Open home assistant notifications and copy the message (Crtl+A, Ctrl+C)
|
3. Go to Settings > System > Logs, click _load full logs_ and scroll down
|
||||||
|
_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
|
||||||
@ -142,326 +93,13 @@ For every device exists a hidden button which can be used to log all infos of yo
|
|||||||
- 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
|
||||||
|
|
||||||
## Special Thanks
|
## Tested Devices
|
||||||
- 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 WD90-B14TEAM5
|
||||||
- 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 HD80-A3959
|
||||||
- to everyone who contributed, created an issue, gave this repo a star, and used this integration.
|
- Haier HWO60SM2F3XH
|
||||||
- to the patience of my girlfriend as I work on this integration.
|
- Hoover H-WASH 500
|
||||||
|
|
||||||
## Appliance Features
|
## About this Repo
|
||||||
|
The existing integrations missed some features from the app I liked to have in HomeAssistant.
|
||||||
### Air conditioner
|
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.
|
||||||
#### Controls
|
I moved the api related stuff into the package [pyhOn](https://github.com/Andre0512/pyhOn).
|
||||||
| Name | Icon | Entity | Key |
|
|
||||||
| --- | --- | --- | --- |
|
|
||||||
| 10° Heating | `heat-wave` | `switch` | `settings.10degreeHeatingStatus` |
|
|
||||||
| Air Conditioner | `air-conditioner` | `climate` | `settings` |
|
|
||||||
| Echo | `account-voice` | `switch` | `settings.echoStatus` |
|
|
||||||
| Eco Mode | | `switch` | `settings.ecoMode` |
|
|
||||||
| Eco Pilot | `run` | `select` | `settings.humanSensingStatus` |
|
|
||||||
| Health Mode | `medication-outline` | `switch` | `settings.healthMode` |
|
|
||||||
| Mute | `volume-off` | `switch` | `settings.muteStatus` |
|
|
||||||
| Rapid Mode | `run-fast` | `switch` | `settings.rapidMode` |
|
|
||||||
| Screen Display | `monitor-small` | `switch` | `settings.screenDisplayStatus` |
|
|
||||||
| Self Cleaning | `air-filter` | `switch` | `settings.selfCleaningStatus` |
|
|
||||||
| Self Cleaning 56 | `air-filter` | `switch` | `settings.selfCleaning56Status` |
|
|
||||||
| Silent Sleep | `bed` | `switch` | `settings.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
|
|
||||||
#### Controls
|
|
||||||
| Name | Icon | Entity | Key |
|
|
||||||
| --- | --- | --- | --- |
|
|
||||||
| Buzzer Disabled | `volume-off` | `switch` | `settings.buzzerDisabled` |
|
|
||||||
| Dish Washer | `dishwasher` | `switch` | `startProgram` / `stopProgram` |
|
|
||||||
#### Configs
|
|
||||||
| Name | Icon | Entity | Key |
|
|
||||||
| --- | --- | --- | --- |
|
|
||||||
| Add Dish | `silverware-fork-knife` | `switch` | `startProgram.addDish` |
|
|
||||||
| Delay time | `timer-plus` | `number` | `startProgram.delayTime` |
|
|
||||||
| Eco Express | `sprout` | `switch` | `startProgram.ecoExpress` |
|
|
||||||
| Eco Index | `sprout` | `sensor` | `startProgram.ecoIndex` |
|
|
||||||
| Energy Label | `lightning-bolt-circle` | `sensor` | `startProgram.energyLabel` |
|
|
||||||
| Extra Dry | `hair-dryer` | `switch` | `startProgram.extraDry` |
|
|
||||||
| Half Load | `fraction-one-half` | `switch` | `startProgram.halfLoad` |
|
|
||||||
| Open Door | `door-open` | `switch` | `startProgram.openDoor` |
|
|
||||||
| Program | | `select` | `startProgram.program` |
|
|
||||||
| Remaining Time | `timer` | `select` | `startProgram.remainingTime` |
|
|
||||||
| Temperature | `thermometer` | `select` | `startProgram.temp` |
|
|
||||||
| Temperature | `thermometer` | `sensor` | `startProgram.temp` |
|
|
||||||
| Three in One | `numeric-3-box-outline` | `switch` | `startProgram.threeInOne` |
|
|
||||||
| Time | `timer` | `sensor` | `startProgram.remainingTime` |
|
|
||||||
| Water Efficiency | `water` | `sensor` | `startProgram.waterEfficiency` |
|
|
||||||
| Water Saving | `water-percent` | `sensor` | `startProgram.waterSaving` |
|
|
||||||
| Water hard | `water` | `number` | `startProgram.waterHard` |
|
|
||||||
#### Sensors
|
|
||||||
| Name | Icon | Entity | Key |
|
|
||||||
| --- | --- | --- | --- |
|
|
||||||
| Connection | | `binary_sensor` | `attributes.lastConnEvent.category` |
|
|
||||||
| Door | | `binary_sensor` | `doorStatus` |
|
|
||||||
| Error | `math-log` | `sensor` | `errors` |
|
|
||||||
| Machine Status | `information` | `sensor` | `machMode` |
|
|
||||||
| Program Phase | `washing-machine` | `sensor` | `prPhase` |
|
|
||||||
| Remaining Time | `timer` | `sensor` | `remainingTimeMM` |
|
|
||||||
| Rinse Aid | `spray-bottle` | `binary_sensor` | `rinseAidStatus` |
|
|
||||||
| Salt | `shaker-outline` | `binary_sensor` | `saltStatus` |
|
|
||||||
|
|
||||||
### Hob
|
|
||||||
#### Controls
|
|
||||||
| Name | Icon | Entity | Key |
|
|
||||||
| --- | --- | --- | --- |
|
|
||||||
| Start Program | `pot-steam` | `button` | `startProgram` |
|
|
||||||
#### Configs
|
|
||||||
| Name | Icon | Entity | Key |
|
|
||||||
| --- | --- | --- | --- |
|
|
||||||
| Power Management | `timelapse` | `number` | `startProgram.powerManagement` |
|
|
||||||
| Program | | `select` | `startProgram.program` |
|
|
||||||
| Temperature | `thermometer` | `number` | `startProgram.temp` |
|
|
||||||
#### Sensors
|
|
||||||
| Name | Icon | Entity | Key |
|
|
||||||
| --- | --- | --- | --- |
|
|
||||||
| Connection | `wifi` | `binary_sensor` | `attributes.lastConnEvent.category` |
|
|
||||||
| Error | `math-log` | `sensor` | `errors` |
|
|
||||||
| Hob Lock | | `binary_sensor` | `hobLockStatus` |
|
|
||||||
| Hot Status | | `binary_sensor` | `hotStatus` |
|
|
||||||
| On | `power-cycle` | `binary_sensor` | `attributes.parameters.onOffStatus` |
|
|
||||||
| Pan Status | `pot-mix` | `binary_sensor` | `panStatus` |
|
|
||||||
| Power | `lightning-bolt` | `sensor` | `power` |
|
|
||||||
| Remaining Time | `timer` | `sensor` | `remainingTimeMM` |
|
|
||||||
| Temperature | `thermometer` | `sensor` | `temp` |
|
|
||||||
|
|
||||||
### Oven
|
|
||||||
#### Controls
|
|
||||||
| Name | Icon | Entity | Key |
|
|
||||||
| --- | --- | --- | --- |
|
|
||||||
| Oven | `toaster-oven` | `switch` | `startProgram` / `stopProgram` |
|
|
||||||
#### Configs
|
|
||||||
| Name | Icon | Entity | Key |
|
|
||||||
| --- | --- | --- | --- |
|
|
||||||
| Delay time | `timer-plus` | `number` | `startProgram.delayTime` |
|
|
||||||
| Preheat | `thermometer-chevron-up` | `switch` | `startProgram.preheatStatus` |
|
|
||||||
| Program | | `select` | `startProgram.program` |
|
|
||||||
| Program Duration | `timelapse` | `number` | `startProgram.prTime` |
|
|
||||||
| Target Temperature | `thermometer` | `number` | `startProgram.tempSel` |
|
|
||||||
#### Sensors
|
|
||||||
| Name | Icon | Entity | Key |
|
|
||||||
| --- | --- | --- | --- |
|
|
||||||
| Connection | `wifi` | `binary_sensor` | `attributes.lastConnEvent.category` |
|
|
||||||
| On | `power-cycle` | `binary_sensor` | `attributes.parameters.onOffStatus` |
|
|
||||||
| Remaining Time | `timer` | `sensor` | `remainingTimeMM` |
|
|
||||||
| Start Time | `clock-start` | `sensor` | `delayTime` |
|
|
||||||
| Temperature | `thermometer` | `sensor` | `temp` |
|
|
||||||
| Temperature Selected | `thermometer` | `sensor` | `tempSel` |
|
|
||||||
|
|
||||||
### Fridge
|
|
||||||
#### Controls
|
|
||||||
| Name | Icon | Entity | Key |
|
|
||||||
| --- | --- | --- | --- |
|
|
||||||
| Auto-Set Mode | `thermometer-auto` | `switch` | `settings.intelligenceMode` |
|
|
||||||
| Freezer Temperature | `thermometer` | `number` | `settings.tempSelZ2` |
|
|
||||||
| Fridge Temperature | `thermometer` | `number` | `settings.tempSelZ1` |
|
|
||||||
| Super Cool | `snowflake` | `switch` | `settings.quickModeZ2` |
|
|
||||||
| Super Freeze | `snowflake-variant` | `switch` | `settings.quickModeZ1` |
|
|
||||||
#### Configs
|
|
||||||
| Name | Icon | Entity | Key |
|
|
||||||
| --- | --- | --- | --- |
|
|
||||||
| Program | | `select` | `startProgram.program` |
|
|
||||||
#### 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` |
|
|
||||||
| 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
|
|
||||||
#### Controls
|
|
||||||
| Name | Icon | Entity | Key |
|
|
||||||
| --- | --- | --- | --- |
|
|
||||||
| Pause Tumble Dryer | `pause` | `switch` | `pauseProgram` / `resumeProgram` |
|
|
||||||
| Tumble Dryer | `tumble-dryer` | `switch` | `startProgram` / `stopProgram` |
|
|
||||||
#### Configs
|
|
||||||
| Name | Icon | Entity | Key |
|
|
||||||
| --- | --- | --- | --- |
|
|
||||||
| Anti-Crease | `timer` | `switch` | `startProgram.antiCreaseTime` |
|
|
||||||
| Anti-Crease | `timer` | `switch` | `startProgram.anticrease` |
|
|
||||||
| 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` |
|
|
||||||
| 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
|
|
||||||
| Name | Icon | Entity | Key |
|
|
||||||
| --- | --- | --- | --- |
|
|
||||||
| Anti-Crease | | `binary_sensor` | `anticrease` |
|
|
||||||
| Connection | | `binary_sensor` | `attributes.lastConnEvent.category` |
|
|
||||||
| Door | | `binary_sensor` | `doorStatus` |
|
|
||||||
| Dry level | `hair-dryer` | `sensor` | `dryLevel` |
|
|
||||||
| Error | `math-log` | `sensor` | `errors` |
|
|
||||||
| Machine Status | `information` | `sensor` | `machMode` |
|
|
||||||
| Program | `tumble-dryer` | `sensor` | `programName` |
|
|
||||||
| Program Phase | `washing-machine` | `sensor` | `prPhase` |
|
|
||||||
| Remaining Time | `timer` | `sensor` | `remainingTimeMM` |
|
|
||||||
| Start Time | `clock-start` | `sensor` | `delayTime` |
|
|
||||||
| Steam level | `smoke` | `sensor` | `steamLevel` |
|
|
||||||
| Temperature level | `thermometer` | `sensor` | `tempLevel` |
|
|
||||||
|
|
||||||
### Washer dryer
|
|
||||||
#### Controls
|
|
||||||
| Name | Icon | Entity | Key |
|
|
||||||
| --- | --- | --- | --- |
|
|
||||||
| Pause Washer Dryer | `pause` | `switch` | `pauseProgram` / `resumeProgram` |
|
|
||||||
| Washer Dryer | `washing-machine` | `switch` | `startProgram` / `stopProgram` |
|
|
||||||
#### Configs
|
|
||||||
| Name | Icon | Entity | Key |
|
|
||||||
| --- | --- | --- | --- |
|
|
||||||
| Acqua Plus | `water-plus` | `switch` | `startProgram.acquaplus` |
|
|
||||||
| Anti-Crease | `timer` | `switch` | `startProgram.antiCreaseTime` |
|
|
||||||
| 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
|
|
||||||
| Name | Icon | Entity | Key |
|
|
||||||
| --- | --- | --- | --- |
|
|
||||||
| Acqua Plus | | `binary_sensor` | `acquaplus` |
|
|
||||||
| Anti-Crease | | `binary_sensor` | `anticrease` |
|
|
||||||
| Current Electricity Used | `lightning-bolt` | `sensor` | `currentElectricityUsed` |
|
|
||||||
| Current Temperature | `thermometer` | `sensor` | `temp` |
|
|
||||||
| Current Water Used | `water` | `sensor` | `currentWaterUsed` |
|
|
||||||
| Dirt level | `liquid-spot` | `sensor` | `dirtyLevel` |
|
|
||||||
| Door | | `binary_sensor` | `doorStatus` |
|
|
||||||
| Door Lock | | `binary_sensor` | `doorLockStatus` |
|
|
||||||
| Dry level | `hair-dryer` | `sensor` | `dryLevel` |
|
|
||||||
| Error | `math-log` | `sensor` | `errors` |
|
|
||||||
| Extra Rinse 1 | | `binary_sensor` | `extraRinse1` |
|
|
||||||
| Extra Rinse 2 | | `binary_sensor` | `extraRinse2` |
|
|
||||||
| Extra Rinse 3 | | `binary_sensor` | `extraRinse3` |
|
|
||||||
| Good Night Mode | | `binary_sensor` | `goodNight` |
|
|
||||||
| Machine Status | `information` | `sensor` | `machMode` |
|
|
||||||
| Pre Wash | | `binary_sensor` | `startProgram.prewash` |
|
|
||||||
| Program | `tumble-dryer` | `sensor` | `programName` |
|
|
||||||
| Program Phase | `washing-machine` | `sensor` | `prPhase` |
|
|
||||||
| Remaining Time | `timer` | `sensor` | `remainingTimeMM` |
|
|
||||||
| Remote Control | `remote` | `binary_sensor` | `attributes.lastConnEvent.category` |
|
|
||||||
| Spin Speed | `speedometer` | `sensor` | `spinSpeed` |
|
|
||||||
| 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
|
|
||||||
#### Controls
|
|
||||||
| Name | Icon | Entity | Key |
|
|
||||||
| --- | --- | --- | --- |
|
|
||||||
| Pause Washing Machine | `pause` | `switch` | `pauseProgram` / `resumeProgram` |
|
|
||||||
| Washing Machine | `washing-machine` | `switch` | `startProgram` / `stopProgram` |
|
|
||||||
#### Configs
|
|
||||||
| Name | Icon | Entity | Key |
|
|
||||||
| --- | --- | --- | --- |
|
|
||||||
| Acqua Plus | `water-plus` | `switch` | `startProgram.acquaplus` |
|
|
||||||
| 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` |
|
|
||||||
| 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` |
|
|
||||||
| 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
|
|
||||||
| Name | Icon | Entity | Key |
|
|
||||||
| --- | --- | --- | --- |
|
|
||||||
| Acqua Plus | | `binary_sensor` | `acquaplus` |
|
|
||||||
| Current Electricity Used | `lightning-bolt` | `sensor` | `currentElectricityUsed` |
|
|
||||||
| Current Temperature | `thermometer` | `sensor` | `temp` |
|
|
||||||
| Current Water Used | `water` | `sensor` | `currentWaterUsed` |
|
|
||||||
| Dirt level | `liquid-spot` | `sensor` | `dirtyLevel` |
|
|
||||||
| Door | | `binary_sensor` | `doorStatus` |
|
|
||||||
| Door Lock | | `binary_sensor` | `doorLockStatus` |
|
|
||||||
| Error | `math-log` | `sensor` | `errors` |
|
|
||||||
| Extra Rinse 1 | | `binary_sensor` | `extraRinse1` |
|
|
||||||
| Extra Rinse 2 | | `binary_sensor` | `extraRinse2` |
|
|
||||||
| Extra Rinse 3 | | `binary_sensor` | `extraRinse3` |
|
|
||||||
| Good Night Mode | | `binary_sensor` | `goodNight` |
|
|
||||||
| 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` |
|
|
||||||
|
Binary file not shown.
Before Width: | Height: | Size: 202 KiB |
@ -11,7 +11,7 @@ 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, unique_entities
|
from .hon import HonCoordinator, HonEntity
|
||||||
|
|
||||||
_LOGGER = logging.getLogger(__name__)
|
_LOGGER = logging.getLogger(__name__)
|
||||||
|
|
||||||
@ -36,39 +36,18 @@ BINARY_SENSORS: dict[str, tuple[HonBinarySensorEntityDescription, ...]] = {
|
|||||||
device_class=BinarySensorDeviceClass.CONNECTIVITY,
|
device_class=BinarySensorDeviceClass.CONNECTIVITY,
|
||||||
on_value="CONNECTED",
|
on_value="CONNECTED",
|
||||||
icon="mdi:remote",
|
icon="mdi:remote",
|
||||||
translation_key="remote_control",
|
|
||||||
),
|
),
|
||||||
HonBinarySensorEntityDescription(
|
HonBinarySensorEntityDescription(
|
||||||
key="doorLockStatus",
|
key="doorLockStatus",
|
||||||
name="Door Lock",
|
name="Door Lock",
|
||||||
device_class=BinarySensorDeviceClass.LOCK,
|
device_class=BinarySensorDeviceClass.LOCK,
|
||||||
on_value="0",
|
on_value="0",
|
||||||
translation_key="door_lock",
|
|
||||||
),
|
),
|
||||||
HonBinarySensorEntityDescription(
|
HonBinarySensorEntityDescription(
|
||||||
key="doorStatus",
|
key="doorStatus",
|
||||||
name="Door",
|
name="Door",
|
||||||
device_class=BinarySensorDeviceClass.DOOR,
|
device_class=BinarySensorDeviceClass.DOOR,
|
||||||
on_value="1",
|
on_value="1",
|
||||||
translation_key="door_open",
|
|
||||||
),
|
|
||||||
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": (
|
||||||
@ -77,17 +56,49 @@ BINARY_SENSORS: dict[str, tuple[HonBinarySensorEntityDescription, ...]] = {
|
|||||||
name="Connection",
|
name="Connection",
|
||||||
device_class=BinarySensorDeviceClass.CONNECTIVITY,
|
device_class=BinarySensorDeviceClass.CONNECTIVITY,
|
||||||
on_value="CONNECTED",
|
on_value="CONNECTED",
|
||||||
translation_key="connection",
|
|
||||||
),
|
),
|
||||||
HonBinarySensorEntityDescription(
|
HonBinarySensorEntityDescription(
|
||||||
key="doorStatus",
|
key="doorStatus",
|
||||||
name="Door",
|
name="Door",
|
||||||
device_class=BinarySensorDeviceClass.DOOR,
|
device_class=BinarySensorDeviceClass.DOOR,
|
||||||
on_value="1",
|
on_value="1",
|
||||||
translation_key="door_open",
|
),
|
||||||
|
),
|
||||||
|
"WD": (
|
||||||
|
HonBinarySensorEntityDescription(
|
||||||
|
key="attributes.lastConnEvent.category",
|
||||||
|
name="Remote Control",
|
||||||
|
device_class=BinarySensorDeviceClass.CONNECTIVITY,
|
||||||
|
on_value="CONNECTED",
|
||||||
|
icon="mdi:remote",
|
||||||
),
|
),
|
||||||
HonBinarySensorEntityDescription(
|
HonBinarySensorEntityDescription(
|
||||||
key="anticrease", name="Anti-Crease", translation_key="anti_crease"
|
key="startProgram.prewash",
|
||||||
|
name="Pre Wash",
|
||||||
|
),
|
||||||
|
HonBinarySensorEntityDescription(
|
||||||
|
key="extraRinse1",
|
||||||
|
name="Extra Rinse 1",
|
||||||
|
),
|
||||||
|
HonBinarySensorEntityDescription(
|
||||||
|
key="extraRinse2",
|
||||||
|
name="Extra Rinse 2",
|
||||||
|
),
|
||||||
|
HonBinarySensorEntityDescription(
|
||||||
|
key="extraRinse3",
|
||||||
|
name="Extra Rinse 3",
|
||||||
|
),
|
||||||
|
HonBinarySensorEntityDescription(
|
||||||
|
key="goodNight",
|
||||||
|
name="Good Night Mode",
|
||||||
|
),
|
||||||
|
HonBinarySensorEntityDescription(
|
||||||
|
key="acquaplus",
|
||||||
|
name="Acqua Plus",
|
||||||
|
),
|
||||||
|
HonBinarySensorEntityDescription(
|
||||||
|
key="anticrease",
|
||||||
|
name="Anti-Crease",
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
"OV": (
|
"OV": (
|
||||||
@ -97,7 +108,13 @@ BINARY_SENSORS: dict[str, tuple[HonBinarySensorEntityDescription, ...]] = {
|
|||||||
device_class=BinarySensorDeviceClass.CONNECTIVITY,
|
device_class=BinarySensorDeviceClass.CONNECTIVITY,
|
||||||
on_value="CONNECTED",
|
on_value="CONNECTED",
|
||||||
icon="mdi:wifi",
|
icon="mdi:wifi",
|
||||||
translation_key="connection",
|
),
|
||||||
|
HonBinarySensorEntityDescription(
|
||||||
|
key="attributes.parameters.remoteCtrValid",
|
||||||
|
name="Remote Control",
|
||||||
|
device_class=BinarySensorDeviceClass.CONNECTIVITY,
|
||||||
|
on_value="1",
|
||||||
|
icon="mdi:remote",
|
||||||
),
|
),
|
||||||
HonBinarySensorEntityDescription(
|
HonBinarySensorEntityDescription(
|
||||||
key="attributes.parameters.onOffStatus",
|
key="attributes.parameters.onOffStatus",
|
||||||
@ -105,17 +122,22 @@ BINARY_SENSORS: dict[str, tuple[HonBinarySensorEntityDescription, ...]] = {
|
|||||||
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": (
|
"IV": (
|
||||||
HonBinarySensorEntityDescription(
|
HonBinarySensorEntityDescription(
|
||||||
key="attributes.lastConnEvent.category",
|
key="attributes.lastConnEvent.category",
|
||||||
name="Connection",
|
name="Connection",
|
||||||
device_class=BinarySensorDeviceClass.CONNECTIVITY,
|
device_class=BinarySensorDeviceClass.CONNECTIVITY,
|
||||||
on_value="CONNECTED",
|
on_value="CONNECTED",
|
||||||
icon="mdi:wifi",
|
icon="mdi:wifi",
|
||||||
translation_key="connection",
|
),
|
||||||
|
HonBinarySensorEntityDescription(
|
||||||
|
key="attributes.parameters.remoteCtrValid",
|
||||||
|
name="Remote Control",
|
||||||
|
device_class=BinarySensorDeviceClass.CONNECTIVITY,
|
||||||
|
on_value="1",
|
||||||
|
icon="mdi:remote",
|
||||||
),
|
),
|
||||||
HonBinarySensorEntityDescription(
|
HonBinarySensorEntityDescription(
|
||||||
key="attributes.parameters.onOffStatus",
|
key="attributes.parameters.onOffStatus",
|
||||||
@ -123,150 +145,48 @@ BINARY_SENSORS: dict[str, tuple[HonBinarySensorEntityDescription, ...]] = {
|
|||||||
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",
|
||||||
name="Hot Status",
|
name="Hot Status",
|
||||||
device_class=BinarySensorDeviceClass.HEAT,
|
device_class=BinarySensorDeviceClass.HEAT,
|
||||||
on_value="1",
|
on_value="1",
|
||||||
translation_key="still_hot",
|
|
||||||
),
|
|
||||||
HonBinarySensorEntityDescription(
|
|
||||||
key="panStatus",
|
|
||||||
name="Pan Status",
|
|
||||||
on_value="1",
|
|
||||||
icon="mdi:pot-mix",
|
|
||||||
translation_key="pan_status",
|
|
||||||
),
|
),
|
||||||
HonBinarySensorEntityDescription(
|
HonBinarySensorEntityDescription(
|
||||||
key="hobLockStatus",
|
key="hobLockStatus",
|
||||||
name="Hob Lock",
|
name="Hob Lock",
|
||||||
device_class=BinarySensorDeviceClass.LOCK,
|
device_class=BinarySensorDeviceClass.LOCK,
|
||||||
on_value="0",
|
on_value="0",
|
||||||
translation_key="child_lock",
|
|
||||||
),
|
|
||||||
),
|
|
||||||
"DW": (
|
|
||||||
HonBinarySensorEntityDescription(
|
|
||||||
key="saltStatus",
|
|
||||||
name="Salt",
|
|
||||||
device_class=BinarySensorDeviceClass.PROBLEM,
|
|
||||||
on_value="1",
|
|
||||||
icon="mdi:shaker-outline",
|
|
||||||
translation_key="salt_level",
|
|
||||||
),
|
|
||||||
HonBinarySensorEntityDescription(
|
|
||||||
key="rinseAidStatus",
|
|
||||||
name="Rinse Aid",
|
|
||||||
device_class=BinarySensorDeviceClass.PROBLEM,
|
|
||||||
on_value="1",
|
|
||||||
icon="mdi:spray-bottle",
|
|
||||||
translation_key="rinse_aid",
|
|
||||||
),
|
|
||||||
HonBinarySensorEntityDescription(
|
|
||||||
key="attributes.lastConnEvent.category",
|
|
||||||
name="Connection",
|
|
||||||
device_class=BinarySensorDeviceClass.CONNECTIVITY,
|
|
||||||
on_value="CONNECTED",
|
|
||||||
translation_key="connection",
|
|
||||||
),
|
|
||||||
HonBinarySensorEntityDescription(
|
|
||||||
key="doorStatus",
|
|
||||||
name="Door",
|
|
||||||
device_class=BinarySensorDeviceClass.DOOR,
|
|
||||||
on_value="1",
|
|
||||||
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]
|
hon: Hon = hass.data[DOMAIN][entry.unique_id]
|
||||||
coordinators = hass.data[DOMAIN]["coordinators"]
|
coordinators = hass.data[DOMAIN]["coordinators"]
|
||||||
appliances = []
|
appliances = []
|
||||||
for device in hon.appliances:
|
for device in hon.appliances:
|
||||||
if device.unique_id in coordinators:
|
if device.mac_address in coordinators:
|
||||||
coordinator = hass.data[DOMAIN]["coordinators"][device.unique_id]
|
coordinator = hass.data[DOMAIN]["coordinators"][device.mac_address]
|
||||||
else:
|
else:
|
||||||
coordinator = HonCoordinator(hass, device)
|
coordinator = HonCoordinator(hass, device)
|
||||||
hass.data[DOMAIN]["coordinators"][device.unique_id] = coordinator
|
hass.data[DOMAIN]["coordinators"][device.mac_address] = coordinator
|
||||||
await coordinator.async_config_entry_first_refresh()
|
await coordinator.async_config_entry_first_refresh()
|
||||||
|
|
||||||
if descriptions := BINARY_SENSORS.get(device.appliance_type):
|
if descriptions := BINARY_SENSORS.get(device.appliance_type):
|
||||||
for description in descriptions:
|
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.append(
|
appliances.extend(
|
||||||
HonBinarySensorEntity(hass, coordinator, entry, device, description)
|
[
|
||||||
|
HonBinarySensorEntity(
|
||||||
|
hass, coordinator, entry, device, description
|
||||||
|
)
|
||||||
|
]
|
||||||
)
|
)
|
||||||
|
|
||||||
async_add_entities(appliances)
|
async_add_entities(appliances)
|
||||||
@ -278,6 +198,8 @@ class HonBinarySensorEntity(HonEntity, BinarySensorEntity):
|
|||||||
def __init__(self, hass, coordinator, entry, device, description) -> None:
|
def __init__(self, hass, coordinator, entry, device, description) -> None:
|
||||||
super().__init__(hass, entry, coordinator, device)
|
super().__init__(hass, entry, coordinator, device)
|
||||||
|
|
||||||
|
self._coordinator = coordinator
|
||||||
|
|
||||||
self.entity_description = description
|
self.entity_description = description
|
||||||
self._attr_unique_id = f"{super().unique_id}{description.key}"
|
self._attr_unique_id = f"{super().unique_id}{description.key}"
|
||||||
|
|
||||||
|
@ -1,26 +1,36 @@
|
|||||||
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 homeassistant.const import EntityCategory
|
|
||||||
from pyhon import Hon
|
from pyhon import Hon
|
||||||
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 HonCoordinator, HonEntity
|
||||||
|
|
||||||
_LOGGER = logging.getLogger(__name__)
|
_LOGGER = logging.getLogger(__name__)
|
||||||
|
|
||||||
BUTTONS: dict[str, tuple[ButtonEntityDescription, ...]] = {
|
BUTTONS: dict[str, tuple[ButtonEntityDescription, ...]] = {
|
||||||
"IH": (
|
"OV": (
|
||||||
|
ButtonEntityDescription(
|
||||||
|
key="startProgram",
|
||||||
|
name="Start Program",
|
||||||
|
icon="mdi:power-cycle",
|
||||||
|
),
|
||||||
|
ButtonEntityDescription(
|
||||||
|
key="stopProgram",
|
||||||
|
name="Stop Program",
|
||||||
|
icon="mdi:power-off",
|
||||||
|
),
|
||||||
|
),
|
||||||
|
"IV": (
|
||||||
ButtonEntityDescription(
|
ButtonEntityDescription(
|
||||||
key="startProgram",
|
key="startProgram",
|
||||||
name="Start Program",
|
name="Start Program",
|
||||||
icon="mdi:pot-steam",
|
icon="mdi:pot-steam",
|
||||||
translation_key="induction_hob",
|
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
}
|
}
|
||||||
@ -31,11 +41,11 @@ async def async_setup_entry(hass, entry: ConfigEntry, async_add_entities) -> Non
|
|||||||
coordinators = hass.data[DOMAIN]["coordinators"]
|
coordinators = hass.data[DOMAIN]["coordinators"]
|
||||||
appliances = []
|
appliances = []
|
||||||
for device in hon.appliances:
|
for device in hon.appliances:
|
||||||
if device.unique_id in coordinators:
|
if device.mac_address in coordinators:
|
||||||
coordinator = hass.data[DOMAIN]["coordinators"][device.unique_id]
|
coordinator = hass.data[DOMAIN]["coordinators"][device.mac_address]
|
||||||
else:
|
else:
|
||||||
coordinator = HonCoordinator(hass, device)
|
coordinator = HonCoordinator(hass, device)
|
||||||
hass.data[DOMAIN]["coordinators"][device.unique_id] = coordinator
|
hass.data[DOMAIN]["coordinators"][device.mac_address] = coordinator
|
||||||
await coordinator.async_config_entry_first_refresh()
|
await coordinator.async_config_entry_first_refresh()
|
||||||
|
|
||||||
if descriptions := BUTTONS.get(device.appliance_type):
|
if descriptions := BUTTONS.get(device.appliance_type):
|
||||||
@ -56,37 +66,25 @@ class HonButtonEntity(HonEntity, ButtonEntity):
|
|||||||
) -> None:
|
) -> None:
|
||||||
super().__init__(hass, entry, coordinator, device)
|
super().__init__(hass, entry, coordinator, device)
|
||||||
|
|
||||||
|
self._coordinator = coordinator
|
||||||
|
self._device = device
|
||||||
self.entity_description = description
|
self.entity_description = description
|
||||||
self._attr_unique_id = f"{super().unique_id}{description.key}"
|
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, coordinator, entry, device: HonAppliance) -> None:
|
||||||
super().__init__(hass, entry, coordinator, device)
|
super().__init__(hass, entry, coordinator, 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 = "Show Device Info"
|
self._attr_name = "Log 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:
|
||||||
pyhon_version = pkg_resources.get_distribution("pyhon").version
|
_LOGGER.error("Device Info:\n" + self._device.diagnose)
|
||||||
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 "))
|
|
||||||
|
@ -1,162 +0,0 @@
|
|||||||
import logging
|
|
||||||
|
|
||||||
from pyhon import Hon
|
|
||||||
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,
|
|
||||||
PRECISION_WHOLE,
|
|
||||||
TEMP_CELSIUS,
|
|
||||||
)
|
|
||||||
from homeassistant.core import callback
|
|
||||||
from .const import HON_HVAC_MODE, HON_FAN, HON_HVAC_PROGRAM, DOMAIN
|
|
||||||
from .hon import HonEntity, HonCoordinator
|
|
||||||
|
|
||||||
_LOGGER = logging.getLogger(__name__)
|
|
||||||
|
|
||||||
CLIMATES = {
|
|
||||||
"AC": (
|
|
||||||
ClimateEntityDescription(
|
|
||||||
key="settings",
|
|
||||||
name="Air Conditioner",
|
|
||||||
icon="mdi:air-conditioner",
|
|
||||||
translation_key="air_conditioner",
|
|
||||||
),
|
|
||||||
),
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
async def async_setup_entry(hass, entry: ConfigEntry, async_add_entities) -> None:
|
|
||||||
hon: Hon = hass.data[DOMAIN][entry.unique_id]
|
|
||||||
coordinators = hass.data[DOMAIN]["coordinators"]
|
|
||||||
appliances = []
|
|
||||||
for device in hon.appliances:
|
|
||||||
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 := CLIMATES.get(device.appliance_type):
|
|
||||||
for description in descriptions:
|
|
||||||
if description.key not in list(device.commands):
|
|
||||||
continue
|
|
||||||
appliances.append(
|
|
||||||
HonClimateEntity(hass, coordinator, entry, device, description)
|
|
||||||
)
|
|
||||||
async_add_entities(appliances)
|
|
||||||
|
|
||||||
|
|
||||||
class HonClimateEntity(HonEntity, ClimateEntity):
|
|
||||||
def __init__(
|
|
||||||
self, hass, coordinator, entry, device: HonAppliance, description
|
|
||||||
) -> None:
|
|
||||||
super().__init__(hass, entry, coordinator, device)
|
|
||||||
self.entity_description = description
|
|
||||||
self._attr_unique_id = f"{super().unique_id}climate"
|
|
||||||
|
|
||||||
self._attr_temperature_unit = TEMP_CELSIUS
|
|
||||||
self._attr_target_temperature_step = PRECISION_WHOLE
|
|
||||||
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)
|
|
||||||
|
|
||||||
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") or "0"]
|
|
||||||
|
|
||||||
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()
|
|
@ -4,6 +4,7 @@ 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
|
||||||
|
|
||||||
from .const import DOMAIN
|
from .const import DOMAIN
|
||||||
|
|
||||||
_LOGGER = logging.getLogger(__name__)
|
_LOGGER = logging.getLogger(__name__)
|
||||||
|
@ -1,11 +1,3 @@
|
|||||||
from homeassistant.components.climate import (
|
|
||||||
HVACMode,
|
|
||||||
FAN_LOW,
|
|
||||||
FAN_MEDIUM,
|
|
||||||
FAN_HIGH,
|
|
||||||
FAN_AUTO,
|
|
||||||
)
|
|
||||||
|
|
||||||
DOMAIN = "hon"
|
DOMAIN = "hon"
|
||||||
|
|
||||||
PLATFORMS = [
|
PLATFORMS = [
|
||||||
@ -15,302 +7,4 @@ 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",
|
|
||||||
}
|
|
||||||
|
|
||||||
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",
|
|
||||||
]
|
]
|
||||||
|
@ -6,6 +6,7 @@ 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 .const import DOMAIN
|
from .const import DOMAIN
|
||||||
|
|
||||||
_LOGGER = logging.getLogger(__name__)
|
_LOGGER = logging.getLogger(__name__)
|
||||||
@ -19,15 +20,14 @@ class HonEntity(CoordinatorEntity):
|
|||||||
|
|
||||||
self._hon = hass.data[DOMAIN][entry.unique_id]
|
self._hon = hass.data[DOMAIN][entry.unique_id]
|
||||||
self._hass = hass
|
self._hass = hass
|
||||||
self._coordinator = coordinator
|
|
||||||
self._device = device
|
self._device = device
|
||||||
|
|
||||||
self._attr_unique_id = self._device.unique_id
|
self._attr_unique_id = self._device.mac_address
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def device_info(self):
|
def device_info(self):
|
||||||
return DeviceInfo(
|
return DeviceInfo(
|
||||||
identifiers={(DOMAIN, self._device.unique_id)},
|
identifiers={(DOMAIN, self._device.mac_address)},
|
||||||
manufacturer=self._device.get("brand", ""),
|
manufacturer=self._device.get("brand", ""),
|
||||||
name=self._device.nick_name
|
name=self._device.nick_name
|
||||||
if self._device.nick_name
|
if self._device.nick_name
|
||||||
@ -43,19 +43,10 @@ class HonCoordinator(DataUpdateCoordinator):
|
|||||||
super().__init__(
|
super().__init__(
|
||||||
hass,
|
hass,
|
||||||
_LOGGER,
|
_LOGGER,
|
||||||
name=device.unique_id,
|
name=device.mac_address,
|
||||||
update_interval=timedelta(seconds=30),
|
update_interval=timedelta(seconds=30),
|
||||||
)
|
)
|
||||||
self._device = device
|
self._device = device
|
||||||
|
|
||||||
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)
|
|
||||||
|
@ -6,6 +6,6 @@
|
|||||||
"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.10.10"],
|
"requirements": ["pyhOn==0.8.0b2"],
|
||||||
"version": "0.8.0-beta.5"
|
"version": "0.6.0-beta.1"
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,8 @@
|
|||||||
from __future__ import annotations
|
from __future__ import annotations
|
||||||
|
|
||||||
|
from pyhon import Hon
|
||||||
|
from pyhon.parameter import HonParameterRange
|
||||||
|
|
||||||
from homeassistant.components.number import (
|
from homeassistant.components.number import (
|
||||||
NumberEntity,
|
NumberEntity,
|
||||||
NumberEntityDescription,
|
NumberEntityDescription,
|
||||||
@ -8,13 +11,9 @@ 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
|
||||||
from pyhon import Hon
|
|
||||||
from pyhon.parameter.base import HonParameter
|
|
||||||
from pyhon.parameter.fixed import HonParameterFixed
|
|
||||||
from pyhon.parameter.range import HonParameterRange
|
|
||||||
|
|
||||||
from .const import DOMAIN
|
from .const import DOMAIN
|
||||||
from .hon import HonEntity, HonCoordinator, unique_entities
|
from .hon import HonEntity, HonCoordinator
|
||||||
|
|
||||||
NUMBERS: dict[str, tuple[NumberEntityDescription, ...]] = {
|
NUMBERS: dict[str, tuple[NumberEntityDescription, ...]] = {
|
||||||
"WM": (
|
"WM": (
|
||||||
@ -24,14 +23,12 @@ NUMBERS: dict[str, tuple[NumberEntityDescription, ...]] = {
|
|||||||
icon="mdi:timer-plus",
|
icon="mdi:timer-plus",
|
||||||
entity_category=EntityCategory.CONFIG,
|
entity_category=EntityCategory.CONFIG,
|
||||||
native_unit_of_measurement=UnitOfTime.MINUTES,
|
native_unit_of_measurement=UnitOfTime.MINUTES,
|
||||||
translation_key="delay_time",
|
|
||||||
),
|
),
|
||||||
NumberEntityDescription(
|
NumberEntityDescription(
|
||||||
key="startProgram.rinseIterations",
|
key="startProgram.rinseIterations",
|
||||||
name="Rinse Iterations",
|
name="Rinse Iterations",
|
||||||
icon="mdi:rotate-right",
|
icon="mdi:rotate-right",
|
||||||
entity_category=EntityCategory.CONFIG,
|
entity_category=EntityCategory.CONFIG,
|
||||||
translation_key="rinse_iterations",
|
|
||||||
),
|
),
|
||||||
NumberEntityDescription(
|
NumberEntityDescription(
|
||||||
key="startProgram.mainWashTime",
|
key="startProgram.mainWashTime",
|
||||||
@ -39,26 +36,6 @@ NUMBERS: dict[str, tuple[NumberEntityDescription, ...]] = {
|
|||||||
icon="mdi:clock-start",
|
icon="mdi:clock-start",
|
||||||
entity_category=EntityCategory.CONFIG,
|
entity_category=EntityCategory.CONFIG,
|
||||||
native_unit_of_measurement=UnitOfTime.MINUTES,
|
native_unit_of_measurement=UnitOfTime.MINUTES,
|
||||||
translation_key="wash_time",
|
|
||||||
),
|
|
||||||
NumberEntityDescription(
|
|
||||||
key="startProgram.steamLevel",
|
|
||||||
name="Steam Level",
|
|
||||||
icon="mdi:weather-dust",
|
|
||||||
entity_category=EntityCategory.CONFIG,
|
|
||||||
translation_key="steam_level",
|
|
||||||
),
|
|
||||||
NumberEntityDescription(
|
|
||||||
key="startProgram.waterHard",
|
|
||||||
name="Water hard",
|
|
||||||
icon="mdi:water",
|
|
||||||
entity_category=EntityCategory.CONFIG,
|
|
||||||
translation_key="water_hard",
|
|
||||||
),
|
|
||||||
NumberEntityDescription(
|
|
||||||
key="startProgram.lang",
|
|
||||||
name="lang",
|
|
||||||
entity_category=EntityCategory.CONFIG,
|
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
"TD": (
|
"TD": (
|
||||||
@ -68,7 +45,13 @@ NUMBERS: dict[str, tuple[NumberEntityDescription, ...]] = {
|
|||||||
icon="mdi:timer-plus",
|
icon="mdi:timer-plus",
|
||||||
entity_category=EntityCategory.CONFIG,
|
entity_category=EntityCategory.CONFIG,
|
||||||
native_unit_of_measurement=UnitOfTime.MINUTES,
|
native_unit_of_measurement=UnitOfTime.MINUTES,
|
||||||
translation_key="delay_time",
|
),
|
||||||
|
NumberEntityDescription(
|
||||||
|
key="startProgram.dryLevel",
|
||||||
|
name="Dry level",
|
||||||
|
entity_category=EntityCategory.CONFIG,
|
||||||
|
icon="mdi:hair-dryer",
|
||||||
|
translation_key="tumbledryerdrylevel",
|
||||||
),
|
),
|
||||||
NumberEntityDescription(
|
NumberEntityDescription(
|
||||||
key="startProgram.tempLevel",
|
key="startProgram.tempLevel",
|
||||||
@ -78,10 +61,26 @@ NUMBERS: dict[str, tuple[NumberEntityDescription, ...]] = {
|
|||||||
translation_key="tumbledryertemplevel",
|
translation_key="tumbledryertemplevel",
|
||||||
),
|
),
|
||||||
NumberEntityDescription(
|
NumberEntityDescription(
|
||||||
key="startProgram.dryTime",
|
key="startProgram.antiCreaseTime",
|
||||||
name="Dry Time",
|
name="Anti-Crease time",
|
||||||
entity_category=EntityCategory.CONFIG,
|
entity_category=EntityCategory.CONFIG,
|
||||||
translation_key="dry_time",
|
icon="mdi:timer",
|
||||||
|
native_unit_of_measurement=UnitOfTime.MINUTES,
|
||||||
|
),
|
||||||
|
NumberEntityDescription(
|
||||||
|
key="startProgram.sterilizationStatus",
|
||||||
|
name="Sterilization status",
|
||||||
|
icon="mdi:clock-start",
|
||||||
|
entity_category=EntityCategory.CONFIG,
|
||||||
|
),
|
||||||
|
),
|
||||||
|
"WD": (
|
||||||
|
NumberEntityDescription(
|
||||||
|
key="startProgram.delayTime",
|
||||||
|
name="Delay Time",
|
||||||
|
icon="mdi:timer-plus",
|
||||||
|
entity_category=EntityCategory.CONFIG,
|
||||||
|
native_unit_of_measurement=UnitOfTime.MINUTES,
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
"OV": (
|
"OV": (
|
||||||
@ -91,7 +90,6 @@ NUMBERS: dict[str, tuple[NumberEntityDescription, ...]] = {
|
|||||||
icon="mdi:timer-plus",
|
icon="mdi:timer-plus",
|
||||||
entity_category=EntityCategory.CONFIG,
|
entity_category=EntityCategory.CONFIG,
|
||||||
native_unit_of_measurement=UnitOfTime.MINUTES,
|
native_unit_of_measurement=UnitOfTime.MINUTES,
|
||||||
translation_key="delay_time",
|
|
||||||
),
|
),
|
||||||
NumberEntityDescription(
|
NumberEntityDescription(
|
||||||
key="startProgram.tempSel",
|
key="startProgram.tempSel",
|
||||||
@ -99,7 +97,6 @@ NUMBERS: dict[str, tuple[NumberEntityDescription, ...]] = {
|
|||||||
entity_category=EntityCategory.CONFIG,
|
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",
|
|
||||||
),
|
),
|
||||||
NumberEntityDescription(
|
NumberEntityDescription(
|
||||||
key="startProgram.prTime",
|
key="startProgram.prTime",
|
||||||
@ -107,87 +104,40 @@ NUMBERS: dict[str, tuple[NumberEntityDescription, ...]] = {
|
|||||||
entity_category=EntityCategory.CONFIG,
|
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",
|
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
"IH": (
|
"IV": (
|
||||||
NumberEntityDescription(
|
NumberEntityDescription(
|
||||||
key="startProgram.temp",
|
key="startProgram.temp",
|
||||||
name="Temperature",
|
name="Temperature",
|
||||||
entity_category=EntityCategory.CONFIG,
|
entity_category=EntityCategory.CONFIG,
|
||||||
icon="mdi:thermometer",
|
icon="mdi:thermometer",
|
||||||
translation_key="temperature",
|
|
||||||
),
|
),
|
||||||
NumberEntityDescription(
|
NumberEntityDescription(
|
||||||
key="startProgram.powerManagement",
|
key="startProgram.powerManagement",
|
||||||
name="Power Management",
|
name="Power Management",
|
||||||
entity_category=EntityCategory.CONFIG,
|
entity_category=EntityCategory.CONFIG,
|
||||||
icon="mdi:timelapse",
|
icon="mdi:timelapse",
|
||||||
translation_key="power_management",
|
|
||||||
),
|
|
||||||
),
|
|
||||||
"DW": (
|
|
||||||
NumberEntityDescription(
|
|
||||||
key="startProgram.delayTime",
|
|
||||||
name="Delay time",
|
|
||||||
icon="mdi:timer-plus",
|
|
||||||
entity_category=EntityCategory.CONFIG,
|
|
||||||
native_unit_of_measurement=UnitOfTime.MINUTES,
|
|
||||||
translation_key="delay_time",
|
|
||||||
),
|
|
||||||
NumberEntityDescription(
|
|
||||||
key="startProgram.waterHard",
|
|
||||||
name="Water hard",
|
|
||||||
icon="mdi:water",
|
|
||||||
entity_category=EntityCategory.CONFIG,
|
|
||||||
translation_key="water_hard",
|
|
||||||
),
|
|
||||||
),
|
|
||||||
"AC": (
|
|
||||||
NumberEntityDescription(
|
|
||||||
key="settings.tempSel",
|
|
||||||
name="Target Temperature",
|
|
||||||
icon="mdi:thermometer",
|
|
||||||
native_unit_of_measurement=UnitOfTemperature.CELSIUS,
|
|
||||||
translation_key="target_temperature",
|
|
||||||
),
|
|
||||||
),
|
|
||||||
"REF": (
|
|
||||||
NumberEntityDescription(
|
|
||||||
key="settings.tempSelZ1",
|
|
||||||
name="Fridge Temperature",
|
|
||||||
icon="mdi:thermometer",
|
|
||||||
native_unit_of_measurement=UnitOfTemperature.CELSIUS,
|
|
||||||
translation_key="fridge_temp_sel",
|
|
||||||
),
|
|
||||||
NumberEntityDescription(
|
|
||||||
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]
|
hon: Hon = hass.data[DOMAIN][entry.unique_id]
|
||||||
coordinators = hass.data[DOMAIN]["coordinators"]
|
coordinators = hass.data[DOMAIN]["coordinators"]
|
||||||
appliances = []
|
appliances = []
|
||||||
for device in hon.appliances:
|
for device in hon.appliances:
|
||||||
if device.unique_id in coordinators:
|
if device.mac_address in coordinators:
|
||||||
coordinator = hass.data[DOMAIN]["coordinators"][device.unique_id]
|
coordinator = hass.data[DOMAIN]["coordinators"][device.mac_address]
|
||||||
else:
|
else:
|
||||||
coordinator = HonCoordinator(hass, device)
|
coordinator = HonCoordinator(hass, device)
|
||||||
hass.data[DOMAIN]["coordinators"][device.unique_id] = coordinator
|
hass.data[DOMAIN]["coordinators"][device.mac_address] = coordinator
|
||||||
await coordinator.async_config_entry_first_refresh()
|
await coordinator.async_config_entry_first_refresh()
|
||||||
|
|
||||||
if descriptions := NUMBERS.get(device.appliance_type):
|
if descriptions := NUMBERS.get(device.appliance_type):
|
||||||
for description in descriptions:
|
for description in descriptions:
|
||||||
if description.key not in device.available_settings:
|
if not device.settings.get(description.key):
|
||||||
continue
|
continue
|
||||||
appliances.extend(
|
appliances.extend(
|
||||||
[HonNumberEntity(hass, coordinator, entry, device, description)]
|
[HonNumberEntity(hass, coordinator, entry, device, description)]
|
||||||
@ -200,6 +150,8 @@ class HonNumberEntity(HonEntity, NumberEntity):
|
|||||||
def __init__(self, hass, coordinator, entry, device, description) -> None:
|
def __init__(self, hass, coordinator, entry, device, description) -> None:
|
||||||
super().__init__(hass, entry, coordinator, device)
|
super().__init__(hass, entry, coordinator, device)
|
||||||
|
|
||||||
|
self._coordinator = coordinator
|
||||||
|
self._device = device
|
||||||
self._data = device.settings[description.key]
|
self._data = device.settings[description.key]
|
||||||
self.entity_description = description
|
self.entity_description = description
|
||||||
self._attr_unique_id = f"{super().unique_id}{description.key}"
|
self._attr_unique_id = f"{super().unique_id}{description.key}"
|
||||||
@ -214,14 +166,8 @@ 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:
|
||||||
setting = self._device.settings[self.entity_description.key]
|
self._device.settings[self.entity_description.key].value = value
|
||||||
if not (
|
await self.coordinator.async_request_refresh()
|
||||||
isinstance(setting, HonParameter) or isinstance(setting, HonParameterFixed)
|
|
||||||
):
|
|
||||||
setting.value = value
|
|
||||||
if "settings." in self.entity_description.key:
|
|
||||||
await self._device.commands["settings"].send()
|
|
||||||
await self.coordinator.async_refresh()
|
|
||||||
|
|
||||||
@callback
|
@callback
|
||||||
def _handle_coordinator_update(self):
|
def _handle_coordinator_update(self):
|
||||||
@ -232,16 +178,3 @@ 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."""
|
|
||||||
if self.entity_category == EntityCategory.CONFIG:
|
|
||||||
return super().available
|
|
||||||
else:
|
|
||||||
return (
|
|
||||||
super().available
|
|
||||||
and self._device.get("remoteCtrValid", "1") == "1"
|
|
||||||
and self._device.get("attributes.lastConnEvent.category")
|
|
||||||
!= "DISCONNECTED"
|
|
||||||
)
|
|
||||||
|
@ -4,15 +4,16 @@ import logging
|
|||||||
|
|
||||||
from pyhon import Hon
|
from pyhon import Hon
|
||||||
from pyhon.appliance import HonAppliance
|
from pyhon.appliance import HonAppliance
|
||||||
from pyhon.parameter.fixed import HonParameterFixed
|
from pyhon.parameter 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
|
||||||
|
|
||||||
from .const import DOMAIN
|
from .const import DOMAIN
|
||||||
from .hon import HonEntity, HonCoordinator, unique_entities
|
from .hon import HonEntity, HonCoordinator
|
||||||
|
|
||||||
_LOGGER = logging.getLogger(__name__)
|
_LOGGER = logging.getLogger(__name__)
|
||||||
|
|
||||||
@ -24,7 +25,6 @@ SELECTS = {
|
|||||||
entity_category=EntityCategory.CONFIG,
|
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",
|
|
||||||
),
|
),
|
||||||
SelectEntityDescription(
|
SelectEntityDescription(
|
||||||
key="startProgram.temp",
|
key="startProgram.temp",
|
||||||
@ -32,13 +32,12 @@ SELECTS = {
|
|||||||
entity_category=EntityCategory.CONFIG,
|
entity_category=EntityCategory.CONFIG,
|
||||||
icon="mdi:thermometer",
|
icon="mdi:thermometer",
|
||||||
unit_of_measurement=UnitOfTemperature.CELSIUS,
|
unit_of_measurement=UnitOfTemperature.CELSIUS,
|
||||||
translation_key="temperature",
|
|
||||||
),
|
),
|
||||||
SelectEntityDescription(
|
SelectEntityDescription(
|
||||||
key="startProgram.program",
|
key="startProgram.program",
|
||||||
name="Program",
|
name="Program",
|
||||||
entity_category=EntityCategory.CONFIG,
|
entity_category=EntityCategory.CONFIG,
|
||||||
translation_key="programs_wm",
|
translation_key="programs",
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
"TD": (
|
"TD": (
|
||||||
@ -46,22 +45,22 @@ SELECTS = {
|
|||||||
key="startProgram.program",
|
key="startProgram.program",
|
||||||
name="Program",
|
name="Program",
|
||||||
entity_category=EntityCategory.CONFIG,
|
entity_category=EntityCategory.CONFIG,
|
||||||
translation_key="programs_td",
|
translation_key="programs",
|
||||||
),
|
),
|
||||||
SelectEntityDescription(
|
SelectEntityDescription(
|
||||||
key="startProgram.dryTimeMM",
|
key="startProgram.dryTimeMM",
|
||||||
name="Dry Time",
|
name="Time",
|
||||||
entity_category=EntityCategory.CONFIG,
|
entity_category=EntityCategory.CONFIG,
|
||||||
icon="mdi:timer",
|
icon="mdi:timer",
|
||||||
unit_of_measurement=UnitOfTime.MINUTES,
|
unit_of_measurement=UnitOfTime.MINUTES,
|
||||||
translation_key="dry_time",
|
|
||||||
),
|
),
|
||||||
|
),
|
||||||
|
"WD": (
|
||||||
SelectEntityDescription(
|
SelectEntityDescription(
|
||||||
key="startProgram.dryLevel",
|
key="startProgram.program",
|
||||||
name="Dry level",
|
name="Program",
|
||||||
entity_category=EntityCategory.CONFIG,
|
entity_category=EntityCategory.CONFIG,
|
||||||
icon="mdi:hair-dryer",
|
translation_key="programs",
|
||||||
translation_key="dry_levels",
|
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
"OV": (
|
"OV": (
|
||||||
@ -69,82 +68,40 @@ SELECTS = {
|
|||||||
key="startProgram.program",
|
key="startProgram.program",
|
||||||
name="Program",
|
name="Program",
|
||||||
entity_category=EntityCategory.CONFIG,
|
entity_category=EntityCategory.CONFIG,
|
||||||
translation_key="programs_ov",
|
translation_key="programs",
|
||||||
|
),
|
||||||
|
SelectEntityDescription(
|
||||||
|
key="startProgram.preheatStatus",
|
||||||
|
name="Preheat",
|
||||||
|
entity_category=EntityCategory.CONFIG,
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
"IH": (
|
"IV": (
|
||||||
SelectEntityDescription(
|
SelectEntityDescription(
|
||||||
key="startProgram.program",
|
key="startProgram.program",
|
||||||
name="Program",
|
name="Program",
|
||||||
entity_category=EntityCategory.CONFIG,
|
entity_category=EntityCategory.CONFIG,
|
||||||
translation_key="programs_ih",
|
translation_key="programs",
|
||||||
),
|
|
||||||
),
|
|
||||||
"DW": (
|
|
||||||
SelectEntityDescription(
|
|
||||||
key="startProgram.program",
|
|
||||||
name="Program",
|
|
||||||
entity_category=EntityCategory.CONFIG,
|
|
||||||
translation_key="programs_dw",
|
|
||||||
),
|
|
||||||
SelectEntityDescription(
|
|
||||||
key="startProgram.temp",
|
|
||||||
name="Temperature",
|
|
||||||
entity_category=EntityCategory.CONFIG,
|
|
||||||
icon="mdi:thermometer",
|
|
||||||
unit_of_measurement=UnitOfTemperature.CELSIUS,
|
|
||||||
translation_key="temperature",
|
|
||||||
),
|
|
||||||
SelectEntityDescription(
|
|
||||||
key="startProgram.remainingTime",
|
|
||||||
name="Remaining Time",
|
|
||||||
entity_category=EntityCategory.CONFIG,
|
|
||||||
icon="mdi:timer",
|
|
||||||
unit_of_measurement=UnitOfTime.MINUTES,
|
|
||||||
translation_key="remaining_time",
|
|
||||||
),
|
|
||||||
),
|
|
||||||
"AC": (
|
|
||||||
SelectEntityDescription(
|
|
||||||
key="startProgram.program",
|
|
||||||
name="Program",
|
|
||||||
translation_key="programs_ac",
|
|
||||||
),
|
|
||||||
SelectEntityDescription(
|
|
||||||
key="settings.humanSensingStatus",
|
|
||||||
name="Eco Pilot",
|
|
||||||
icon="mdi:run",
|
|
||||||
translation_key="eco_pilot",
|
|
||||||
),
|
|
||||||
),
|
|
||||||
"REF": (
|
|
||||||
SelectEntityDescription(
|
|
||||||
key="startProgram.program",
|
|
||||||
name="Program",
|
|
||||||
entity_category=EntityCategory.CONFIG,
|
|
||||||
translation_key="programs_ref",
|
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
}
|
}
|
||||||
|
|
||||||
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]
|
hon: Hon = hass.data[DOMAIN][entry.unique_id]
|
||||||
coordinators = hass.data[DOMAIN]["coordinators"]
|
coordinators = hass.data[DOMAIN]["coordinators"]
|
||||||
appliances = []
|
appliances = []
|
||||||
for device in hon.appliances:
|
for device in hon.appliances:
|
||||||
if device.unique_id in coordinators:
|
if device.mac_address in coordinators:
|
||||||
coordinator = hass.data[DOMAIN]["coordinators"][device.unique_id]
|
coordinator = hass.data[DOMAIN]["coordinators"][device.mac_address]
|
||||||
else:
|
else:
|
||||||
coordinator = HonCoordinator(hass, device)
|
coordinator = HonCoordinator(hass, device)
|
||||||
hass.data[DOMAIN]["coordinators"][device.unique_id] = coordinator
|
hass.data[DOMAIN]["coordinators"][device.mac_address] = coordinator
|
||||||
await coordinator.async_config_entry_first_refresh()
|
await coordinator.async_config_entry_first_refresh()
|
||||||
|
|
||||||
if descriptions := SELECTS.get(device.appliance_type):
|
if descriptions := SELECTS.get(device.appliance_type):
|
||||||
for description in descriptions:
|
for description in descriptions:
|
||||||
if description.key not in device.available_settings:
|
if not device.settings.get(description.key):
|
||||||
continue
|
continue
|
||||||
appliances.extend(
|
appliances.extend(
|
||||||
[HonSelectEntity(hass, coordinator, entry, device, description)]
|
[HonSelectEntity(hass, coordinator, entry, device, description)]
|
||||||
@ -158,53 +115,35 @@ class HonSelectEntity(HonEntity, SelectEntity):
|
|||||||
) -> None:
|
) -> None:
|
||||||
super().__init__(hass, entry, coordinator, device)
|
super().__init__(hass, entry, coordinator, device)
|
||||||
|
|
||||||
|
self._coordinator = coordinator
|
||||||
|
self._device = device
|
||||||
self.entity_description = description
|
self.entity_description = description
|
||||||
self._attr_unique_id = f"{super().unique_id}{description.key}"
|
self._attr_unique_id = f"{super().unique_id}{description.key}"
|
||||||
|
|
||||||
if not (setting := self._device.settings.get(description.key)):
|
if not isinstance(self._device.settings[description.key], HonParameterFixed):
|
||||||
self._attr_options: list[str] = []
|
self._attr_options: list[str] = device.settings[description.key].values
|
||||||
elif not isinstance(setting, HonParameterFixed):
|
|
||||||
self._attr_options: list[str] = setting.values
|
|
||||||
else:
|
else:
|
||||||
self._attr_options: list[str] = [setting.value]
|
self._attr_options: list[str] = [device.settings[description.key].value]
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def current_option(self) -> str | None:
|
def current_option(self) -> str | None:
|
||||||
value = self._device.settings.get(self.entity_description.key)
|
value = self._device.settings[self.entity_description.key].value
|
||||||
if value is None or value.value not in self._attr_options:
|
if value is None or value not in self._attr_options:
|
||||||
return None
|
return None
|
||||||
return value.value
|
return value
|
||||||
|
|
||||||
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
|
||||||
if "settings." in self.entity_description.key:
|
await self.coordinator.async_request_refresh()
|
||||||
await self._device.commands["settings"].send()
|
|
||||||
elif self._device.appliance_type in ["AC"]:
|
|
||||||
await self._device.commands["startProgram"].send()
|
|
||||||
await self.coordinator.async_refresh()
|
|
||||||
|
|
||||||
@callback
|
@callback
|
||||||
def _handle_coordinator_update(self):
|
def _handle_coordinator_update(self):
|
||||||
setting = self._device.settings.get(self.entity_description.key)
|
setting = self._device.settings[self.entity_description.key]
|
||||||
if setting is None:
|
if not isinstance(
|
||||||
self._attr_available = False
|
self._device.settings[self.entity_description.key], HonParameterFixed
|
||||||
self._attr_options: list[str] = []
|
):
|
||||||
self._attr_native_value = None
|
|
||||||
else:
|
|
||||||
self._attr_available = True
|
|
||||||
self._attr_options: list[str] = setting.values
|
self._attr_options: list[str] = setting.values
|
||||||
self._attr_native_value = setting.value
|
|
||||||
self.async_write_ha_state()
|
|
||||||
|
|
||||||
@property
|
|
||||||
def available(self) -> bool:
|
|
||||||
"""Return True if entity is available."""
|
|
||||||
if self.entity_category == EntityCategory.CONFIG:
|
|
||||||
return super().available
|
|
||||||
else:
|
else:
|
||||||
return (
|
self._attr_options = [setting.value]
|
||||||
super().available
|
self._attr_native_value = setting.value
|
||||||
and self._device.get("remoteCtrValid", "1") == "1"
|
self.async_write_ha_state()
|
||||||
and self._device.get("attributes.lastConnEvent.category")
|
|
||||||
!= "DISCONNECTED"
|
|
||||||
)
|
|
||||||
|
@ -9,7 +9,6 @@ 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,
|
||||||
@ -22,30 +21,20 @@ 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 . import const
|
|
||||||
from .const import DOMAIN
|
from .const import DOMAIN
|
||||||
from .hon import HonCoordinator, HonEntity, unique_entities
|
from .hon import HonCoordinator, HonEntity
|
||||||
|
|
||||||
_LOGGER = logging.getLogger(__name__)
|
_LOGGER = logging.getLogger(__name__)
|
||||||
|
|
||||||
|
|
||||||
SENSORS: dict[str, tuple[SensorEntityDescription, ...]] = {
|
SENSORS: dict[str, tuple[SensorEntityDescription, ...]] = {
|
||||||
"WM": (
|
"WM": (
|
||||||
SensorEntityDescription(
|
|
||||||
key="prPhase",
|
|
||||||
name="Program Phase",
|
|
||||||
icon="mdi:washing-machine",
|
|
||||||
device_class=SensorDeviceClass.ENUM,
|
|
||||||
translation_key="program_phases_wm",
|
|
||||||
options=list(const.WASHING_PR_PHASE),
|
|
||||||
),
|
|
||||||
SensorEntityDescription(
|
SensorEntityDescription(
|
||||||
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(
|
SensorEntityDescription(
|
||||||
key="totalWaterUsed",
|
key="totalWaterUsed",
|
||||||
@ -53,14 +42,12 @@ SENSORS: dict[str, tuple[SensorEntityDescription, ...]] = {
|
|||||||
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(
|
SensorEntityDescription(
|
||||||
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(
|
SensorEntityDescription(
|
||||||
key="currentElectricityUsed",
|
key="currentElectricityUsed",
|
||||||
@ -69,14 +56,12 @@ SENSORS: dict[str, tuple[SensorEntityDescription, ...]] = {
|
|||||||
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(
|
SensorEntityDescription(
|
||||||
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(
|
SensorEntityDescription(
|
||||||
key="startProgram.weight",
|
key="startProgram.weight",
|
||||||
@ -85,15 +70,12 @@ SENSORS: dict[str, tuple[SensorEntityDescription, ...]] = {
|
|||||||
entity_category=EntityCategory.CONFIG,
|
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(
|
SensorEntityDescription(
|
||||||
key="machMode",
|
key="machMode",
|
||||||
name="Machine Status",
|
name="Machine Status",
|
||||||
icon="mdi:information",
|
icon="mdi:information",
|
||||||
device_class=SensorDeviceClass.ENUM,
|
translation_key="mode",
|
||||||
translation_key="washing_modes",
|
|
||||||
options=list(const.MACH_MODE),
|
|
||||||
),
|
),
|
||||||
SensorEntityDescription(
|
SensorEntityDescription(
|
||||||
key="errors", name="Error", icon="mdi:math-log", translation_key="errors"
|
key="errors", name="Error", icon="mdi:math-log", translation_key="errors"
|
||||||
@ -104,69 +86,13 @@ SENSORS: dict[str, tuple[SensorEntityDescription, ...]] = {
|
|||||||
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",
|
|
||||||
),
|
),
|
||||||
SensorEntityDescription(
|
SensorEntityDescription(
|
||||||
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=REVOLUTIONS_PER_MINUTE,
|
|
||||||
translation_key="spin_speed",
|
|
||||||
),
|
|
||||||
SensorEntityDescription(
|
|
||||||
key="startProgram.energyLabel",
|
|
||||||
name="Energy Label",
|
|
||||||
icon="mdi:lightning-bolt-circle",
|
|
||||||
state_class=SensorStateClass.MEASUREMENT,
|
|
||||||
entity_category=EntityCategory.CONFIG,
|
|
||||||
translation_key="energy_label",
|
|
||||||
),
|
|
||||||
SensorEntityDescription(
|
|
||||||
key="startProgram.liquidDetergentDose",
|
|
||||||
name="Liquid Detergent Dose",
|
|
||||||
icon="mdi:cup-water",
|
|
||||||
entity_category=EntityCategory.CONFIG,
|
|
||||||
translation_key="det_liquid",
|
|
||||||
),
|
|
||||||
SensorEntityDescription(
|
|
||||||
key="startProgram.powderDetergentDose",
|
|
||||||
name="Powder Detergent Dose",
|
|
||||||
icon="mdi:cup",
|
|
||||||
entity_category=EntityCategory.CONFIG,
|
|
||||||
translation_key="det_dust",
|
|
||||||
),
|
|
||||||
SensorEntityDescription(
|
|
||||||
key="startProgram.remainingTime",
|
|
||||||
name="Remaining Time",
|
|
||||||
icon="mdi:timer",
|
|
||||||
state_class=SensorStateClass.MEASUREMENT,
|
|
||||||
native_unit_of_measurement=UnitOfTime.MINUTES,
|
native_unit_of_measurement=UnitOfTime.MINUTES,
|
||||||
entity_category=EntityCategory.CONFIG,
|
|
||||||
translation_key="remaining_time",
|
|
||||||
),
|
|
||||||
SensorEntityDescription(
|
|
||||||
key="dirtyLevel",
|
|
||||||
name="Dirt level",
|
|
||||||
icon="mdi:liquid-spot",
|
|
||||||
translation_key="dirt_level",
|
|
||||||
),
|
|
||||||
SensorEntityDescription(
|
|
||||||
key="startProgram.suggestedLoadW",
|
|
||||||
name="Suggested Load",
|
|
||||||
icon="mdi:weight-kilogram",
|
|
||||||
entity_category=EntityCategory.CONFIG,
|
|
||||||
state_class=SensorStateClass.MEASUREMENT,
|
|
||||||
native_unit_of_measurement=UnitOfMass.KILOGRAMS,
|
|
||||||
translation_key="suggested_load",
|
|
||||||
),
|
|
||||||
SensorEntityDescription(
|
|
||||||
key="temp",
|
|
||||||
name="Current Temperature",
|
|
||||||
icon="mdi:thermometer",
|
|
||||||
state_class=SensorStateClass.MEASUREMENT,
|
|
||||||
native_unit_of_measurement=UnitOfTemperature.CELSIUS,
|
|
||||||
translation_key="temperature",
|
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
"TD": (
|
"TD": (
|
||||||
@ -174,9 +100,7 @@ SENSORS: dict[str, tuple[SensorEntityDescription, ...]] = {
|
|||||||
key="machMode",
|
key="machMode",
|
||||||
name="Machine Status",
|
name="Machine Status",
|
||||||
icon="mdi:information",
|
icon="mdi:information",
|
||||||
device_class=SensorDeviceClass.ENUM,
|
translation_key="mode",
|
||||||
translation_key="washing_modes",
|
|
||||||
options=list(const.MACH_MODE),
|
|
||||||
),
|
),
|
||||||
SensorEntityDescription(
|
SensorEntityDescription(
|
||||||
key="errors", name="Error", icon="mdi:math-log", translation_key="errors"
|
key="errors", name="Error", icon="mdi:math-log", translation_key="errors"
|
||||||
@ -187,7 +111,6 @@ SENSORS: dict[str, tuple[SensorEntityDescription, ...]] = {
|
|||||||
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",
|
|
||||||
),
|
),
|
||||||
SensorEntityDescription(
|
SensorEntityDescription(
|
||||||
key="delayTime",
|
key="delayTime",
|
||||||
@ -195,31 +118,24 @@ SENSORS: dict[str, tuple[SensorEntityDescription, ...]] = {
|
|||||||
icon="mdi:clock-start",
|
icon="mdi:clock-start",
|
||||||
state_class=SensorStateClass.MEASUREMENT,
|
state_class=SensorStateClass.MEASUREMENT,
|
||||||
native_unit_of_measurement=UnitOfTime.MINUTES,
|
native_unit_of_measurement=UnitOfTime.MINUTES,
|
||||||
translation_key="delay_time",
|
|
||||||
),
|
),
|
||||||
SensorEntityDescription(
|
SensorEntityDescription(
|
||||||
key="programName",
|
key="prCode",
|
||||||
name="Program",
|
name="Program",
|
||||||
icon="mdi:tumble-dryer",
|
icon="mdi:tumble-dryer",
|
||||||
device_class=SensorDeviceClass.ENUM,
|
translation_key="tumbledryerprogram",
|
||||||
translation_key="programs_td",
|
|
||||||
options=const.PROGRAMS_TD,
|
|
||||||
),
|
),
|
||||||
SensorEntityDescription(
|
SensorEntityDescription(
|
||||||
key="prPhase",
|
key="prPhase",
|
||||||
name="Program Phase",
|
name="Program Phase",
|
||||||
icon="mdi:washing-machine",
|
icon="mdi:tumble-dryer",
|
||||||
device_class=SensorDeviceClass.ENUM,
|
translation_key="tumbledryerprogramphase",
|
||||||
translation_key="program_phases_td",
|
|
||||||
options=list(const.TUMBLE_DRYER_PR_PHASE),
|
|
||||||
),
|
),
|
||||||
SensorEntityDescription(
|
SensorEntityDescription(
|
||||||
key="dryLevel",
|
key="dryLevel",
|
||||||
name="Dry level",
|
name="Dry level",
|
||||||
icon="mdi:hair-dryer",
|
icon="mdi:hair-dryer",
|
||||||
device_class=SensorDeviceClass.ENUM,
|
translation_key="tumbledryerdrylevel",
|
||||||
translation_key="dry_levels",
|
|
||||||
options=list(const.TUMBLE_DRYER_DRY_LEVEL),
|
|
||||||
),
|
),
|
||||||
SensorEntityDescription(
|
SensorEntityDescription(
|
||||||
key="tempLevel",
|
key="tempLevel",
|
||||||
@ -227,41 +143,59 @@ SENSORS: dict[str, tuple[SensorEntityDescription, ...]] = {
|
|||||||
icon="mdi:thermometer",
|
icon="mdi:thermometer",
|
||||||
translation_key="tumbledryertemplevel",
|
translation_key="tumbledryertemplevel",
|
||||||
),
|
),
|
||||||
|
),
|
||||||
|
"WD": (
|
||||||
SensorEntityDescription(
|
SensorEntityDescription(
|
||||||
key="startProgram.suggestedLoadD",
|
key="machMode",
|
||||||
name="Suggested Load",
|
name="Machine Status",
|
||||||
icon="mdi:weight-kilogram",
|
icon="mdi:information",
|
||||||
entity_category=EntityCategory.CONFIG,
|
translation_key="mode",
|
||||||
state_class=SensorStateClass.MEASUREMENT,
|
|
||||||
native_unit_of_measurement=UnitOfMass.KILOGRAMS,
|
|
||||||
translation_key="suggested_load",
|
|
||||||
),
|
),
|
||||||
SensorEntityDescription(
|
SensorEntityDescription(
|
||||||
key="startProgram.energyLabel",
|
key="spinSpeed",
|
||||||
name="Energy Label",
|
name="Spin Speed",
|
||||||
icon="mdi:lightning-bolt-circle",
|
icon="mdi:fast-forward-outline",
|
||||||
state_class=SensorStateClass.MEASUREMENT,
|
state_class=SensorStateClass.MEASUREMENT,
|
||||||
entity_category=EntityCategory.CONFIG,
|
native_unit_of_measurement=REVOLUTIONS_PER_MINUTE,
|
||||||
translation_key="energy_label",
|
|
||||||
),
|
),
|
||||||
SensorEntityDescription(
|
SensorEntityDescription(
|
||||||
key="startProgram.steamLevel",
|
key="remainingTimeMM",
|
||||||
name="Steam level",
|
name="Remaining Time",
|
||||||
icon="mdi:smoke",
|
icon="mdi:timer",
|
||||||
entity_category=EntityCategory.CONFIG,
|
state_class=SensorStateClass.MEASUREMENT,
|
||||||
translation_key="steam_level",
|
native_unit_of_measurement=UnitOfTime.MINUTES,
|
||||||
|
),
|
||||||
|
SensorEntityDescription(
|
||||||
|
key="prCode",
|
||||||
|
name="Current Program",
|
||||||
|
icon="mdi:tumble-dryer",
|
||||||
|
),
|
||||||
|
SensorEntityDescription(
|
||||||
|
key="prPhase",
|
||||||
|
name="Program Phase",
|
||||||
|
icon="mdi:tumble-dryer",
|
||||||
|
),
|
||||||
|
SensorEntityDescription(
|
||||||
|
key="dryLevel",
|
||||||
|
name="Dry level",
|
||||||
|
icon="mdi:hair-dryer",
|
||||||
|
),
|
||||||
|
SensorEntityDescription(
|
||||||
|
key="dirtyLevel",
|
||||||
|
name="Dirt level",
|
||||||
|
icon="mdi:liquid-spot",
|
||||||
),
|
),
|
||||||
SensorEntityDescription(
|
SensorEntityDescription(
|
||||||
key="steamLevel",
|
key="steamLevel",
|
||||||
name="Steam level",
|
name="Steam level",
|
||||||
icon="mdi:smoke",
|
icon="mdi:smoke",
|
||||||
translation_key="steam_level",
|
|
||||||
),
|
),
|
||||||
SensorEntityDescription(
|
SensorEntityDescription(
|
||||||
key="steamType",
|
key="temp",
|
||||||
name="Steam Type",
|
name="Current Temperature",
|
||||||
icon="mdi:weather-dust",
|
icon="mdi:thermometer",
|
||||||
entity_category=EntityCategory.CONFIG,
|
state_class=SensorStateClass.MEASUREMENT,
|
||||||
|
native_unit_of_measurement=UnitOfTemperature.CELSIUS,
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
"OV": (
|
"OV": (
|
||||||
@ -270,36 +204,29 @@ SENSORS: dict[str, tuple[SensorEntityDescription, ...]] = {
|
|||||||
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",
|
|
||||||
),
|
),
|
||||||
SensorEntityDescription(
|
SensorEntityDescription(
|
||||||
key="delayTime",
|
key="delayTime",
|
||||||
name="Start Time",
|
name="Start Time",
|
||||||
icon="mdi:clock-start",
|
icon="mdi:clock-start",
|
||||||
state_class=SensorStateClass.MEASUREMENT,
|
|
||||||
native_unit_of_measurement=UnitOfTime.MINUTES,
|
|
||||||
translation_key="delay_time",
|
|
||||||
),
|
),
|
||||||
SensorEntityDescription(
|
SensorEntityDescription(
|
||||||
key="temp",
|
key="temp",
|
||||||
name="Temperature",
|
name="Temperature",
|
||||||
icon="mdi:thermometer",
|
icon="mdi:thermometer",
|
||||||
translation_key="temperature",
|
|
||||||
),
|
),
|
||||||
SensorEntityDescription(
|
SensorEntityDescription(
|
||||||
key="tempSel",
|
key="tempSel",
|
||||||
name="Temperature Selected",
|
name="Temperature Selected",
|
||||||
icon="mdi:thermometer",
|
icon="mdi:thermometer",
|
||||||
translation_key="target_temperature",
|
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
"IH": (
|
"IV": (
|
||||||
SensorEntityDescription(
|
SensorEntityDescription(
|
||||||
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",
|
|
||||||
),
|
),
|
||||||
SensorEntityDescription(
|
SensorEntityDescription(
|
||||||
key="temp",
|
key="temp",
|
||||||
@ -307,204 +234,10 @@ SENSORS: dict[str, tuple[SensorEntityDescription, ...]] = {
|
|||||||
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,
|
||||||
translation_key="temperature",
|
|
||||||
),
|
|
||||||
SensorEntityDescription(
|
|
||||||
key="errors", name="Error", icon="mdi:math-log", translation_key="errors"
|
|
||||||
),
|
|
||||||
SensorEntityDescription(
|
|
||||||
key="power",
|
|
||||||
name="Power",
|
|
||||||
icon="mdi:lightning-bolt",
|
|
||||||
state_class=SensorStateClass.MEASUREMENT,
|
|
||||||
translation_key="power",
|
|
||||||
),
|
|
||||||
),
|
|
||||||
"DW": (
|
|
||||||
SensorEntityDescription(
|
|
||||||
key="startProgram.ecoIndex",
|
|
||||||
name="Eco Index",
|
|
||||||
icon="mdi:sprout",
|
|
||||||
state_class=SensorStateClass.MEASUREMENT,
|
|
||||||
entity_category=EntityCategory.CONFIG,
|
|
||||||
),
|
|
||||||
SensorEntityDescription(
|
|
||||||
key="startProgram.waterEfficiency",
|
|
||||||
name="Water Efficiency",
|
|
||||||
icon="mdi:water",
|
|
||||||
state_class=SensorStateClass.MEASUREMENT,
|
|
||||||
entity_category=EntityCategory.CONFIG,
|
|
||||||
translation_key="water_efficiency",
|
|
||||||
),
|
|
||||||
SensorEntityDescription(
|
|
||||||
key="startProgram.waterSaving",
|
|
||||||
name="Water Saving",
|
|
||||||
icon="mdi:water-percent",
|
|
||||||
state_class=SensorStateClass.MEASUREMENT,
|
|
||||||
native_unit_of_measurement=PERCENTAGE,
|
|
||||||
entity_category=EntityCategory.CONFIG,
|
|
||||||
translation_key="water_saving",
|
|
||||||
),
|
|
||||||
SensorEntityDescription(
|
|
||||||
key="startProgram.temp",
|
|
||||||
name="Temperature",
|
|
||||||
icon="mdi:thermometer",
|
|
||||||
state_class=SensorStateClass.MEASUREMENT,
|
|
||||||
native_unit_of_measurement=UnitOfTemperature.CELSIUS,
|
|
||||||
entity_category=EntityCategory.CONFIG,
|
|
||||||
translation_key="temperature",
|
|
||||||
),
|
|
||||||
SensorEntityDescription(
|
|
||||||
key="startProgram.energyLabel",
|
|
||||||
name="Energy Label",
|
|
||||||
icon="mdi:lightning-bolt-circle",
|
|
||||||
state_class=SensorStateClass.MEASUREMENT,
|
|
||||||
entity_category=EntityCategory.CONFIG,
|
|
||||||
translation_key="energy_label",
|
|
||||||
),
|
|
||||||
SensorEntityDescription(
|
|
||||||
key="startProgram.remainingTime",
|
|
||||||
name="Time",
|
|
||||||
icon="mdi:timer",
|
|
||||||
state_class=SensorStateClass.MEASUREMENT,
|
|
||||||
native_unit_of_measurement=UnitOfTime.MINUTES,
|
|
||||||
entity_category=EntityCategory.CONFIG,
|
|
||||||
translation_key="duration",
|
|
||||||
),
|
|
||||||
SensorEntityDescription(
|
|
||||||
key="machMode",
|
|
||||||
name="Machine Status",
|
|
||||||
icon="mdi:information",
|
|
||||||
device_class=SensorDeviceClass.ENUM,
|
|
||||||
translation_key="washing_modes",
|
|
||||||
options=list(const.MACH_MODE),
|
|
||||||
),
|
|
||||||
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="prPhase",
|
|
||||||
name="Program Phase",
|
|
||||||
icon="mdi:washing-machine",
|
|
||||||
device_class=SensorDeviceClass.ENUM,
|
|
||||||
translation_key="program_phases_dw",
|
|
||||||
options=list(const.DISHWASHER_PR_PHASE),
|
|
||||||
),
|
|
||||||
),
|
|
||||||
"AC": (
|
|
||||||
SensorEntityDescription(
|
|
||||||
key="tempAirOutdoor",
|
|
||||||
name="Air Temperature Outdoor",
|
|
||||||
icon="mdi:thermometer",
|
|
||||||
state_class=SensorStateClass.MEASUREMENT,
|
|
||||||
device_class=SensorDeviceClass.TEMPERATURE,
|
|
||||||
native_unit_of_measurement=UnitOfTemperature.CELSIUS,
|
|
||||||
),
|
|
||||||
SensorEntityDescription(
|
|
||||||
key="tempCoilerIndoor",
|
|
||||||
name="Coiler Temperature Indoor",
|
|
||||||
icon="mdi:thermometer",
|
|
||||||
state_class=SensorStateClass.MEASUREMENT,
|
|
||||||
device_class=SensorDeviceClass.TEMPERATURE,
|
|
||||||
native_unit_of_measurement=UnitOfTemperature.CELSIUS,
|
|
||||||
),
|
|
||||||
SensorEntityDescription(
|
|
||||||
key="tempCoilerOutdoor",
|
|
||||||
name="Coiler Temperature Outside",
|
|
||||||
icon="mdi:thermometer",
|
|
||||||
state_class=SensorStateClass.MEASUREMENT,
|
|
||||||
device_class=SensorDeviceClass.TEMPERATURE,
|
|
||||||
native_unit_of_measurement=UnitOfTemperature.CELSIUS,
|
|
||||||
),
|
|
||||||
SensorEntityDescription(
|
|
||||||
key="tempDefrostOutdoor",
|
|
||||||
name="Defrost Temperature Outdoor",
|
|
||||||
icon="mdi:thermometer",
|
|
||||||
state_class=SensorStateClass.MEASUREMENT,
|
|
||||||
device_class=SensorDeviceClass.TEMPERATURE,
|
|
||||||
native_unit_of_measurement=UnitOfTemperature.CELSIUS,
|
|
||||||
),
|
|
||||||
SensorEntityDescription(
|
|
||||||
key="tempInAirOutdoor",
|
|
||||||
name="In Air Temperature Outdoor",
|
|
||||||
icon="mdi:thermometer",
|
|
||||||
state_class=SensorStateClass.MEASUREMENT,
|
|
||||||
device_class=SensorDeviceClass.TEMPERATURE,
|
|
||||||
native_unit_of_measurement=UnitOfTemperature.CELSIUS,
|
|
||||||
),
|
|
||||||
SensorEntityDescription(
|
|
||||||
key="tempIndoor",
|
|
||||||
name="Indoor Temperature",
|
|
||||||
icon="mdi:thermometer",
|
|
||||||
state_class=SensorStateClass.MEASUREMENT,
|
|
||||||
device_class=SensorDeviceClass.TEMPERATURE,
|
|
||||||
native_unit_of_measurement=UnitOfTemperature.CELSIUS,
|
|
||||||
),
|
|
||||||
SensorEntityDescription(
|
|
||||||
key="tempOutdoor",
|
|
||||||
name="Outdoor Temperature",
|
|
||||||
icon="mdi:thermometer",
|
|
||||||
state_class=SensorStateClass.MEASUREMENT,
|
|
||||||
device_class=SensorDeviceClass.TEMPERATURE,
|
|
||||||
native_unit_of_measurement=UnitOfTemperature.CELSIUS,
|
|
||||||
),
|
|
||||||
SensorEntityDescription(
|
|
||||||
key="tempSel",
|
|
||||||
name="Selected Temperature",
|
|
||||||
icon="mdi:thermometer",
|
|
||||||
state_class=SensorStateClass.MEASUREMENT,
|
|
||||||
device_class=SensorDeviceClass.TEMPERATURE,
|
|
||||||
native_unit_of_measurement=UnitOfTemperature.CELSIUS,
|
|
||||||
),
|
|
||||||
),
|
|
||||||
"REF": (
|
|
||||||
SensorEntityDescription(
|
|
||||||
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",
|
|
||||||
),
|
|
||||||
SensorEntityDescription(
|
|
||||||
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",
|
|
||||||
),
|
|
||||||
SensorEntityDescription(
|
|
||||||
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",
|
|
||||||
),
|
|
||||||
SensorEntityDescription(
|
|
||||||
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",
|
|
||||||
),
|
),
|
||||||
|
SensorEntityDescription(key="errors", name="Error", icon="mdi:math-log"),
|
||||||
),
|
),
|
||||||
}
|
}
|
||||||
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:
|
||||||
@ -512,18 +245,19 @@ async def async_setup_entry(hass, entry: ConfigEntry, async_add_entities) -> Non
|
|||||||
coordinators = hass.data[DOMAIN]["coordinators"]
|
coordinators = hass.data[DOMAIN]["coordinators"]
|
||||||
appliances = []
|
appliances = []
|
||||||
for device in hon.appliances:
|
for device in hon.appliances:
|
||||||
if device.unique_id in coordinators:
|
if device.mac_address in coordinators:
|
||||||
coordinator = hass.data[DOMAIN]["coordinators"][device.unique_id]
|
coordinator = hass.data[DOMAIN]["coordinators"][device.mac_address]
|
||||||
else:
|
else:
|
||||||
coordinator = HonCoordinator(hass, device)
|
coordinator = HonCoordinator(hass, device)
|
||||||
hass.data[DOMAIN]["coordinators"][device.unique_id] = coordinator
|
hass.data[DOMAIN]["coordinators"][device.mac_address] = coordinator
|
||||||
await coordinator.async_config_entry_first_refresh()
|
await coordinator.async_config_entry_first_refresh()
|
||||||
|
|
||||||
if descriptions := SENSORS.get(device.appliance_type):
|
if descriptions := SENSORS.get(device.appliance_type):
|
||||||
for description in descriptions:
|
for description in descriptions:
|
||||||
if not device.get(description.key) and not device.settings.get(
|
if not device.get(description.key):
|
||||||
description.key
|
_LOGGER.warning(
|
||||||
):
|
"[%s] Can't setup %s", device.appliance_type, description.key
|
||||||
|
)
|
||||||
continue
|
continue
|
||||||
appliances.extend(
|
appliances.extend(
|
||||||
[HonSensorEntity(hass, coordinator, entry, device, description)]
|
[HonSensorEntity(hass, coordinator, entry, device, description)]
|
||||||
@ -536,20 +270,16 @@ class HonSensorEntity(HonEntity, SensorEntity):
|
|||||||
def __init__(self, hass, coordinator, entry, device, description) -> None:
|
def __init__(self, hass, coordinator, entry, device, description) -> None:
|
||||||
super().__init__(hass, entry, coordinator, device)
|
super().__init__(hass, entry, coordinator, device)
|
||||||
|
|
||||||
|
self._coordinator = coordinator
|
||||||
|
|
||||||
self.entity_description = description
|
self.entity_description = description
|
||||||
self._attr_unique_id = f"{super().unique_id}{description.key}"
|
self._attr_unique_id = f"{super().unique_id}{description.key}"
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def native_value(self) -> StateType:
|
def native_value(self) -> StateType:
|
||||||
value = self._device.get(self.entity_description.key, "")
|
return self._device.get(self.entity_description.key, "")
|
||||||
if not value and self.entity_description.state_class is not None:
|
|
||||||
return 0
|
|
||||||
return value
|
|
||||||
|
|
||||||
@callback
|
@callback
|
||||||
def _handle_coordinator_update(self):
|
def _handle_coordinator_update(self):
|
||||||
value = self._device.get(self.entity_description.key, "")
|
self._attr_native_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()
|
self.async_write_ha_state()
|
||||||
|
@ -1,17 +1,16 @@
|
|||||||
import logging
|
import logging
|
||||||
|
|
||||||
from dataclasses import dataclass
|
from dataclasses import dataclass
|
||||||
from typing import Any
|
from typing import Any
|
||||||
|
|
||||||
from pyhon import Hon
|
|
||||||
from pyhon.appliance import HonAppliance
|
|
||||||
from pyhon.parameter.range import HonParameterRange
|
|
||||||
|
|
||||||
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 homeassistant.core import callback
|
from pyhon import Hon
|
||||||
|
from pyhon.appliance import HonAppliance
|
||||||
|
|
||||||
from .const import DOMAIN
|
from .const import DOMAIN
|
||||||
from .hon import HonCoordinator, HonEntity, unique_entities
|
from .hon import HonCoordinator, HonEntity
|
||||||
|
|
||||||
_LOGGER = logging.getLogger(__name__)
|
_LOGGER = logging.getLogger(__name__)
|
||||||
|
|
||||||
@ -20,7 +19,6 @@ _LOGGER = logging.getLogger(__name__)
|
|||||||
class HonSwitchEntityDescriptionMixin:
|
class HonSwitchEntityDescriptionMixin:
|
||||||
turn_on_key: str = ""
|
turn_on_key: str = ""
|
||||||
turn_off_key: str = ""
|
turn_off_key: str = ""
|
||||||
status_key: str = ""
|
|
||||||
|
|
||||||
|
|
||||||
@dataclass
|
@dataclass
|
||||||
@ -38,7 +36,6 @@ SWITCHES: dict[str, tuple[HonSwitchEntityDescription, ...]] = {
|
|||||||
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="washing_machine",
|
|
||||||
),
|
),
|
||||||
HonSwitchEntityDescription(
|
HonSwitchEntityDescription(
|
||||||
key="pause",
|
key="pause",
|
||||||
@ -46,77 +43,18 @@ SWITCHES: dict[str, tuple[HonSwitchEntityDescription, ...]] = {
|
|||||||
icon="mdi:pause",
|
icon="mdi:pause",
|
||||||
turn_on_key="pauseProgram",
|
turn_on_key="pauseProgram",
|
||||||
turn_off_key="resumeProgram",
|
turn_off_key="resumeProgram",
|
||||||
translation_key="pause",
|
|
||||||
),
|
),
|
||||||
HonSwitchEntityDescription(
|
HonSwitchEntityDescription(
|
||||||
key="startProgram.delayStatus",
|
key="startProgram.delayStatus",
|
||||||
name="Delay Status",
|
name="Delay Status",
|
||||||
icon="mdi:timer-check",
|
icon="mdi:timer-check",
|
||||||
entity_category=EntityCategory.CONFIG,
|
entity_category=EntityCategory.CONFIG,
|
||||||
translation_key="delay_time",
|
|
||||||
),
|
),
|
||||||
HonSwitchEntityDescription(
|
HonSwitchEntityDescription(
|
||||||
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,
|
entity_category=EntityCategory.CONFIG,
|
||||||
translation_key="prewash",
|
|
||||||
),
|
|
||||||
HonSwitchEntityDescription(
|
|
||||||
key="startProgram.permanentPressStatus",
|
|
||||||
name="Keep Fresh",
|
|
||||||
entity_category=EntityCategory.CONFIG,
|
|
||||||
icon="mdi:refresh-circle",
|
|
||||||
translation_key="keep_fresh",
|
|
||||||
),
|
|
||||||
HonSwitchEntityDescription(
|
|
||||||
key="startProgram.autoSoftenerStatus",
|
|
||||||
name="Auto Dose Softener",
|
|
||||||
entity_category=EntityCategory.CONFIG,
|
|
||||||
icon="mdi:teddy-bear",
|
|
||||||
translation_key="auto_dose_softener",
|
|
||||||
),
|
|
||||||
HonSwitchEntityDescription(
|
|
||||||
key="startProgram.autoDetergentStatus",
|
|
||||||
name="Auto Dose Detergent",
|
|
||||||
entity_category=EntityCategory.CONFIG,
|
|
||||||
icon="mdi:cup",
|
|
||||||
translation_key="auto_dose_detergent",
|
|
||||||
),
|
|
||||||
HonSwitchEntityDescription(
|
|
||||||
key="startProgram.acquaplus",
|
|
||||||
name="Acqua Plus",
|
|
||||||
entity_category=EntityCategory.CONFIG,
|
|
||||||
icon="mdi:water-plus",
|
|
||||||
translation_key="acqua_plus",
|
|
||||||
),
|
|
||||||
HonSwitchEntityDescription(
|
|
||||||
key="startProgram.extraRinse1",
|
|
||||||
name="Extra Rinse 1",
|
|
||||||
entity_category=EntityCategory.CONFIG,
|
|
||||||
icon="mdi:numeric-1-box-multiple-outline",
|
|
||||||
translation_key="extra_rinse_1",
|
|
||||||
),
|
|
||||||
HonSwitchEntityDescription(
|
|
||||||
key="startProgram.extraRinse2",
|
|
||||||
name="Extra Rinse 2",
|
|
||||||
entity_category=EntityCategory.CONFIG,
|
|
||||||
icon="mdi:numeric-2-box-multiple-outline",
|
|
||||||
translation_key="extra_rinse_2",
|
|
||||||
),
|
|
||||||
HonSwitchEntityDescription(
|
|
||||||
key="startProgram.extraRinse3",
|
|
||||||
name="Extra Rinse 3",
|
|
||||||
entity_category=EntityCategory.CONFIG,
|
|
||||||
icon="mdi:numeric-3-box-multiple-outline",
|
|
||||||
translation_key="extra_rinse_3",
|
|
||||||
),
|
|
||||||
HonSwitchEntityDescription(
|
|
||||||
key="startProgram.goodNight",
|
|
||||||
name="Good Night",
|
|
||||||
icon="mdi:weather-night",
|
|
||||||
entity_category=EntityCategory.CONFIG,
|
|
||||||
translation_key="good_night",
|
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
"TD": (
|
"TD": (
|
||||||
@ -126,7 +64,6 @@ SWITCHES: dict[str, tuple[HonSwitchEntityDescription, ...]] = {
|
|||||||
icon="mdi:tumble-dryer",
|
icon="mdi:tumble-dryer",
|
||||||
turn_on_key="startProgram",
|
turn_on_key="startProgram",
|
||||||
turn_off_key="stopProgram",
|
turn_off_key="stopProgram",
|
||||||
translation_key="tumble_dryer",
|
|
||||||
),
|
),
|
||||||
HonSwitchEntityDescription(
|
HonSwitchEntityDescription(
|
||||||
key="pause",
|
key="pause",
|
||||||
@ -134,243 +71,52 @@ SWITCHES: dict[str, tuple[HonSwitchEntityDescription, ...]] = {
|
|||||||
icon="mdi:pause",
|
icon="mdi:pause",
|
||||||
turn_on_key="pauseProgram",
|
turn_on_key="pauseProgram",
|
||||||
turn_off_key="resumeProgram",
|
turn_off_key="resumeProgram",
|
||||||
translation_key="pause",
|
|
||||||
),
|
|
||||||
HonSwitchEntityDescription(
|
|
||||||
key="startProgram.sterilizationStatus",
|
|
||||||
name="Sterilization",
|
|
||||||
icon="mdi:clock-start",
|
|
||||||
entity_category=EntityCategory.CONFIG,
|
|
||||||
),
|
|
||||||
HonSwitchEntityDescription(
|
|
||||||
key="startProgram.antiCreaseTime",
|
|
||||||
name="Anti-Crease",
|
|
||||||
entity_category=EntityCategory.CONFIG,
|
|
||||||
icon="mdi:timer",
|
|
||||||
translation_key="anti_crease",
|
|
||||||
),
|
|
||||||
HonSwitchEntityDescription(
|
|
||||||
key="startProgram.anticrease",
|
|
||||||
name="Anti-Crease",
|
|
||||||
entity_category=EntityCategory.CONFIG,
|
|
||||||
icon="mdi:timer",
|
|
||||||
translation_key="anti_crease",
|
|
||||||
),
|
|
||||||
),
|
|
||||||
"OV": (
|
|
||||||
HonSwitchEntityDescription(
|
|
||||||
key="active",
|
|
||||||
name="Oven",
|
|
||||||
icon="mdi:toaster-oven",
|
|
||||||
turn_on_key="startProgram",
|
|
||||||
turn_off_key="stopProgram",
|
|
||||||
translation_key="oven",
|
|
||||||
),
|
|
||||||
HonSwitchEntityDescription(
|
|
||||||
key="startProgram.preheatStatus",
|
|
||||||
name="Preheat",
|
|
||||||
icon="mdi:thermometer-chevron-up",
|
|
||||||
entity_category=EntityCategory.CONFIG,
|
|
||||||
translation_key="preheat",
|
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
"WD": (
|
"WD": (
|
||||||
HonSwitchEntityDescription(
|
HonSwitchEntityDescription(
|
||||||
key="active",
|
key="active",
|
||||||
name="Washer Dryer",
|
name="Washing Machine",
|
||||||
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",
|
|
||||||
),
|
),
|
||||||
HonSwitchEntityDescription(
|
HonSwitchEntityDescription(
|
||||||
key="pause",
|
key="pause",
|
||||||
name="Pause Washer Dryer",
|
name="Pause Washing Machine",
|
||||||
icon="mdi:pause",
|
icon="mdi:pause",
|
||||||
turn_on_key="pauseProgram",
|
turn_on_key="pauseProgram",
|
||||||
turn_off_key="resumeProgram",
|
turn_off_key="resumeProgram",
|
||||||
translation_key="pause",
|
|
||||||
),
|
|
||||||
),
|
|
||||||
"DW": (
|
|
||||||
HonSwitchEntityDescription(
|
|
||||||
key="active",
|
|
||||||
name="Dish Washer",
|
|
||||||
icon="mdi:dishwasher",
|
|
||||||
turn_on_key="startProgram",
|
|
||||||
turn_off_key="stopProgram",
|
|
||||||
translation_key="dish_washer",
|
|
||||||
),
|
|
||||||
HonSwitchEntityDescription(
|
|
||||||
key="startProgram.extraDry",
|
|
||||||
name="Extra Dry",
|
|
||||||
icon="mdi:hair-dryer",
|
|
||||||
entity_category=EntityCategory.CONFIG,
|
|
||||||
translation_key="extra_dry",
|
|
||||||
),
|
|
||||||
HonSwitchEntityDescription(
|
|
||||||
key="startProgram.halfLoad",
|
|
||||||
name="Half Load",
|
|
||||||
icon="mdi:fraction-one-half",
|
|
||||||
entity_category=EntityCategory.CONFIG,
|
|
||||||
translation_key="half_load",
|
|
||||||
),
|
|
||||||
HonSwitchEntityDescription(
|
|
||||||
key="startProgram.openDoor",
|
|
||||||
name="Open Door",
|
|
||||||
icon="mdi:door-open",
|
|
||||||
entity_category=EntityCategory.CONFIG,
|
|
||||||
translation_key="open_door",
|
|
||||||
),
|
|
||||||
HonSwitchEntityDescription(
|
|
||||||
key="startProgram.threeInOne",
|
|
||||||
name="Three in One",
|
|
||||||
icon="mdi:numeric-3-box-outline",
|
|
||||||
entity_category=EntityCategory.CONFIG,
|
|
||||||
translation_key="three_in_one",
|
|
||||||
),
|
|
||||||
HonSwitchEntityDescription(
|
|
||||||
key="startProgram.ecoExpress",
|
|
||||||
name="Eco Express",
|
|
||||||
icon="mdi:sprout",
|
|
||||||
entity_category=EntityCategory.CONFIG,
|
|
||||||
translation_key="eco",
|
|
||||||
),
|
|
||||||
HonSwitchEntityDescription(
|
|
||||||
key="startProgram.addDish",
|
|
||||||
name="Add Dish",
|
|
||||||
icon="mdi:silverware-fork-knife",
|
|
||||||
entity_category=EntityCategory.CONFIG,
|
|
||||||
translation_key="add_dish",
|
|
||||||
),
|
|
||||||
HonSwitchEntityDescription(
|
|
||||||
key="settings.buzzerDisabled",
|
|
||||||
name="Buzzer Disabled",
|
|
||||||
icon="mdi:volume-off",
|
|
||||||
translation_key="buzzer",
|
|
||||||
),
|
|
||||||
),
|
|
||||||
"AC": (
|
|
||||||
HonSwitchEntityDescription(
|
|
||||||
key="settings.10degreeHeatingStatus",
|
|
||||||
status_key="10degreeHeatingStatus",
|
|
||||||
name="10° Heating",
|
|
||||||
icon="mdi:heat-wave",
|
|
||||||
translation_key="10_degree_heating",
|
|
||||||
),
|
|
||||||
HonSwitchEntityDescription(
|
|
||||||
key="settings.echoStatus",
|
|
||||||
status_key="echoStatus",
|
|
||||||
name="Echo",
|
|
||||||
icon="mdi:account-voice",
|
|
||||||
),
|
|
||||||
HonSwitchEntityDescription(
|
|
||||||
key="settings.ecoMode",
|
|
||||||
name="Eco Mode",
|
|
||||||
translation_key="eco_mode",
|
|
||||||
),
|
|
||||||
HonSwitchEntityDescription(
|
|
||||||
key="settings.healthMode",
|
|
||||||
status_key="healthMode",
|
|
||||||
name="Health Mode",
|
|
||||||
icon="mdi:medication-outline",
|
|
||||||
),
|
|
||||||
HonSwitchEntityDescription(
|
|
||||||
key="settings.muteStatus",
|
|
||||||
status_key="muteStatus",
|
|
||||||
name="Mute",
|
|
||||||
icon="mdi:volume-off",
|
|
||||||
translation_key="mute_mode",
|
|
||||||
),
|
|
||||||
HonSwitchEntityDescription(
|
|
||||||
key="settings.rapidMode",
|
|
||||||
status_key="rapidMode",
|
|
||||||
name="Rapid Mode",
|
|
||||||
icon="mdi:run-fast",
|
|
||||||
translation_key="rapid_mode",
|
|
||||||
),
|
|
||||||
HonSwitchEntityDescription(
|
|
||||||
key="settings.screenDisplayStatus",
|
|
||||||
status_key="screenDisplayStatus",
|
|
||||||
name="Screen Display",
|
|
||||||
icon="mdi:monitor-small",
|
|
||||||
),
|
|
||||||
HonSwitchEntityDescription(
|
|
||||||
key="settings.selfCleaning56Status",
|
|
||||||
name="Self Cleaning 56",
|
|
||||||
icon="mdi:air-filter",
|
|
||||||
translation_key="self_clean_56",
|
|
||||||
),
|
|
||||||
HonSwitchEntityDescription(
|
|
||||||
key="settings.selfCleaningStatus",
|
|
||||||
status_key="selfCleaningStatus",
|
|
||||||
name="Self Cleaning",
|
|
||||||
icon="mdi:air-filter",
|
|
||||||
translation_key="self_clean",
|
|
||||||
),
|
|
||||||
HonSwitchEntityDescription(
|
|
||||||
key="settings.silentSleepStatus",
|
|
||||||
status_key="silentSleepStatus",
|
|
||||||
name="Silent Sleep",
|
|
||||||
icon="mdi:bed",
|
|
||||||
translation_key="silent_mode",
|
|
||||||
),
|
|
||||||
),
|
|
||||||
"REF": (
|
|
||||||
HonSwitchEntityDescription(
|
|
||||||
key="settings.intelligenceMode",
|
|
||||||
name="Auto-Set Mode",
|
|
||||||
icon="mdi:thermometer-auto",
|
|
||||||
translation_key="auto_set",
|
|
||||||
),
|
|
||||||
HonSwitchEntityDescription(
|
|
||||||
key="settings.quickModeZ1",
|
|
||||||
name="Super Freeze",
|
|
||||||
icon="mdi:snowflake-variant",
|
|
||||||
translation_key="super_freeze",
|
|
||||||
),
|
|
||||||
HonSwitchEntityDescription(
|
|
||||||
key="settings.quickModeZ2",
|
|
||||||
name="Super Cool",
|
|
||||||
icon="mdi:snowflake",
|
|
||||||
translation_key="super_cool",
|
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
}
|
}
|
||||||
|
|
||||||
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]
|
hon: Hon = hass.data[DOMAIN][entry.unique_id]
|
||||||
coordinators = hass.data[DOMAIN]["coordinators"]
|
coordinators = hass.data[DOMAIN]["coordinators"]
|
||||||
appliances = []
|
appliances = []
|
||||||
for device in hon.appliances:
|
for device in hon.appliances:
|
||||||
if device.unique_id in coordinators:
|
if device.mac_address in coordinators:
|
||||||
coordinator = hass.data[DOMAIN]["coordinators"][device.unique_id]
|
coordinator = hass.data[DOMAIN]["coordinators"][device.mac_address]
|
||||||
else:
|
else:
|
||||||
coordinator = HonCoordinator(hass, device)
|
coordinator = HonCoordinator(hass, device)
|
||||||
hass.data[DOMAIN]["coordinators"][device.unique_id] = coordinator
|
hass.data[DOMAIN]["coordinators"][device.mac_address] = coordinator
|
||||||
await coordinator.async_config_entry_first_refresh()
|
await coordinator.async_config_entry_first_refresh()
|
||||||
|
|
||||||
if descriptions := SWITCHES.get(device.appliance_type):
|
if descriptions := SWITCHES.get(device.appliance_type):
|
||||||
for description in descriptions:
|
for description in descriptions:
|
||||||
if description.entity_category == EntityCategory.CONFIG:
|
if (
|
||||||
if description.key not in device.available_settings:
|
device.get(description.key) is not None
|
||||||
continue
|
or device.commands.get(description.key) is not None
|
||||||
|
):
|
||||||
|
appliances.extend(
|
||||||
|
[HonSwitchEntity(hass, coordinator, entry, device, description)]
|
||||||
|
)
|
||||||
else:
|
else:
|
||||||
if not any(
|
_LOGGER.warning(
|
||||||
[
|
"[%s] Can't setup %s", device.appliance_type, description.key
|
||||||
device.get(description.key) is not None,
|
)
|
||||||
description.turn_on_key in list(device.commands),
|
|
||||||
description.turn_off_key in list(device.commands),
|
|
||||||
]
|
|
||||||
):
|
|
||||||
continue
|
|
||||||
appliances.extend(
|
|
||||||
[HonSwitchEntity(hass, coordinator, entry, device, description)]
|
|
||||||
)
|
|
||||||
|
|
||||||
async_add_entities(appliances)
|
async_add_entities(appliances)
|
||||||
|
|
||||||
@ -387,10 +133,18 @@ class HonSwitchEntity(HonEntity, SwitchEntity):
|
|||||||
description: HonSwitchEntityDescription,
|
description: HonSwitchEntityDescription,
|
||||||
) -> None:
|
) -> None:
|
||||||
super().__init__(hass, entry, coordinator, device)
|
super().__init__(hass, entry, coordinator, device)
|
||||||
|
self._coordinator = coordinator
|
||||||
|
self._device = device
|
||||||
self.entity_description = description
|
self.entity_description = description
|
||||||
self._attr_unique_id = f"{super().unique_id}{description.key}"
|
self._attr_unique_id = f"{super().unique_id}{description.key}"
|
||||||
|
|
||||||
|
def available(self) -> bool:
|
||||||
|
if self.entity_category == EntityCategory.CONFIG:
|
||||||
|
return (
|
||||||
|
self._device.settings[self.entity_description.key].typology != "fixed"
|
||||||
|
)
|
||||||
|
return True
|
||||||
|
|
||||||
@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."""
|
||||||
@ -401,59 +155,20 @@ class HonSwitchEntity(HonEntity, SwitchEntity):
|
|||||||
or hasattr(setting, "min")
|
or hasattr(setting, "min")
|
||||||
and setting.value != setting.min
|
and setting.value != setting.min
|
||||||
)
|
)
|
||||||
elif self.entity_description.status_key:
|
|
||||||
return self._device.get(self.entity_description.status_key, "0") == "1"
|
|
||||||
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 (
|
if self.entity_category == EntityCategory.CONFIG:
|
||||||
self.entity_category == EntityCategory.CONFIG
|
|
||||||
or "settings." in self.entity_description.key
|
|
||||||
):
|
|
||||||
setting = self._device.settings[self.entity_description.key]
|
setting = self._device.settings[self.entity_description.key]
|
||||||
setting.value = (
|
setting.value = setting.max
|
||||||
setting.max if isinstance(setting, HonParameterRange) else "1"
|
|
||||||
)
|
|
||||||
self.async_write_ha_state()
|
self.async_write_ha_state()
|
||||||
if "settings." in self.entity_description.key:
|
|
||||||
await self._device.commands["settings"].send()
|
|
||||||
await self.coordinator.async_refresh()
|
|
||||||
else:
|
else:
|
||||||
await self._device.commands[self.entity_description.turn_on_key].send()
|
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 (
|
if self.entity_category == EntityCategory.CONFIG:
|
||||||
self.entity_category == EntityCategory.CONFIG
|
|
||||||
or "settings." in self.entity_description.key
|
|
||||||
):
|
|
||||||
setting = self._device.settings[self.entity_description.key]
|
setting = self._device.settings[self.entity_description.key]
|
||||||
setting.value = (
|
setting.value = setting.min
|
||||||
setting.min if isinstance(setting, HonParameterRange) else "0"
|
|
||||||
)
|
|
||||||
self.async_write_ha_state()
|
self.async_write_ha_state()
|
||||||
if "settings." in self.entity_description.key:
|
|
||||||
await self._device.commands["settings"].send()
|
|
||||||
await self.coordinator.async_refresh()
|
|
||||||
else:
|
else:
|
||||||
await self._device.commands[self.entity_description.turn_off_key].send()
|
await self._device.commands[self.entity_description.turn_off_key].send()
|
||||||
|
|
||||||
@property
|
|
||||||
def available(self) -> bool:
|
|
||||||
"""Return True if entity is available."""
|
|
||||||
if self.entity_category == EntityCategory.CONFIG:
|
|
||||||
return super().available
|
|
||||||
else:
|
|
||||||
return (
|
|
||||||
super().available
|
|
||||||
and self._device.get("remoteCtrValid", "1") == "1"
|
|
||||||
and self._device.get("attributes.lastConnEvent.category")
|
|
||||||
!= "DISCONNECTED"
|
|
||||||
)
|
|
||||||
|
|
||||||
@callback
|
|
||||||
def _handle_coordinator_update(self):
|
|
||||||
if not self.entity_description.status_key:
|
|
||||||
return
|
|
||||||
value = self._device.get(self.entity_description.status_key, "0")
|
|
||||||
self._attr_state = value == "1"
|
|
||||||
self.async_write_ha_state()
|
|
||||||
|
@ -30,7 +30,7 @@
|
|||||||
"8000000000000": "E4: Провери подаването на вода"
|
"8000000000000": "E4: Провери подаването на вода"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"programs": {
|
"tumbledryerprogram": {
|
||||||
"state": {
|
"state": {
|
||||||
"0": "Стандартна",
|
"0": "Стандартна",
|
||||||
"62": "Памук",
|
"62": "Памук",
|
||||||
@ -49,7 +49,7 @@
|
|||||||
"103": "Отдалечен"
|
"103": "Отдалечен"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"program_phases_td": {
|
"tumbledryerprogramphase": {
|
||||||
"state": {
|
"state": {
|
||||||
"0": "Изчаване",
|
"0": "Изчаване",
|
||||||
"2": "Сушене",
|
"2": "Сушене",
|
||||||
@ -65,7 +65,7 @@
|
|||||||
"4": "Висока температура L-3"
|
"4": "Висока температура L-3"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"dry_levels": {
|
"tumbledryerdrylevel": {
|
||||||
"state": {
|
"state": {
|
||||||
"3": "Готови за съхранение",
|
"3": "Готови за съхранение",
|
||||||
"12": "Готови за гладене H-1",
|
"12": "Готови за гладене H-1",
|
||||||
@ -75,12 +75,334 @@
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
"select": {
|
"select": {
|
||||||
"dry_levels": {
|
"programs": {
|
||||||
"state": {
|
"state": {
|
||||||
"3": "Готови за съхранение",
|
"20_degrees_coloured_cottons": "20° Colored and Cottons",
|
||||||
"12": "Готови за гладене H-1",
|
"20_degrees_new_energy_label": "20°C",
|
||||||
"13": "Готови за съхранение H-2",
|
"active_steam": "Steam",
|
||||||
"14": "Екстра сухо H-3"
|
"active_wash": "Active Wash",
|
||||||
|
"active_wash_steam": "Active Wash + Steam",
|
||||||
|
"allergy_care": "Allergy Care",
|
||||||
|
"allergy_care_pro": "Allergy Care Pro",
|
||||||
|
"all_in_one_49": "All in One 49'",
|
||||||
|
"all_in_one_59": "All in One 59'",
|
||||||
|
"all_in_one_59_steam": "Active Wash + Steam",
|
||||||
|
"autocare": "Autocare",
|
||||||
|
"autoclean": "Drum Cleaning",
|
||||||
|
"baby_60": "All Baby 60°C",
|
||||||
|
"care_14": "Rapid Care 14'",
|
||||||
|
"care_30": "Rapid Care 30'",
|
||||||
|
"care_44": "Rapid Care 44'",
|
||||||
|
"checkup": "Check-Up",
|
||||||
|
"colour_59": "Colored 59'",
|
||||||
|
"colour_59_steam": "Colored 59' + Steam",
|
||||||
|
"cottons": "Cotton",
|
||||||
|
"cottons_prewash": "Cottons + Prewash",
|
||||||
|
"cottons_steam": "Cotton + Steam",
|
||||||
|
"cotton_care_59": "Cotton Care 59'",
|
||||||
|
"delicate_59": "Delicate 59'",
|
||||||
|
"delicate_silk": "Delicate and Silk",
|
||||||
|
"delicate_silk_steam": "Delicate and Silk + Steam",
|
||||||
|
"delicati_59": "Delicate 59'",
|
||||||
|
"delicati_59_steam": "Delicate 59' + Steam",
|
||||||
|
"drain_spin": "Drain + Spin",
|
||||||
|
"easy_iron": "Easy Iron",
|
||||||
|
"eco_40_60_new_energy_label": "Eco 40-60",
|
||||||
|
"extra_care": "Extra Care",
|
||||||
|
"fitness": "Fitness Care",
|
||||||
|
"fitness_care": "Fitness Care",
|
||||||
|
"fresh_care": "Fresh Care",
|
||||||
|
"fresh_care_steam": "Fresh Care + Steam",
|
||||||
|
"handwash_wool": "Hand Wash + Wool",
|
||||||
|
"high_dry": "High Heat Dry",
|
||||||
|
"hqd_20_degrees": "Cotton 20℃",
|
||||||
|
"hqd_allergy": "Allergy Care",
|
||||||
|
"hqd_autoclean": "Автоматично почистване",
|
||||||
|
"hqd_babycare": "Бебе",
|
||||||
|
"hqd_baby_care": "Бебе",
|
||||||
|
"hqd_bath_towel": "Хавлиени кърпи",
|
||||||
|
"hqd_bed_sheets": "Чаршафи",
|
||||||
|
"hqd_checkup": "Check-Up",
|
||||||
|
"hqd_bulky": "Обемисти",
|
||||||
|
"hqd_casual": "Ежедневни",
|
||||||
|
"hqd_cold_wind_30": "Студен бриз 30 мин",
|
||||||
|
"hqd_cold_wind_timing": "Студен бриз за време",
|
||||||
|
"hqd_cotton": "Памук",
|
||||||
|
"hqd_cottons": "Памук",
|
||||||
|
"hqd_curtain": "Пердета",
|
||||||
|
"hqd_delicate": "Деликатни",
|
||||||
|
"hqd_delicate_cradle": "Деликатни",
|
||||||
|
"hqd_diaper": "Бебешки пелени",
|
||||||
|
"hqd_dry": "Cotton Dry",
|
||||||
|
"hqd_dry_synthetics": "Low Heat Dry",
|
||||||
|
"hqd_duvet": "Олекотени завивки",
|
||||||
|
"hqd_eco_40_60_degrees": "Eco 40-60",
|
||||||
|
"hqd_feather": "Пълнеж от пера(пух)",
|
||||||
|
"hqd_handwash_wool": "Wool",
|
||||||
|
"hqd_hot_wind_timing": "Горещ въздух за време",
|
||||||
|
"hqd_hygienic": "Здравословна",
|
||||||
|
"hqd_i_refresh": "i-Refresh",
|
||||||
|
"hqd_i_refresh_pro": "i-Refresh Pro",
|
||||||
|
"hqd_jacket": "Якета",
|
||||||
|
"hqd_jeans": "Дънки",
|
||||||
|
"hqd_luxury": "Луксозно",
|
||||||
|
"hqd_mix": "Смесен тип",
|
||||||
|
"hqd_night_dry": "Сушене през ноща",
|
||||||
|
"hqd_outdoor": "Дрехи за открито",
|
||||||
|
"hqd_precious_cure": "Precious cure",
|
||||||
|
"hqd_quick_15": "Бързо 15 мин",
|
||||||
|
"hqd_quick_20": "Бързо 20 мин",
|
||||||
|
"hqd_quick_30": "Бързо 30 мин",
|
||||||
|
"hqd_quick_dry": "Бързо",
|
||||||
|
"hqd_quick_wash_57": "Quick Wash 57'",
|
||||||
|
"hqd_quilt": "Юргани",
|
||||||
|
"hqd_rapid_wash_and_dry": "Wash and dry",
|
||||||
|
"hqd_refresh": "Освежаване",
|
||||||
|
"hqd_rinse": "Rinses",
|
||||||
|
"hqd_school_uniform": "Ученически униформи",
|
||||||
|
"hqd_shirt": "Ризи",
|
||||||
|
"hqd_shirts": "Ризи",
|
||||||
|
"hqd_shoes": "Обувки",
|
||||||
|
"hqd_silk": "Коприна",
|
||||||
|
"hqd_smart": "Smart A.I.",
|
||||||
|
"hqd_spin": "Spin",
|
||||||
|
"hqd_sport": "Спорт",
|
||||||
|
"hqd_sports": "Спорт",
|
||||||
|
"hqd_synthetics": "Синтетика",
|
||||||
|
"hqd_super_fast": "Супер бързо 39 мин",
|
||||||
|
"hqd_synthetic_and_coloured": "Synthetics",
|
||||||
|
"hqd_timer": "Таймер",
|
||||||
|
"hqd_towel": "Хавлиени кърпи",
|
||||||
|
"hqd_underwear": "Бельо",
|
||||||
|
"hqd_warm_up": "Затопляне",
|
||||||
|
"hqd_wool": "Вълна",
|
||||||
|
"hqd_working_suit": "Работно облекло",
|
||||||
|
"hygiene_59": "Hygiene Plus 59'",
|
||||||
|
"hygiene_60": "Hygiene 60°C",
|
||||||
|
"hygiene_plus_59": "Hygiene Plus 59'",
|
||||||
|
"hygiene_plus_59_min": "Hygiene Plus 59'",
|
||||||
|
"hygiene_pro_4_min": "Hygiene Pro 49'",
|
||||||
|
"hygiene_pro_49_min": "Hygiene Pro 49'",
|
||||||
|
"hygiene_pro_steam": "Hygiene Pro + Steam",
|
||||||
|
"intensive_40": "Intensive 40°C",
|
||||||
|
"intensive_40_steam": "Intensive 40°C + Steam",
|
||||||
|
"iot_checkup": "Check-Up",
|
||||||
|
"iot_dry_air_refresh": "Air Refresh",
|
||||||
|
"iot_dry_anti_mites": "Anti-mite",
|
||||||
|
"iot_dry_baby": "Бебе",
|
||||||
|
"iot_dry_backpacks": "Раници",
|
||||||
|
"iot_dry_bathrobe": "Халати за баня",
|
||||||
|
"iot_dry_bed_linen": "Спално бельо",
|
||||||
|
"iot_dry_cotton": "Памук",
|
||||||
|
"iot_dry_cotton_dry": "Памук",
|
||||||
|
"iot_dry_cuddly_toys": "Плюшени играчки",
|
||||||
|
"iot_dry_curtains": "Пердета",
|
||||||
|
"iot_dry_dehumidifier": "Humidity Remover",
|
||||||
|
"iot_dry_delicates": "Деликатни",
|
||||||
|
"iot_dry_delicates_antiallergy": "Delicates Anti-allergy",
|
||||||
|
"iot_dry_delicate_tablecloths": "Delicate Tablecloths",
|
||||||
|
"iot_dry_denim_jeans": "Дънки",
|
||||||
|
"iot_dry_down_jacket": "Пухени якета",
|
||||||
|
"iot_dry_duvet": "Олекотени завивки",
|
||||||
|
"iot_dry_easy_iron_cotton": "Easy Iron - Cotton",
|
||||||
|
"iot_dry_easy_iron_synthetics": "Easy Iron - Synthetics",
|
||||||
|
"iot_dry_gym_fit": "Фитнес",
|
||||||
|
"iot_dry_lingerie": "Деликано бельо",
|
||||||
|
"iot_dry_mixed": "Смесен тип",
|
||||||
|
"iot_dry_mixed_dry": "Смесен тип",
|
||||||
|
"iot_dry_rapid_30": "Бързо 30 мин",
|
||||||
|
"iot_dry_rapid_59": "Бързо 59 мин",
|
||||||
|
"iot_dry_rapid_60_min_delicates": "Rapid 60' - Delicates",
|
||||||
|
"iot_dry_shirts": "Ризи",
|
||||||
|
"iot_dry_swimsuits_and_bikinis": "Бански",
|
||||||
|
"iot_dry_synthetics": "Синтетика",
|
||||||
|
"iot_dry_synthetic_dry": "Synthetic Dry",
|
||||||
|
"iot_dry_tablecloths": "Покривки",
|
||||||
|
"iot_dry_technical_fabrics": "Технически тъкани",
|
||||||
|
"iot_dry_warm_embrace": "Warm Embrace",
|
||||||
|
"iot_dry_wool": "Вълна",
|
||||||
|
"iot_dry_wool_dry": "Вълна",
|
||||||
|
"iot_wash_and_dry": "Wash and dry",
|
||||||
|
"iot_wash_anti_mites": "Anti-mites",
|
||||||
|
"iot_wash_anti_odor": "Anti-odour",
|
||||||
|
"iot_wash_ariel_clean_cycle": "Ariel Ultimate Clean",
|
||||||
|
"iot_wash_ariel_cold_cycle": "Ariel Cold Clean",
|
||||||
|
"iot_wash_ariel_fresh_cycle": "Ariel Fresh Clean",
|
||||||
|
"iot_wash_baby_sanitizer": "Sanitizer",
|
||||||
|
"iot_wash_baby_sanitizer_steam": "Sanitiser + Steam",
|
||||||
|
"iot_wash_backpacks": "Backpacks",
|
||||||
|
"iot_wash_backpacks_zelig": "Backpacks",
|
||||||
|
"iot_wash_bathrobe": "Bathrobes and Towels",
|
||||||
|
"iot_wash_bathrobe_steam": "Bathrobe and Towels + Steam",
|
||||||
|
"iot_wash_bed_linen": "Bed Linen",
|
||||||
|
"iot_wash_bed_linen_steam": "Bed Linen + Steam",
|
||||||
|
"iot_wash_bed_linen_zelig": "Bed Linens",
|
||||||
|
"iot_wash_big_single_load": "Big single load",
|
||||||
|
"iot_wash_bleaching": "Bleaching",
|
||||||
|
"iot_wash_blood_stains": "Bloodstains",
|
||||||
|
"iot_wash_cashmere": "Cashmere",
|
||||||
|
"iot_wash_chocolate_stains": "Chocolate stains",
|
||||||
|
"iot_wash_cold_wash": "Cold Wash",
|
||||||
|
"iot_wash_colored": "Colored",
|
||||||
|
"iot_wash_colored_anti_stain": "Colored Anti-stain",
|
||||||
|
"iot_wash_colored_delicate": "Colored Delicate",
|
||||||
|
"iot_wash_coloured": "Colored",
|
||||||
|
"iot_wash_coloured_bed_linen": "Colored Bed Linen",
|
||||||
|
"iot_wash_coloured_bed_linen_steam": "Coloured Bed Linen + Steam",
|
||||||
|
"iot_wash_coloured_curtains": "Colored Curtains",
|
||||||
|
"iot_wash_coloured_shirts": "Colored Shirts",
|
||||||
|
"iot_wash_coloured_shirts_steam": "Colored Shirts + Steam",
|
||||||
|
"iot_wash_coloured_steam": "Colored + Steam",
|
||||||
|
"iot_wash_coloured_tableclothes": "Colored Tableclothes",
|
||||||
|
"iot_wash_coloured_tableclothes_steam": "Coloured Tablecloths + Steam",
|
||||||
|
"iot_wash_cotton": "Cotton",
|
||||||
|
"iot_wash_cotton_steam": "Cotton + Steam",
|
||||||
|
"iot_wash_cuddly_toys": "Cuddly Toys",
|
||||||
|
"iot_wash_curtains": "Curtains",
|
||||||
|
"iot_wash_curtains_steam": "Curtains + Steam",
|
||||||
|
"iot_wash_curtains_zelig": "Curtains",
|
||||||
|
"iot_wash_dark": "Darks",
|
||||||
|
"iot_wash_darks_and_coloured_44": "Darks and Colored 44'",
|
||||||
|
"iot_wash_darks_and_coloured_59": "Darks and Colored 59'",
|
||||||
|
"iot_wash_darks_and_coloured_xl": "Darks and Colored XL",
|
||||||
|
"iot_wash_dark_steam": "Darks + Steam",
|
||||||
|
"iot_wash_dash_clean_cycle": "Dash Ultimate Clean",
|
||||||
|
"iot_wash_dash_cold_cycle": "Dash Cold Clean",
|
||||||
|
"iot_wash_dash_fresh_cycle": "Dash Fresh Clean",
|
||||||
|
"iot_wash_delicate": "Delicates",
|
||||||
|
"iot_wash_delicate_antiallergy": "Delicate Anti-Allergy",
|
||||||
|
"iot_wash_delicate_antiallergy_steam": "Delicate Anti-Allergy + Steam",
|
||||||
|
"iot_wash_delicate_antiallergy_zelig": "Delicate Anti-Allergy",
|
||||||
|
"iot_wash_delicate_colors": "Delicate Colors",
|
||||||
|
"iot_wash_delicate_colors_steam": "Delicate Colors + Steam",
|
||||||
|
"iot_wash_delicate_dark": "Delicate Darks",
|
||||||
|
"iot_wash_delicate_steam": "Delicates + Steam",
|
||||||
|
"iot_wash_delicate_tablecloths": "Delicate Tablecloths",
|
||||||
|
"iot_wash_delicate_tablecloths_steam": "Delicate Tablecloths + Steam",
|
||||||
|
"iot_wash_delicate_whites": "Delicate Whites",
|
||||||
|
"iot_wash_denim_jeans": "Denim - Jeans",
|
||||||
|
"iot_wash_diving_suits": "Diving Suits",
|
||||||
|
"iot_wash_diving_suits_zelig": "Diving Suits",
|
||||||
|
"iot_wash_down_jackets": "Down Jackets",
|
||||||
|
"iot_wash_down_jackets_zelig": "Down Jackets",
|
||||||
|
"iot_wash_duvet": "Duvet",
|
||||||
|
"iot_wash_fruit_stains": "Fruit stains",
|
||||||
|
"iot_wash_gym_fit": "Gym Fit - Fitness",
|
||||||
|
"iot_wash_handwash": "Handwash",
|
||||||
|
"iot_wash_handwash_colored": "Handwash Colored",
|
||||||
|
"iot_wash_handwash_dark": "Handwash Darks",
|
||||||
|
"iot_wash_lingerie": "Lingerie",
|
||||||
|
"iot_wash_masks_refresh": "Masks Refresh",
|
||||||
|
"iot_wash_masks_sanification": "Masks Sanitization",
|
||||||
|
"iot_wash_masks_sanification_steam": "Mask Sanitisation + Steam",
|
||||||
|
"iot_wash_mats": "Mats",
|
||||||
|
"iot_wash_men_s_trousers": "Trousers",
|
||||||
|
"iot_wash_mixed": "Mixed",
|
||||||
|
"iot_wash_mixed_steam": "Mixed + Steam",
|
||||||
|
"iot_wash_mix_and_coloured_44": "Mix and Colored 44'",
|
||||||
|
"iot_wash_mix_and_coloured_59": "Mix and Colored 59'",
|
||||||
|
"iot_wash_mix_and_coloured_xl": "Mix and colored XL",
|
||||||
|
"iot_wash_new_clothes": "New Clothes",
|
||||||
|
"iot_wash_perfect_white": "Perfect White",
|
||||||
|
"iot_wash_perfect_white_steam": "Perfect White + Steam",
|
||||||
|
"iot_wash_pets": "Pet Accessories",
|
||||||
|
"iot_wash_pets_hair_removal": "Pets Hair Removal",
|
||||||
|
"iot_wash_pets_odours_stains_removal": "Pets Odours and Stains Removal",
|
||||||
|
"iot_wash_pets_steam": "Pet Accessories + Steam",
|
||||||
|
"iot_wash_playsuits": "Playsuits",
|
||||||
|
"iot_wash_playsuits_steam": "Playsuits + Steam",
|
||||||
|
"iot_wash_quick_drum_cleaner": "Quick drum cleaner",
|
||||||
|
"iot_wash_rapid_14": "Rapid 14’",
|
||||||
|
"iot_wash_rapid_30": "Rapid 30’",
|
||||||
|
"iot_wash_rapid_44": "Rapid 44'",
|
||||||
|
"iot_wash_rapid_59": "Rapid 59'",
|
||||||
|
"iot_wash_rapid_59_steam": "Rapid 59' + Steam",
|
||||||
|
"iot_wash_refresh_14_min": "Refresh 14'",
|
||||||
|
"iot_wash_resistant_colored": "Resistant Colored",
|
||||||
|
"iot_wash_resistant_dark": "Resistant Darks",
|
||||||
|
"iot_wash_resistant_whites": "Resistant Whites",
|
||||||
|
"iot_wash_rinse": "Rinses",
|
||||||
|
"iot_wash_shirts": "Shirts",
|
||||||
|
"iot_wash_shirts_steam": "Shirts + Steam",
|
||||||
|
"iot_wash_silk": "Silk",
|
||||||
|
"iot_wash_ski_suit": "Ski Suit",
|
||||||
|
"iot_wash_ski_suit_zelig": "Ski Suit",
|
||||||
|
"iot_wash_spin": "Spin",
|
||||||
|
"iot_wash_sport": "Sport",
|
||||||
|
"iot_wash_sport_anti_odor": "Anti-odour Sportswear",
|
||||||
|
"iot_wash_sport_anti_odor_zelig": "Anti-odour Sportswear",
|
||||||
|
"iot_wash_stains_remover": "Stain Remover",
|
||||||
|
"iot_wash_swimsuits_and_bikinis": "Swimsuits and Bikinis",
|
||||||
|
"iot_wash_synthetic": "Synthetics",
|
||||||
|
"iot_wash_synthetic_steam": "Synthetics + Steam",
|
||||||
|
"iot_wash_tablecloths": "Tablecloths",
|
||||||
|
"iot_wash_tablecloths_steam": "Tablecloths + Steam",
|
||||||
|
"iot_wash_technical_fabrics": "Technical Fabrics",
|
||||||
|
"iot_wash_technical_fabrics_zelig": "Technical Fabrics",
|
||||||
|
"iot_wash_technical_jackets": "Technical Jackets",
|
||||||
|
"iot_wash_technical_jackets_zelig": "Technical Jackets",
|
||||||
|
"iot_wash_trainers": "Trainers",
|
||||||
|
"iot_wash_whites": "Whites",
|
||||||
|
"iot_wash_whites_44": "Whites 44'",
|
||||||
|
"iot_wash_whites_59": "Whites 59'",
|
||||||
|
"iot_wash_whites_xl": "Whites XL",
|
||||||
|
"iot_wash_wine_stains": "Wine Stains",
|
||||||
|
"iot_wash_wool": "Wool",
|
||||||
|
"jeans": "Jeans",
|
||||||
|
"jeans_60": "Jeans",
|
||||||
|
"low_dry": "Low Heat Dry",
|
||||||
|
"mixed": "Mixed",
|
||||||
|
"mixed_and_colored_59": "Mixed and Colored 59'",
|
||||||
|
"mixed_steam": "Mixed + Steam",
|
||||||
|
"mix_and_colour_59": "Mixed and Colored 59'",
|
||||||
|
"mix_and_colour_59_steam": "Mixed and Coloured 59' + Steam",
|
||||||
|
"night_and_day": "Night and Day",
|
||||||
|
"night_wash": "Night Wash",
|
||||||
|
"perfect_59": "Perfect 59'",
|
||||||
|
"perfect_cotton_59": "Perfect Cotton 59'",
|
||||||
|
"perfect_cotton_59_steam": "Perfect Cotton 59' + Steam",
|
||||||
|
"perfect_whites_59": "Perfect White 59'",
|
||||||
|
"rapid_14_min": "Rapid 14'",
|
||||||
|
"rapid_30_min": "Rapid 30'",
|
||||||
|
"rapid_44_min": "Rapid 44'",
|
||||||
|
"rapid_a_class_60": "Rapid 59' A Class",
|
||||||
|
"rapid_a_class_60_steam": "Rapid 59' A Class + Steam",
|
||||||
|
"rapid_wash_and_dry_59_min": "Wash and Dry 59'",
|
||||||
|
"resistant_cotton": "Resistant Cotton",
|
||||||
|
"resistant_cotton_steam": "Resistant Cotton + Steam",
|
||||||
|
"rinse": "Rinse",
|
||||||
|
"shirts_steam": "Shirts + Steam",
|
||||||
|
"silent_night": "Silent Night",
|
||||||
|
"single_item": "Single Item",
|
||||||
|
"single_item_steam": "Single Item + Steam",
|
||||||
|
"smart_wash": "Smart Wash",
|
||||||
|
"soft_care": "Soft Care",
|
||||||
|
"soft_care_steam": "Soft Care + Steam",
|
||||||
|
"soft_care_steam_title": "Soft Care + Steam",
|
||||||
|
"special_39": "Special 39'",
|
||||||
|
"special_39_full_load": "Special 39'",
|
||||||
|
"special_39_full_load_steam": "Special 39' + Steam",
|
||||||
|
"special_49": "Special 49'",
|
||||||
|
"sport_39": "Sport 39'",
|
||||||
|
"sport_plus_29": "Sport Plus 29'",
|
||||||
|
"sport_plus_39": "Sport Plus 39'",
|
||||||
|
"steam_39": "Steam 39'",
|
||||||
|
"steam_care_pro": "Steam Care Pro",
|
||||||
|
"steam_care_pro_cotton": "Steam Care Pro - Cottons",
|
||||||
|
"steam_care_pro_delicates": "Steam Care Pro - Delicates",
|
||||||
|
"steam_care_pro_synthetic": "Steam Care Pro - Synthetics",
|
||||||
|
"steam_hygiene_plus": "Hygiene Plus + Steam",
|
||||||
|
"synthetics": "Synthetics",
|
||||||
|
"synthetic_and_coloured": "Synthetic and Colored",
|
||||||
|
"synthetic_and_coloured_steam": "Synthetic and Coloured + Steam",
|
||||||
|
"tailored_resistant_cotton": "Tailored Resistant Cotton",
|
||||||
|
"tailored_synthetic_and_coloured": "Tailored Synthetic Colored",
|
||||||
|
"total_care": "Total Care",
|
||||||
|
"tumbling": "Tumbling",
|
||||||
|
"wool": "Wool",
|
||||||
|
"wool_and_delicates_49": "Wool and Delicates 49'",
|
||||||
|
"wool_dry": "Wool Dry",
|
||||||
|
"wool_soft_care": "Wool and Soft Car"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
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
@ -1,776 +0,0 @@
|
|||||||
{
|
|
||||||
"entity": {
|
|
||||||
"sensor": {
|
|
||||||
"washing_modes": {
|
|
||||||
"state": {
|
|
||||||
"0": "מוּכָן",
|
|
||||||
"1": "מוּכָן",
|
|
||||||
"3": "הַפסָקָה",
|
|
||||||
"4": "מתוזמן",
|
|
||||||
"5": "מתוזמן",
|
|
||||||
"6": "שְׁגִיאָה",
|
|
||||||
"7": "מוּכָן",
|
|
||||||
"2": "התוכנית פועלת",
|
|
||||||
"8": "Test",
|
|
||||||
"9": "Stopping cycle…"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"program_phases_wm": {
|
|
||||||
"state": {
|
|
||||||
"0": "מוּכָן",
|
|
||||||
"1": "לִשְׁטוֹף",
|
|
||||||
"2": "לִשְׁטוֹף",
|
|
||||||
"3": "Spin",
|
|
||||||
"4": "לִשְׁטוֹף",
|
|
||||||
"5": "לִשְׁטוֹף",
|
|
||||||
"6": "לִשְׁטוֹף",
|
|
||||||
"7": "יִבּוּשׁ",
|
|
||||||
"9": "קִיטוֹר",
|
|
||||||
"10": "מוּכָן",
|
|
||||||
"11": "Spin",
|
|
||||||
"12": "Weighing ",
|
|
||||||
"13": "Weighing ",
|
|
||||||
"14": "לִשְׁטוֹף",
|
|
||||||
"15": "לִשְׁטוֹף",
|
|
||||||
"16": "לִשְׁטוֹף",
|
|
||||||
"17": "לִשְׁטוֹף",
|
|
||||||
"18": "לִשְׁטוֹף",
|
|
||||||
"19": "מתוזמן",
|
|
||||||
"20": "שמור על טריות",
|
|
||||||
"24": "Refresh",
|
|
||||||
"25": "לִשְׁטוֹף",
|
|
||||||
"26": "Heating",
|
|
||||||
"27": "לִשְׁטוֹף"
|
|
||||||
},
|
|
||||||
"name": "שלב"
|
|
||||||
},
|
|
||||||
"program_phases_td": {
|
|
||||||
"state": {
|
|
||||||
"0": "מוּכָן",
|
|
||||||
"1": "Drying",
|
|
||||||
"2": "יִבּוּשׁ",
|
|
||||||
"3": "Cooldown",
|
|
||||||
"13": "Cooldown",
|
|
||||||
"14": "Drying",
|
|
||||||
"15": "Drying",
|
|
||||||
"16": "Cooldown",
|
|
||||||
"18": "Keep Fresh",
|
|
||||||
"19": "יִבּוּשׁ",
|
|
||||||
"20": "יִבּוּשׁ",
|
|
||||||
"11": "מוּכָן",
|
|
||||||
"17": "unknown"
|
|
||||||
},
|
|
||||||
"name": "שלב"
|
|
||||||
},
|
|
||||||
"program_phases_dw": {
|
|
||||||
"state": {
|
|
||||||
"0": "מוּכָן",
|
|
||||||
"1": "Prewash",
|
|
||||||
"2": "לִשְׁטוֹף",
|
|
||||||
"3": "לִשְׁטוֹף",
|
|
||||||
"4": "יִבּוּשׁ",
|
|
||||||
"5": "מוּכָן",
|
|
||||||
"6": "Hot rinse"
|
|
||||||
},
|
|
||||||
"name": "שלב"
|
|
||||||
},
|
|
||||||
"dry_levels": {
|
|
||||||
"state": {
|
|
||||||
"0": "ללא ייבוש",
|
|
||||||
"1": "בַּרזֶל",
|
|
||||||
"2": "לא לייבש ברזל",
|
|
||||||
"3": "ארון יבש",
|
|
||||||
"4": "יבש במיוחד",
|
|
||||||
"12": "בַּרזֶל",
|
|
||||||
"13": "ארון יבש",
|
|
||||||
"14": "Ready to wear",
|
|
||||||
"15": "יבש במיוחד",
|
|
||||||
"11": "ללא ייבוש"
|
|
||||||
},
|
|
||||||
"name": "רמת ייבוש"
|
|
||||||
},
|
|
||||||
"anti_crease": {
|
|
||||||
"name": "Anticrease"
|
|
||||||
},
|
|
||||||
"power": {
|
|
||||||
"name": "Power level"
|
|
||||||
},
|
|
||||||
"remaining_time": {
|
|
||||||
"name": "זמן שנותר"
|
|
||||||
},
|
|
||||||
"temperature": {
|
|
||||||
"name": "Temperature"
|
|
||||||
},
|
|
||||||
"water_efficiency": {
|
|
||||||
"name": "Water efficiency"
|
|
||||||
},
|
|
||||||
"water_saving": {
|
|
||||||
"name": "Water savings"
|
|
||||||
},
|
|
||||||
"duration": {
|
|
||||||
"name": "מֶשֶׁך"
|
|
||||||
},
|
|
||||||
"target_temperature": {
|
|
||||||
"name": "Target temperature"
|
|
||||||
},
|
|
||||||
"spin_speed": {
|
|
||||||
"name": "סיבוב"
|
|
||||||
},
|
|
||||||
"steam_leve": {
|
|
||||||
"name": "מפלס קיטור"
|
|
||||||
},
|
|
||||||
"dirt_level": {
|
|
||||||
"name": "רמת עפר"
|
|
||||||
},
|
|
||||||
"delay_time": {
|
|
||||||
"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": {
|
|
||||||
"programs_dw": {
|
|
||||||
"state": {
|
|
||||||
"gentle_wash": "Gentle wash",
|
|
||||||
"iot_checkup": "בְּדִיקָה",
|
|
||||||
"iot_dreft_quick_cycle": "Dreft Quick",
|
|
||||||
"iot_fairy_quick_cycle": "Fairy Quick",
|
|
||||||
"iot_jar_quick_cycle": "Jar Quick",
|
|
||||||
"iot_yes_quick_cycle": "Yes Quick",
|
|
||||||
"smart_ai": "Smart AI"
|
|
||||||
},
|
|
||||||
"name": "Program"
|
|
||||||
},
|
|
||||||
"programs_ih": {
|
|
||||||
"state": {
|
|
||||||
"iot_special_grilled_vegetables": "Grilled vegetables"
|
|
||||||
},
|
|
||||||
"name": "Program"
|
|
||||||
},
|
|
||||||
"programs_ov": {
|
|
||||||
"state": {
|
|
||||||
"iot_h20_clean": "h2O clean",
|
|
||||||
"pizza": "Pizza",
|
|
||||||
"tailor_bake": "Tailor bake"
|
|
||||||
},
|
|
||||||
"name": "Program"
|
|
||||||
},
|
|
||||||
"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": "סינתטי יבש"
|
|
||||||
},
|
|
||||||
"name": "Program"
|
|
||||||
},
|
|
||||||
"programs_wm": {
|
|
||||||
"state": {
|
|
||||||
"20_degrees_new_energy_label": "20 מעלות צלזיוס",
|
|
||||||
"active_steam": "קִיטוֹר",
|
|
||||||
"active_wash": "שטיפה פעילה",
|
|
||||||
"active_wash_steam": "שטיפה פעילה",
|
|
||||||
"allergy_care": "טיפול באלרגיה",
|
|
||||||
"allergy_care_pro": "Allergy Care Pro",
|
|
||||||
"all_in_one_49": "All in One 49 '",
|
|
||||||
"all_in_one_59": "All in One 59 '",
|
|
||||||
"all_in_one_59_steam": "שטיפה פעילה",
|
|
||||||
"autocare": "טיפול אוטומטי",
|
|
||||||
"autoclean": "ניקוי אוטומטי",
|
|
||||||
"baby_60": "BABY_60",
|
|
||||||
"care_14": "טיפול מהיר 14 '",
|
|
||||||
"care_30": "טיפול מהיר 30 '",
|
|
||||||
"care_44": "טיפול מהיר 44 '",
|
|
||||||
"checkup": "בְּדִיקָה",
|
|
||||||
"cottons": "כותנה",
|
|
||||||
"cottons_prewash": "כותנה + כביסה מוקדמת",
|
|
||||||
"cotton_care_59": "Cotton Care 59 Min",
|
|
||||||
"delicate_59": "עדין 59 '",
|
|
||||||
"delicati_59": "DELICATI_59",
|
|
||||||
"delicati_59_steam": "DELICATI_59",
|
|
||||||
"drain_spin": "ניקוז + סיבוב",
|
|
||||||
"easy_iron": "גיהוץ קל",
|
|
||||||
"eco_40_60_new_energy_label": "אקו 40-60",
|
|
||||||
"extra_care": "אכפתיות מוגברת",
|
|
||||||
"fitness": "טיפול בכושר",
|
|
||||||
"fitness_care": "טיפול בכושר",
|
|
||||||
"fresh_care": "טיפול טרי",
|
|
||||||
"fresh_care_steam": "טיפול טרי",
|
|
||||||
"handwash_wool": "שטיפת ידיים + צמר",
|
|
||||||
"high_dry": "יבש בחום גבוה",
|
|
||||||
"hqd_dry_synthetics": "יבש בחום נמוך",
|
|
||||||
"hygiene_60": "היגיינה 60 מעלות צלזיוס",
|
|
||||||
"intensive_40": "40°C אינטנסיביים",
|
|
||||||
"iot_active_steam": "קִיטוֹר",
|
|
||||||
"iot_active_wash_steam": "שטיפה פעילה",
|
|
||||||
"iot_allergy_care_pro": "Allergy Care Pro",
|
|
||||||
"iot_all_in_one_59_steam": "שטיפה פעילה",
|
|
||||||
"iot_checkup": "בְּדִיקָה",
|
|
||||||
"iot_delicati_59_steam": "DELICATI_59",
|
|
||||||
"iot_dry_air_refresh": "רענון אוויר",
|
|
||||||
"iot_dry_anti_mites": "נגד קרדית",
|
|
||||||
"iot_dry_baby": "תִינוֹק",
|
|
||||||
"iot_dry_backpacks": "תיקי גב",
|
|
||||||
"iot_dry_bathrobe": "חלוקי רחצה",
|
|
||||||
"iot_dry_bed_linen": "מצעים",
|
|
||||||
"iot_dry_cotton_dry": "כותנה יבשה",
|
|
||||||
"iot_dry_cuddly_toys": "צעצועי חיבוק",
|
|
||||||
"iot_dry_curtains": "וילונות",
|
|
||||||
"iot_dry_dehumidifier": "מסיר לחות",
|
|
||||||
"iot_dry_delicates_antiallergy": "עדין נגד אלרגיה",
|
|
||||||
"iot_dry_delicate_tablecloths": "מפות עדינות",
|
|
||||||
"iot_dry_denim_jeans": "ג'ינס",
|
|
||||||
"iot_dry_easy_iron_cotton": "ברזל קל - כותנה",
|
|
||||||
"iot_dry_easy_iron_synthetics": "קל ברזל - סינתטיים",
|
|
||||||
"iot_dry_gym_fit": "כושר כושר - כושר",
|
|
||||||
"iot_dry_lingerie": "לִבנֵי נָשִׁים",
|
|
||||||
"iot_dry_mixed_dry": "מעורבב יבש",
|
|
||||||
"iot_dry_rapid_60_min_delicates": "מהיר 60 '- עדינים",
|
|
||||||
"iot_dry_shirts": "חולצות",
|
|
||||||
"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_dry": "צמר יבש",
|
|
||||||
"iot_easy_iron": "גיהוץ קל",
|
|
||||||
"iot_fresh_care_steam": "טיפול טרי",
|
|
||||||
"iot_synthetic_and_coloured_steam": "סינטטי וצבעוני",
|
|
||||||
"iot_wash_anti_mites": "נגד קרדית",
|
|
||||||
"iot_wash_anti_odor": "נגד ריח",
|
|
||||||
"iot_wash_ariel_clean_cycle": "Ariel Ultimate Clean",
|
|
||||||
"iot_wash_ariel_cold_cycle": "Ariel Cold Clean",
|
|
||||||
"iot_wash_ariel_fresh_cycle": "Ariel Fresh Clean",
|
|
||||||
"iot_wash_baby_sanitizer": "חיטוי לתינוקות",
|
|
||||||
"iot_wash_backpacks": "תיקי גב",
|
|
||||||
"iot_wash_bathrobe": "חלוקי רחצה ובדים נקבוביים",
|
|
||||||
"iot_wash_bed_linen": "מצעים",
|
|
||||||
"iot_wash_bed_linen_zelig": "מצעים",
|
|
||||||
"iot_wash_bleaching": "הַלבָּנָה",
|
|
||||||
"iot_wash_blood_stains": "כתמי דם",
|
|
||||||
"iot_wash_cashmere": "קשמיר",
|
|
||||||
"iot_wash_chocolate_stains": "כתמי שוקולד",
|
|
||||||
"iot_wash_cold_wash": "שטיפה קרה",
|
|
||||||
"iot_wash_colored": "צבעוני",
|
|
||||||
"iot_wash_colored_anti_stain": "נגד כתם צבעוני",
|
|
||||||
"iot_wash_colored_delicate": "צבעוני עדין",
|
|
||||||
"iot_wash_coloured": "צבעוני",
|
|
||||||
"iot_wash_cotton": "כותנה",
|
|
||||||
"iot_wash_cuddly_toys": "צעצועי חיבוק",
|
|
||||||
"iot_wash_curtains": "וילונות",
|
|
||||||
"iot_wash_curtains_zelig": "וילונות",
|
|
||||||
"iot_wash_dark": "אפל",
|
|
||||||
"iot_wash_darks_and_coloured_44": "חביבים וצבעוניים 44 '",
|
|
||||||
"iot_wash_darks_and_coloured_59": "חביבים וצבעוני 59 '",
|
|
||||||
"iot_wash_darks_and_coloured_xl": "חפצים וצבע XL",
|
|
||||||
"iot_wash_dash_clean_cycle": "Dash Ultimate Clean",
|
|
||||||
"iot_wash_dash_cold_cycle": "Dash Cold Clean",
|
|
||||||
"iot_wash_dash_fresh_cycle": "Dash Fresh Clean",
|
|
||||||
"iot_wash_delicate": "עדינים",
|
|
||||||
"iot_wash_delicate_antiallergy": "אנטי אלרגיה עדין",
|
|
||||||
"iot_wash_delicate_antiallergy_zelig": "אנטי אלרגיה עדין",
|
|
||||||
"iot_wash_delicate_colors": "צבעוני עדין",
|
|
||||||
"iot_wash_delicate_dark": "כהה עדין",
|
|
||||||
"iot_wash_delicate_tablecloths": "מפות עדינות",
|
|
||||||
"iot_wash_delicate_whites": "לבנים עדינים",
|
|
||||||
"iot_wash_denim_jeans": "ג'ינס",
|
|
||||||
"iot_wash_diving_suits": "חליפות צלילה",
|
|
||||||
"iot_wash_diving_suits_zelig": "חליפות צלילה",
|
|
||||||
"iot_wash_down_jackets": "מעילי פוך",
|
|
||||||
"iot_wash_down_jackets_zelig": "מעילי פוך",
|
|
||||||
"iot_wash_fruit_stains": "כתמי פרי",
|
|
||||||
"iot_wash_gym_fit": "כושר כושר - כושר",
|
|
||||||
"iot_wash_handwash": "שטיפת ידיים",
|
|
||||||
"iot_wash_handwash_colored": "שטיפת ידיים בצבע",
|
|
||||||
"iot_wash_handwash_dark": "שטיפת ידיים כהה",
|
|
||||||
"iot_wash_lingerie": "לִבנֵי נָשִׁים",
|
|
||||||
"iot_wash_masks_refresh": "מסכות רענן",
|
|
||||||
"iot_wash_masks_sanification": "חיטוי מסכות",
|
|
||||||
"iot_wash_mats": "מחצלות",
|
|
||||||
"iot_wash_men_s_trousers": "מכנסי גברים",
|
|
||||||
"iot_wash_mixed": "מעורב",
|
|
||||||
"iot_wash_mix_and_coloured_44": "לערבב וצבעוני 44 '",
|
|
||||||
"iot_wash_mix_and_coloured_59": "מיקס וצבעוני 59 '",
|
|
||||||
"iot_wash_mix_and_coloured_xl": "מערבבים וצבעים XL",
|
|
||||||
"iot_wash_new_clothes": "בגדים חדשים",
|
|
||||||
"iot_wash_perfect_white": "לבן מושלם",
|
|
||||||
"iot_wash_pets": "חיות מחמד",
|
|
||||||
"iot_wash_pets_steam": "חיות מחמד",
|
|
||||||
"iot_wash_playsuits": "חליפות משחק",
|
|
||||||
"iot_wash_rapid_14": "מהיר 14 '",
|
|
||||||
"iot_wash_rapid_30": "מהיר 30 '",
|
|
||||||
"iot_wash_rapid_44": "מהיר 44 '",
|
|
||||||
"iot_wash_rapid_59": "מהיר 59 '",
|
|
||||||
"iot_wash_refresh_14_min": "רענן 14 דקות",
|
|
||||||
"iot_wash_resistant_colored": "צבעוני עמיד",
|
|
||||||
"iot_wash_resistant_dark": "כהה עמיד",
|
|
||||||
"iot_wash_resistant_whites": "לבנים עמידים",
|
|
||||||
"iot_wash_rinse": "לִשְׁטוֹף",
|
|
||||||
"iot_wash_shirts": "חולצות",
|
|
||||||
"iot_wash_silk": "משי",
|
|
||||||
"iot_wash_ski_suit": "חליפת סקי",
|
|
||||||
"iot_wash_ski_suit_zelig": "חליפת סקי",
|
|
||||||
"iot_wash_spin": "סיבוב",
|
|
||||||
"iot_wash_sport": "ספּוֹרט",
|
|
||||||
"iot_wash_stains_remover": "מסיר כתמים",
|
|
||||||
"iot_wash_swimsuits_and_bikinis": "בגדי ים וביקיני",
|
|
||||||
"iot_wash_synthetic": "סינתטיים",
|
|
||||||
"iot_wash_tablecloths": "מפות שולחן",
|
|
||||||
"iot_wash_technical_fabrics": "בדים טכניים",
|
|
||||||
"iot_wash_technical_fabrics_zelig": "בדים טכניים",
|
|
||||||
"iot_wash_technical_jackets": "ז'קטים טכניים",
|
|
||||||
"iot_wash_technical_jackets_zelig": "ז'קטים טכניים",
|
|
||||||
"iot_wash_trainers": "מאמנים",
|
|
||||||
"iot_wash_whites": "לְבָנִים",
|
|
||||||
"iot_wash_whites_44": "לבנים 44 '",
|
|
||||||
"iot_wash_whites_59": "לבנים 59 '",
|
|
||||||
"iot_wash_whites_xl": "לבנים XL",
|
|
||||||
"iot_wash_wine_stains": "כתמי יין",
|
|
||||||
"iot_wash_wool": "צֶמֶר",
|
|
||||||
"jeans": "גִ'ינס",
|
|
||||||
"low_dry": "יבש בחום נמוך",
|
|
||||||
"mixed_and_colored_59": "מעורב וצבעוני 59 '",
|
|
||||||
"night_and_day": "לילה ויום",
|
|
||||||
"night_wash": "Night Wash",
|
|
||||||
"perfect_59": "מושלם 59 '",
|
|
||||||
"perfect_whites_59": "לבן מושלם",
|
|
||||||
"rapid_wash_and_dry_59_min": "לשטוף ולייבש 59 '",
|
|
||||||
"resistant_cotton": "כותנה",
|
|
||||||
"rinse": "לִשְׁטוֹף",
|
|
||||||
"silent_night": "Night Wash",
|
|
||||||
"soft_care": "טיפול רך",
|
|
||||||
"special_49": "מיוחד 49 '",
|
|
||||||
"sport_39": "ספורט 39 '",
|
|
||||||
"sport_plus_29": "ספורט פלוס 29 \"",
|
|
||||||
"steam_39": "קיטור 39 '",
|
|
||||||
"steam_care_pro": "Steam Care Pro",
|
|
||||||
"steam_care_pro_cotton": "Steam Care Pro",
|
|
||||||
"steam_care_pro_delicates": "Steam Care Pro",
|
|
||||||
"steam_care_pro_synthetic": "Steam Care Pro",
|
|
||||||
"synthetics": "סינתטיים",
|
|
||||||
"synthetic_and_coloured": "סינטטי וצבעוני",
|
|
||||||
"synthetic_and_coloured_steam": "סינטטי וצבעוני",
|
|
||||||
"tailored_resistant_cotton": "Tailored Resistant Cotton",
|
|
||||||
"tailored_synthetic_and_coloured": "Tailored Synthetic Colored",
|
|
||||||
"total_care": "טיפול טוטאלי",
|
|
||||||
"tumbling": "נופלים",
|
|
||||||
"wool_and_delicates_49": "Wool/Delicates 49'",
|
|
||||||
"wool_dry": "צמר יבש",
|
|
||||||
"wool_soft_care": "Wool & Soft Care"
|
|
||||||
},
|
|
||||||
"name": "Program"
|
|
||||||
},
|
|
||||||
"dry_levels": {
|
|
||||||
"state": {
|
|
||||||
"0": "ללא ייבוש",
|
|
||||||
"1": "בַּרזֶל",
|
|
||||||
"2": "לא לייבש ברזל",
|
|
||||||
"3": "ארון יבש",
|
|
||||||
"4": "יבש במיוחד",
|
|
||||||
"12": "בַּרזֶל",
|
|
||||||
"13": "ארון יבש",
|
|
||||||
"14": "Ready to wear",
|
|
||||||
"15": "יבש במיוחד",
|
|
||||||
"11": "ללא ייבוש"
|
|
||||||
},
|
|
||||||
"name": "רמת ייבוש"
|
|
||||||
},
|
|
||||||
"spin_speed": {
|
|
||||||
"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": "זמן שנותר"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"switch": {
|
|
||||||
"anti_crease": {
|
|
||||||
"name": "Anticrease"
|
|
||||||
},
|
|
||||||
"add_dish": {
|
|
||||||
"name": "Add dishes"
|
|
||||||
},
|
|
||||||
"eco_express": {
|
|
||||||
"name": "Eco"
|
|
||||||
},
|
|
||||||
"extra_dry": {
|
|
||||||
"name": "Extra dry"
|
|
||||||
},
|
|
||||||
"half_load": {
|
|
||||||
"name": "Half load"
|
|
||||||
},
|
|
||||||
"open_door": {
|
|
||||||
"name": "Open door"
|
|
||||||
},
|
|
||||||
"three_in_one": {
|
|
||||||
"name": "3 in 1"
|
|
||||||
},
|
|
||||||
"preheat": {
|
|
||||||
"name": "Preheat"
|
|
||||||
},
|
|
||||||
"dish_washer": {
|
|
||||||
"name": "Dish washer"
|
|
||||||
},
|
|
||||||
"tumble_dryer": {
|
|
||||||
"name": "Tumble dryer"
|
|
||||||
},
|
|
||||||
"washing_machine": {
|
|
||||||
"name": "Washing machine"
|
|
||||||
},
|
|
||||||
"washer_dryer": {
|
|
||||||
"name": "Washer dryer"
|
|
||||||
},
|
|
||||||
"oven": {
|
|
||||||
"name": "Oven"
|
|
||||||
},
|
|
||||||
"prewash": {
|
|
||||||
"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"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"binary_sensor": {
|
|
||||||
"door_lock": {
|
|
||||||
"name": "מנעול דלת"
|
|
||||||
},
|
|
||||||
"extra_rinse_1": {
|
|
||||||
"name": "+1 שטיפה"
|
|
||||||
},
|
|
||||||
"extra_rinse_2": {
|
|
||||||
"name": "+2 שטיפות"
|
|
||||||
},
|
|
||||||
"extra_rinse_3": {
|
|
||||||
"name": "+3 שטיפות"
|
|
||||||
},
|
|
||||||
"good_night": {
|
|
||||||
"name": "לילה טוב"
|
|
||||||
},
|
|
||||||
"anti_crease": {
|
|
||||||
"name": "Anticrease"
|
|
||||||
},
|
|
||||||
"aqua_plus": {
|
|
||||||
"name": "Acquaplus"
|
|
||||||
},
|
|
||||||
"spin_speed": {
|
|
||||||
"name": "סיבוב"
|
|
||||||
},
|
|
||||||
"programs_dw": {
|
|
||||||
"name": "Program"
|
|
||||||
},
|
|
||||||
"programs_ih": {
|
|
||||||
"name": "Program"
|
|
||||||
},
|
|
||||||
"programs_ov": {
|
|
||||||
"name": "Program"
|
|
||||||
},
|
|
||||||
"programs_td": {
|
|
||||||
"name": "Program"
|
|
||||||
},
|
|
||||||
"programs_wm": {
|
|
||||||
"name": "Program"
|
|
||||||
},
|
|
||||||
"still_hot": {
|
|
||||||
"name": "Still hot"
|
|
||||||
},
|
|
||||||
"pan_status": {
|
|
||||||
"name": "Pan"
|
|
||||||
},
|
|
||||||
"remote_control": {
|
|
||||||
"name": "Remote control"
|
|
||||||
},
|
|
||||||
"rinse_aid": {
|
|
||||||
"name": "Rinse Aid level"
|
|
||||||
},
|
|
||||||
"salt_level": {
|
|
||||||
"name": "Salt level"
|
|
||||||
},
|
|
||||||
"door_open": {
|
|
||||||
"name": "Door open"
|
|
||||||
},
|
|
||||||
"connection": {
|
|
||||||
"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": {
|
|
||||||
"power_management": {
|
|
||||||
"name": "Power management"
|
|
||||||
},
|
|
||||||
"temperature": {
|
|
||||||
"name": "Temperature"
|
|
||||||
},
|
|
||||||
"delay_time": {
|
|
||||||
"name": "Delay Start"
|
|
||||||
},
|
|
||||||
"water_hard": {
|
|
||||||
"name": "קשיות מים"
|
|
||||||
},
|
|
||||||
"program_duration": {
|
|
||||||
"name": "Program duration"
|
|
||||||
},
|
|
||||||
"target_temperature": {
|
|
||||||
"name": "Target temperature"
|
|
||||||
},
|
|
||||||
"rinse_iterations": {
|
|
||||||
"name": "Number of rinses"
|
|
||||||
},
|
|
||||||
"wash_time": {
|
|
||||||
"name": "Washing intensity"
|
|
||||||
},
|
|
||||||
"dry_time": {
|
|
||||||
"name": "זמן ייבוש"
|
|
||||||
},
|
|
||||||
"steam_level": {
|
|
||||||
"name": "מפלס קיטור"
|
|
||||||
},
|
|
||||||
"freezer_temp_sel": {
|
|
||||||
"name": "Target temperature Freezer"
|
|
||||||
},
|
|
||||||
"fridge_temp_sel": {
|
|
||||||
"name": "Target temperature Fridge"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"button": {
|
|
||||||
"induction_hob": {
|
|
||||||
"name": "Induction Hob"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"climate": {
|
|
||||||
"air_conditioner": {
|
|
||||||
"name": "Air conditioner"
|
|
||||||
}
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"config": {
|
|
||||||
"step": {
|
|
||||||
"user": {
|
|
||||||
"description": "Do the login",
|
|
||||||
"data": {
|
|
||||||
"email": "Email",
|
|
||||||
"password": "Password"
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
82
info.md
82
info.md
@ -1,18 +1,22 @@
|
|||||||
# Haier hOn
|
# Haier hOn
|
||||||
[](https://github.com/Andre0512/hon/releases/latest)
|
[](https://github.com/Andre0512/hon/releases/latest)
|
||||||
[](https://github.com/Andre0512/hon/blob/main/LICENSE)
|

|
||||||
[](https://tooomm.github.io/github-release-stats/?username=Andre0512&repository=hon)
|
[](https://analytics.home-assistant.io/)
|
||||||
Support for home appliances of Haier's mobile app hOn.
|
Support for home appliances of Haier's mobile app hOn.
|
||||||
|
|
||||||
## Supported Appliances
|
## Supported Appliances
|
||||||
- [Washing Machine](https://github.com/Andre0512/hon#washing-machine)
|
- Tumble Dryer
|
||||||
- [Tumble Dryer](https://github.com/Andre0512/hon#tumble-dryer)
|
- Washer Dryer
|
||||||
- [Washer Dryer](https://github.com/Andre0512/hon#washer-dryer)
|
- Washing Machine
|
||||||
- [Oven](https://github.com/Andre0512/hon#oven)
|
- Oven
|
||||||
- [Hob](https://github.com/Andre0512/hon#hob)
|
- Hob
|
||||||
- [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
|
||||||
|
|
||||||
@ -21,70 +25,16 @@ Support for home appliances of Haier's mobile app hOn.
|
|||||||
**Method 2**: Settings > Devices & Services > Add Integration > **Haier hOn**
|
**Method 2**: Settings > Devices & Services > Add Integration > **Haier hOn**
|
||||||
_If the integration is not in the list, you need to clear the browser cache._
|
_If the integration is not in the list, you need to clear the browser cache._
|
||||||
|
|
||||||
## Supported 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
|
|
||||||

|
|
||||||
|
|
||||||
## 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 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 HWPD 69AMBC/1-S
|
|
||||||
- Hoover HWPS4954DAMR-11
|
|
||||||
- Hoover NDE H10A2TCE-80
|
|
||||||
- Hoover NDE H9A2TSBEXS-S
|
|
||||||
- Hoover NDPHY10A2TCBEXSS
|
|
||||||
|
|
||||||
## Contribute
|
## Contribute
|
||||||
Want to help us to support more appliances? Or add more sensors? Or help with translating? Or beautify some icons or captions?
|
Want to help us to support more appliances? Or add more sensors? Or help with translating? Or beautify some icons or captions?
|
||||||
Check out the [project on GitHub](https://github.com/Andre0512/hon), every contribution is welcome!
|
Check out the [project on GitHub](https://github.com/Andre0512/hon), every contribution is welcome!
|
||||||
|
|
||||||
## 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)
|
||||||
|
|
||||||
|
@ -1,3 +0,0 @@
|
|||||||
pyhOn
|
|
||||||
black
|
|
||||||
homeassistant
|
|
@ -1,301 +0,0 @@
|
|||||||
#!/usr/bin/env python
|
|
||||||
|
|
||||||
import asyncio
|
|
||||||
import json
|
|
||||||
import re
|
|
||||||
import sys
|
|
||||||
from pathlib import Path
|
|
||||||
|
|
||||||
from pyhon import HonAPI
|
|
||||||
|
|
||||||
if __name__ == "__main__":
|
|
||||||
sys.path.insert(0, str(Path(__file__).parent.parent))
|
|
||||||
|
|
||||||
from custom_components.hon import const
|
|
||||||
|
|
||||||
SENSOR = {
|
|
||||||
"washing_modes": const.MACH_MODE,
|
|
||||||
"mach_modes_ac": const.AC_MACH_MODE,
|
|
||||||
"program_phases_wm": const.WASHING_PR_PHASE,
|
|
||||||
"program_phases_td": const.TUMBLE_DRYER_PR_PHASE,
|
|
||||||
"program_phases_dw": const.DISHWASHER_PR_PHASE,
|
|
||||||
"dry_levels": const.TUMBLE_DRYER_DRY_LEVEL,
|
|
||||||
}
|
|
||||||
|
|
||||||
SELECT = {
|
|
||||||
"dry_levels": const.TUMBLE_DRYER_DRY_LEVEL,
|
|
||||||
"eco_pilot": const.AC_HUMAN_SENSE,
|
|
||||||
"fan_mode": const.AC_FAN_MODE,
|
|
||||||
}
|
|
||||||
|
|
||||||
PROGRAMS = {
|
|
||||||
"select": {
|
|
||||||
"programs_ac": "PROGRAMS.AC",
|
|
||||||
"programs_dw": "PROGRAMS.DW",
|
|
||||||
"programs_ih": "PROGRAMS.IH",
|
|
||||||
"programs_ov": "PROGRAMS.OV",
|
|
||||||
"programs_td": "PROGRAMS.TD",
|
|
||||||
"programs_wm": "PROGRAMS.WM_WD",
|
|
||||||
"programs_ref": "PROGRAMS.REF",
|
|
||||||
},
|
|
||||||
"sensor": {
|
|
||||||
"programs_td": "PROGRAMS.TD",
|
|
||||||
},
|
|
||||||
}
|
|
||||||
|
|
||||||
NAMES = {
|
|
||||||
"switch": {
|
|
||||||
"anti_crease": "HDRY_CMD&CTRL.PROGRAM_CYCLE_DETAIL.ANTICREASE_TITLE",
|
|
||||||
"add_dish": "DW.ADD_DISH",
|
|
||||||
"eco_express": "DW_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OTHER_OPTIONS.ECO",
|
|
||||||
"extra_dry": "DW_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OTHER_OPTIONS.EXTRA_DRY",
|
|
||||||
"half_load": "DW_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OTHER_OPTIONS.HALF_LOAD",
|
|
||||||
"open_door": "DW_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OTHER_OPTIONS.OPEN_DOOR",
|
|
||||||
"three_in_one": "DW_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OTHER_OPTIONS.THREE_IN_ONE",
|
|
||||||
"preheat": "OV.PROGRAM_DETAIL.PREHEAT",
|
|
||||||
"dish_washer": "GLOBALS.APPLIANCES_NAME.DW",
|
|
||||||
"tumble_dryer": "GLOBALS.APPLIANCES_NAME.TD",
|
|
||||||
"washing_machine": "GLOBALS.APPLIANCES_NAME.WM",
|
|
||||||
"washer_dryer": "GLOBALS.APPLIANCES_NAME.WD",
|
|
||||||
"oven": "GLOBALS.APPLIANCES_NAME.OV",
|
|
||||||
"prewash": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OTHER_OPTIONS.PREWASH",
|
|
||||||
"pause": "GENERAL.PAUSE_PROGRAM",
|
|
||||||
"keep_fresh": "GLOBALS.APPLIANCE_STATUS.TUMBLING",
|
|
||||||
"delay_time": "HINTS.TIPS_TIME_ENERGY_SAVING.TIPS_USE_AT_NIGHT_TITLE",
|
|
||||||
"rapid_mode": "AC.PROGRAM_CARD.RAPID",
|
|
||||||
"eco_mode": "AC.PROGRAM_CARD.ECO_MODE",
|
|
||||||
"10_degree_heating": "PROGRAMS.AC.IOT_10_HEATING",
|
|
||||||
"self_clean": "PROGRAMS.AC.IOT_SELF_CLEAN",
|
|
||||||
"self_clean_56": "PROGRAMS.AC.IOT_SELF_CLEAN_56",
|
|
||||||
"silent_mode": "AC.PROGRAM_DETAIL.SILENT_MODE",
|
|
||||||
"mute_mode": "AC.PROGRAM_DETAIL.MUTE_MODE",
|
|
||||||
"extra_rinse_1": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OTHER_OPTIONS.EXTRARINSE1",
|
|
||||||
"extra_rinse_2": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OTHER_OPTIONS.EXTRARINSE2",
|
|
||||||
"extra_rinse_3": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OTHER_OPTIONS.EXTRARINSE3",
|
|
||||||
"acqua_plus": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OTHER_OPTIONS.ACQUAPLUS",
|
|
||||||
"auto_dose_softener": [
|
|
||||||
"WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OTHER_OPTIONS.AUTODOSE",
|
|
||||||
"WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OTHER_OPTIONS.SOFTENER",
|
|
||||||
],
|
|
||||||
"auto_dose_detergent": [
|
|
||||||
"WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OTHER_OPTIONS.AUTODOSE",
|
|
||||||
"WASHING_CMD&CTRL.DASHBOARD_MENU_MORE_SETTINGS_WATER.DETERGENT",
|
|
||||||
],
|
|
||||||
"good_night": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OTHER_OPTIONS.GOODNIGHT",
|
|
||||||
"auto_set": "REF_CMD&CTRL.MODALITIES.ECO",
|
|
||||||
"super_cool": "REF_CMD&CTRL.MODALITIES.SUPER_COOL",
|
|
||||||
"super_freeze": "REF_CMD&CTRL.MODALITIES.SUPER_FREEZE",
|
|
||||||
},
|
|
||||||
"binary_sensor": {
|
|
||||||
"door_lock": "WASHING_CMD&CTRL.CHECK_UP_RESULTS.DOOR_LOCK",
|
|
||||||
"extra_rinse_1": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OTHER_OPTIONS.EXTRARINSE1",
|
|
||||||
"extra_rinse_2": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OTHER_OPTIONS.EXTRARINSE2",
|
|
||||||
"extra_rinse_3": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OTHER_OPTIONS.EXTRARINSE3",
|
|
||||||
"good_night": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OTHER_OPTIONS.GOODNIGHT",
|
|
||||||
"anti_crease": "HDRY_CMD&CTRL.PROGRAM_CYCLE_DETAIL.ANTICREASE_TITLE",
|
|
||||||
"acqua_plus": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OTHER_OPTIONS.ACQUAPLUS",
|
|
||||||
"spin_speed": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_MAIN_OPTIONS.SPINSPEED",
|
|
||||||
"still_hot": "IH.COILS_STATUS.STILL_HOT",
|
|
||||||
"pan_status": "IH.COILS_STATUS.PAN",
|
|
||||||
"remote_control": "OV.SUPPORT.REMOTE_CONTROL",
|
|
||||||
"rinse_aid": "DW_CMD&CTRL.MAINTENANCE.CONSUMABLE_LEVELS_ICON_RINSE_AID",
|
|
||||||
"salt_level": "DW_CMD&CTRL.MAINTENANCE.CONSUMABLE_LEVELS_ICON_SALT",
|
|
||||||
"door_open": "GLOBALS.APPLIANCE_STATUS.DOOR_OPEN",
|
|
||||||
"connection": "ENROLLMENT_COMMON.HEADER_NAME.STEP_APPLIANCE_CONNECTION",
|
|
||||||
"child_lock": "AP.FOOTER_MENU_MORE.SECURITY_LOCK_TITLE",
|
|
||||||
"on": "GLOBALS.GENERAL.ON",
|
|
||||||
"prewash": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_OTHER_OPTIONS.PREWASH",
|
|
||||||
"buzzer": "DW_CMD&CTRL.SETTINGS.END_CYCLE_BUZZER",
|
|
||||||
"holiday_mode": "REF.DASHBOARD_MENU_MORE_NOTIFICATIONS.HOLIDAY_MODE",
|
|
||||||
"auto_set": "REF_CMD&CTRL.MODALITIES.ECO",
|
|
||||||
"super_cool": "REF_CMD&CTRL.MODALITIES.SUPER_COOL",
|
|
||||||
"super_freeze": "REF_CMD&CTRL.MODALITIES.SUPER_FREEZE",
|
|
||||||
"freezer_door": ["GLOBALS.APPLIANCE_STATUS.DOOR_OPEN", "REF.ZONES.FREEZER"],
|
|
||||||
"fridge_door": ["GLOBALS.APPLIANCE_STATUS.DOOR_OPEN", "REF.ZONES.FRIDGE"],
|
|
||||||
"filter_replacement": "AP.MAINTENANCE.FILTER_REPLACEMENT",
|
|
||||||
},
|
|
||||||
"button": {
|
|
||||||
"induction_hob": "GLOBALS.APPLIANCES_NAME.IH",
|
|
||||||
},
|
|
||||||
"select": {
|
|
||||||
"dry_levels": "WASHING_CMD&CTRL.DRAWER_CYCLE_DRYING.TAB_LEVEL",
|
|
||||||
"dry_time": "WASHING_CMD&CTRL.DRAWER_CYCLE_DRYING.TAB_TIME",
|
|
||||||
"spin_speed": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_MAIN_OPTIONS.SPINSPEED",
|
|
||||||
"temperature": "IH.COMMON.TEMPERATURE",
|
|
||||||
"programs_dw": "WC.SET_PROGRAM.PROGRAM",
|
|
||||||
"programs_ih": "WC.SET_PROGRAM.PROGRAM",
|
|
||||||
"programs_ov": "WC.SET_PROGRAM.PROGRAM",
|
|
||||||
"programs_td": "WC.SET_PROGRAM.PROGRAM",
|
|
||||||
"programs_wm": "WC.SET_PROGRAM.PROGRAM",
|
|
||||||
"eco_pilot": "AC.PROGRAM_DETAIL.ECO_PILOT",
|
|
||||||
"remaining_time": "ENROLLMENT_COMMON.GENERAL.REMAINING_TIME",
|
|
||||||
},
|
|
||||||
"sensor": {
|
|
||||||
"dry_levels": "WASHING_CMD&CTRL.DRAWER_CYCLE_DRYING.TAB_LEVEL",
|
|
||||||
"dry_time": "WASHING_CMD&CTRL.DRAWER_CYCLE_DRYING.TAB_TIME",
|
|
||||||
"power": "OV.RECIPE_DETAIL.POWER_LEVEL",
|
|
||||||
"remaining_time": "ENROLLMENT_COMMON.GENERAL.REMAINING_TIME",
|
|
||||||
"temperature": "IH.COMMON.TEMPERATURE",
|
|
||||||
"water_efficiency": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_RESULT.WATER_EFFICIENCY",
|
|
||||||
"water_saving": "STATISTICS.SMART_AI_CYCLE.WATER_SAVING",
|
|
||||||
"duration": "WASHING_CMD&CTRL.DRAWER_PROGRAM_FILTERS.DURATION",
|
|
||||||
"target_temperature": "IH.COOKING_DETAIL.TEMPERATURE_TARGETING",
|
|
||||||
"spin_speed": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_MAIN_OPTIONS.SPINSPEED",
|
|
||||||
"steam_leve": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_MAIN_OPTIONS.STEAM_LEVEL",
|
|
||||||
"dirt_level": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_MAIN_OPTIONS.DIRTY_LEVEL",
|
|
||||||
"program_phases_wm": "WASHING_CMD&CTRL.STATISTICS_GRAPHIC_INSTANT_CONSUMPTION.PHASE",
|
|
||||||
"program_phases_td": "WASHING_CMD&CTRL.STATISTICS_GRAPHIC_INSTANT_CONSUMPTION.PHASE",
|
|
||||||
"program_phases_dw": "WASHING_CMD&CTRL.STATISTICS_GRAPHIC_INSTANT_CONSUMPTION.PHASE",
|
|
||||||
"delay_time": "HINTS.TIPS_TIME_ENERGY_SAVING.TIPS_USE_AT_NIGHT_TITLE",
|
|
||||||
"suggested_load": "WASHING_CMD&CTRL.DRAWER_PROGRAM_FILTERS.LOAD_CAPACITY",
|
|
||||||
"energy_label": "WASHING_CMD&CTRL.DRAWER_PROGRAM_FILTERS.ENERGY_EFFICIENCY",
|
|
||||||
"det_dust": "HUBS.WIDGET.STAINS_WIDGET.STAINS.SUGGESTED_DET_DUST",
|
|
||||||
"det_liquid": "HUBS.WIDGET.STAINS_WIDGET.STAINS.SUGGESTED_DET_LIQUID",
|
|
||||||
"errors": "ROBOT_CMD&CTRL.PHASE_ERROR.TITLE",
|
|
||||||
"programs": "OV.TABS.CURRENT_PROGRAM",
|
|
||||||
"room_temperature": "REF.SMART_DRINK_ASSISTANT.AMBIENT",
|
|
||||||
"humidity": "AP.TITLES.HUMIDITY",
|
|
||||||
"cycles_total": [
|
|
||||||
"WASHING_CMD&CTRL.GENERAL.CYCLES",
|
|
||||||
"WC.VIRTUAL_WINE_STATS_COUNTRY.TOTAL",
|
|
||||||
],
|
|
||||||
"energy_total": [
|
|
||||||
"MISE.ENERGY_CONSUMPTION.TITLE",
|
|
||||||
"WC.VIRTUAL_WINE_STATS_COUNTRY.TOTAL",
|
|
||||||
],
|
|
||||||
"water_total": [
|
|
||||||
"WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_RESULT.WATER_EFFICIENCY",
|
|
||||||
"WC.VIRTUAL_WINE_STATS_COUNTRY.TOTAL",
|
|
||||||
],
|
|
||||||
"energy_current": [
|
|
||||||
"MISE.ENERGY_CONSUMPTION.TITLE",
|
|
||||||
"CUBE90_GLOBAL.GENERAL.CURRENT",
|
|
||||||
],
|
|
||||||
"water_current": [
|
|
||||||
"WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_RESULT.WATER_EFFICIENCY",
|
|
||||||
"CUBE90_GLOBAL.GENERAL.CURRENT",
|
|
||||||
],
|
|
||||||
"freezer_temp": "REF_CMD&CTRL.TEMPERATURE_DRAWER_FREEZER.FREEZER_TEMPERATURE_TITLE",
|
|
||||||
"fridge_temp": "REF_CMD&CTRL.TEMPERATURE_DRAWER_FRIDGE.FRIDGE_TEMPERATURE_TITLE",
|
|
||||||
},
|
|
||||||
"number": {
|
|
||||||
"power_management": "HINTS.COOKING_WITH_INDUCTION.POWER_MANAGEMENT",
|
|
||||||
"temperature": "IH.COMMON.TEMPERATURE",
|
|
||||||
"delay_time": "HINTS.TIPS_TIME_ENERGY_SAVING.TIPS_USE_AT_NIGHT_TITLE",
|
|
||||||
"water_hard": "WASHING_CMD&CTRL.DASHBOARD_MENU_MORE_SETTINGS_WATER.TITLE",
|
|
||||||
"program_duration": "OV.PROGRAM_DETAIL.PROGRAM_DURATION",
|
|
||||||
"target_temperature": "IH.COOKING_DETAIL.TEMPERATURE_TARGETING",
|
|
||||||
"rinse_iterations": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL.DRAWER_HEADER_RINSE",
|
|
||||||
"wash_time": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL.WASHING_TIME",
|
|
||||||
"dry_time": "WASHING_CMD&CTRL.DRAWER_CYCLE_DRYING.TAB_TIME",
|
|
||||||
"steam_level": "WASHING_CMD&CTRL.PROGRAM_CYCLE_DETAIL_MAIN_OPTIONS.STEAM_LEVEL",
|
|
||||||
"freezer_temp_sel": ["OV.COMMON.GOAL_TEMPERATURE", "REF.ZONES.FREEZER"],
|
|
||||||
"fridge_temp_sel": ["OV.COMMON.GOAL_TEMPERATURE", "REF.ZONES.FRIDGE"],
|
|
||||||
},
|
|
||||||
"climate": {"air_conditioner": "GLOBALS.APPLIANCES_NAME.AC"},
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
async def check_translation_files(translations):
|
|
||||||
for language in const.LANGUAGES:
|
|
||||||
path = translations / f"{language}.json"
|
|
||||||
if not path.is_file():
|
|
||||||
async with HonAPI(anonymous=True) as hon:
|
|
||||||
keys = await hon.translation_keys(language)
|
|
||||||
save_json(path, keys)
|
|
||||||
|
|
||||||
|
|
||||||
def load_hon_translations():
|
|
||||||
translations = Path(__file__).parent / "translations"
|
|
||||||
translations.mkdir(exist_ok=True)
|
|
||||||
asyncio.run(check_translation_files(translations))
|
|
||||||
return {f.stem: f for f in translations.glob("*.json")}
|
|
||||||
|
|
||||||
|
|
||||||
def load_hass_translations():
|
|
||||||
translations = (
|
|
||||||
Path(__file__).parent.parent / "custom_components" / "hon" / "translations"
|
|
||||||
)
|
|
||||||
return {f.stem: f for f in translations.glob("*.json")}
|
|
||||||
|
|
||||||
|
|
||||||
def load_json(path):
|
|
||||||
if path:
|
|
||||||
with open(path, "r") as file:
|
|
||||||
return json.loads(file.read())
|
|
||||||
return {}
|
|
||||||
|
|
||||||
|
|
||||||
def save_json(path, keys):
|
|
||||||
with open(path, "w") as json_file:
|
|
||||||
json_file.write(json.dumps(keys, indent=4, ensure_ascii=False))
|
|
||||||
|
|
||||||
|
|
||||||
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()
|
|
||||||
for key in full_key.split("."):
|
|
||||||
result = result.get(key, {})
|
|
||||||
if not result and fallback:
|
|
||||||
return load_key(full_key, fallback)
|
|
||||||
return result or full_key
|
|
||||||
|
|
||||||
|
|
||||||
def load_keys(full_key, json_data):
|
|
||||||
blacklist = ["description", "desctiption", "_recipe_", "_guided_"]
|
|
||||||
first, last = full_key.split(".")
|
|
||||||
data = json_data.get(first, {}).get(last, {})
|
|
||||||
return {
|
|
||||||
key.lower(): value
|
|
||||||
for key, value in data.items()
|
|
||||||
if not any(b in key.lower() for b in blacklist)
|
|
||||||
and re.findall("^[a-z0-9-_]+$", key.lower())
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
def add_data(old, original, fallback, data, name, entity="sensor"):
|
|
||||||
sensor = old.setdefault("entity", {}).setdefault(entity, {})
|
|
||||||
for number, phase in data.items():
|
|
||||||
state = sensor.setdefault(name, {}).setdefault("state", {})
|
|
||||||
if key := load_key(phase, original, fallback):
|
|
||||||
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():
|
|
||||||
hass = load_hass_translations()
|
|
||||||
hon = load_hon_translations()
|
|
||||||
base_path = Path(__file__).parent.parent / "custom_components/hon/translations"
|
|
||||||
fallback = load_json(hon.get("en", ""))
|
|
||||||
for language in const.LANGUAGES:
|
|
||||||
original = load_json(hon.get(language, ""))
|
|
||||||
old = load_json(hass.get(language, ""))
|
|
||||||
for name, data in SENSOR.items():
|
|
||||||
add_data(old, original, fallback, data, name)
|
|
||||||
for name, data in SELECT.items():
|
|
||||||
add_data(old, original, fallback, data, name, "select")
|
|
||||||
for entity, data in PROGRAMS.items():
|
|
||||||
for name, program in data.items():
|
|
||||||
select = old.setdefault("entity", {}).setdefault(entity, {})
|
|
||||||
select.setdefault(name, {})["state"] = load_keys(program, original)
|
|
||||||
for entity, data in NAMES.items():
|
|
||||||
for name, key in data.items():
|
|
||||||
select = old.setdefault("entity", {}).setdefault(entity, {})
|
|
||||||
select.setdefault(name, {})["name"] = load_key(key, original, fallback)
|
|
||||||
translate_login(old, original, fallback)
|
|
||||||
save_json(base_path / f"{language}.json", old)
|
|
||||||
|
|
||||||
|
|
||||||
if __name__ == "__main__":
|
|
||||||
main()
|
|
@ -1,93 +0,0 @@
|
|||||||
#!/usr/bin/env python
|
|
||||||
|
|
||||||
import re
|
|
||||||
import sys
|
|
||||||
from pathlib import Path
|
|
||||||
|
|
||||||
|
|
||||||
if __name__ == "__main__":
|
|
||||||
sys.path.insert(0, str(Path(__file__).parent.parent))
|
|
||||||
|
|
||||||
from custom_components.hon.binary_sensor import BINARY_SENSORS
|
|
||||||
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.select import SELECTS
|
|
||||||
from custom_components.hon.sensor import SENSORS
|
|
||||||
from custom_components.hon.switch import SWITCHES, HonSwitchEntityDescription
|
|
||||||
|
|
||||||
APPLIANCES = {
|
|
||||||
"AC": "Air conditioner",
|
|
||||||
"AP": "Air purifier",
|
|
||||||
"AS": "Air scanner",
|
|
||||||
"DW": "Dish washer",
|
|
||||||
"HO": "Hood",
|
|
||||||
"IH": "Hob",
|
|
||||||
"MW": "Microwave",
|
|
||||||
"OV": "Oven",
|
|
||||||
"REF": "Fridge",
|
|
||||||
"RVC": "Robot vacuum cleaner",
|
|
||||||
"TD": "Tumble dryer",
|
|
||||||
"WC": "Wine Cellar",
|
|
||||||
"WD": "Washer dryer",
|
|
||||||
"WH": "Water Heater",
|
|
||||||
"WM": "Washing machine",
|
|
||||||
}
|
|
||||||
|
|
||||||
ENTITY_CATEGORY_SORT = ["control", "config", "sensor"]
|
|
||||||
|
|
||||||
entities = {
|
|
||||||
"binary_sensor": BINARY_SENSORS,
|
|
||||||
"button": BUTTONS,
|
|
||||||
"number": NUMBERS,
|
|
||||||
"select": SELECTS,
|
|
||||||
"sensor": SENSORS,
|
|
||||||
"switch": SWITCHES,
|
|
||||||
"climate": CLIMATES,
|
|
||||||
}
|
|
||||||
|
|
||||||
result = {}
|
|
||||||
for entity_type, appliances in entities.items():
|
|
||||||
for appliance, data in appliances.items():
|
|
||||||
for entity in data:
|
|
||||||
if (
|
|
||||||
isinstance(entity, HonSwitchEntityDescription)
|
|
||||||
and entity.entity_category != "config"
|
|
||||||
and "settings." not in entity.key
|
|
||||||
):
|
|
||||||
key = f"{entity.turn_on_key}` / `{entity.turn_off_key}"
|
|
||||||
else:
|
|
||||||
key = entity.key
|
|
||||||
attributes = (key, entity.name, entity.icon, entity_type)
|
|
||||||
category = (
|
|
||||||
"control"
|
|
||||||
if entity.key.startswith("settings")
|
|
||||||
or hasattr(entity, "turn_on_key")
|
|
||||||
or entity_type in ["button", "climate"]
|
|
||||||
else "sensor"
|
|
||||||
)
|
|
||||||
result.setdefault(appliance, {}).setdefault(
|
|
||||||
entity.entity_category or category, []
|
|
||||||
).append(attributes)
|
|
||||||
text = ""
|
|
||||||
for appliance, categories in sorted(result.items()):
|
|
||||||
text += f"\n### {APPLIANCES[appliance]}\n"
|
|
||||||
categories = {k: categories[k] for k in ENTITY_CATEGORY_SORT if k in categories}
|
|
||||||
for category, data in categories.items():
|
|
||||||
text += f"#### {str(category).capitalize()}s\n"
|
|
||||||
text += "| Name | Icon | Entity | Key |\n"
|
|
||||||
text += "| --- | --- | --- | --- |\n"
|
|
||||||
for key, name, icon, entity_type in sorted(data, key=lambda d: d[1]):
|
|
||||||
icon = f"`{icon.replace('mdi:', '')}`" if icon else ""
|
|
||||||
text += f"| {name} | {icon} | `{entity_type}` | `{key}` |\n"
|
|
||||||
|
|
||||||
with open(Path(__file__).parent.parent / "README.md", "r") as file:
|
|
||||||
readme = file.read()
|
|
||||||
readme = re.sub(
|
|
||||||
"(## Appliance Features\n)(?:.|\\s)+?([^#]## |\\Z)",
|
|
||||||
f"\\1{text}\\2",
|
|
||||||
readme,
|
|
||||||
re.DOTALL,
|
|
||||||
)
|
|
||||||
with open(Path(__file__).parent.parent / "README.md", "w") as file:
|
|
||||||
file.write(readme)
|
|
Reference in New Issue
Block a user