2023-03-05 13:16:09 -07:00
# Haier hOn
2023-04-10 10:50:51 -06:00
[![hacs_badge ](https://img.shields.io/badge/HACS-Default-41BDF5.svg )](https://hacs.xyz)
[![GitHub release (latest by date) ](https://img.shields.io/github/v/release/Andre0512/hon?color=green )](https://github.com/Andre0512/hon/releases/latest)
2023-04-18 15:50:27 -06:00
[![GitHub ](https://img.shields.io/github/license/Andre0512/hon?color=red )](https://github.com/Andre0512/hon/blob/main/LICENSE)
[![GitHub all releases ](https://img.shields.io/github/downloads/Andre0512/hon/total?color=blue )](https://tooomm.github.io/github-release-stats/?username=Andre0512& repository=hon)
2023-04-01 18:43:20 -06:00
Home Assistant integration for Haier hOn: support for Haier/Candy/Hoover home appliances like washing machines.
2023-04-16 15:35:43 -06:00
2023-03-21 15:28:08 -06:00
## Supported Appliances
2023-04-16 15:35:43 -06:00
- [Washing Machine ](https://github.com/Andre0512/hon#washing-machine )
- [Tumble Dryer ](https://github.com/Andre0512/hon#tumble-dryer )
- [Washer Dryer ](https://github.com/Andre0512/hon#washer-dryer )
- [Oven ](https://github.com/Andre0512/hon#oven )
- [Hob ](https://github.com/Andre0512/hon#hob )
- [Dish Washer ](https://github.com/Andre0512/hon#dish-washer )
2023-04-11 14:08:47 -06:00
2023-03-04 17:22:05 -07:00
## Installation
2023-04-07 22:15:33 -06:00
**Method 1:** [![Open your Home Assistant instance and open a repository inside the Home Assistant Community Store. ](https://my.home-assistant.io/badges/hacs_repository.svg )](https://my.home-assistant.io/redirect/hacs_repository/?owner=Andre0512& repository=hon& category=integration)
2023-04-01 18:43:20 -06:00
2023-04-07 22:15:33 -06:00
**Method 2:** [HACS ](https://hacs.xyz/ ) > Integrations > Add Integration > **Haier hOn** > Install
2023-04-01 18:43:20 -06:00
2023-04-07 22:15:33 -06:00
**Method 3:** Manually copy `hon` folder from [latest release ](https://github.com/Andre0512/hon/releases/latest ) to `config/custom_components` folder.
2023-04-01 18:43:20 -06:00
2023-04-10 00:17:27 -06:00
_Restart Home Assistant_
2023-04-01 18:43:20 -06:00
## Configuration
2023-04-07 22:15:33 -06:00
**Method 1**: [![Open your Home Assistant instance and start setting up a new integration. ](https://my.home-assistant.io/badges/config_flow_start.svg )](https://my.home-assistant.io/redirect/config_flow_start/?domain=hon)
2023-04-01 18:43:20 -06:00
2023-04-07 22:15:33 -06:00
**Method 2**: Settings > Devices & Services > Add Integration > **Haier hOn**
_If the integration is not in the list, you need to clear the browser cache._
2023-03-04 17:22:05 -07:00
2023-03-06 10:40:30 -07:00
## Contribute
Any kind of contribution is welcome!
2023-04-11 14:08:47 -06:00
### 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.
For every device exists a hidden button which can be used to log all info of your appliance.
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._
2. Press the button
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
2023-03-06 10:40:30 -07:00
1. Install [pyhOn ](https://github.com/Andre0512/pyhOn )
```commandline
$ pip install pyhOn
```
2023-04-11 14:08:47 -06:00
2. Use the command line tool to read out all appliance data from your account
2023-03-06 10:40:30 -07:00
```commandline
$ pyhOn
User for hOn account: user.name@example.com
Password for hOn account: ** ******
========== WM - Washing Machine ==========
commands:
pauseProgram: pauseProgram command
resumeProgram: resumeProgram command
startProgram: startProgram command
stopProgram: stopProgram command
data:
actualWeight: 0
airWashTempLevel: 0
airWashTime: 0
antiAllergyStatus: 0
...
```
3. Fork this repository and clone it to your local machine
4. Add the keys of the attributes you'd like to have as `EntityDescription` into this Repository
_Example: Add pause button_
```python
BUTTONS: dict[str, tuple[ButtonEntityDescription, ...]] = {
"WM": ( # WM is the applianceTypeName
ButtonEntityDescription(
key="pauseProgram", # key from pyhOn
name="Pause Program", # name in home assistant
icon="mdi:pause", # icon in home assistant
...
),
...
```
5. Create a [pull request ](https://github.com/Andre0512/hon/pulls )
#### Tips and Tricks
2023-04-10 00:17:27 -06:00
- If you want to have some states humanreadable, have a look at the `translation_key` parameter of the `EntityDescription` .
2023-03-06 10:40:30 -07:00
- 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.
2023-04-10 17:03:54 -06:00
- Use [pyhOn's translate command ](https://github.com/Andre0512/pyhOn#translation ) to read out the official translations
2023-03-06 10:40:30 -07:00
2023-03-04 17:22:05 -07:00
## Tested Devices
2023-03-21 15:28:08 -06:00
- Haier WD90-B14TEAM5
- Haier HD80-A3959
2023-04-07 22:15:33 -06:00
- Haier HWO60SM2F3XH
- Hoover H-WASH 500
2023-04-19 09:47:05 -06:00
- Candy CIS633SCTTWIFI
- Haier XIB 3B2SFS-80
- Haier XIB 6B2D3FB
2023-03-04 17:22:05 -07:00
2023-04-22 13:33:49 -06:00
## Supported Languages
Translation of internal names like programs are available for all languages which are official supported by the hOn app:
2023-04-22 13:52:49 -06:00
* 🇨🇳 Chinese
* 🇭🇷 Croatian
* 🇨🇿 Czech
* 🇳🇱 Dutch
* 🇬🇧 English
* 🇫🇷 French
* 🇩🇪 German
* 🇬🇷 Greek
* 🇮🇱 Hebrew
* 🇮🇹 Italian
* 🇵🇱 Polish
* 🇵🇹 Portuguese
* 🇷🇴 Romanian
* 🇷🇺 Russian
* 🇷🇸 Serbian
* 🇸🇰 Slovak
* 🇸🇮 Slovenian
* 🇪🇸 Spanish
* 🇹🇷 Turkish
2023-04-22 13:33:49 -06:00
2023-03-04 17:22:05 -07:00
## About this Repo
The existing integrations missed some features from the app I liked to have in HomeAssistant.
I tried to create a pull request, but in the structures of these existing repos, I find it hard to fit in my needs, so I basically rewrote everything.
I moved the api related stuff into the package [pyhOn ](https://github.com/Andre0512/pyhOn ).
2023-04-16 15:35:43 -06:00
## Appliance Features
2023-04-17 15:18:27 -06:00
2023-04-16 15:35:43 -06:00
### Dish washer
#### Controls
2023-04-22 18:01:14 -06:00
| Name | Icon | Entity | Key | Auto-Translation |
| --- | --- | --- | --- | --- |
| Dish Washer | `dishwasher` | `switch` | `startProgram` / `stopProgram` | ✔ |
2023-04-16 15:35:43 -06:00
#### Configs
2023-04-22 18:01:14 -06:00
| Name | Icon | Entity | Key | Auto-Translation |
| --- | --- | --- | --- | --- |
| 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` | ❌ |
2023-04-23 08:24:30 -06:00
| Energy Label | `lightning-bolt-circle` | `sensor` | `startProgram.energyLabel` | ✔ |
2023-04-22 18:01:14 -06:00
| 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` | ✔ |
| 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` | ✔ |
2023-04-16 15:35:43 -06:00
#### Sensors
2023-04-22 18:01:14 -06:00
| Name | Icon | Entity | Key | Auto-Translation |
| --- | --- | --- | --- | --- |
| 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` | ✔ |
2023-04-17 15:18:27 -06:00
2023-04-16 15:35:43 -06:00
### Hob
#### Controls
2023-04-22 18:01:14 -06:00
| Name | Icon | Entity | Key | Auto-Translation |
| --- | --- | --- | --- | --- |
| Start Program | `pot-steam` | `button` | `startProgram` | ✔ |
2023-04-16 15:35:43 -06:00
#### Configs
2023-04-22 18:01:14 -06:00
| Name | Icon | Entity | Key | Auto-Translation |
| --- | --- | --- | --- | --- |
| Power Management | `timelapse` | `number` | `startProgram.powerManagement` | ✔ |
| Program | | `select` | `startProgram.program` | ✔ |
| Temperature | `thermometer` | `number` | `startProgram.temp` | ✔ |
2023-04-16 15:35:43 -06:00
#### Sensors
2023-04-22 18:01:14 -06:00
| Name | Icon | Entity | Key | Auto-Translation |
| --- | --- | --- | --- | --- |
| 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` | ✔ |
| Remote Control | `remote` | `binary_sensor` | `attributes.parameters.remoteCtrValid` | ✔ |
| Temperature | `thermometer` | `sensor` | `temp` | ✔ |
2023-04-17 15:18:27 -06:00
2023-04-16 15:35:43 -06:00
### Oven
#### Controls
2023-04-22 18:01:14 -06:00
| Name | Icon | Entity | Key | Auto-Translation |
| --- | --- | --- | --- | --- |
| Oven | `toaster-oven` | `switch` | `startProgram` / `stopProgram` | ✔ |
2023-04-16 15:35:43 -06:00
#### Configs
2023-04-22 18:01:14 -06:00
| Name | Icon | Entity | Key | Auto-Translation |
| --- | --- | --- | --- | --- |
| 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` | ✔ |
2023-04-16 15:35:43 -06:00
#### Sensors
2023-04-22 18:01:14 -06:00
| Name | Icon | Entity | Key | Auto-Translation |
| --- | --- | --- | --- | --- |
| Connection | `wifi` | `binary_sensor` | `attributes.lastConnEvent.category` | ✔ |
| On | `power-cycle` | `binary_sensor` | `attributes.parameters.onOffStatus` | ❌ |
| Remaining Time | `timer` | `sensor` | `remainingTimeMM` | ✔ |
| Remote Control | `remote` | `binary_sensor` | `attributes.parameters.remoteCtrValid` | ✔ |
| Start Time | `clock-start` | `sensor` | `delayTime` | ✔ |
| Temperature | `thermometer` | `sensor` | `temp` | ✔ |
| Temperature Selected | `thermometer` | `sensor` | `tempSel` | ✔ |
2023-04-17 15:18:27 -06:00
2023-04-16 15:35:43 -06:00
### Tumble dryer
#### Controls
2023-04-22 18:01:14 -06:00
| Name | Icon | Entity | Key | Auto-Translation |
| --- | --- | --- | --- | --- |
| Pause Tumble Dryer | `pause` | `switch` | `pauseProgram` / `resumeProgram` | ✔ |
| Tumble Dryer | `tumble-dryer` | `switch` | `startProgram` / `stopProgram` | ✔ |
2023-04-16 15:35:43 -06:00
#### Configs
2023-04-22 18:01:14 -06:00
| Name | Icon | Entity | Key | Auto-Translation |
| --- | --- | --- | --- | --- |
| Anti-Crease | `timer` | `switch` | `startProgram.antiCreaseTime` | ✔ |
| Delay time | `timer-plus` | `number` | `startProgram.delayTime` | ✔ |
2023-04-23 08:24:30 -06:00
| Dry Time | | `number` | `startProgram.dryTime` | ✔ |
| Dry Time | `timer` | `select` | `startProgram.dryTimeMM` | ✔ |
2023-04-22 18:01:14 -06:00
| Dry level | `hair-dryer` | `select` | `startProgram.dryLevel` | ✔ |
2023-04-23 08:24:30 -06:00
| Energy Label | `lightning-bolt-circle` | `sensor` | `startProgram.energyLabel` | ✔ |
2023-04-22 18:01:14 -06:00
| Program | | `select` | `startProgram.program` | ✔ |
| Sterilization | `clock-start` | `switch` | `startProgram.sterilizationStatus` | ❌ |
2023-04-23 08:24:30 -06:00
| Suggested Load | `weight-kilogram` | `sensor` | `startProgram.suggestedLoadD` | ✔ |
2023-04-22 18:01:14 -06:00
| Temperature level | `thermometer` | `number` | `startProgram.tempLevel` | ✔ |
2023-04-16 15:35:43 -06:00
#### Sensors
2023-04-22 18:01:14 -06:00
| Name | Icon | Entity | Key | Auto-Translation |
| --- | --- | --- | --- | --- |
| Connection | | `binary_sensor` | `attributes.lastConnEvent.category` | ✔ |
2023-04-23 08:24:30 -06:00
| Door | | `binary_sensor` | `doorStatus` | ✔ |
2023-04-22 18:01:14 -06:00
| Dry level | `hair-dryer` | `sensor` | `dryLevel` | ✔ |
| Error | `math-log` | `sensor` | `errors` | ✔ |
| Machine Status | `information` | `sensor` | `machMode` | ✔ |
| Program | `tumble-dryer` | `sensor` | `prCode` | ✔ |
| Program Phase | `washing-machine` | `sensor` | `prPhase` | ✔ |
| Remaining Time | `timer` | `sensor` | `remainingTimeMM` | ✔ |
| Start Time | `clock-start` | `sensor` | `delayTime` | ✔ |
| Temperature level | `thermometer` | `sensor` | `tempLevel` | ✔ |
2023-04-17 15:18:27 -06:00
2023-04-16 15:35:43 -06:00
### Washer dryer
#### Controls
2023-04-22 18:01:14 -06:00
| Name | Icon | Entity | Key | Auto-Translation |
| --- | --- | --- | --- | --- |
| Pause Washing Machine | `pause` | `switch` | `pauseProgram` / `resumeProgram` | ✔ |
| Washing Machine | `washing-machine` | `switch` | `startProgram` / `stopProgram` | ✔ |
2023-04-16 15:35:43 -06:00
#### Configs
2023-04-22 18:01:14 -06:00
| Name | Icon | Entity | Key | Auto-Translation |
| --- | --- | --- | --- | --- |
| Delay Time | `timer-plus` | `number` | `startProgram.delayTime` | ✔ |
| Program | | `select` | `startProgram.program` | ✔ |
2023-04-23 08:24:30 -06:00
| Suggested weight | `weight-kilogram` | `sensor` | `startProgram.weight` | ✔ |
2023-04-16 15:35:43 -06:00
#### Sensors
2023-04-22 18:01:14 -06:00
| Name | Icon | Entity | Key | Auto-Translation |
| --- | --- | --- | --- | --- |
| Acqua Plus | | `binary_sensor` | `acquaplus` | ✔ |
| Anti-Crease | | `binary_sensor` | `anticrease` | ✔ |
| Current Electricity Used | `lightning-bolt` | `sensor` | `currentElectricityUsed` | ❌ |
| Current Program | `tumble-dryer` | `sensor` | `prCode` | ❌ |
| Current Temperature | `thermometer` | `sensor` | `temp` | ✔ |
| Current Water Used | `water` | `sensor` | `currentWaterUsed` | ❌ |
| Dirt level | `liquid-spot` | `sensor` | `dirtyLevel` | ✔ |
| Dry level | `hair-dryer` | `sensor` | `dryLevel` | ✔ |
| 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 | `fast-forward-outline` | `sensor` | `spinSpeed` | ✔ |
| Steam level | `smoke` | `sensor` | `steamLevel` | ✔ |
| Total Power | | `sensor` | `totalElectricityUsed` | ❌ |
| Total Wash Cycle | `counter` | `sensor` | `totalWashCycle` | ❌ |
| Total Water | | `sensor` | `totalWaterUsed` | ❌ |
2023-04-17 15:18:27 -06:00
2023-04-16 15:35:43 -06:00
### Washing machine
#### Controls
2023-04-22 18:01:14 -06:00
| Name | Icon | Entity | Key | Auto-Translation |
| --- | --- | --- | --- | --- |
| Pause Washing Machine | `pause` | `switch` | `pauseProgram` / `resumeProgram` | ✔ |
| Washing Machine | `washing-machine` | `switch` | `startProgram` / `stopProgram` | ✔ |
2023-04-16 15:35:43 -06:00
#### Configs
2023-04-22 18:01:14 -06:00
| Name | Icon | Entity | Key | Auto-Translation |
| --- | --- | --- | --- | --- |
| Delay Status | `timer-check` | `switch` | `startProgram.delayStatus` | ❌ |
| Delay Time | `timer-plus` | `number` | `startProgram.delayTime` | ✔ |
2023-04-23 08:24:30 -06:00
| Energy Label | `lightning-bolt-circle` | `sensor` | `startProgram.energyLabel` | ✔ |
| Keep Fresh | `refresh-circle` | `switch` | `startProgram.autoSoftenerStatus` | ✔ |
| Liquid Detergent Dose | `cup-water` | `sensor` | `startProgram.liquidDetergentDose` | ✔ |
2023-04-22 18:01:14 -06:00
| Main Wash Time | `clock-start` | `number` | `startProgram.mainWashTime` | ✔ |
2023-04-23 08:24:30 -06:00
| Powder Detergent Dose | `cup` | `sensor` | `startProgram.powderDetergentDose` | ✔ |
2023-04-22 18:01:14 -06:00
| Program | | `select` | `startProgram.program` | ✔ |
| Rinse Iterations | `rotate-right` | `number` | `startProgram.rinseIterations` | ✔ |
| Soak Prewash Selection | `tshirt-crew` | `switch` | `startProgram.haier_SoakPrewashSelection` | ✔ |
| Spin speed | `numeric` | `select` | `startProgram.spinSpeed` | ✔ |
2023-04-23 08:24:30 -06:00
| Suggested weight | `weight-kilogram` | `sensor` | `startProgram.weight` | ✔ |
2023-04-22 18:01:14 -06:00
| Temperature | `thermometer` | `select` | `startProgram.temp` | ✔ |
2023-04-16 15:35:43 -06:00
#### Sensors
2023-04-22 18:01:14 -06:00
| Name | Icon | Entity | Key | Auto-Translation |
| --- | --- | --- | --- | --- |
| Current Electricity Used | `lightning-bolt` | `sensor` | `currentElectricityUsed` | ❌ |
| Current Water Used | `water` | `sensor` | `currentWaterUsed` | ❌ |
2023-04-23 08:24:30 -06:00
| Door | | `binary_sensor` | `doorStatus` | ✔ |
2023-04-22 18:01:14 -06:00
| Door Lock | | `binary_sensor` | `doorLockStatus` | ✔ |
| Error | `math-log` | `sensor` | `errors` | ✔ |
| Machine Status | `information` | `sensor` | `machMode` | ✔ |
| 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` | ❌ |