More information about the M5 Stack Dial
This component turns the M5 Stack Dial into a universal remote control for Home Assistant.
Currently supported entities are:
- climate
- cover
- fan
- light
- switch
- media_player
- lock
For quick exchanges, suggestions, and updates on the current development status, our Discord is also available.
Invite Link: https://discord.gg/pN7SpK7
substitutions:
name: "m5-dial"
wifi_ssid: !secret wifi_ssid
wifi_password: !secret wifi_password
packages:
m5_tough_package:
url: https://github.com/chadlipscomb/m5-dial-for-esphome
ref: main
file: shys-m5-dial.yaml
refresh: 1h
shys_m5_dial:
name: Dial
screen_off_time: 45000
rotary_step_width: 5
long_press_duration: 1200
font: FreeSans12pt7b
font_factor: 1
devices:
lights:
- entity: light.my_light1
name: Light 1
modes:
dimm_mode:
enable: true
rotary_step_width: 10
rgb_mode:
enable: true
rotary_step_width: 30
white_mode:
enable: true
rotary_step_width: 100
min_kelvin: 2500
max_kelvin: 7000
- entity: light.my_light2
name: Light 2
switches:
- entity: switch.my_switch
name: Switch 1
climates:
- entity: climate.my_climate1
name: Heater
modes:
temp_mode:
rotary_step_width: 1
min_temperature: 4
max_temperature: 30
covers:
- entity: cover.my_cover1
name: Cover 1
modes:
position_mode:
rotary_step_width: 5
fans:
- entity: fan.my_fan1
name: Fan 1
modes:
speed_mode:
changeable_direction: true
rotary_step_width: 10
media_player:
- entity: media_player.my_player1
name: MediaPlayer 1
modes:
play_mode:
rotary_step_width: 10
source_mode:
rotary_step_width: 1
sources:
- name: 1Live
content_id: 1Live
content_type: TUNEIN
- name: WDR2
content_id: "http://wdr-wdr2-bergischesland.icecast.wdr.de/wdr/wdr2/bergischesland/mp3/128/stream.mp3"
content_type: custom
lock:
- entity: lock.my_lock1
name: Lock 1
modes:
lock_mode:
rotary_step_width: 1
open_on_button: false
In substitutions, the devicename
must be specified.
The wireless network connection must be fully configured either through the normal wifi:
section, or alternatively, you can simply specify the WLAN SSID and WLAN password in the substitutions.
substitutions:
name: "m5-dial"
wifi_ssid: !secret wifi_ssid
wifi_password: !secret wifi_password
name
The hostname of the device. (default: m5-dial)
wifi_ssid
The hostname of the device. (default: !secret wifi_ssid)
wifi_password
The hostname of the device. (default: !secret wifi_password)
General attributes are all parameters available directly under the custom component "shys_m5_dial".
Code:
shys_m5_dial:
name: Dial
screenOffTime: 45000
rotaryStepWidth: 5
longPressDuration: 1200
name
Sets the name of the component.
screenOffTime (optional) (Default: 30000)
Indicates after how many milliseconds the display automatically turns off.
rotaryStepWidth (optional) (Default: 10)
Specifies the general step width by which the value changes per step when using the rotary encoder.
The value set here applies to all modes where no different step width is specified.
longPressDuration (optional) (Default: 1200)
Indicates the duration, in milliseconds, after which a button press is considered a long press.
font (optional) (Default: FreeSans12pt7b)
Specifies the font to be used.
All available fonts are defined in a map in globals.h.
font_factor (optional) (Default: 1)
Specifies the factor to be applied to the font size.
Valid values: 0.1 - 10.0
Under Devices, all entities to be controlled with the M5 Dial are specified.
The entities are specified in individual lists per device type (domain) such as lights, switches, covers, etc.
Code:
shys_m5_dial:
...
devices:
Under "devices - lights" all light entities are specified.
Without further specifications, the lamp can only be turned on/off via the Dial.
To adjust color, brightness, or white value, the respective mode must be activated.
Code:
shys_m5_dial:
...
devices:
lights:
- entity: light.my_light1
name: Light 1
entity
Specifies the Light Entity ID from Home Assistant to be controlled.
name
The name of the entity displayed on the screen.
The Dimm Mode allows regulating the brightness of the light entity.
When Dimm Mode is active, it replaces the standard On/Off Mode.
Brightness can be controlled both via the rotary encoder and touch.
A press on the button turns the light on/off.
Code:
shys_m5_dial:
...
devices:
lights:
- entity: light.my_light1
name: Light 1
modes:
dimm_mode:
enable: true
rotary_step_width: 10
enable (Default: false)
Setting to true activates the mode for the entity.
rotary_step_width (optional)
Specifies the general step width by which the value changes per step when using the rotary encoder.
The value set here overrides the general setting and applies only to the brightness mode of this light entity.
Valid values: 1 - 100
The White Mode allows regulating the white tone for the light entity in Kelvin.
The white tone can be controlled both via the rotary encoder and touch.
A press on the button turns the light on/off.
Code:
shys_m5_dial:
...
devices:
lights:
- entity: light.my_light1
name: Light 1
modes:
white_mode:
enable: true
rotary_step_width: 100
min_kelvin: 2500
max_kelvin: 7000
enable (Default: false)
Setting to true activates the mode for the entity.
rotary_step_width (optional)
Specifies the general step width by which the value changes per step when using the rotary encoder.
The value set here overrides the general setting and applies only to the white tone mode of this light entity.
Valid values: 1 - 500
min_kelvin (optional) (Default: 2000)
Specifies the minimum value in Kelvin for white tone control.
Valid values: 1000 - 10000
max_kelvin (optional) (Default: 6500)
Specifies the maximum value in Kelvin for white tone control.
Valid values: 1000 - 10000
The RGB Mode (color selection) allows selecting the color for the light entity.
Color can be controlled both via the rotary encoder and touch.
A press on the button turns the light on/off.
Code:
shys_m5_dial:
...
devices:
lights:
- entity: light.my_light1
name: Light 1
modes:
rgb_mode:
enable: true
rotary_step_width: 30
enable Default: false
Setting to true activates the mode for the entity.
rotary_step_width (optional)
Specifies the general step width by which the value changes per step when using the rotary encoder.
The value set here overrides the general setting and applies only to the color selection mode of this light entity.
Valid values: 1 - 100
Under "devices - climates" all climate entities are specified.
Code:
shys_m5_dial:
...
devices:
climates:
- entity: climate.my_climate1
name: Heater
entity
Specifies the Climate Entity ID from Home Assistant to be controlled.
name
The name of the entity displayed on the screen.
The Temp Mode allows regulating the temperature of the climate entity.
Temperature can be controlled both via the rotary encoder and touch.
A press on the button turns the heater on/off.
Code:
shys_m5_dial:
...
devices:
climates:
- entity: climate.my_climate1
name: Heater
modes:
temp_mode:
rotary_step_width: 1
min_temperature: 4
max_temperature: 30
rotary_step_width (optional) Default: 1
Specifies the general step width by which the value changes per step when using the rotary encoder.
For climates, 1 is the default, regardless of what is set as the general standard in the component.
Valid values: 1 - 100
min_temperature (optional) Default: 4
Sets the minimum temperature that can be set for this climate entity on the Dial.
max_temperature (optional) Default: 30
Sets the maximum temperature that can be set for this climate entity on the Dial.
Under "devices - cover" all cover entities are specified.
Code:
shys_m5_dial:
...
devices:
covers:
- entity: cover.my_cover1
name: Cover 1
entity
Specifies the Cover Entity ID from Home Assistant to be controlled.
name
The name of the entity displayed on the screen.
The Position Mode allows controlling the position of the cover entity.
Position can be controlled both via the rotary encoder and touch.
Code:
shys_m5_dial:
...
devices:
covers:
- entity: cover.my_cover1
name: Cover 1
modes:
position_mode:
rotary_step_width: 5
rotary_step_width (optional)
Specifies the general step width by which the value changes per step when using the rotary encoder.
The value set here overrides the general setting and applies only to the position mode of this cover entity.
Valid values: 1 - 100
Under "devices - cover" all fan entities are specified.
Code:
shys_m5_dial:
...
devices:
fans:
- entity: fan.my_fan1
name: Fan 1
entity
Specifies the Fan Entity ID from Home Assistant to be controlled.
name
The name of the fan displayed on the screen.
The Speed Mode allows controlling the speed of the fan entity.
Speed can be controlled both via the rotary encoder and touch.
A press on the button turns the fan on/off.
Code:
shys_m5_dial:
...
devices:
fans:
- entity: fan.my_fan1
name: Fan 1
modes:
speed_mode:
changeable_direction: true
rotary_step_width: 10
changeable_direction (optional) (Default: false)
Indicates whether the fan has two directions of rotation and can therefore be switched between forward and reverse.
False = Only one direction of rotation. Turning right increases the speed, turning left reduces the speed.
True = Two directions of rotation. Turning right increases the speed for forward, turning left reduces the speed for forward.
However, you can now turn past 0 and thus change the direction of rotation.
If the fan is running in reverse, turning left increases the speed and turning right reduces it.
Valid values: true / false
rotary_step_width (optional)
Specifies the general step width by which the value changes per step when using the rotary encoder.
The value set here overrides the general setting and applies only to the speed mode of this fan entity.
Valid values: 1 - 100
Under "devices - media_player" all MediaPlayer entities are specified.
Code:
shys_m5_dial:
...
devices:
media_player:
- entity: media_player.my_player1
name: MediaPlayer 1
entity
Specifies the MediaPlayer Entity ID from Home Assistant to be controlled.
name
The name of the MediaPlayer displayed on the screen.
The Play Mode allows adjusting the volume via the rotary encoder, as well as starting/pausing playback or skipping to the next or previous track via touch.
A press on the button toggles between play and pause.
Code:
shys_m5_dial:
...
devices:
media_player:
- entity: media_player.my_player1
name: MediaPlayer 1
modes:
play_mode:
rotary_step_width: 10
rotary_step_width (optional)
Specifies the general step width by which the value changes per step when using the rotary encoder.
The value set here overrides the general setting and applies only to the play mode of this MediaPlayer entity.
Valid values: 1 - 100
The Source Mode allows selecting a source from the stored "Sources" using the rotary encoder for playback.
A press on the button starts playback of the selected source.
Code:
shys_m5_dial:
...
devices:
media_player:
- entity: media_player.my_player1
name: MediaPlayer 1
modes:
play_mode:
rotary_step_width: 10
source_mode:
rotary_step_width: 1
sources:
- name: 1Live
content_id: 1Live
content_type: TUNEIN
- name: WDR2
content_id: "http://wdr-wdr2-bergischesland.icecast.wdr.de/wdr/wdr2/bergischesland/mp3/128/stream.mp3"
content_type: custom
rotary_step_width (optional) (Default: 1)
Specifies the general step width by which the value changes per step when using the rotary encoder.
For source_mode of media_player, 1 is the default, regardless of what is set as the general standard in the component.
Valid values: 1 - 100
sources (optional)
A list of audio sources available for playback selection.
Entries must always include the attributes "name", "content_id", and "content_type"!
Example for Amazon Echo (Alexa):
- name: 1Live
content_id: 1Live
content_type: TUNEIN
- name: Metallica
content_id: metallica
content_type: AMAZON_MUSIC
- name: Nothing else matters
content_id: play metallica nothing else matters
content_type: custom
Example for DLNA Player:
- name: 1Live
content_id: "https://wdr-1live-live.icecastssl.wdr.de/wdr/1live/live/mp3/128/stream.mp3"
content_type: custom
Under "devices - lock" all lock entities are listed.
Code:
shys_m5_dial:
...
devices:
lock:
- entity: lock.my_lock1
name: Lock 1
entity
Specifies the lock entity ID from Home Assistant to be controlled.
name
The name of the lock displayed on the screen.
With the lock mode, the state of the lock entity can be controlled.
The lock can be unlocked, locked, and opened using the rotary encoder.
A press on the button usually unlocks or locks the lock depending on the current state.
However, if open_on_button is set to true, pressing the button will open the lock directly instead of just unlocking it.
Code:
shys_m5_dial:
...
devices:
lock:
- entity: lock.my_lock1
name: Lock 1
modes:
lock_mode:
open_on_button: true
rotary_step_width: 10
open_on_button (optional) (Default: false)
Setting to true will directly open the lock when pressing the button instead of just unlocking it.
If the parameter is set to false (or not specified), the lock will only be unlocked but not fully opened.
Valid values: true / false
rotary_step_width (optional) (Default: 1)
Specifies the general step width by which the value changes when using the rotary encoder per step.
For lock mode of lock, 1 is the default value, regardless of what is set as the general standard in the component.
If a step width of 2 is specified here, turning the encoder will not only unlock the lock but also automatically fully open it.
Valid values: 1 - 2
The following attributes are present, but generally should not need to be changed.
send_value_delay
Specifies the delay in milliseconds to wait after a value change before transmitting the change to Home Assistant.
This is especially important when using the rotary encoder to avoid generating unnecessary API calls. (Default: 1200)
send_value_lock
Specifies how long to wait after an API call before the next API call can be made. (Default: 3000)