Tarjetas de habitación 2.0

In this post, we are going to create room cards in Home Assistant to easily control the status of the devices at a glance.

Previously, we have used specific examples like occupancy cards or the Smart TV card, but in this case, the goal is to concentrate all the information into a small card. For me, this is ideal for rooms like the bedroom or living room, where we spend a lot of time but have limited devices (so we don’t want to create a dedicated section on the lovelace panel).

In the end, you will have cards that look like this:

Requirements

If you want to build this card, consider this:

  • To create the card, you need to install the Mushroom Cards, Card-mod, Stack in card, and ApexCharts Card through HACS.
  • If you are going to control Zigbee bulbs that you frequently turn on and off with wall switches, I recommend checking out this trick to display the actual status of your Zigbee bulbs. This will prevent them from showing as «on» when they are turned off via the switch.
  • You can copy and paste the code at the end of the post, but you are also free to modify it however you like.

Building the Card

To create the room cards, we will consider their different parts.

Card Header

First, we can configure the background image. For this, you can use a real image of your rooms, or even generate them with artificial intelligence. Then, you just need to upload them to your Home Assistant instance and specify the path in the code.

💡 I recommend uploading the images from your file explorer using the Samba Share add-on to the path '/config/www/', which corresponds to '/local/' in the code. For example, you can use the image located at '/config/www/image.jpg' on your cards with the path '/local/image.jpg'.

In the header, we will display important information about the room. In my case, I want to show the room’s temperature and humidity percentage (but you can include whatever data you prefer). For this, you’ll obviously need a sensor that provides this information. In my case, I use these types of sensors integrated through Zigbee2MQTT.

-67%
Sensor inteligente de temperatura y humedad Tuya Zigbee, Monitor de termómetro interior para el trabajo en casa con asistente de Google Home Alexa
Aliexpress
6,43€ 19,66€
Sensor inteligente de temperatura y humedad Tuya Zigbee, Monitor de termómetro interior para el trabajo en casa con asistente de Google Home Alexa
-50%
MOES Tuya Smart ZigBee Sensor de temperatura y humedad, higrómetro interior con pantalla LCD
Aliexpress
13,58€ 27,16€
MOES Tuya Smart ZigBee Sensor de temperatura y humedad, higrómetro interior con pantalla LCD
Zigbee-Sensor de temperatura y humedad para el hogar, termómetro inteligente con Wifi, higrómetro, Detector con Alexa y Google Smart Life, 3,0, 1/10 unidades
Aliexpress
7,40€
Zigbee-Sensor de temperatura y humedad para el hogar, termómetro inteligente con Wifi, higrómetro, Detector con Alexa y Google Smart Life, 3,0, 1/10 unidades
-67%
Tuya Zigbee-Sensor de temperatura y humedad para Smart Home, pantalla LCD, funciona con Alexa, Google Home APP, Smart Life, Tuya Smart Yandex
Aliexpress
6,72€ 20,99€
Tuya Zigbee-Sensor de temperatura y humedad para Smart Home, pantalla LCD, funciona con Alexa, Google Home APP, Smart Life, Tuya Smart Yandex
*Some prices may have changed since the last review

You can modify the card header in the following part of the code:

## CARD HEADER
  - type: custom:stack-in-card
    card_mod:
      style: |
        ha-card {
          background: linear-gradient(rgba(0,0,0,0.7), rgba(0,0,0,0.7)), url('/local/habitaciones/dormitorio.jpg'); ## IMAGEN DE FONDO
          background-position: center;
          background-size: cover;
          --primary-text-color: #ffffff;
          min-height: 133px;
        }
    cards:
      - type: custom:mushroom-template-card
        primary: Dormitorio ## ROOM NAME
        secondary: >- ## ROOM SENSORS
          {{ states('sensor.sensor_temperatura_dormitorio_temperature') | int
          }}ºC | {{ states('sensor.sensor_temperatura_dormitorio_humidity') |
          int }}%
        icon: ''
        card_mod:
          style: |
            ha-card {
              border: 0px;
            }
        tap_action:
          action: none

Card Icon

Obviously, the icon represents the room the card is for, and you can customize the color as you prefer. You may have noticed that it has a ring around it of variable length to provide information at a glance. You can associate this with any entity you like (for example, the room’s temperature or the number of items on your shopping list) so the the ring will change based on its value.

Additionally, a badge appears on top when certain conditions are met (which you can customize as you wish).

  • If the humidity equals or exceeds 60%, a drop icon with a blue background appears.
  • If the temperature equals or exceeds 26ºC, a flame icon with a red background appears.
  • If the temperature equals or drops below 18ºC, a snowflake icon with a blue background appears.

You can modify the icon, the ring, and the badges on the card in the following part of the code:

## ICON RING
      - type: custom:apexcharts-card
        card_mod:
          style: |
            ha-card {
              margin-top: -26px;
              margin-bottom: -75px;
              margin-left: -110px;
              border: 0px;
            }
        header:
          show: false
        chart_type: radialBar
        apex_config:
          legend:
            show: false
          chart:
            height: 180px
          plotOptions:
            radialBar:
              hollow:
                size: 70%
              dataLabels:
                name:
                  show: false
                value:
                  show: false
              startAngle: -45
              endAngle: 125
        series:
          - entity: sensor.sensor_temperatura_dormitorio_temperature ## RING ENTITY
            color: aquamarine
            min: 10 ## MIN VALUE OF THE ENTITY
            max: 30 ## MAX VALUE OF THE ENTITY
      - type: custom:mushroom-template-card
        layout: horizontal
        primary: ''
        secondary: ''
        icon: mdi:bed ## ICON
        icon_color: teal ## ICON COLOR
        tap_action:
          action: none
        card_mod:
          style: |
            ha-card {
              border: 0px;
              --icon-size: 100px;
              margin-left: -25px;
              margin-bottom: -55px;
              margin-top: -32px;
            }
            mushroom-badge-icon {
              margin-right: 10px;
              margin-top: 10px;
              --badge-icon-size: 10px;
              --badge-size: 20px;
            }
## CHANGE HERE BADGE RULES
        badge_icon: >
          {% if (states('sensor.sensor_temperatura_dormitorio_humidity') | int)
          >= 60 %} mdi:water {% elif
          (states('sensor.sensor_temperatura_dormitorio_temperature') | int) >=
          26 %} mdi:fire {% elif
          (states('sensor.sensor_temperatura_dormitorio_temperature') | int) <=
          18 %} mdi:snowflake {% endif %}
        badge_color: >
          {% if (states('sensor.sensor_temperatura_dormitorio_humidity') | int)
          >= 60 %} blue

          {% elif (states('sensor.sensor_temperatura_dormitorio_temperature') |
          int)

          >= 26 %} red

          {% elif (states('sensor.sensor_temperatura_dormitorio_temperature') |
          int)

          <= 18 %} blue

          {% endif %}

Side Icons

Side icons will be used to show the status of the room’s devices and to control them (for example, the different bulbs and lamps in the room, or the television). However, you can use them for anything you can think of (such as controlling fans, checking security cameras, etc.).

The card is optimized for you to include between 1 and 6 icons, arranged in 1 or 2 columns. As long as you stay within this range, the card will adapt perfectly to the design. Additionally, you can use conditional styles to change the color of the icons based on the entity’s state, or even animate them.

You can configure the icons in this part of the code:

      - type: custom:stack-in-card
        card_mod:
          style: |
            ha-card {
              background: transparent!important;
              margin-top: -110px;
              margin-left: auto;
              margin-right: 5px;
              width: 44%;
              border: 0px;
            }
        cards:
          - type: grid
            square: false
            columns: 1 ## NUMBER OF COLUMNS (1 OR 2)
            cards:
              - type: custom:mushroom-template-card
                primary: ''
                secondary: ''
                layout: vertical
                icon: mdi:ceiling-light ## ICON DEVICE
                entity: light.bombilla_dormitorio
                icon_color: > ## CONDITIONAL COLOR
                  {% if (states('light.bombilla_dormitorio')) == 'on' %} teal {%
                  endif %}
                card_mod:
                  style: |
                    ha-card {
                      border: 0px;
                      --icon-size: 35px;
                      margin: -10px!important;
                    }

Card Code

The quickest way to create your own room cards is to copy the code I’m going to provide you, create a new manual card in your dashboard, and paste it using the code editor. Keep in mind that you will need to modify the names of your rooms, sensors, and entities, as well as customize the colors as I explained in the previous sections.

Below you can copy the complete code for the cards shown in the example image:

square: false
type: grid
columns: 2
cards:
  - type: custom:stack-in-card
    card_mod:
      style: |
        ha-card {
          background: linear-gradient(rgba(0,0,0,0.7), rgba(0,0,0,0.7)), url('/local/habitaciones/dormitorio.jpg');
          background-position: center;
          background-size: cover;
          --primary-text-color: #ffffff;
          min-height: 133px;
        }
    cards:
      - type: custom:mushroom-template-card
        primary: Dormitorio
        secondary: >-
          {{ states('sensor.sensor_temperatura_dormitorio_temperature') | int
          }}ºC | {{ states('sensor.sensor_temperatura_dormitorio_humidity') |
          int }}%
        icon: ''
        card_mod:
          style: |
            ha-card {
              border: 0px;
            }
        tap_action:
          action: none
      - type: custom:apexcharts-card
        card_mod:
          style: |
            ha-card {
              margin-top: -26px;
              margin-bottom: -75px;
              margin-left: -110px;
              border: 0px;
            }
        header:
          show: false
        chart_type: radialBar
        apex_config:
          legend:
            show: false
          chart:
            height: 180px
          plotOptions:
            radialBar:
              hollow:
                size: 70%
              dataLabels:
                name:
                  show: false
                value:
                  show: false
              startAngle: -45
              endAngle: 125
        series:
          - entity: sensor.sensor_temperatura_dormitorio_temperature
            color: aquamarine
            min: 10
            max: 30
      - type: custom:mushroom-template-card
        layout: horizontal
        primary: ''
        secondary: ''
        icon: mdi:bed
        icon_color: teal
        tap_action:
          action: none
        card_mod:
          style: |
            ha-card {
              border: 0px;
              --icon-size: 100px;
              margin-left: -25px;
              margin-bottom: -55px;
              margin-top: -32px;
            }
            mushroom-badge-icon {
              margin-right: 10px;
              margin-top: 10px;
              --badge-icon-size: 10px;
              --badge-size: 20px;
            }
        badge_icon: >
          {% if (states('sensor.sensor_temperatura_dormitorio_humidity') | int)
          >= 60 %} mdi:water {% elif
          (states('sensor.sensor_temperatura_dormitorio_temperature') | int) >=
          26 %} mdi:fire {% elif
          (states('sensor.sensor_temperatura_dormitorio_temperature') | int) <=
          18 %} mdi:snowflake {% endif %}
        badge_color: >
          {% if (states('sensor.sensor_temperatura_dormitorio_humidity') | int)
          >= 60 %} blue

          {% elif (states('sensor.sensor_temperatura_dormitorio_temperature') |
          int)

          >= 26 %} red

          {% elif (states('sensor.sensor_temperatura_dormitorio_temperature') |
          int)

          <= 18 %} blue

          {% endif %}
      - type: custom:stack-in-card
        card_mod:
          style: |
            ha-card {
              background: transparent!important;
              margin-top: -110px;
              margin-left: auto;
              margin-right: 5px;
              width: 44%;
              border: 0px;
            }
        cards:
          - type: grid
            square: false
            columns: 1
            cards:
              - type: custom:mushroom-template-card
                primary: ''
                secondary: ''
                layout: vertical
                icon: mdi:ceiling-light
                entity: light.bombilla_dormitorio
                icon_color: >
                  {% if (states('light.bombilla_dormitorio')) == 'on' %} teal {%
                  endif %}
                card_mod:
                  style: |
                    ha-card {
                      border: 0px;
                      --icon-size: 35px;
                      margin: -10px!important;
                    }
              - type: custom:mushroom-template-card
                primary: ''
                secondary: ''
                layout: vertical
                icon: mdi:lightbulb-variant-outline
                entity: light.bombilla_dormitorio_filamento
                icon_color: >
                  {% if (states('light.bombilla_dormitorio_filamento')) == 'on'
                  %} teal {% endif %}
                card_mod:
                  style: |
                    ha-card {
                      border: 0px;
                      --icon-size: 35px;
                      margin: -10px!important;
                    }
              - type: custom:mushroom-template-card
                primary: ''
                secondary: ''
                layout: vertical
                icon: mdi:television
                entity: media_player.tv_dormitorio
                tap_action:
                  action: more-info
                icon_color: >
                  {% if (states('media_player.tv_dormitorio')) == 'off' %} {%
                  else %} teal {% endif %}
                card_mod:
                  style: |
                    ha-card {
                      border: 0px;
                      --icon-size: 35px;
                      margin: -10px!important;
                    }
  - type: custom:stack-in-card
    card_mod:
      style: |
        ha-card {
          background: linear-gradient(rgba(0,0,0,0.7), rgba(0,0,0,0.7)), url('/local/habitaciones/salon.jpg');
          background-position: center;
          background-size: cover;
          --primary-text-color: #ffffff;
          min-height: 133px;
        }
    cards:
      - type: custom:mushroom-template-card
        primary: Salón
        secondary: >-
          {{ states('sensor.salon_temperatura') | int }}ºC | {{
          states('sensor.salon_humedad') | int }}%
        icon: ''
        card_mod:
          style: |
            ha-card {
              border: 0px;
            }
        tap_action:
          action: none
      - type: custom:apexcharts-card
        card_mod:
          style: |
            ha-card {
              margin-top: -26px;
              margin-bottom: -75px;
              margin-left: -110px;
            }
        header:
          show: false
        chart_type: radialBar
        apex_config:
          legend:
            show: false
          chart:
            height: 180px
          plotOptions:
            radialBar:
              hollow:
                size: 70%
              dataLabels:
                name:
                  show: false
                value:
                  show: false
              startAngle: -45
              endAngle: 125
        series:
          - entity: sensor.salon_temperatura
            color: lightgreen
            min: 10
            max: 30
      - type: custom:mushroom-template-card
        layout: horizontal
        primary: ''
        secondary: ''
        icon: mdi:sofa
        icon_color: lime
        tap_action:
          action: none
        card_mod:
          style: |
            ha-card {
              border: 0px;
              --icon-size: 100px;
              margin-left: -25px;
              margin-bottom: -55px;
              margin-top: -32px;
            }
            mushroom-badge-icon {
              margin-right: 10px;
              margin-top: 10px;
              --badge-icon-size: 10px;
              --badge-size: 20px;
            }
        badge_icon: >
          {% if (states('sensor.sensor_temperatura_dormitorio_humidity') | int)
          >= 60 %} mdi:water {% elif
          (states('sensor.sensor_temperatura_dormitorio_temperature') | int) >=
          26 %} mdi:fire {% elif
          (states('sensor.sensor_temperatura_dormitorio_temperature') | int) <=
          18 %} mdi:snowflake {% endif %}
        badge_color: >
          {% if (states('sensor.sensor_temperatura_dormitorio_humidity') | int)
          >= 60 %} blue

          {% elif (states('sensor.sensor_temperatura_dormitorio_temperature') |
          int)

          >= 26 %} red

          {% elif (states('sensor.sensor_temperatura_dormitorio_temperature') |
          int)

          <= 18 %} blue

          {% endif %}
      - type: custom:stack-in-card
        card_mod:
          style: |
            ha-card {
              background: transparent!important;
              margin-top: -110px;
              margin-left: auto;
              margin-right: 5px;
              width: 44%;
            }
        cards:
          - type: grid
            square: false
            columns: 2
            cards:
              - type: custom:mushroom-template-card
                primary: ''
                secondary: ''
                layout: vertical
                icon: mdi:floor-lamp
                entity: light.bombilla_salon
                icon_color: >
                  {% if (states('light.bombilla_salon')) == 'on' %} lime {%
                  endif %}
                card_mod:
                  style: |
                    ha-card {
                      border: 0px;
                      --icon-size: 35px;
                      margin: -10px!important;
                    }
              - type: custom:mushroom-template-card
                primary: ''
                secondary: ''
                layout: vertical
                icon: mdi:television
                entity: media_player.tv_salon
                tap_action:
                  action: more-info
                icon_color: >
                  {% if (states('media_player.tv_salon')) == 'off' %} {% else %}
                  lime {% endif %}
                card_mod:
                  style: |
                    ha-card {
                      border: 0px;
                      --icon-size: 35px;
                      margin: -10px!important;
                    }
              - type: custom:mushroom-template-card
                primary: ''
                secondary: ''
                layout: vertical
                icon: mdi:sprout
                tap_action:
                  action: navigate
                  navigation_path: '#plantas'
                card_mod:
                  style: |
                    ha-card {
                      border: 0px;
                      --icon-size: 35px;
                      margin: -10px!important;
                    }
              - type: custom:mushroom-template-card
                primary: ''
                secondary: ''
                layout: vertical
                icon: mdi:led-strip-variant
                entity: light.bombilla_salon
                icon_color: >
                  {% if (states('light.bombilla_salon')) == 'on' %} lime {%
                  endif %}
                card_mod:
                  style: |
                    ha-card {
                      border: 0px;
                      --icon-size: 35px;
                      margin: -10px!important;
                    }
              - type: custom:mushroom-template-card
                primary: ''
                secondary: ''
                layout: vertical
                icon: mdi:fan
                entity: media_player.tv_salon
                tap_action:
                  action: more-info
                icon_color: >
                  {% if (states('media_player.tv_salon')) == 'off' %} {% else %}
                  lime {% endif %}
                card_mod:
                  style: |
                    ha-card {
                      border: 0px;
                      --icon-size: 35px;
                      margin: -10px!important;
                    }
              - type: custom:mushroom-template-card
                primary: ''
                secondary: ''
                layout: vertical
                icon: mdi:lamp
                tap_action:
                  action: navigate
                  navigation_path: '#plantas'
                card_mod:
                  style: |
                    ha-card {
                      border: 0px;
                      --icon-size: 35px;
                      margin: -10px!important;
                    }

Bonus! Room Cards in HACS!

I can’t miss the chance to share with you this version created by our friend Muyayo, inspired by our room cards and available in HACS. If you’re someone who dislikes YAML, you’re going to love it. It’s easy to install and highly customizable! 😊

In his GitHub repository, you can find the different installation methods, as well as the configuration options.

🛟 ¿Dudas? Si necesitas ayuda entra aquí 👈 🎁 Y si te ha gustado y quieres más... 🥑
Contenido exclusivo de Aguacatec