home-assistant-javascript-templates 4.0.0 → 5.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +69 -50
- package/dist/esm/index.d.ts +31 -11
- package/dist/esm/index.js +1 -1
- package/dist/index.d.ts +31 -11
- package/dist/index.js +1 -1
- package/package.json +5 -5
package/README.md
CHANGED
|
@@ -34,11 +34,17 @@ pnpm add home-assistant-javascript-templates
|
|
|
34
34
|
```javascript
|
|
35
35
|
const HomeAssistantJavaScriptTemplates = require('home-assistant-javascript-templates');
|
|
36
36
|
|
|
37
|
-
const
|
|
37
|
+
const haJsTemplates = new HomeAssistantJavaScriptTemplates(
|
|
38
38
|
document.querySelector('home-assistant')
|
|
39
39
|
);
|
|
40
40
|
|
|
41
|
-
|
|
41
|
+
haJsTemplates.getRenderer()
|
|
42
|
+
then((renderer) => {
|
|
43
|
+
renderer.renderTemplate('... template string ...');
|
|
44
|
+
renderer.trackTemplate('... template string ...', () => {
|
|
45
|
+
// execute this function every time that en entity used in the template changes
|
|
46
|
+
});
|
|
47
|
+
});
|
|
42
48
|
```
|
|
43
49
|
|
|
44
50
|
#### Usage with ES6 modules
|
|
@@ -46,16 +52,22 @@ renderer.renderTemplate('... template string ...');
|
|
|
46
52
|
```javascript
|
|
47
53
|
import HomeAssistantJavaScriptTemplates from 'home-assistant-javascript-templates';
|
|
48
54
|
|
|
49
|
-
const
|
|
55
|
+
const haJsTemplates = new HomeAssistantJavaScriptTemplates(
|
|
50
56
|
document.querySelector('home-assistant')
|
|
51
57
|
);
|
|
52
58
|
|
|
53
|
-
|
|
59
|
+
haJsTemplates.getRenderer()
|
|
60
|
+
then((renderer) => {
|
|
61
|
+
renderer.renderTemplate('... template string ...');
|
|
62
|
+
renderer.trackTemplate('... template string ...', () => {
|
|
63
|
+
// execute this function every time that en entity used in the template changes
|
|
64
|
+
});
|
|
65
|
+
});
|
|
54
66
|
```
|
|
55
67
|
|
|
56
68
|
## API
|
|
57
69
|
|
|
58
|
-
The package exposes a class that needs to be instantiated and
|
|
70
|
+
The package exposes a class that needs to be instantiated and the resolved promise that returns the `getRenderer` method of this instance is what you need to use in your code to render `JavaScript` templates.
|
|
59
71
|
|
|
60
72
|
### HomeAssistantJavaScriptTemplates class
|
|
61
73
|
|
|
@@ -64,36 +76,31 @@ Main class of the library, it is the `default` export in the package.
|
|
|
64
76
|
```typescript
|
|
65
77
|
new HomeAssistantJavaScriptTemplates(
|
|
66
78
|
ha,
|
|
67
|
-
|
|
68
|
-
trackNonExistent = false
|
|
79
|
+
options
|
|
69
80
|
);
|
|
70
81
|
```
|
|
71
82
|
|
|
72
83
|
| Parameter | Optional | Description |
|
|
73
84
|
| ------------------ | ------------- | -------------------------------------------------- |
|
|
74
85
|
| `ha` | no | An HTML element that has the `hass` object as a property (e.g. the `home-assistant` custom element). |
|
|
75
|
-
| `
|
|
76
|
-
| `trackNonExistent` | yes | Indicates if the library should track those domains and entities that doesn't exist. |
|
|
86
|
+
| `options` | yes | An object containing the configuration options. |
|
|
77
87
|
|
|
78
|
-
|
|
88
|
+
#### Configuration options
|
|
79
89
|
|
|
80
|
-
|
|
90
|
+
| Parameter | Optional | Default | Description |
|
|
91
|
+
| ------------------ | ------------- | ------- | -------------------------------------------------- |
|
|
92
|
+
| `throwErrors` | yes | false | Indicates if the library should throw if the template contains any error. If not, it will log the errors as a warning in the console and return `undefined` instead. |
|
|
93
|
+
| `throwWarnings` | yes | true | Indicates if the library should throw warnings in the console, either when there is an error in the templates and `throwErrors` is configured in `false`, or when a non-existent entity or domain is used in the templates. |
|
|
81
94
|
|
|
82
|
-
|
|
83
|
-
interface Tracked {
|
|
84
|
-
entities: string[];
|
|
85
|
-
domains: string[];
|
|
86
|
-
}
|
|
95
|
+
### Methods
|
|
87
96
|
|
|
88
|
-
|
|
89
|
-
```
|
|
97
|
+
#### getRenderer
|
|
90
98
|
|
|
91
|
-
|
|
99
|
+
Returns a `Promise` than once it resolved returns an instance of the [HomeAssistantJavaScriptTemplatesRenderer](#homeassistantjavascripttemplatesrenderer-class) class.
|
|
92
100
|
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
> 3. The rest of the methods will track only entities.
|
|
101
|
+
### HomeAssistantJavaScriptTemplatesRenderer class
|
|
102
|
+
|
|
103
|
+
This class is only exported as a type in the package, you cannot import it directly. An instance of this class will be returned by the promise that is returned by the [getRenderer method](#getrenderer) of the [HomeAssistantJavaScriptTemplates class](#homeassistantjavascripttemplates-class).
|
|
97
104
|
|
|
98
105
|
### Methods
|
|
99
106
|
|
|
@@ -103,31 +110,28 @@ This property will return an object with two properties (`entities` and `domains
|
|
|
103
110
|
renderTemplate(template: string): any
|
|
104
111
|
```
|
|
105
112
|
|
|
106
|
-
This
|
|
113
|
+
This method renders a `JavaScript` template and return its result. It needs a string as a parameter. Inside this string you can use [several objects and methods](#objects-and-methods-available-in-the-templates). It returns whatever the `JavaScript` code returns, because of that it is typed as `any`.
|
|
107
114
|
|
|
108
|
-
####
|
|
115
|
+
#### trackTemplate
|
|
109
116
|
|
|
110
117
|
```typescript
|
|
111
|
-
|
|
118
|
+
trackTemplate(
|
|
119
|
+
template: string,
|
|
120
|
+
renderingFunction: (result?: any) => void
|
|
121
|
+
): void
|
|
112
122
|
```
|
|
113
123
|
|
|
114
|
-
This method
|
|
115
|
-
|
|
116
|
-
#### cleanTrackedDomains
|
|
124
|
+
This method registers a template tracking. It executes the `renderingFunction` sent to the method with the result of the rendered `template` and will execute `renderingFunction` with an updated result of the rendered `template` every time that the entities used in the template update. You can use [several objects and methods](#objects-and-methods-available-in-the-templates) inside the `template` string.
|
|
117
125
|
|
|
118
|
-
|
|
119
|
-
cleanTrackedDomains(): void
|
|
120
|
-
```
|
|
121
|
-
|
|
122
|
-
This method will clean all the tracked domains until the moment, so after being called, the `tracked` property will return an empty array as `domains`.
|
|
126
|
+
If some entity was not reached in the template code because it was inside a condition that never met, then it will not be tracked, so if its state changes it will not trigger the `renderingFunction`. Only those entities that were called during the rendering using [states](#states), [is_state](#is_state), [state_attr](#state_attr), [is_state_attr](#is_state_attr), [has_value](#has_value) [entities](#entities), [entity_prop](#entity_prop), [is_entity_prop](#is_entity_prop) or [device_id](#device_id) will be included.
|
|
123
127
|
|
|
124
128
|
#### cleanTracked
|
|
125
129
|
|
|
126
130
|
```typescript
|
|
127
|
-
cleanTracked(): void
|
|
131
|
+
cleanTracked(entityId?: string): void
|
|
128
132
|
```
|
|
129
133
|
|
|
130
|
-
This method will clean
|
|
134
|
+
This method will clean the template tracking for a specific entity or will clean all the template trackings if no entity id is specified.
|
|
131
135
|
|
|
132
136
|
### Objects and methods available in the templates
|
|
133
137
|
|
|
@@ -339,7 +343,7 @@ user_agent
|
|
|
339
343
|
```javascript
|
|
340
344
|
import HomeAssistantJavaScriptTemplates from 'home-assistant-javascript-templates';
|
|
341
345
|
|
|
342
|
-
const
|
|
346
|
+
const haJsTemplates = new HomeAssistantJavaScriptTemplates(
|
|
343
347
|
document.querySelector('home-assistant')
|
|
344
348
|
);
|
|
345
349
|
|
|
@@ -349,28 +353,43 @@ const renderer = new HomeAssistantJavaScriptTemplates(
|
|
|
349
353
|
* Return the value of the attribute prefixed with "sn: "
|
|
350
354
|
* It will return something like "sn: 123456"
|
|
351
355
|
*/
|
|
352
|
-
|
|
353
|
-
|
|
354
|
-
|
|
355
|
-
|
|
356
|
-
|
|
356
|
+
haJsTemplates.getRenderer()
|
|
357
|
+
.then((renderer) => {
|
|
358
|
+
const result = renderer.renderTemplate(`
|
|
359
|
+
const deviceId = device_id("binary_sensor.koffiezetapparaat_aan");
|
|
360
|
+
const serialNumber = device_attr(deviceId, "serial_number");
|
|
361
|
+
return "sn:" + serialNumber;
|
|
362
|
+
`);
|
|
363
|
+
console.log(result);
|
|
364
|
+
});
|
|
365
|
+
|
|
357
366
|
```
|
|
358
367
|
|
|
359
|
-
#### Get all the available updates
|
|
368
|
+
#### Get all the available updates and update an HTML element with the result with entity changes
|
|
360
369
|
|
|
361
370
|
```javascript
|
|
362
371
|
import HomeAssistantJavaScriptTemplates from 'home-assistant-javascript-templates';
|
|
363
372
|
|
|
364
|
-
const
|
|
373
|
+
const haJsTemplates = new HomeAssistantJavaScriptTemplates(
|
|
365
374
|
document.querySelector('home-assistant')
|
|
366
375
|
);
|
|
367
376
|
|
|
368
|
-
|
|
369
|
-
|
|
370
|
-
|
|
371
|
-
|
|
372
|
-
|
|
373
|
-
|
|
377
|
+
haJsTemplates.getRenderer()
|
|
378
|
+
.then((renderer) => {
|
|
379
|
+
const element = document.querySelector('#my-element');
|
|
380
|
+
renderer.trackTemplate(
|
|
381
|
+
`
|
|
382
|
+
const udatesEntities = states.update;
|
|
383
|
+
const updateEntitiesValues = Object.values(udatesEntities);
|
|
384
|
+
const updatesEntitiesOn = updateEntitiesValues.filter((entity) => entity.state === 'on');
|
|
385
|
+
return updatesEntitiesOn.length;
|
|
386
|
+
`,
|
|
387
|
+
(result) => {
|
|
388
|
+
element.innerHTML = result;
|
|
389
|
+
}
|
|
390
|
+
);
|
|
391
|
+
});
|
|
392
|
+
|
|
374
393
|
```
|
|
375
394
|
|
|
376
395
|
[Optional chaining operator]: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Operators/Optional_chaining
|
package/dist/esm/index.d.ts
CHANGED
|
@@ -1,3 +1,8 @@
|
|
|
1
|
+
interface Options {
|
|
2
|
+
throwErrors?: boolean;
|
|
3
|
+
throwWarnings?: boolean;
|
|
4
|
+
}
|
|
5
|
+
type RenderingFunction = (result?: any) => void;
|
|
1
6
|
interface Area {
|
|
2
7
|
area_id: string;
|
|
3
8
|
name: string;
|
|
@@ -32,18 +37,33 @@ interface Hass {
|
|
|
32
37
|
interface HomeAssistant extends HTMLElement {
|
|
33
38
|
hass: Hass;
|
|
34
39
|
}
|
|
35
|
-
interface
|
|
36
|
-
|
|
37
|
-
|
|
40
|
+
interface HassConnection {
|
|
41
|
+
conn: {
|
|
42
|
+
subscribeMessage: <T>(callback: (response: T) => void, options: Record<string, unknown>) => void;
|
|
43
|
+
};
|
|
38
44
|
}
|
|
39
|
-
declare
|
|
40
|
-
|
|
45
|
+
declare global {
|
|
46
|
+
interface Window {
|
|
47
|
+
hassConnection: Promise<HassConnection>;
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
declare class HomeAssistantJavaScriptTemplatesRenderer {
|
|
51
|
+
constructor(ha: HomeAssistant, options: Options);
|
|
52
|
+
private _throwErrors;
|
|
53
|
+
private _throwWarnings;
|
|
54
|
+
private _subscriptions;
|
|
41
55
|
private _scopped;
|
|
42
|
-
private
|
|
56
|
+
private _watchForEntitiesChange;
|
|
57
|
+
private _entityWatchCallback;
|
|
58
|
+
private _storeTracked;
|
|
43
59
|
renderTemplate(template: string): any;
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
60
|
+
trackTemplate(template: string, renderingFunction: RenderingFunction): void;
|
|
61
|
+
cleanTracked(entityId?: string): void;
|
|
62
|
+
}
|
|
63
|
+
declare class HomeAssistantJavaScriptTemplates {
|
|
64
|
+
constructor(ha: HomeAssistant, options?: Options);
|
|
65
|
+
private _renderer;
|
|
66
|
+
getRenderer(): Promise<HomeAssistantJavaScriptTemplatesRenderer>;
|
|
48
67
|
}
|
|
49
|
-
export { HomeAssistantJavaScriptTemplates as default
|
|
68
|
+
export { HomeAssistantJavaScriptTemplates as default };
|
|
69
|
+
export type { HomeAssistant, HomeAssistantJavaScriptTemplatesRenderer, HassConnection, Hass };
|
package/dist/esm/index.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
var e,
|
|
1
|
+
var t,e,i="[home-assistant-javascript-templates]",n=/^([a-z_]+)\.(\w+)$/;!function(t){t.UNKNOWN="unknown",t.UNAVAILABLE="unavailable"}(t||(t={})),function(t){t.AREA_ID="area_id",t.NAME="name"}(e||(e={}));var s=function(t){return t.reduce((function(t,e){var i=e[0],s=e[1];return t[i.replace(n,"$2")]=s,t}),{})},r=function(t){return t.includes(".")};function a(n,a){var o=function(){return Object.entries(n.hass.areas)},c=function(){return Object.entries(n.hass.entities)},u=new Set,d=function(t,e){a&&console.warn("".concat(t," ").concat(e," used in a JavaScript template doesn't exist"))},_=function(t){return d("Entity",t)},h=function(t){return d("Domain",t)},p=function(t){n.hass.states[t]?u.add(t):_(t)};return{get hass(){return n.hass},states:new Proxy((function(t){var e;if(r(t))return p(t),null===(e=n.hass.states[t])||void 0===e?void 0:e.state;throw SyntaxError("".concat(i,": states method cannot be used with a domain, use it as an object instead."))}),{get:function(t,e){if(r(e))return p(e),n.hass.states[e];var i=Object.entries(n.hass.states).filter((function(t){return t[0].startsWith(e)}));return i.length||h(e),new Proxy(s(i),{get:function(t,i){return p("".concat(e,".").concat(i)),t[i]}})}}),is_state:function(t,e){var i;return p(t),(null===(i=n.hass.states[t])||void 0===i?void 0:i.state)===e},state_attr:function(t,e){var i,s;return p(t),null===(s=null===(i=n.hass.states[t])||void 0===i?void 0:i.attributes)||void 0===s?void 0:s[e]},is_state_attr:function(t,e,i){return this.state_attr(t,e)===i},has_value:function(e){return this.states(e)?!(this.is_state(e,t.UNKNOWN)||this.is_state(e,t.UNAVAILABLE)):(_(e),!1)},entities:new Proxy((function(t){if(void 0===t)return n.hass.entities;if(r(t))return p(t),n.hass.entities[t];var e=c().filter((function(e){return e[0].startsWith(t)}));return e.length||h(t),new Proxy(s(e),{get:function(e,i){return p("".concat(t,".").concat(i)),e[i]}})}),{get:function(t,e){return t(e)}}),entity_prop:function(t,e){var i;return p(t),null===(i=n.hass.entities[t])||void 0===i?void 0:i[e]},is_entity_prop:function(t,e,i){return this.entity_prop(t,e)===i},devices:new Proxy((function(t){if(void 0===t)return n.hass.devices;if(r(t))throw SyntaxError("".concat(i,": devices method cannot be used with an entity id, you should use a device id instead."));return n.hass.devices[t]}),{get:function(t,e){if(r(e))throw SyntaxError("".concat(i,": devices cannot be accesed using an entity id, you should use a device id instead."));return n.hass.devices[e]}}),device_attr:function(t,e){var i;return null===(i=n.hass.devices[t])||void 0===i?void 0:i[e]},is_device_attr:function(t,e,i){return this.device_attr(t,e)===i},device_id:function(t){var e;return p(t),null===(e=n.hass.entities[t])||void 0===e?void 0:e.device_id},areas:function(){return o().map((function(t){return t[1].area_id}))},area_id:function(t){var i,s;if(t in n.hass.devices)return this.device_attr(t,e.AREA_ID);var r=null===(i=n.hass.entities[t])||void 0===i?void 0:i.device_id;if(r)return this.device_attr(r,e.AREA_ID);var a=o().find((function(e){return e[1].name===t}));return null===(s=null==a?void 0:a[1])||void 0===s?void 0:s.area_id},area_name:function(t){var i,s,r;t in n.hass.devices&&(r=this.device_attr(t,e.AREA_ID));var a=null===(i=n.hass.entities[t])||void 0===i?void 0:i.device_id;a&&(r=this.device_attr(a,e.AREA_ID));var c=o().find((function(e){var i=e[1];return i.area_id===t||i.area_id===r}));return null===(s=null==c?void 0:c[1])||void 0===s?void 0:s.name},area_entities:function(t){var e=o().find((function(e){var i=e[1];return i.area_id===t||i.name===t}));return e?c().filter((function(t){return t[1].area_id===e[1].area_id})).map((function(t){return t[0]})):[]},area_devices:function(t){var e=o().find((function(e){var i=e[1];return i.area_id===t||i.name===t}));return e?Object.entries(n.hass.devices).filter((function(t){return t[1].area_id===e[1].area_id})).map((function(t){return t[1].id})):[]},get user_name(){return n.hass.user.name},get user_is_admin(){return n.hass.user.is_admin},get user_is_owner(){return n.hass.user.is_owner},get user_agent(){return window.navigator.userAgent},get tracked(){return u},cleanTracked:function(){u.clear()}}}var o=function(){function t(t,e){var i=e.throwErrors,n=void 0!==i&&i,s=e.throwWarnings,r=void 0===s||s;this._throwErrors=n,this._throwWarnings=r,this._subscriptions=new Map,this._scopped=a(t,r),this._watchForEntitiesChange()}return t.prototype._watchForEntitiesChange=function(){var t=this;window.hassConnection.then((function(e){e.conn.subscribeMessage((function(e){return t._entityWatchCallback(e)}),{type:"subscribe_events",event_type:"state_changed"})}))},t.prototype._entityWatchCallback=function(t){var e=this;if(this._subscriptions.size){var i=t.data.entity_id;this._subscriptions.has(i)&&this._subscriptions.get(i).forEach((function(t,i){e.trackTemplate(i,t)}))}},t.prototype._storeTracked=function(t,e){var i=this;this._scopped.tracked.forEach((function(n){if(i._subscriptions.has(n)){var s=i._subscriptions.get(n);s.has(t)||s.set(t,e)}else i._subscriptions.set(n,new Map([[t,e]]))}))},t.prototype.renderTemplate=function(t){try{var e=t.includes("return")?t:"return ".concat(t);return new Function("hass","states","is_state","state_attr","is_state_attr","has_value","entities","entity_prop","is_entity_prop","devices","device_attr","is_device_attr","device_id","areas","area_id","area_name","area_entities","area_devices","user_name","user_is_admin","user_is_owner","user_agent","".concat('"use strict";'," ").concat(e))(this._scopped.hass,this._scopped.states,this._scopped.is_state.bind(this._scopped),this._scopped.state_attr.bind(this._scopped),this._scopped.is_state_attr.bind(this._scopped),this._scopped.has_value.bind(this._scopped),this._scopped.entities,this._scopped.entity_prop,this._scopped.is_entity_prop.bind(this._scopped),this._scopped.devices,this._scopped.device_attr.bind(this._scopped),this._scopped.is_device_attr.bind(this._scopped),this._scopped.device_id.bind(this._scopped),this._scopped.areas.bind(this._scopped),this._scopped.area_id.bind(this._scopped),this._scopped.area_name.bind(this._scopped),this._scopped.area_entities.bind(this._scopped),this._scopped.area_devices.bind(this._scopped),this._scopped.user_name,this._scopped.user_is_admin,this._scopped.user_is_owner,this._scopped.user_agent)}catch(t){if(this._throwErrors)throw t;return void(this._throwWarnings&&console.warn(t))}},t.prototype.trackTemplate=function(t,e){this._scopped.cleanTracked();var i=this.renderTemplate(t);this._storeTracked(t,e),e(i)},t.prototype.cleanTracked=function(t){t?this._subscriptions.has(t)&&this._subscriptions.delete(t):this._subscriptions.clear()},t}(),c=function(){function t(t,e){var i,n;void 0===e&&(e={}),this._renderer=(i=function(){return t.hass},n=function(t){return!!(t&&t.areas&&t.devices&&t.entities&&t.states&&t.user)},new Promise((function(t,e){var s=0,r=function(){var a=i();n(a)?t(a):++s<100?setTimeout(r,50):e()};r()}))).then((function(){return new o(t,e)})).catch((function(){throw new Error("The provided element doesn't contain a proper or initialised hass object")}))}return t.prototype.getRenderer=function(){return this._renderer},t}();export{c as default};
|
package/dist/index.d.ts
CHANGED
|
@@ -1,3 +1,8 @@
|
|
|
1
|
+
interface Options {
|
|
2
|
+
throwErrors?: boolean;
|
|
3
|
+
throwWarnings?: boolean;
|
|
4
|
+
}
|
|
5
|
+
type RenderingFunction = (result?: any) => void;
|
|
1
6
|
interface Area {
|
|
2
7
|
area_id: string;
|
|
3
8
|
name: string;
|
|
@@ -32,18 +37,33 @@ interface Hass {
|
|
|
32
37
|
interface HomeAssistant extends HTMLElement {
|
|
33
38
|
hass: Hass;
|
|
34
39
|
}
|
|
35
|
-
interface
|
|
36
|
-
|
|
37
|
-
|
|
40
|
+
interface HassConnection {
|
|
41
|
+
conn: {
|
|
42
|
+
subscribeMessage: <T>(callback: (response: T) => void, options: Record<string, unknown>) => void;
|
|
43
|
+
};
|
|
38
44
|
}
|
|
39
|
-
declare
|
|
40
|
-
|
|
45
|
+
declare global {
|
|
46
|
+
interface Window {
|
|
47
|
+
hassConnection: Promise<HassConnection>;
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
declare class HomeAssistantJavaScriptTemplatesRenderer {
|
|
51
|
+
constructor(ha: HomeAssistant, options: Options);
|
|
52
|
+
private _throwErrors;
|
|
53
|
+
private _throwWarnings;
|
|
54
|
+
private _subscriptions;
|
|
41
55
|
private _scopped;
|
|
42
|
-
private
|
|
56
|
+
private _watchForEntitiesChange;
|
|
57
|
+
private _entityWatchCallback;
|
|
58
|
+
private _storeTracked;
|
|
43
59
|
renderTemplate(template: string): any;
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
60
|
+
trackTemplate(template: string, renderingFunction: RenderingFunction): void;
|
|
61
|
+
cleanTracked(entityId?: string): void;
|
|
62
|
+
}
|
|
63
|
+
declare class HomeAssistantJavaScriptTemplates {
|
|
64
|
+
constructor(ha: HomeAssistant, options?: Options);
|
|
65
|
+
private _renderer;
|
|
66
|
+
getRenderer(): Promise<HomeAssistantJavaScriptTemplatesRenderer>;
|
|
48
67
|
}
|
|
49
|
-
export { HomeAssistantJavaScriptTemplates as default
|
|
68
|
+
export { HomeAssistantJavaScriptTemplates as default };
|
|
69
|
+
export type { HomeAssistant, HomeAssistantJavaScriptTemplatesRenderer, HassConnection, Hass };
|
package/dist/index.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";var e,
|
|
1
|
+
"use strict";var t,e,i="[home-assistant-javascript-templates]",n=/^([a-z_]+)\.(\w+)$/;!function(t){t.UNKNOWN="unknown",t.UNAVAILABLE="unavailable"}(t||(t={})),function(t){t.AREA_ID="area_id",t.NAME="name"}(e||(e={}));var s=function(t){return t.reduce((function(t,e){var i=e[0],s=e[1];return t[i.replace(n,"$2")]=s,t}),{})},r=function(t){return t.includes(".")};function a(n,a){var o=function(){return Object.entries(n.hass.areas)},c=function(){return Object.entries(n.hass.entities)},u=new Set,d=function(t,e){a&&console.warn("".concat(t," ").concat(e," used in a JavaScript template doesn't exist"))},_=function(t){return d("Entity",t)},h=function(t){return d("Domain",t)},p=function(t){n.hass.states[t]?u.add(t):_(t)};return{get hass(){return n.hass},states:new Proxy((function(t){var e;if(r(t))return p(t),null===(e=n.hass.states[t])||void 0===e?void 0:e.state;throw SyntaxError("".concat(i,": states method cannot be used with a domain, use it as an object instead."))}),{get:function(t,e){if(r(e))return p(e),n.hass.states[e];var i=Object.entries(n.hass.states).filter((function(t){return t[0].startsWith(e)}));return i.length||h(e),new Proxy(s(i),{get:function(t,i){return p("".concat(e,".").concat(i)),t[i]}})}}),is_state:function(t,e){var i;return p(t),(null===(i=n.hass.states[t])||void 0===i?void 0:i.state)===e},state_attr:function(t,e){var i,s;return p(t),null===(s=null===(i=n.hass.states[t])||void 0===i?void 0:i.attributes)||void 0===s?void 0:s[e]},is_state_attr:function(t,e,i){return this.state_attr(t,e)===i},has_value:function(e){return this.states(e)?!(this.is_state(e,t.UNKNOWN)||this.is_state(e,t.UNAVAILABLE)):(_(e),!1)},entities:new Proxy((function(t){if(void 0===t)return n.hass.entities;if(r(t))return p(t),n.hass.entities[t];var e=c().filter((function(e){return e[0].startsWith(t)}));return e.length||h(t),new Proxy(s(e),{get:function(e,i){return p("".concat(t,".").concat(i)),e[i]}})}),{get:function(t,e){return t(e)}}),entity_prop:function(t,e){var i;return p(t),null===(i=n.hass.entities[t])||void 0===i?void 0:i[e]},is_entity_prop:function(t,e,i){return this.entity_prop(t,e)===i},devices:new Proxy((function(t){if(void 0===t)return n.hass.devices;if(r(t))throw SyntaxError("".concat(i,": devices method cannot be used with an entity id, you should use a device id instead."));return n.hass.devices[t]}),{get:function(t,e){if(r(e))throw SyntaxError("".concat(i,": devices cannot be accesed using an entity id, you should use a device id instead."));return n.hass.devices[e]}}),device_attr:function(t,e){var i;return null===(i=n.hass.devices[t])||void 0===i?void 0:i[e]},is_device_attr:function(t,e,i){return this.device_attr(t,e)===i},device_id:function(t){var e;return p(t),null===(e=n.hass.entities[t])||void 0===e?void 0:e.device_id},areas:function(){return o().map((function(t){return t[1].area_id}))},area_id:function(t){var i,s;if(t in n.hass.devices)return this.device_attr(t,e.AREA_ID);var r=null===(i=n.hass.entities[t])||void 0===i?void 0:i.device_id;if(r)return this.device_attr(r,e.AREA_ID);var a=o().find((function(e){return e[1].name===t}));return null===(s=null==a?void 0:a[1])||void 0===s?void 0:s.area_id},area_name:function(t){var i,s,r;t in n.hass.devices&&(r=this.device_attr(t,e.AREA_ID));var a=null===(i=n.hass.entities[t])||void 0===i?void 0:i.device_id;a&&(r=this.device_attr(a,e.AREA_ID));var c=o().find((function(e){var i=e[1];return i.area_id===t||i.area_id===r}));return null===(s=null==c?void 0:c[1])||void 0===s?void 0:s.name},area_entities:function(t){var e=o().find((function(e){var i=e[1];return i.area_id===t||i.name===t}));return e?c().filter((function(t){return t[1].area_id===e[1].area_id})).map((function(t){return t[0]})):[]},area_devices:function(t){var e=o().find((function(e){var i=e[1];return i.area_id===t||i.name===t}));return e?Object.entries(n.hass.devices).filter((function(t){return t[1].area_id===e[1].area_id})).map((function(t){return t[1].id})):[]},get user_name(){return n.hass.user.name},get user_is_admin(){return n.hass.user.is_admin},get user_is_owner(){return n.hass.user.is_owner},get user_agent(){return window.navigator.userAgent},get tracked(){return u},cleanTracked:function(){u.clear()}}}var o=function(){function t(t,e){var i=e.throwErrors,n=void 0!==i&&i,s=e.throwWarnings,r=void 0===s||s;this._throwErrors=n,this._throwWarnings=r,this._subscriptions=new Map,this._scopped=a(t,r),this._watchForEntitiesChange()}return t.prototype._watchForEntitiesChange=function(){var t=this;window.hassConnection.then((function(e){e.conn.subscribeMessage((function(e){return t._entityWatchCallback(e)}),{type:"subscribe_events",event_type:"state_changed"})}))},t.prototype._entityWatchCallback=function(t){var e=this;if(this._subscriptions.size){var i=t.data.entity_id;this._subscriptions.has(i)&&this._subscriptions.get(i).forEach((function(t,i){e.trackTemplate(i,t)}))}},t.prototype._storeTracked=function(t,e){var i=this;this._scopped.tracked.forEach((function(n){if(i._subscriptions.has(n)){var s=i._subscriptions.get(n);s.has(t)||s.set(t,e)}else i._subscriptions.set(n,new Map([[t,e]]))}))},t.prototype.renderTemplate=function(t){try{var e=t.includes("return")?t:"return ".concat(t);return new Function("hass","states","is_state","state_attr","is_state_attr","has_value","entities","entity_prop","is_entity_prop","devices","device_attr","is_device_attr","device_id","areas","area_id","area_name","area_entities","area_devices","user_name","user_is_admin","user_is_owner","user_agent","".concat('"use strict";'," ").concat(e))(this._scopped.hass,this._scopped.states,this._scopped.is_state.bind(this._scopped),this._scopped.state_attr.bind(this._scopped),this._scopped.is_state_attr.bind(this._scopped),this._scopped.has_value.bind(this._scopped),this._scopped.entities,this._scopped.entity_prop,this._scopped.is_entity_prop.bind(this._scopped),this._scopped.devices,this._scopped.device_attr.bind(this._scopped),this._scopped.is_device_attr.bind(this._scopped),this._scopped.device_id.bind(this._scopped),this._scopped.areas.bind(this._scopped),this._scopped.area_id.bind(this._scopped),this._scopped.area_name.bind(this._scopped),this._scopped.area_entities.bind(this._scopped),this._scopped.area_devices.bind(this._scopped),this._scopped.user_name,this._scopped.user_is_admin,this._scopped.user_is_owner,this._scopped.user_agent)}catch(t){if(this._throwErrors)throw t;return void(this._throwWarnings&&console.warn(t))}},t.prototype.trackTemplate=function(t,e){this._scopped.cleanTracked();var i=this.renderTemplate(t);this._storeTracked(t,e),e(i)},t.prototype.cleanTracked=function(t){t?this._subscriptions.has(t)&&this._subscriptions.delete(t):this._subscriptions.clear()},t}(),c=function(){function t(t,e){var i,n;void 0===e&&(e={}),this._renderer=(i=function(){return t.hass},n=function(t){return!!(t&&t.areas&&t.devices&&t.entities&&t.states&&t.user)},new Promise((function(t,e){var s=0,r=function(){var a=i();n(a)?t(a):++s<100?setTimeout(r,50):e()};r()}))).then((function(){return new o(t,e)})).catch((function(){throw new Error("The provided element doesn't contain a proper or initialised hass object")}))}return t.prototype.getRenderer=function(){return this._renderer},t}();module.exports=c;
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "home-assistant-javascript-templates",
|
|
3
|
-
"version": "
|
|
3
|
+
"version": "5.0.0",
|
|
4
4
|
"description": "A JavaScript utility to render Home Assistant JavaScript templates",
|
|
5
5
|
"keywords": [
|
|
6
6
|
"home-assistant",
|
|
@@ -46,14 +46,14 @@
|
|
|
46
46
|
},
|
|
47
47
|
"devDependencies": {
|
|
48
48
|
"@rollup/plugin-terser": "^0.4.4",
|
|
49
|
-
"@types/jest": "^29.5.
|
|
50
|
-
"@types/node": "^22.5.
|
|
49
|
+
"@types/jest": "^29.5.13",
|
|
50
|
+
"@types/node": "^22.5.5",
|
|
51
51
|
"jest": "^29.7.0",
|
|
52
52
|
"jest-environment-jsdom": "^29.7.0",
|
|
53
|
-
"rollup": "^4.21.
|
|
53
|
+
"rollup": "^4.21.3",
|
|
54
54
|
"rollup-plugin-ts": "^3.4.5",
|
|
55
55
|
"ts-jest": "^29.2.5",
|
|
56
56
|
"tslib": "^2.7.0",
|
|
57
|
-
"typescript": "^5.
|
|
57
|
+
"typescript": "^5.6.2"
|
|
58
58
|
}
|
|
59
59
|
}
|