🔹 Card-mod - Add css styles to any lovelace card

Bingo!!

that was the syntax I overlooked… I’ve gotten rather used to splitting the $: and the .: | in the main path, but didnt see this yet under the $: itself

getting this now

Scherm­afbeelding 2024-11-25 om 16.54.41

with the yaml only, so no longer using the Inspector for it.
Finally I can remove that ha-card border, and make those borders much nicer and having consistent badge sizes with and without the border.

thank you very much Arganto, made my day!

for reference, this is what works as I have it now, and the commented mods also work, but I chose not to use

card_mod:
  style:
    hui-entity-badge:
      $:
        ha-badge:
          $: |
            .badge {
              border: 2px solid {{'var(--success-color)' if
                             is_state('binary_sensor.werkdag','off') else
                             'var(--warning-color)'}} !important;
            }
        .: |
          ha-state-icon {
            --mdc-icon-size: 24px;
            /*color: {{'var(--warning-color)'
              if is_state('binary_sensor.werkdag','on')}};*/
          }
          /*state-display {
            font-size: 14px;
            color: {{'var(--success-color)' if
                      is_state('binary_sensor.werkdag','off') else
                      'var(--warning-color)'}};
          }*/

    .: |
       /*hui-entity-badge {
        --ha-card-background: {{'var(--success-color)'
          if is_state('binary_sensor.werkdag','off') else 'var(--card-background-color)'}};
       }*/

       ha-card {
         /*border: 2px solid {{'var(--success-color)' if
                             is_state('binary_sensor.werkdag','off') else
                             'var(--warning-color)'}};*/
         border-radius: 24px;
         /*--ha-card-background: gray;*/
         /*--primary-text-color: white;*/
         --card-mod-icon-color: {{'var(--success-color)' if
                             is_state('binary_sensor.werkdag','off') else
                             'var(--warning-color)'}}; /*--icon-primary-color:*/
       }

as you can see the border nicely fits ‘inside’ the badge space and align correctly with unbordered badges
Scherm­afbeelding 2024-11-25 om 17.02.08

🔹 Card-mod - Add css styles to any lovelace card - #103 by thomasloven
What’s wrong?
It’s always written in black

type: picture-elements
image: local/jbb/plan-32-lafontaine-rdc-1er.png
style: |
  ha-card { 
    --color-state-climate: cyan;
  }
elements:

  - type: state-label
    attribute: current_temperature
    style:
      left: 75%
      top: 10%
      font-size: 10px
      font-weight: bold
      color: var(--color-state-climate)
      # color: blue
    entity: climate.chambrecam


card_mod keyword is missing

already tried

Styling elements in Picture elements card: a small tutorial - #223 by ciscolyon69

Do you have card-mod installed?

Some more styles for mini-graph-card:

389731478-4c77806a-31d9-4da9-89f0-5dcf69522161

389731539-f6e051f9-c463-4036-af33-21165be77e19

image

shame on me.
I missed this essential step and we wasted our time
mea culpa

1 Like

Naamfsdfdsfdsloos

I have 4 buttons with this code

          - type: horizontal-stack 
            cards:
              - type: "custom:stack-in-card"
                cards:   
                  - type: custom:mushroom-template-card
                    primary: Energie
                    icon: mdi:alpha-e-circle-outline
                    tap_action:
                      action: call-service
                      service: input_select.select_option
                      service_data:
                        entity_id: input_select.dashboard_view  # Helper entiteit
                        option: energie
                    icon_color: white
                    fill_container: true
                    card_mod:
                      style: | 
                        ha-card {
                          box-shadow: 0px 2px 5px 0px rgba(0,0,0,0.3) !important;
                          background-color: rgba({{ states("input_text.kleur_iconen")}},0.2) !important;
                        }
                  - type: custom:mushroom-chips-card
                    chips:
                      - type: template
                        entity: climate.ruimte1
                        icon: mdi:fan
                        icon_color: white
                        tap_action:
                          action: toggle
                        card_mod:
                          style: |
                            ha-card {
                              border: none !important;
                              box-shadow: none !important;
                            }

and I have 2 questions :slight_smile:

  1. how do I get more space between the 4 buttons ?
  2. how do I achieve that the white space of the button acts like a button ? so it looks like green and white are like 1 button ?

Dear All,

Like many others I am a bit lost in trying to do what I thought was a simple operation with card-mod, but I think shadow-root has confused the socks off me!

I have installed card-mod and used it successfuly to modify icon and text colours, really cool! But now I just want to reduce the top and bottom padding on an entities card to save some vertical space.

Here is the card image:

2024-11-26_18-54-50 Entities card for wind

Here is the YAML:

type: entities
entities:
  - entity: sensor.wind
    name: " "
    icon: mdi:windsock
    card_mod:
      style: |
        :host {
          --paper-item-icon-color: 
            {% if states('sensor.wind_speed_source') == 'main' %}
              green;
            {% elif states('sensor.wind_speed_source') == 'backup' %}
              orange;
            {% else %}
              gray;
            {% endif %} !important;
        }
        .entities-row {
          display: flex;
          flex-direction: row; /* Layout items side by side */
          align-items: center; /* Align the icon and value properly */
        }
        .info {
          display: none !important; /* Hide the name completely */
        }
        .entity__name {
          display: none !important; /* Hide the name completely */
        }
        .value {
          color: 
            {% set beaufort = states('sensor.wind_scale_beaufort') | int %}
            {% if 1 <= beaufort <= 2 %}
              green;
            {% elif 3 <= beaufort <= 4 %}
              yellow;
            {% elif 5 <= beaufort <= 6 %}
              orange;
            {% elif 7 <= beaufort <= 8 %}
              red;
            {% else %}
              purple;
            {% endif %} !important;
          white-space: nowrap; /* Prevent wrapping */
          overflow: hidden; /* Prevent overflow */
          text-overflow: ellipsis; /* Handle overflow gracefully */
          flex-grow: 1; /* Ensure value takes all available space */
        }
show_header_toggle: false

I have tried various ways to reach the padding-top and padding-bottom values but to no avail.

I can change the padding value (all 4) in the Firefox developer mode and that removes the padding so I know these are the styles I want to change. I only want to change padding-top and padding-bottom, not the left and right ones.

Here is the HTML:

Any help gratefully recieved.

Many thanks, Colin

Padding is at the card level, so you need to put your card_mod styles there:

type: entities
card_mod:
  style: |
    div#states.card-content {
      padding-top: 8px;
      padding-right: 4px;
      padding-bottom: 8px;
      padding-left: 4px;
    }
entities:

If you want the same padding for all 4 sides then just padding: 4px; would do for example.

Thank you Chris so much that works perfectly.

It was the div#states.card-content that I was missing, not sure I understand what div#states.card-content does exactly but thank you all the same.

Best regards, Colin

1 Like

Glad it worked!

This is really a self-taught learner trying to explain things here, so forgive me if I don’t quite get things 100% correct, or this is stuff you already know - but if you look at your screenshot, you have the <div id="states" class="card-content"> line highlighted. That’s the level where the padding values are applied for the entities card. (Your screenshot doesn’t show the CSS values for that level, displayed in the styles window in the inspector.)

I’m no CSS expert, but I believe id’s are denoted by a hash (#), and classes by a dot (.). So your card_mod code is basically saying 'apply these padding values to the div with the id states and class card-content.

I believe the div tag is just the way an HTML document is divided into sections.

I’m not seeing any card_mod code in your YAML - isn’t this really a question for the browser_mod thread? I would think you’re more likely to get help there if so.

1 Like

Thanks Chris that does help, I couldn’t see the sense of the # and the . now I can!

Best regards, Colin

How to reuse a card-mod code
(these questions are asked rather often)

There are several ways:
– yaml-anchors
– include
– secret
– macros
– decluttering-card
– card-mod theme
– external js

Note: examples below are synthetic and may be not optimal, but they give a general idea of re-use.

1. yaml-anchors
Only can be used in yaml-mode dashboards.
Anchors are one file-wide: if you have same repeated code in 2 files - you will have to declare same anchor in both files.

type: entities
entities:
  - entity: sun.sun
    card_mod: &ref_card_mod
      style: |
        :host { color: red; }
  - entity: sun.sun
    card_mod: *ref_card_mod
  - entity: sun.sun
    card_mod: *ref_card_mod

2. include
Only can be used in yaml-mode dashboards.

type: entities
entities:
  - entity: sun.sun
    card_mod: !include ...../style.yaml

where “style.yaml” contains

  style: |
    :host { color: red; }

Note: one imported file may contain one snippet - you cannot place several definitions like

style: |
  :host { color: red; }

style: |
  :host { color: green; }

style: |
  :host { color: blue; }

and then select a particular snippet.

Also, you can kind of “pass a variable” to the imported code:

type: entities
entities:
  - entity: sun.sun
    SUPER_COLOR: red #up to you how to name this option
    card_mod: !include ...../style.yaml
style: |
  :host { color: {{ config.SUPER_COLOR }}; }

3. secret
Only can be used in yaml-mode dashboards.

type: entities
entities:
  - entity: sun.sun
    card_mod: !secret card_mod_red_row

where “secrets.yaml” contains

card_mod_red_row:
  style: |
    :host { color: red; }

Note: one secrets file may contain several snippets like

card_mod_red_row:
  style: |
    :host { color: red; }

card_mod_green_row:
  style: |
    :host { color: green; }

card_mod_blue_row:
  style: |
    :host { color: blue; }

Although it is more convenient than using “include” (where each imported file must contain one snippet) - I would not recommend using secrets for not-secret data, wrong approach.


4. macros
Can be used both in yaml-mode & storage-mode dashboards.

type: entities
entities:
  - entity: sun.sun
card_mod:
  style: |
    ha-card {
      color: red;
    }
    {% from 'card_mod_macros.jinja' import MY_SUPER_HEADER -%}
    {{ MY_SUPER_HEADER() }}

where “card_mod_macros.jinja” contains

{% macro MY_SUPER_HEADER() -%}
  .card-content {
    color: red;
    ... other styles
  }
{%- endmacro %}

And ofc you can pass variables into a macros:

type: entities
entities:
  - entity: sun.sun
card_mod:
  style: |
    ha-card {
      color: red;
    }
    {% from 'card_mod_macros.jinja' import MY_SUPER_HEADER -%}
    {{ MY_SUPER_HEADER('magenta') }}
{% macro MY_SUPER_HEADER(COLOR) -%}
  .card-header {
    color: {{ COLOR }};
    ... other styles
  }
{%- endmacro %}

Note: one jinja-file may contain several macros like

{% macro card_mod_colored_state(COLOR) -%}
  ...
{%- endmacro %}

{% macro card_mod_colored_icon(COLOR) -%}
  ...
{%- endmacro %}

{% macro card_mod_colored_name(COLOR) -%}
  ...
{%- endmacro %}

5. decluttering-card
Can be used both in yaml-mode & storage-mode dashboards. There are some complexities in case of storage-mode dashboards (not to be described here, check Docs & other info for decluttering-card).
Assume you want to have card-modded Entities card in many places:

type: entities
title: ...
entities: ...
card_mod: ...

Create a decluttering template for this Entity card:

my_template:
  card:
    type: entities
    ... use input variables to define options
    card_mod: ...you may use input variable here like a particular color

and use this template where it is needed:

type: vertical-stack
cards:
  - ...
  - type: custom:decluttering-card
    template: my_template
    variables:
      - ...

You can pass a card-mod code as an input variable:

my_template:
  default:
    - STYLE: 'ha-card { color: red; }'
  card:
    type: entities
    ...
    card_mod:
      style: '[[STYLE]]'
type: vertical-stack
cards:
  - ...
  - type: custom:decluttering-card
    template: my_template
    variables:
      - STYLE: 'ha-card { color: cyan; }'
      - ...

to replace a default red color by a cyan color.
Also, you can pass an additional card-mod code as an input variable:

my_template:
  default:
    - STYLE: ''
  card:
    type: entities
    ...
    card_mod:
      style: |
        ha-card {
          color: red;
        }
        [[STYLE]]
type: vertical-stack
cards:
  - ...
  - type: custom:decluttering-card
    template: my_template
    variables:
      - STYLE: '.card-header { color: cyan; }'
      - ...

to add additional styles.
These were simple examples with string-like styles; in case of dictionary-like styles & styles with jinja templates there are more peculiarities which are beyond this topic.


6. card-mod theme
Traditional card-modding is about styling a particular card / row / other element of a particular card.
Card-mod theme provides “global” styles like:
– all Entities cards
– all rows with toggles
(not to mention other UI elements not covered by traditional card-modding like “view layout”, “sidebar”, “header”, “more-info dialog”, …)
Also, it is possible to mass-style SOME elements like:
– some Entities cards
– some rows with toggles
by using classes:

type: entities
card_mod:
  class: yellow_card

where “yellow_card” class is defined as

card-mod-card-yaml: |
  .: |
    ha-card.yellow_card {
      ... add your styles
    }

Check Docs for card-mod about defining themes.


7. External js
Can be used to style all UI elements of a particular type/class.
Particular examples will be not provided, it is not about card-mod & an off-topic here.

4 Likes

is it possible to add a background color to one heading badge icon?

Starting point:
1st post → link at the bottom → Heading

i know your fantastic overview and checked this out but i couldn´t find a answer to my question. I want a background of a badge in the heading title.

that is why a said it is a starting point… Find a post about Heading.

Map card - some animations

m1

code
type: map
entities:
  - entity: ...
card_mod:
  style:
    ha-map $:
      ha-entity-marker $: |
        .marker {
          outline-style: solid;
          outline-width: 1px;
          outline-color: var(--accent-color);
          animation: resizing_outline 1s linear infinite;
        } 
        @keyframes resizing_outline {
          0% {
            outline-offset: 0;
          }
          25% {
            outline-offset: 5px;
          }
          50% {
            outline-offset: 10px;
          }
          75% {
            outline-offset: 15px;
          }
          100% {
            outline-offset: 20px;
          }
        }

m2

code
type: map
entities:
  - entity: ...
card_mod:
  style:
    ha-map $:
      ha-icon $: |
        ha-svg-icon {
          animation: resizing 1s linear infinite;
        }
        @keyframes resizing {
          0% {
            transform: scale(0.3,0.3);
          }
          25% {
            transform: scale(0.7,0.7);
          }
          50% {
            transform: scale(1,1);
          }
          75% {
            transform: scale(1.15,1.15);
          }
          100% {
            transform: scale(1.3,1.3);
          }
        }
7 Likes