2018-05-13 11:37:02 +02:00
|
|
|
Fan Component
|
|
|
|
=============
|
|
|
|
|
2018-11-14 22:12:27 +01:00
|
|
|
.. seo::
|
|
|
|
:description: Instructions for setting up the base fan component.
|
2018-11-19 18:32:16 +01:00
|
|
|
:image: folder-open.png
|
2018-11-14 22:12:27 +01:00
|
|
|
|
2018-05-13 11:37:02 +02:00
|
|
|
With the ``fan`` domain you can create components that appear as fans in
|
|
|
|
the Home Assistant frontend. A fan can be switched ON or OFF, optionally
|
2021-03-17 14:40:33 +01:00
|
|
|
has a speed level between 1 and the maximum supported speed level of the fan, and can have an
|
|
|
|
oscillate and direction output.
|
2018-05-13 11:37:02 +02:00
|
|
|
|
2019-03-17 12:10:03 +01:00
|
|
|
This component restores its state on reboot/reset.
|
|
|
|
|
2018-06-01 18:10:00 +02:00
|
|
|
.. figure:: images/fan-ui.png
|
|
|
|
:align: center
|
2018-05-13 11:37:02 +02:00
|
|
|
|
2018-06-01 18:10:00 +02:00
|
|
|
.. _config-fan:
|
2018-05-13 11:37:02 +02:00
|
|
|
|
|
|
|
Base Fan Configuration
|
2018-08-24 22:44:01 +02:00
|
|
|
----------------------
|
2018-05-13 11:37:02 +02:00
|
|
|
|
2018-11-19 18:32:16 +01:00
|
|
|
.. code-block:: yaml
|
2018-05-13 11:37:02 +02:00
|
|
|
|
|
|
|
fan:
|
|
|
|
- platform: ...
|
|
|
|
name: ...
|
|
|
|
|
|
|
|
Configuration variables:
|
|
|
|
|
2018-06-01 18:10:00 +02:00
|
|
|
- **name** (**Required**, string): The name of the fan.
|
2019-02-17 12:28:17 +01:00
|
|
|
- **internal** (*Optional*, boolean): Mark this component as internal. Internal components will
|
|
|
|
not be exposed to the frontend (like Home Assistant). Only specifying an ``id`` without
|
|
|
|
a ``name`` will implicitly set this to true.
|
2021-08-10 03:45:41 +02:00
|
|
|
- **disabled_by_default** (*Optional*, boolean): If true, then this entity should not be added to any client's frontend,
|
|
|
|
(usually Home Assistant) without the user manually enabling it (via the Home Assistant UI).
|
|
|
|
Requires Home Assistant 2021.9 or newer. Defaults to ``false``.
|
2019-02-17 12:28:17 +01:00
|
|
|
|
|
|
|
MQTT options:
|
|
|
|
|
2018-06-01 18:10:00 +02:00
|
|
|
- **oscillation_state_topic** (*Optional*, string): The topic to
|
2018-10-20 15:10:26 +02:00
|
|
|
publish fan oscillation state changes to.
|
2018-06-01 18:10:00 +02:00
|
|
|
- **oscillation_command_topic** (*Optional*, string): The topic to
|
|
|
|
receive oscillation commands on.
|
|
|
|
- **speed_state_topic** (*Optional*, string): The topic to publish fan
|
|
|
|
speed state changes to.
|
|
|
|
- **speed_command_topic** (*Optional*, string): The topic to receive
|
2018-06-06 16:10:46 +02:00
|
|
|
speed commands on.
|
2018-06-01 18:10:00 +02:00
|
|
|
- All other options from :ref:`MQTT Component <config-mqtt-component>`.
|
|
|
|
|
2021-05-19 06:12:59 +02:00
|
|
|
Automation triggers:
|
|
|
|
|
|
|
|
- **on_turn_on** (*Optional*, :ref:`Action <config-action>`): An automation to perform
|
|
|
|
when the fan is turned on. See :ref:`fan-on_turn_on_off_trigger`.
|
|
|
|
- **on_turn_off** (*Optional*, :ref:`Action <config-action>`): An automation to perform
|
|
|
|
when the fan is turned off. See :ref:`fan-on_turn_on_off_trigger`.
|
|
|
|
|
2018-06-01 18:10:00 +02:00
|
|
|
.. _fan-toggle_action:
|
|
|
|
|
|
|
|
``fan.toggle`` Action
|
2018-08-24 22:44:01 +02:00
|
|
|
---------------------
|
2018-06-01 18:10:00 +02:00
|
|
|
|
|
|
|
Toggles the ON/OFF state of the fan with the given ID when executed.
|
|
|
|
|
2018-11-19 18:32:16 +01:00
|
|
|
.. code-block:: yaml
|
2018-06-01 18:10:00 +02:00
|
|
|
|
|
|
|
on_...:
|
|
|
|
then:
|
2018-10-20 14:53:27 +02:00
|
|
|
- fan.toggle: fan_1
|
2018-06-01 18:10:00 +02:00
|
|
|
|
|
|
|
.. _fan-turn_off_action:
|
|
|
|
|
|
|
|
``fan.turn_off`` Action
|
2018-08-24 22:44:01 +02:00
|
|
|
-----------------------
|
2018-06-01 18:10:00 +02:00
|
|
|
|
|
|
|
Turns the fan with the given ID off when executed.
|
|
|
|
|
2018-11-19 18:32:16 +01:00
|
|
|
.. code-block:: yaml
|
2018-06-01 18:10:00 +02:00
|
|
|
|
|
|
|
on_...:
|
|
|
|
then:
|
2018-10-20 14:53:27 +02:00
|
|
|
- fan.turn_off: fan_1
|
2018-06-01 18:10:00 +02:00
|
|
|
|
|
|
|
.. _fan-turn_on_action:
|
|
|
|
|
|
|
|
``fan.turn_on`` Action
|
2018-08-24 22:44:01 +02:00
|
|
|
----------------------
|
2018-06-01 18:10:00 +02:00
|
|
|
|
2021-05-26 00:35:11 +02:00
|
|
|
Turns the fan with the given ID on when executed.
|
2018-06-01 18:10:00 +02:00
|
|
|
|
2018-11-19 18:32:16 +01:00
|
|
|
.. code-block:: yaml
|
2018-06-01 18:10:00 +02:00
|
|
|
|
|
|
|
on_...:
|
|
|
|
then:
|
|
|
|
- fan.turn_on:
|
2018-06-02 21:54:39 +02:00
|
|
|
id: fan_1
|
2018-11-10 14:31:27 +01:00
|
|
|
# Shorthand:
|
|
|
|
- fan.turn_on: fan_1
|
2018-06-01 18:10:00 +02:00
|
|
|
|
|
|
|
Configuration options:
|
|
|
|
|
2018-06-02 21:54:39 +02:00
|
|
|
- **id** (**Required**, :ref:`config-id`): The ID of the fan.
|
2018-06-01 18:10:00 +02:00
|
|
|
- **oscillating** (*Optional*, boolean, :ref:`templatable <config-templatable>`):
|
|
|
|
Set the oscillation state of the fan. Defaults to not affecting oscillation.
|
2021-03-17 14:40:33 +01:00
|
|
|
- **speed** (*Optional*, int, :ref:`templatable <config-templatable>`):
|
|
|
|
Set the speed level of the fan. Can be a number between 1 and the maximum speed level of the fan.
|
2018-06-01 18:10:00 +02:00
|
|
|
|
2021-05-19 06:12:59 +02:00
|
|
|
.. _fan-on_turn_on_off_trigger:
|
|
|
|
|
|
|
|
``fan.on_turn_on`` / ``fan.on_turn_off`` Trigger
|
|
|
|
****************************************************
|
|
|
|
|
|
|
|
This trigger is activated each time the fan is turned on or off. It does not fire
|
|
|
|
if a command to turn the fan on or off already matches the current state.
|
|
|
|
|
|
|
|
.. code-block:: yaml
|
|
|
|
|
|
|
|
fan:
|
|
|
|
- platform: speed # or any other platform
|
|
|
|
# ...
|
|
|
|
on_turn_on:
|
|
|
|
- logger.log: "Fan Turned On!"
|
|
|
|
on_turn_off:
|
|
|
|
- logger.log: "Fan Turned Off!"
|
|
|
|
|
2018-06-01 18:10:00 +02:00
|
|
|
Full Fan Index
|
2018-08-24 22:44:01 +02:00
|
|
|
--------------
|
2018-06-01 18:10:00 +02:00
|
|
|
|
2019-02-07 13:54:45 +01:00
|
|
|
- :apiref:`fan/fan_state.h`
|
|
|
|
- :ghedit:`Edit`
|
2018-06-01 18:10:00 +02:00
|
|
|
|
|
|
|
.. toctree::
|
|
|
|
:maxdepth: 1
|
2018-10-20 14:53:27 +02:00
|
|
|
:glob:
|
2018-06-01 18:10:00 +02:00
|
|
|
|
2018-10-20 14:53:27 +02:00
|
|
|
*
|