HA Clima total

Control total del clima en Home Assistant

Con estas dos sencillas tarjetas vamos a tener el control total del clima en Home Assistant, tanto dentro como fuera de casa.

Clima total

Requisitos previos

Para poder tener control total del clima en Home Assistant con estas tarjetas necesitas lo siguiente:

  • Disponer de alguna integración en Home Assistant que te proporcione información meteorológica. En el código y los ejemplos voy a utilizar los sensores de OpenWeather. No obstante, te aconsejo que utilices aquella integración que te proporcione información más precisa para tu zona (por ejemplo, AEMET). Eso sí, en ese caso aseguráte de adaptar los sensores correspondientes en el código.
  • Disponer, al menos, de un sensor de temperatura y/o humedad. En mi caso utilizo estos sensores de Tuya integrados a través de zigbee2mqtt, además del que me proporciona el termostato Tadoº.
-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 inteligente de temperatura y humedad, dispositivo de seguridad para el hogar, funciona con batería, Tuya, WIFI, Alexa y Google Home
Aliexpress
5,35€
ZigBee-Sensor inteligente de temperatura y humedad, dispositivo de seguridad para el hogar, funciona con batería, Tuya, WIFI, Alexa y Google Home
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%
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
*Algún precio puede haber cambiado desde la última revisión

Ten en cuenta que el objetivo no es reemplazar tus integraciones, si no unificar la información en dos pequeñas tarjetas, para hacerla accesible de un simple vistazo. Por tanto, tendrás que modificar el código para incluir tus entidades y tus preferencias.

Ya sabes que si tienes dudas en nuestra comunidad de Telegram de ayudamos encantados!

Tarjeta de tiempo meteorológico

Para tener el control total del clima en Home Assistant primero necesitamos la información de nuestro entorno. Esta tarjeta tiene como objetivo condensar la información más útil en un sencillo ‘widget’, para acceder a ella de un rápido vistazo.

Tarjeta weather

Tiene las siguientes características:

  • El título, icono y color de fondo muestran el tiempo meteorológico actual.
  • El icono grande que se encuentra en la esquina superior izquierda, indica si es de día o de noche.
  • Los iconos que se encuentran a la derecha del icono principal, muestran la evolución meteorológica.
  • Los iconos de la parte inferior muestran la temperatura y la probabilidad de lluvia.
  • Al pulsar sobre la tarjeta me lleva a información ampliada sobre la previsión meteorológica en Google.

Además con esta información puedes crear un montón de automatizaciones, en función de tus gustos y tus dispositivos. Te sugiero que agrupes en una sola todas las automatizaciones relacionadas con el clima, y les asignes distintos ‘trigger IDs’. Aquí tienes algunas ideas:

  • Pogramar acciones cuando la probabilidad de lluvia supere un porcentaje (por ejemplo, una notificación recordando coger el paraguas antes de salir de casa).
  • Programar acciones cuando empiece a llover (por ejemplo, recibir notificaciones, bajar las persianas, recoger el toldo…)
  • Programar acciones en función de la temperatura (por ejemplo, encender la calefacción, el aire acondicionado, etc).
  • Programar acciones en función de la luz (por ejemplo, encender las luces cuando se hace de noche, o subir las persianas y estores cuando se hace de día).

Para añadirla a tu panel, crea una nueva tarjeta y pega el siguiente código:

type: custom:stack-in-card
card_mod:
  style: |
    ha-card {
      --primary-text-color: #ffffff;
      --secondary-text-color: #ffffff;
    {% if states('sun.sun') == "below_horizon" %}
      background: linear-gradient( rgba(13, 55, 113, 1), rgba(15, 33, 70, 1) );
    {% else %}
      {% set condition = states('sensor.openweathermap_condition') %}
      {% if condition =="clear-night"%} background: #0b3d4e!important;
      {% elif condition =="exceptional" or condition =="sunny" or condition =="windy"
      or condition =="partlycloudy" %} background: #1d9cc7!important;
      {% elif condition =="hail" or condition =="snowy" or condition =="snowy-rainy"
      %} background: #ffffff!important;
      {% elif condition =="lightning" or condition =="lightning-rainy" or condition =="pouring" or condition
      =="rainy" %} background: #586f77!important;
      {% else %} background: #79929b!important;
      {% endif %}
    {% endif %} }
cards:
  - type: custom:mushroom-template-card
    primary: |
      {{ states('sensor.openweathermap_weather') | capitalize}} 
    layout: vertical
    icon: >-
      {% set condition = states('sensor.openweathermap_condition') %} {% if
      condition =="clear-night" %} mdi:weather-night {% elif condition
      =="exceptional" %} mdi:weather-sunny {% elif condition =="partlycloudy" %}
      mdi:weather-partly-cloudy {% else %} mdi:weather-{{ condition }} {% endif
      %}
    tap_action:
      action: url
      url_path: >-
        https://www.google.es/search?q=prevision+tiempo&sca_esv=580414175&sxsrf=AM9HkKkJYmeDd5NTU6ux_SxL1iEGV3AUuQ%3A1699433288101&ei=SEtLZZTRBa-rkdUP-4CU8AY&ved=0ahUKEwiUldOrgrSCAxWvVaQEHXsABW4Q4dUDCBA&uact=5&oq=prevision+tiempo&gs_lp=Egxnd3Mtd2l6LXNlcnAiEHByZXZpc2lvbiB0aWVtcG8yChAjGIoFGCcYnQIyEBAAGIAEGBQYhwIYsQMYyQMyCBAAGIoFGJIDMgsQABiKBRixAxiDATILEAAYigUYsQMYgwEyCxAAGIoFGLEDGIMBMgsQABiKBRixAxiDATILEAAYigUYsQMYgwEyBRAAGIAEMgUQABiABEjdB1CkBViKBnACeAGQAQCYAUmgAUmqAQExuAEDyAEA-AEBwgIKEAAYRxjWBBiwA8ICDRAAGEcY1gQYyQMYsAPCAgsQABiKBRiSAxiwA-IDBBgAIEGIBgGQBgo&sclient=gws-wiz-serp
    icon_color: |-
      {% if states('sun.sun') == "below_horizon" %} #ffffff {% else %}

        {% set condition = states('sensor.openweathermap_condition') %} {% if
        condition =="clear-night" or condition =="lightning" or condition
        =="lightning-rainy" %} #ebe584 {% elif condition =="exceptional" or
        condition =="sunny" or condition =="partlycloudy" %} #e4ff00 {% elif
        condition =="windy" %} #ffffff {% elif condition =="hail" or condition
        =="snowy" or condition =="snowy-rainy" %} #2b2b2b {% elif condition
        =="lightning" or condition =="snowy" or condition =="snowy-rainy" %}
        #2b2b2b {% elif condition =="pouring" or condition =="rainy" %}
        #84e7eb {% else %} #e5e5e5 {% endif %} 

      {% endif %}
    card_mod:
      style: |
        ha-card {
          border: 0px;
        }
  - type: custom:mushroom-chips-card
    alignment: center
    card_mod:
      style: |
        ha-card {
          margin-top: -15px;
          margin-bottom: -20px;
          --chip-spacing: 0px !important;
          --chip-padding: 5px !important;
        }
    chips:
      - type: template
        tap_action:
          action: none
        icon: mdi:thermometer
        content: '{{ states(''sensor.openweathermap_temperature'') |int}}ºC'
        card_mod:
          style: |
            ha-card {
              border: 0px;
              background: transparent!important;
              box-shadow: none!important;
              height: 33px!important;
            }
      - type: template
        tap_action:
          action: none
        icon: mdi:umbrella
        content: >-
          {{ states('sensor.openweathermap_forecast_precipitation_probability')
          }}%
        card_mod:
          style: |
            ha-card {
              border: 0px;
              background: transparent!important;
              box-shadow: none!important;
              height: 33px!important;
            }
  - type: custom:mushroom-template-card
    primary: ''
    secondary: ''
    icon: |
      {% if states('sun.sun') == "below_horizon" %}
      mdi:circle
      {% elif states('sun.sun') == "above_horizon" %}
      mdi:white-balance-sunny
      {% endif %}    
    tap_action:
      action: url
      url_path: >-
        https://www.google.es/search?q=prevision+tiempo&sca_esv=580414175&sxsrf=AM9HkKkJYmeDd5NTU6ux_SxL1iEGV3AUuQ%3A1699433288101&ei=SEtLZZTRBa-rkdUP-4CU8AY&ved=0ahUKEwiUldOrgrSCAxWvVaQEHXsABW4Q4dUDCBA&uact=5&oq=prevision+tiempo&gs_lp=Egxnd3Mtd2l6LXNlcnAiEHByZXZpc2lvbiB0aWVtcG8yChAjGIoFGCcYnQIyEBAAGIAEGBQYhwIYsQMYyQMyCBAAGIoFGJIDMgsQABiKBRixAxiDATILEAAYigUYsQMYgwEyCxAAGIoFGLEDGIMBMgsQABiKBRixAxiDATILEAAYigUYsQMYgwEyBRAAGIAEMgUQABiABEjdB1CkBViKBnACeAGQAQCYAUmgAUmqAQExuAEDyAEA-AEBwgIKEAAYRxjWBBiwA8ICDRAAGEcY1gQYyQMYsAPCAgsQABiKBRiSAxiwA-IDBBgAIEGIBgGQBgo&sclient=gws-wiz-serp
    icon_color: |
      {% if states('sun.sun') == "below_horizon" %}
      white
      {% elif states('sun.sun') == "above_horizon" %}
      yellow
      {% endif %}    
    card_mod:
      style: |
        ha-card {
          border: 0px;
          margin-top: -220px;
          margin-bottom: -20px;
          margin-left: -100px;
          --icon-size: 200px;
          opacity: 0.5;
        }
        {% if states('sun.sun') == "below_horizon" %}
        ha-state-icon {
          animation: beat 3.3s ease-out infinite both;
          transform-origin: 50% 60%;
        }
        @keyframes beat {
          0% { transform: scale(1); }
          10% { transform: scale(1.05); }
          17% { transform: scale(1); }
          33% { transform: scale(1.05); }
          60% { transform: scale(1); }
        }
        {% elif states('sun.sun') == "above_horizon" %}
        ha-state-icon {
          animation: spin 20s linear infinite;
        }
        {% endif %}    
        mushroom-shape-icon {
          --shape-color: none !important;
        }
  - type: custom:mushroom-chips-card
    alignment: center
    card_mod:
      style: |
        ha-card {
          margin-top: -105px;
          margin-left: 90px;
          --chip-spacing: 0px !important;
          --chip-padding: 0px !important;
          opacity: 0.5;
        }
    chips:
      - type: template
        tap_action:
          action: none
        icon: >-
          {% set condition =
          states.weather.openweathermap.attributes.forecast[0].condition %} {%
          if condition =="clear-night" %} mdi:weather-night {% elif condition
          =="exceptional" %} mdi:weather-sunny {% elif condition
          =="partlycloudy" %} mdi:weather-partly-cloudy {% else %}
          mdi:weather-{{ condition }} {% endif %}
        card_mod:
          style: |
            ha-card {
              border: 0px;
              background: transparent!important;
              box-shadow: none!important;
            }            
  - type: custom:mushroom-chips-card
    alignment: center
    card_mod:
      style: |
        ha-card {
          margin-top: -113px;
          margin-left: 140px;
          --chip-spacing: 0px !important;
          --chip-padding: 0px !important;
          opacity: 0.2;
        }
    chips:
      - type: template
        tap_action:
          action: none
        icon: >-
          {% set condition =
          states.weather.openweathermap.attributes.forecast[1].condition %} {%
          if condition =="clear-night" %} mdi:weather-night {% elif condition
          =="exceptional" %} mdi:weather-sunny {% elif condition
          =="partlycloudy" %} mdi:weather-partly-cloudy {% else %}
          mdi:weather-{{ condition }} {% endif %}
        card_mod:
          style: |
            ha-card {
              border: 0px;
              background: transparent!important;
              box-shadow: none!important;
            }            

Tarjeta de clima interior

Esta tarjeta tiene como objetivo mostrar la información más relevante de los dispositivos relacionados (calefacción, aire acondicionado, etc.) en un sencillo ‘widget’, así como sugerirte acciones relacionadas con el control del clima en tu hogar.

Por tanto, el contenido de la tarjeta va a depender de los dispositivos que tengas integrados y tus preferencias. Para ello en primer lugar vamos a crear un sensor dinámico, variando su valor e icono en función de las circunstancias.

Dispositivos

En mi caso el sensor está configurado de la siguiente forma, pero puedes adaptarlo como quieras.

  • Si la calefacción está encendida, toma el valor «Calefacción» y el icono es una llama (mdi:fire). Además, en este caso el fondo de la tarjeta será de color rojo y el icono palpitará.
  • Si el aire acondicionado está encendido, toma el valor «Aire acondicionado» y el icono es un ventilador (mdi:fan). En este caso el fondo de la tarjeta será de color azul y el icono rotará.
  • Si todos los dispositivos están apagados:
    • Si la temperatura supera los 25ºC, toma el valor «Qué calor!» y el icono es una llama (mdi:fire). En este caso el fondo de la tarjeta será de color rojo.
    • Si la temperatura está por debajo de los 18ºC, toma el valor «Qué frío!» y el icono es un copo de nieve (mdi:snowflake). En este caso el fondo de la tarjeta será de color azul.
    • Si la temperatura está entre los 18 y los 25ºC, toma el valor «Clima ideal» y el icono es una casa con un corazón (mdi:home-heart). En este caso el fondo de la tarjeta será de color verde.

Para crear este sensor pega el siguiente código en tu fichero ‘sensors.yaml’. Esto creará la entidad ‘sensor.indoor_climate’. Ten en cuenta que tienes que modificar el código para adaptar tu temperatura ideal e incluir tus dispositivos.

- platform: template
  sensors:
    indoor_climate:
      friendly_name: "Indoor Climate"
      value_template: >
        {% if states('climate.salon') == "heat" %} Calefacción
        {% elif states('input_boolean.aire_acondicionado') == "on" %} Aire acondicionado
        {% else %}
          {% if (states('sensor.home_temperatura') |int) > 25 %}
            Qué calor!
          {% elif (states('sensor.home_temperatura') |int) < 18 %}
            Qué frío!
          {% else %}
            Clima ideal
          {% endif %}
        {% endif %}
      icon_template: >
        {% if states('climate.salon') == "heat" %} mdi:fire
        {% elif states('input_boolean.aire_acondicionado') == "on" %} mdi:fan
        {% else %}
          {% if (states('sensor.home_temperatura') |int) > 25 %}
            mdi:fire
          {% elif (states('sensor.home_temperatura') |int) < 18 %}
            mdi:snowflake
          {% else %}
            mdi:home-heart
          {% endif %}
        {% endif %}
Distintivo

Además, la tarjeta tiene las siguientes características:

  • Los iconos de la parte inferior muestran la temperatura y humedad en casa. En mi caso tengo varios sensores repartidos por casa, por lo que he creado unos sensores de tipo «grupo» para mostrar la temperatura media y la humedad máxima.
  • Al pulsa sobre ella, dirige al apartado del panel de control donde tengo toda la información detallada de temperatura y humedad, incluyendo gráficas de históricos, datos por habitación y las tarjetas de control de cada dispositivo. Si, como yo, quieres una solución más elegante, también puedes crear un pop-up con Bubble Card. Asegúrate de adaptar la ruta (o cambiar la acción al pulsar).
  • Si se dan ciertas circunstancias, aparece un distintivo sobre el icono principal:
    • Distintivos de aviso:
      • Si la humedad alcanza el 60% aparece una gota (mdi:water) con el fondo rojo.
    • Distintivos de ahorro de energía:
      • Si hace frío en casa (temperatura por debajo de 18ºC), pero la temperatura exterior es superior que la interior, aparece una hoja (mdi:leaf) con el fondo verde. Esto significa que podemos aumentar la temperatura interior de forma natural (por ejemplo, abriendo las ventanas).
      • Si hace calor en casa (temperatura por encima de 25ºC), pero la temperatura exterior es inferior que la interior, aparece una hoja (mdi:leaf) con el fondo verde. Esto significa que podemos disminuir la temperatura interior de forma natural (por ejemplo, abriendo las ventanas).
    • Añade otros distintivos en función de los dispositivos que tengas disponibles. Por ejemplo, un distintivo que te avise cuando tengas las ventanas abiertas mientras tengas la calefacción o el aire acondicionado encendido. De esta forma mejorarás la eficiencia y ahorrarás energía.

Con esta información también puedes añadir automatizaciones para tener el control total del clima en Home Assistant, por ejemplo:

  • Programar acciones cuando en alguno de los sensores la humedad máxima supere un valor determinado (por ejemplo, recibir una notificación aconsejándote ventilar para evitar humedades o encender un condensador de humedad).
  • Automatiza el apagado de dispositivos cuando sales de casa, o el encendido cuando llegas de vuelta, si la temperatura no es la adecuada.
  • Automatiza el encendido y apagado de ventiladores, en función de la habitación en la que te encuentres.
  • Automatiza el encendido y apagado de dispositivos cuando se alcanza una temperatura determinada.

Crea temporizadores para tus dispositivos

¿Cuántas veces te has dejado la calefacción o el aire acondicionado encendido durante horas? Cuando se trata de un descuido esto supone un derroche energético y económico. Pues resulta que con los ayudantes de tipo ‘timer’ podemos incorporar la función de temporizador a CUALQUIER dispositivo.

Para ello sólo tienes que seguir estos pasos:

  • Ve a Ajustes > Dispositivos y servicios > Ayudantes > Crear ayudante > Temporizador y llámalo «Calefacción» (o el nombre correspondiente a tu dispositivo). Esto creará la entidad ‘timer.calefacción’. Este ayudante servirá para programar el tiempo máximo de funcionamiento.
  • Ve a Ajustes > Dispositivos y servicios > Ayudantes > Crear ayudante > Número y llámalo «Calefacción timer» (o el nombre correspondiente a tu dispositivo). En este caso indica como valor mínimo y tamaño del paso 30 (máximo el que quieras, por ejemplo 300), y minutos como unidad de medida. Esto creará el ayudante ‘input_number.calefaccion_timer‘ que indicará al temporizador cuánto tiempo tiene que durar. Modifícalo siempre que quieras para cambiar el límite de tiempo de funcionamiento de tu dispositivo.
  • Ahora sólo tienes que incluir en la automatización que has creado las siguientes secuencias:
    • Añade un desencadenante cuando el «estado» del dispositivo (por ejemplo, termostato) pase a «encendido». Esto debe generar como acción «llamar al servicio» (‘timer.start’) que inicia el timer correspondiente (‘timer.calefaccion’) con la duración marcada por el ayudante de tipo número (‘input_number.calefaccion_timer’). Esto hará que siempre que se encienda el dispositivo se inicie el temporizador.
    • Añade un desencadenante cuando el «estado» del dispositivo (por ejemplo, termostato) pase a «apagado». Esto debe generar como acción «llamar al servicio» (‘timer.finish’) que detiene el timer correspondiente (‘timer.calefaccion’). Esto hará que cuando se apague manualmente el dispositivo, se detenga el temporizador.
    • Añade un desencadenante cuando finalice el timer (por ejemplo, ‘timer.calefacción’), es decir pase a estado ‘inactivo’. Esto debe generar como acción «llamar al servicio» para apagar el dispositivo (por ejemplo, el termostato). Esto hará que cuando acabe el temporizador se detenga el dispositivo.
    • Añade un desencadenante cuando cambie el tiempo máximo de funcionamiento (‘input_number.calefaccion_timer’) mientras se de la condición de que el dispositivo (por ejemplo, el termostato) esté encendido. Esto debe generar como acción «llamar al servicio» (‘timer.start’) que inicia el timer correspondiente (‘timer.calefaccion’) con la nueva duración indicada. Esto hará que siempre que podamos modificar el tiempo de funcionamiento mientras el aparato esté encendido.

A continuación te adjunto el código de la automatización que incluye las secuencias que acabamos de comentar. Recuerda que es válido para cualquier dispositivo mientras reemplaces las entidades correspondientes.

alias: Temporizador para la calefacción
description: ""
trigger:
  - platform: state
    entity_id:
      - climate.salon
    to: heat
    id: Calefaccion encendida
    alias: Calefacción encendida
  - platform: state
    entity_id:
      - climate.salon
    to: "off"
    alias: Calefacción apagada
    id: Calefaccion apagada
  - platform: state
    entity_id:
      - timer.calefaccion
    to: idle
    id: Fin timer calefaccion
    alias: Fin timer calefaccion
  - platform: state
    entity_id:
      - input_number.calefaccion_timer
    id: Cambio timer calefaccion
    alias: Cambio timer calefacción
condition: []
action:
  - choose:
      - conditions:
          - condition: trigger
            id:
              - Calefaccion encendida
        sequence:
          - service: timer.start
            data:
              duration: "{{states('input_number.calefaccion_timer') | int *60}}"
            target:
              entity_id: timer.calefaccion
      - conditions:
          - condition: trigger
            id:
              - Calefaccion apagada
        sequence:
          - service: timer.finish
            data: {}
            target:
              entity_id: timer.calefaccion
      - conditions:
          - condition: trigger
            id:
              - Fin timer calefaccion
        sequence:
          - service: climate.turn_off
            data: {}
            target:
              entity_id: climate.salon
      - conditions:
          - condition: trigger
            id:
              - Cambio timer calefaccion
          - condition: state
            entity_id: climate.salon
            state: heat
        sequence:
          - service: timer.start
            data:
              duration: "{{states('input_number.calefaccion_timer') | int *60}}"
            target:
              entity_id: timer.calefaccion
mode: single

Tras realizar lo anterior, si hay algún dispositivo en funcionamiento (calefacción o aire acondicionado) el fondo de la tarjeta será una barra de progeso que indica el tiempo restante de funcionamiento.

Barra de progreso

Código de la Lovelace Card

Para crear la tarjeta con todas las características mencionadas, crea una nueva tarjeta y pega el siguiente código:

type: custom:stack-in-card
card_mod:
  style: |
    ha-card {
      --primary-text-color: #ffffff;
      --secondary-text-color: #ffffff;
    {% if states('climate.salon') == "heat" %}
      background: linear-gradient( rgba(238, 82, 79, 1), rgba(181, 42, 39, 1) );
    {% elif states('input_boolean.aire_acondicionado') == "on" %}
      background: linear-gradient( rgba(79, 171, 162, 1), rgba(38, 133, 124, 1) );
    {% else %}
      {% if (states('sensor.home_temperatura') |int) > 25 %}
        background: linear-gradient( rgba(238, 82, 79, 1), rgba(181, 42, 39, 1) );
      {% elif (states('sensor.home_temperatura') |int) < 18 %}
        background: linear-gradient( rgba(79, 171, 162, 1), rgba(38, 133, 124, 1) );
      {% else %}
        background: linear-gradient( rgba(143, 184, 84, 1), rgba(107, 139, 62, 1) );
      {% endif %}
    {% endif %}
    height: 128px;
    }
cards:
  - type: custom:mushroom-template-card
    entity: sensor.indoor_climate
    primary: |
      {{ states('sensor.indoor_climate') }}
    layout: vertical
    icon: |
      {{ state_attr('sensor.indoor_climate','icon') }}
    icon_color: white
    badge_icon: >
      {% if (states('sensor.home_humedad') | int) >= 60 %}

      mdi:water

      {% elif (states('sensor.home_temperatura') | int) < 18 and
      (states('sensor.openweathermap_temperature') |int) >
      (states('sensor.home_temperatura') | int) %}

      mdi:leaf

      {% endif %}
    badge_color: >
      {% if (states('sensor.home_humedad') | int) >= 60 %}

      red

      {% elif (states('sensor.home_temperatura') | int) < 18 and
      (states('sensor.openweathermap_temperature') |int) >
      (states('sensor.home_temperatura') | int) %}

      green

      {% endif %}
    tap_action:
      action: navigate
      navigation_path: /lovelace/clima
    card_mod:
      style: |
        {% if states('climate.salon') == "heat" %}
        ha-state-icon {
          animation: beat 1.3s ease-out infinite both;
          transform-origin: 50% 60%;
        }
        @keyframes beat {
          0% { transform: scale(1); }
          10% { transform: scale(1.1); }
          17% { transform: scale(1.05); }
          33% { transform: scale(1.25); }
          60% { transform: scale(1); }
        }
        ha-card {
          margin-bottom: -25px;         
          border: 0px;
        }
        {% elif states('input_boolean.aire_acondicionado') == "on" %}
        ha-state-icon {
          animation: spin 1.4s linear infinite;
        }
        ha-card {
          margin-bottom: -25px;
          border: 0px;
        }
        {% endif %}    
        ha-card {
          border: 0px;
        }
  - type: conditional
    conditions:
      - entity: timer.calefaccion
        state: active
    card:
      type: custom:timer-bar-card
      entity: timer.calefaccion
      layout: full_row
      bar_background: '#d24d4b'
      bar_foreground: '#df6865'
      bar_height: 200px
      text_width: 0px
      sync_issues: ignore
  - type: conditional
    conditions:
      - entity: timer.aire_acondicionado
        state: active
    card:
      type: custom:timer-bar-card
      entity: timer.aire_acondicionado
      layout: full_row
      bar_background: '#35938a'
      bar_foreground: '#6cb5ae'
      bar_height: 200px
      text_width: 0px
      sync_issues: ignore
  - type: custom:mushroom-chips-card
    alignment: center
    card_mod:
      style: |
        ha-card {
          {% if states('climate.salon') == "heat" or states('input_boolean.aire_acondicionado') == "on" %}
          margin-top: -39px;                    
          {% else %}
          margin-top: -15px;          
          {% endif %}
          --chip-spacing: 0px !important;
          --chip-padding: 5px !important;
        }
    chips:
      - type: template
        tap_action:
          action: none
        icon: mdi:thermometer
        content: '{{ states(''sensor.home_temperatura'') |int}}ºC'
        card_mod:
          style: |
            ha-card {
              border: 0px;
              background: transparent!important;
              box-shadow: none!important;
              height: 33px!important;
            }
      - type: template
        tap_action:
          action: none
        icon: mdi:water-percent
        content: '{{ states(''sensor.home_humedad'') |int }}%'
        card_mod:
          style: |
            ha-card {
              border: 0px;
              background: transparent!important;
              box-shadow: none!important;
              height: 33px!important;
            }

Y si quieres personalizar el fondo de las tarjetas con imágenes y degradados, visita esta entrada!

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