ESPHome-Devices/components/tuya_dimmer_as_fan
2024-07-22 18:34:02 -05:00
..
__init__.py Rewrite the Tuya dimmer as fan component (#11) 2021-07-13 07:55:29 -05:00
fan.py A bunch of misc changes (#32) 2022-03-29 13:54:34 -05:00
README.md Bunch of updates from the last year or so (#47) 2024-07-22 18:34:02 -05:00
tuya_dimmer_as_fan.cpp Updates to support ESPHome 2022.8.0 (#41) 2022-08-26 19:03:39 -05:00
tuya_dimmer_as_fan.h A bunch of misc changes (#32) 2022-03-29 13:54:34 -05:00

Tuya Dimmer as Fan Component

Overview

This a modified version of the Tuya fan component I use with Feit Dimmers (but it will likely work with other Tuya dimmers) to control bathroom fans. Changes from the standard Tuya fan component include the following:

  • Remove options for speed, oscillation, and direction as they don't apply.
  • Always change the "brightness" back to the maximum value effectively making this only an on/off device.
  • Can add a sensor to report current power usage based on a configured wattage of the fan(s) it controls.

Setup

Using the External Components feature in ESPHome you can add this component to your devices directly from my GitHub repo.

external_components:
  - source: github://nuttytree/ESPHome-Devices
    components: [ tuya_dimmer_as_fan ]

Like the standard Tuya fan component you need to have the UART and Tuya components.

uart:
  rx_pin: GPIO3
  tx_pin: GPIO1
  baud_rate: 9600

tuya:

Add and configure the Tuya Dimmer as Fan component

fan:
  - platform: tuya_dimmer_as_fan
    name: my_fan
    switch_datapoint: 1
    dimmer_datapoint: 2
    dimmer_max_value: 1000
    power:
      id: my_fan_power
      name: My Fan Power
      fan_wattage: 21.6
      update_interval: 60s

Configuration Variables (In addition to the standard variables)

  • dimmer_datapoint (Required, int): The datapoint id number of the dimmer value.
  • dimmer_max_value (Optional, int, default 255): The highest dimmer value allowed.
  • power.id (Optional, string) Manually specify the power sensor ID used for code generation.
  • power.name (Optional, string) The name for the power sensor.
  • power.fan_wattage (Optional, float) The total wattage of the fan(s) controled by this dimmer.
  • power.update_interval (Optional, Time, default: 60s) Amount of time between updates of the power value while on.