diff --git a/src/cards/chips-card/chips/weather-chip.ts b/src/cards/chips-card/chips/weather-chip.ts index 22e6a7fd3..f4174d0d5 100644 --- a/src/cards/chips-card/chips/weather-chip.ts +++ b/src/cards/chips-card/chips/weather-chip.ts @@ -95,7 +95,7 @@ export class WeatherChip extends LitElement implements LovelaceChip { > ${weatherIcon} ${displayLabels.length > 0 - ? html`${displayLabels.join(" / ")}` + ? html`${displayLabels.join(" ⸱ ")}` : nothing} `; diff --git a/src/cards/climate-card/climate-card.ts b/src/cards/climate-card/climate-card.ts index a8a836adb..52fc59ab0 100644 --- a/src/cards/climate-card/climate-card.ts +++ b/src/cards/climate-card/climate-card.ts @@ -172,7 +172,7 @@ export class ClimateCard stateObj, "current_temperature" ); - stateDisplay += ` - ${temperature}`; + stateDisplay += ` ⸱ ${temperature}`; } const rtl = computeRTL(this.hass); diff --git a/src/cards/cover-card/cover-card.ts b/src/cards/cover-card/cover-card.ts index 2285182f5..8769f283f 100644 --- a/src/cards/cover-card/cover-card.ts +++ b/src/cards/cover-card/cover-card.ts @@ -12,7 +12,6 @@ import { styleMap } from "lit/directives/style-map.js"; import { actionHandler, ActionHandlerEvent, - blankBeforePercent, computeRTL, CoverEntity, handleAction, @@ -196,7 +195,12 @@ export class CoverCard let stateDisplay = this.hass.formatEntityState(stateObj); if (this.position) { - stateDisplay += ` - ${this.position}${blankBeforePercent(this.hass.locale)}%`; + const position = this.hass.formatEntityAttributeValue( + stateObj, + "current_position", + this.position + ); + stateDisplay += ` ⸱ ${position}`; } const rtl = computeRTL(this.hass); diff --git a/src/cards/fan-card/fan-card.ts b/src/cards/fan-card/fan-card.ts index ee8e3d068..8f6fd3805 100644 --- a/src/cards/fan-card/fan-card.ts +++ b/src/cards/fan-card/fan-card.ts @@ -13,7 +13,6 @@ import { styleMap } from "lit/directives/style-map.js"; import { actionHandler, ActionHandlerEvent, - blankBeforePercent, computeRTL, handleAction, hasAction, @@ -138,7 +137,12 @@ export class FanCard let stateDisplay = this.hass.formatEntityState(stateObj); if (this.percentage != null && stateObj.state === "on") { - stateDisplay = `${this.percentage}${blankBeforePercent(this.hass.locale)}%`; + const percentage = this.hass.formatEntityAttributeValue( + stateObj, + "percentage", + this.percentage + ); + stateDisplay = percentage; } const rtl = computeRTL(this.hass); diff --git a/src/cards/humidifier-card/humidifier-card.ts b/src/cards/humidifier-card/humidifier-card.ts index 59eaf921d..3dac3656f 100644 --- a/src/cards/humidifier-card/humidifier-card.ts +++ b/src/cards/humidifier-card/humidifier-card.ts @@ -4,7 +4,6 @@ import { classMap } from "lit/directives/class-map.js"; import { actionHandler, ActionHandlerEvent, - blankBeforePercent, computeRTL, handleAction, hasAction, @@ -111,7 +110,12 @@ export class HumidifierCard let stateDisplay = this.hass.formatEntityState(stateObj); if (this.humidity) { - stateDisplay = `${this.humidity}${blankBeforePercent(this.hass.locale)}%`; + const humidity = this.hass.formatEntityAttributeValue( + stateObj, + "current_humidity", + this.humidity + ); + stateDisplay = humidity; } const rtl = computeRTL(this.hass); diff --git a/src/cards/light-card/light-card.ts b/src/cards/light-card/light-card.ts index bee9469c7..0a0ed1d4e 100644 --- a/src/cards/light-card/light-card.ts +++ b/src/cards/light-card/light-card.ts @@ -12,7 +12,6 @@ import { styleMap } from "lit/directives/style-map.js"; import { actionHandler, ActionHandlerEvent, - blankBeforePercent, computeRTL, handleAction, hasAction, @@ -45,7 +44,6 @@ import "./controls/light-color-control"; import "./controls/light-color-temp-control"; import { LightCardConfig } from "./light-card-config"; import { - getBrightness, getRGBColor, isColorLight, isColorSuperLight, @@ -157,12 +155,12 @@ export class LightCard const stateObj = this._stateObj; if (!stateObj) return; - this.brightness = getBrightness(stateObj); + this.brightness = stateObj.attributes.brightness; } private onCurrentBrightnessChange(e: CustomEvent<{ value?: number }>): void { if (e.detail.value != null) { - this.brightness = e.detail.value; + this.brightness = (e.detail.value * 255) / 100; } } @@ -197,7 +195,12 @@ export class LightCard let stateDisplay = this.hass.formatEntityState(stateObj); if (this.brightness != null) { - stateDisplay = `${this.brightness}${blankBeforePercent(this.hass.locale)}%`; + const brightness = this.hass.formatEntityAttributeValue( + stateObj, + "brightness", + this.brightness + ); + stateDisplay = brightness; } const rtl = computeRTL(this.hass); diff --git a/src/cards/media-player-card/media-player-card.ts b/src/cards/media-player-card/media-player-card.ts index 4c14ba10c..93b8009a5 100644 --- a/src/cards/media-player-card/media-player-card.ts +++ b/src/cards/media-player-card/media-player-card.ts @@ -11,7 +11,6 @@ import { classMap } from "lit/directives/class-map.js"; import { actionHandler, ActionHandlerEvent, - blankBeforePercent, computeRTL, handleAction, hasAction, @@ -45,7 +44,6 @@ import { computeMediaIcon, computeMediaNameDisplay, computeMediaStateDisplay, - getVolumeLevel, } from "./utils"; type MediaPlayerCardControl = "media_control" | "volume_control"; @@ -137,13 +135,12 @@ export class MediaPlayerCard const stateObj = this._stateObj; if (!stateObj) return; - const volume = getVolumeLevel(stateObj); - this.volume = volume != null ? Math.round(volume) : volume; + this.volume = stateObj.attributes.volume_level; } private onCurrentVolumeChange(e: CustomEvent<{ value?: number }>): void { if (e.detail.value != null) { - this.volume = e.detail.value; + this.volume = e.detail.value / 100; } } @@ -173,18 +170,22 @@ export class MediaPlayerCard const icon = computeMediaIcon(this._config, stateObj); const nameDisplay = computeMediaNameDisplay(this._config, stateObj); - const stateDisplay = computeMediaStateDisplay( + const appearance = computeAppearance(this._config); + const picture = computeEntityPicture(stateObj, appearance.icon_type); + let stateDisplay = computeMediaStateDisplay( this._config, stateObj, this.hass ); - const appearance = computeAppearance(this._config); - const picture = computeEntityPicture(stateObj, appearance.icon_type); - const stateValue = - this.volume != null && this._config.show_volume_level - ? `${stateDisplay} - ${this.volume}${blankBeforePercent(this.hass.locale)}%` - : stateDisplay; + if (this.volume != null && this._config.show_volume_level) { + const volume = this.hass.formatEntityAttributeValue( + stateObj, + "volume_level", + this.volume + ); + stateDisplay += ` ⸱ ${volume}`; + } const rtl = computeRTL(this.hass); @@ -216,7 +217,7 @@ export class MediaPlayerCard stateObj, appearance, nameDisplay, - stateValue + stateDisplay )}; ${isControlVisible diff --git a/src/ha/common/translations/blank_before_percent.ts b/src/ha/common/translations/blank_before_percent.ts deleted file mode 100644 index 4c489c96c..000000000 --- a/src/ha/common/translations/blank_before_percent.ts +++ /dev/null @@ -1,18 +0,0 @@ -import { FrontendLocaleData } from "../../data/translation"; - -// Logic based on https://en.wikipedia.org/wiki/Percent_sign#Form_and_spacing -export const blankBeforePercent = ( - localeOptions: FrontendLocaleData -): string => { - switch (localeOptions.language) { - case "cz": - case "de": - case "fi": - case "fr": - case "sk": - case "sv": - return " "; - default: - return ""; - } -}; diff --git a/src/ha/types.ts b/src/ha/types.ts index 1b8282f24..5511dcc0f 100644 --- a/src/ha/types.ts +++ b/src/ha/types.ts @@ -224,7 +224,7 @@ export interface HomeAssistant { formatEntityAttributeValue( stateObj: HassEntity, attribute: string, - value?: string + value?: any ): string; formatEntityAttributeName(stateObj: HassEntity, attribute: string): string; }