@c8y/ngx-components 1021.22.68 → 1021.22.70
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/core/common/interval-based-reload.abstract.d.ts +12 -1
- package/core/common/interval-based-reload.abstract.d.ts.map +1 -1
- package/datapoint-selector/datapoint-attributes-form/datapoint-attributes-form.component.d.ts +15 -46
- package/datapoint-selector/datapoint-attributes-form/datapoint-attributes-form.component.d.ts.map +1 -1
- package/datapoint-selector/datapoint-attributes-form/datapoint-attributes.model.d.ts +3 -0
- package/datapoint-selector/datapoint-attributes-form/datapoint-attributes.model.d.ts.map +1 -1
- package/datapoint-selector/datapoint-selection.model.d.ts +4 -6
- package/datapoint-selector/datapoint-selection.model.d.ts.map +1 -1
- package/esm2022/core/common/interval-based-reload.abstract.mjs +50 -2
- package/esm2022/datapoint-selector/datapoint-attributes-form/datapoint-attributes-form.component.mjs +47 -22
- package/esm2022/datapoint-selector/datapoint-attributes-form/datapoint-attributes.model.mjs +1 -1
- package/esm2022/datapoint-selector/datapoint-selection.model.mjs +1 -1
- package/esm2022/datapoint-selector/datapoint-selector-list-item/datapoint-selector-list-item.component.mjs +3 -3
- package/esm2022/widgets/implementations/alarms/alarm-widget-alarms-reload.component.mjs +9 -7
- package/esm2022/widgets/implementations/datapoints-table/datapoints-table-config/datapoints-table-config.component.mjs +3 -2
- package/esm2022/widgets/implementations/datapoints-table/datapoints-table-view/datapoints-reload/datapoints-reload.component.mjs +9 -7
- package/fesm2022/c8y-ngx-components-datapoint-selector.mjs +48 -23
- package/fesm2022/c8y-ngx-components-datapoint-selector.mjs.map +1 -1
- package/fesm2022/c8y-ngx-components-widgets-implementations-alarms.mjs +8 -6
- package/fesm2022/c8y-ngx-components-widgets-implementations-alarms.mjs.map +1 -1
- package/fesm2022/c8y-ngx-components-widgets-implementations-datapoints-table.mjs +10 -7
- package/fesm2022/c8y-ngx-components-widgets-implementations-datapoints-table.mjs.map +1 -1
- package/fesm2022/c8y-ngx-components.mjs +392 -346
- package/fesm2022/c8y-ngx-components.mjs.map +1 -1
- package/locales/de.po +9 -0
- package/locales/es.po +11 -1
- package/locales/fr.po +9 -0
- package/locales/ja_JP.po +9 -0
- package/locales/ko.po +9 -0
- package/locales/nl.po +9 -0
- package/locales/pl.po +9 -0
- package/locales/pt_BR.po +9 -0
- package/locales/zh_CN.po +9 -0
- package/locales/zh_TW.po +9 -0
- package/package.json +1 -1
- package/widgets/implementations/alarms/alarm-widget-alarms-reload.component.d.ts +7 -2
- package/widgets/implementations/alarms/alarm-widget-alarms-reload.component.d.ts.map +1 -1
- package/widgets/implementations/datapoints-table/datapoints-table-config/datapoints-table-config.component.d.ts.map +1 -1
- package/widgets/implementations/datapoints-table/datapoints-table-view/datapoints-reload/datapoints-reload.component.d.ts +7 -2
- package/widgets/implementations/datapoints-table/datapoints-table-view/datapoints-reload/datapoints-reload.component.d.ts.map +1 -1
|
@@ -52,7 +52,8 @@ export class DatapointsTableWidgetConfigComponent {
|
|
|
52
52
|
this.datapointSelectionConfig = {};
|
|
53
53
|
this.disabledAggregationOptions = {};
|
|
54
54
|
this.defaultFormOptions = {
|
|
55
|
-
|
|
55
|
+
selectableChartLineTypes: [],
|
|
56
|
+
selectableAxisTypes: [],
|
|
56
57
|
showRedRange: true,
|
|
57
58
|
showYellowRange: true
|
|
58
59
|
};
|
|
@@ -384,4 +385,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImpor
|
|
|
384
385
|
}], ctorParameters: () => [{ type: i1.DatapointsTableService }, { type: i2.DatapointsTableConfigService }, { type: i3.FormBuilder }, { type: i3.NgForm }, { type: i4.WidgetConfigComponent }], propDecorators: { config: [{
|
|
385
386
|
type: Input
|
|
386
387
|
}] } });
|
|
387
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datapoints-table-config.component.js","sourceRoot":"","sources":["../../../../../../widgets/implementations/datapoints-table/datapoints-table-config/datapoints-table-config.component.ts","../../../../../../widgets/implementations/datapoints-table/datapoints-table-config/datapoints-table-config.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnDestroy, OnInit } from '@angular/core';\nimport {\n  AbstractControl,\n  FormBuilder,\n  FormControl,\n  NgForm,\n  ReactiveFormsModule,\n  ValidationErrors,\n  ValidatorFn,\n  Validators\n} from '@angular/forms';\nimport {\n  AGGREGATION_LABELS,\n  AGGREGATION_VALUES,\n  AGGREGATION_VALUES_ARR,\n  AggregationOption,\n  AggregationOptionStatus,\n  CoreModule\n} from '@c8y/ngx-components';\nimport { WidgetConfigComponent } from '@c8y/ngx-components/context-dashboard';\nimport {\n  DatapointAttributesFormConfig,\n  DatapointSelectorModalOptions,\n  DatapointSelectorModule,\n  KPIDetails\n} from '@c8y/ngx-components/datapoint-selector';\nimport {\n  dateRangeValidator,\n  TIME_RANGE_INTERVAL_UNITS_VALUES,\n  TimeRangeInterval\n} from '@c8y/ngx-components/datapoints-export-selector';\nimport { INTERVAL_VALUES } from '@c8y/ngx-components/interval-picker';\nimport { PopoverModule } from 'ngx-bootstrap/popover';\nimport { merge, Subject, takeUntil } from 'rxjs';\nimport {\n  DatapointsTableConfig,\n  DATE_SELECTION_LABELS,\n  DATE_SELECTION_VALUES,\n  DATE_SELECTION_VALUES_ARR,\n  DateRange,\n  DEFAULT_COUNTDOWN_VALUE,\n  INTERVAL_VALUES_ARR,\n  REFRESH_INTERVAL_VALUES_ARR,\n  TIME_RANGE_INTERVAL_LABELS\n} from '../datapoints-table-widget.model';\nimport { DatapointsTableService } from '../datapoints-table.service';\nimport { DateRangePickerComponent } from '../date-range-picker.component';\nimport { DatapointsTableConfigService } from './datapoints-table-config.service';\n\nexport function minOneDatapointActive(): ValidatorFn {\n  return (control: AbstractControl): ValidationErrors | null => {\n    const datapoints: KPIDetails[] = control.value;\n\n    if (!datapoints || !datapoints.length) {\n      return null;\n    }\n\n    const activeDatapoints = datapoints.filter(datapoint => datapoint.__active);\n\n    if (activeDatapoints.length >= 1) {\n      return null;\n    }\n    return { exactlyOneDatapointNeedsToBeActive: true };\n  };\n}\n\n@Component({\n  selector: 'c8y-datapoints-table-view-config',\n  templateUrl: './datapoints-table-config.component.html',\n  standalone: true,\n  imports: [\n    CoreModule,\n    DatapointSelectorModule,\n    DateRangePickerComponent,\n    PopoverModule,\n    ReactiveFormsModule\n  ]\n})\nexport class DatapointsTableWidgetConfigComponent implements OnInit, OnDestroy {\n  /**\n   *  Data points table widget config.\n   */\n  @Input() config: DatapointsTableConfig;\n\n  readonly AGGREGATION_LABELS = AGGREGATION_LABELS;\n  readonly DATE_SELECTION_LABELS = DATE_SELECTION_LABELS;\n  readonly DEFAULT_DATE_SELECTOR_VALUE = DATE_SELECTION_VALUES.dashboard_context;\n  readonly DEFAULT_INTERVAL_VALUE = INTERVAL_VALUES.hours;\n  readonly TIME_RANGE_INTERVAL_LABELS = TIME_RANGE_INTERVAL_LABELS;\n\n  readonly AGGREGATION_VALUES_ARR = AGGREGATION_VALUES_ARR;\n  readonly DATE_SELECTION_VALUES_ARR = DATE_SELECTION_VALUES_ARR;\n  readonly INTERVAL_VALUES_ARR = INTERVAL_VALUES_ARR;\n  readonly REFRESH_INTERVAL_VALUES_ARR = REFRESH_INTERVAL_VALUES_ARR;\n\n  datapointSelectionConfig: Partial<DatapointSelectorModalOptions> = {};\n  disabledAggregationOptions: AggregationOptionStatus = {};\n  defaultFormOptions: Partial<DatapointAttributesFormConfig> = {\n    showDisplay: true,\n    showRedRange: true,\n    showYellowRange: true\n  };\n  formGroup: ReturnType<DatapointsTableWidgetConfigComponent['createForm']>;\n  isWidgetLinkedToGlobalTimeContext: boolean;\n\n  private decimalLimits = {\n    numberOfDecimalPlacesMin: 0,\n    numberOfDecimalPlacesMax: 10\n  } as const;\n\n  /**\n   * Indicate when the time interval selector item has been changed programmatically.\n   *\n   * This property is used to track changes in the time interval selector\n   * that are not triggered by direct user interaction, but by the application itself.\n   *\n   * In our case, the date selector and the interval selector are linked.\n   * So, when one of them changes, it affects the other.\n   * For example, selecting \"Last hour\" in the interval selector should automatically update the date range to the last hour.\n   * But without this flag, changing the date range would also update the interval selector, resulting in \"Custom date\" being selected.\n   * This happens because the system would interpret the behavior this way.\n   */\n  private isIntervalSelectorChangedProgrammatically = false;\n  private destroy$ = new Subject<void>();\n\n  constructor(\n    private datapointsTableService: DatapointsTableService,\n    private datapointsTableConfigService: DatapointsTableConfigService,\n    private formBuilder: FormBuilder,\n    private form: NgForm,\n    private widgetConfig: WidgetConfigComponent\n  ) {}\n\n  ngOnInit(): void {\n    if (this.widgetConfig.context?.id) {\n      this.datapointSelectionConfig.contextAsset = this.widgetConfig?.context;\n    }\n\n    this.isWidgetLinkedToGlobalTimeContext =\n      this.config.widgetInstanceGlobalAutoRefreshContext ?? true;\n\n    this.initForm();\n\n    this.handleAutoRefreshToggleChanges();\n    this.handleIntervalSelectorChanges();\n    this.handleDateSelectorChanges();\n    this.handleGlobalDateSelectorChanges();\n\n    this.disabledAggregationOptions =\n      this.datapointsTableConfigService.updateDisabledStateOfAggregationOptionEntries(\n        this.formGroup.controls.dateFrom.value,\n        this.formGroup.controls.dateTo.value,\n        AGGREGATION_VALUES_ARR\n      );\n  }\n\n  ngOnDestroy(): void {\n    this.destroy$.next();\n    this.destroy$.complete();\n  }\n\n  onBeforeSave(config?: DatapointsTableConfig): void {\n    if (\n      this.formGroup.value.aggregation === AGGREGATION_VALUES.none ||\n      (!this.formGroup.value.aggregation && config.aggregation === AGGREGATION_VALUES.none)\n    ) {\n      // The 'NONE' aggregation type is not handled by a backend, so it simply needs to be deleted to get data without aggregation.\n      this.deleteAggregationProperty(config);\n    }\n    this.updateTimeContext(config, this.formGroup.value.globalDateSelector);\n    Object.assign(config, this.formGroup.value);\n  }\n\n  toggleRefreshIntervalControl(): void {\n    this.formGroup.controls.isAutoRefreshEnabled.value\n      ? this.formGroup.controls.refreshInterval.disable()\n      : this.formGroup.controls.refreshInterval.enable();\n  }\n\n  private updateTimeContext(config: DatapointsTableConfig, selectedDateContext: string): void {\n    switch (selectedDateContext) {\n      case DATE_SELECTION_VALUES.dashboard_context:\n        config.displayDateSelection = false;\n        config.widgetInstanceGlobalAutoRefreshContext = true;\n        if (config.aggregation !== 'NONE') {\n          this.deleteAggregationProperty(config);\n        }\n        break;\n      case DATE_SELECTION_VALUES.view_and_config:\n        config.displayDateSelection = true;\n        config.widgetInstanceGlobalAutoRefreshContext = false;\n        break;\n      case DATE_SELECTION_VALUES.config:\n      default:\n        config.displayDateSelection = false;\n        config.widgetInstanceGlobalAutoRefreshContext = false;\n    }\n  }\n\n  private initForm(): void {\n    this.formGroup = this.createForm();\n    // When the 'NONE' aggregation is removed at the 'onBeforeSave' block,\n    // and a Global Date Context forces widgets auto refresh to be enabled\n    // then, the aggregation selector will be empty on initial load.\n    this.config.aggregation = this.config.aggregation ?? AGGREGATION_VALUES.none;\n\n    this.form.form.addControl('config', this.formGroup);\n    this.formGroup.patchValue(this.config);\n  }\n\n  private createForm() {\n    const { dateFrom, dateTo } = this.datapointsTableService.calculateDateRange(\n      this.DEFAULT_INTERVAL_VALUE\n    );\n    const isLegacyWidget =\n      this.config.hasOwnProperty('widgetInstanceGlobalTimeContext') &&\n      !this.config.hasOwnProperty('decimalPlaces');\n\n    return this.formBuilder.group(\n      {\n        aggregation: new FormControl({\n          value: AGGREGATION_VALUES.none as AggregationOption,\n          disabled: !this.isAutoRefershDisabled()\n        }),\n        datapoints: this.formBuilder.control(new Array<KPIDetails>(), [\n          Validators.required,\n          Validators.minLength(1),\n          minOneDatapointActive()\n        ]),\n        globalDateSelector: new FormControl(\n          isLegacyWidget\n            ? this.determineGlobalDateSelectorValueForLegacyWidget()\n            : this.DEFAULT_DATE_SELECTOR_VALUE\n        ),\n        dateFrom: new FormControl(dateFrom),\n        dateTo: new FormControl(dateTo),\n        decimalPlaces: [\n          2,\n          [\n            Validators.required,\n            Validators.min(this.decimalLimits.numberOfDecimalPlacesMin),\n            Validators.max(this.decimalLimits.numberOfDecimalPlacesMax),\n            Validators.pattern('^[0-9]+$')\n          ]\n        ],\n        interval: new FormControl(this.DEFAULT_INTERVAL_VALUE as TimeRangeInterval),\n        isAutoRefreshEnabled: isLegacyWidget ? this.config.realtime : [true],\n        refreshInterval: new FormControl({\n          value: DEFAULT_COUNTDOWN_VALUE,\n          disabled: this.isAutoRefershDisabled()\n        })\n      },\n      { validators: dateRangeValidator }\n    );\n  }\n\n  private determineGlobalDateSelectorValueForLegacyWidget(): string {\n    const { displayDateSelection, widgetInstanceGlobalAutoRefreshContext } = this.config;\n\n    // State of widgetInstanceGlobalTimeContext was converted to widgetInstanceGlobalAutoRefreshContext.\n    // That is why it use here in a legacy widget context.\n    if (widgetInstanceGlobalAutoRefreshContext) {\n      return DATE_SELECTION_VALUES.dashboard_context;\n    }\n\n    return displayDateSelection\n      ? DATE_SELECTION_VALUES.view_and_config\n      : DATE_SELECTION_VALUES.config;\n  }\n\n  private isAutoRefershDisabled(): boolean {\n    const isInitialWidgetCreation =\n      Object.keys(this.config).length === 1 && this.config['settings'];\n\n    if (isInitialWidgetCreation) {\n      return false;\n    }\n\n    const isLegacyWidgetRealtimeNotActive =\n      !this.config.realtime &&\n      !this.config.hasOwnProperty('decimalPlaces') &&\n      !this.config.hasOwnProperty('refreshInterval') &&\n      !this.config.hasOwnProperty('isAutoRefreshEnabled');\n\n    if (isLegacyWidgetRealtimeNotActive) {\n      return true;\n    }\n\n    return !this.config.isAutoRefreshEnabled;\n  }\n\n  /**\n   * Handles changes to the auto-refresh toggle control and updates the aggregation control accordingly.\n   *\n   * This method subscribes to the value changes of the auto-refresh toggle form control.\n   * When auto-refresh is enabled, the aggregation control's value is set to 'none' and the control is\n   * visually disabled (but not programmatically disabled to ensure the value is saved).\n   * When auto-refresh is disabled, the aggregation control is enabled.\n   */\n  private handleAutoRefreshToggleChanges(): void {\n    this.formGroup.controls.isAutoRefreshEnabled.valueChanges\n      .pipe(takeUntil(this.destroy$))\n      .subscribe((isAutoRefreshEnabled: boolean) => {\n        const aggregationControl = this.formGroup.controls.aggregation;\n        if (isAutoRefreshEnabled) {\n          aggregationControl.setValue(AGGREGATION_VALUES.none);\n          // Do not disable the control programmatically to ensure the value is saved.\n        } else {\n          aggregationControl.enable();\n        }\n      });\n  }\n\n  /**\n   * Handles changes in the interval selector form control.\n   */\n  private handleIntervalSelectorChanges(): void {\n    this.formGroup.controls.interval.valueChanges\n      .pipe(takeUntil(this.destroy$))\n      .subscribe((selectedInterval: TimeRangeInterval) => {\n        if (selectedInterval === TIME_RANGE_INTERVAL_UNITS_VALUES.custom) {\n          this.updateDisabledAggregationOptions();\n          return;\n        }\n\n        this.handleNonCustomInterval(selectedInterval);\n      });\n  }\n\n  private handleNonCustomInterval(selectedInterval: TimeRangeInterval): void {\n    this.isIntervalSelectorChangedProgrammatically = true;\n    this.updateDateRange(selectedInterval);\n    this.updateDisabledAggregationOptions();\n    this.updateAggregationIfAutoRefreshDisabled(selectedInterval);\n  }\n\n  private updateDateRange(selectedInterval: TimeRangeInterval): void {\n    const dateRange: DateRange = this.datapointsTableService.calculateDateRange(selectedInterval);\n    this.formGroup.controls.dateTo.setValue(dateRange.dateTo);\n\n    // MTM-61351\n    // Use requestAnimationFrame to queue the dateFrom update.\n    // This prevents timing issues where rapid setValue calls might\n    // cause the view to go out of sync with form control values,\n    // especially during the first change after initialization.\n    // requestAnimationFrame(() => {\n    /**\n     * Without this requestAnimationFrame or setTimeout, dateFrom won't change to a correct value after first selector change.\n     * When form is saved it saves with a correct value, even without with this fix.\n     * How to reproduce:\n     * 1. set date values to e.g.: 01.05.2024-30.05.2024 and save it\n     * 2. reopen a config and switch interval to last month\n     */\n    // This fix brakes a logic behind disabling non available aggregations.\n    // Form will be still saved with correct date value, only view is out of a sync.\n    this.formGroup.controls.dateFrom.setValue(dateRange.dateFrom);\n    this.isIntervalSelectorChangedProgrammatically = false;\n    // });\n  }\n\n  private updateDisabledAggregationOptions(): void {\n    this.disabledAggregationOptions =\n      this.datapointsTableConfigService.updateDisabledStateOfAggregationOptionEntries(\n        this.formGroup.controls.dateFrom.value,\n        this.formGroup.controls.dateTo.value,\n        AGGREGATION_VALUES_ARR\n      );\n  }\n\n  private updateAggregationIfAutoRefreshDisabled(selectedInterval: TimeRangeInterval): void {\n    const isAutoRefreshDisabled = !this.formGroup.controls.isAutoRefreshEnabled.value;\n    if (isAutoRefreshDisabled) {\n      this.setAggregationValue(selectedInterval);\n    }\n  }\n\n  private setAggregationValue(interval: TimeRangeInterval): void {\n    const aggregationControl = this.formGroup.controls.aggregation;\n\n    const newAggregationValue =\n      this.datapointsTableConfigService.determineAggregationValue(interval);\n    aggregationControl.setValue(newAggregationValue);\n  }\n\n  /**\n   * Handles changes in the date selector form control.\n   */\n  private handleDateSelectorChanges(): void {\n    merge(\n      this.formGroup.controls.dateFrom.valueChanges,\n      this.formGroup.controls.dateTo.valueChanges\n    )\n      .pipe(takeUntil(this.destroy$))\n      .subscribe(() => this.handleDateChange());\n  }\n\n  private handleDateChange(): void {\n    if (this.isIntervalSelectorChangedProgrammatically) {\n      return;\n    }\n\n    const intervalControl = this.formGroup.controls.interval;\n    if (intervalControl.value === TIME_RANGE_INTERVAL_UNITS_VALUES.custom) {\n      this.handleCustomIntervalDateChange();\n    } else {\n      this.setIntervalToCustom(intervalControl);\n    }\n    this.setToFirstAvailableAggregationOptionIfCurrentAggregationIsDisabled();\n  }\n\n  private handleCustomIntervalDateChange(): void {\n    this.updateDisabledAggregationOptions();\n  }\n\n  private setIntervalToCustom(intervalControl: AbstractControl): void {\n    intervalControl.setValue(TIME_RANGE_INTERVAL_UNITS_VALUES.custom);\n  }\n\n  /**\n   * Handles changes in the global date selector form control.\n   */\n  private handleGlobalDateSelectorChanges(): void {\n    this.formGroup.controls.globalDateSelector.valueChanges\n      .pipe(takeUntil(this.destroy$))\n      .subscribe((selected: string) => {\n        if (selected === DATE_SELECTION_VALUES.dashboard_context) {\n          this.handleDashboardContext();\n        } else {\n          this.handleNonDashboardContext();\n        }\n      });\n  }\n\n  private handleDashboardContext(): void {\n    this.isWidgetLinkedToGlobalTimeContext = true;\n  }\n\n  private handleNonDashboardContext(): void {\n    this.isWidgetLinkedToGlobalTimeContext = false;\n\n    if (this.isConfigSavedWithoutDashboardTimeOption()) {\n      return;\n    }\n\n    this.updateAggregationIfNecessary();\n    this.setIntervalToCustom(this.formGroup.controls.interval);\n  }\n\n  private isConfigSavedWithoutDashboardTimeOption(): boolean {\n    return !this.config.widgetInstanceGlobalAutoRefreshContext;\n  }\n\n  private updateAggregationIfNecessary(): void {\n    const aggregationControl = this.formGroup.controls.aggregation;\n    const isDashboardTimeOptionSetAggregationToNull = !aggregationControl.value;\n\n    if (isDashboardTimeOptionSetAggregationToNull) {\n      aggregationControl.setValue(AGGREGATION_VALUES.none);\n    }\n  }\n\n  /**\n   * Sets the aggregation control to the first available (non-disabled) option if the current option is disabled.\n   *\n   * This method:\n   * - Retrieves the current value of the aggregation control.\n   * - Checks if the current aggregation option is disabled.\n   * - If the current option is disabled, sets the control to the first available (non-disabled) option based on the following order:\n   *   - If the current value is `DAILY`, it switches to `HOURLY` if it's not disabled, otherwise to `MINUTELY` if `HOURLY` is also disabled.\n   *   - If the current value is `HOURLY`, it switches to `MINUTELY` if it's not disabled.\n   *   - If all options are disabled, it sets the value to `NONE`.\n   *\n   * The disabled state is stored in the `disabledAggregationOptions` object,\n   * where the key is the aggregation value and the value is a boolean indicating whether the option is disabled.\n   *\n   * The `AGGREGATION_VALUES` object defines the possible aggregation values.\n   */\n  // TODO same method is in datapoints export component. Consider moving it to a shared service when DPT will be integrating with MTM-59689.\n  // TODO 'determineNewAggregationValue' will be a shared method.\n  // Integration task: MTM-60221\n  private setToFirstAvailableAggregationOptionIfCurrentAggregationIsDisabled(): void {\n    const aggregationControl = this.formGroup.controls.aggregation;\n    const currentValue = aggregationControl.value;\n\n    const newAggregationValue = this.datapointsTableConfigService.determineNewAggregationValue(\n      currentValue,\n      this.disabledAggregationOptions\n    );\n\n    if (newAggregationValue !== currentValue) {\n      aggregationControl.setValue(newAggregationValue);\n    }\n  }\n\n  private deleteAggregationProperty(config: DatapointsTableConfig): void {\n    delete this.formGroup.value.aggregation;\n    delete config.aggregation;\n  }\n}\n","<div class=\"p-l-24 p-r-24\">\n  <form\n    class=\"no-card-context\"\n    [formGroup]=\"formGroup\"\n  >\n    <!-- <datapoints-selector> -->\n    <div class=\"col-md-6\">\n      <div class=\"row\">\n        <!-- global-time-context-selector -->\n        <div class=\"form-group m-b-0 p-b-16 separator-bottom\">\n          <label\n            class=\"d-flex a-i-center p-t-4\"\n            for=\"dateSelection\"\n          >\n            {{ 'Date selection' | translate }}\n            <button\n              class=\"btn-help btn-help--sm\"\n              [attr.aria-label]=\"'Help' | translate\"\n              [popover]=\"popoverTemplate\"\n              placement=\"right\"\n              triggers=\"focus\"\n              container=\"body\"\n              type=\"button\"\n              [adaptivePosition]=\"true\"\n            ></button>\n          </label>\n          <ng-template #popoverTemplate>\n            <span translate>\n              Choose how to select a date range, the available options are:\n              <ul class=\"m-l-0 p-l-8 m-t-8 m-b-0\">\n                <li>\n                  <b>Dashboard time range:</b>\n                  restricts date selection to the global dashboard configuration only\n                </li>\n                <li>\n                  <b>Widget configuration:</b>\n                  restricts the date selection only to the widget configuration\n                </li>\n                <li>\n                  <b>Widget and widget configuration:</b>\n                  restricts the date selection to the widget view and widget configuration only\n                </li>\n              </ul>\n            </span>\n          </ng-template>\n          <div class=\"c8y-select-wrapper\">\n            <select\n              class=\"form-control text-12\"\n              [title]=\"'Date selection' | translate\"\n              [attr.aria-label]=\"'Date selection' | translate\"\n              id=\"globalDateSelector\"\n              formControlName=\"globalDateSelector\"\n            >\n              <option\n                *ngFor=\"let dataSelectionValue of DATE_SELECTION_VALUES_ARR\"\n                [ngValue]=\"dataSelectionValue\"\n              >\n                {{ DATE_SELECTION_LABELS[dataSelectionValue] | translate }}\n              </option>\n            </select>\n          </div>\n        </div>\n      </div>\n      <div class=\"row\">\n        <c8y-datapoint-selection-list\n          class=\"bg-inherit separator-top p-t-16 d-block\"\n          listTitle=\"{{ 'Data points' | translate }}\"\n          name=\"datapoints\"\n          [defaultFormOptions]=\"defaultFormOptions\"\n          [config]=\"datapointSelectionConfig\"\n          [minActiveCount]=\"1\"\n          formControlName=\"datapoints\"\n        ></c8y-datapoint-selection-list>\n      </div>\n    </div>\n    <div class=\"col-md-6\">\n      <div class=\"row\">\n        <ng-container *ngIf=\"!isWidgetLinkedToGlobalTimeContext\">\n          <div class=\"col-md-6\">\n            <!-- interval selector -->\n            <fieldset class=\"c8y-fieldset\">\n              <legend class=\"d-flex a-i-center\">\n                {{ 'Auto refresh' | translate }}\n                <button\n                  class=\"btn-help btn-help--sm\"\n                  [attr.aria-label]=\"'Help' | translate\"\n                  [popover]=\"\n                    'Change the state of interval automatic refresh and set the refresh frequency.'\n                      | translate\n                  \"\n                  placement=\"top\"\n                  triggers=\"focus\"\n                  container=\"body\"\n                  type=\"button\"\n                  [adaptivePosition]=\"true\"\n                ></button>\n              </legend>\n              <c8y-form-group class=\"m-b-16 form-group-sm\">\n                <div class=\"d-flex gap-4 m-t-8 m-b-8 a-i-center\">\n                  <label class=\"c8y-switch\">\n                    <input\n                      id=\"refreshToggle\"\n                      name=\"isAutoRefreshEnabled\"\n                      type=\"checkbox\"\n                      formControlName=\"isAutoRefreshEnabled\"\n                      (click)=\"toggleRefreshIntervalControl()\"\n                    />\n                    <span></span>\n                    <span class=\"sr-only\">{{ 'Auto refresh' | translate }}</span>\n                  </label>\n                  <label\n                    class=\"m-b-0\"\n                    for=\"refreshInterval\"\n                  >\n                    {{ 'Interval' | translate }}\n                  </label>\n                  <div class=\"c8y-select-wrapper\">\n                    <select\n                      class=\"form-control text-12\"\n                      [title]=\"'Refresh interval in seconds' | translate\"\n                      id=\"refreshInterval\"\n                      formControlName=\"refreshInterval\"\n                    >\n                      <option\n                        *ngFor=\"let refreshInterval of REFRESH_INTERVAL_VALUES_ARR\"\n                        [ngValue]=\"refreshInterval\"\n                      >\n                        {{ '{{ seconds }} s' | translate: { seconds: refreshInterval / 1000 } }}\n                      </option>\n                    </select>\n                  </div>\n                </div>\n              </c8y-form-group>\n            </fieldset>\n          </div>\n        </ng-container>\n        <!-- decimal input -->\n        <div class=\"col-md-6\">\n          <fieldset class=\"c8y-fieldset\">\n            <legend>\n              {{ 'Decimal places' | translate }}\n            </legend>\n            <c8y-form-group class=\"p-t-8\">\n              <input\n                class=\"form-control\"\n                name=\"decimalPlaces\"\n                type=\"number\"\n                formControlName=\"decimalPlaces\"\n                step=\"1\"\n              />\n            </c8y-form-group>\n          </fieldset>\n        </div>\n      </div>\n      <!-- aggregation selector -->\n      <div class=\"row\">\n        <ng-container *ngIf=\"!isWidgetLinkedToGlobalTimeContext\">\n          <div class=\"col-md-6\">\n            <fieldset class=\"c8y-fieldset\">\n              <legend>\n                {{ 'Aggregation' | translate }}\n              </legend>\n              <c8y-form-group class=\"p-t-8\">\n                <div class=\"c8y-select-wrapper\">\n                  <!-- Setting below [attr.disabled] ensures that the control is visually disabled and user interaction is prevented,\n               while still allowing the value to be updated and saved correctly in the form.\n               This solution covers the case where the user enables auto-refresh, in which case aggregation must be set to NONE. -->\n                  <select\n                    class=\"form-control text-12\"\n                    [title]=\"'Aggregation' | translate\"\n                    id=\"aggregation\"\n                    formControlName=\"aggregation\"\n                    [attr.disabled]=\"formGroup.value.isAutoRefreshEnabled ? true : null\"\n                  >\n                    <option\n                      *ngFor=\"let aggregationValue of AGGREGATION_VALUES_ARR\"\n                      [ngValue]=\"aggregationValue\"\n                      [disabled]=\"disabledAggregationOptions[aggregationValue]\"\n                    >\n                      {{ AGGREGATION_LABELS[aggregationValue] | translate }}\n                    </option>\n                  </select>\n                </div>\n              </c8y-form-group>\n            </fieldset>\n          </div>\n        </ng-container>\n        <!-- time interval selector -->\n        <div class=\"col-md-6\">\n          <fieldset class=\"c8y-fieldset\">\n            <legend>\n              {{ 'Time interval' | translate }}\n            </legend>\n            <c8y-form-group class=\"p-t-8\">\n              <div class=\"c8y-select-wrapper\">\n                <select\n                  class=\"form-control text-12\"\n                  [title]=\"'Interval' | translate\"\n                  id=\"interval\"\n                  formControlName=\"interval\"\n                >\n                  <option\n                    *ngFor=\"let intervalValue of INTERVAL_VALUES_ARR\"\n                    [ngValue]=\"intervalValue\"\n                  >\n                    {{ TIME_RANGE_INTERVAL_LABELS[intervalValue] | translate }}\n                  </option>\n                </select>\n              </div>\n            </c8y-form-group>\n          </fieldset>\n        </div>\n      </div>\n      <!-- date pickers -->\n      <fieldset class=\"c8y-fieldset\">\n        <legend>\n          {{ 'Date range' | translate }}\n        </legend>\n        <c8y-date-range-picker></c8y-date-range-picker>\n      </fieldset>\n    </div>\n  </form>\n</div>\n"]}
|
|
388
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datapoints-table-config.component.js","sourceRoot":"","sources":["../../../../../../widgets/implementations/datapoints-table/datapoints-table-config/datapoints-table-config.component.ts","../../../../../../widgets/implementations/datapoints-table/datapoints-table-config/datapoints-table-config.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnDestroy, OnInit } from '@angular/core';\nimport {\n  AbstractControl,\n  FormBuilder,\n  FormControl,\n  NgForm,\n  ReactiveFormsModule,\n  ValidationErrors,\n  ValidatorFn,\n  Validators\n} from '@angular/forms';\nimport {\n  AGGREGATION_LABELS,\n  AGGREGATION_VALUES,\n  AGGREGATION_VALUES_ARR,\n  AggregationOption,\n  AggregationOptionStatus,\n  CoreModule\n} from '@c8y/ngx-components';\nimport { WidgetConfigComponent } from '@c8y/ngx-components/context-dashboard';\nimport {\n  DatapointAttributesFormConfig,\n  DatapointSelectorModalOptions,\n  DatapointSelectorModule,\n  KPIDetails\n} from '@c8y/ngx-components/datapoint-selector';\nimport {\n  dateRangeValidator,\n  TIME_RANGE_INTERVAL_UNITS_VALUES,\n  TimeRangeInterval\n} from '@c8y/ngx-components/datapoints-export-selector';\nimport { INTERVAL_VALUES } from '@c8y/ngx-components/interval-picker';\nimport { PopoverModule } from 'ngx-bootstrap/popover';\nimport { merge, Subject, takeUntil } from 'rxjs';\nimport {\n  DatapointsTableConfig,\n  DATE_SELECTION_LABELS,\n  DATE_SELECTION_VALUES,\n  DATE_SELECTION_VALUES_ARR,\n  DateRange,\n  DEFAULT_COUNTDOWN_VALUE,\n  INTERVAL_VALUES_ARR,\n  REFRESH_INTERVAL_VALUES_ARR,\n  TIME_RANGE_INTERVAL_LABELS\n} from '../datapoints-table-widget.model';\nimport { DatapointsTableService } from '../datapoints-table.service';\nimport { DateRangePickerComponent } from '../date-range-picker.component';\nimport { DatapointsTableConfigService } from './datapoints-table-config.service';\n\nexport function minOneDatapointActive(): ValidatorFn {\n  return (control: AbstractControl): ValidationErrors | null => {\n    const datapoints: KPIDetails[] = control.value;\n\n    if (!datapoints || !datapoints.length) {\n      return null;\n    }\n\n    const activeDatapoints = datapoints.filter(datapoint => datapoint.__active);\n\n    if (activeDatapoints.length >= 1) {\n      return null;\n    }\n    return { exactlyOneDatapointNeedsToBeActive: true };\n  };\n}\n\n@Component({\n  selector: 'c8y-datapoints-table-view-config',\n  templateUrl: './datapoints-table-config.component.html',\n  standalone: true,\n  imports: [\n    CoreModule,\n    DatapointSelectorModule,\n    DateRangePickerComponent,\n    PopoverModule,\n    ReactiveFormsModule\n  ]\n})\nexport class DatapointsTableWidgetConfigComponent implements OnInit, OnDestroy {\n  /**\n   *  Data points table widget config.\n   */\n  @Input() config: DatapointsTableConfig;\n\n  readonly AGGREGATION_LABELS = AGGREGATION_LABELS;\n  readonly DATE_SELECTION_LABELS = DATE_SELECTION_LABELS;\n  readonly DEFAULT_DATE_SELECTOR_VALUE = DATE_SELECTION_VALUES.dashboard_context;\n  readonly DEFAULT_INTERVAL_VALUE = INTERVAL_VALUES.hours;\n  readonly TIME_RANGE_INTERVAL_LABELS = TIME_RANGE_INTERVAL_LABELS;\n\n  readonly AGGREGATION_VALUES_ARR = AGGREGATION_VALUES_ARR;\n  readonly DATE_SELECTION_VALUES_ARR = DATE_SELECTION_VALUES_ARR;\n  readonly INTERVAL_VALUES_ARR = INTERVAL_VALUES_ARR;\n  readonly REFRESH_INTERVAL_VALUES_ARR = REFRESH_INTERVAL_VALUES_ARR;\n\n  datapointSelectionConfig: Partial<DatapointSelectorModalOptions> = {};\n  disabledAggregationOptions: AggregationOptionStatus = {};\n  defaultFormOptions: Partial<DatapointAttributesFormConfig> = {\n    selectableChartLineTypes: [],\n    selectableAxisTypes: [],\n    showRedRange: true,\n    showYellowRange: true\n  };\n  formGroup: ReturnType<DatapointsTableWidgetConfigComponent['createForm']>;\n  isWidgetLinkedToGlobalTimeContext: boolean;\n\n  private decimalLimits = {\n    numberOfDecimalPlacesMin: 0,\n    numberOfDecimalPlacesMax: 10\n  } as const;\n\n  /**\n   * Indicate when the time interval selector item has been changed programmatically.\n   *\n   * This property is used to track changes in the time interval selector\n   * that are not triggered by direct user interaction, but by the application itself.\n   *\n   * In our case, the date selector and the interval selector are linked.\n   * So, when one of them changes, it affects the other.\n   * For example, selecting \"Last hour\" in the interval selector should automatically update the date range to the last hour.\n   * But without this flag, changing the date range would also update the interval selector, resulting in \"Custom date\" being selected.\n   * This happens because the system would interpret the behavior this way.\n   */\n  private isIntervalSelectorChangedProgrammatically = false;\n  private destroy$ = new Subject<void>();\n\n  constructor(\n    private datapointsTableService: DatapointsTableService,\n    private datapointsTableConfigService: DatapointsTableConfigService,\n    private formBuilder: FormBuilder,\n    private form: NgForm,\n    private widgetConfig: WidgetConfigComponent\n  ) {}\n\n  ngOnInit(): void {\n    if (this.widgetConfig.context?.id) {\n      this.datapointSelectionConfig.contextAsset = this.widgetConfig?.context;\n    }\n\n    this.isWidgetLinkedToGlobalTimeContext =\n      this.config.widgetInstanceGlobalAutoRefreshContext ?? true;\n\n    this.initForm();\n\n    this.handleAutoRefreshToggleChanges();\n    this.handleIntervalSelectorChanges();\n    this.handleDateSelectorChanges();\n    this.handleGlobalDateSelectorChanges();\n\n    this.disabledAggregationOptions =\n      this.datapointsTableConfigService.updateDisabledStateOfAggregationOptionEntries(\n        this.formGroup.controls.dateFrom.value,\n        this.formGroup.controls.dateTo.value,\n        AGGREGATION_VALUES_ARR\n      );\n  }\n\n  ngOnDestroy(): void {\n    this.destroy$.next();\n    this.destroy$.complete();\n  }\n\n  onBeforeSave(config?: DatapointsTableConfig): void {\n    if (\n      this.formGroup.value.aggregation === AGGREGATION_VALUES.none ||\n      (!this.formGroup.value.aggregation && config.aggregation === AGGREGATION_VALUES.none)\n    ) {\n      // The 'NONE' aggregation type is not handled by a backend, so it simply needs to be deleted to get data without aggregation.\n      this.deleteAggregationProperty(config);\n    }\n    this.updateTimeContext(config, this.formGroup.value.globalDateSelector);\n    Object.assign(config, this.formGroup.value);\n  }\n\n  toggleRefreshIntervalControl(): void {\n    this.formGroup.controls.isAutoRefreshEnabled.value\n      ? this.formGroup.controls.refreshInterval.disable()\n      : this.formGroup.controls.refreshInterval.enable();\n  }\n\n  private updateTimeContext(config: DatapointsTableConfig, selectedDateContext: string): void {\n    switch (selectedDateContext) {\n      case DATE_SELECTION_VALUES.dashboard_context:\n        config.displayDateSelection = false;\n        config.widgetInstanceGlobalAutoRefreshContext = true;\n        if (config.aggregation !== 'NONE') {\n          this.deleteAggregationProperty(config);\n        }\n        break;\n      case DATE_SELECTION_VALUES.view_and_config:\n        config.displayDateSelection = true;\n        config.widgetInstanceGlobalAutoRefreshContext = false;\n        break;\n      case DATE_SELECTION_VALUES.config:\n      default:\n        config.displayDateSelection = false;\n        config.widgetInstanceGlobalAutoRefreshContext = false;\n    }\n  }\n\n  private initForm(): void {\n    this.formGroup = this.createForm();\n    // When the 'NONE' aggregation is removed at the 'onBeforeSave' block,\n    // and a Global Date Context forces widgets auto refresh to be enabled\n    // then, the aggregation selector will be empty on initial load.\n    this.config.aggregation = this.config.aggregation ?? AGGREGATION_VALUES.none;\n\n    this.form.form.addControl('config', this.formGroup);\n    this.formGroup.patchValue(this.config);\n  }\n\n  private createForm() {\n    const { dateFrom, dateTo } = this.datapointsTableService.calculateDateRange(\n      this.DEFAULT_INTERVAL_VALUE\n    );\n    const isLegacyWidget =\n      this.config.hasOwnProperty('widgetInstanceGlobalTimeContext') &&\n      !this.config.hasOwnProperty('decimalPlaces');\n\n    return this.formBuilder.group(\n      {\n        aggregation: new FormControl({\n          value: AGGREGATION_VALUES.none as AggregationOption,\n          disabled: !this.isAutoRefershDisabled()\n        }),\n        datapoints: this.formBuilder.control(new Array<KPIDetails>(), [\n          Validators.required,\n          Validators.minLength(1),\n          minOneDatapointActive()\n        ]),\n        globalDateSelector: new FormControl(\n          isLegacyWidget\n            ? this.determineGlobalDateSelectorValueForLegacyWidget()\n            : this.DEFAULT_DATE_SELECTOR_VALUE\n        ),\n        dateFrom: new FormControl(dateFrom),\n        dateTo: new FormControl(dateTo),\n        decimalPlaces: [\n          2,\n          [\n            Validators.required,\n            Validators.min(this.decimalLimits.numberOfDecimalPlacesMin),\n            Validators.max(this.decimalLimits.numberOfDecimalPlacesMax),\n            Validators.pattern('^[0-9]+$')\n          ]\n        ],\n        interval: new FormControl(this.DEFAULT_INTERVAL_VALUE as TimeRangeInterval),\n        isAutoRefreshEnabled: isLegacyWidget ? this.config.realtime : [true],\n        refreshInterval: new FormControl({\n          value: DEFAULT_COUNTDOWN_VALUE,\n          disabled: this.isAutoRefershDisabled()\n        })\n      },\n      { validators: dateRangeValidator }\n    );\n  }\n\n  private determineGlobalDateSelectorValueForLegacyWidget(): string {\n    const { displayDateSelection, widgetInstanceGlobalAutoRefreshContext } = this.config;\n\n    // State of widgetInstanceGlobalTimeContext was converted to widgetInstanceGlobalAutoRefreshContext.\n    // That is why it use here in a legacy widget context.\n    if (widgetInstanceGlobalAutoRefreshContext) {\n      return DATE_SELECTION_VALUES.dashboard_context;\n    }\n\n    return displayDateSelection\n      ? DATE_SELECTION_VALUES.view_and_config\n      : DATE_SELECTION_VALUES.config;\n  }\n\n  private isAutoRefershDisabled(): boolean {\n    const isInitialWidgetCreation =\n      Object.keys(this.config).length === 1 && this.config['settings'];\n\n    if (isInitialWidgetCreation) {\n      return false;\n    }\n\n    const isLegacyWidgetRealtimeNotActive =\n      !this.config.realtime &&\n      !this.config.hasOwnProperty('decimalPlaces') &&\n      !this.config.hasOwnProperty('refreshInterval') &&\n      !this.config.hasOwnProperty('isAutoRefreshEnabled');\n\n    if (isLegacyWidgetRealtimeNotActive) {\n      return true;\n    }\n\n    return !this.config.isAutoRefreshEnabled;\n  }\n\n  /**\n   * Handles changes to the auto-refresh toggle control and updates the aggregation control accordingly.\n   *\n   * This method subscribes to the value changes of the auto-refresh toggle form control.\n   * When auto-refresh is enabled, the aggregation control's value is set to 'none' and the control is\n   * visually disabled (but not programmatically disabled to ensure the value is saved).\n   * When auto-refresh is disabled, the aggregation control is enabled.\n   */\n  private handleAutoRefreshToggleChanges(): void {\n    this.formGroup.controls.isAutoRefreshEnabled.valueChanges\n      .pipe(takeUntil(this.destroy$))\n      .subscribe((isAutoRefreshEnabled: boolean) => {\n        const aggregationControl = this.formGroup.controls.aggregation;\n        if (isAutoRefreshEnabled) {\n          aggregationControl.setValue(AGGREGATION_VALUES.none);\n          // Do not disable the control programmatically to ensure the value is saved.\n        } else {\n          aggregationControl.enable();\n        }\n      });\n  }\n\n  /**\n   * Handles changes in the interval selector form control.\n   */\n  private handleIntervalSelectorChanges(): void {\n    this.formGroup.controls.interval.valueChanges\n      .pipe(takeUntil(this.destroy$))\n      .subscribe((selectedInterval: TimeRangeInterval) => {\n        if (selectedInterval === TIME_RANGE_INTERVAL_UNITS_VALUES.custom) {\n          this.updateDisabledAggregationOptions();\n          return;\n        }\n\n        this.handleNonCustomInterval(selectedInterval);\n      });\n  }\n\n  private handleNonCustomInterval(selectedInterval: TimeRangeInterval): void {\n    this.isIntervalSelectorChangedProgrammatically = true;\n    this.updateDateRange(selectedInterval);\n    this.updateDisabledAggregationOptions();\n    this.updateAggregationIfAutoRefreshDisabled(selectedInterval);\n  }\n\n  private updateDateRange(selectedInterval: TimeRangeInterval): void {\n    const dateRange: DateRange = this.datapointsTableService.calculateDateRange(selectedInterval);\n    this.formGroup.controls.dateTo.setValue(dateRange.dateTo);\n\n    // MTM-61351\n    // Use requestAnimationFrame to queue the dateFrom update.\n    // This prevents timing issues where rapid setValue calls might\n    // cause the view to go out of sync with form control values,\n    // especially during the first change after initialization.\n    // requestAnimationFrame(() => {\n    /**\n     * Without this requestAnimationFrame or setTimeout, dateFrom won't change to a correct value after first selector change.\n     * When form is saved it saves with a correct value, even without with this fix.\n     * How to reproduce:\n     * 1. set date values to e.g.: 01.05.2024-30.05.2024 and save it\n     * 2. reopen a config and switch interval to last month\n     */\n    // This fix brakes a logic behind disabling non available aggregations.\n    // Form will be still saved with correct date value, only view is out of a sync.\n    this.formGroup.controls.dateFrom.setValue(dateRange.dateFrom);\n    this.isIntervalSelectorChangedProgrammatically = false;\n    // });\n  }\n\n  private updateDisabledAggregationOptions(): void {\n    this.disabledAggregationOptions =\n      this.datapointsTableConfigService.updateDisabledStateOfAggregationOptionEntries(\n        this.formGroup.controls.dateFrom.value,\n        this.formGroup.controls.dateTo.value,\n        AGGREGATION_VALUES_ARR\n      );\n  }\n\n  private updateAggregationIfAutoRefreshDisabled(selectedInterval: TimeRangeInterval): void {\n    const isAutoRefreshDisabled = !this.formGroup.controls.isAutoRefreshEnabled.value;\n    if (isAutoRefreshDisabled) {\n      this.setAggregationValue(selectedInterval);\n    }\n  }\n\n  private setAggregationValue(interval: TimeRangeInterval): void {\n    const aggregationControl = this.formGroup.controls.aggregation;\n\n    const newAggregationValue =\n      this.datapointsTableConfigService.determineAggregationValue(interval);\n    aggregationControl.setValue(newAggregationValue);\n  }\n\n  /**\n   * Handles changes in the date selector form control.\n   */\n  private handleDateSelectorChanges(): void {\n    merge(\n      this.formGroup.controls.dateFrom.valueChanges,\n      this.formGroup.controls.dateTo.valueChanges\n    )\n      .pipe(takeUntil(this.destroy$))\n      .subscribe(() => this.handleDateChange());\n  }\n\n  private handleDateChange(): void {\n    if (this.isIntervalSelectorChangedProgrammatically) {\n      return;\n    }\n\n    const intervalControl = this.formGroup.controls.interval;\n    if (intervalControl.value === TIME_RANGE_INTERVAL_UNITS_VALUES.custom) {\n      this.handleCustomIntervalDateChange();\n    } else {\n      this.setIntervalToCustom(intervalControl);\n    }\n    this.setToFirstAvailableAggregationOptionIfCurrentAggregationIsDisabled();\n  }\n\n  private handleCustomIntervalDateChange(): void {\n    this.updateDisabledAggregationOptions();\n  }\n\n  private setIntervalToCustom(intervalControl: AbstractControl): void {\n    intervalControl.setValue(TIME_RANGE_INTERVAL_UNITS_VALUES.custom);\n  }\n\n  /**\n   * Handles changes in the global date selector form control.\n   */\n  private handleGlobalDateSelectorChanges(): void {\n    this.formGroup.controls.globalDateSelector.valueChanges\n      .pipe(takeUntil(this.destroy$))\n      .subscribe((selected: string) => {\n        if (selected === DATE_SELECTION_VALUES.dashboard_context) {\n          this.handleDashboardContext();\n        } else {\n          this.handleNonDashboardContext();\n        }\n      });\n  }\n\n  private handleDashboardContext(): void {\n    this.isWidgetLinkedToGlobalTimeContext = true;\n  }\n\n  private handleNonDashboardContext(): void {\n    this.isWidgetLinkedToGlobalTimeContext = false;\n\n    if (this.isConfigSavedWithoutDashboardTimeOption()) {\n      return;\n    }\n\n    this.updateAggregationIfNecessary();\n    this.setIntervalToCustom(this.formGroup.controls.interval);\n  }\n\n  private isConfigSavedWithoutDashboardTimeOption(): boolean {\n    return !this.config.widgetInstanceGlobalAutoRefreshContext;\n  }\n\n  private updateAggregationIfNecessary(): void {\n    const aggregationControl = this.formGroup.controls.aggregation;\n    const isDashboardTimeOptionSetAggregationToNull = !aggregationControl.value;\n\n    if (isDashboardTimeOptionSetAggregationToNull) {\n      aggregationControl.setValue(AGGREGATION_VALUES.none);\n    }\n  }\n\n  /**\n   * Sets the aggregation control to the first available (non-disabled) option if the current option is disabled.\n   *\n   * This method:\n   * - Retrieves the current value of the aggregation control.\n   * - Checks if the current aggregation option is disabled.\n   * - If the current option is disabled, sets the control to the first available (non-disabled) option based on the following order:\n   *   - If the current value is `DAILY`, it switches to `HOURLY` if it's not disabled, otherwise to `MINUTELY` if `HOURLY` is also disabled.\n   *   - If the current value is `HOURLY`, it switches to `MINUTELY` if it's not disabled.\n   *   - If all options are disabled, it sets the value to `NONE`.\n   *\n   * The disabled state is stored in the `disabledAggregationOptions` object,\n   * where the key is the aggregation value and the value is a boolean indicating whether the option is disabled.\n   *\n   * The `AGGREGATION_VALUES` object defines the possible aggregation values.\n   */\n  // TODO same method is in datapoints export component. Consider moving it to a shared service when DPT will be integrating with MTM-59689.\n  // TODO 'determineNewAggregationValue' will be a shared method.\n  // Integration task: MTM-60221\n  private setToFirstAvailableAggregationOptionIfCurrentAggregationIsDisabled(): void {\n    const aggregationControl = this.formGroup.controls.aggregation;\n    const currentValue = aggregationControl.value;\n\n    const newAggregationValue = this.datapointsTableConfigService.determineNewAggregationValue(\n      currentValue,\n      this.disabledAggregationOptions\n    );\n\n    if (newAggregationValue !== currentValue) {\n      aggregationControl.setValue(newAggregationValue);\n    }\n  }\n\n  private deleteAggregationProperty(config: DatapointsTableConfig): void {\n    delete this.formGroup.value.aggregation;\n    delete config.aggregation;\n  }\n}\n","<div class=\"p-l-24 p-r-24\">\n  <form\n    class=\"no-card-context\"\n    [formGroup]=\"formGroup\"\n  >\n    <!-- <datapoints-selector> -->\n    <div class=\"col-md-6\">\n      <div class=\"row\">\n        <!-- global-time-context-selector -->\n        <div class=\"form-group m-b-0 p-b-16 separator-bottom\">\n          <label\n            class=\"d-flex a-i-center p-t-4\"\n            for=\"dateSelection\"\n          >\n            {{ 'Date selection' | translate }}\n            <button\n              class=\"btn-help btn-help--sm\"\n              [attr.aria-label]=\"'Help' | translate\"\n              [popover]=\"popoverTemplate\"\n              placement=\"right\"\n              triggers=\"focus\"\n              container=\"body\"\n              type=\"button\"\n              [adaptivePosition]=\"true\"\n            ></button>\n          </label>\n          <ng-template #popoverTemplate>\n            <span translate>\n              Choose how to select a date range, the available options are:\n              <ul class=\"m-l-0 p-l-8 m-t-8 m-b-0\">\n                <li>\n                  <b>Dashboard time range:</b>\n                  restricts date selection to the global dashboard configuration only\n                </li>\n                <li>\n                  <b>Widget configuration:</b>\n                  restricts the date selection only to the widget configuration\n                </li>\n                <li>\n                  <b>Widget and widget configuration:</b>\n                  restricts the date selection to the widget view and widget configuration only\n                </li>\n              </ul>\n            </span>\n          </ng-template>\n          <div class=\"c8y-select-wrapper\">\n            <select\n              class=\"form-control text-12\"\n              [title]=\"'Date selection' | translate\"\n              [attr.aria-label]=\"'Date selection' | translate\"\n              id=\"globalDateSelector\"\n              formControlName=\"globalDateSelector\"\n            >\n              <option\n                *ngFor=\"let dataSelectionValue of DATE_SELECTION_VALUES_ARR\"\n                [ngValue]=\"dataSelectionValue\"\n              >\n                {{ DATE_SELECTION_LABELS[dataSelectionValue] | translate }}\n              </option>\n            </select>\n          </div>\n        </div>\n      </div>\n      <div class=\"row\">\n        <c8y-datapoint-selection-list\n          class=\"bg-inherit separator-top p-t-16 d-block\"\n          listTitle=\"{{ 'Data points' | translate }}\"\n          name=\"datapoints\"\n          [defaultFormOptions]=\"defaultFormOptions\"\n          [config]=\"datapointSelectionConfig\"\n          [minActiveCount]=\"1\"\n          formControlName=\"datapoints\"\n        ></c8y-datapoint-selection-list>\n      </div>\n    </div>\n    <div class=\"col-md-6\">\n      <div class=\"row\">\n        <ng-container *ngIf=\"!isWidgetLinkedToGlobalTimeContext\">\n          <div class=\"col-md-6\">\n            <!-- interval selector -->\n            <fieldset class=\"c8y-fieldset\">\n              <legend class=\"d-flex a-i-center\">\n                {{ 'Auto refresh' | translate }}\n                <button\n                  class=\"btn-help btn-help--sm\"\n                  [attr.aria-label]=\"'Help' | translate\"\n                  [popover]=\"\n                    'Change the state of interval automatic refresh and set the refresh frequency.'\n                      | translate\n                  \"\n                  placement=\"top\"\n                  triggers=\"focus\"\n                  container=\"body\"\n                  type=\"button\"\n                  [adaptivePosition]=\"true\"\n                ></button>\n              </legend>\n              <c8y-form-group class=\"m-b-16 form-group-sm\">\n                <div class=\"d-flex gap-4 m-t-8 m-b-8 a-i-center\">\n                  <label class=\"c8y-switch\">\n                    <input\n                      id=\"refreshToggle\"\n                      name=\"isAutoRefreshEnabled\"\n                      type=\"checkbox\"\n                      formControlName=\"isAutoRefreshEnabled\"\n                      (click)=\"toggleRefreshIntervalControl()\"\n                    />\n                    <span></span>\n                    <span class=\"sr-only\">{{ 'Auto refresh' | translate }}</span>\n                  </label>\n                  <label\n                    class=\"m-b-0\"\n                    for=\"refreshInterval\"\n                  >\n                    {{ 'Interval' | translate }}\n                  </label>\n                  <div class=\"c8y-select-wrapper\">\n                    <select\n                      class=\"form-control text-12\"\n                      [title]=\"'Refresh interval in seconds' | translate\"\n                      id=\"refreshInterval\"\n                      formControlName=\"refreshInterval\"\n                    >\n                      <option\n                        *ngFor=\"let refreshInterval of REFRESH_INTERVAL_VALUES_ARR\"\n                        [ngValue]=\"refreshInterval\"\n                      >\n                        {{ '{{ seconds }} s' | translate: { seconds: refreshInterval / 1000 } }}\n                      </option>\n                    </select>\n                  </div>\n                </div>\n              </c8y-form-group>\n            </fieldset>\n          </div>\n        </ng-container>\n        <!-- decimal input -->\n        <div class=\"col-md-6\">\n          <fieldset class=\"c8y-fieldset\">\n            <legend>\n              {{ 'Decimal places' | translate }}\n            </legend>\n            <c8y-form-group class=\"p-t-8\">\n              <input\n                class=\"form-control\"\n                name=\"decimalPlaces\"\n                type=\"number\"\n                formControlName=\"decimalPlaces\"\n                step=\"1\"\n              />\n            </c8y-form-group>\n          </fieldset>\n        </div>\n      </div>\n      <!-- aggregation selector -->\n      <div class=\"row\">\n        <ng-container *ngIf=\"!isWidgetLinkedToGlobalTimeContext\">\n          <div class=\"col-md-6\">\n            <fieldset class=\"c8y-fieldset\">\n              <legend>\n                {{ 'Aggregation' | translate }}\n              </legend>\n              <c8y-form-group class=\"p-t-8\">\n                <div class=\"c8y-select-wrapper\">\n                  <!-- Setting below [attr.disabled] ensures that the control is visually disabled and user interaction is prevented,\n               while still allowing the value to be updated and saved correctly in the form.\n               This solution covers the case where the user enables auto-refresh, in which case aggregation must be set to NONE. -->\n                  <select\n                    class=\"form-control text-12\"\n                    [title]=\"'Aggregation' | translate\"\n                    id=\"aggregation\"\n                    formControlName=\"aggregation\"\n                    [attr.disabled]=\"formGroup.value.isAutoRefreshEnabled ? true : null\"\n                  >\n                    <option\n                      *ngFor=\"let aggregationValue of AGGREGATION_VALUES_ARR\"\n                      [ngValue]=\"aggregationValue\"\n                      [disabled]=\"disabledAggregationOptions[aggregationValue]\"\n                    >\n                      {{ AGGREGATION_LABELS[aggregationValue] | translate }}\n                    </option>\n                  </select>\n                </div>\n              </c8y-form-group>\n            </fieldset>\n          </div>\n        </ng-container>\n        <!-- time interval selector -->\n        <div class=\"col-md-6\">\n          <fieldset class=\"c8y-fieldset\">\n            <legend>\n              {{ 'Time interval' | translate }}\n            </legend>\n            <c8y-form-group class=\"p-t-8\">\n              <div class=\"c8y-select-wrapper\">\n                <select\n                  class=\"form-control text-12\"\n                  [title]=\"'Interval' | translate\"\n                  id=\"interval\"\n                  formControlName=\"interval\"\n                >\n                  <option\n                    *ngFor=\"let intervalValue of INTERVAL_VALUES_ARR\"\n                    [ngValue]=\"intervalValue\"\n                  >\n                    {{ TIME_RANGE_INTERVAL_LABELS[intervalValue] | translate }}\n                  </option>\n                </select>\n              </div>\n            </c8y-form-group>\n          </fieldset>\n        </div>\n      </div>\n      <!-- date pickers -->\n      <fieldset class=\"c8y-fieldset\">\n        <legend>\n          {{ 'Date range' | translate }}\n        </legend>\n        <c8y-date-range-picker></c8y-date-range-picker>\n      </fieldset>\n    </div>\n  </form>\n</div>\n"]}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { ChangeDetectorRef, Component, EventEmitter, Input, Output, ViewChild } from '@angular/core';
|
|
2
|
-
import { CommonModule, CountdownIntervalComponent, CountdownIntervalModule, IntervalBasedReload, ListGroupModule, WidgetGlobalAutoRefreshService, gettext } from '@c8y/ngx-components';
|
|
2
|
+
import { CommonModule, CountdownIntervalComponent, CountdownIntervalModule, GainsightService, IntervalBasedReload, ListGroupModule, WIDGET_TYPE_VALUES, WidgetGlobalAutoRefreshService, gettext } from '@c8y/ngx-components';
|
|
3
3
|
import { TranslateService } from '@ngx-translate/core';
|
|
4
4
|
import { TooltipModule } from 'ngx-bootstrap/tooltip';
|
|
5
5
|
import { BehaviorSubject, Subject, takeUntil, tap } from 'rxjs';
|
|
@@ -9,11 +9,13 @@ import * as i2 from "@c8y/ngx-components";
|
|
|
9
9
|
import * as i3 from "@angular/common";
|
|
10
10
|
import * as i4 from "ngx-bootstrap/tooltip";
|
|
11
11
|
export class DatapointsReloadComponent extends IntervalBasedReload {
|
|
12
|
-
constructor(cdRef, translateService, widgetGlobalAutoRefreshService) {
|
|
12
|
+
constructor(cdRef, translateService, widgetGlobalAutoRefreshService, gainsightService) {
|
|
13
13
|
super();
|
|
14
14
|
this.cdRef = cdRef;
|
|
15
15
|
this.translateService = translateService;
|
|
16
16
|
this.widgetGlobalAutoRefreshService = widgetGlobalAutoRefreshService;
|
|
17
|
+
this.gainsightService = gainsightService;
|
|
18
|
+
this.WIDGET_TYPE_VALUES = WIDGET_TYPE_VALUES;
|
|
17
19
|
/**
|
|
18
20
|
* @inheritdoc
|
|
19
21
|
*/
|
|
@@ -109,13 +111,13 @@ export class DatapointsReloadComponent extends IntervalBasedReload {
|
|
|
109
111
|
!this.isScrolling &&
|
|
110
112
|
!this.hideCountdown);
|
|
111
113
|
}
|
|
112
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: DatapointsReloadComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.TranslateService }, { token: i2.WidgetGlobalAutoRefreshService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
113
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.9", type: DatapointsReloadComponent, isStandalone: true, selector: "c8y-datapoints-reload", inputs: { isAutoRefreshEnabled: "isAutoRefreshEnabled", isRefreshDisabled: "isRefreshDisabled", isLoading: "isLoading", isScrolling: "isScrolling", isExportModalOpen: "isExportModalOpen", refreshInterval: "refreshInterval", widgetInstanceGlobalAutoRefreshContext: "widgetInstanceGlobalAutoRefreshContext" }, outputs: { onCountdownEnded: "onCountdownEnded" }, viewQueries: [{ propertyName: "countdownIntervalComponent", first: true, predicate: CountdownIntervalComponent, descendants: true }], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<ng-container *ngIf=\"!widgetInstanceGlobalAutoRefreshContext\">\n <div class=\"a-i-center input-group p-t-4 p-b-4 max-width-fit m-l-auto\">\n <label\n class=\"m-b-0 m-r-8 text-label-small text-truncate flex-no-shrink\"\n title=\" {{ 'Auto refresh' | translate }}\"\n *ngIf=\"refreshInterval && isAutoRefreshEnabled\"\n >\n {{ 'Auto refresh' | translate }}\n </label>\n <div class=\"input-group\">\n <label\n class=\"toggle-countdown\"\n [class.toggle-countdown-disabled]=\"isRefreshDisabled\"\n [attr.aria-label]=\"toggleCountdownButtonTooltipText\"\n [tooltip]=\"toggleCountdownButtonTooltipText\"\n placement=\"bottom\"\n *ngIf=\"refreshInterval && isAutoRefreshEnabled\"\n [adaptivePosition]=\"false\"\n [container]=\"'body'\"\n [delay]=\"500\"\n >\n <input\n type=\"checkbox\"\n [checked]=\"isIntervalRefreshToggleOn\"\n [disabled]=\"isRefreshDisabled\"\n data-cy=\"c8y-data-points-table-widget--interval-toggle-button\"\n (click)=\"onToggleCountdownButtonState($event)\"\n />\n\n <c8y-countdown-interval\n *ngIf=\"isIntervalRefreshToggleOn\"\n [countdownInterval]=\"refreshInterval\"\n (countdownEnded)=\"countdownEnded()\"\n ></c8y-countdown-interval>\n <i\n c8yIcon=\"pause\"\n *ngIf=\"!isIntervalRefreshToggleOn\"\n ></i>\n </label>\n\n <div class=\"input-group-btn\">\n <button\n class=\"btn btn-default\"\n [attr.aria-label]=\"'Refresh' | translate\"\n [tooltip]=\"'Refresh' | translate\"\n placement=\"bottom\"\n type=\"button\"\n [adaptivePosition]=\"false\"\n [container]=\"'body'\"\n [delay]=\"500\"\n [disabled]=\"isRefreshDisabled || (isLoading | async)\"\n (click)=\"reload()\"\n data-cy=\"c8y-data-points-table-widget--reload-button\"\n >\n <i\n c8yIcon=\"refresh\"\n [ngClass]=\"{ 'icon-spin': isLoading | async }\"\n ></i>\n </button>\n </div>\n </div>\n </div>\n</ng-container>\n", dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.IconDirective, selector: "[c8yIcon]", inputs: ["c8yIcon"] }, { kind: "pipe", type: i2.C8yTranslatePipe, name: "translate" }, { kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }, { kind: "ngmodule", type: CountdownIntervalModule }, { kind: "component", type: i2.CountdownIntervalComponent, selector: "c8y-countdown-interval", inputs: ["countdownInterval"], outputs: ["countdownEnded"] }, { kind: "ngmodule", type: ListGroupModule }, { kind: "ngmodule", type: TooltipModule }, { kind: "directive", type: i4.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"] }] }); }
|
|
114
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: DatapointsReloadComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.TranslateService }, { token: i2.WidgetGlobalAutoRefreshService }, { token: i2.GainsightService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
115
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.9", type: DatapointsReloadComponent, isStandalone: true, selector: "c8y-datapoints-reload", inputs: { isAutoRefreshEnabled: "isAutoRefreshEnabled", isRefreshDisabled: "isRefreshDisabled", isLoading: "isLoading", isScrolling: "isScrolling", isExportModalOpen: "isExportModalOpen", refreshInterval: "refreshInterval", widgetInstanceGlobalAutoRefreshContext: "widgetInstanceGlobalAutoRefreshContext" }, outputs: { onCountdownEnded: "onCountdownEnded" }, viewQueries: [{ propertyName: "countdownIntervalComponent", first: true, predicate: CountdownIntervalComponent, descendants: true }], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<ng-container *ngIf=\"!widgetInstanceGlobalAutoRefreshContext\">\n <div class=\"a-i-center input-group p-t-4 p-b-4 max-width-fit m-l-auto\">\n <label\n class=\"m-b-0 m-r-8 text-label-small text-truncate flex-no-shrink\"\n title=\" {{ 'Auto refresh' | translate }}\"\n *ngIf=\"refreshInterval && isAutoRefreshEnabled\"\n >\n {{ 'Auto refresh' | translate }}\n </label>\n <div class=\"input-group\">\n <label\n class=\"toggle-countdown\"\n [class.toggle-countdown-disabled]=\"isRefreshDisabled\"\n [attr.aria-label]=\"toggleCountdownButtonTooltipText\"\n [tooltip]=\"toggleCountdownButtonTooltipText\"\n placement=\"bottom\"\n *ngIf=\"refreshInterval && isAutoRefreshEnabled\"\n [adaptivePosition]=\"false\"\n [container]=\"'body'\"\n [delay]=\"500\"\n >\n <input\n type=\"checkbox\"\n [checked]=\"isIntervalRefreshToggleOn\"\n [disabled]=\"isRefreshDisabled\"\n data-cy=\"c8y-data-points-table-widget--interval-toggle-button\"\n (click)=\"onToggleCountdownButtonState($event, WIDGET_TYPE_VALUES.DATA_POINTS_TABLE)\"\n />\n\n <c8y-countdown-interval\n *ngIf=\"isIntervalRefreshToggleOn\"\n [countdownInterval]=\"refreshInterval\"\n (countdownEnded)=\"countdownEnded()\"\n ></c8y-countdown-interval>\n <i\n c8yIcon=\"pause\"\n *ngIf=\"!isIntervalRefreshToggleOn\"\n ></i>\n </label>\n\n <div class=\"input-group-btn\">\n <button\n class=\"btn btn-default\"\n [attr.aria-label]=\"'Refresh' | translate\"\n [tooltip]=\"'Refresh' | translate\"\n placement=\"bottom\"\n type=\"button\"\n [adaptivePosition]=\"false\"\n [container]=\"'body'\"\n [delay]=\"500\"\n [disabled]=\"isRefreshDisabled || (isLoading | async)\"\n (click)=\"reload()\"\n data-cy=\"c8y-data-points-table-widget--reload-button\"\n >\n <i\n c8yIcon=\"refresh\"\n [ngClass]=\"{ 'icon-spin': isLoading | async }\"\n ></i>\n </button>\n </div>\n </div>\n </div>\n</ng-container>\n", dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.IconDirective, selector: "[c8yIcon]", inputs: ["c8yIcon"] }, { kind: "pipe", type: i2.C8yTranslatePipe, name: "translate" }, { kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }, { kind: "ngmodule", type: CountdownIntervalModule }, { kind: "component", type: i2.CountdownIntervalComponent, selector: "c8y-countdown-interval", inputs: ["countdownInterval"], outputs: ["countdownEnded"] }, { kind: "ngmodule", type: ListGroupModule }, { kind: "ngmodule", type: TooltipModule }, { kind: "directive", type: i4.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"] }] }); }
|
|
114
116
|
}
|
|
115
117
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: DatapointsReloadComponent, decorators: [{
|
|
116
118
|
type: Component,
|
|
117
|
-
args: [{ selector: 'c8y-datapoints-reload', standalone: true, imports: [CommonModule, CountdownIntervalModule, ListGroupModule, TooltipModule], template: "<ng-container *ngIf=\"!widgetInstanceGlobalAutoRefreshContext\">\n <div class=\"a-i-center input-group p-t-4 p-b-4 max-width-fit m-l-auto\">\n <label\n class=\"m-b-0 m-r-8 text-label-small text-truncate flex-no-shrink\"\n title=\" {{ 'Auto refresh' | translate }}\"\n *ngIf=\"refreshInterval && isAutoRefreshEnabled\"\n >\n {{ 'Auto refresh' | translate }}\n </label>\n <div class=\"input-group\">\n <label\n class=\"toggle-countdown\"\n [class.toggle-countdown-disabled]=\"isRefreshDisabled\"\n [attr.aria-label]=\"toggleCountdownButtonTooltipText\"\n [tooltip]=\"toggleCountdownButtonTooltipText\"\n placement=\"bottom\"\n *ngIf=\"refreshInterval && isAutoRefreshEnabled\"\n [adaptivePosition]=\"false\"\n [container]=\"'body'\"\n [delay]=\"500\"\n >\n <input\n type=\"checkbox\"\n [checked]=\"isIntervalRefreshToggleOn\"\n [disabled]=\"isRefreshDisabled\"\n data-cy=\"c8y-data-points-table-widget--interval-toggle-button\"\n (click)=\"onToggleCountdownButtonState($event)\"\n />\n\n <c8y-countdown-interval\n *ngIf=\"isIntervalRefreshToggleOn\"\n [countdownInterval]=\"refreshInterval\"\n (countdownEnded)=\"countdownEnded()\"\n ></c8y-countdown-interval>\n <i\n c8yIcon=\"pause\"\n *ngIf=\"!isIntervalRefreshToggleOn\"\n ></i>\n </label>\n\n <div class=\"input-group-btn\">\n <button\n class=\"btn btn-default\"\n [attr.aria-label]=\"'Refresh' | translate\"\n [tooltip]=\"'Refresh' | translate\"\n placement=\"bottom\"\n type=\"button\"\n [adaptivePosition]=\"false\"\n [container]=\"'body'\"\n [delay]=\"500\"\n [disabled]=\"isRefreshDisabled || (isLoading | async)\"\n (click)=\"reload()\"\n data-cy=\"c8y-data-points-table-widget--reload-button\"\n >\n <i\n c8yIcon=\"refresh\"\n [ngClass]=\"{ 'icon-spin': isLoading | async }\"\n ></i>\n </button>\n </div>\n </div>\n </div>\n</ng-container>\n" }]
|
|
118
|
-
}], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: i1.TranslateService }, { type: i2.WidgetGlobalAutoRefreshService }], propDecorators: { countdownIntervalComponent: [{
|
|
119
|
+
args: [{ selector: 'c8y-datapoints-reload', standalone: true, imports: [CommonModule, CountdownIntervalModule, ListGroupModule, TooltipModule], template: "<ng-container *ngIf=\"!widgetInstanceGlobalAutoRefreshContext\">\n <div class=\"a-i-center input-group p-t-4 p-b-4 max-width-fit m-l-auto\">\n <label\n class=\"m-b-0 m-r-8 text-label-small text-truncate flex-no-shrink\"\n title=\" {{ 'Auto refresh' | translate }}\"\n *ngIf=\"refreshInterval && isAutoRefreshEnabled\"\n >\n {{ 'Auto refresh' | translate }}\n </label>\n <div class=\"input-group\">\n <label\n class=\"toggle-countdown\"\n [class.toggle-countdown-disabled]=\"isRefreshDisabled\"\n [attr.aria-label]=\"toggleCountdownButtonTooltipText\"\n [tooltip]=\"toggleCountdownButtonTooltipText\"\n placement=\"bottom\"\n *ngIf=\"refreshInterval && isAutoRefreshEnabled\"\n [adaptivePosition]=\"false\"\n [container]=\"'body'\"\n [delay]=\"500\"\n >\n <input\n type=\"checkbox\"\n [checked]=\"isIntervalRefreshToggleOn\"\n [disabled]=\"isRefreshDisabled\"\n data-cy=\"c8y-data-points-table-widget--interval-toggle-button\"\n (click)=\"onToggleCountdownButtonState($event, WIDGET_TYPE_VALUES.DATA_POINTS_TABLE)\"\n />\n\n <c8y-countdown-interval\n *ngIf=\"isIntervalRefreshToggleOn\"\n [countdownInterval]=\"refreshInterval\"\n (countdownEnded)=\"countdownEnded()\"\n ></c8y-countdown-interval>\n <i\n c8yIcon=\"pause\"\n *ngIf=\"!isIntervalRefreshToggleOn\"\n ></i>\n </label>\n\n <div class=\"input-group-btn\">\n <button\n class=\"btn btn-default\"\n [attr.aria-label]=\"'Refresh' | translate\"\n [tooltip]=\"'Refresh' | translate\"\n placement=\"bottom\"\n type=\"button\"\n [adaptivePosition]=\"false\"\n [container]=\"'body'\"\n [delay]=\"500\"\n [disabled]=\"isRefreshDisabled || (isLoading | async)\"\n (click)=\"reload()\"\n data-cy=\"c8y-data-points-table-widget--reload-button\"\n >\n <i\n c8yIcon=\"refresh\"\n [ngClass]=\"{ 'icon-spin': isLoading | async }\"\n ></i>\n </button>\n </div>\n </div>\n </div>\n</ng-container>\n" }]
|
|
120
|
+
}], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: i1.TranslateService }, { type: i2.WidgetGlobalAutoRefreshService }, { type: i2.GainsightService }], propDecorators: { countdownIntervalComponent: [{
|
|
119
121
|
type: ViewChild,
|
|
120
122
|
args: [CountdownIntervalComponent, { static: false }]
|
|
121
123
|
}], isAutoRefreshEnabled: [{
|
|
@@ -135,4 +137,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImpor
|
|
|
135
137
|
}], onCountdownEnded: [{
|
|
136
138
|
type: Output
|
|
137
139
|
}] } });
|
|
138
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datapoints-reload.component.js","sourceRoot":"","sources":["../../../../../../../widgets/implementations/datapoints-table/datapoints-table-view/datapoints-reload/datapoints-reload.component.ts","../../../../../../../widgets/implementations/datapoints-table/datapoints-table-view/datapoints-reload/datapoints-reload.component.html"],"names":[],"mappings":"AAAA,OAAO,EAEL,iBAAiB,EACjB,SAAS,EACT,YAAY,EACZ,KAAK,EAGL,MAAM,EAEN,SAAS,EACV,MAAM,eAAe,CAAC;AACvB,OAAO,EACL,YAAY,EACZ,0BAA0B,EAC1B,uBAAuB,EACvB,mBAAmB,EACnB,eAAe,EACf,8BAA8B,EAC9B,OAAO,EACR,MAAM,qBAAqB,CAAC;AAC7B,OAAO,EAAE,gBAAgB,EAAE,MAAM,qBAAqB,CAAC;AACvD,OAAO,EAAE,aAAa,EAAE,MAAM,uBAAuB,CAAC;AACtD,OAAO,EAAE,eAAe,EAAE,OAAO,EAAE,SAAS,EAAE,GAAG,EAAE,MAAM,MAAM,CAAC;;;;;;AAQhE,MAAM,OAAO,yBACX,SAAQ,mBAAmB;IAgD3B,YACU,KAAwB,EACxB,gBAAkC,EAClC,8BAA8D;QAEtE,KAAK,EAAE,CAAC;QAJA,UAAK,GAAL,KAAK,CAAmB;QACxB,qBAAgB,GAAhB,gBAAgB,CAAkB;QAClC,mCAA8B,GAA9B,8BAA8B,CAAgC;QA1CxE;;WAEG;QACM,sBAAiB,GAAG,KAAK,CAAC;QAenC;;WAEG;QACO,qBAAgB,GAAG,IAAI,YAAY,EAAQ,CAAC;QAOtD;;WAEG;QACO,8BAAyB,GAAG,KAAK,CAAC;QAMlC,aAAQ,GAAG,IAAI,OAAO,EAAQ,CAAC;IAQzC,CAAC;IAED,eAAe;QACb,IAAI,IAAI,CAAC,sCAAsC,EAAE,CAAC;YAChD,IAAI,CAAC,8BAA8B,CAAC,gBAAgB,CAAC,eAAe;iBACjE,IAAI,CACH,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,EACxB,GAAG,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,gBAAgB,CAAC,IAAI,EAAE,CAAC,CACxC;iBACA,SAAS,EAAE,CAAC;QACjB,CAAC;IACH,CAAC;IAED,WAAW,CAAC,OAAsB;QAChC,IAAI,IAAI,CAAC,iBAAiB,IAAI,IAAI,CAAC,oBAAoB,EAAE,CAAC;YACxD,IAAI,CAAC,yBAAyB,GAAG,KAAK,CAAC;YACvC,IAAI,CAAC,gBAAgB,EAAE,CAAC;YACxB,OAAO;QACT,CAAC;QAED,IAAI,IAAI,CAAC,iBAAiB,IAAI,IAAI,CAAC,kCAAkC,EAAE,EAAE,CAAC;YACxE,IAAI,CAAC,yBAAyB,GAAG,CAAC,IAAI,CAAC,yBAAyB,CAAC;YACjE,IAAI,CAAC,gBAAgB,EAAE,CAAC;QAC1B,CAAC;aAAM,CAAC;YACN,IAAI,IAAI,CAAC,iBAAiB,CAAC,OAAO,CAAC,EAAE,CAAC;gBACpC,IAAI,CAAC,yBAAyB,GAAG,IAAI,CAAC;gBACtC,IAAI,CAAC,cAAc,EAAE,CAAC;YACxB,CAAC;YAED,IAAI,IAAI,CAAC,kBAAkB,EAAE,EAAE,CAAC;gBAC9B,IAAI,CAAC,eAAe,EAAE,CAAC;YACzB,CAAC;QACH,CAAC;IACH,CAAC;IAED,WAAW;QACT,IAAI,IAAI,CAAC,qBAAqB,EAAE,CAAC;YAC/B,IAAI,CAAC,qBAAqB,CAAC,WAAW,EAAE,CAAC;QAC3C,CAAC;QACD,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;QACrB,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC;IAC3B,CAAC;IAED;;OAEG;IACH,cAAc;QACZ;;WAEG;QACH,IAAI,CAAC,eAAe,EAAE,CAAC;IACzB,CAAC;IAED,MAAM;QACJ;;WAEG;QACH,IAAI,CAAC,eAAe,EAAE,CAAC;IACzB,CAAC;IAED;;OAEG;IACH,eAAe;QACb,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;QAC3B,iEAAiE;QACjE,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,CAAC;QAC3B,IAAI,CAAC,cAAc,EAAE,CAAC;IACxB,CAAC;IAED;;OAEG;IACO,gCAAgC;QACxC,IAAI,CAAC,gCAAgC,GAAG,IAAI,CAAC,yBAAyB;YACpE,CAAC,CAAC,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,OAAO,CAAC,sBAAsB,CAAC,CAAC;YAChE,CAAC,CAAC,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,OAAO,CAAC,qBAAqB,CAAC,CAAC,CAAC;IACpE,CAAC;IAEO,iBAAiB,CAAC,OAAsB;QAC9C,MAAM,EAAE,oBAAoB,EAAE,eAAe,EAAE,GAAG,OAAO,CAAC;QAC1D,OAAO,CACL,CAAC,oBAAoB,IAAI,eAAe,CAAC;YACzC,CAAC,IAAI,CAAC,oBAAoB,IAAI,CAAC,CAAC,IAAI,CAAC,eAAe,CAAC,CACtD,CAAC;IACJ,CAAC;IAEO,kBAAkB;QACxB,OAAO,CAAC,IAAI,CAAC,yBAAyB,IAAI,IAAI,CAAC,oBAAoB,CAAC;IACtE,CAAC;IAEO,kCAAkC;QACxC,OAAO,CACL,IAAI,CAAC,oBAAoB;YACzB,CAAC,CAAC,IAAI,CAAC,eAAe;YACtB,CAAC,IAAI,CAAC,yBAAyB;YAC/B,CAAC,IAAI,CAAC,WAAW;YACjB,CAAC,IAAI,CAAC,aAAa,CACpB,CAAC;IACJ,CAAC;8GA1JU,yBAAyB;kGAAzB,yBAAyB,ofAIzB,0BAA0B,4FCnCvC,4qEA+DA,2CDlCY,YAAY,gbAAE,uBAAuB,0LAAE,eAAe,8BAAE,aAAa;;2FAEpE,yBAAyB;kBANrC,SAAS;+BACE,uBAAuB,cAErB,IAAI,WACP,CAAC,YAAY,EAAE,uBAAuB,EAAE,eAAe,EAAE,aAAa,CAAC;kKAOhF,0BAA0B;sBADzB,SAAS;uBAAC,0BAA0B,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE;gBAK/C,oBAAoB;sBAA5B,KAAK;gBAIG,iBAAiB;sBAAzB,KAAK;gBAIG,SAAS;sBAAjB,KAAK;gBAEG,WAAW;sBAAnB,KAAK;gBAEG,iBAAiB;sBAAzB,KAAK;gBAIG,eAAe;sBAAvB,KAAK;gBAEG,sCAAsC;sBAA9C,KAAK;gBAII,gBAAgB;sBAAzB,MAAM","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnDestroy,\n  Output,\n  SimpleChanges,\n  ViewChild\n} from '@angular/core';\nimport {\n  CommonModule,\n  CountdownIntervalComponent,\n  CountdownIntervalModule,\n  IntervalBasedReload,\n  ListGroupModule,\n  WidgetGlobalAutoRefreshService,\n  gettext\n} from '@c8y/ngx-components';\nimport { TranslateService } from '@ngx-translate/core';\nimport { TooltipModule } from 'ngx-bootstrap/tooltip';\nimport { BehaviorSubject, Subject, takeUntil, tap } from 'rxjs';\n\n@Component({\n  selector: 'c8y-datapoints-reload',\n  templateUrl: './datapoints-reload.component.html',\n  standalone: true,\n  imports: [CommonModule, CountdownIntervalModule, ListGroupModule, TooltipModule]\n})\nexport class DatapointsReloadComponent\n  extends IntervalBasedReload\n  implements OnChanges, AfterViewInit, OnDestroy\n{\n  @ViewChild(CountdownIntervalComponent, { static: false })\n  countdownIntervalComponent: CountdownIntervalComponent;\n  /**\n   * @inheritdoc\n   */\n  @Input() isAutoRefreshEnabled: boolean;\n  /**\n   * @inheritdoc\n   */\n  @Input() isRefreshDisabled = false;\n  /**\n   * @inheritdoc\n   */\n  @Input() isLoading: BehaviorSubject<boolean>;\n\n  @Input() isScrolling: boolean;\n\n  @Input() isExportModalOpen: boolean;\n  /**\n   * @inheritdoc\n   */\n  @Input() refreshInterval: number;\n\n  @Input() widgetInstanceGlobalAutoRefreshContext: boolean;\n  /**\n   * @inheritdoc\n   */\n  @Output() onCountdownEnded = new EventEmitter<void>();\n  /**\n   * @inheritdoc\n   */\n  isIntervalRefreshToggleOn: boolean;\n\n  toggleCountdownButtonTooltipText: string;\n  /**\n   * @inheritdoc\n   */\n  protected manuallyDisabledCountdown = false;\n  /**\n   * @inheritdoc\n   */\n  protected hideCountdown: boolean;\n\n  protected destroy$ = new Subject<void>();\n\n  constructor(\n    private cdRef: ChangeDetectorRef,\n    private translateService: TranslateService,\n    private widgetGlobalAutoRefreshService: WidgetGlobalAutoRefreshService\n  ) {\n    super();\n  }\n\n  ngAfterViewInit() {\n    if (this.widgetInstanceGlobalAutoRefreshContext) {\n      this.widgetGlobalAutoRefreshService.countdownActions.countdownEnded$\n        .pipe(\n          takeUntil(this.destroy$),\n          tap(() => this.onCountdownEnded.emit())\n        )\n        .subscribe();\n    }\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (this.isRefreshDisabled && this.isAutoRefreshEnabled) {\n      this.isIntervalRefreshToggleOn = false;\n      this.disableCountdown();\n      return;\n    }\n\n    if (this.isExportModalOpen && this.canDisableCountdownWhenModalIsOpen()) {\n      this.isIntervalRefreshToggleOn = !this.isIntervalRefreshToggleOn;\n      this.disableCountdown();\n    } else {\n      if (this.canStartCountdown(changes)) {\n        this.isIntervalRefreshToggleOn = true;\n        this.startCountdown();\n      }\n\n      if (this.canHandleScrolling()) {\n        this.handleScrolling();\n      }\n    }\n  }\n\n  ngOnDestroy(): void {\n    if (this.countdownSubscription) {\n      this.countdownSubscription.unsubscribe();\n    }\n    this.destroy$.next();\n    this.destroy$.complete();\n  }\n\n  /**\n   * @inheritdoc\n   */\n  countdownEnded(): void {\n    /**\n     * @inheritdoc\n     */\n    this.autoRefreshList();\n  }\n\n  reload(): void {\n    /**\n     * @inheritdoc\n     */\n    this.autoRefreshList();\n  }\n\n  /**\n   * @inheritdoc\n   */\n  enableCountdown(): void {\n    this.hideCountdown = false;\n    // Prevents the countdown from getting stuck on an initial value.\n    this.cdRef.detectChanges();\n    this.startCountdown();\n  }\n\n  /**\n   * @inheritdoc\n   */\n  protected updateCountdownButtonTooltipText(): void {\n    this.toggleCountdownButtonTooltipText = this.isIntervalRefreshToggleOn\n      ? this.translateService.instant(gettext('Disable auto refresh'))\n      : this.translateService.instant(gettext('Enable auto refresh'));\n  }\n\n  private canStartCountdown(changes: SimpleChanges): boolean {\n    const { isAutoRefreshEnabled, refreshInterval } = changes;\n    return (\n      (isAutoRefreshEnabled || refreshInterval) &&\n      (this.isAutoRefreshEnabled || !!this.refreshInterval)\n    );\n  }\n\n  private canHandleScrolling(): boolean {\n    return !this.manuallyDisabledCountdown && this.isAutoRefreshEnabled;\n  }\n\n  private canDisableCountdownWhenModalIsOpen(): boolean {\n    return (\n      this.isAutoRefreshEnabled &&\n      !!this.refreshInterval &&\n      !this.manuallyDisabledCountdown &&\n      !this.isScrolling &&\n      !this.hideCountdown\n    );\n  }\n}\n","<ng-container *ngIf=\"!widgetInstanceGlobalAutoRefreshContext\">\n  <div class=\"a-i-center input-group p-t-4 p-b-4 max-width-fit m-l-auto\">\n    <label\n      class=\"m-b-0 m-r-8 text-label-small text-truncate flex-no-shrink\"\n      title=\" {{ 'Auto refresh' | translate }}\"\n      *ngIf=\"refreshInterval && isAutoRefreshEnabled\"\n    >\n      {{ 'Auto refresh' | translate }}\n    </label>\n    <div class=\"input-group\">\n      <label\n        class=\"toggle-countdown\"\n        [class.toggle-countdown-disabled]=\"isRefreshDisabled\"\n        [attr.aria-label]=\"toggleCountdownButtonTooltipText\"\n        [tooltip]=\"toggleCountdownButtonTooltipText\"\n        placement=\"bottom\"\n        *ngIf=\"refreshInterval && isAutoRefreshEnabled\"\n        [adaptivePosition]=\"false\"\n        [container]=\"'body'\"\n        [delay]=\"500\"\n      >\n        <input\n          type=\"checkbox\"\n          [checked]=\"isIntervalRefreshToggleOn\"\n          [disabled]=\"isRefreshDisabled\"\n          data-cy=\"c8y-data-points-table-widget--interval-toggle-button\"\n          (click)=\"onToggleCountdownButtonState($event)\"\n        />\n\n        <c8y-countdown-interval\n          *ngIf=\"isIntervalRefreshToggleOn\"\n          [countdownInterval]=\"refreshInterval\"\n          (countdownEnded)=\"countdownEnded()\"\n        ></c8y-countdown-interval>\n        <i\n          c8yIcon=\"pause\"\n          *ngIf=\"!isIntervalRefreshToggleOn\"\n        ></i>\n      </label>\n\n      <div class=\"input-group-btn\">\n        <button\n          class=\"btn btn-default\"\n          [attr.aria-label]=\"'Refresh' | translate\"\n          [tooltip]=\"'Refresh' | translate\"\n          placement=\"bottom\"\n          type=\"button\"\n          [adaptivePosition]=\"false\"\n          [container]=\"'body'\"\n          [delay]=\"500\"\n          [disabled]=\"isRefreshDisabled || (isLoading | async)\"\n          (click)=\"reload()\"\n          data-cy=\"c8y-data-points-table-widget--reload-button\"\n        >\n          <i\n            c8yIcon=\"refresh\"\n            [ngClass]=\"{ 'icon-spin': isLoading | async }\"\n          ></i>\n        </button>\n      </div>\n    </div>\n  </div>\n</ng-container>\n"]}
|
|
140
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datapoints-reload.component.js","sourceRoot":"","sources":["../../../../../../../widgets/implementations/datapoints-table/datapoints-table-view/datapoints-reload/datapoints-reload.component.ts","../../../../../../../widgets/implementations/datapoints-table/datapoints-table-view/datapoints-reload/datapoints-reload.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnDestroy,\n  Output,\n  SimpleChanges,\n  ViewChild\n} from '@angular/core';\nimport {\n  CommonModule,\n  CountdownIntervalComponent,\n  CountdownIntervalModule,\n  GainsightService,\n  IntervalBasedReload,\n  ListGroupModule,\n  WIDGET_TYPE_VALUES,\n  WidgetGlobalAutoRefreshService,\n  gettext\n} from '@c8y/ngx-components';\nimport { TranslateService } from '@ngx-translate/core';\nimport { TooltipModule } from 'ngx-bootstrap/tooltip';\nimport { BehaviorSubject, Subject, takeUntil, tap } from 'rxjs';\n\n@Component({\n  selector: 'c8y-datapoints-reload',\n  templateUrl: './datapoints-reload.component.html',\n  standalone: true,\n  imports: [CommonModule, CountdownIntervalModule, ListGroupModule, TooltipModule]\n})\nexport class DatapointsReloadComponent\n  extends IntervalBasedReload\n  implements OnChanges, AfterViewInit, OnDestroy\n{\n  readonly WIDGET_TYPE_VALUES = WIDGET_TYPE_VALUES;\n\n  @ViewChild(CountdownIntervalComponent, { static: false })\n  countdownIntervalComponent: CountdownIntervalComponent;\n  /**\n   * @inheritdoc\n   */\n  @Input() isAutoRefreshEnabled: boolean;\n  /**\n   * @inheritdoc\n   */\n  @Input() isRefreshDisabled = false;\n  /**\n   * @inheritdoc\n   */\n  @Input() isLoading: BehaviorSubject<boolean>;\n\n  @Input() isScrolling: boolean;\n\n  @Input() isExportModalOpen: boolean;\n  /**\n   * @inheritdoc\n   */\n  @Input() refreshInterval: number;\n\n  @Input() widgetInstanceGlobalAutoRefreshContext: boolean;\n  /**\n   * @inheritdoc\n   */\n  @Output() onCountdownEnded = new EventEmitter<void>();\n  /**\n   * @inheritdoc\n   */\n  isIntervalRefreshToggleOn: boolean;\n\n  toggleCountdownButtonTooltipText: string;\n  /**\n   * @inheritdoc\n   */\n  protected manuallyDisabledCountdown = false;\n  /**\n   * @inheritdoc\n   */\n  protected hideCountdown: boolean;\n\n  protected destroy$ = new Subject<void>();\n\n  constructor(\n    private cdRef: ChangeDetectorRef,\n    private translateService: TranslateService,\n    private widgetGlobalAutoRefreshService: WidgetGlobalAutoRefreshService,\n    protected gainsightService: GainsightService\n  ) {\n    super();\n  }\n\n  ngAfterViewInit() {\n    if (this.widgetInstanceGlobalAutoRefreshContext) {\n      this.widgetGlobalAutoRefreshService.countdownActions.countdownEnded$\n        .pipe(\n          takeUntil(this.destroy$),\n          tap(() => this.onCountdownEnded.emit())\n        )\n        .subscribe();\n    }\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (this.isRefreshDisabled && this.isAutoRefreshEnabled) {\n      this.isIntervalRefreshToggleOn = false;\n      this.disableCountdown();\n      return;\n    }\n\n    if (this.isExportModalOpen && this.canDisableCountdownWhenModalIsOpen()) {\n      this.isIntervalRefreshToggleOn = !this.isIntervalRefreshToggleOn;\n      this.disableCountdown();\n    } else {\n      if (this.canStartCountdown(changes)) {\n        this.isIntervalRefreshToggleOn = true;\n        this.startCountdown();\n      }\n\n      if (this.canHandleScrolling()) {\n        this.handleScrolling();\n      }\n    }\n  }\n\n  ngOnDestroy(): void {\n    if (this.countdownSubscription) {\n      this.countdownSubscription.unsubscribe();\n    }\n    this.destroy$.next();\n    this.destroy$.complete();\n  }\n\n  /**\n   * @inheritdoc\n   */\n  countdownEnded(): void {\n    /**\n     * @inheritdoc\n     */\n    this.autoRefreshList();\n  }\n\n  reload(): void {\n    /**\n     * @inheritdoc\n     */\n    this.autoRefreshList();\n  }\n\n  /**\n   * @inheritdoc\n   */\n  enableCountdown(): void {\n    this.hideCountdown = false;\n    // Prevents the countdown from getting stuck on an initial value.\n    this.cdRef.detectChanges();\n    this.startCountdown();\n  }\n\n  /**\n   * @inheritdoc\n   */\n  protected updateCountdownButtonTooltipText(): void {\n    this.toggleCountdownButtonTooltipText = this.isIntervalRefreshToggleOn\n      ? this.translateService.instant(gettext('Disable auto refresh'))\n      : this.translateService.instant(gettext('Enable auto refresh'));\n  }\n\n  private canStartCountdown(changes: SimpleChanges): boolean {\n    const { isAutoRefreshEnabled, refreshInterval } = changes;\n    return (\n      (isAutoRefreshEnabled || refreshInterval) &&\n      (this.isAutoRefreshEnabled || !!this.refreshInterval)\n    );\n  }\n\n  private canHandleScrolling(): boolean {\n    return !this.manuallyDisabledCountdown && this.isAutoRefreshEnabled;\n  }\n\n  private canDisableCountdownWhenModalIsOpen(): boolean {\n    return (\n      this.isAutoRefreshEnabled &&\n      !!this.refreshInterval &&\n      !this.manuallyDisabledCountdown &&\n      !this.isScrolling &&\n      !this.hideCountdown\n    );\n  }\n}\n","<ng-container *ngIf=\"!widgetInstanceGlobalAutoRefreshContext\">\n  <div class=\"a-i-center input-group p-t-4 p-b-4 max-width-fit m-l-auto\">\n    <label\n      class=\"m-b-0 m-r-8 text-label-small text-truncate flex-no-shrink\"\n      title=\" {{ 'Auto refresh' | translate }}\"\n      *ngIf=\"refreshInterval && isAutoRefreshEnabled\"\n    >\n      {{ 'Auto refresh' | translate }}\n    </label>\n    <div class=\"input-group\">\n      <label\n        class=\"toggle-countdown\"\n        [class.toggle-countdown-disabled]=\"isRefreshDisabled\"\n        [attr.aria-label]=\"toggleCountdownButtonTooltipText\"\n        [tooltip]=\"toggleCountdownButtonTooltipText\"\n        placement=\"bottom\"\n        *ngIf=\"refreshInterval && isAutoRefreshEnabled\"\n        [adaptivePosition]=\"false\"\n        [container]=\"'body'\"\n        [delay]=\"500\"\n      >\n        <input\n          type=\"checkbox\"\n          [checked]=\"isIntervalRefreshToggleOn\"\n          [disabled]=\"isRefreshDisabled\"\n          data-cy=\"c8y-data-points-table-widget--interval-toggle-button\"\n          (click)=\"onToggleCountdownButtonState($event, WIDGET_TYPE_VALUES.DATA_POINTS_TABLE)\"\n        />\n\n        <c8y-countdown-interval\n          *ngIf=\"isIntervalRefreshToggleOn\"\n          [countdownInterval]=\"refreshInterval\"\n          (countdownEnded)=\"countdownEnded()\"\n        ></c8y-countdown-interval>\n        <i\n          c8yIcon=\"pause\"\n          *ngIf=\"!isIntervalRefreshToggleOn\"\n        ></i>\n      </label>\n\n      <div class=\"input-group-btn\">\n        <button\n          class=\"btn btn-default\"\n          [attr.aria-label]=\"'Refresh' | translate\"\n          [tooltip]=\"'Refresh' | translate\"\n          placement=\"bottom\"\n          type=\"button\"\n          [adaptivePosition]=\"false\"\n          [container]=\"'body'\"\n          [delay]=\"500\"\n          [disabled]=\"isRefreshDisabled || (isLoading | async)\"\n          (click)=\"reload()\"\n          data-cy=\"c8y-data-points-table-widget--reload-button\"\n        >\n          <i\n            c8yIcon=\"refresh\"\n            [ngClass]=\"{ 'icon-spin': isLoading | async }\"\n          ></i>\n        </button>\n      </div>\n    </div>\n  </div>\n</ng-container>\n"]}
|