You need to configure your configuration.yaml file, adding the code below for your Home Assistant to search for themes in the themes folder:
frontend:
themes: !include_dir_merge_named themes
ATTENTION! It is necessary to restart after this configuration!
(If you are not HACS) Learn how to install
- Go to the HACS Community Store
- Click on the "Frontend" option
- Click on the (+) button
- Search for "Zeno Themes"
- Click "Install"
- Restart your Home Assistant
Then download the zeno-themes.yaml clicking here and copy the file to your themes folder.
If your themes folder does not yet exist, you must create it within the config folder
10 of the 40 themes have backgrounds and all themes use animated icons for the weather forecast card. These files need to be downloaded and copied to your Home Assistant server.
- Download the backgrounds and icons
- Extract the file
- Copy the folder zeno-themes into the folder config/www/. The final path to the file folder should be config/www/zeno-themes/
*ATTENTION! If your www folder does not yet exist, create it within the config folder. *
Now restart your Home Assistant and the themes will be available for use.
We will create a theme selector to be implemented in your user interface. It is a practical way to change the theme instantly on all devices connected to your Home Assistant. See how it works in the gif below:
The input_select will be used to create the selection list with the themes that I created.
Insert this code into your file configuration.yaml
If you've never used input select, learn more by clicking here.
input_select:
themes:
name: 'Themes'
icon: mdi:format-paint
options:
- Zeno Dark Rose
- Zeno Dark Purple
- Zeno Dark Blue
- Zeno Dark Aqua
- Zeno Dark Green
- Zeno Dark Yellow
- Zeno Dark Orange
- Zeno Dark Coral
- Zeno Dark Pink
- Zeno Dark Gray
- Zeno Light Rose
- Zeno Light Purple
- Zeno Light Blue
- Zeno Light Aqua
- Zeno Light Green
- Zeno Light Yellow
- Zeno Light Orange
- Zeno Light Coral
- Zeno Light Pink
- Zeno Light Gray
- default
Restart your Home Assistant so that the input_select is created.
Result:
- input_select.themes
Copy the code below and paste it into your file automations.yaml
- alias: "set Themes"
initial_state: true
trigger:
platform: state
entity_id: input_select.themes
action:
- service: frontend.set_theme
data_template:
name: >
{{ trigger.to_state.state }}
WARNING! If you've never used Node-RED, learn more by clicking here.
We will create a flow in Node-RED to define the theme automatically every time you choose a theme in your interface. It's very simple! Just download the .json file or copy the code and paste it into the Node-RED import window.
Click here to copy or download the code for Node-RED flows
After importing the flow to your Node-RED, click Deploy
Now just insert the selector code in your interface.
- If you use the interface in YAML Mode, copy the code and insert it into your ui-lovelace.yaml
- If you use the interface in automatic mode, go to the editing mode of your interface, choose the "manual" option at the end, then copy and paste the code below.
type: entities
show_header_toggle: false
entities:
- entity: input_select.themes
Change the theme in the user's profile to "Backend-selected". This way, all connected devices with the theme "Backend-selected" will have their themes changed synchronously with the theme selector you just created.