Add themes variables to tile card to change border radius (#26999)

This commit is contained in:
Paul Bottein
2025-09-11 14:55:07 +02:00
committed by GitHub
parent 1abedcd5f0
commit dcea227f4a
5 changed files with 67 additions and 37 deletions

View File

@@ -528,6 +528,10 @@ export class HaControlSlider extends LitElement {
background-color: white;
}
.slider .slider-track-bar {
--slider-track-bar-border-radius: min(
var(--control-slider-border-radius),
var(--ha-border-radius-md)
);
top: 0;
left: 0;
transform: translate3d(
@@ -535,7 +539,7 @@ export class HaControlSlider extends LitElement {
0,
0
);
border-radius: 0 8px 8px 0;
border-radius: var(--slider-track-bar-border-radius);
}
.slider .slider-track-bar:after {
top: 0;
@@ -548,7 +552,6 @@ export class HaControlSlider extends LitElement {
right: 0;
left: initial;
transform: translate3d(calc(var(--value, 0) * var(--slider-size)), 0, 0);
border-radius: 8px 0 0 8px;
}
.slider .slider-track-bar.end::after {
right: initial;
@@ -563,7 +566,6 @@ export class HaControlSlider extends LitElement {
calc((1 - var(--value, 0)) * var(--slider-size)),
0
);
border-radius: 8px 8px 0 0;
}
:host([vertical]) .slider .slider-track-bar:after {
top: var(--handle-margin);
@@ -581,7 +583,6 @@ export class HaControlSlider extends LitElement {
calc((0 - var(--value, 0)) * var(--slider-size)),
0
);
border-radius: 0 0 8px 8px;
}
:host([vertical]) .slider .slider-track-bar.end::after {
top: initial;
@@ -605,7 +606,10 @@ export class HaControlSlider extends LitElement {
--cursor-size: calc(var(--control-slider-thickness) / 4);
position: absolute;
background-color: white;
border-radius: var(--handle-size);
border-radius: min(
var(--handle-size),
var(--control-slider-border-radius)
);
transition:
left 180ms ease-in-out,
bottom 180ms ease-in-out;

View File

@@ -3,28 +3,35 @@ import { LitElement, css, html } from "lit";
import { customElement, property } from "lit/decorators";
import "../ha-icon";
import "../ha-svg-icon";
import { classMap } from "lit/directives/class-map";
export type TileIconImageStyle = "square" | "rounded-square" | "circle";
export const DEFAULT_TILE_ICON_BORDER_STYLE = "circle";
/**
* Home Assistant tile icon component
*
* @element ha-tile-icon
*
* @summary
* A tile icon component, used in tile card in Home Assistant to display an icon or image.
*
* @slot - Additional content (for example, a badge).
* @slot icon - The icon container (usually for icons).
*
* @cssprop --ha-tile-icon-border-radius - The border radius of the tile icon. defaults to `var(--ha-border-radius-pill)`.
*
* @attr {boolean} interactive - Whether the icon is interactive (hover and focus styles).
* @attr {string} image-url - The URL of the image to display instead of an icon.
*/
@customElement("ha-tile-icon")
export class HaTileIcon extends LitElement {
@property({ type: Boolean, reflect: true })
public interactive = false;
@property({ attribute: "border-style", type: String })
public imageStyle?: TileIconImageStyle;
@property({ attribute: false })
@property({ attribute: "image-url", type: String })
public imageUrl?: string;
protected render(): TemplateResult {
if (this.imageUrl) {
const imageStyle = this.imageStyle || DEFAULT_TILE_ICON_BORDER_STYLE;
return html`
<div class="container ${classMap({ [imageStyle]: this.imageUrl })}">
<div class="container">
<img alt="" src=${this.imageUrl} />
</div>
<slot></slot>
@@ -44,6 +51,11 @@ export class HaTileIcon extends LitElement {
--tile-icon-color: var(--disabled-color);
--tile-icon-opacity: 0.2;
--tile-icon-hover-opacity: 0.35;
--tile-icon-border-radius: var(
--ha-tile-icon-border-radius,
var(--ha-border-radius-pill)
);
--tile-icon-size: 36px;
--mdc-icon-size: 24px;
position: relative;
user-select: none;
@@ -60,21 +72,15 @@ export class HaTileIcon extends LitElement {
display: flex;
align-items: center;
justify-content: center;
width: 36px;
height: 36px;
border-radius: 18px;
width: var(--tile-icon-size);
height: var(--tile-icon-size);
border-radius: var(--tile-icon-border-radius);
overflow: hidden;
transition: box-shadow 180ms ease-in-out;
}
:host([interactive]:focus-visible) .container {
box-shadow: 0 0 0 2px var(--tile-icon-color);
}
.container.rounded-square {
border-radius: 8px;
}
.container.square {
border-radius: 0;
}
.container.background::before {
content: "";
position: absolute;