Skip to content

Commit

Permalink
feat(helpers)!: all template functions are now available through the …
Browse files Browse the repository at this point in the history
…`helpers` object

BREAKING CHANGE: If you were using any of the beta before `4.0.0-dev14`. Please replace all the calls to helper functions with `helpers.xxx` for eg. `helpers.relativeTime(entity.state)` or `helpers.localize(entity)`
  • Loading branch information
RomRider committed Jul 26, 2023
1 parent f192ded commit f22ed69
Show file tree
Hide file tree
Showing 2 changed files with 34 additions and 39 deletions.
19 changes: 10 additions & 9 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -334,15 +334,16 @@ Inside the javascript code, you'll have access to those variables:
- `user`: The user object (equivalent to `hass.user`)
- `hass`: The complete `hass` object
- `variables`: an object containing all your variables defined in the configuration. See [Variables](#variables)
- `localize(entity, state?, numeric_precision?, show_units?, units?)`: a function which localizes a state (eg. `localize(entity)`) and returns a string. Takes an entity object as argument (not the state of the entity as we need context) and takes optional arguments.
- If `state` is not provided, it localizes the state of the `entity` (Eg. `localize(entity)` or `localize(states['weather.your_city'])`).
- If `state` is provided, it localizes `state` in the context of the `entity` (eg. : `localize(entity, entity.attributes.forecast[0].condition)` or `localize(states['weather.your_city'], states['weather.your_city'].attributes.forecast[0].condition)`)
- `numeric_precision` (number or `'card'`. Default is `undefined`): For state which are numbers, force the precision instead of letting HA decide for you. If the value is set to `'card'`, it will use the `numeric_precision` from the main config. If `undefined`, it will use the default value for the entity you're willing to display. The latter is the default.
- `show_units` (boolean. Default is `true`): Will display units or not. Default is to display them.
- `units` (string): Will force the units to be the value of that parameter.
- To skip one or multiple parameter while calling the function, use `undefined`. Eg. `localize(states['sensor.temperature'], undefined, 1, undefined, 'Celcius')`
- `formatDateTime(date)`, `formatShortDateTimeWithYear(date)`, `formatShortDateTime(date)`, `formatDateTimeWithSeconds(date)`, `formatDateTimeNumeric(date)`: Some helper functions to format a date time string or Date object. Name are pretty explicit. Example: `return formatDateTime(entity.attribute.last_changed)`
- `relativeTime(date)`: Returns an lit-html template which will render a relative time and update automatically. `date` should be a string. Usage for eg.: `return relativeTime(entity.last_changed)`
- Helper functions availble through the object `helpers`:
- `helpers.localize(entity, state?, numeric_precision?, show_units?, units?)`: a function which localizes a state (eg. `helpers.localize(entity)`) and returns a string. Takes an entity object as argument (not the state of the entity as we need context) and takes optional arguments.
- If `state` is not provided, it localizes the state of the `entity` (Eg. `helpers.localize(entity)` or `helpers.localize(states['weather.your_city'])`).
- If `state` is provided, it localizes `state` in the context of the `entity` (eg. : `helpers.localize(entity, entity.attributes.forecast[0].condition)` or `helpers.localize(states['weather.your_city'], states['weather.your_city'].attributes.forecast[0].condition)`)
- `numeric_precision` (number or `'card'`. Default is `undefined`): For state which are numbers, force the precision instead of letting HA decide for you. If the value is set to `'card'`, it will use the `numeric_precision` from the main config. If `undefined`, it will use the default value for the entity you're willing to display. The latter is the default.
- `show_units` (boolean. Default is `true`): Will display units or not. Default is to display them.
- `units` (string): Will force the units to be the value of that parameter.
- To skip one or multiple parameter while calling the function, use `undefined`. Eg. `helpers.localize(states['sensor.temperature'], undefined, 1, undefined, 'Celcius')`
- `helpers.formatDateTime(date)`, `helpers.formatShortDateTimeWithYear(date)`, `helpers.formatShortDateTime(date)`, `helpers.formatDateTimeWithSeconds(date)`, `helpers.formatDateTimeNumeric(date)`: Some helper functions to format a date time string or Date object. Name are pretty explicit. Example: `return helpers.formatDateTime(entity.attribute.last_changed)`
- `helpers.relativeTime(date)`: Returns an lit-html template which will render a relative time and update automatically. `date` should be a string. Usage for eg.: `return helpers.relativeTime(entity.last_changed)`

See [here](#templates-support) for some examples or [here](#custom-fields) for some crazy advanced stuff using templates!

Expand Down
54 changes: 24 additions & 30 deletions src/button-card.ts
Original file line number Diff line number Diff line change
Expand Up @@ -318,22 +318,6 @@ class ButtonCard extends LitElement {
);
}

private _formatDateTime(date: string | Date): string {
return formatDateTime(new Date(date), this._hass!.locale, this._hass!.config);
}
private _formatShortDateTimeWithYear(date: string | Date): string {
return formatShortDateTimeWithYear(new Date(date), this._hass!.locale, this._hass!.config);
}
private _formatShortDateTime(date: string | Date): string {
return formatShortDateTime(new Date(date), this._hass!.locale, this._hass!.config);
}
private _formatDateTimeWithSeconds(date: string | Date): string {
return formatDateTimeWithSeconds(new Date(date), this._hass!.locale, this._hass!.config);
}
private _formatDateTimeNumeric(date: string | Date): string {
return formatDateTimeNumeric(new Date(date), this._hass!.locale, this._hass!.config);
}

private _relativeTime(date: string | undefined) {
if (date) {
return html`
Expand All @@ -348,6 +332,28 @@ class ButtonCard extends LitElement {
return '';
}

private _getHelpers() {
return {
localize: this._localize.bind(this),
formatDateTime: (date) => {
return formatDateTime(new Date(date), this._hass!.locale, this._hass!.config);
},
formatShortDateTimeWithYear: (date) => {
return formatShortDateTimeWithYear(new Date(date), this._hass!.locale, this._hass!.config);
},
formatShortDateTime: (date) => {
return formatShortDateTime(new Date(date), this._hass!.locale, this._hass!.config);
},
formatDateTimeWithSeconds: (date) => {
return formatDateTimeWithSeconds(new Date(date), this._hass!.locale, this._hass!.config);
},
formatDateTimeNumeric: (date) => {
return formatDateTimeNumeric(new Date(date), this._hass!.locale, this._hass!.config);
},
relativeTime: this._relativeTime.bind(this),
};
}

private _evalTemplate(state: HassEntity | undefined, func: any): any {
/* eslint no-new-func: 0 */
try {
Expand All @@ -358,13 +364,7 @@ class ButtonCard extends LitElement {
'hass',
'variables',
'html',
`localize`,
`formatDateTime`,
`formatShortDateTimeWithYear`,
`formatShortDateTime`,
`formatDateTimeWithSeconds`,
`formatDateTimeNumeric`,
`relativeTime`,
`helpers`,
`'use strict'; ${func}`,
).call(
this,
Expand All @@ -374,13 +374,7 @@ class ButtonCard extends LitElement {
this._hass,
this._evaledVariables,
html,
this._localize.bind(this),
this._formatDateTime.bind(this),
this._formatShortDateTimeWithYear.bind(this),
this._formatShortDateTime.bind(this),
this._formatDateTimeWithSeconds.bind(this),
this._formatDateTimeNumeric.bind(this),
this._relativeTime.bind(this),
this._getHelpers(),
);
} catch (e: any) {
const funcTrimmed = func.length <= 100 ? func.trim() : `${func.trim().substring(0, 98)}...`;
Expand Down

0 comments on commit f22ed69

Please sign in to comment.