UNPKG

@c8y/ngx-components

Version:

Angular modules for Cumulocity IoT applications

143 lines 30.3 kB
import { Component, EventEmitter, Input, Output, ViewChild } from '@angular/core'; import { BehaviorSubject, Subject } from 'rxjs'; import { FormBuilder } from '@angular/forms'; import { filter, takeUntil, tap } from 'rxjs/operators'; import { CountdownIntervalComponent, gettext } from '@c8y/ngx-components'; import { AlarmsViewService } from './alarms-view.service'; import * as i0 from "@angular/core"; import * as i1 from "@angular/forms"; import * as i2 from "./alarms-view.service"; import * as i3 from "@c8y/ngx-components"; import * as i4 from "@angular/common"; import * as i5 from "ngx-bootstrap/tooltip"; import * as i6 from "@ngx-translate/core"; export class AlarmsIntervalRefreshComponent { /** * * Set the value of `isIntervalEnabled` in response to user interactions with the alarm list scroll. * * * * This input setter allows you to control the `isIntervalEnabled` property, which is used to manage the state * * of a toggle button. When a user scrolls through the alarms list, you can update the `isIntervalEnabled` value * * using this setter. * * * * @param value - A boolean value representing the new state of the `isIntervalEnabled` property. * * - `true` indicates that the interval is enabled. * * - `false` indicates that the interval is disabled. */ set isIntervalToggleEnabled(value) { const shouldSetInterval = this.isIntervalToggleEnabled || this.doesUserCheckedIntervalToggle; const shouldToggleInterval = !this.isDisabled && this.isIntervalToggleEnabled && this.doesUserCheckedIntervalToggle && value; const intervalToggleControl = this.toggleIntervalForm.get('intervalToggle'); /** * We check if any interactions to toggle interval button were made. * When user interacts with toggle button, we need to ignore assigning value to the form. */ if (intervalToggleControl.dirty && !shouldSetInterval) { return; } /** * This condition checks if the interval toggle is enabled and if there has been user interaction, * and if the provided value is truthy. * If all conditions are met, the interval toggle should not be updated due to unnecessary update of countdown interval component */ if (shouldToggleInterval) { return; } intervalToggleControl.setValue(value); } /** * This getter allows you to access the current state of the `isIntervalEnabled` property, which reflects * the state of a toggle button. It retrieves the value from the associated form control, providing the * current state of the toggle button. */ get isIntervalToggleEnabled() { return !this.isDisabled && this.toggleIntervalForm.get('intervalToggle').value; } constructor(fb, alarmsViewService) { this.fb = fb; this.alarmsViewService = alarmsViewService; this.refreshIntervalsInMilliseconds = this.alarmsViewService.DEFAULT_INTERVAL_VALUES; this.DISABLE_AUTO_REFRESH = gettext('Disable auto refresh'); this.ENABLE_AUTO_REFRESH = gettext('Enable auto refresh'); this.SECONDS_UNTIL_REFRESH = gettext('{{ seconds }} s'); this.isDisabled = false; /** * Event emitter for notifying when a countdown timer has completed. */ this.onCountdownEnded = new EventEmitter(); this.toggleIntervalForm = this.initForm(); this.destroy$ = new Subject(); } ngOnInit() { this.listenToRefreshIntervalChange(); } ngAfterViewInit() { this.onIntervalToggleChange(); this.listenOnLoadingChanges(); } ngOnDestroy() { this.destroy$.next(); this.destroy$.complete(); } resetCountdown() { this.countdownIntervalComponent?.reset(); } trackUserClickOnIntervalToggle(target) { this.doesUserCheckedIntervalToggle = target.checked; } getTooltip() { return this.isDisabled ? gettext('Disabled') : this.isIntervalToggleEnabled ? this.DISABLE_AUTO_REFRESH : this.ENABLE_AUTO_REFRESH; } startCountdown() { this.countdownIntervalComponent.start(); } onIntervalToggleChange() { this.toggleIntervalForm .get('intervalToggle') .valueChanges.pipe(takeUntil(this.destroy$), filter(Boolean)) .subscribe(() => setTimeout(() => this.startCountdown())); } initForm() { return this.fb.group({ intervalToggle: true, refreshInterval: this.alarmsViewService.DEFAULT_INTERVAL_VALUE }); } listenToRefreshIntervalChange() { this.toggleIntervalForm .get('refreshInterval') .valueChanges.pipe(takeUntil(this.destroy$)) .subscribe(() => this.resetCountdown()); } listenOnLoadingChanges() { this.alarmsListLoading$ .pipe(tap(() => this.countdownIntervalComponent?.stop())) .subscribe(state => { !state && this.countdownIntervalComponent?.reset(); }); } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AlarmsIntervalRefreshComponent, deps: [{ token: i1.FormBuilder }, { token: i2.AlarmsViewService }], target: i0.ɵɵFactoryTarget.Component }); } static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: AlarmsIntervalRefreshComponent, selector: "c8y-alarms-interval-refresh", inputs: { isDisabled: "isDisabled", alarmsListLoading$: "alarmsListLoading$", isIntervalToggleEnabled: "isIntervalToggleEnabled" }, outputs: { onCountdownEnded: "onCountdownEnded" }, viewQueries: [{ propertyName: "countdownIntervalComponent", first: true, predicate: CountdownIntervalComponent, descendants: true }], ngImport: i0, template: "<form\n class=\"d-flex a-i-center fit-w fit-h\"\n [formGroup]=\"toggleIntervalForm\"\n>\n <label class=\"m-b-0 m-r-8 text-normal text-muted flex-no-shrink\">\n {{ 'Auto refresh' | translate }}\n </label>\n <div class=\"input-group\">\n <label\n class=\"toggle-countdown\"\n [class.toggle-countdown-disabled]=\"isDisabled\"\n [attr.aria-label]=\"getTooltip() | translate\"\n [tooltip]=\"getTooltip() | translate\"\n placement=\"bottom\"\n [adaptivePosition]=\"false\"\n [delay]=\"500\"\n >\n <input\n type=\"checkbox\"\n data-cy=\"c8y-alarms-interval-toggle\"\n formControlName=\"intervalToggle\"\n (click)=\"trackUserClickOnIntervalToggle($event.target)\"\n />\n <c8y-countdown-interval\n *ngIf=\"isIntervalToggleEnabled\"\n [countdownInterval]=\"toggleIntervalForm.value.refreshInterval\"\n (countdownEnded)=\"onCountdownEnded.emit()\"\n ></c8y-countdown-interval>\n <i\n c8yIcon=\"pause\"\n *ngIf=\"!isIntervalToggleEnabled\"\n ></i>\n </label>\n <div\n class=\"c8y-select-wrapper\"\n *ngIf=\"!isDisabled\"\n >\n <select\n class=\"form-control text-12\"\n [attr.aria-label]=\"'Refresh interval in seconds' | translate\"\n [tooltip]=\"'Refresh interval in seconds' | translate\"\n placement=\"bottom\"\n [adaptivePosition]=\"false\"\n [delay]=\"500\"\n [container]=\"'body'\"\n formControlName=\"refreshInterval\"\n data-cy=\"c8y-alarms-interval-selector\"\n >\n <option\n [disabled]=\"isDisabled\"\n *ngFor=\"let refreshInterval of refreshIntervalsInMilliseconds\"\n [ngValue]=\"refreshInterval\"\n >\n {{ SECONDS_UNTIL_REFRESH | translate: { seconds: refreshInterval / 1000 } }}\n </option>\n </select>\n <span></span>\n </div>\n <div class=\"input-group-btn\">\n <button\n class=\"btn btn-default\"\n style=\"border-left: 0\"\n [attr.aria-label]=\"'Refresh' | translate\"\n [tooltip]=\"'Refresh' | translate\"\n placement=\"bottom\"\n type=\"button\"\n [adaptivePosition]=\"false\"\n [delay]=\"500\"\n [disabled]=\"isDisabled || (alarmsListLoading$ | async)\"\n (click)=\"onCountdownEnded.emit()\"\n data-cy=\"c8y-alarms-reload-button\"\n >\n <i\n c8yIcon=\"refresh\"\n [ngClass]=\"{ 'icon-spin': alarmsListLoading$ | async }\"\n ></i>\n </button>\n </div>\n </div>\n</form>\n", dependencies: [{ kind: "directive", type: i3.IconDirective, selector: "[c8yIcon]", inputs: ["c8yIcon"] }, { kind: "directive", type: i4.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i1.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i1.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i1.CheckboxControlValueAccessor, selector: "input[type=checkbox][formControlName],input[type=checkbox][formControl],input[type=checkbox][ngModel]" }, { kind: "directive", type: i1.SelectControlValueAccessor, selector: "select:not([multiple])[formControlName],select:not([multiple])[formControl],select:not([multiple])[ngModel]", inputs: ["compareWith"] }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i3.RequiredInputPlaceholderDirective, selector: "input[required], input[formControlName]" }, { kind: "directive", type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i1.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "component", type: i3.CountdownIntervalComponent, selector: "c8y-countdown-interval", inputs: ["countdownInterval"], outputs: ["countdownEnded"] }, { kind: "directive", type: i5.TooltipDirective, selector: "[tooltip], [tooltipHtml]", inputs: ["adaptivePosition", "tooltip", "placement", "triggers", "container", "containerClass", "boundariesElement", "isOpen", "isDisabled", "delay", "tooltipHtml", "tooltipPlacement", "tooltipIsOpen", "tooltipEnable", "tooltipAppendToBody", "tooltipAnimation", "tooltipClass", "tooltipContext", "tooltipPopupDelay", "tooltipFadeDuration", "tooltipTrigger"], outputs: ["tooltipChange", "onShown", "onHidden", "tooltipStateChanged"], exportAs: ["bs-tooltip"] }, { kind: "pipe", type: i4.AsyncPipe, name: "async" }, { kind: "pipe", type: i6.TranslatePipe, name: "translate" }] }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AlarmsIntervalRefreshComponent, decorators: [{ type: Component, args: [{ selector: 'c8y-alarms-interval-refresh', template: "<form\n class=\"d-flex a-i-center fit-w fit-h\"\n [formGroup]=\"toggleIntervalForm\"\n>\n <label class=\"m-b-0 m-r-8 text-normal text-muted flex-no-shrink\">\n {{ 'Auto refresh' | translate }}\n </label>\n <div class=\"input-group\">\n <label\n class=\"toggle-countdown\"\n [class.toggle-countdown-disabled]=\"isDisabled\"\n [attr.aria-label]=\"getTooltip() | translate\"\n [tooltip]=\"getTooltip() | translate\"\n placement=\"bottom\"\n [adaptivePosition]=\"false\"\n [delay]=\"500\"\n >\n <input\n type=\"checkbox\"\n data-cy=\"c8y-alarms-interval-toggle\"\n formControlName=\"intervalToggle\"\n (click)=\"trackUserClickOnIntervalToggle($event.target)\"\n />\n <c8y-countdown-interval\n *ngIf=\"isIntervalToggleEnabled\"\n [countdownInterval]=\"toggleIntervalForm.value.refreshInterval\"\n (countdownEnded)=\"onCountdownEnded.emit()\"\n ></c8y-countdown-interval>\n <i\n c8yIcon=\"pause\"\n *ngIf=\"!isIntervalToggleEnabled\"\n ></i>\n </label>\n <div\n class=\"c8y-select-wrapper\"\n *ngIf=\"!isDisabled\"\n >\n <select\n class=\"form-control text-12\"\n [attr.aria-label]=\"'Refresh interval in seconds' | translate\"\n [tooltip]=\"'Refresh interval in seconds' | translate\"\n placement=\"bottom\"\n [adaptivePosition]=\"false\"\n [delay]=\"500\"\n [container]=\"'body'\"\n formControlName=\"refreshInterval\"\n data-cy=\"c8y-alarms-interval-selector\"\n >\n <option\n [disabled]=\"isDisabled\"\n *ngFor=\"let refreshInterval of refreshIntervalsInMilliseconds\"\n [ngValue]=\"refreshInterval\"\n >\n {{ SECONDS_UNTIL_REFRESH | translate: { seconds: refreshInterval / 1000 } }}\n </option>\n </select>\n <span></span>\n </div>\n <div class=\"input-group-btn\">\n <button\n class=\"btn btn-default\"\n style=\"border-left: 0\"\n [attr.aria-label]=\"'Refresh' | translate\"\n [tooltip]=\"'Refresh' | translate\"\n placement=\"bottom\"\n type=\"button\"\n [adaptivePosition]=\"false\"\n [delay]=\"500\"\n [disabled]=\"isDisabled || (alarmsListLoading$ | async)\"\n (click)=\"onCountdownEnded.emit()\"\n data-cy=\"c8y-alarms-reload-button\"\n >\n <i\n c8yIcon=\"refresh\"\n [ngClass]=\"{ 'icon-spin': alarmsListLoading$ | async }\"\n ></i>\n </button>\n </div>\n </div>\n</form>\n" }] }], ctorParameters: () => [{ type: i1.FormBuilder }, { type: i2.AlarmsViewService }], propDecorators: { isDisabled: [{ type: Input }], alarmsListLoading$: [{ type: Input }], isIntervalToggleEnabled: [{ type: Input }], onCountdownEnded: [{ type: Output }], countdownIntervalComponent: [{ type: ViewChild, args: [CountdownIntervalComponent] }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"alarms-interval-refresh.component.js","sourceRoot":"","sources":["../../../alarms/alarms-interval-refresh.component.ts","../../../alarms/alarms-interval-refresh.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  Component,\n  EventEmitter,\n  Input,\n  OnDestroy,\n  OnInit,\n  Output,\n  ViewChild\n} from '@angular/core';\nimport { BehaviorSubject, Subject } from 'rxjs';\nimport { FormBuilder } from '@angular/forms';\nimport { filter, takeUntil, tap } from 'rxjs/operators';\nimport { CountdownIntervalComponent, gettext } from '@c8y/ngx-components';\nimport { AlarmsViewService } from './alarms-view.service';\n\n@Component({\n  selector: 'c8y-alarms-interval-refresh',\n  templateUrl: './alarms-interval-refresh.component.html'\n})\nexport class AlarmsIntervalRefreshComponent implements OnInit, AfterViewInit, OnDestroy {\n  readonly refreshIntervalsInMilliseconds = this.alarmsViewService.DEFAULT_INTERVAL_VALUES;\n  readonly DISABLE_AUTO_REFRESH = gettext('Disable auto refresh');\n  readonly ENABLE_AUTO_REFRESH = gettext('Enable auto refresh');\n  readonly SECONDS_UNTIL_REFRESH = gettext('{{ seconds }} s');\n\n  @Input() isDisabled = false;\n  /**\n   * Controls the loading state of the alarms list reload button.\n   */\n  @Input()\n  alarmsListLoading$: BehaviorSubject<boolean>;\n  /**\n   * * Set the value of `isIntervalEnabled` in response to user interactions with the alarm list scroll.\n   *  *\n   *  * This input setter allows you to control the `isIntervalEnabled` property, which is used to manage the state\n   *  * of a toggle button. When a user scrolls through the alarms list, you can update the `isIntervalEnabled` value\n   *  * using this setter.\n   *  *\n   *  * @param value - A boolean value representing the new state of the `isIntervalEnabled` property.\n   *  *   - `true` indicates that the interval is enabled.\n   *  *   - `false` indicates that the interval is disabled.\n   */\n  @Input()\n  set isIntervalToggleEnabled(value: boolean) {\n    const shouldSetInterval = this.isIntervalToggleEnabled || this.doesUserCheckedIntervalToggle;\n    const shouldToggleInterval =\n      !this.isDisabled &&\n      this.isIntervalToggleEnabled &&\n      this.doesUserCheckedIntervalToggle &&\n      value;\n    const intervalToggleControl = this.toggleIntervalForm.get('intervalToggle');\n    /**\n     * We check if any interactions to toggle interval button were made.\n     * When user interacts with toggle button, we need to ignore assigning value to the form.\n     */\n    if (intervalToggleControl.dirty && !shouldSetInterval) {\n      return;\n    }\n    /**\n     * This condition checks if the interval toggle is enabled and if there has been user interaction,\n     * and if the provided value is truthy.\n     * If all conditions are met, the interval toggle should not be updated due to unnecessary update of countdown interval component\n     */\n    if (shouldToggleInterval) {\n      return;\n    }\n    intervalToggleControl.setValue(value);\n  }\n  /**\n   * This getter allows you to access the current state of the `isIntervalEnabled` property, which reflects\n   * the state of a toggle button. It retrieves the value from the associated form control, providing the\n   * current state of the toggle button.\n   */\n  get isIntervalToggleEnabled(): boolean {\n    return !this.isDisabled && this.toggleIntervalForm.get('intervalToggle').value;\n  }\n  /**\n   * Event emitter for notifying when a countdown timer has completed.\n   */\n  @Output()\n  onCountdownEnded = new EventEmitter<void>();\n\n  @ViewChild(CountdownIntervalComponent)\n  countdownIntervalComponent: CountdownIntervalComponent;\n  toggleIntervalForm = this.initForm();\n  private destroy$: Subject<void> = new Subject<void>();\n  /**\n   * Indicates whether the user has been interacting with the interval toggle.\n   * Property holds the current state of the interval toggle input element entered by the user,\n   * distinguishing it from changes made programmatically (e.g. value from isIntervalToggleEnabled).\n   */\n  private doesUserCheckedIntervalToggle: boolean;\n\n  constructor(\n    private fb: FormBuilder,\n    private alarmsViewService: AlarmsViewService\n  ) {}\n\n  ngOnInit(): void {\n    this.listenToRefreshIntervalChange();\n  }\n\n  ngAfterViewInit(): void {\n    this.onIntervalToggleChange();\n    this.listenOnLoadingChanges();\n  }\n\n  ngOnDestroy(): void {\n    this.destroy$.next();\n    this.destroy$.complete();\n  }\n\n  resetCountdown(): void {\n    this.countdownIntervalComponent?.reset();\n  }\n\n  trackUserClickOnIntervalToggle(target: EventTarget): void {\n    this.doesUserCheckedIntervalToggle = (target as HTMLInputElement).checked;\n  }\n\n  getTooltip() {\n    return this.isDisabled\n      ? gettext('Disabled')\n      : this.isIntervalToggleEnabled\n        ? this.DISABLE_AUTO_REFRESH\n        : this.ENABLE_AUTO_REFRESH;\n  }\n\n  private startCountdown(): void {\n    this.countdownIntervalComponent.start();\n  }\n\n  private onIntervalToggleChange(): void {\n    this.toggleIntervalForm\n      .get('intervalToggle')\n      .valueChanges.pipe(takeUntil(this.destroy$), filter(Boolean))\n      .subscribe(() => setTimeout(() => this.startCountdown()));\n  }\n\n  private initForm() {\n    return this.fb.group({\n      intervalToggle: true,\n      refreshInterval: this.alarmsViewService.DEFAULT_INTERVAL_VALUE\n    });\n  }\n\n  private listenToRefreshIntervalChange(): void {\n    this.toggleIntervalForm\n      .get('refreshInterval')\n      .valueChanges.pipe(takeUntil(this.destroy$))\n      .subscribe(() => this.resetCountdown());\n  }\n\n  private listenOnLoadingChanges() {\n    this.alarmsListLoading$\n      .pipe(tap(() => this.countdownIntervalComponent?.stop()))\n      .subscribe(state => {\n        !state && this.countdownIntervalComponent?.reset();\n      });\n  }\n}\n","<form\n  class=\"d-flex a-i-center fit-w fit-h\"\n  [formGroup]=\"toggleIntervalForm\"\n>\n  <label class=\"m-b-0 m-r-8 text-normal text-muted flex-no-shrink\">\n    {{ 'Auto refresh' | translate }}\n  </label>\n  <div class=\"input-group\">\n    <label\n      class=\"toggle-countdown\"\n      [class.toggle-countdown-disabled]=\"isDisabled\"\n      [attr.aria-label]=\"getTooltip() | translate\"\n      [tooltip]=\"getTooltip() | translate\"\n      placement=\"bottom\"\n      [adaptivePosition]=\"false\"\n      [delay]=\"500\"\n    >\n      <input\n        type=\"checkbox\"\n        data-cy=\"c8y-alarms-interval-toggle\"\n        formControlName=\"intervalToggle\"\n        (click)=\"trackUserClickOnIntervalToggle($event.target)\"\n      />\n      <c8y-countdown-interval\n        *ngIf=\"isIntervalToggleEnabled\"\n        [countdownInterval]=\"toggleIntervalForm.value.refreshInterval\"\n        (countdownEnded)=\"onCountdownEnded.emit()\"\n      ></c8y-countdown-interval>\n      <i\n        c8yIcon=\"pause\"\n        *ngIf=\"!isIntervalToggleEnabled\"\n      ></i>\n    </label>\n    <div\n      class=\"c8y-select-wrapper\"\n      *ngIf=\"!isDisabled\"\n    >\n      <select\n        class=\"form-control text-12\"\n        [attr.aria-label]=\"'Refresh interval in seconds' | translate\"\n        [tooltip]=\"'Refresh interval in seconds' | translate\"\n        placement=\"bottom\"\n        [adaptivePosition]=\"false\"\n        [delay]=\"500\"\n        [container]=\"'body'\"\n        formControlName=\"refreshInterval\"\n        data-cy=\"c8y-alarms-interval-selector\"\n      >\n        <option\n          [disabled]=\"isDisabled\"\n          *ngFor=\"let refreshInterval of refreshIntervalsInMilliseconds\"\n          [ngValue]=\"refreshInterval\"\n        >\n          {{ SECONDS_UNTIL_REFRESH | translate: { seconds: refreshInterval / 1000 } }}\n        </option>\n      </select>\n      <span></span>\n    </div>\n    <div class=\"input-group-btn\">\n      <button\n        class=\"btn btn-default\"\n        style=\"border-left: 0\"\n        [attr.aria-label]=\"'Refresh' | translate\"\n        [tooltip]=\"'Refresh' | translate\"\n        placement=\"bottom\"\n        type=\"button\"\n        [adaptivePosition]=\"false\"\n        [delay]=\"500\"\n        [disabled]=\"isDisabled || (alarmsListLoading$ | async)\"\n        (click)=\"onCountdownEnded.emit()\"\n        data-cy=\"c8y-alarms-reload-button\"\n      >\n        <i\n          c8yIcon=\"refresh\"\n          [ngClass]=\"{ 'icon-spin': alarmsListLoading$ | async }\"\n        ></i>\n      </button>\n    </div>\n  </div>\n</form>\n"]}