@iotize/ionic
Version:
Iotize specific building blocks on top of @ionic/angular.
111 lines • 15 kB
JavaScript
import { __decorate, __metadata } from "tslib";
import { ChangeDetectorRef, Component, Input, ViewChild, } from '@angular/core';
import { IonToggle } from '@ionic/angular';
import { TapValueEditorContainerComponent } from '@iotize/ionic';
import { map } from 'rxjs/operators';
import { MonitoringAppGenComponent, } from '../../metadata/decorators';
import * as i0 from "@angular/core";
import * as i1 from "@ionic/angular";
import * as i2 from "@iotize/ionic";
import * as i3 from "@angular/common";
let TapVariableToggleComponent = class TapVariableToggleComponent {
constructor(changeDetectorRef) {
this.changeDetectorRef = changeDetectorRef;
this.textOnLeft = 'Off';
this.textOnRight = 'On';
this.lines = 'none';
this.toggleColor = 'primary';
this.editable = false;
this.valueOn = 1;
this.valueOff = 0;
this.chip = {
outline: false,
color: '',
};
this.chipOutline = false;
this.inputOptions = {
type: 'toggle',
};
}
ngAfterViewInit() {
this._valueSub = this.ctx?.valueToDisplay
.pipe(map((value) => {
if (value === this.valueOn) {
value = true;
}
else if (value === this.valueOff) {
value = false;
}
value = !!value;
return value;
}))
.subscribe((value) => {
this._lastValueDisplayed = value;
if (this.ctx.pendingSubmitValue === undefined) {
this.toggle.checked = value;
this.changeDetectorRef.detectChanges();
}
});
}
ngOnDestroy() {
this._valueSub?.unsubscribe();
}
switchToggle() {
if (!this.toggle.disabled) {
this.toggle.checked = !this.toggle.checked;
}
}
onValueChange(event) {
if (this._lastValueDisplayed !== event.detail.checked) {
const value = event.detail.checked ? this.valueOn : this.valueOff;
this.ctx?.notifyValueChange(value);
}
}
};
/** @nocollapse */ TapVariableToggleComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TapVariableToggleComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
/** @nocollapse */ TapVariableToggleComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: TapVariableToggleComponent, selector: "tap-variable-toggle", inputs: { textOnLeft: "textOnLeft", textOnRight: "textOnRight", lines: "lines", toggleColor: "toggleColor", variable: "variable", editable: "editable", valueOn: "valueOn", valueOff: "valueOff", chip: "chip" }, viewQueries: [{ propertyName: "toggle", first: true, predicate: ["toggle"], descendants: true }, { propertyName: "ctx", first: true, predicate: ["ctx"], descendants: true }], ngImport: i0, template: "<tap-value-editor-container #ctx [variable]=\"variable\" [lines]=\"lines\">\n <ion-chip\n [color]=\"chip?.color\"\n [outline]=\"chip?.outline\"\n (click)=\"switchToggle()\"\n [disabled]=\"!editable || (ctx.loadingChange | async)\"\n >\n <span class=\"spanToggle\"> {{ textOnLeft }} </span>\n <ion-toggle\n [color]=\"toggleColor\"\n #toggle\n [disabled]=\"!editable || (ctx.loadingChange | async)\"\n style=\"pointer-events: none\"\n (ionChange)=\"onValueChange($event)\"\n ></ion-toggle>\n <span class=\"spanToggle\"> {{ textOnRight }} </span>\n </ion-chip>\n</tap-value-editor-container>\n", styles: [".toggle-icon{font-size:5em}\n"], dependencies: [{ kind: "component", type: i1.IonChip, selector: "ion-chip", inputs: ["color", "disabled", "mode", "outline"] }, { kind: "component", type: i1.IonToggle, selector: "ion-toggle", inputs: ["checked", "color", "disabled", "enableOnOffLabels", "mode", "name", "value"] }, { kind: "directive", type: i1.BooleanValueAccessor, selector: "ion-checkbox,ion-toggle" }, { kind: "component", type: i2.TapValueEditorContainerComponent, selector: "tap-value-editor-container", inputs: ["button", "variable", "inputOptions", "showRefreshButton", "showSubmitButton", "showEditButton", "error", "lines", "modalEdition", "value"], outputs: ["submit", "refresh"] }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }] });
TapVariableToggleComponent = __decorate([
MonitoringAppGenComponent({
constraints: {
isArray: 'NO',
isNumber: 'YES',
},
events: [
{
name: 'submit',
dataType: 'boolean',
},
],
}),
__metadata("design:paramtypes", [ChangeDetectorRef])
], TapVariableToggleComponent);
export { TapVariableToggleComponent };
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TapVariableToggleComponent, decorators: [{
type: Component,
args: [{ selector: 'tap-variable-toggle', template: "<tap-value-editor-container #ctx [variable]=\"variable\" [lines]=\"lines\">\n <ion-chip\n [color]=\"chip?.color\"\n [outline]=\"chip?.outline\"\n (click)=\"switchToggle()\"\n [disabled]=\"!editable || (ctx.loadingChange | async)\"\n >\n <span class=\"spanToggle\"> {{ textOnLeft }} </span>\n <ion-toggle\n [color]=\"toggleColor\"\n #toggle\n [disabled]=\"!editable || (ctx.loadingChange | async)\"\n style=\"pointer-events: none\"\n (ionChange)=\"onValueChange($event)\"\n ></ion-toggle>\n <span class=\"spanToggle\"> {{ textOnRight }} </span>\n </ion-chip>\n</tap-value-editor-container>\n", styles: [".toggle-icon{font-size:5em}\n"] }]
}], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }]; }, propDecorators: { toggle: [{
type: ViewChild,
args: ['toggle']
}], ctx: [{
type: ViewChild,
args: ['ctx']
}], textOnLeft: [{
type: Input
}], textOnRight: [{
type: Input
}], lines: [{
type: Input
}], toggleColor: [{
type: Input
}], variable: [{
type: Input
}], editable: [{
type: Input
}], valueOn: [{
type: Input
}], valueOff: [{
type: Input
}], chip: [{
type: Input
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tap-variable-toggle.component.js","sourceRoot":"","sources":["../../../../../../../../projects/iotize-ionic/monitoring/src/lib/ui-components/tap-variable-toggle/tap-variable-toggle.component.ts","../../../../../../../../projects/iotize-ionic/monitoring/src/lib/ui-components/tap-variable-toggle/tap-variable-toggle.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectorRef,\n  Component,\n  Input,\n  OnDestroy,\n  ViewChild,\n} from '@angular/core';\nimport { IonToggle } from '@ionic/angular';\nimport { TapValueEditorContainerComponent } from '@iotize/ionic';\nimport { EditableValueDataStreamInterface } from '@iotize/tap/data';\nimport { Subscription } from 'rxjs';\nimport { map } from 'rxjs/operators';\nimport {\n  AppGenField,\n  MonitoringAppGenComponent,\n} from '../../metadata/decorators';\nimport {\n  COLOR_SCHEME_SCHEMA,\n  IONIC_COLOR_SCHEMA,\n  TAP_VARIABLE_SCHEMA,\n} from '../shared-schema';\n\n@MonitoringAppGenComponent({\n  constraints: {\n    isArray: 'NO',\n    isNumber: 'YES',\n  },\n  events: [\n    {\n      name: 'submit',\n      dataType: 'boolean',\n    },\n  ],\n})\n@Component({\n  selector: 'tap-variable-toggle',\n  templateUrl: './tap-variable-toggle.component.html',\n  styleUrls: ['./tap-variable-toggle.component.scss'],\n})\nexport class TapVariableToggleComponent implements AfterViewInit, OnDestroy {\n  @ViewChild('toggle') toggle!: IonToggle;\n  @ViewChild('ctx') ctx!: TapValueEditorContainerComponent;\n\n  error?: Error;\n\n  @Input()\n  textOnLeft = 'Off';\n\n  @Input()\n  textOnRight = 'On';\n\n  @Input()\n  lines = 'none';\n\n  @Input()\n  toggleColor = 'primary';\n\n  @Input()\n  variable?: EditableValueDataStreamInterface<number, any>;\n\n  @Input()\n  editable = false;\n\n  @Input()\n  valueOn = 1;\n\n  @Input()\n  valueOff = 0;\n\n  @Input()\n  chip: { outline?: boolean; color?: string } = {\n    outline: false,\n    color: '',\n  };\n\n  chipOutline = false;\n\n  _valueSub?: Subscription;\n\n  private _lastValueDisplayed?: boolean;\n\n  inputOptions = {\n    type: 'toggle',\n  };\n\n  constructor(private changeDetectorRef: ChangeDetectorRef) {}\n\n  ngAfterViewInit(): void {\n    this._valueSub = this.ctx?.valueToDisplay\n      .pipe(\n        map((value) => {\n          if (value === this.valueOn) {\n            value = true;\n          } else if (value === this.valueOff) {\n            value = false;\n          }\n          value = !!value;\n          return value;\n        })\n      )\n      .subscribe((value) => {\n        this._lastValueDisplayed = value;\n        if (this.ctx.pendingSubmitValue === undefined) {\n          this.toggle.checked = value;\n          this.changeDetectorRef.detectChanges();\n        }\n      });\n  }\n\n  ngOnDestroy(): void {\n    this._valueSub?.unsubscribe();\n  }\n\n  switchToggle() {\n    if (!this.toggle.disabled) {\n      this.toggle.checked = !this.toggle.checked;\n    }\n  }\n\n  onValueChange(event: CustomEvent<{ value: string; checked: boolean }>) {\n    if (this._lastValueDisplayed !== event.detail.checked) {\n      const value = event.detail.checked ? this.valueOn : this.valueOff;\n      this.ctx?.notifyValueChange(value);\n    }\n  }\n}\n","<tap-value-editor-container #ctx [variable]=\"variable\" [lines]=\"lines\">\n  <ion-chip\n    [color]=\"chip?.color\"\n    [outline]=\"chip?.outline\"\n    (click)=\"switchToggle()\"\n    [disabled]=\"!editable || (ctx.loadingChange | async)\"\n  >\n    <span class=\"spanToggle\"> {{ textOnLeft }} </span>\n    <ion-toggle\n      [color]=\"toggleColor\"\n      #toggle\n      [disabled]=\"!editable || (ctx.loadingChange | async)\"\n      style=\"pointer-events: none\"\n      (ionChange)=\"onValueChange($event)\"\n    ></ion-toggle>\n    <span class=\"spanToggle\"> {{ textOnRight }} </span>\n  </ion-chip>\n</tap-value-editor-container>\n"]}