@c8y/ngx-components 1021.50.0 → 1021.51.1
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/aggregation/aggregation.model.d.ts.map +1 -0
- package/core/aggregation/aggregation.service.d.ts +44 -0
- package/core/aggregation/aggregation.service.d.ts.map +1 -0
- package/core/aggregation/index.d.ts +3 -0
- package/core/aggregation/index.d.ts.map +1 -0
- package/core/common/index.d.ts +0 -2
- package/core/common/index.d.ts.map +1 -1
- package/core/dashboard/wiget-time-context/aggregation-picker/aggregation-picker.component.d.ts +2 -2
- package/core/dashboard/wiget-time-context/aggregation-picker/aggregation-picker.component.d.ts.map +1 -1
- package/core/dashboard/wiget-time-context/widget-time-context-icon-bar/widget-time-context-icon-bar.component.d.ts +1 -1
- package/core/dashboard/wiget-time-context/widget-time-context-icon-bar/widget-time-context-icon-bar.component.d.ts.map +1 -1
- package/core/dashboard/wiget-time-context/widget-time-context.component.d.ts +1 -1
- package/core/dashboard/wiget-time-context/widget-time-context.component.d.ts.map +1 -1
- package/core/index.d.ts +1 -0
- package/core/index.d.ts.map +1 -1
- package/datapoints-export-selector/datapoints-export-selector-modal/datapoints-export-selector-file-exporter/data-fetching.service.d.ts +54 -42
- package/datapoints-export-selector/datapoints-export-selector-modal/datapoints-export-selector-file-exporter/data-fetching.service.d.ts.map +1 -1
- package/datapoints-export-selector/datapoints-export-selector-modal/datapoints-export-selector-file-exporter/datapoints-export-selector-file-exporter.component.d.ts +28 -8
- package/datapoints-export-selector/datapoints-export-selector-modal/datapoints-export-selector-file-exporter/datapoints-export-selector-file-exporter.component.d.ts.map +1 -1
- package/datapoints-export-selector/datapoints-export-selector-modal/datapoints-export-selector-file-exporter/datapoints-export-selector-file-exporter.service.d.ts +3 -52
- package/datapoints-export-selector/datapoints-export-selector-modal/datapoints-export-selector-file-exporter/datapoints-export-selector-file-exporter.service.d.ts.map +1 -1
- package/datapoints-export-selector/datapoints-export-selector.model.d.ts +5 -14
- package/datapoints-export-selector/datapoints-export-selector.model.d.ts.map +1 -1
- package/device-grid/device-grid.component.d.ts.map +1 -1
- package/device-grid/device-grid.service.d.ts +2 -0
- package/device-grid/device-grid.service.d.ts.map +1 -1
- package/esm2022/core/aggregation/aggregation.model.mjs +46 -0
- package/esm2022/core/aggregation/aggregation.service.mjs +76 -0
- package/esm2022/core/aggregation/index.mjs +3 -0
- package/esm2022/core/common/index.mjs +1 -3
- package/esm2022/core/dashboard/wiget-time-context/aggregation-picker/aggregation-picker.component.mjs +2 -2
- package/esm2022/core/dashboard/wiget-time-context/widget-time-context-icon-bar/widget-time-context-icon-bar.component.mjs +2 -2
- package/esm2022/core/dashboard/wiget-time-context/widget-time-context.component.mjs +4 -4
- package/esm2022/core/index.mjs +2 -1
- package/esm2022/datapoints-export-selector/datapoints-export-selector-modal/datapoints-export-selector-file-exporter/data-fetching.service.mjs +165 -163
- package/esm2022/datapoints-export-selector/datapoints-export-selector-modal/datapoints-export-selector-file-exporter/datapoints-export-selector-file-exporter.component.mjs +82 -48
- package/esm2022/datapoints-export-selector/datapoints-export-selector-modal/datapoints-export-selector-file-exporter/datapoints-export-selector-file-exporter.service.mjs +5 -95
- package/esm2022/datapoints-export-selector/datapoints-export-selector-modal/datapoints-export-selector-file-exporter/datapoints-exports-selector-data-scope/datapoints-exports-selector-data-scope.component.mjs +3 -3
- package/esm2022/datapoints-export-selector/datapoints-export-selector.component.mjs +3 -3
- package/esm2022/datapoints-export-selector/datapoints-export-selector.model.mjs +1 -9
- package/esm2022/device-grid/device-grid.component.mjs +3 -3
- package/esm2022/device-grid/device-grid.service.mjs +16 -1
- package/esm2022/interval-picker/interval-picker.model.mjs +5 -1
- package/esm2022/widgets/implementations/datapoints-table/datapoints-table-config/datapoints-table-config.component.mjs +25 -41
- package/esm2022/widgets/implementations/datapoints-table/datapoints-table-view/datapoints-reload/datapoints-reload.component.mjs +3 -3
- package/esm2022/widgets/implementations/datapoints-table/datapoints-table-view/datapoints-table-view.component.mjs +55 -49
- package/esm2022/widgets/implementations/datapoints-table/datapoints-table-view/datapoints-table-view.service.mjs +25 -73
- package/esm2022/widgets/implementations/datapoints-table/datapoints-table-widget.model.mjs +20 -20
- package/esm2022/widgets/implementations/datapoints-table/datapoints-table.service.mjs +19 -19
- package/fesm2022/c8y-ngx-components-datapoints-export-selector.mjs +247 -307
- package/fesm2022/c8y-ngx-components-datapoints-export-selector.mjs.map +1 -1
- package/fesm2022/c8y-ngx-components-device-grid.mjs +17 -2
- package/fesm2022/c8y-ngx-components-device-grid.mjs.map +1 -1
- package/fesm2022/c8y-ngx-components-interval-picker.mjs +5 -1
- package/fesm2022/c8y-ngx-components-interval-picker.mjs.map +1 -1
- package/fesm2022/c8y-ngx-components-widgets-implementations-datapoints-table.mjs +1075 -1253
- package/fesm2022/c8y-ngx-components-widgets-implementations-datapoints-table.mjs.map +1 -1
- package/fesm2022/c8y-ngx-components.mjs +118 -76
- package/fesm2022/c8y-ngx-components.mjs.map +1 -1
- package/interval-picker/interval-picker.model.d.ts +6 -0
- package/interval-picker/interval-picker.model.d.ts.map +1 -1
- package/locales/de.po +40 -27
- package/locales/es.po +40 -27
- package/locales/fr.po +40 -27
- package/locales/ja_JP.po +40 -26
- package/locales/ko.po +38 -24
- package/locales/locales.pot +23 -25
- package/locales/nl.po +40 -27
- package/locales/pl.po +40 -26
- package/locales/pt_BR.po +40 -27
- package/locales/zh_CN.po +38 -24
- package/locales/zh_TW.po +38 -24
- package/package.json +1 -1
- package/widgets/implementations/datapoints-table/datapoints-table-config/datapoints-table-config.component.d.ts +3 -5
- 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-table-view.component.d.ts +7 -2
- package/widgets/implementations/datapoints-table/datapoints-table-view/datapoints-table-view.component.d.ts.map +1 -1
- package/widgets/implementations/datapoints-table/datapoints-table-view/datapoints-table-view.service.d.ts +7 -27
- package/widgets/implementations/datapoints-table/datapoints-table-view/datapoints-table-view.service.d.ts.map +1 -1
- package/widgets/implementations/datapoints-table/datapoints-table-widget.model.d.ts +4 -3
- package/widgets/implementations/datapoints-table/datapoints-table-widget.model.d.ts.map +1 -1
- package/widgets/implementations/datapoints-table/datapoints-table.service.d.ts +5 -5
- package/widgets/implementations/datapoints-table/datapoints-table.service.d.ts.map +1 -1
- package/core/common/aggregation/aggregation.model.d.ts.map +0 -1
- package/core/common/aggregation/aggregation.service.d.ts +0 -17
- package/core/common/aggregation/aggregation.service.d.ts.map +0 -1
- package/esm2022/core/common/aggregation/aggregation.model.mjs +0 -46
- package/esm2022/core/common/aggregation/aggregation.service.mjs +0 -34
- package/esm2022/widgets/implementations/datapoints-table/datapoints-table-config/datapoints-table-config.service.mjs +0 -124
- package/widgets/implementations/datapoints-table/datapoints-table-config/datapoints-table-config.service.d.ts +0 -56
- package/widgets/implementations/datapoints-table/datapoints-table-config/datapoints-table-config.service.d.ts.map +0 -1
- /package/core/{common/aggregation → aggregation}/aggregation.model.d.ts +0 -0
|
@@ -90,11 +90,11 @@ export class DatapointsReloadComponent extends IntervalBasedReload {
|
|
|
90
90
|
!this.hideCountdown);
|
|
91
91
|
}
|
|
92
92
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: DatapointsReloadComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i0.Injector }, { token: i1.TranslateService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
93
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.9", type: DatapointsReloadComponent, isStandalone: true, selector: "c8y-datapoints-reload", inputs: { isAutoRefreshEnabled: "isAutoRefreshEnabled", isDisabled: "isDisabled", isLoading: "isLoading", isScrolling: "isScrolling", isExportModalOpen: "isExportModalOpen", refreshInterval: "refreshInterval" }, outputs: { onCountdownEnded: "onCountdownEnded" }, viewQueries: [{ propertyName: "countdownIntervalComponent", first: true, predicate: CountdownIntervalComponent, descendants: true }], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<div class=\"
|
|
93
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.9", type: DatapointsReloadComponent, isStandalone: true, selector: "c8y-datapoints-reload", inputs: { isAutoRefreshEnabled: "isAutoRefreshEnabled", isDisabled: "isDisabled", isLoading: "isLoading", isScrolling: "isScrolling", isExportModalOpen: "isExportModalOpen", refreshInterval: "refreshInterval" }, outputs: { onCountdownEnded: "onCountdownEnded" }, viewQueries: [{ propertyName: "countdownIntervalComponent", first: true, predicate: CountdownIntervalComponent, descendants: true }], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<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]=\"isDisabled\"\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]=\"isDisabled\"\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]=\"isLoading()\"\n (click)=\"reload()\"\n data-cy=\"c8y-data-points-table-widget--reload-button\"\n >\n <i\n c8yIcon=\"refresh\"\n [ngClass]=\"{ 'icon-spin': isLoading() }\"\n ></i>\n </button>\n </div>\n </div>\n</div>\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: "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"] }] }); }
|
|
94
94
|
}
|
|
95
95
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: DatapointsReloadComponent, decorators: [{
|
|
96
96
|
type: Component,
|
|
97
|
-
args: [{ selector: 'c8y-datapoints-reload', standalone: true, imports: [CommonModule, CountdownIntervalModule, ListGroupModule, TooltipModule], template: "<div class=\"
|
|
97
|
+
args: [{ selector: 'c8y-datapoints-reload', standalone: true, imports: [CommonModule, CountdownIntervalModule, ListGroupModule, TooltipModule], template: "<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]=\"isDisabled\"\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]=\"isDisabled\"\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]=\"isLoading()\"\n (click)=\"reload()\"\n data-cy=\"c8y-data-points-table-widget--reload-button\"\n >\n <i\n c8yIcon=\"refresh\"\n [ngClass]=\"{ 'icon-spin': isLoading() }\"\n ></i>\n </button>\n </div>\n </div>\n</div>\n" }]
|
|
98
98
|
}], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: i0.Injector }, { type: i1.TranslateService }], propDecorators: { countdownIntervalComponent: [{
|
|
99
99
|
type: ViewChild,
|
|
100
100
|
args: [CountdownIntervalComponent, { static: false }]
|
|
@@ -113,4 +113,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImpor
|
|
|
113
113
|
}], onCountdownEnded: [{
|
|
114
114
|
type: Output
|
|
115
115
|
}] } });
|
|
116
|
-
//# 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  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  Injector,\n  Input,\n  OnChanges,\n  Output,\n  Signal,\n  SimpleChanges,\n  ViewChild\n} from '@angular/core';\nimport {\n  CommonModule,\n  CountdownIntervalComponent,\n  CountdownIntervalModule,\n  IntervalBasedReload,\n  ListGroupModule,\n  gettext\n} from '@c8y/ngx-components';\nimport { TranslateService } from '@ngx-translate/core';\nimport { TooltipModule } from 'ngx-bootstrap/tooltip';\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 extends IntervalBasedReload implements OnChanges {\n  @ViewChild(CountdownIntervalComponent, { static: false })\n  countdownIntervalComponent: CountdownIntervalComponent;\n  /**\n   * @inheritdoc\n   */\n  @Input() isAutoRefreshEnabled: boolean;\n\n  @Input() isDisabled: boolean;\n  /**\n   * @inheritdoc\n   */\n  @Input() isLoading: Signal<boolean>;\n\n  @Input() isScrolling: boolean;\n\n  @Input() isExportModalOpen: boolean;\n  /**\n   * @inheritdoc\n   */\n  @Input() refreshInterval: number;\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  constructor(\n    private cdRef: ChangeDetectorRef,\n    private injector: Injector,\n    private translateService: TranslateService\n  ) {\n    super();\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (this.isDisabled && 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(this.injector);\n      }\n\n      if (this.canHandleScrolling()) {\n        this.handleScrolling();\n      }\n    }\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(this.injector);\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","<div class=\"d-flex a-i-center p-t-4 p-b-4\">\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]=\"isDisabled\"\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]=\"isDisabled\"\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]=\"isLoading()\"\n        (click)=\"reload()\"\n        data-cy=\"c8y-data-points-table-widget--reload-button\"\n      >\n        <i\n          c8yIcon=\"refresh\"\n          [ngClass]=\"{ 'icon-spin': isLoading() }\"\n        ></i>\n      </button>\n    </div>\n  </div>\n</div>\n"]}
|
|
116
|
+
//# 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  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  Injector,\n  Input,\n  OnChanges,\n  Output,\n  Signal,\n  SimpleChanges,\n  ViewChild\n} from '@angular/core';\nimport {\n  CommonModule,\n  CountdownIntervalComponent,\n  CountdownIntervalModule,\n  IntervalBasedReload,\n  ListGroupModule,\n  gettext\n} from '@c8y/ngx-components';\nimport { TranslateService } from '@ngx-translate/core';\nimport { TooltipModule } from 'ngx-bootstrap/tooltip';\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 extends IntervalBasedReload implements OnChanges {\n  @ViewChild(CountdownIntervalComponent, { static: false })\n  countdownIntervalComponent: CountdownIntervalComponent;\n  /**\n   * @inheritdoc\n   */\n  @Input() isAutoRefreshEnabled: boolean;\n\n  @Input() isDisabled: boolean;\n  /**\n   * @inheritdoc\n   */\n  @Input() isLoading: Signal<boolean>;\n\n  @Input() isScrolling: boolean;\n\n  @Input() isExportModalOpen: boolean;\n  /**\n   * @inheritdoc\n   */\n  @Input() refreshInterval: number;\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  constructor(\n    private cdRef: ChangeDetectorRef,\n    private injector: Injector,\n    private translateService: TranslateService\n  ) {\n    super();\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (this.isDisabled && 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(this.injector);\n      }\n\n      if (this.canHandleScrolling()) {\n        this.handleScrolling();\n      }\n    }\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(this.injector);\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","<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]=\"isDisabled\"\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]=\"isDisabled\"\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]=\"isLoading()\"\n        (click)=\"reload()\"\n        data-cy=\"c8y-data-points-table-widget--reload-button\"\n      >\n        <i\n          c8yIcon=\"refresh\"\n          [ngClass]=\"{ 'icon-spin': isLoading() }\"\n        ></i>\n      </button>\n    </div>\n  </div>\n</div>\n"]}
|
|
@@ -1,23 +1,26 @@
|
|
|
1
1
|
import { Component, Input, signal } from '@angular/core';
|
|
2
2
|
import { FormBuilder, FormControl, ReactiveFormsModule } from '@angular/forms';
|
|
3
3
|
import { CommonModule, DismissAlertStrategy, DynamicComponentAlert, gettext } from '@c8y/ngx-components';
|
|
4
|
+
import { DataFetchingService, DatapointsExportSelectorComponent, dateRangeValidator } from '@c8y/ngx-components/datapoints-export-selector';
|
|
5
|
+
import { INTERVAL_VALUES } from '@c8y/ngx-components/interval-picker';
|
|
4
6
|
import { TranslateService } from '@ngx-translate/core';
|
|
5
|
-
import { TIME_RANGE_INTERVAL_UNITS_VALUES, dateRangeValidator } from '@c8y/ngx-components/datapoints-export-selector';
|
|
6
7
|
import { Subject, debounceTime } from 'rxjs';
|
|
7
|
-
import {
|
|
8
|
+
import { DATE_SELECTION_VALUES, DEFAULT_DPT_REFRESH_INTERVAL_VALUE } from '../datapoints-table-widget.model';
|
|
8
9
|
import { DatapointsTableService } from '../datapoints-table.service';
|
|
9
10
|
import { DateRangePickerComponent } from '../date-range-picker.component';
|
|
10
11
|
import { DatapointsReloadComponent } from './datapoints-reload/datapoints-reload.component';
|
|
11
12
|
import { DatapointsTableViewService } from './datapoints-table-view.service';
|
|
12
13
|
import { DatapointsTableComponent } from './datapoints-table/datapoints-table.component';
|
|
13
14
|
import * as i0 from "@angular/core";
|
|
14
|
-
import * as i1 from "
|
|
15
|
-
import * as i2 from "
|
|
16
|
-
import * as i3 from "
|
|
17
|
-
import * as i4 from "@
|
|
18
|
-
import * as i5 from "@
|
|
15
|
+
import * as i1 from "@c8y/ngx-components/datapoints-export-selector";
|
|
16
|
+
import * as i2 from "../datapoints-table.service";
|
|
17
|
+
import * as i3 from "./datapoints-table-view.service";
|
|
18
|
+
import * as i4 from "@angular/forms";
|
|
19
|
+
import * as i5 from "@ngx-translate/core";
|
|
20
|
+
import * as i6 from "@angular/common";
|
|
19
21
|
export class DatapointsTableViewWidgetComponent {
|
|
20
|
-
constructor(datapointsTableConfigService, datapointsTableViewService, formBuilder, translateService) {
|
|
22
|
+
constructor(dataFetchingService, datapointsTableConfigService, datapointsTableViewService, formBuilder, translateService) {
|
|
23
|
+
this.dataFetchingService = dataFetchingService;
|
|
21
24
|
this.datapointsTableConfigService = datapointsTableConfigService;
|
|
22
25
|
this.datapointsTableViewService = datapointsTableViewService;
|
|
23
26
|
this.formBuilder = formBuilder;
|
|
@@ -56,9 +59,15 @@ export class DatapointsTableViewWidgetComponent {
|
|
|
56
59
|
// this.handleGlobalTimeContextSettings();
|
|
57
60
|
// }
|
|
58
61
|
// Condition will be removed in MTM-61920
|
|
62
|
+
// Dashboard context is temporary not supported in the new implementation
|
|
59
63
|
if (this.config.widgetInstanceGlobalTimeContext) {
|
|
60
64
|
this.config.widgetInstanceGlobalTimeContext = false;
|
|
61
65
|
}
|
|
66
|
+
// Condition will be removed in MTM-61920
|
|
67
|
+
// Dashboard context is temporary not supported in the new implementation
|
|
68
|
+
if (this.config['globalDateSelector'] === 'dashboard_context') {
|
|
69
|
+
this.config['globalDateSelector'] = DATE_SELECTION_VALUES.config;
|
|
70
|
+
}
|
|
62
71
|
this.setScrollingSubscription();
|
|
63
72
|
const isLegacyWidgetRealtimeActive = this.config.realtime &&
|
|
64
73
|
!this.config.decimalPlaces &&
|
|
@@ -67,35 +76,24 @@ export class DatapointsTableViewWidgetComponent {
|
|
|
67
76
|
if (isLegacyWidgetRealtimeActive) {
|
|
68
77
|
this.setDefaultRefreshRelatedProperties();
|
|
69
78
|
}
|
|
70
|
-
if (
|
|
71
|
-
/**
|
|
72
|
-
* Fix for legacy widget bug.
|
|
73
|
-
* When new legacy widget is created and saved
|
|
74
|
-
* then interval value in a config would stay null until interval is manually changed
|
|
75
|
-
* and saved again.
|
|
76
|
-
* Bug was introduced post 1018.0.164 version of UI.
|
|
77
|
-
*/
|
|
78
|
-
this.config.interval = 'hours';
|
|
79
|
-
}
|
|
80
|
-
if (this.config.interval !== TIME_RANGE_INTERVAL_UNITS_VALUES.custom) {
|
|
79
|
+
if (this.config.interval !== INTERVAL_VALUES.custom) {
|
|
81
80
|
this.recalculateIntervalToMatchFromNowDate();
|
|
82
81
|
}
|
|
83
82
|
if (this.config.displayDateSelection) {
|
|
84
83
|
this.prepareDateRangeForm();
|
|
85
84
|
}
|
|
86
85
|
await this.prepareTableData();
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
// };
|
|
86
|
+
this.exportConfig = {
|
|
87
|
+
aggregation: this.config.aggregation,
|
|
88
|
+
dateFrom: this.config.dateFrom,
|
|
89
|
+
dateTo: this.config.dateTo,
|
|
90
|
+
datapointDetails: this.activeDatapoints.map(({ __target, fragment, series }) => ({
|
|
91
|
+
deviceName: __target.name,
|
|
92
|
+
source: __target.id,
|
|
93
|
+
valueFragmentSeries: series,
|
|
94
|
+
valueFragmentType: fragment
|
|
95
|
+
}))
|
|
96
|
+
};
|
|
99
97
|
}
|
|
100
98
|
ngOnDestroy() {
|
|
101
99
|
if (this.subscription) {
|
|
@@ -113,11 +111,7 @@ export class DatapointsTableViewWidgetComponent {
|
|
|
113
111
|
this.config.dateTo = data.dateTo;
|
|
114
112
|
}
|
|
115
113
|
this.prepareTableData();
|
|
116
|
-
|
|
117
|
-
// TODO-2: each manual/auto list reload should update exports config date range to sync current state of view with
|
|
118
|
-
// inital export config
|
|
119
|
-
// this.exportConfig.dateFrom = this.config.dateFrom;
|
|
120
|
-
// this.exportConfig.dateTo = this.config.dateTo;
|
|
114
|
+
this.updateExportConfigDateRange();
|
|
121
115
|
}
|
|
122
116
|
onExportModalOpen(isOpened) {
|
|
123
117
|
this.isExportModalOpen = isOpened;
|
|
@@ -129,12 +123,13 @@ export class DatapointsTableViewWidgetComponent {
|
|
|
129
123
|
const dateRange = this.datapointsTableViewService.prepareTimeRange(this.config.interval, this.config.dateFrom, this.config.dateTo);
|
|
130
124
|
this.config.dateFrom = dateRange.dateFrom;
|
|
131
125
|
this.config.dateTo = dateRange.dateTo;
|
|
126
|
+
this.updateExportConfigDateRange();
|
|
132
127
|
await this.prepareTableData(false);
|
|
133
128
|
this.onScrolling(false);
|
|
134
129
|
}
|
|
135
130
|
handleGlobalTimeContextSettings() {
|
|
136
|
-
this.config.dateFrom = this.
|
|
137
|
-
this.config.dateTo = this.
|
|
131
|
+
this.config.dateFrom = this.dataFetchingService.adjustDate(this.config.date[0], 0, false);
|
|
132
|
+
this.config.dateTo = this.dataFetchingService.adjustDate(this.config.date[1], 0, false);
|
|
138
133
|
if (this.config.realtime) {
|
|
139
134
|
this.setDefaultRefreshRelatedProperties();
|
|
140
135
|
}
|
|
@@ -154,7 +149,7 @@ export class DatapointsTableViewWidgetComponent {
|
|
|
154
149
|
}
|
|
155
150
|
setDefaultRefreshRelatedProperties() {
|
|
156
151
|
this.config.isAutoRefreshEnabled = true;
|
|
157
|
-
this.config.refreshInterval =
|
|
152
|
+
this.config.refreshInterval = DEFAULT_DPT_REFRESH_INTERVAL_VALUE;
|
|
158
153
|
}
|
|
159
154
|
recalculateIntervalToMatchFromNowDate() {
|
|
160
155
|
if (this.config.widgetInstanceGlobalTimeContext) {
|
|
@@ -259,24 +254,35 @@ export class DatapointsTableViewWidgetComponent {
|
|
|
259
254
|
</div>
|
|
260
255
|
`;
|
|
261
256
|
}
|
|
262
|
-
|
|
263
|
-
|
|
264
|
-
|
|
265
|
-
|
|
266
|
-
|
|
257
|
+
updateExportConfigDateRange() {
|
|
258
|
+
this.config.dateTo = this.adjustTargetDateBasedOnConditionTime(this.config.dateFrom, this.config.dateTo);
|
|
259
|
+
this.config.dateFrom = this.adjustTargetDateBasedOnConditionTime(this.config.dateTo, this.config.dateFrom);
|
|
260
|
+
this.syncExportConfigDates();
|
|
261
|
+
}
|
|
262
|
+
adjustTargetDateBasedOnConditionTime(conditionDate, targetDate) {
|
|
263
|
+
if (this.datapointsTableViewService.hasSecondsAndMillisecondsEqualZero(conditionDate)) {
|
|
264
|
+
return this.dataFetchingService.adjustDate(targetDate, 0, true);
|
|
265
|
+
}
|
|
266
|
+
return targetDate;
|
|
267
|
+
}
|
|
268
|
+
syncExportConfigDates() {
|
|
269
|
+
this.exportConfig.dateFrom = this.config.dateFrom;
|
|
270
|
+
this.exportConfig.dateTo = this.config.dateTo;
|
|
271
|
+
}
|
|
272
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: DatapointsTableViewWidgetComponent, deps: [{ token: i1.DataFetchingService }, { token: i2.DatapointsTableService }, { token: i3.DatapointsTableViewService }, { token: i4.FormBuilder }, { token: i5.TranslateService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
273
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.9", type: DatapointsTableViewWidgetComponent, isStandalone: true, selector: "c8y-datapoints-table-view", inputs: { config: "config" }, host: { classAttribute: "d-col fit-h" }, ngImport: i0, template: "<div class=\"d-flex gap-16 p-l-16 p-r-16 flex-wrap\">\n <ng-container *ngIf=\"config.displayDateSelection\">\n <form [formGroup]=\"formGroup\">\n <c8y-date-range-picker\n class=\"d-contents\"\n [isEmittingDateChange]=\"true\"\n [showLabel]=\"true\"\n (updatedDate)=\"onDateChange($event)\"\n ></c8y-date-range-picker>\n </form>\n </ng-container>\n <ng-container *ngIf=\"config.datapoints.length > 0\">\n <c8y-datapoints-reload\n class=\"d-contents\"\n [isAutoRefreshEnabled]=\"config.isAutoRefreshEnabled\"\n [refreshInterval]=\"config.refreshInterval\"\n [isDisabled]=\"isDisabled\"\n [isLoading]=\"isLoading\"\n [isScrolling]=\"isScrolling()\"\n [isExportModalOpen]=\"isExportModalOpen\"\n (onCountdownEnded)=\"onCountdownEnded()\"\n ></c8y-datapoints-reload>\n </ng-container>\n <c8y-datapoints-export-selector\n class=\"d-contents\"\n [exportConfig]=\"exportConfig\"\n (isOpen)=\"onExportModalOpen($event)\"\n ></c8y-datapoints-export-selector>\n</div>\n<ng-container *ngIf=\"devicesColumnHeaders\">\n <c8y-datapoints-table\n [aggregationType]=\"config.aggregation\"\n [datapointsTableItems]=\"datapointsTableItems\"\n [decimalPlaces]=\"config.decimalPlaces\"\n [devicesColumnHeaders]=\"devicesColumnHeaders\"\n [hasMultipleDatapoints]=\"hasMultipleDatapoints\"\n [isLoading]=\"isLoading()\"\n [seriesWithoutPermissionToReadCount]=\"seriesWithoutPermissionToRead?.length\"\n (isScrolling)=\"onScrolling($event)\"\n ></c8y-datapoints-table>\n</ng-container>\n", dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: DatapointsExportSelectorComponent, selector: "c8y-datapoints-export-selector", inputs: ["exportConfig"], outputs: ["isOpen"] }, { kind: "component", type: DatapointsReloadComponent, selector: "c8y-datapoints-reload", inputs: ["isAutoRefreshEnabled", "isDisabled", "isLoading", "isScrolling", "isExportModalOpen", "refreshInterval"], outputs: ["onCountdownEnded"] }, { kind: "component", type: DatapointsTableComponent, selector: "c8y-datapoints-table", inputs: ["aggregationType", "datapointsTableItems", "devicesColumnHeaders", "decimalPlaces", "hasMultipleDatapoints", "isLoading", "seriesWithoutPermissionToReadCount"], outputs: ["isScrolling"] }, { kind: "component", type: DateRangePickerComponent, selector: "c8y-date-range-picker", inputs: ["isEmittingDateChange", "showLabel"], outputs: ["updatedDate"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i4.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i4.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i4.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }] }); }
|
|
267
274
|
}
|
|
268
275
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: DatapointsTableViewWidgetComponent, decorators: [{
|
|
269
276
|
type: Component,
|
|
270
277
|
args: [{ selector: 'c8y-datapoints-table-view', host: { class: 'd-col fit-h' }, standalone: true, imports: [
|
|
271
278
|
CommonModule,
|
|
272
|
-
|
|
273
|
-
// DatapointsExportSelectorComponent,
|
|
279
|
+
DatapointsExportSelectorComponent,
|
|
274
280
|
DatapointsReloadComponent,
|
|
275
281
|
DatapointsTableComponent,
|
|
276
282
|
DateRangePickerComponent,
|
|
277
283
|
ReactiveFormsModule
|
|
278
|
-
], template: "<div class=\"d-flex gap-16 p-l-16 p-r-16 flex-wrap\">\n <ng-container *ngIf=\"config.displayDateSelection\">\n <form [formGroup]=\"formGroup\">\n <c8y-date-range-picker\n class=\"d-contents\"\n [isEmittingDateChange]=\"true\"\n [showLabel]=\"true\"\n (updatedDate)=\"onDateChange($event)\"\n ></c8y-date-range-picker>\n </form>\n </ng-container>\n
|
|
279
|
-
}], ctorParameters: () => [{ type: i1.
|
|
284
|
+
], template: "<div class=\"d-flex gap-16 p-l-16 p-r-16 flex-wrap\">\n <ng-container *ngIf=\"config.displayDateSelection\">\n <form [formGroup]=\"formGroup\">\n <c8y-date-range-picker\n class=\"d-contents\"\n [isEmittingDateChange]=\"true\"\n [showLabel]=\"true\"\n (updatedDate)=\"onDateChange($event)\"\n ></c8y-date-range-picker>\n </form>\n </ng-container>\n <ng-container *ngIf=\"config.datapoints.length > 0\">\n <c8y-datapoints-reload\n class=\"d-contents\"\n [isAutoRefreshEnabled]=\"config.isAutoRefreshEnabled\"\n [refreshInterval]=\"config.refreshInterval\"\n [isDisabled]=\"isDisabled\"\n [isLoading]=\"isLoading\"\n [isScrolling]=\"isScrolling()\"\n [isExportModalOpen]=\"isExportModalOpen\"\n (onCountdownEnded)=\"onCountdownEnded()\"\n ></c8y-datapoints-reload>\n </ng-container>\n <c8y-datapoints-export-selector\n class=\"d-contents\"\n [exportConfig]=\"exportConfig\"\n (isOpen)=\"onExportModalOpen($event)\"\n ></c8y-datapoints-export-selector>\n</div>\n<ng-container *ngIf=\"devicesColumnHeaders\">\n <c8y-datapoints-table\n [aggregationType]=\"config.aggregation\"\n [datapointsTableItems]=\"datapointsTableItems\"\n [decimalPlaces]=\"config.decimalPlaces\"\n [devicesColumnHeaders]=\"devicesColumnHeaders\"\n [hasMultipleDatapoints]=\"hasMultipleDatapoints\"\n [isLoading]=\"isLoading()\"\n [seriesWithoutPermissionToReadCount]=\"seriesWithoutPermissionToRead?.length\"\n (isScrolling)=\"onScrolling($event)\"\n ></c8y-datapoints-table>\n</ng-container>\n" }]
|
|
285
|
+
}], ctorParameters: () => [{ type: i1.DataFetchingService }, { type: i2.DatapointsTableService }, { type: i3.DatapointsTableViewService }, { type: i4.FormBuilder }, { type: i5.TranslateService }], propDecorators: { config: [{
|
|
280
286
|
type: Input
|
|
281
287
|
}] } });
|
|
282
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datapoints-table-view.component.js","sourceRoot":"","sources":["../../../../../../widgets/implementations/datapoints-table/datapoints-table-view/datapoints-table-view.component.ts","../../../../../../widgets/implementations/datapoints-table/datapoints-table-view/datapoints-table-view.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnDestroy, OnInit, signal } from '@angular/core';\nimport { FormBuilder, FormControl, ReactiveFormsModule } from '@angular/forms';\nimport {\n  CommonModule,\n  DismissAlertStrategy,\n  DynamicComponentAlert,\n  DynamicComponentAlertAggregator,\n  gettext\n} from '@c8y/ngx-components';\nimport { KPIDetails } from '@c8y/ngx-components/datapoint-selector';\nimport { TranslateService } from '@ngx-translate/core';\n// TODO: temporarily commented out, will be enabled when MTM-59689 is integrated\n// import {\n//   DatapointsExportSelectorComponent,\n//   ExportConfig\n// } from '@c8y/ngx-components/datapoints-export-selector';\nimport { ISeries } from '@c8y/client';\nimport {\n  DatapointsValuesDataMap,\n  SourceId,\n  TIME_RANGE_INTERVAL_UNITS_VALUES,\n  dateRangeValidator\n} from '@c8y/ngx-components/datapoints-export-selector';\nimport { Subject, Subscription, debounceTime } from 'rxjs';\nimport {\n  DEFAULT_COUNTDOWN_VALUE,\n  DatapointTableItem,\n  DatapointWithValues,\n  DatapointsTableConfig,\n  GroupedDatapointTableItem,\n  TableColumnHeader\n} from '../datapoints-table-widget.model';\nimport { DatapointsTableService } from '../datapoints-table.service';\nimport { DateRangePickerComponent } from '../date-range-picker.component';\nimport { DatapointsReloadComponent } from './datapoints-reload/datapoints-reload.component';\nimport { DatapointsTableViewService } from './datapoints-table-view.service';\nimport { DatapointsTableComponent } from './datapoints-table/datapoints-table.component';\n\n@Component({\n  selector: 'c8y-datapoints-table-view',\n  templateUrl: './datapoints-table-view.component.html',\n  host: { class: 'd-col fit-h' },\n  standalone: true,\n  imports: [\n    CommonModule,\n    // TODO: temporarily commented out, will be enabled when MTM-59689 is integrated\n    // DatapointsExportSelectorComponent,\n    DatapointsReloadComponent,\n    DatapointsTableComponent,\n    DateRangePickerComponent,\n    ReactiveFormsModule\n  ]\n})\nexport class DatapointsTableViewWidgetComponent implements OnInit, OnDestroy {\n  /**\n   *  Data points table widget config.\n   */\n  @Input() config: DatapointsTableConfig;\n  // config: DatapointsTableConfig;\n\n  alerts: DynamicComponentAlertAggregator;\n\n  /**\n   * Represents the data points where __active property is set to true.\n   */\n  activeDatapoints: KPIDetails[] = [];\n  /**\n   * An array of objects representing datapoints with their corresponding values.\n   * Used to populate the CSV/Excel file with data.\n   */\n  datapointsWithValues: DatapointWithValues[];\n  /**\n   * An array of `GroupedDatapointTableItem` objects representing the datapoints table items.\n   * Used to populate the table with data.\n   */\n  datapointsTableItems: GroupedDatapointTableItem[] = [];\n\n  devicesColumnHeaders: TableColumnHeader[];\n  /**\n   * Represents a configuration options used by a c8y-datapoints-export-selector.\n   */\n  // TODO: temporarily commented out, will be enabled when MTM-59689 is integrated\n  // exportConfig: ExportConfig;\n\n  formGroup: ReturnType<DatapointsTableViewWidgetComponent['createForm']>;\n  /**\n   * Indicates whether there is more than one data point.\n   * If is true, then a column 'Device' will be displayed in the table.\n   */\n  hasMultipleDatapoints: boolean;\n\n  isDisabled = false;\n\n  /**\n   * Indicates whether the component is in the initial request state\n   * where data for a table structure is being prepared.\n   */\n  isInitialRequest = true;\n  /**\n   * Current isLoading state. Indicates whether the data is being loaded.\n   */\n  isLoading = signal(true);\n\n  isExportModalOpen = false;\n\n  isScrolling = signal(false);\n\n  seriesWithoutPermissionToRead: { key: SourceId; value: string[] }[];\n\n  private scrollingSubject$: Subject<boolean> = new Subject<boolean>();\n  private subscription: Subscription;\n  /**\n   * Indicates if the alert has already been displayed and can be dismissed.\n   * The message is only displayed when a component is initialized.\n   */\n  private isMissingAnyPermissionAlertShown = false;\n\n  constructor(\n    private datapointsTableConfigService: DatapointsTableService,\n    private datapointsTableViewService: DatapointsTableViewService,\n    private formBuilder: FormBuilder,\n    private translateService: TranslateService\n  ) {}\n\n  async ngOnInit(): Promise<void> {\n    // Will be uncommented in MTM-61920\n    // if (this.config.widgetInstanceGlobalTimeContext) {\n    //   this.handleGlobalTimeContextSettings();\n    // }\n\n    // Condition will be removed in MTM-61920\n    if (this.config.widgetInstanceGlobalTimeContext) {\n      this.config.widgetInstanceGlobalTimeContext = false;\n    }\n\n    this.setScrollingSubscription();\n\n    const isLegacyWidgetRealtimeActive =\n      this.config.realtime &&\n      !this.config.decimalPlaces &&\n      !this.config.refreshInterval &&\n      !this.config.isAutoRefreshEnabled;\n\n    if (isLegacyWidgetRealtimeActive) {\n      this.setDefaultRefreshRelatedProperties();\n    }\n\n    if (!this.config.interval) {\n      /**\n       * Fix for legacy widget bug.\n       * When new legacy widget is created and saved\n       * then interval value in a config would stay null until interval is manually changed\n       * and saved again.\n       * Bug was introduced post 1018.0.164 version of UI.\n       */\n      this.config.interval = 'hours';\n    }\n\n    if (this.config.interval !== TIME_RANGE_INTERVAL_UNITS_VALUES.custom) {\n      this.recalculateIntervalToMatchFromNowDate();\n    }\n\n    if (this.config.displayDateSelection) {\n      this.prepareDateRangeForm();\n    }\n\n    await this.prepareTableData();\n\n    // TODO: temporarily commented out, will be enabled when MTM-59689 is integrated\n    // this.exportConfig = {\n    //   aggregation: this.config.aggregation,\n    //   dateFrom: this.config.dateFrom,\n    //   dateTo: this.config.dateTo,\n    //   datapointDetails: this.activeDatapoints.map(({ __target, fragment, series }) => ({\n    //     deviceName: __target.name,\n    //     source: __target.id,\n    //     valueFragmentSeries: series,\n    //     valueFragmentType: fragment\n    //   }))\n    // };\n  }\n\n  ngOnDestroy(): void {\n    if (this.subscription) {\n      this.subscription.unsubscribe();\n    }\n  }\n\n  onDateChange(data: { dateFrom?: string | null; dateTo?: string | null }): void {\n    if (this.formGroup.invalid) {\n      return;\n    }\n\n    if (data.dateFrom) {\n      this.config.dateFrom = data.dateFrom;\n    }\n    if (data.dateTo) {\n      this.config.dateTo = data.dateTo;\n    }\n    this.prepareTableData();\n\n    // TODO: temporarily commented out, will be enabled when MTM-59689 is integrated\n    // TODO-2: each manual/auto list reload should update exports config date range to sync current state of view with\n    // inital export config\n    // this.exportConfig.dateFrom = this.config.dateFrom;\n    // this.exportConfig.dateTo = this.config.dateTo;\n  }\n\n  onExportModalOpen(isOpened: boolean): void {\n    this.isExportModalOpen = isOpened;\n  }\n\n  onScrolling(value: boolean): void {\n    this.scrollingSubject$.next(value);\n  }\n\n  async onCountdownEnded(): Promise<void> {\n    const dateRange = this.datapointsTableViewService.prepareTimeRange(\n      this.config.interval,\n      this.config.dateFrom,\n      this.config.dateTo\n    );\n\n    this.config.dateFrom = dateRange.dateFrom;\n    this.config.dateTo = dateRange.dateTo;\n\n    await this.prepareTableData(false);\n\n    this.onScrolling(false);\n  }\n\n  private handleGlobalTimeContextSettings(): void {\n    this.config.dateFrom = this.datapointsTableViewService.adjustDate(\n      this.config.date[0],\n      0,\n      false\n    );\n    this.config.dateTo = this.datapointsTableViewService.adjustDate(this.config.date[1], 0, false);\n    if (this.config.realtime) {\n      this.setDefaultRefreshRelatedProperties();\n    } else {\n      this.config.isAutoRefreshEnabled = false;\n    }\n  }\n\n  /**\n   * Sets up the scrolling subscription.\n   *\n   * Ensures similar UX as in the alarms countdown-pause logic.\n   */\n  private setScrollingSubscription(): void {\n    this.subscription = this.scrollingSubject$\n      .pipe(debounceTime(300))\n      .subscribe(value => this.isScrolling.set(value));\n  }\n\n  private setDefaultRefreshRelatedProperties(): void {\n    this.config.isAutoRefreshEnabled = true;\n    this.config.refreshInterval = DEFAULT_COUNTDOWN_VALUE;\n  }\n\n  private recalculateIntervalToMatchFromNowDate(): void {\n    if (this.config.widgetInstanceGlobalTimeContext) {\n      return;\n    }\n\n    const { dateFrom, dateTo } = this.datapointsTableConfigService.calculateDateRange(\n      this.config.interval\n    );\n    this.config.dateFrom = dateFrom;\n    this.config.dateTo = dateTo;\n  }\n\n  private prepareDateRangeForm() {\n    this.formGroup = this.createForm();\n  }\n\n  private createForm() {\n    return this.formBuilder.group(\n      {\n        dateFrom: new FormControl(this.config.dateFrom),\n        dateTo: new FormControl(this.config.dateTo)\n      },\n      { validators: dateRangeValidator }\n    );\n  }\n\n  /**\n   * Prepares the table data by:\n   * - filtering out inactive data points,\n   * - checking if there are multiple devices as a source of data points,\n   * - getting the column headers for devices,\n   * - getting the series data for active data points (API call),\n   * - preparing data points with values list,\n   * - mapping data points with values to list items,\n   * - grouping data points by date and device,\n   * - sorting data by date descending.\n   *\n   * @param roundSeconds - Whether to round the seconds or not.\n   *                       If true, the seconds will be rounded to 0.\n   *                       If false, the seconds will be displayed as they are.\n   */\n  private async prepareTableData(roundSeconds = true): Promise<void> {\n    this.isLoading.set(true);\n\n    if (this.isInitialRequest) {\n      this.activeDatapoints = this.datapointsTableViewService.filterOutInactiveDatapoints(\n        this.config.datapoints\n      );\n\n      this.hasMultipleDatapoints = this.datapointsTableViewService.hasMultipleDatapoints(\n        this.activeDatapoints\n      );\n\n      this.devicesColumnHeaders = this.datapointsTableViewService.getColumnHeaders(\n        this.activeDatapoints\n      );\n\n      this.isInitialRequest = false;\n    }\n\n    const activeDatapointsIdsWithSeries: DatapointsValuesDataMap =\n      this.datapointsTableViewService.groupSeriesByDeviceId(this.activeDatapoints);\n\n    const activeDatapointsSeriesData: Map<string | number, ISeries> =\n      await this.getActiveDatapointsSeriesDataMap(\n        activeDatapointsIdsWithSeries,\n        this.config,\n        roundSeconds\n      );\n\n    this.seriesWithoutPermissionToRead =\n      this.datapointsTableViewService.getSeriesWithoutPermissionToRead(\n        activeDatapointsSeriesData,\n        activeDatapointsIdsWithSeries\n      );\n\n    if (\n      !this.isMissingAnyPermissionAlertShown &&\n      this.seriesWithoutPermissionToRead?.length > 0 &&\n      activeDatapointsSeriesData?.size\n    ) {\n      this.handleMissingAnyPermissionErrorMessage();\n      this.isMissingAnyPermissionAlertShown = true;\n    }\n\n    if (!activeDatapointsSeriesData) {\n      return;\n    }\n\n    this.datapointsWithValues = this.datapointsTableViewService.getDatapointsWithValues(\n      this.activeDatapoints,\n      activeDatapointsSeriesData\n    );\n\n    const datapointsListItems: DatapointTableItem[] =\n      this.datapointsTableViewService.mapDatapointsWithValuesToList(this.datapointsWithValues);\n\n    const groupedDatapointsListItems: GroupedDatapointTableItem[] =\n      this.datapointsTableViewService.groupByDateAndDevice(\n        datapointsListItems,\n        this.devicesColumnHeaders\n      );\n\n    this.datapointsTableItems = this.datapointsTableViewService.sortDataByDateDescending(\n      groupedDatapointsListItems\n    );\n\n    this.isLoading.set(false);\n  }\n\n  /**\n   * Retrieves the active data points series data and returns it as a map.\n   *\n   * It's a wrapper method with try-catch block.\n   *\n   * @param datapointsIdsWithSeries - A map of data point IDs with their associated series.\n   * @param config - The configuration of the data points table.\n   * @param roundSeconds - Whether to round the seconds or not.\n   *                       If true, the seconds will be rounded to 0.\n   *                       If false, the seconds will be displayed as they are.\n   * @returns A Promise that resolves to a Map object with data point IDs as keys and DataObject as values.\n   */\n  private async getActiveDatapointsSeriesDataMap(\n    datapointsIdsWithSeries: DatapointsValuesDataMap,\n    config: DatapointsTableConfig,\n    roundSeconds: boolean\n  ): Promise<Map<string | number, ISeries>> {\n    try {\n      return await this.datapointsTableViewService.getAllActiveSeriesDataMap(\n        datapointsIdsWithSeries,\n        config,\n        roundSeconds\n      );\n    } catch (error) {\n      this.isDisabled = true;\n      this.isLoading.set(false);\n    }\n  }\n\n  private handleMissingAnyPermissionErrorMessage() {\n    this.alerts.setAlertGroupDismissStrategy('system', DismissAlertStrategy.TEMPORARY);\n\n    this.alerts.addAlerts(\n      new DynamicComponentAlert({\n        allowHtml: true,\n        text: this.getMissingPermissionsMessage(),\n        type: 'system'\n      })\n    );\n  }\n\n  private getMissingPermissionsMessage(): string {\n    const baseMessage = this.translateService.instant(\n      gettext(`You don't have permissions to read the following series:`)\n    );\n\n    const formattedList = this.seriesWithoutPermissionToRead\n      .map(datapoint => `<li>${datapoint.key.valueOf()}_${datapoint.value}</li>`)\n      .join('');\n\n    return `\n      <div>\n        <p>${baseMessage}</p>\n        <ul>\n          ${formattedList}\n        </ul>\n        <p><strong>Note:</strong> The name convention for each list item is: <code>[source]_[fragment.series]</code></p>\n      </div>\n    `;\n  }\n}\n","<div class=\"d-flex gap-16 p-l-16 p-r-16 flex-wrap\">\n  <ng-container *ngIf=\"config.displayDateSelection\">\n    <form [formGroup]=\"formGroup\">\n      <c8y-date-range-picker\n        class=\"d-contents\"\n        [isEmittingDateChange]=\"true\"\n        [showLabel]=\"true\"\n        (updatedDate)=\"onDateChange($event)\"\n      ></c8y-date-range-picker>\n    </form>\n  </ng-container>\n  <!-- TODO: temporarily commented out, will be enabled when MTM-59689 is integrated -->\n  <!-- <c8y-datapoints-export-selector\n    class=\"d-contents\"\n    [exportConfig]=\"exportConfig\"\n    (isExportModalOpen)=\"onExportModalOpen($event)\"\n  ></c8y-datapoints-export-selector> -->\n  <!-- TODO: below div is just a temp fix, it will be removed when MTM-59689 is integrated  -->\n  <div class=\"input-group p-t-4 p-b-4 max-width-fit m-l-auto\"></div>\n  <ng-container *ngIf=\"config.datapoints.length > 0\">\n    <c8y-datapoints-reload\n      class=\"d-contents\"\n      [isAutoRefreshEnabled]=\"config.isAutoRefreshEnabled\"\n      [refreshInterval]=\"config.refreshInterval\"\n      [isDisabled]=\"isDisabled\"\n      [isLoading]=\"isLoading\"\n      [isScrolling]=\"isScrolling()\"\n      [isExportModalOpen]=\"isExportModalOpen\"\n      (onCountdownEnded)=\"onCountdownEnded()\"\n    ></c8y-datapoints-reload>\n  </ng-container>\n</div>\n<ng-container *ngIf=\"devicesColumnHeaders\">\n  <c8y-datapoints-table\n    [aggregationType]=\"config.aggregation\"\n    [datapointsTableItems]=\"datapointsTableItems\"\n    [decimalPlaces]=\"config.decimalPlaces\"\n    [devicesColumnHeaders]=\"devicesColumnHeaders\"\n    [hasMultipleDatapoints]=\"hasMultipleDatapoints\"\n    [isLoading]=\"isLoading()\"\n    [seriesWithoutPermissionToReadCount]=\"seriesWithoutPermissionToRead?.length\"\n    (isScrolling)=\"onScrolling($event)\"\n  ></c8y-datapoints-table>\n</ng-container>\n"]}
|
|
288
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datapoints-table-view.component.js","sourceRoot":"","sources":["../../../../../../widgets/implementations/datapoints-table/datapoints-table-view/datapoints-table-view.component.ts","../../../../../../widgets/implementations/datapoints-table/datapoints-table-view/datapoints-table-view.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnDestroy, OnInit, signal } from '@angular/core';\nimport { FormBuilder, FormControl, ReactiveFormsModule } from '@angular/forms';\nimport { ISeries } from '@c8y/client';\nimport {\n  CommonModule,\n  DismissAlertStrategy,\n  DynamicComponentAlert,\n  DynamicComponentAlertAggregator,\n  gettext\n} from '@c8y/ngx-components';\nimport { KPIDetails } from '@c8y/ngx-components/datapoint-selector';\nimport {\n  DataFetchingService,\n  DatapointsExportSelectorComponent,\n  DatapointsValuesDataMap,\n  ExportConfig,\n  SourceId,\n  dateRangeValidator\n} from '@c8y/ngx-components/datapoints-export-selector';\nimport { INTERVAL_VALUES } from '@c8y/ngx-components/interval-picker';\nimport { TranslateService } from '@ngx-translate/core';\nimport { Subject, Subscription, debounceTime } from 'rxjs';\nimport {\n  DATE_SELECTION_VALUES,\n  DEFAULT_DPT_REFRESH_INTERVAL_VALUE,\n  DatapointTableItem,\n  DatapointWithValues,\n  DatapointsTableConfig,\n  GroupedDatapointTableItem,\n  TableColumnHeader\n} from '../datapoints-table-widget.model';\nimport { DatapointsTableService } from '../datapoints-table.service';\nimport { DateRangePickerComponent } from '../date-range-picker.component';\nimport { DatapointsReloadComponent } from './datapoints-reload/datapoints-reload.component';\nimport { DatapointsTableViewService } from './datapoints-table-view.service';\nimport { DatapointsTableComponent } from './datapoints-table/datapoints-table.component';\n\n@Component({\n  selector: 'c8y-datapoints-table-view',\n  templateUrl: './datapoints-table-view.component.html',\n  host: { class: 'd-col fit-h' },\n  standalone: true,\n  imports: [\n    CommonModule,\n    DatapointsExportSelectorComponent,\n    DatapointsReloadComponent,\n    DatapointsTableComponent,\n    DateRangePickerComponent,\n    ReactiveFormsModule\n  ]\n})\nexport class DatapointsTableViewWidgetComponent implements OnInit, OnDestroy {\n  /**\n   *  Data points table widget config.\n   */\n  @Input() config: DatapointsTableConfig;\n\n  alerts: DynamicComponentAlertAggregator;\n\n  /**\n   * Represents the data points where __active property is set to true.\n   */\n  activeDatapoints: KPIDetails[] = [];\n  /**\n   * An array of objects representing datapoints with their corresponding values.\n   * Used to populate the CSV/Excel file with data.\n   */\n  datapointsWithValues: DatapointWithValues[];\n  /**\n   * An array of `GroupedDatapointTableItem` objects representing the datapoints table items.\n   * Used to populate the table with data.\n   */\n  datapointsTableItems: GroupedDatapointTableItem[] = [];\n\n  devicesColumnHeaders: TableColumnHeader[];\n  /**\n   * Represents a configuration options used by a c8y-datapoints-export-selector.\n   */\n  exportConfig: ExportConfig;\n\n  formGroup: ReturnType<DatapointsTableViewWidgetComponent['createForm']>;\n  /**\n   * Indicates whether there is more than one data point.\n   * If is true, then a column 'Device' will be displayed in the table.\n   */\n  hasMultipleDatapoints: boolean;\n\n  isDisabled = false;\n\n  /**\n   * Indicates whether the component is in the initial request state\n   * where data for a table structure is being prepared.\n   */\n  isInitialRequest = true;\n  /**\n   * Current isLoading state. Indicates whether the data is being loaded.\n   */\n  isLoading = signal(true);\n\n  isExportModalOpen = false;\n\n  isScrolling = signal(false);\n\n  seriesWithoutPermissionToRead: { key: SourceId; value: string[] }[];\n\n  private scrollingSubject$: Subject<boolean> = new Subject<boolean>();\n  private subscription: Subscription;\n  /**\n   * Indicates if the alert has already been displayed and can be dismissed.\n   * The message is only displayed when a component is initialized.\n   */\n  private isMissingAnyPermissionAlertShown = false;\n\n  constructor(\n    private dataFetchingService: DataFetchingService,\n    private datapointsTableConfigService: DatapointsTableService,\n    private datapointsTableViewService: DatapointsTableViewService,\n    private formBuilder: FormBuilder,\n    private translateService: TranslateService\n  ) {}\n\n  async ngOnInit(): Promise<void> {\n    // Will be uncommented in MTM-61920\n    // if (this.config.widgetInstanceGlobalTimeContext) {\n    //   this.handleGlobalTimeContextSettings();\n    // }\n\n    // Condition will be removed in MTM-61920\n    // Dashboard context is temporary not supported in the new implementation\n    if (this.config.widgetInstanceGlobalTimeContext) {\n      this.config.widgetInstanceGlobalTimeContext = false;\n    }\n\n    // Condition will be removed in MTM-61920\n    // Dashboard context is temporary not supported in the new implementation\n    if (this.config['globalDateSelector'] === 'dashboard_context') {\n      this.config['globalDateSelector'] = DATE_SELECTION_VALUES.config;\n    }\n\n    this.setScrollingSubscription();\n\n    const isLegacyWidgetRealtimeActive =\n      this.config.realtime &&\n      !this.config.decimalPlaces &&\n      !this.config.refreshInterval &&\n      !this.config.isAutoRefreshEnabled;\n\n    if (isLegacyWidgetRealtimeActive) {\n      this.setDefaultRefreshRelatedProperties();\n    }\n\n    if (this.config.interval !== INTERVAL_VALUES.custom) {\n      this.recalculateIntervalToMatchFromNowDate();\n    }\n\n    if (this.config.displayDateSelection) {\n      this.prepareDateRangeForm();\n    }\n\n    await this.prepareTableData();\n\n    this.exportConfig = {\n      aggregation: this.config.aggregation,\n      dateFrom: this.config.dateFrom,\n      dateTo: this.config.dateTo,\n      datapointDetails: this.activeDatapoints.map(({ __target, fragment, series }) => ({\n        deviceName: __target.name,\n        source: __target.id,\n        valueFragmentSeries: series,\n        valueFragmentType: fragment\n      }))\n    };\n  }\n\n  ngOnDestroy(): void {\n    if (this.subscription) {\n      this.subscription.unsubscribe();\n    }\n  }\n\n  onDateChange(data: { dateFrom?: string | null; dateTo?: string | null }): void {\n    if (this.formGroup.invalid) {\n      return;\n    }\n\n    if (data.dateFrom) {\n      this.config.dateFrom = data.dateFrom;\n    }\n    if (data.dateTo) {\n      this.config.dateTo = data.dateTo;\n    }\n    this.prepareTableData();\n\n    this.updateExportConfigDateRange();\n  }\n\n  onExportModalOpen(isOpened: boolean): void {\n    this.isExportModalOpen = isOpened;\n  }\n\n  onScrolling(value: boolean): void {\n    this.scrollingSubject$.next(value);\n  }\n\n  async onCountdownEnded(): Promise<void> {\n    const dateRange = this.datapointsTableViewService.prepareTimeRange(\n      this.config.interval,\n      this.config.dateFrom,\n      this.config.dateTo\n    );\n\n    this.config.dateFrom = dateRange.dateFrom;\n    this.config.dateTo = dateRange.dateTo;\n\n    this.updateExportConfigDateRange();\n    await this.prepareTableData(false);\n\n    this.onScrolling(false);\n  }\n\n  private handleGlobalTimeContextSettings(): void {\n    this.config.dateFrom = this.dataFetchingService.adjustDate(this.config.date[0], 0, false);\n    this.config.dateTo = this.dataFetchingService.adjustDate(this.config.date[1], 0, false);\n    if (this.config.realtime) {\n      this.setDefaultRefreshRelatedProperties();\n    } else {\n      this.config.isAutoRefreshEnabled = false;\n    }\n  }\n\n  /**\n   * Sets up the scrolling subscription.\n   *\n   * Ensures similar UX as in the alarms countdown-pause logic.\n   */\n  private setScrollingSubscription(): void {\n    this.subscription = this.scrollingSubject$\n      .pipe(debounceTime(300))\n      .subscribe(value => this.isScrolling.set(value));\n  }\n\n  private setDefaultRefreshRelatedProperties(): void {\n    this.config.isAutoRefreshEnabled = true;\n    this.config.refreshInterval = DEFAULT_DPT_REFRESH_INTERVAL_VALUE;\n  }\n\n  private recalculateIntervalToMatchFromNowDate(): void {\n    if (this.config.widgetInstanceGlobalTimeContext) {\n      return;\n    }\n\n    const { dateFrom, dateTo } = this.datapointsTableConfigService.calculateDateRange(\n      this.config.interval\n    );\n    this.config.dateFrom = dateFrom;\n    this.config.dateTo = dateTo;\n  }\n\n  private prepareDateRangeForm() {\n    this.formGroup = this.createForm();\n  }\n\n  private createForm() {\n    return this.formBuilder.group(\n      {\n        dateFrom: new FormControl(this.config.dateFrom),\n        dateTo: new FormControl(this.config.dateTo)\n      },\n      { validators: dateRangeValidator }\n    );\n  }\n\n  /**\n   * Prepares the table data by:\n   * - filtering out inactive data points,\n   * - checking if there are multiple devices as a source of data points,\n   * - getting the column headers for devices,\n   * - getting the series data for active data points (API call),\n   * - preparing data points with values list,\n   * - mapping data points with values to list items,\n   * - grouping data points by date and device,\n   * - sorting data by date descending.\n   *\n   * @param roundSeconds - Whether to round the seconds or not.\n   *                       If true, the seconds will be rounded to 0.\n   *                       If false, the seconds will be displayed as they are.\n   */\n  private async prepareTableData(roundSeconds = true): Promise<void> {\n    this.isLoading.set(true);\n\n    if (this.isInitialRequest) {\n      this.activeDatapoints = this.datapointsTableViewService.filterOutInactiveDatapoints(\n        this.config.datapoints\n      );\n\n      this.hasMultipleDatapoints = this.datapointsTableViewService.hasMultipleDatapoints(\n        this.activeDatapoints\n      );\n\n      this.devicesColumnHeaders = this.datapointsTableViewService.getColumnHeaders(\n        this.activeDatapoints\n      );\n\n      this.isInitialRequest = false;\n    }\n\n    const activeDatapointsIdsWithSeries: DatapointsValuesDataMap =\n      this.datapointsTableViewService.groupSeriesByDeviceId(this.activeDatapoints);\n\n    const activeDatapointsSeriesData: Map<string | number, ISeries> =\n      await this.getActiveDatapointsSeriesDataMap(\n        activeDatapointsIdsWithSeries,\n        this.config,\n        roundSeconds\n      );\n\n    this.seriesWithoutPermissionToRead =\n      this.datapointsTableViewService.getSeriesWithoutPermissionToRead(\n        activeDatapointsSeriesData,\n        activeDatapointsIdsWithSeries\n      );\n\n    if (\n      !this.isMissingAnyPermissionAlertShown &&\n      this.seriesWithoutPermissionToRead?.length > 0 &&\n      activeDatapointsSeriesData?.size\n    ) {\n      this.handleMissingAnyPermissionErrorMessage();\n      this.isMissingAnyPermissionAlertShown = true;\n    }\n\n    if (!activeDatapointsSeriesData) {\n      return;\n    }\n\n    this.datapointsWithValues = this.datapointsTableViewService.getDatapointsWithValues(\n      this.activeDatapoints,\n      activeDatapointsSeriesData\n    );\n\n    const datapointsListItems: DatapointTableItem[] =\n      this.datapointsTableViewService.mapDatapointsWithValuesToList(this.datapointsWithValues);\n\n    const groupedDatapointsListItems: GroupedDatapointTableItem[] =\n      this.datapointsTableViewService.groupByDateAndDevice(\n        datapointsListItems,\n        this.devicesColumnHeaders\n      );\n\n    this.datapointsTableItems = this.datapointsTableViewService.sortDataByDateDescending(\n      groupedDatapointsListItems\n    );\n\n    this.isLoading.set(false);\n  }\n\n  /**\n   * Retrieves the active data points series data and returns it as a map.\n   *\n   * It's a wrapper method with try-catch block.\n   *\n   * @param datapointsIdsWithSeries - A map of data point IDs with their associated series.\n   * @param config - The configuration of the data points table.\n   * @param roundSeconds - Whether to round the seconds or not.\n   *                       If true, the seconds will be rounded to 0.\n   *                       If false, the seconds will be displayed as they are.\n   * @returns A Promise that resolves to a Map object with data point IDs as keys and DataObject as values.\n   */\n  private async getActiveDatapointsSeriesDataMap(\n    datapointsIdsWithSeries: DatapointsValuesDataMap,\n    config: DatapointsTableConfig,\n    roundSeconds: boolean\n  ): Promise<Map<string | number, ISeries>> {\n    try {\n      return await this.datapointsTableViewService.getAllActiveSeriesDataMap(\n        datapointsIdsWithSeries,\n        config,\n        roundSeconds\n      );\n    } catch (error) {\n      this.isDisabled = true;\n      this.isLoading.set(false);\n    }\n  }\n\n  private handleMissingAnyPermissionErrorMessage() {\n    this.alerts.setAlertGroupDismissStrategy('system', DismissAlertStrategy.TEMPORARY);\n\n    this.alerts.addAlerts(\n      new DynamicComponentAlert({\n        allowHtml: true,\n        text: this.getMissingPermissionsMessage(),\n        type: 'system'\n      })\n    );\n  }\n\n  private getMissingPermissionsMessage(): string {\n    const baseMessage = this.translateService.instant(\n      gettext(`You don't have permissions to read the following series:`)\n    );\n\n    const formattedList = this.seriesWithoutPermissionToRead\n      .map(datapoint => `<li>${datapoint.key.valueOf()}_${datapoint.value}</li>`)\n      .join('');\n\n    return `\n      <div>\n        <p>${baseMessage}</p>\n        <ul>\n          ${formattedList}\n        </ul>\n        <p><strong>Note:</strong> The name convention for each list item is: <code>[source]_[fragment.series]</code></p>\n      </div>\n    `;\n  }\n\n  private updateExportConfigDateRange(): void {\n    this.config.dateTo = this.adjustTargetDateBasedOnConditionTime(\n      this.config.dateFrom,\n      this.config.dateTo\n    );\n\n    this.config.dateFrom = this.adjustTargetDateBasedOnConditionTime(\n      this.config.dateTo,\n      this.config.dateFrom\n    );\n\n    this.syncExportConfigDates();\n  }\n\n  private adjustTargetDateBasedOnConditionTime(conditionDate: string, targetDate: string): string {\n    if (this.datapointsTableViewService.hasSecondsAndMillisecondsEqualZero(conditionDate)) {\n      return this.dataFetchingService.adjustDate(targetDate, 0, true);\n    }\n    return targetDate;\n  }\n\n  private syncExportConfigDates(): void {\n    this.exportConfig.dateFrom = this.config.dateFrom;\n    this.exportConfig.dateTo = this.config.dateTo;\n  }\n}\n","<div class=\"d-flex gap-16 p-l-16 p-r-16 flex-wrap\">\n  <ng-container *ngIf=\"config.displayDateSelection\">\n    <form [formGroup]=\"formGroup\">\n      <c8y-date-range-picker\n        class=\"d-contents\"\n        [isEmittingDateChange]=\"true\"\n        [showLabel]=\"true\"\n        (updatedDate)=\"onDateChange($event)\"\n      ></c8y-date-range-picker>\n    </form>\n  </ng-container>\n  <ng-container *ngIf=\"config.datapoints.length > 0\">\n    <c8y-datapoints-reload\n      class=\"d-contents\"\n      [isAutoRefreshEnabled]=\"config.isAutoRefreshEnabled\"\n      [refreshInterval]=\"config.refreshInterval\"\n      [isDisabled]=\"isDisabled\"\n      [isLoading]=\"isLoading\"\n      [isScrolling]=\"isScrolling()\"\n      [isExportModalOpen]=\"isExportModalOpen\"\n      (onCountdownEnded)=\"onCountdownEnded()\"\n    ></c8y-datapoints-reload>\n  </ng-container>\n  <c8y-datapoints-export-selector\n    class=\"d-contents\"\n    [exportConfig]=\"exportConfig\"\n    (isOpen)=\"onExportModalOpen($event)\"\n  ></c8y-datapoints-export-selector>\n</div>\n<ng-container *ngIf=\"devicesColumnHeaders\">\n  <c8y-datapoints-table\n    [aggregationType]=\"config.aggregation\"\n    [datapointsTableItems]=\"datapointsTableItems\"\n    [decimalPlaces]=\"config.decimalPlaces\"\n    [devicesColumnHeaders]=\"devicesColumnHeaders\"\n    [hasMultipleDatapoints]=\"hasMultipleDatapoints\"\n    [isLoading]=\"isLoading()\"\n    [seriesWithoutPermissionToReadCount]=\"seriesWithoutPermissionToRead?.length\"\n    (isScrolling)=\"onScrolling($event)\"\n  ></c8y-datapoints-table>\n</ng-container>\n"]}
|