@iotize/ionic
Version:
Iotize specific building blocks on top of @ionic/angular.
150 lines • 20.3 kB
JavaScript
import { Component, ContentChild, Directive, ElementRef, EventEmitter, Input, Output, TemplateRef, ViewChild, ViewEncapsulation, } from '@angular/core';
import { IonRange } from '@ionic/angular';
import { BehaviorSubject, NEVER } from 'rxjs';
import { shareReplay, switchMap } from 'rxjs/operators';
import * as i0 from "@angular/core";
import * as i1 from "@angular/common";
import * as i2 from "@ionic/angular";
import * as i3 from "@iotize/app-common";
export class MonitoringRangeContentDirective {
tpl;
constructor(tpl) {
this.tpl = tpl;
}
/** @nocollapse */ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: MonitoringRangeContentDirective, deps: [{ token: i0.TemplateRef }], target: i0.ɵɵFactoryTarget.Directive });
/** @nocollapse */ static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.14", type: MonitoringRangeContentDirective, selector: "[monitoringRangeContent]", ngImport: i0 });
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: MonitoringRangeContentDirective, decorators: [{
type: Directive,
args: [{
selector: '[monitoringRangeContent]',
}]
}], ctorParameters: () => [{ type: i0.TemplateRef }] });
export class MonitoringRangeComponent {
focusChange = new BehaviorSubject(false);
dualKnobs = false;
_valueSub;
currentValue = undefined;
previousValue = undefined;
rangeTemplate;
get rangeTemplateContext() {
return { $implicit: this };
}
range;
onValueChanged = new EventEmitter();
set inputStream(stream) {
this._valueSub?.unsubscribe();
if (stream) {
this._valueSub = this.focusChange
.pipe(switchMap((hasFocus) => {
if (hasFocus) {
return NEVER;
}
else {
return stream;
}
}), shareReplay(1))
.subscribe((v) => {
this.currentValue = v;
});
}
else {
this.currentValue = undefined;
}
}
min = 0;
max = 100;
_step = 1;
set step(step) {
if (step == 0) {
step = 1;
}
this._step = step;
}
debounce = 0;
pin = true;
disabled = false;
snaps = true;
ticks = true;
writeValueForEveryChange = false;
leftIcon;
leftIconColor;
rightIcon;
rightIconColor;
color;
el;
constructor() { }
ngOnDestroy() {
this._valueSub?.unsubscribe();
}
_onValueChanged(event) {
this.previousValue = this.currentValue;
this.currentValue = event.detail.value;
if (this.writeValueForEveryChange) {
this.onSliderReleased(event);
}
}
onSliderReleased($event) {
let currentValue = this.currentValue;
// Issue on mobile: onSliderReleased() may be called before _onValueChanged() event
// So we directly read the value from the range HTML element if available
if (typeof this.range?.value === 'number') {
currentValue = this.range.value;
}
if (this.previousValue !== currentValue) {
this.onValueChanged.emit(currentValue);
this.previousValue = currentValue;
}
}
/** @nocollapse */ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: MonitoringRangeComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
/** @nocollapse */ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.14", type: MonitoringRangeComponent, selector: "monitoring-range", inputs: { inputStream: "inputStream", min: "min", max: "max", step: "step", debounce: "debounce", pin: "pin", disabled: "disabled", snaps: "snaps", ticks: "ticks", writeValueForEveryChange: "writeValueForEveryChange", leftIcon: "leftIcon", leftIconColor: "leftIconColor", rightIcon: "rightIcon", rightIconColor: "rightIconColor", color: "color" }, outputs: { onValueChanged: "onValueChanged" }, queries: [{ propertyName: "rangeTemplate", first: true, predicate: MonitoringRangeContentDirective, descendants: true, read: TemplateRef, static: true }], viewQueries: [{ propertyName: "range", first: true, predicate: ["range"], descendants: true, static: true }, { propertyName: "el", first: true, predicate: [".range-knob"], descendants: true }], ngImport: i0, template: "<ion-range\n #range\n [value]=\"currentValue\"\n [class.disableRange]=\"disabled\"\n [min]=\"min\"\n [max]=\"max\"\n [step]=\"_step\"\n [color]=\"color\"\n [snaps]=\"snaps\"\n [debounce]=\"debounce\"\n [pin]=\"pin\"\n [ticks]=\"ticks\"\n [dualKnobs]=\"dualKnobs\"\n [disabled]=\"disabled\"\n (ionChange)=\"_onValueChanged($event)\"\n (ionKnobMoveEnd)=\"onSliderReleased($event)\"\n [ngClass]=\"disabled ? 'rangeDisabled' : ''\"\n>\n <app-common-icon\n *ngIf=\"leftIcon\"\n slot=\"start\"\n [image]=\"leftIcon\"\n [color]=\"leftIconColor\"\n ></app-common-icon>\n <ng-container\n *ngTemplateOutlet=\"\n rangeTemplate || defaultRangeTemplate;\n context: rangeTemplateContext\n \"\n ></ng-container>\n <app-common-icon\n *ngIf=\"rightIcon\"\n slot=\"end\"\n [image]=\"rightIcon\"\n [color]=\"rightIconColor\"\n ></app-common-icon>\n</ion-range>\n\n<ng-template #defaultRangeTemplate>\n <ion-label slot=\"start\">{{ min }}</ion-label>\n <ion-label slot=\"end\">{{ max }}</ion-label>\n</ng-template>\n", styles: ["ion-range{padding-left:0;padding-right:0;min-width:150px}@media (prefers-color-scheme: dark){.rangeDisabled{--knob-size: 0px}}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i2.IonLabel, selector: "ion-label", inputs: ["color", "mode", "position"] }, { kind: "component", type: i2.IonRange, selector: "ion-range", inputs: ["activeBarStart", "color", "debounce", "disabled", "dualKnobs", "label", "labelPlacement", "max", "min", "mode", "name", "pin", "pinFormatter", "snaps", "step", "ticks", "value"] }, { kind: "directive", type: i2.NumericValueAccessor, selector: "ion-input[type=number],ion-input-otp:not([type=text]),ion-range" }, { kind: "component", type: i3.IconComponent, selector: "app-common-icon", inputs: ["imageSize", "color", "image"] }], encapsulation: i0.ViewEncapsulation.None });
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: MonitoringRangeComponent, decorators: [{
type: Component,
args: [{ selector: 'monitoring-range', encapsulation: ViewEncapsulation.None, template: "<ion-range\n #range\n [value]=\"currentValue\"\n [class.disableRange]=\"disabled\"\n [min]=\"min\"\n [max]=\"max\"\n [step]=\"_step\"\n [color]=\"color\"\n [snaps]=\"snaps\"\n [debounce]=\"debounce\"\n [pin]=\"pin\"\n [ticks]=\"ticks\"\n [dualKnobs]=\"dualKnobs\"\n [disabled]=\"disabled\"\n (ionChange)=\"_onValueChanged($event)\"\n (ionKnobMoveEnd)=\"onSliderReleased($event)\"\n [ngClass]=\"disabled ? 'rangeDisabled' : ''\"\n>\n <app-common-icon\n *ngIf=\"leftIcon\"\n slot=\"start\"\n [image]=\"leftIcon\"\n [color]=\"leftIconColor\"\n ></app-common-icon>\n <ng-container\n *ngTemplateOutlet=\"\n rangeTemplate || defaultRangeTemplate;\n context: rangeTemplateContext\n \"\n ></ng-container>\n <app-common-icon\n *ngIf=\"rightIcon\"\n slot=\"end\"\n [image]=\"rightIcon\"\n [color]=\"rightIconColor\"\n ></app-common-icon>\n</ion-range>\n\n<ng-template #defaultRangeTemplate>\n <ion-label slot=\"start\">{{ min }}</ion-label>\n <ion-label slot=\"end\">{{ max }}</ion-label>\n</ng-template>\n", styles: ["ion-range{padding-left:0;padding-right:0;min-width:150px}@media (prefers-color-scheme: dark){.rangeDisabled{--knob-size: 0px}}\n"] }]
}], ctorParameters: () => [], propDecorators: { rangeTemplate: [{
type: ContentChild,
args: [MonitoringRangeContentDirective, {
read: TemplateRef,
static: true,
}]
}], range: [{
type: ViewChild,
args: ['range', { static: true }]
}], onValueChanged: [{
type: Output
}], inputStream: [{
type: Input
}], min: [{
type: Input
}], max: [{
type: Input
}], step: [{
type: Input
}], debounce: [{
type: Input
}], pin: [{
type: Input
}], disabled: [{
type: Input
}], snaps: [{
type: Input
}], ticks: [{
type: Input
}], writeValueForEveryChange: [{
type: Input
}], leftIcon: [{
type: Input
}], leftIconColor: [{
type: Input
}], rightIcon: [{
type: Input
}], rightIconColor: [{
type: Input
}], color: [{
type: Input
}], el: [{
type: ViewChild,
args: ['.range-knob']
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"monitoring-range.component.js","sourceRoot":"","sources":["../../../../../../../../projects/iotize-ionic/monitoring/src/lib/ui-components/monitoring-range/monitoring-range.component.ts","../../../../../../../../projects/iotize-ionic/monitoring/src/lib/ui-components/monitoring-range/monitoring-range.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  ContentChild,\n  Directive,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnDestroy,\n  Output,\n  TemplateRef,\n  ViewChild,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { IonRange } from '@ionic/angular';\nimport { BehaviorSubject, NEVER, Observable, Subscription } from 'rxjs';\nimport { shareReplay, switchMap } from 'rxjs/operators';\nimport { debug } from '../../debug';\n\ntype ColorType = any;\n\n@Directive({\n  selector: '[monitoringRangeContent]',\n})\nexport class MonitoringRangeContentDirective {\n  constructor(public tpl: TemplateRef<any>) {}\n}\n@Component({\n  selector: 'monitoring-range',\n  templateUrl: './monitoring-range.component.html',\n  styleUrls: ['./monitoring-range.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n})\nexport class MonitoringRangeComponent implements OnDestroy {\n  public focusChange = new BehaviorSubject<boolean>(false);\n  public dualKnobs = false;\n\n  private _valueSub?: Subscription;\n  currentValue: number | undefined = undefined;\n  private previousValue: number | undefined = undefined;\n\n  @ContentChild(MonitoringRangeContentDirective, {\n    read: TemplateRef,\n    static: true,\n  })\n  rangeTemplate?: TemplateRef<any>;\n\n  get rangeTemplateContext(): object {\n    return { $implicit: this };\n  }\n\n  @ViewChild('range', { static: true }) range?: IonRange;\n\n  @Output() onValueChanged = new EventEmitter<number>();\n\n  @Input()\n  set inputStream(stream: Observable<number> | undefined) {\n    this._valueSub?.unsubscribe();\n    if (stream) {\n      this._valueSub = this.focusChange\n        .pipe(\n          switchMap((hasFocus) => {\n            if (hasFocus) {\n              return NEVER;\n            } else {\n              return stream;\n            }\n          }),\n          shareReplay(1)\n        )\n        .subscribe((v) => {\n          this.currentValue = v;\n        });\n    } else {\n      this.currentValue = undefined;\n    }\n  }\n\n  @Input() min = 0;\n  @Input() max = 100;\n\n  _step: number = 1;\n\n  @Input() set step(step: number) {\n    if (step == 0) {\n      step = 1;\n    }\n    this._step = step;\n  }\n\n  @Input() debounce = 0;\n  @Input() pin = true;\n  @Input() disabled = false;\n  @Input() snaps = true;\n  @Input() ticks = true;\n  @Input() writeValueForEveryChange: boolean = false;\n\n  @Input() leftIcon?: string;\n  @Input() leftIconColor?: string;\n  @Input() rightIcon?: string;\n  @Input() rightIconColor?: string;\n\n  @Input() color?: ColorType;\n\n  @ViewChild('.range-knob') el!: ElementRef;\n\n  constructor() {}\n\n  ngOnDestroy(): void {\n    this._valueSub?.unsubscribe();\n  }\n\n  _onValueChanged(event: CustomEvent<{ value: number }>) {\n    this.previousValue = this.currentValue;\n    this.currentValue = event.detail.value;\n    if (this.writeValueForEveryChange) {\n      this.onSliderReleased(event);\n    }\n  }\n\n  onSliderReleased($event: CustomEvent) {\n    let currentValue = this.currentValue;\n    // Issue on mobile: onSliderReleased() may be called before _onValueChanged() event\n    // So we directly read the value from the range HTML element if available\n    if (typeof this.range?.value === 'number') {\n      currentValue = this.range.value;\n    }\n    if (this.previousValue !== currentValue) {\n      this.onValueChanged.emit(currentValue);\n      this.previousValue = currentValue;\n    }\n  }\n}\n","<ion-range\n  #range\n  [value]=\"currentValue\"\n  [class.disableRange]=\"disabled\"\n  [min]=\"min\"\n  [max]=\"max\"\n  [step]=\"_step\"\n  [color]=\"color\"\n  [snaps]=\"snaps\"\n  [debounce]=\"debounce\"\n  [pin]=\"pin\"\n  [ticks]=\"ticks\"\n  [dualKnobs]=\"dualKnobs\"\n  [disabled]=\"disabled\"\n  (ionChange)=\"_onValueChanged($event)\"\n  (ionKnobMoveEnd)=\"onSliderReleased($event)\"\n  [ngClass]=\"disabled ? 'rangeDisabled' : ''\"\n>\n  <app-common-icon\n    *ngIf=\"leftIcon\"\n    slot=\"start\"\n    [image]=\"leftIcon\"\n    [color]=\"leftIconColor\"\n  ></app-common-icon>\n  <ng-container\n    *ngTemplateOutlet=\"\n      rangeTemplate || defaultRangeTemplate;\n      context: rangeTemplateContext\n    \"\n  ></ng-container>\n  <app-common-icon\n    *ngIf=\"rightIcon\"\n    slot=\"end\"\n    [image]=\"rightIcon\"\n    [color]=\"rightIconColor\"\n  ></app-common-icon>\n</ion-range>\n\n<ng-template #defaultRangeTemplate>\n  <ion-label slot=\"start\">{{ min }}</ion-label>\n  <ion-label slot=\"end\">{{ max }}</ion-label>\n</ng-template>\n"]}