@larva.io/webcomponents
Version:
Fentrica SmartUnits WebComponents package
176 lines (171 loc) • 6.65 kB
JavaScript
/*!
* (C) Fentrica http://fentrica.com - Seee LICENSE.md
*/
import { p as proxyCustomElement, H, c as createEvent, h } from './p-AOwgnAK2.js';
import { d as defineCustomElement$8 } from './p-B7x5gzZv.js';
import { d as defineCustomElement$7 } from './p-C9VBtzS4.js';
import { d as defineCustomElement$6 } from './p-9A4J2Z7t.js';
import { d as defineCustomElement$5 } from './p-Dsy6MkCW.js';
import { d as defineCustomElement$4 } from './p-CNwVOfNs.js';
import { d as defineCustomElement$3 } from './p-Bk24sn12.js';
import { d as defineCustomElement$2 } from './p-B-fmI6sr.js';
const innerRangeAreaCss = "slot-fb[hidden],slot[hidden]{display:initial !important}";
const InnerRangeArea = /*@__PURE__*/ proxyCustomElement(class InnerRangeArea extends H {
constructor(registerHost) {
super();
if (registerHost !== false) {
this.__registerHost();
}
this.__attachShadow();
this.output = createEvent(this, "output");
this.request = createEvent(this, "request");
/////// LarvaNode base properties
/**
* Component main icon
*/
this.icon = 'security';
/**
* The color to use from your application's color palette.
* Detrouble options are: `"primary"`, `"secondary"`, `"tertiary"`, `"success"`, `"warning"`, `"danger"`, `"light"`, `"medium"`, and `"dark"`.
*/
this.color = 'primary';
/**
* Allow node indication color automatic change based on feedback/node value. Defaults to false
*/
this.allowIndicationAutoColoring = false;
/**
* Allow node color automatic change based on feedback/node value. Defaults to true
*/
this.allowNodeAutoColoring = true;
/**
* Is logging for this component enabled (lar-log subcomponent loaded)
*/
this.log = false;
/**
* Node size
*/
this.nodeSize = 'default';
/////// LarvaNode base properties and events - end
this.armed = false;
this.alarm = false;
this.loading = true;
}
/**
* Larva error input
*/
async error(data) {
if (this.node) {
this.node.error(data);
}
this.loading = false;
}
/**
* Larva input message
*/
async input(data) {
if (data && data.State) {
this.armed = data.State === 'Armed';
this.loading = false;
}
}
componentDidLoad() {
const el = this.el.shadowRoot || this.el;
this.node = el.querySelector('lar-node');
this.loading = true;
this.output.emit();
}
armDisarm() {
if (this.loading === false) {
this.loading = true;
return this.output.emit({ command: this.armed ? 'disarm' : 'arm' });
}
}
render() {
const iconSmall = this.armed ? 'lock' : 'unlock';
const componentProps = {
onClick: () => this.armDisarm(),
value: this.armed ? 'area.arm' : 'area.disarm',
icon: iconSmall,
disabled: this.loading,
color: this.colorInputs || this.color
};
return [
h("lar-node", { key: '68c1426d8546c37dda212da711fe4525aa8e75f6', value: this.armed ? 'area.armed' : 'area.disarmed', hideTitles: this.hideTitles, iconSmall: iconSmall, icon: this.icon, colorIconSmall: this.alarm && this.allowIndicationAutoColoring === true ? 'danger' : this.colorIconSmall, color: this.alarm && this.allowNodeAutoColoring === true ? 'danger' : this.color, supTitle: this.supTitle, mainTitle: this.mainTitle, subTitle: this.subTitle, colorModal: this.alarm && this.allowNodeAutoColoring === true ? 'danger' : this.colorModal, colorInputs: this.colorInputs, log: this.log, loading: this.loading, nodeSize: this.nodeSize, component: "lar-inner-range-area-door-content", componentProps: componentProps }, h("slot", { key: '943acad917c59f853434db7b8aaa89dcaddc4949' }))
];
}
get el() { return this; }
static get style() { return innerRangeAreaCss; }
}, [257, "lar-inner-range-area", {
"icon": [1025],
"color": [1025],
"colorModal": [1025, "color-modal"],
"colorInputs": [1025, "color-inputs"],
"colorIconSmall": [1, "color-icon-small"],
"allowIndicationAutoColoring": [4, "allow-indication-auto-coloring"],
"allowNodeAutoColoring": [4, "allow-node-auto-coloring"],
"hideTitles": [4, "hide-titles"],
"supTitle": [1, "sup-title"],
"subTitle": [1, "sub-title"],
"log": [4],
"mainTitle": [1, "main-title"],
"nodeSize": [1, "node-size"],
"armed": [32],
"alarm": [32],
"loading": [32],
"error": [64],
"input": [64]
}]);
function defineCustomElement$1() {
if (typeof customElements === "undefined") {
return;
}
const components = ["lar-inner-range-area", "lar-backdrop", "lar-icon", "lar-modal", "lar-node", "lar-node-titles", "lar-notify", "lar-translate"];
components.forEach(tagName => { switch (tagName) {
case "lar-inner-range-area":
if (!customElements.get(tagName)) {
customElements.define(tagName, InnerRangeArea);
}
break;
case "lar-backdrop":
if (!customElements.get(tagName)) {
defineCustomElement$8();
}
break;
case "lar-icon":
if (!customElements.get(tagName)) {
defineCustomElement$7();
}
break;
case "lar-modal":
if (!customElements.get(tagName)) {
defineCustomElement$6();
}
break;
case "lar-node":
if (!customElements.get(tagName)) {
defineCustomElement$5();
}
break;
case "lar-node-titles":
if (!customElements.get(tagName)) {
defineCustomElement$4();
}
break;
case "lar-notify":
if (!customElements.get(tagName)) {
defineCustomElement$3();
}
break;
case "lar-translate":
if (!customElements.get(tagName)) {
defineCustomElement$2();
}
break;
} });
}
defineCustomElement$1();
const LarInnerRangeArea = InnerRangeArea;
const defineCustomElement = defineCustomElement$1;
export { LarInnerRangeArea, defineCustomElement };
//# sourceMappingURL=lar-inner-range-area.js.map
//# sourceMappingURL=lar-inner-range-area.js.map