Just for a light card in general.
. The secondary information is limited to a few choices, and I jsut want it to alwsy say a custom word. Can you tell me how or if I can do that using this?
I just started using Card-mod and Iām verry happy with it.
Now i come to a situation, where I stuck in the middle of nowhere:
In the picture you can see the green padding-top and padding bottom. I try to modify the padding-bottom.
But whatever I put in the code, it has no effect. Here is my code:
`
`
type: custom:atomic-calendar-revive
style: |
ha-card {
background: none;
box-shadow: none;
}
div.headerName {
letter-spacing: 0.112em !important;
box-shadow: none;
font-size: 2.55em;
}
div.headerDate {
letter-spacing: 0.1em !important;
box-shadow: none;
font-size: 5.55em;
line-height: 1.2;
font-weight: bold;
}
div.cal-eventContainer {
letter-spacing: 0.1em !important;
box-shadow: none;
font-weight: normal;
font-size: 2.55em;
letter-spacing: 0.02em !important;
line-height: 1.2;
padding-bottom: 0px;
}
# the following code is not working
ha-card:
$:
div:
$:
table:
$:
tbody:
$:
tr:
$:
td {
padding-bottom: 100px;
}
``
I tried with the card-mod-helper as well:
"#view>hui-view>hui-panel-view$hui-vertical-stack-card$#root>atomic-calendar-revive$ha-card>div>table>tbody>tr:nth-child(1)>td:nth-child(2)"
But no success.
Any ideas? Thanks!
Styling statistics-graph
card
What is changed:
- Header: textās color, font-size, padding-bottom.
- Legend: margin-top, textās color, font-size, bulletsā color. (note that since 2024.3 a legend contains only 1 label per-entity)
- Cardās background.
- type: statistics-graph
chart_type: line
period: 5minute
days_to_show: 90
stat_types:
- mean
- min
- max
entities:
- sensor.xiaomi_cg_1_temperature
title: Statistics
card_mod:
style:
$: |
.card-header {
color: red !important;
font-size: 38px !important;
padding-bottom: 0px !important;
}
.content statistics-chart $ ha-chart-base $: |
.chart-legend li:nth-child(1) .label {
color: red;
font-size: 8px;
}
.chart-legend li:nth-child(1) .bullet {
background-color: yellow !important;
height: 8px;
width: 8px;
}
.chart-legend li:nth-child(2) .label {
color: white;
font-size: 12px;
}
.chart-legend li:nth-child(2) .bullet {
background-color: green !important;
height: 12px;
width: 12px;
}
.chart-legend li:nth-child(3) .label {
color: orange;
font-size: 18px;
}
.chart-legend li:nth-child(3) .bullet {
background-color: magenta !important;
height: 18px;
width: 18px;
}
.chart-legend ul {
margin-top: 0px !important;
}
.: |
ha-card {
background-color: lightgreen;
}
How to hide a legend (not needed since hide_legend
option was added):
chart_type: line
period: 5minute
days_to_show: 90
type: statistics-graph
entities:
- sensor.xiaomi_cg_1_temperature
stat_types:
- mean
- min
- max
title: Statistics
card_mod:
style:
.content statistics-chart $ ha-chart-base $: |
.chart-legend {
display: none;
}
More examples are described here.
Assuming your pasted code has come out faithfully, Iām not sure your indentation is 100% correct. You should also be using the card_mod
key as standard practice by now.
However, it seems that this particular setting needs the !important
rule to make it stick. Try this to see if it works for you:
type: custom:atomic-calendar-revive
card_mod:
style: |
ha-card {
background: none;
box-shadow: none;
}
div.headerName {
letter-spacing: 0.112em !important;
box-shadow: none;
font-size: 2.55em;
}
div.headerDate {
letter-spacing: 0.1em !important;
box-shadow: none;
font-size: 5.55em;
line-height: 1.2;
font-weight: bold;
}
div.cal-eventContainer {
letter-spacing: 0.1em !important;
box-shadow: none;
font-weight: normal;
font-size: 2.55em;
letter-spacing: 0.02em !important;
line-height: 1.2;
padding-bottom: 0px !important;
}
div.cal-eventContainer table tbody tr td {
padding-top: 10px !important;
}
Thanks a lot! Now its working!
Grouping / aligning labels in a statistics-graph
:
In a statistics-graph
card, each sensor may have up to several labels (min, max, mean, ā¦).
This is how these labels may be allocated:
instead of:
There are at least 2 methods of grouping labels - check this example:
type: vertical-stack
cards:
- <<: &ref_card
type: statistics-graph
chart_type: line
period: 5minute
days_to_show: 90
entities:
- entity: sensor.xiaomi_cg_1_temperature
name: t1
- entity: sensor.xiaomi_cg_2_temperature
name: t2
stat_types:
- mean
- min
- max
- <<: *ref_card
card_mod:
style:
.content statistics-chart $ ha-chart-base $: |
.chart-legend li {
justify-content: center;
}
.chart-legend ul {
display: grid !important;
grid-template-columns: repeat(3,1fr);
}
- <<: *ref_card
card_mod:
style:
.content statistics-chart $ ha-chart-base $: |
.chart-legend li {
flex: 0 0 33.3333%;
justify-content: center;
}
.chart-legend ul {
flex-wrap: wrap;
display: flex !important;
}
Another case is when one sensor has a long name, another sensor has a short name:
instead of:
How to solve it:
type: vertical-stack
cards:
- <<: &ref_card
type: statistics-graph
chart_type: line
period: 5minute
days_to_show: 90
entities:
- entity: sensor.xiaomi_cg_1_temperature
name: temperature
- entity: sensor.xiaomi_cg_2_temperature
name: temp
stat_types:
- mean
- min
- max
- <<: *ref_card
card_mod:
style:
.content statistics-chart $ ha-chart-base $: |
.chart-legend li {
justify-content: center;
}
.chart-legend li:nth-child(3) {
flex-basis: 100%;
}
.chart-legend ul {
display: flex !important;
flex-wrap: wrap;
justify-content: center;
}
I recently encountered an issue with the background of my cards:
I had a setup where the background of all cards in a view was a big image over the whole view that was fixed.
Since some time (the HA update with the card stuff?) the background is shown on every card and not as a single image (as before).
Does someone hava a similar problem and did solve this?
Here is a sample theme:
theme_livingroom:
card-mod-theme: theme_livingroom
card-mod-card: |
ha-card {
background: url('/local/images/cards/livingroom.jpg') !important;
background-attachment: fixed !important;
background-size: cover !important;
}
I wonāt to change icon colour based on status of two sensors.
If one of my windows is open then I want gold colour else colour must be steelblue
Does not work as expected.
Can you please check my code:
show_name: true
show_icon: true
type: button
tap_action:
action: navigate
navigation_path: /devices-dashboarf/prozori_vrata
entity: ''
name: Prozori i vrata
card_mod: null
style: |
:host {
--paper-item-icon-color: {% if is_state("binary_sensor.senzor_prozora_dnevna_soba", "on") or ("binary_sensor.senzor_prozora_spavaca_soba", "on") -%} gold
{% else %} steelblue
{% endif %};
icon: mdi:window-closed-variant
show_state: true
icon_height: 70px
hold_action:
action: none
Iām trying to use card mod to alter a card layout, and I have the individual elements working, but Iām not sure how the syntax should be to merge the two styles Iām trying to apply.
Could anyone advise what the correct syntax is to add this;
mushroom-state-item:
$: |
.container {
flex-direction: row-reverse !important;
}
onto this;
- type: custom:mushroom-template-card
primary: Home
icon: mdi:home
icon_color: blue
card_mod:
style: |
mushroom-card {
background: rgba(10,70,170,0.2);
padding: 6px;
border-radius: 12px
}
ha-card {
box-shadow: none !important;
padding-top: 0px !important;
padding-bottom: 10px !important;
--card-primary-font-size: 18px;
--card-primary-font-weight: 300 !important;
}
?
Iām trying to adjust the font size of the āvalueā for https://github.com/custom-cards/dual-gauge-card - if itās been mentioned somewhere I accept the humiliation on failing to find the answer with Google.
Iāve attempted various combinations and tried to use developer view of browser but CSS is all Chinese to me.
What it looks currently:
Current attempt (yeah, I know 40px is not the value I want to use, but trying it for debug purposes to see when I wouldāve managed to change the value).
type: custom:dual-gauge-card
title: Teho vaihe 1
min: -1370
max: 8050
outer:
entity: sensor.shellyem3_1_channel_a_power
label: Koti
inner:
entity: sensor.shellyem3_2_channel_a_power
label: Laturi
min: 0
max: 3680
colors:
- color: var(--label-badge-red)
value: 3000
- color: var(--label-badge-yellow)
value: 1500
- color: var(--label-badge-green)
value: 500
- color: var(--label-badge-blue)
value: 0
colors:
- color: var(--label-badge-red)
value: 7000
- color: var(--label-badge-yellow)
value: 3000
- color: var(--label-badge-green)
value: -500
- color: var(--label-badge-blue)
value: -1370
card_mod:
style: |
ha-card.type-custom-dual-gauge-card {
font-size: 40px;
}
Thanks in advance!
Also screenshot from developer view, on separate message due to these being my first 2 messages here so Iām allowed to post 1 media file per post.
I am trying to set font size of the ākitchenā part of this card. But i am struggling a bit. The color and background and weight settings work, but not the font size. I am also not sure when to use ha-card vs :host? On a related note, can i set the background color as a rgb code, or take from the time, or does it have to be a ānamed colorā?
cards:
- type: button
name: Kitchen
show_icon: false
card_mod:
style: |
:host {
--ha-card-background: teal;
font-size: 80px;
font-weight: 1000;
color: red;
}
How to combine icons?
This is an example of probably useless styling; consider it as a demo.
āUselessā - because alternative ways may be used; anyway, this is up to a user which way to choose.
Consider some device with 2 attributes.
Each attribute may be expressed by some icon.
Here there is a device with 2 attributes:
- battery level - expressed by some ābatteryā icon;
- āworking / not workingā - expressed by some āfanā icon.
This example contains 2 Entities cards:
- To select a battery level.
- To represent this device.
The 2nd Entities card has 2 rows:
- For battery level - has a hidden state label.
- For āworking/not workingā state.
And both rows are placed in one row.
This is achieved by this styles:
- type: entities
card_mod:
style: |
div#states {
display: grid;
}
div#states > * {
grid-row-start: 1;
grid-column-start: 1;
}
Other styles are basically to improve a presentation.
Choose your own set of colors/opacities.
Battery color is implemented by Custom UI.
The whole code is here
type: vertical-stack
cards:
- type: entities
entities:
- entity: input_number.test_level_1
name: battery level
- type: entities
card_mod:
style: |
div#states {
display: grid;
}
div#states > * {
margin: 0;
grid-row-start: 1;
grid-column-start: 1;
}
entities:
- entity: sensor.test_battery
name: ' '
card_mod:
style:
hui-generic-entity-row $: |
.text-content:not(.info) {
display: none;
}
state-badge {
opacity: 0.6 !important;
}
.: |
:host {
--mdc-icon-size: 32px;
}
- entity: input_boolean.test_boolean_2
name: some device
icon: mdi:fan
card_mod:
style:
hui-generic-entity-row $ state-badge $ ha-state-icon $ ha-icon $: |
ha-svg-icon {
{% if is_state(config.entity,'on') %}
animation: spin 3s infinite linear;
color: black;
opacity: 0.2;
{% else %}
opacity: 0.2;
{% endif %}
}
@keyframes spin {
0% {
transform: rotate(0deg);
}
100% {
transform: rotate(359deg);
}
}
BTW, a similar functionality may be used with a custom:button-card
- see this example.
(untested) Try to replace it with ha-card
I donāt know enough about car-mod to know when host is right and ha-card is right, but in this case i tried ha-card first and it seems to give the same result. Background, color and font-weight changes how it looks, but font-size seems to make no difference.
Try !important in such cases first. Did you do this? You can see this good in developer tools in Chrome, etc. as well. Just open it and see which styles are applied and which are crossed out, etc. If your set value is crossed out then another one overruling and you can avoid via !important.
And you can set any color you want, not only named.
Thanks. You seem to be right it is crossed out (see picture on the bottom), not sure why though, but what does it mean to try ā!importantā? Do I have to write !important font-size: 80px? And to set an RGB-color how do i do it? Rgb(x,x,x) instead of āredā?
Most of the time google is your friend as well. Try searching for css + important
.
font-size: 80px !important;
Why are you not just testing it? As said, it is not important, if it is red or rgb(100,0,0) or #ff0000 or ā¦
Thanks, Iām sorry I am not that skilled with CSS, I tried googling, that is why i came up with the original solution. As with the testing, it just felt easier to ask about what the right syntax was instead of trying stuff that could just as well not work. Sorry for wasting your time.
Bit thanks a lot for the solution, it now works just like i wanted with the !important-tag and the rgb(x,x,x) syntax.
@ATWindsor let me explain you how it works.
To help you someone in most cases should:
- take your code,
- paste it into own dashboard,
- add necessary sensors, replace your sensors in the code with the added sensors,
- see if styles what you need are applied,
- try to experiment with different CSS properties, adding ā!importantā, changing DOM navigation.
This is not ā1-second-glanceā. This all takes time.
And this may be done by YOU.
There are a lot of examples here.
Enough to use them by ācopy/pasteā, enough to adapt them to personal needs, enough to self-educate.