mirror of
https://github.com/home-assistant/frontend.git
synced 2025-07-25 18:26:35 +00:00
Format number attribute for media player (#18949)
This commit is contained in:
parent
80edeebab9
commit
b855b3e103
@ -1,5 +1,6 @@
|
|||||||
import { HassConfig, HassEntity } from "home-assistant-js-websocket";
|
import { HassConfig, HassEntity } from "home-assistant-js-websocket";
|
||||||
import {
|
import {
|
||||||
|
DOMAIN_ATTRIBUTES_FORMATERS,
|
||||||
DOMAIN_ATTRIBUTES_UNITS,
|
DOMAIN_ATTRIBUTES_UNITS,
|
||||||
TEMPERATURE_ATTRIBUTES,
|
TEMPERATURE_ATTRIBUTES,
|
||||||
} from "../../data/entity_attributes";
|
} from "../../data/entity_attributes";
|
||||||
@ -14,11 +15,10 @@ import { formatNumber } from "../number/format_number";
|
|||||||
import { capitalizeFirstLetter } from "../string/capitalize-first-letter";
|
import { capitalizeFirstLetter } from "../string/capitalize-first-letter";
|
||||||
import { isDate } from "../string/is_date";
|
import { isDate } from "../string/is_date";
|
||||||
import { isTimestamp } from "../string/is_timestamp";
|
import { isTimestamp } from "../string/is_timestamp";
|
||||||
import { blankBeforePercent } from "../translations/blank_before_percent";
|
import { blankBeforeUnit } from "../translations/blank_before_unit";
|
||||||
import { LocalizeFunc } from "../translations/localize";
|
import { LocalizeFunc } from "../translations/localize";
|
||||||
import { computeDomain } from "./compute_domain";
|
import { computeDomain } from "./compute_domain";
|
||||||
import { computeStateDomain } from "./compute_state_domain";
|
import { computeStateDomain } from "./compute_state_domain";
|
||||||
import { blankBeforeUnit } from "../translations/blank_before_unit";
|
|
||||||
|
|
||||||
export const computeAttributeValueDisplay = (
|
export const computeAttributeValueDisplay = (
|
||||||
localize: LocalizeFunc,
|
localize: LocalizeFunc,
|
||||||
@ -39,19 +39,18 @@ export const computeAttributeValueDisplay = (
|
|||||||
|
|
||||||
// Number value, return formatted number
|
// Number value, return formatted number
|
||||||
if (typeof attributeValue === "number") {
|
if (typeof attributeValue === "number") {
|
||||||
const formattedValue = formatNumber(attributeValue, locale);
|
|
||||||
|
|
||||||
const domain = computeStateDomain(stateObj);
|
const domain = computeStateDomain(stateObj);
|
||||||
|
|
||||||
|
const formatter = DOMAIN_ATTRIBUTES_FORMATERS[domain]?.[attribute];
|
||||||
|
|
||||||
|
const formattedValue = formatter
|
||||||
|
? formatter(attributeValue, locale)
|
||||||
|
: formatNumber(attributeValue, locale);
|
||||||
|
|
||||||
let unit = DOMAIN_ATTRIBUTES_UNITS[domain]?.[attribute] as
|
let unit = DOMAIN_ATTRIBUTES_UNITS[domain]?.[attribute] as
|
||||||
| string
|
| string
|
||||||
| undefined;
|
| undefined;
|
||||||
|
|
||||||
if (domain === "light" && attribute === "brightness") {
|
|
||||||
const percentage = Math.round((attributeValue / 255) * 100);
|
|
||||||
return `${percentage}${blankBeforePercent(locale)}%`;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (domain === "weather") {
|
if (domain === "weather") {
|
||||||
unit = getWeatherUnit(config, stateObj as WeatherEntity, attribute);
|
unit = getWeatherUnit(config, stateObj as WeatherEntity, attribute);
|
||||||
}
|
}
|
||||||
|
@ -1,3 +1,6 @@
|
|||||||
|
import { formatDuration } from "../common/datetime/duration";
|
||||||
|
import { FrontendLocaleData } from "./translation";
|
||||||
|
|
||||||
export const STATE_ATTRIBUTES = [
|
export const STATE_ATTRIBUTES = [
|
||||||
"entity_id",
|
"entity_id",
|
||||||
"assumed_state",
|
"assumed_state",
|
||||||
@ -64,6 +67,7 @@ export const DOMAIN_ATTRIBUTES_UNITS = {
|
|||||||
color_temp_kelvin: "K",
|
color_temp_kelvin: "K",
|
||||||
min_color_temp_kelvin: "K",
|
min_color_temp_kelvin: "K",
|
||||||
max_color_temp_kelvin: "K",
|
max_color_temp_kelvin: "K",
|
||||||
|
brightness: "%",
|
||||||
},
|
},
|
||||||
sun: {
|
sun: {
|
||||||
elevation: "°",
|
elevation: "°",
|
||||||
@ -74,4 +78,22 @@ export const DOMAIN_ATTRIBUTES_UNITS = {
|
|||||||
sensor: {
|
sensor: {
|
||||||
battery_level: "%",
|
battery_level: "%",
|
||||||
},
|
},
|
||||||
|
media_player: {
|
||||||
|
volume_level: "%",
|
||||||
|
},
|
||||||
} as const satisfies Record<string, Record<string, string>>;
|
} as const satisfies Record<string, Record<string, string>>;
|
||||||
|
|
||||||
|
type Formatter = (value: number, locale: FrontendLocaleData) => string;
|
||||||
|
|
||||||
|
export const DOMAIN_ATTRIBUTES_FORMATERS: Record<
|
||||||
|
string,
|
||||||
|
Record<string, Formatter>
|
||||||
|
> = {
|
||||||
|
light: {
|
||||||
|
brightness: (value) => Math.round((value / 255) * 100).toString(),
|
||||||
|
},
|
||||||
|
media_player: {
|
||||||
|
volume_level: (value) => Math.round(value * 100).toString(),
|
||||||
|
media_duration: (value) => formatDuration(value.toString(), "s"),
|
||||||
|
},
|
||||||
|
};
|
||||||
|
Loading…
x
Reference in New Issue
Block a user