šŸ”¹ Card-mod - Add css styles to any lovelace card

Well, at least using one more syntax gives us more flexibility!

just a thought, but would it all be possible have the overview posts separated into a Community Guide of sorts. No discussions there, those are done here, simply all posts like @Ildar_Gabdullin did for the various cards and stylings.

Right now, we need to go back and forth in this thread to find these (or save them locally, as I didā€¦). I think it would be very beneficial to all of us to have them on display permanently.

With the separated/dedicated community guide, checking how to style a badge, or a font-size for Entities card would be a breeze.

4 Likes

I would appreciate guidance for suppressing the display of the entire toggle button in an Entities card.

Iā€™ve tried enough things to confirm I donā€™t have a good grasp of the core concepts (i.e. seems straighforward in theory but not in practice). For example, I tried this but it doesnā€™t work:

type: entities
entities:
  - entity: input_boolean.test
show_header_toggle: false
style:
  ha-entity-toggle:
    $: |
      ha-switch {
        display: none !important;
      }

The toggle button is within a shadow-root and, based on my limitation understanding, that implies more complexity in how to define the item I wish to act on.

1 Like

The doc says:
ā€œI recommend using HACS to install and keep track of plugins.ā€
But this plug-in is nowhere to be found in HACS ?
Is a custom repository needed to install it ? If so, whatā€™s the URL ?

Hi.
Thanks for all your work and help here!

Iā€™ve searched for a few days but cant seem to figure out how it actually works.
Iā€™ve also read that there might be problems with picture elemts cards, but there was a work around?

I have 2 icons, which actually should show a debug boolean state (removed to simplify) but I just want to change the color depending on on/off state and the only way to do it seems to be card-mod.

elements:
  - icon: 'mdi:android-debug-bridge'
    title: Debug
    type: icon
    style:
      '--mdc-icon-size': 40px
      color: 'rgba(255, 0, 0, 0.6)'
      background-color: 'rgba(3, 169, 244, 0.6)'
      border-radius: 50%
      top: 35%
      left: 40%
      padding: 10px 10px 10px 10px
  - icon: 'mdi:android-debug-bridge'
    title: Debug
    type: icon
    style: |
      hui-icon-element {
        color: blue;
      }
image: /
type: picture-elements

But Iā€™m unable to make the second icon use any of the attributes of the first icon.
Iā€™ve also tryed the debug method of my browser and found some elemts names but they modify colors of the entire page.

<hui-icon-element class="element" style="--mdc-icon-size:40px; color: rgba(255, 0, 0, 0.6); background-color: rgba(3, 169, 244, 0.6); border-radius: 50%; top: 35%; left: 40%; padding: 10px;"></hui-icon-element>

Any help apreciated

Uh, Maybe I can hepl here!

I just made it work:

In Hacs, under Frontend, press ā€œ+ EXPLORE & ADD REPOSITURIESā€ and search for card-mod. Think thats how I made it work!

Found it :+1: Thank you!

2 Likes

Here all my posts which may be useful:


NOTE:
Do not forget to add a "card_mod:" keyword before "style:" (new in card-mod 3).
And also read this important note to create optimized code. In most examples here a code is NOT optimized - just to describe a DOM navigation.


Entity card
post
rotating icon (by @dolodobendan)
disabled tap_action


Entities card (including some special row elements - button, section, divider)
post
using standard vars for some domains

font-size for Entities card
post

Entities card with attributes
post

Slider entity inside Entities card
main post
popup baloon issue
hide the popup baloon

"hui-input-number-entity-row" - entity row for "input_number"
main post
How to make input_number rows look less different from other entity rows - part 1, part 2

input_select row
main post
How to make input_select rows look less different from other entity rows - part 1, part 2
How to add secondary_info: last-changed

input-text row
post
How to make input_text rows look less different from other entity rows - part 1, part 2

input_datetime row
part 1
part 2
How to make input_datetime rows look less different from other entity rows - part 1, part 2

Conditional row inside Entities card
post

Toggle row inside Entities card
colored checkbox
how to disable a toggle button
how to disable a toggle button - inside auto-entities
moving toggle to the left

Hiding checkboxes inside Entities card
for some entity row
for all entity rows

Animations for Entities card
post

ā€œChipā€ buttons
post
card-mod theme for chip buttons
changing styles for a particular button in a footer dependently on a state
changing an icon

Cover entity row
main post
disable a cover control conditionally
ā€œnarrowedā€ look

Light entity row
how to show lights with using only ā€œactiveā€ & ā€œinactiveā€ colors

How to manage a rowā€™s height
decrease height
increase height

How to shift rows to the right
post

How to center weblinks & commands
post

ā€œEmpty slotā€ for Entities card
post

Circular progress indicator
post


Glance card
main post
changing margin
Allocate items in a compact manner


Footer / Header
post


custom:multiple-entity-row
main post
displaying "last-changed" or any other labels for items
distribute items evenly
animated icons


custom:fold-entity-row
main post
How to enable / disable a ā€œfold / unfoldā€ control for fold-entity-row
RTL fix for a section row


custom:template-entity-row
main post
t-e-r inside a conditional row


custom:numberbox-card
post


custom:multiline-text-input-card
post


custom:text-divider-row
post


Tile card
colored icon & background on hover
remove background from an icon
adding a button
custom icons for features


Heading
post
change icons


Thermostat
custom icons for features


custom:bar-card
animation
2 text lines
displaying an image instead of an icon
centered title
hide the whole bar-card if all bars are hidden
replacing a value
adding a prefix
RTL fix for vertical bars


Gauge
disabled tap_action


markdown
scrollbar
scrollbar for some text
markdown with images
markdown with a table: post 1, post 2, post 3
colorize only some text
external js for ā€œhrā€ element


Picture Glance card
post
changing an icon by card-mod
distributing icons


Sensor card with a graph
post


History-graph card
styling
prevent clipping when using inside stack-in-card
added scrollbar
custom line colors
custom timeline colors
how to set a 0 lower bound for Y-axis
styling a tooltip
how to add an icon to a cardā€™s title
how to set a height


statistics-graph card
post
grouping / aligning labels
custom line colors
replacing a label
how to set a 0 lower bound for Y-axis


custom:mini-graph-card
main post
animation - blinking name, resized & rotating icon
how to display an additional info on the card
how to display additional text items (prefixes & suffixes)
solid (non-semitransparent) fill
move a graph for the 2nd sensor to the bottom
how to set a color for the last bar
place 2 sensorsā€™ states on the left side
displaying states as a part of the legend
displaying a UoM under the state
displaying a UoM before a state
displaying a state & extrema data on the same line
using card-mod to compare mini-graph-card & history-graph
non-elegant & unstable way to show labels for X-axis
fixing an issue with a card inside state-switch
imitating statistics card
how to nicely align legendā€™s elements
compact view when used in horizontal stack or grid
styling Y-axis labelsā€™ background
how to change graphā€™s color dynamically


custom:apexcharts
RTL fix


Weather Card
post


Styling a card inside ā€˜custom:config-template-cardā€™
post


Styling a card inside ā€˜custom:decluttering-cardā€™ + passing a style as a variable
post 1
post 2


Badges (before 2024.8)
important - fix to restore a possibility to style badges after 2024.8
Badges: different styling
Badges: conditional show/hide
Badges: hidden name
Square badges
Dynamic icon
Show either an icon or a value
Manually added UoM
Replacing a state
Replacing a UoM
Gradient colors for a badge dependingly on a value (by @parautenbach)


Badges (2024.8)
badges themselves
badges themselves (mod-card) by @arganto
themes - one, two, three


custom:badge-card
post
after 2024.8


Picture Elements card
main post
conditional elements
rotated background image
ā€œselection areaā€
3 ways to change an element dynamically
on-hover effect for elements
example: show a charging process


Logbook card
main post
styling images by using external js-module
Logbook in a Panel mode
styling a scrollbar (style is unstable)


Media Player card
post


custom:mini-media-player
post


vertical-stack, horizontal-stack
main post
How to fix the ā€œmargin-topā€ problem for a hidden conditional card
Stack inside ā€œhui-elementā€ card
Removing internal borders & margins inside vertical-stack
how to add an icon to a cardā€™s title


grid
how to add an icon to a cardā€™s title


custom:stack-in-card
main post
example of customizing a width in a horizontal stack
styling a header
how to add an icon to a cardā€™s title


custom:flex-table-card
main post
How to style a header


Map card
styling markers
display values on a Map card


custom:shutter-card
disable controls


custom:hui-element
post


custom:restriction-card
main post
custom background
fix for a restriction card inside a Grid with square cells


custom:button-card
One of rare cases when card-mod is needed for custom:button-card
Using button-card variables in jinja card-mod code
Adapting for sections


custom:tabbed-card
post


custom: fluid-level-background-card
post


auto-entities
list of posts with styles


Sticky cards
post


Additional small title for any card with a title
post


How to scale an iframe content
post
post


custom:sun-card, custom:horizon-card
post


Other stuff
About these examples
Important notes about navigation
About navigation
About navigation #2
Combining ā€œ$:ā€ styles and ā€œnot $:ā€ styles
Using variables (especially after 2022.12)
Card for testing colors for binary_sensor entities (icons, history) (may be useful after 2022.12)
Using "::before" , "::after" & "content"
How to change card-mod styles for dark & light modes
How to let HA to choose a default style
How to combine icons
Possible errors when using card-mod
Conditional styles for different clients
Using global macros
Issue with re-defining a variable
Adding a color outline to icons
Showing an old HA logo (pre 2023.10)
How to add an icon to a cardā€™s title
User-defined config options - to be used inside card-mod
config.entity + mod-card
Using yaml-anchors
Meaning of these ā€œ{%ā€ & ā€œ{%-ā€ things for card-mod code


Themes
for beginners: where to put card-mod theme code?, also here
ā€œ-yamlā€ vs ā€œw/o -yamlā€: schema
Using classes

Styling badges
Badges-2024.8: column layout

ā€œSidebarā€ view: how to set a fixed width for a right sidebar
ā€œSidebarā€ view: moving a right sidebar to the left
ā€œSidebarā€ view: allow to scroll ā€œmainā€ area w/o scrolling a sidebar

Header: styling tabs
Header: moving a header to the bottom
Header: hiding a header
Header: how to change a headerā€™s icon size
Header: badges in a header
Header: hide a ā€œsearchā€ button (also - hide all buttons & menu)
Header: vivid selected & hovered tabs
Header: remove ā€œopacityā€ effect

Sidebar: styling a sidebar + adding badges to a sidebar

168 Likes

ŠøŠ·Š¾Š±Ń€Š°Š¶ŠµŠ½ŠøŠµ

type: entities
entities:
  - entity: input_boolean.test_boolean
    name: 'Checkbox: hidden'
    style:
      hui-generic-entity-row:
        ha-entity-toggle:
          $: |
            ha-switch {
             display: none;
            }
1 Like

Thank you! I think I now understand why the many things I have tried all failed to work.

If the Entities card contains multiple entities, is there a way to make the style apply to all of them? Or does it have to be repeated for each one separately?

Please check here:

There are examples with common style for all entities.
Note that you can specify a common style and then override it for some particular entity like here:

type: entities
title: 'Changed color'
style: |
  ha-card {
    color: blue;
  }
  ha-card .card-content {
    color: red;
  }
entities:
  - entity: input_boolean.test_boolean
    name: Inherited color
  - entity: sun.sun
    name: Inherited color
    secondary_info: last-changed
  - entity: sun.sun
    name: Changed color
    secondary_info: last-changed
    style: |
      :host {
       color: cyan;
      }

ŠøŠ·Š¾Š±Ń€Š°Š¶ŠµŠ½ŠøŠµ

The issue I am experiencing is that if I move the style block to the left, so it applies to all entities, it fails to work (even for just one entity).

type: entities
entities:
  - entity: input_boolean.test_boolean
style:
  hui-generic-entity-row:
    ha-entity-toggle:
      $: |
        ha-switch {
         display: none;
        }

Does the reference within the style have to be modified?

Please check this:
ŠøŠ·Š¾Š±Ń€Š°Š¶ŠµŠ½ŠøŠµ

type: entities
title: 'Checkbox: hidden'
show_header_toggle: false
entities:
  - entity: input_boolean.test_boolean
  - entity: input_boolean.test_boolean
style:
  hui-toggle-entity-row:
    $:
      hui-generic-entity-row:
        ha-entity-toggle:
          $: |
            ha-switch {
             display: none;
            }

"hui-generic-entity-row" is inside shadow-root of "hui-toggle-entity-row", so you must specify it.
And you mustnā€™t if the style is for a particular entity (in short, you are already inside the shadow-root).

Colored checkbox:

NOTE:
Do not forget to add a "card_mod:" keyword before "style:" (new in card-mod 3).

Track with static color, colored trackā€™s border:

  - entity: input_boolean.test_boolean
    name: 'colored back (static), colored border'
    style:
      hui-generic-entity-row:
        ha-entity-toggle:
          $:
            ha-switch:
              $: |
                .mdc-switch .mdc-switch__track {
                  background-color: yellow !important;
                  border-color: green !important;
                }

ŠøŠ·Š¾Š±Ń€Š°Š¶ŠµŠ½ŠøŠµ ŠøŠ·Š¾Š±Ń€Š°Š¶ŠµŠ½ŠøŠµ

Track with conditional color, colored trackā€™s border:

  - entity: input_boolean.test_boolean
    name: 'colored back (conditional), colored border'
    style:
      hui-generic-entity-row:
        ha-entity-toggle:
          $:
            ha-switch:
              $: |
                .mdc-switch .mdc-switch__track {
                  border-color: green !important;
                }
              .: |
                ha-switch {
                --switch-unchecked-track-color: yellow;
                --switch-checked-track-color: red;
                }

ŠøŠ·Š¾Š±Ń€Š°Š¶ŠµŠ½ŠøŠµ ŠøŠ·Š¾Š±Ń€Š°Š¶ŠµŠ½ŠøŠµ


Thumb with conditional color:

  - entity: input_boolean.test_boolean
    name: colored button (conditional)
    style:
      hui-generic-entity-row:
        ha-entity-toggle:
          $: |
            ha-switch {
              --switch-unchecked-button-color: yellow;
              --switch-checked-button-color: red;
            }

ŠøŠ·Š¾Š±Ń€Š°Š¶ŠµŠ½ŠøŠµ ŠøŠ·Š¾Š±Ń€Š°Š¶ŠµŠ½ŠøŠµ

More examples are described here.

3 Likes

Thanks again! I will have to learn more about how to navigate through the various levels. Your examples are very helpful.

1 Like

Thanks for all your posts, they have been quite informative!

But I think Iā€™m at a state where you were too in the beginning. Not grasping the whole idea and not being able to read a good toturial.

Is the idea that you start your tree in the top layer, and write in code your way down untill you get to the eneioty you want changed?
And that $: is to change into those shadow-y-thing-y?
And the dot-colon-space-pipe >> .: | << is for when theres actually coming style code?

Yes, I am trying to use this approach.
Also, in this thread there was at least one more method described by the developer of card-mod (look at his posts, you will find the needed one).

It was described in the GitHub (GitHub - thomasloven/lovelace-card-mod: šŸ”¹ Add CSS styles to (almost) any lovelace card).
$: is used to go inside shadow-root of some element.

.: is used to go inside some element (not shadow-root) - see GitHub.

I am not 100% sure but I think that the pipe | is used to break a line before styles:

    style: |
      :host {
        color: red;
      }
or
    style: ':host { color: red; }'
    style:
      hui-generic-entity-row:
        ha-entity-toggle:
          $: |
            ha-switch {
              --switch-unchecked-button-color: yellow;
              --switch-checked-button-color: red;
            }            
or
    style:
      hui-generic-entity-row ha-entity-toggle:
        $: 'ha-switch { --switch-unchecked-button-color: yellow; --switch-checked-button-color: red; }'

The means that the pipe must be used ONE time after the LAST colon.

The example:

type: entities
title: Using pipe
show_header_toggle: false
entities:
  - entity: input_boolean.test_boolean
    name: colored text
    style: |
      :host {
        color: red;
      }
  - entity: input_boolean.test_boolean
    name: colored text
    style: ':host { color: red; }'
  - entity: input_boolean.test_boolean
    name: colored button
    style:
      hui-generic-entity-row:
        ha-entity-toggle:
          $: |
            ha-switch {
              --switch-unchecked-button-color: yellow;
              --switch-checked-button-color: red;
            }            
  - entity: input_boolean.test_boolean
    name: colored button
    style:
      hui-generic-entity-row:
        ha-entity-toggle:
          $: 'ha-switch { --switch-unchecked-button-color: yellow; --switch-checked-button-color: red; }'
  - entity: input_boolean.test_boolean
    name: colored button
    style:
      hui-generic-entity-row ha-entity-toggle:
        $: 'ha-switch { --switch-unchecked-button-color: yellow; --switch-checked-button-color: red; }'

ŠøŠ·Š¾Š±Ń€Š°Š¶ŠµŠ½ŠøŠµ

3 Likes

Iā€™ve been off here for a bit. Are there any posts that havenā€™t already been answered?

How can I reach the first div in order to add style elements? I tried a few searches but Iā€™m not even sure what to search for. I scanned a number of Ildar Gabdullinā€™s posts as there are many examples but except for going into shadow roots I couldnā€™t find the answer for this.

Iā€™m pretty sure you donā€™t need shadow-rooting for that. What happens without shadow-rooting? Could you also specify your whole intentions?