Welcome to the Quick Look Mobile Dashboard for Home Assistant!
- This dashboard offers a minimalist mobile interface for a simple home devices management.
- It is designed to
- Facilitate rapid navigation to any desired device in just two clicks, while still maintaining access to all of their controls.
- Deliver crucial information at a glance, such as "is my home secure? Is it occupied? Are there any lights turned on? If yes, how many?"
You can watch the Video Presentation of the v1 dashboard : Or even try the Figma Demo before installation.
Before beginning, make sure you have:
- Familiarity with YAML and Home Assistant configuration files.
- HACS with following integrations:
- Button Card by RomRider
- Slider Card by Anton MS
- Layout Card by Thomas Lovén
- Card Mod by Thomas Lovén
- Click on the 'Code' button, then select 'Download ZIP'.
- Save the ZIP file to a location on your computer.
- Extract the contents of the ZIP file.
- Using your preferred method (Visual Studio Code, Samba, SSH, local access, etc.),
- Copy the four extracted folders (
/custom_templates
,/dashboards
,/entities
and/themes
) to your/config
directory.
frontend:
themes: !include_dir_merge_named themes/
lovelace:
mode: storage
dashboards: !include dashboards/dashboards.yaml
sensor: !include_dir_list entities/sensors/
sensor: alternative
You might need to modify these lines to match your current setup, particularly if you don't want to split your sensor configuration across multiple files. Here is the non-splitted alternative:
sensor:
- platform: template
sensors:
############################
#
# SECURITY MONITORING
#
############################
# ALARMS :
some_alarms_are_on:
friendly_name: "Some Alarms Are On"
value_template: >-
{% from 'quick_look_mobile_macros.jinja' import some_alarms_are_on %}
{{ some_alarms_are_on().split(',')[0] }}
alarms_count:
friendly_name: "Alarms Count"
value_template: >-
{% from 'quick_look_mobile_macros.jinja' import some_alarms_are_on %}
{{ some_alarms_are_on().split(',')[1] }}
# DOORS & WINDOWS :
some_contact_sensors_are_on:
friendly_name: "Some Contact Sensors Are On"
value_template: >-
{% from 'quick_look_mobile_macros.jinja' import some_contact_sensors_are_on %}
{{ some_contact_sensors_are_on().split(',')[0] }}
contact_sensors_count:
friendly_name: "Contact Sensors Count"
value_template: >-
{% from 'quick_look_mobile_macros.jinja' import some_contact_sensors_are_on %}
{{ some_contact_sensors_are_on().split(',')[1] }}
# PRESENCES :
some_occupancy_sensors_are_on:
friendly_name: "Some Occupancy Sensors Are On"
value_template: >-
{% from 'quick_look_mobile_macros.jinja' import some_occupancy_sensors_are_on %}
{{ some_occupancy_sensors_are_on().split(',')[0] }}
occupancy_sensors_count:
friendly_name: "Occupancy Sensors Count"
value_template: >-
{% from 'quick_look_mobile_macros.jinja' import some_occupancy_sensors_are_on %}
{{ some_occupancy_sensors_are_on().split(',')[1] }}
# LOCKS :
some_locks_are_on:
friendly_name: "Some Locks Are On"
value_template: >-
{% from 'quick_look_mobile_macros.jinja' import some_locks_are_on %}
{{ some_locks_are_on().split(',')[0] }}
locks_count:
friendly_name: "Locks Count"
value_template: >-
{% from 'quick_look_mobile_macros.jinja' import some_locks_are_on %}
{{ some_locks_are_on().split(',')[1] }}
############################
#
# AIR MONITORING
#
############################
# CLIMATES :
some_climates_are_on:
friendly_name: "Some Climates Are On"
value_template: >-
{% from 'quick_look_mobile_macros.jinja' import some_climates_are_on %}
{% set count = some_climates_are_on().split(',')[1]|int %}
{{ 'on' if count > 0 else 'off' }}
climates_dominance:
friendly_name: "Climates Dominance"
value_template: >-
{% from 'quick_look_mobile_macros.jinja' import some_climates_are_on %}
{{ some_climates_are_on().split(',')[0] }}
climates_count:
friendly_name: "Climates Count"
value_template: >-
{% from 'quick_look_mobile_macros.jinja' import some_climates_are_on %}
{{ some_climates_are_on().split(',')[1] }}
# FANS :
some_fans_are_on:
friendly_name: "Some Fans Are On"
value_template: >-
{% from 'quick_look_mobile_macros.jinja' import some_fans_are_on %}
{{ some_fans_are_on().split(',')[0] }}
fans_count:
friendly_name: "Fans Count"
value_template: >-
{% from 'quick_look_mobile_macros.jinja' import some_fans_are_on %}
{{ some_fans_are_on().split(',')[1] }}
############################
#
# LIGHT
#
############################
# LIGHTBULBS :
some_lights_are_on:
friendly_name: "Some Lights Are On"
value_template: >-
{% from 'quick_look_mobile_macros.jinja' import some_lights_are_on %}
{{ some_lights_are_on().split(',')[0] }}
lights_count:
friendly_name: "Lights Count"
value_template: >-
{% from 'quick_look_mobile_macros.jinja' import some_lights_are_on %}
{{ some_lights_are_on().split(',')[1] }}
# COVERS :
some_covers_are_on:
friendly_name: "Some Covers Are On"
value_template: >-
{% from 'quick_look_mobile_macros.jinja' import some_covers_are_on %}
{{ some_covers_are_on().split(',')[0] }}
covers_count:
friendly_name: "Covers Count"
value_template: >-
{% from 'quick_look_mobile_macros.jinja' import some_covers_are_on %}
{{ some_covers_are_on().split(',')[1] }}
############################
#
# MEDIA PLAYERS MONITORING
#
############################
# AUDIO PLAYERS :
some_audio_players_are_on:
friendly_name: "Some Audio Players Are On"
value_template: >-
{% from 'quick_look_mobile_macros.jinja' import some_audio_players_are_on %}
{{ some_audio_players_are_on().split(',')[0] }}
audio_players_count:
friendly_name: "Audio Players Count"
value_template: >-
{% from 'quick_look_mobile_macros.jinja' import some_audio_players_are_on %}
{{ some_audio_players_are_on().split(',')[1] }}
# VIDEO PLAYERS :
some_video_players_are_on:
friendly_name: "Some Video Players Are On"
value_template: >-
{% from 'quick_look_mobile_macros.jinja' import some_video_players_are_on %}
{{ some_video_players_are_on().split(',')[0] }}
video_players_count:
friendly_name: "Video Players Count"
value_template: >-
{% from 'quick_look_mobile_macros.jinja' import some_video_players_are_on %}
{{ some_video_players_are_on().split(',')[1] }}
############################
#
# EQUIPMENT MONITORING
#
############################
# DEVICES (SWITCHES, VACUUMS, SENSORS, etc) :
some_devices_are_on:
friendly_name: "Some Devices Are On"
value_template: >-
{% from 'quick_look_mobile_macros.jinja' import some_devices_are_on %}
{{ some_devices_are_on().split(',')[0] }}
devices_count:
friendly_name: "Devices Count"
value_template: >-
{% from 'quick_look_mobile_macros.jinja' import some_devices_are_on %}
{{ some_devices_are_on().split(',')[1] }}
- Restart your Home Assistant for the changes to take effect.
- Once rebooted, apply the 'Quick Look Mobile' theme.
- On the left lateral menu, open the newly created dashboard.
- Since this dashboard is designed for mobile view, it might appear too large on a computer screen. To correct this, press F12 or open your browser's developer tools and select the 'mobile view' option.
- This dashboard is pre-configured with 14 distinct views, which are uniformly structured and can be accessed at
/config/dashboard/quick_look_mobile/views/
. 1.1_home.yaml
corresponds to your home view,2.1_security_sensors.yaml
corresponds to your security sensors view, and so forth.- Each view represents a unique mobile interface that can be navigated to, using the header and subheader sections.
- The remaining sections, from top to bottom, include main part, footer title and footer spaces.
- The header is designed for two main purposes:
- allow for rapid navigation through five main categories, each leading to different views:
Security
,Air
,Light
,Media
, andEquipment
. Additionally, there is a specialFamily
category which can be accessed through the upper left person icon. If none of those categories is selected,Home
view will be displayed. You can also navigate back toHome
by clicking again on the active category. - provide useful status information by changing its color and icon based on 'template sensors' (see Customize Header Monitoring) e.g. if a lightbulb is turned on, the light category will turn yellow. If no entities are active, it will revert to its default grey color. This feature provides a quick and easy way to identify the status of your various devices and systems.
- allow for rapid navigation through five main categories, each leading to different views:
- Sometimes, icons and colors can change with a predefined priority order. For example, in the Security header, the priority is given to the triggered alarm, followed by open doors, detected motion and unlocked locks.
- Each of the Header categories further has two subcategories :
Home
includesFavorites
andEnergy
(this last one is no functional yet),Security
includesSensors
andCameras
,Air
includesClimates
andFans
,Light
includesBulbs
andCovers
,Media
includesAudio
andVideo
,Equipment
includesFavorites
andAll
,Family
includesMembers
andMap
.
- This section is designed with a two-column layout that can display eight cards at once.
- However, it does not limit the total number of cards as it allows for vertical scrolling to view and interact with an unlimited number of cards.
- Each card is structured with an icon on the left, usually acting as a switch, and a name&label container on the right, providing the more-info dialog when clicked for full control.
- To configure those cards with your entities, refer to Add your Entities.
- This section is primarily designed for scene management, offering group controls or shortcuts for quick actions. However, when scenes are not relevant, it can be used to display specialized cards such as the alarm or weather cards.
- Open the file corresponding to the view you want add entities to. eg open the
3.1_air_climates.yaml
file to add your climate and temperature sensors. - I recommend starting by customizing views 2.1 to 7.2 to familiarize yourself with the process of templates and variables, then proceed to view 1.1, which provides a wider range of customization options.
-
- Navigate to the Main section in the view file. By default, you'll find 16 empty entities but you can also add or delete some, depending on your needs.
- To avoid disrupting the setup, only modify the lines where it is explicitly mentioned
#can be changed, #required or #optional
at the end. These lines have been marked for easy and safe modification. - Each entity block requires certain parameters to be defined :
Each entity is associated with a predefined template card. The available cards include :
climate
,climate_expandable
,cover
,cover_expandable
,device
,device_expandable
,fan
,fan_expandable
,light
,light_expandable
,media
,media_expandable
,media_expanded
,person
,person_expandable
,security
,security_expandable
.- You will notice that each template has an 'expandable' version, which allows expanding the entity to a subview that includes other entities, thanks to the
expand_to
variable. This feature is particularly useful for managing groups. - Expanded views can be customized or created in the same way as existing views in
/dashboards/quick_look_mobile/views/expanded/
. - Expandable cards can also include other 'expandable' cards without nesting limit.
-
Variables provide you with the flexibility to personalize the cards according to your devices and personal information.
-
Some are optional and clearly indicated in the view file that you'll be modifying.
-
For a
climate
template card , you'll have to defineentity
,name
,temperature
,temperature_unit
,battery
,expand_to
.Entity
is the entity_id of your device (e.g.,climate.kitchen
), others are optional. When no name is given, the friendly name of the entity will be used. -
Refresh your dashboard to see the changes by clicking the three dots in the upper-right corner of the Home Assistant interface.
-
Repeat the above steps to all your views.
- The Header is designed to change color and display badge counts based on active devices.
- It is, however, not directly linked to the configured cards in each view.
- To monitor specific entities, an intermediate step of entities listing is required.
- Lists can be modified at
/config/custom_templates/quick_look_mobile_macros.jinja/
whereyour_entity
have to be replaced by your entity_ids. - It is logical, but not mandatory, to list the same entities as those configured in each view.
- Call
service: homeassistant.reload_custom_templates
or restart Home Assistant for the changes to take effect.
If you don't like or don't want to use badge counts, you can disable this feature by changing show_badge: true
to show_badge: false
in /dashboards/quick_look_mobile/templates/layout/header_category.yaml
(line 5)
- The Titles for Subheader, Main, and Footer sections can be easily modified or translated in their corresponding view YAML files, located in
/config/dashboards/quick_look_mobile/views/
where#can be changed
is mentioned. - If you need to translate Header titles or any content within a card (such as the weather card) that can't be modified directly via its view file, you will need to adjust the corresponding template YAML file, located in
/config/dashboards/quick_look_mobile/templates/
.
Enjoy your new, customized mobile dashboard for Home Assistant!