@c8y/ngx-components 1021.55.1 → 1021.55.3

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.
Files changed (64) hide show
  1. package/core/common/interval-based-reload.abstract.d.ts +13 -3
  2. package/core/common/interval-based-reload.abstract.d.ts.map +1 -1
  3. package/core/dashboard/widget-auto-refresh-context/auto-refresh-control.component.d.ts +3 -4
  4. package/core/dashboard/widget-auto-refresh-context/auto-refresh-control.component.d.ts.map +1 -1
  5. package/core/dashboard/widget-auto-refresh-context/widget-auto-refresh-context.component.d.ts +1 -0
  6. package/core/dashboard/widget-auto-refresh-context/widget-auto-refresh-context.component.d.ts.map +1 -1
  7. package/core/dashboard/widgets-dashboard-event.service.d.ts +7 -0
  8. package/core/dashboard/widgets-dashboard-event.service.d.ts.map +1 -1
  9. package/core/dashboard/wiget-time-context/widget-time-context.component.d.ts +6 -2
  10. package/core/dashboard/wiget-time-context/widget-time-context.component.d.ts.map +1 -1
  11. package/datapoint-explorer/view/configuration/workspace-configuration.component.d.ts.map +1 -1
  12. package/datapoints-export-selector/datapoints-export-selector-modal/datapoints-export-selector-file-exporter/data-fetching.service.d.ts.map +1 -1
  13. package/datapoints-export-selector/datapoints-export-selector.component.d.ts +3 -1
  14. package/datapoints-export-selector/datapoints-export-selector.component.d.ts.map +1 -1
  15. package/echart/charts.component.d.ts.map +1 -1
  16. package/esm2022/core/aggregation/aggregation.model.mjs +2 -2
  17. package/esm2022/core/common/interval-based-reload.abstract.mjs +13 -13
  18. package/esm2022/core/dashboard/dashboard-child.component.mjs +3 -3
  19. package/esm2022/core/dashboard/widget-auto-refresh-context/auto-refresh-control.component.mjs +6 -8
  20. package/esm2022/core/dashboard/widget-auto-refresh-context/widget-auto-refresh-context.component.mjs +9 -1
  21. package/esm2022/core/dashboard/widgets-dashboard-event.service.mjs +19 -2
  22. package/esm2022/core/dashboard/widgets-dashboard.component.mjs +3 -3
  23. package/esm2022/core/dashboard/wiget-time-context/widget-time-context-icon-bar/widget-time-context-icon-bar.component.mjs +3 -3
  24. package/esm2022/core/dashboard/wiget-time-context/widget-time-context.component.mjs +48 -23
  25. package/esm2022/datapoint-explorer/view/configuration/workspace-configuration.component.mjs +13 -8
  26. package/esm2022/datapoint-explorer/view/datapoint-explorer.component.mjs +2 -2
  27. package/esm2022/datapoints-export-selector/datapoints-export-selector-modal/datapoints-export-selector-file-exporter/data-fetching.service.mjs +1 -3
  28. package/esm2022/datapoints-export-selector/datapoints-export-selector.component.mjs +9 -5
  29. package/esm2022/echart/charts.component.mjs +22 -84
  30. package/esm2022/widgets/definitions/datapoints-table/index.mjs +3 -2
  31. package/esm2022/widgets/implementations/alarms/alarm-list-widget-view/alarm-list-widget.component.mjs +3 -3
  32. package/esm2022/widgets/implementations/alarms/alarm-widget-alarms-reload.component.mjs +17 -100
  33. package/esm2022/widgets/implementations/datapoints-table/datapoints-table-config/datapoints-table-config.component.mjs +47 -34
  34. package/esm2022/widgets/implementations/datapoints-table/datapoints-table-view/datapoints-reload/datapoints-reload.component.mjs +35 -13
  35. package/esm2022/widgets/implementations/datapoints-table/datapoints-table-view/datapoints-table/datapoints-table.component.mjs +3 -3
  36. package/esm2022/widgets/implementations/datapoints-table/datapoints-table-view/datapoints-table-view.component.mjs +75 -35
  37. package/esm2022/widgets/implementations/datapoints-table/datapoints-table-widget.model.mjs +3 -5
  38. package/fesm2022/c8y-ngx-components-datapoint-explorer-view.mjs +13 -8
  39. package/fesm2022/c8y-ngx-components-datapoint-explorer-view.mjs.map +1 -1
  40. package/fesm2022/c8y-ngx-components-datapoints-export-selector.mjs +7 -6
  41. package/fesm2022/c8y-ngx-components-datapoints-export-selector.mjs.map +1 -1
  42. package/fesm2022/c8y-ngx-components-echart.mjs +21 -83
  43. package/fesm2022/c8y-ngx-components-echart.mjs.map +1 -1
  44. package/fesm2022/c8y-ngx-components-widgets-definitions-datapoints-table.mjs +2 -1
  45. package/fesm2022/c8y-ngx-components-widgets-definitions-datapoints-table.mjs.map +1 -1
  46. package/fesm2022/c8y-ngx-components-widgets-implementations-alarms.mjs +18 -101
  47. package/fesm2022/c8y-ngx-components-widgets-implementations-alarms.mjs.map +1 -1
  48. package/fesm2022/c8y-ngx-components-widgets-implementations-datapoints-table.mjs +147 -76
  49. package/fesm2022/c8y-ngx-components-widgets-implementations-datapoints-table.mjs.map +1 -1
  50. package/fesm2022/c8y-ngx-components.mjs +209 -162
  51. package/fesm2022/c8y-ngx-components.mjs.map +1 -1
  52. package/locales/locales.pot +3 -7
  53. package/package.json +1 -1
  54. package/widgets/definitions/datapoints-table/index.d.ts.map +1 -1
  55. package/widgets/implementations/alarms/alarm-widget-alarms-reload.component.d.ts +18 -63
  56. package/widgets/implementations/alarms/alarm-widget-alarms-reload.component.d.ts.map +1 -1
  57. package/widgets/implementations/datapoints-table/datapoints-table-config/datapoints-table-config.component.d.ts +4 -2
  58. package/widgets/implementations/datapoints-table/datapoints-table-config/datapoints-table-config.component.d.ts.map +1 -1
  59. package/widgets/implementations/datapoints-table/datapoints-table-view/datapoints-reload/datapoints-reload.component.d.ts +16 -8
  60. package/widgets/implementations/datapoints-table/datapoints-table-view/datapoints-reload/datapoints-reload.component.d.ts.map +1 -1
  61. package/widgets/implementations/datapoints-table/datapoints-table-view/datapoints-table-view.component.d.ts +21 -4
  62. package/widgets/implementations/datapoints-table/datapoints-table-view/datapoints-table-view.component.d.ts.map +1 -1
  63. package/widgets/implementations/datapoints-table/datapoints-table-widget.model.d.ts +4 -1
  64. package/widgets/implementations/datapoints-table/datapoints-table-widget.model.d.ts.map +1 -1
@@ -1,34 +1,34 @@
1
+ import { NgClass, NgIf, NgTemplateOutlet } from '@angular/common';
1
2
  import { Component, effect, EventEmitter, Input, Output, ViewChild } from '@angular/core';
2
3
  import { FormBuilder, FormsModule, ReactiveFormsModule } from '@angular/forms';
3
4
  import { ActivationEnd, NavigationEnd, NavigationStart, Router } from '@angular/router';
4
5
  import { aggregationType } from '@c8y/client';
6
+ import { INTERVAL_TITLES, IntervalPickerComponent } from '@c8y/ngx-components/interval-picker';
5
7
  import { BsDropdownDirective, BsDropdownModule } from 'ngx-bootstrap/dropdown';
8
+ import { TooltipModule } from 'ngx-bootstrap/tooltip';
6
9
  import { interval, Subject } from 'rxjs';
7
- import { filter, takeUntil } from 'rxjs/operators';
10
+ import { filter, takeUntil, tap } from 'rxjs/operators';
8
11
  import { ActionBarService } from '../../action-bar';
12
+ import { ActionBarItemComponent } from '../../action-bar/action-bar-item.component';
9
13
  import { AGGREGATION_LIMITS } from '../../aggregation/aggregation.model';
10
14
  import { AggregationService } from '../../aggregation/aggregation.service';
15
+ import { DatePipe } from '../../common/date.pipe';
16
+ import { IconDirective } from '../../common/icon.directive';
17
+ import { DateTimePickerComponent } from '../../date-time-picker';
18
+ import { FormGroupComponent } from '../../forms/form-group.component';
19
+ import { MessageDirective } from '../../forms/message.directive';
20
+ import { MessagesComponent } from '../../forms/messages.component';
11
21
  import { gettext } from '../../i18n';
22
+ import { C8yTranslateDirective } from '../../i18n/c8y-translate.directive';
23
+ import { C8yTranslatePipe } from '../../i18n/c8y-translate.pipe';
12
24
  import { DashboardChildActionComponent } from '../dashboard-child-action.component';
13
25
  import { DashboardChildComponent } from '../dashboard-child.component';
14
26
  import { WidgetsDashboardEventService } from '../widgets-dashboard-event.service';
27
+ import { AggregationPickerComponent } from './aggregation-picker/aggregation-picker.component';
28
+ import { RealtimeControlComponent } from './realtime-control/realtime-control.component';
29
+ import { WidgetTimeContextDateRangeService } from './widget-time-context-date-range.service';
15
30
  import { WidgetTimeContextHelperService } from './widget-time-context-helper.service';
16
31
  import { WidgetTimeContextQueryService } from './widget-time-context-query.service';
17
- import { INTERVAL_TITLES, IntervalPickerComponent } from '@c8y/ngx-components/interval-picker';
18
- import { WidgetTimeContextDateRangeService } from './widget-time-context-date-range.service';
19
- import { NgIf, NgTemplateOutlet, NgClass } from '@angular/common';
20
- import { ActionBarItemComponent } from '../../action-bar/action-bar-item.component';
21
- import { TooltipModule } from 'ngx-bootstrap/tooltip';
22
- import { IconDirective } from '../../common/icon.directive';
23
- import { FormGroupComponent } from '../../forms/form-group.component';
24
- import { C8yTranslateDirective } from '../../i18n/c8y-translate.directive';
25
- import { MessagesComponent } from '../../forms/messages.component';
26
- import { MessageDirective } from '../../forms/message.directive';
27
- import { RealtimeControlComponent } from './realtime-control/realtime-control.component';
28
- import { AggregationPickerComponent } from './aggregation-picker/aggregation-picker.component';
29
- import { C8yTranslatePipe } from '../../i18n/c8y-translate.pipe';
30
- import { DatePipe } from '../../common/date.pipe';
31
- import { DateTimePickerComponent } from '../../date-time-picker';
32
32
  import * as i0 from "@angular/core";
33
33
  import * as i1 from "../widgets-dashboard-event.service";
34
34
  import * as i2 from "../dashboard-child.component";
@@ -116,6 +116,16 @@ export class WidgetTimeContextComponent {
116
116
  this.subscribeToIntervalChange();
117
117
  this.subscribeToRealtimeChange();
118
118
  this.subscribeToAggregationChange();
119
+ this.widgetEventService.onAutoRefresh$
120
+ .pipe(takeUntil(this.destroy$), tap(autoRefresh => (this.isAutoRefreshEnabled = autoRefresh)))
121
+ .subscribe(autoRefresh => {
122
+ // Fix for:
123
+ // 1. Make a group with dashboard having a widget with with auto-refresh time context enabled.
124
+ // 2. When you route to e.g. home page and back to the group dashboard, none of a groups will be routable again.
125
+ queueMicrotask(() => {
126
+ autoRefresh ? this.onDisableAutoRefresh() : this.enableDateRangeAndAggregation();
127
+ });
128
+ });
119
129
  if (initialContext.realtime) {
120
130
  this.onRealtimeValueChange(initialContext.realtime);
121
131
  this.startRealtime();
@@ -179,6 +189,8 @@ export class WidgetTimeContextComponent {
179
189
  ngOnDestroy() {
180
190
  this.unsubscribeFromGlobalContext();
181
191
  this.clearQueryParamsIfNeeded();
192
+ this.widgetEventService.setRealtimeTimeContextSetting();
193
+ this.widgetEventService.emitAutoRefresh(false);
182
194
  this.destroy$.next();
183
195
  this.destroy$.complete();
184
196
  }
@@ -393,9 +405,7 @@ export class WidgetTimeContextComponent {
393
405
  };
394
406
  }
395
407
  startRealtime() {
396
- this.form.controls.temporaryUserSelectedFromDate.disable();
397
- this.form.controls.temporaryUserSelectedToDate.disable();
398
- this.form.controls.aggregation.disable();
408
+ this.disableDateRangeAndAggregation();
399
409
  this.realtimeSubscription = interval(this.REALTIME_INTERVAL)
400
410
  .pipe(takeUntil(this.destroy$))
401
411
  .subscribe(() => {
@@ -409,11 +419,26 @@ export class WidgetTimeContextComponent {
409
419
  });
410
420
  });
411
421
  }
422
+ onDisableAutoRefresh() {
423
+ this.form.controls.aggregation.setValue(null);
424
+ this.disableDateRangeAndAggregation();
425
+ }
426
+ disableDateRangeAndAggregation() {
427
+ this.form.controls.temporaryUserSelectedFromDate.disable();
428
+ this.form.controls.temporaryUserSelectedToDate.disable();
429
+ this.form.controls.aggregation.disable();
430
+ }
431
+ enableDateRangeAndAggregation() {
432
+ if (this.form.controls.realtime.value || this.isAutoRefreshEnabled) {
433
+ return;
434
+ }
435
+ this.form.controls.temporaryUserSelectedFromDate.enable();
436
+ this.form.controls.temporaryUserSelectedToDate.enable();
437
+ this.form.controls.aggregation.enable();
438
+ }
412
439
  stopRealtime() {
413
440
  this.realtimeSubscription?.unsubscribe();
414
- this.form?.controls.temporaryUserSelectedFromDate.enable();
415
- this.form?.controls.temporaryUserSelectedToDate.enable();
416
- this.form?.controls.aggregation.enable();
441
+ this.enableDateRangeAndAggregation();
417
442
  }
418
443
  onRealtimeValueChange(realtime) {
419
444
  let dateTimeContext;
@@ -496,4 +521,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
496
521
  type: ViewChild,
497
522
  args: [BsDropdownDirective]
498
523
  }] } });
499
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"widget-time-context.component.js","sourceRoot":"","sources":["../../../../../core/dashboard/wiget-time-context/widget-time-context.component.ts","../../../../../core/dashboard/wiget-time-context/widget-time-context.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  Component,\n  effect,\n  EventEmitter,\n  Input,\n  OnDestroy,\n  OnInit,\n  Output,\n  ViewChild\n} from '@angular/core';\nimport { FormBuilder, FormsModule, ReactiveFormsModule } from '@angular/forms';\nimport { ActivationEnd, NavigationEnd, NavigationStart, Router } from '@angular/router';\nimport { aggregationType } from '@c8y/client';\nimport { BsDropdownDirective, BsDropdownModule } from 'ngx-bootstrap/dropdown';\nimport { interval, Subject, Subscription } from 'rxjs';\nimport { filter, takeUntil } from 'rxjs/operators';\nimport { ActionBarService } from '../../action-bar';\nimport { AGGREGATION_LIMITS } from '../../aggregation/aggregation.model';\nimport { AggregationService } from '../../aggregation/aggregation.service';\nimport { gettext } from '../../i18n';\nimport { DashboardChildActionComponent } from '../dashboard-child-action.component';\nimport { DashboardChildComponent } from '../dashboard-child.component';\nimport { DateTimeContext, TimeContextEvent, WidgetTimeContext } from '../widget-change-event.model';\nimport { WidgetsDashboardEventService } from '../widgets-dashboard-event.service';\nimport { WidgetTimeContextHelperService } from './widget-time-context-helper.service';\nimport { WidgetTimeContextQueryService } from './widget-time-context-query.service';\nimport {\n  InputDateContextQueryParams,\n  WidgetDisplaySettings,\n  WidgetTimeContextState\n} from './widget-time-context.model';\nimport {\n  Interval,\n  INTERVAL_TITLES,\n  IntervalPickerComponent\n} from '@c8y/ngx-components/interval-picker';\nimport { WidgetTimeContextDateRangeService } from './widget-time-context-date-range.service';\nimport { NgIf, NgTemplateOutlet, NgClass } from '@angular/common';\nimport { ActionBarItemComponent } from '../../action-bar/action-bar-item.component';\nimport { TooltipModule } from 'ngx-bootstrap/tooltip';\nimport { IconDirective } from '../../common/icon.directive';\nimport { FormGroupComponent } from '../../forms/form-group.component';\nimport { C8yTranslateDirective } from '../../i18n/c8y-translate.directive';\nimport { MessagesComponent } from '../../forms/messages.component';\nimport { MessageDirective } from '../../forms/message.directive';\nimport { RealtimeControlComponent } from './realtime-control/realtime-control.component';\nimport { AggregationPickerComponent } from './aggregation-picker/aggregation-picker.component';\nimport { C8yTranslatePipe } from '../../i18n/c8y-translate.pipe';\nimport { DatePipe } from '../../common/date.pipe';\nimport { DateTimePickerComponent } from '../../date-time-picker';\n\n@Component({\n  selector: 'c8y-widget-time-context',\n  templateUrl: './widget-time-context.component.html',\n  host: { class: 'd-flex a-i-center gap-4' },\n  standalone: true,\n  imports: [\n    NgIf,\n    ActionBarItemComponent,\n    NgTemplateOutlet,\n    FormsModule,\n    ReactiveFormsModule,\n    BsDropdownModule,\n    TooltipModule,\n    IconDirective,\n    IntervalPickerComponent,\n    FormGroupComponent,\n    NgClass,\n    C8yTranslateDirective,\n    MessagesComponent,\n    MessageDirective,\n    RealtimeControlComponent,\n    AggregationPickerComponent,\n    C8yTranslatePipe,\n    DatePipe,\n    DashboardChildActionComponent,\n    DateTimePickerComponent\n  ]\n})\nexport class WidgetTimeContextComponent implements OnInit, OnDestroy, AfterViewInit {\n  readonly INTERVAL_TITLES = INTERVAL_TITLES;\n  readonly DATE_FORMAT = 'short';\n  /**\n   * Indicates if the component can decouple or not.\n   */\n  @Input()\n  canDecouple = true;\n\n  @Input() displaySettings: WidgetDisplaySettings;\n\n  @Input() hidden = false;\n\n  /**\n   * Emits each change as an array of dates [from, to].\n   */\n  @Output()\n  dateContextChange = new EventEmitter<any>();\n  /**\n   * @ignore\n   */\n  @ViewChild(DashboardChildActionComponent) action: DashboardChildActionComponent;\n  @ViewChild(BsDropdownDirective) dropdown: BsDropdownDirective;\n  /**\n   * Indicates if the time context is bound to the global scope.\n   */\n  isCoupled = true;\n  decoupleTimeContextLabel = gettext('Decouple time context');\n  coupleTimeContextLabel = gettext('Couple time context');\n  form: ReturnType<WidgetTimeContextComponent['createForm']>;\n  actionBarInGroupPriority: number;\n  disabledAggregations: Partial<Record<aggregationType, boolean>> = {};\n  sliderChange: boolean;\n  readonly DEFAULT_INTERVAL: Interval['id'] = 'days';\n  readonly ACTION_BAR_PRIORITY = 7;\n  readonly ACTION_BAR_GROUP_ID = 'timecontext';\n  readonly REALTIME_INTERVAL = 1000;\n  private subscription: Subscription;\n  private destroy$: Subject<void> = new Subject();\n  private navigationInProgress: boolean;\n  private realtimeSubscription: Subscription;\n\n  /**\n   * @ignore only DI.\n   */\n  constructor(\n    private widgetEventService: WidgetsDashboardEventService,\n    private dashboardChild: DashboardChildComponent,\n    private formBuilder: FormBuilder,\n    private queryService: WidgetTimeContextQueryService,\n    private helperService: WidgetTimeContextHelperService,\n    private router: Router,\n    private actionBarService: ActionBarService,\n    private aggregationService: AggregationService,\n    private widgetTimeContextDateRangeService: WidgetTimeContextDateRangeService\n  ) {\n    effect(() => {\n      const data = this.widgetTimeContextDateRangeService.timeContextChange();\n      if (data) {\n        const updatedFormData = {\n          date: [new Date(data.dateFrom), new Date(data.dateTo)],\n          interval: data.interval,\n          realtime: false,\n          aggregation: this.form.value.aggregation\n        } as WidgetTimeContextState;\n        this.sliderChange = true;\n        this.dateContextChange.emit({ ...updatedFormData, sliderChange: true });\n        this.stopRealtime();\n        this.updateFormValues(updatedFormData);\n      }\n    });\n  }\n\n  /**\n   * @ignore Subscribing to the global context.\n   */\n  ngOnInit(): void {\n    this.actionBarInGroupPriority = this.helperService.getActionBarPriority(this.displaySettings);\n    const initialContext: WidgetTimeContextState =\n      this.getInitialContext() || this.getDefaultContext();\n    initialContext.aggregation = this.calculateAggregation(\n      initialContext.date,\n      initialContext.aggregation\n    );\n    this.form = this.createForm(initialContext);\n\n    this.dateContextChange.emit({\n      date: initialContext.date,\n      realtime: initialContext.realtime,\n      aggregation: initialContext.aggregation\n    });\n    if (this.isCoupled) {\n      this.queryService.setDateContextQueryParams(initialContext);\n    }\n    this.subscribeToGlobalContext();\n    this.subscribeToQueryParamsChange();\n    this.subscribeToRouterEvents();\n    this.subscribeToIntervalChange();\n    this.subscribeToRealtimeChange();\n    this.subscribeToAggregationChange();\n\n    if (initialContext.realtime) {\n      this.onRealtimeValueChange(initialContext.realtime);\n      this.startRealtime();\n    }\n  }\n\n  /**\n   * @ignore Adding custom actions.\n   */\n  ngAfterViewInit(): void {\n    if (this.canDecouple) {\n      this.dashboardChild.addActions([this.action]);\n    }\n  }\n\n  /**\n   * Toggles the coupling on or off.\n   */\n  toggleDecoupling(): void {\n    this.isCoupled = !this.isCoupled;\n    const lastEventValue = this.widgetEventService.getLastValue('TIME_CONTEXT');\n    const { realtime, aggregation, interval } = lastEventValue;\n    let date: DateTimeContext;\n    if (interval) {\n      date = this.helperService.getDateTimeContextByInterval(interval);\n    } else {\n      date = lastEventValue.dateTimeContext;\n    }\n    this.updateFormValues({ date, interval, realtime, aggregation });\n\n    if (this.isCoupled) {\n      this.subscribeToGlobalContext();\n      this.dateContextChange.emit({ date, realtime, aggregation });\n    } else {\n      this.unsubscribeFromGlobalContext();\n    }\n  }\n\n  /**\n   * Applies form value to global or local date context.\n   */\n  applyDatetimeContext(): void {\n    this.update({\n      date: [\n        new Date(this.form.value.temporaryUserSelectedFromDate),\n        new Date(this.form.value.temporaryUserSelectedToDate)\n      ],\n      interval: null,\n      realtime: this.form.value.realtime,\n      aggregation: this.form.value.aggregation\n    });\n  }\n\n  /**\n   * Resets form to initial value and update context.\n   */\n  reset(): void {\n    this.stopRealtime();\n    this.update(this.getDefaultContext());\n  }\n\n  /**\n   * @ignore unsubscribing.\n   */\n  ngOnDestroy(): void {\n    this.unsubscribeFromGlobalContext();\n    this.clearQueryParamsIfNeeded();\n    this.destroy$.next();\n    this.destroy$.complete();\n  }\n\n  private subscribeToIntervalChange(): void {\n    this.form.controls.currentDateContextInterval.valueChanges\n      .pipe(takeUntil(this.destroy$))\n      .subscribe(interval => {\n        let date: DateTimeContext;\n        if (interval === 'custom') {\n          date = [\n            new Date(this.form.controls.currentDateContextFromDate.value),\n            new Date(this.form.controls.currentDateContextToDate.value)\n          ];\n        } else {\n          date = this.helperService.getDateTimeContextByInterval(interval);\n          this.dropdown.isOpen = false;\n        }\n        this.update({\n          date,\n          interval,\n          realtime: this.form.value.realtime,\n          aggregation: this.form.value.aggregation\n        });\n      });\n  }\n\n  private subscribeToRealtimeChange(): void {\n    this.form.controls.realtime.valueChanges.pipe(takeUntil(this.destroy$)).subscribe(realtime => {\n      this.onRealtimeValueChange(realtime);\n\n      if (realtime) {\n        this.startRealtime();\n      } else {\n        this.stopRealtime();\n      }\n    });\n  }\n\n  private subscribeToAggregationChange() {\n    this.form.controls.aggregation.valueChanges\n      .pipe(takeUntil(this.destroy$))\n      .subscribe(aggregation => {\n        if (this.sliderChange) {\n          this.sliderChange = false;\n          return;\n        }\n        this.update({\n          date: [\n            new Date(this.form.value.currentDateContextFromDate),\n            new Date(this.form.value.currentDateContextToDate)\n          ],\n          interval: this.form.value.currentDateContextInterval,\n          realtime: this.form.value.realtime,\n          aggregation\n        });\n      });\n  }\n\n  private createForm(context: WidgetTimeContextState) {\n    return this.formBuilder.group({\n      temporaryUserSelectedFromDate: context.date[0].toISOString(),\n      temporaryUserSelectedToDate: context.date[1].toISOString(),\n      currentDateContextFromDate: context.date[0].toISOString(),\n      currentDateContextToDate: context.date[1].toISOString(),\n      currentDateContextInterval: context.interval || 'custom',\n      realtime: context.realtime,\n      aggregation: context.aggregation\n    });\n  }\n\n  /**\n   * Fires a new WidgetChangeEvent either on the local change emitter or on the global one.\n   * @param widgetTimeContextState New widget time context value.*/\n  private update({ date, interval, realtime, aggregation }: WidgetTimeContextState): void {\n    const validAggregation = this.calculateAggregation(date, aggregation);\n    if (this.isCoupled) {\n      const eventData: WidgetTimeContext =\n        interval && interval !== 'custom'\n          ? { interval, realtime, aggregation: validAggregation }\n          : { dateTimeContext: date, realtime, aggregation: validAggregation };\n      this.widgetEventService.emit({ type: 'TIME_CONTEXT', data: eventData });\n    } else {\n      this.updateFormValues({ date, interval, realtime, aggregation: validAggregation });\n      this.dateContextChange.emit({ date, realtime, aggregation: validAggregation });\n    }\n  }\n\n  private subscribeToGlobalContext(): void {\n    const event$ = this.widgetEventService.getObservable<TimeContextEvent>('TIME_CONTEXT');\n    this.subscription = event$.subscribe((context: WidgetTimeContext) => {\n      let date: DateTimeContext;\n      const { realtime, interval, aggregation } = context;\n      if (interval) {\n        date = this.helperService.getDateTimeContextByInterval(context.interval);\n      } else {\n        date = context.dateTimeContext;\n      }\n\n      this.dateContextChange.emit({\n        date,\n        sliderChange: false,\n        interval,\n        realtime,\n        aggregation\n      });\n      this.updateFormValues({ date, interval, realtime, aggregation });\n      this.queryService.setDateContextQueryParams({ interval, date, realtime, aggregation });\n    });\n  }\n\n  private updateFormValues({\n    date,\n    interval,\n    realtime,\n    aggregation\n  }: WidgetTimeContextState): void {\n    this.form.patchValue(\n      {\n        temporaryUserSelectedFromDate: date[0].toISOString(),\n        temporaryUserSelectedToDate: date[1].toISOString(),\n        currentDateContextFromDate: date[0].toISOString(),\n        currentDateContextToDate: date[1].toISOString(),\n        realtime,\n        currentDateContextInterval: interval || 'custom',\n        aggregation: aggregation || null\n      },\n      {\n        emitEvent: false\n      }\n    );\n  }\n\n  private unsubscribeFromGlobalContext(): void {\n    if (this.subscription) {\n      this.subscription.unsubscribe();\n    }\n  }\n\n  private getInitialContext(): WidgetTimeContextState | null {\n    const dateTimeContextFromQueryParams = this.queryService.dateTimeContextFromQueryParams();\n    if (dateTimeContextFromQueryParams) {\n      return {\n        ...dateTimeContextFromQueryParams,\n        realtime: dateTimeContextFromQueryParams.realtime ?? false,\n        aggregation: dateTimeContextFromQueryParams.realtime\n          ? null\n          : dateTimeContextFromQueryParams.aggregation || null\n      };\n    }\n    // get value from last value of events service\n    const lastEventValue = this.widgetEventService.getLastValue('TIME_CONTEXT');\n    const realtime = lastEventValue?.realtime ?? false;\n    if (lastEventValue && lastEventValue.dateTimeContext) {\n      return {\n        date: lastEventValue.dateTimeContext,\n        interval: 'custom',\n        realtime,\n        aggregation: realtime ? null : lastEventValue.aggregation\n      };\n    }\n    if (lastEventValue && lastEventValue.interval) {\n      return {\n        date: this.helperService.getDateTimeContextByInterval(lastEventValue.interval),\n        interval: lastEventValue.interval,\n        realtime,\n        aggregation: realtime ? null : lastEventValue.aggregation\n      };\n    }\n\n    return null;\n  }\n\n  private subscribeToQueryParamsChange(): void {\n    this.queryService\n      .queryParamsChange$()\n      .pipe(takeUntil(this.destroy$))\n      .subscribe(\n        ({\n          dateContextFrom,\n          dateContextTo,\n          dateContextInterval,\n          dateContextRealtime,\n          dateContextAggregation\n        }: InputDateContextQueryParams) => {\n          const realtime = dateContextRealtime ?? this.form.value.realtime;\n          if (dateContextInterval) {\n            this.widgetEventService.emit({\n              type: 'TIME_CONTEXT',\n              data: {\n                interval: dateContextInterval,\n                realtime,\n                aggregation: dateContextAggregation\n              }\n            });\n          } else {\n            const dateContext: DateTimeContext = [\n              new Date(dateContextFrom),\n              new Date(dateContextTo)\n            ];\n            this.widgetEventService.emit({\n              type: 'TIME_CONTEXT',\n              data: {\n                dateTimeContext: dateContext,\n                realtime,\n                aggregation: dateContextAggregation\n              }\n            });\n          }\n        }\n      );\n  }\n\n  private clearQueryParamsIfNeeded(): void {\n    // If navigation is in progress, router will take care of clearing query params. This way we avoid unnecessary manipulation of browser history\n    if (this.navigationInProgress) {\n      return;\n    }\n    // check if any other WidgetTimeContextComponent action in action bar exists\n    const anyWidgetTimeContextActionLeft = Array.from(this.actionBarService.state).some(\n      action => action.groupId === this.ACTION_BAR_GROUP_ID\n    );\n    if (!anyWidgetTimeContextActionLeft) {\n      this.queryService.clearQueryParams();\n    }\n  }\n\n  private subscribeToRouterEvents(): void {\n    this.router.events\n      .pipe(\n        filter(\n          e =>\n            e instanceof NavigationStart || e instanceof NavigationEnd || e instanceof ActivationEnd\n        ),\n        takeUntil(this.destroy$)\n      )\n      .subscribe(e => {\n        this.navigationInProgress = e instanceof NavigationStart;\n      });\n  }\n\n  private getDefaultContext(): WidgetTimeContextState {\n    return {\n      date: this.helperService.getDateTimeContextByInterval(this.DEFAULT_INTERVAL),\n      interval: this.DEFAULT_INTERVAL,\n      realtime: false,\n      aggregation: aggregationType.MINUTELY\n    };\n  }\n\n  private startRealtime(): void {\n    this.form.controls.temporaryUserSelectedFromDate.disable();\n    this.form.controls.temporaryUserSelectedToDate.disable();\n    this.form.controls.aggregation.disable();\n\n    this.realtimeSubscription = interval(this.REALTIME_INTERVAL)\n      .pipe(takeUntil(this.destroy$))\n      .subscribe(() => {\n        const newDateFrom = new Date(\n          new Date(this.form.value.currentDateContextFromDate).valueOf() + this.REALTIME_INTERVAL\n        );\n        const newDateTo = new Date(\n          new Date(this.form.value.currentDateContextToDate).valueOf() + this.REALTIME_INTERVAL\n        );\n        this.updateFormValues({\n          date: [newDateFrom, newDateTo],\n          interval: this.form.value.currentDateContextInterval,\n          realtime: true,\n          aggregation: null\n        });\n      });\n  }\n\n  private stopRealtime(): void {\n    this.realtimeSubscription?.unsubscribe();\n    this.form?.controls.temporaryUserSelectedFromDate.enable();\n    this.form?.controls.temporaryUserSelectedToDate.enable();\n    this.form?.controls.aggregation.enable();\n  }\n\n  private onRealtimeValueChange(realtime: boolean): void {\n    let dateTimeContext: DateTimeContext;\n    if (this.form.value.currentDateContextInterval !== 'custom') {\n      dateTimeContext = this.helperService.getDateTimeContextByInterval(\n        this.form.value.currentDateContextInterval\n      );\n    } else {\n      const currentTimeSpanInMs =\n        new Date(this.form.value.currentDateContextToDate).valueOf() -\n        new Date(this.form.value.currentDateContextFromDate).valueOf();\n      const dateTo = new Date();\n      const dateFrom = new Date(dateTo.valueOf() - currentTimeSpanInMs);\n      dateTimeContext = [dateFrom, dateTo];\n    }\n\n    this.update({\n      date: dateTimeContext,\n      interval: this.form.value.currentDateContextInterval,\n      realtime,\n      aggregation: null\n    });\n  }\n\n  private calculateAggregation(\n    [dateFrom, dateTo]: DateTimeContext,\n    aggregation: aggregationType\n  ): aggregationType {\n    this.disabledAggregations = this.aggregationService.getDisabledAggregationOptions(\n      dateFrom,\n      dateTo\n    );\n    const timeRangeInMs = dateTo.valueOf() - dateFrom.valueOf();\n    const isProperAggregation = !this.disabledAggregations[aggregation] || aggregation === null;\n\n    if (isProperAggregation) {\n      return aggregation;\n    }\n    if (timeRangeInMs >= AGGREGATION_LIMITS.DAILY_LIMIT) {\n      return aggregationType.DAILY;\n    } else if (timeRangeInMs >= AGGREGATION_LIMITS.HOURLY_LIMIT) {\n      return aggregationType.HOURLY;\n    } else if (timeRangeInMs >= AGGREGATION_LIMITS.MINUTELY_LIMIT) {\n      return aggregationType.MINUTELY;\n    } else {\n      return null;\n    }\n  }\n}\n","<c8y-action-bar-item\n  *ngIf=\"isCoupled && !hidden\"\n  [priority]=\"ACTION_BAR_PRIORITY\"\n  [groupId]=\"ACTION_BAR_GROUP_ID\"\n  [inGroupPriority]=\"actionBarInGroupPriority\"\n  [placement]=\"'left'\"\n>\n  <ng-container\n    [ngTemplateOutlet]=\"dateTimePicker\"\n    [ngTemplateOutletContext]=\"{\n      date: [form.value.currentDateContextFromDate, form.value.currentDateContextToDate]\n    }\"\n  ></ng-container>\n</c8y-action-bar-item>\n\n<ng-container\n  *ngIf=\"!isCoupled\"\n  [ngTemplateOutlet]=\"dateTimePicker\"\n  [ngTemplateOutletContext]=\"{\n    date: [form.value.currentDateContextFromDate, form.value.currentDateContextToDate]\n  }\"\n></ng-container>\n\n<ng-template\n  #dateTimePicker\n  let-date=\"date\"\n>\n  <form\n    class=\"d-flex gap-16 p-l-xs-16 p-r-xs-16 m-t-xs-8 m-b-xs-8\"\n    [formGroup]=\"form\"\n  >\n    <ng-container *ngIf=\"displaySettings.globalTimeContext\">\n      <div>\n        <div\n          class=\"dropdown flex-grow\"\n          #dropdown=\"bs-dropdown\"\n          dropdown\n          [insideClick]=\"true\"\n          *ngIf=\"date\"\n        >\n          <button\n            class=\"dropdown-toggle form-control l-h-tight d-flex a-i-center\"\n            attr.aria-label=\"{{ date[0] | c8yDate: DATE_FORMAT }} — {{\n              date[1] | c8yDate: DATE_FORMAT\n            }}\"\n            tooltip=\"{{ date[0] | c8yDate: DATE_FORMAT }} — {{ date[1] | c8yDate: DATE_FORMAT }}\"\n            placement=\"top\"\n            container=\"body\"\n            data-cy=\"widget-time-context--date-picker-dropdown-button\"\n            [adaptivePosition]=\"false\"\n            [delay]=\"500\"\n            dropdownToggle\n          >\n            <i\n              class=\"m-r-4\"\n              c8yIcon=\"schedule1\"\n            ></i>\n            <div class=\"d-col text-left fit-w\">\n              <span\n                class=\"text-12\"\n                data-cy=\"widget-time-context--selected-interval\"\n              >\n                {{ INTERVAL_TITLES[form.controls.currentDateContextInterval.value] | translate }}\n              </span>\n              <span\n                class=\"text-10 text-muted text-truncate\"\n                data-cy=\"widget-time-context--selected-time-range\"\n              >\n                {{ date[0] | c8yDate: DATE_FORMAT }} — {{ date[1] | c8yDate: DATE_FORMAT }}\n              </span>\n            </div>\n            <span class=\"caret m-r-16 m-l-4\"></span>\n          </button>\n\n          <ul\n            class=\"dropdown-menu dropdown-menu--date-range\"\n            *dropdownMenu\n          >\n            <c8y-interval-picker\n              class=\"d-contents\"\n              formControlName=\"currentDateContextInterval\"\n            ></c8y-interval-picker>\n\n            <ng-container *ngIf=\"form.controls.currentDateContextInterval.value === 'custom'\">\n              <div class=\"p-l-16 p-r-16\">\n                <c8y-form-group\n                  [ngClass]=\"form.controls.temporaryUserSelectedFromDate.errors ? 'has-error' : ''\"\n                >\n                  <label\n                    [title]=\"'From`date`' | translate\"\n                    for=\"temporaryUserSelectedFromDate\"\n                    translate\n                  >\n                    From`date`\n                  </label>\n                  <c8y-date-time-picker\n                    id=\"temporaryUserSelectedFromDate\"\n                    [maxDate]=\"form.value.temporaryUserSelectedToDate\"\n                    [placeholder]=\"'From`date`' | translate\"\n                    [formControl]=\"form.controls.temporaryUserSelectedFromDate\"\n                    [ngClass]=\"\n                      form.controls.temporaryUserSelectedFromDate.errors ? 'has-error' : ''\n                    \"\n                  ></c8y-date-time-picker>\n                  <c8y-messages [show]=\"form.controls.temporaryUserSelectedFromDate.errors\">\n                    <c8y-message\n                      name=\"dateAfterRangeMax\"\n                      [text]=\"'This date is after the latest allowed date.' | translate\"\n                    ></c8y-message>\n                    <c8y-message\n                      name=\"invalidDateTime\"\n                      [text]=\"'This date is invalid.' | translate\"\n                    ></c8y-message>\n                  </c8y-messages>\n                </c8y-form-group>\n\n                <c8y-form-group\n                  [ngClass]=\"form.controls.temporaryUserSelectedToDate.errors ? 'has-error' : ''\"\n                >\n                  <label\n                    [title]=\"'To`date`' | translate\"\n                    for=\"temporaryUserSelectedToDate\"\n                    translate\n                  >\n                    To`date`\n                  </label>\n                  <c8y-date-time-picker\n                    id=\"temporaryUserSelectedToDate\"\n                    [minDate]=\"form.value.temporaryUserSelectedFromDate\"\n                    [placeholder]=\"'To`date`' | translate\"\n                    [formControl]=\"form.controls.temporaryUserSelectedToDate\"\n                    [ngClass]=\"form.controls.temporaryUserSelectedToDate.errors ? 'has-error' : ''\"\n                  ></c8y-date-time-picker>\n                  <c8y-messages [show]=\"form.controls.temporaryUserSelectedToDate.errors\">\n                    <c8y-message\n                      name=\"dateBeforeRangeMin\"\n                      [text]=\"'This date is before the earliest allowed date.' | translate\"\n                    ></c8y-message>\n                    <c8y-message\n                      name=\"invalidDateTime\"\n                      [text]=\"'This date is invalid.' | translate\"\n                    ></c8y-message>\n                  </c8y-messages>\n                </c8y-form-group>\n              </div>\n\n              <div class=\"p-16 d-flex gap-8 separator-top\">\n                <button\n                  class=\"btn btn-default btn-sm flex-grow\"\n                  title=\"{{ 'Reset' | translate }}\"\n                  type=\"button\"\n                  (click)=\"reset(); dropdown.isOpen = false\"\n                  [disabled]=\"form.value.realtime\"\n                  translate\n                >\n                  Reset\n                </button>\n\n                <button\n                  class=\"btn btn-primary btn-sm flex-grow\"\n                  title=\"{{ 'Apply' | translate }}\"\n                  type=\"button\"\n                  (click)=\"applyDatetimeContext(); dropdown.isOpen = false\"\n                  [disabled]=\"\n                    (form.pristine && form.untouched) || form.invalid || form.value.realtime\n                  \"\n                  translate\n                >\n                  Apply\n                </button>\n              </div>\n            </ng-container>\n          </ul>\n        </div>\n      </div>\n    </ng-container>\n\n    <div class=\"input-group w-auto\">\n      <c8y-realtime-control\n        class=\"form-control p-0 flex-no-grow w-auto\"\n        *ngIf=\"displaySettings.globalRealtimeContext\"\n        formControlName=\"realtime\"\n      ></c8y-realtime-control>\n\n      <c8y-aggregation-picker\n        *ngIf=\"displaySettings.globalAggregationContext\"\n        formControlName=\"aggregation\"\n        [disabledAggregations]=\"disabledAggregations\"\n      ></c8y-aggregation-picker>\n    </div>\n  </form>\n</ng-template>\n\n<c8y-dashboard-child-action>\n  <button\n    type=\"button\"\n    (click)=\"toggleDecoupling()\"\n  >\n    <i [c8yIcon]=\"isCoupled ? 'schedule1' : 'today'\"></i>\n    <span class=\"m-l-4\">\n      {{ (isCoupled ? decoupleTimeContextLabel : coupleTimeContextLabel) | translate }}\n    </span>\n  </button>\n</c8y-dashboard-child-action>\n"]}
524
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"widget-time-context.component.js","sourceRoot":"","sources":["../../../../../core/dashboard/wiget-time-context/widget-time-context.component.ts","../../../../../core/dashboard/wiget-time-context/widget-time-context.component.html"],"names":[],"mappings":"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","sourcesContent":["import { NgClass, NgIf, NgTemplateOutlet } from '@angular/common';\nimport {\n  AfterViewInit,\n  Component,\n  effect,\n  EventEmitter,\n  Input,\n  OnDestroy,\n  OnInit,\n  Output,\n  ViewChild\n} from '@angular/core';\nimport { FormBuilder, FormsModule, ReactiveFormsModule } from '@angular/forms';\nimport { ActivationEnd, NavigationEnd, NavigationStart, Router } from '@angular/router';\nimport { aggregationType } from '@c8y/client';\nimport {\n  Interval,\n  INTERVAL_TITLES,\n  IntervalPickerComponent\n} from '@c8y/ngx-components/interval-picker';\nimport { BsDropdownDirective, BsDropdownModule } from 'ngx-bootstrap/dropdown';\nimport { TooltipModule } from 'ngx-bootstrap/tooltip';\nimport { interval, Subject, Subscription } from 'rxjs';\nimport { filter, takeUntil, tap } from 'rxjs/operators';\nimport { ActionBarService } from '../../action-bar';\nimport { ActionBarItemComponent } from '../../action-bar/action-bar-item.component';\nimport { AGGREGATION_LIMITS } from '../../aggregation/aggregation.model';\nimport { AggregationService } from '../../aggregation/aggregation.service';\nimport { DatePipe } from '../../common/date.pipe';\nimport { IconDirective } from '../../common/icon.directive';\nimport { DateTimePickerComponent } from '../../date-time-picker';\nimport { FormGroupComponent } from '../../forms/form-group.component';\nimport { MessageDirective } from '../../forms/message.directive';\nimport { MessagesComponent } from '../../forms/messages.component';\nimport { gettext } from '../../i18n';\nimport { C8yTranslateDirective } from '../../i18n/c8y-translate.directive';\nimport { C8yTranslatePipe } from '../../i18n/c8y-translate.pipe';\nimport { DashboardChildActionComponent } from '../dashboard-child-action.component';\nimport { DashboardChildComponent } from '../dashboard-child.component';\nimport { DateTimeContext, TimeContextEvent, WidgetTimeContext } from '../widget-change-event.model';\nimport { WidgetsDashboardEventService } from '../widgets-dashboard-event.service';\nimport { AggregationPickerComponent } from './aggregation-picker/aggregation-picker.component';\nimport { RealtimeControlComponent } from './realtime-control/realtime-control.component';\nimport { WidgetTimeContextDateRangeService } from './widget-time-context-date-range.service';\nimport { WidgetTimeContextHelperService } from './widget-time-context-helper.service';\nimport { WidgetTimeContextQueryService } from './widget-time-context-query.service';\nimport {\n  InputDateContextQueryParams,\n  WidgetDisplaySettings,\n  WidgetTimeContextState\n} from './widget-time-context.model';\n\n@Component({\n  selector: 'c8y-widget-time-context',\n  templateUrl: './widget-time-context.component.html',\n  host: { class: 'd-flex a-i-center gap-4' },\n  standalone: true,\n  imports: [\n    NgIf,\n    ActionBarItemComponent,\n    NgTemplateOutlet,\n    FormsModule,\n    ReactiveFormsModule,\n    BsDropdownModule,\n    TooltipModule,\n    IconDirective,\n    IntervalPickerComponent,\n    FormGroupComponent,\n    NgClass,\n    C8yTranslateDirective,\n    MessagesComponent,\n    MessageDirective,\n    RealtimeControlComponent,\n    AggregationPickerComponent,\n    C8yTranslatePipe,\n    DatePipe,\n    DashboardChildActionComponent,\n    DateTimePickerComponent\n  ]\n})\nexport class WidgetTimeContextComponent implements OnInit, OnDestroy, AfterViewInit {\n  readonly INTERVAL_TITLES = INTERVAL_TITLES;\n  readonly DATE_FORMAT = 'short';\n  /**\n   * Indicates if the component can decouple or not.\n   */\n  @Input()\n  canDecouple = true;\n\n  @Input() displaySettings: WidgetDisplaySettings;\n\n  @Input() hidden = false;\n\n  /**\n   * Emits each change as an array of dates [from, to].\n   */\n  @Output()\n  dateContextChange = new EventEmitter<any>();\n  /**\n   * @ignore\n   */\n  @ViewChild(DashboardChildActionComponent) action: DashboardChildActionComponent;\n  @ViewChild(BsDropdownDirective) dropdown: BsDropdownDirective;\n  /**\n   * Indicates if the time context is bound to the global scope.\n   */\n  isCoupled = true;\n  decoupleTimeContextLabel = gettext('Decouple time context');\n  coupleTimeContextLabel = gettext('Couple time context');\n  form: ReturnType<WidgetTimeContextComponent['createForm']>;\n  actionBarInGroupPriority: number;\n  disabledAggregations: Partial<Record<aggregationType, boolean>> = {};\n  sliderChange: boolean;\n  readonly DEFAULT_INTERVAL: Interval['id'] = 'days';\n  readonly ACTION_BAR_PRIORITY = 7;\n  readonly ACTION_BAR_GROUP_ID = 'timecontext';\n  readonly REALTIME_INTERVAL = 1000;\n  private subscription: Subscription;\n  private destroy$: Subject<void> = new Subject();\n  private navigationInProgress: boolean;\n  private realtimeSubscription: Subscription;\n  private isAutoRefreshEnabled: boolean;\n\n  /**\n   * @ignore only DI.\n   */\n  constructor(\n    private widgetEventService: WidgetsDashboardEventService,\n    private dashboardChild: DashboardChildComponent,\n    private formBuilder: FormBuilder,\n    private queryService: WidgetTimeContextQueryService,\n    private helperService: WidgetTimeContextHelperService,\n    private router: Router,\n    private actionBarService: ActionBarService,\n    private aggregationService: AggregationService,\n    private widgetTimeContextDateRangeService: WidgetTimeContextDateRangeService\n  ) {\n    effect(() => {\n      const data = this.widgetTimeContextDateRangeService.timeContextChange();\n      if (data) {\n        const updatedFormData = {\n          date: [new Date(data.dateFrom), new Date(data.dateTo)],\n          interval: data.interval,\n          realtime: false,\n          aggregation: this.form.value.aggregation\n        } as WidgetTimeContextState;\n        this.sliderChange = true;\n        this.dateContextChange.emit({ ...updatedFormData, sliderChange: true });\n        this.stopRealtime();\n        this.updateFormValues(updatedFormData);\n      }\n    });\n  }\n\n  /**\n   * @ignore Subscribing to the global context.\n   */\n  ngOnInit(): void {\n    this.actionBarInGroupPriority = this.helperService.getActionBarPriority(this.displaySettings);\n    const initialContext: WidgetTimeContextState =\n      this.getInitialContext() || this.getDefaultContext();\n    initialContext.aggregation = this.calculateAggregation(\n      initialContext.date,\n      initialContext.aggregation\n    );\n    this.form = this.createForm(initialContext);\n\n    this.dateContextChange.emit({\n      date: initialContext.date,\n      realtime: initialContext.realtime,\n      aggregation: initialContext.aggregation\n    });\n    if (this.isCoupled) {\n      this.queryService.setDateContextQueryParams(initialContext);\n    }\n    this.subscribeToGlobalContext();\n    this.subscribeToQueryParamsChange();\n    this.subscribeToRouterEvents();\n    this.subscribeToIntervalChange();\n    this.subscribeToRealtimeChange();\n    this.subscribeToAggregationChange();\n\n    this.widgetEventService.onAutoRefresh$\n      .pipe(\n        takeUntil(this.destroy$),\n        tap(autoRefresh => (this.isAutoRefreshEnabled = autoRefresh))\n      )\n      .subscribe(autoRefresh => {\n        // Fix for:\n        // 1. Make a group with dashboard having a widget with with auto-refresh time context enabled.\n        // 2. When you route to e.g. home page and back to the group dashboard, none of a groups will be routable again.\n        queueMicrotask(() => {\n          autoRefresh ? this.onDisableAutoRefresh() : this.enableDateRangeAndAggregation();\n        });\n      });\n\n    if (initialContext.realtime) {\n      this.onRealtimeValueChange(initialContext.realtime);\n      this.startRealtime();\n    }\n  }\n\n  /**\n   * @ignore Adding custom actions.\n   */\n  ngAfterViewInit(): void {\n    if (this.canDecouple) {\n      this.dashboardChild.addActions([this.action]);\n    }\n  }\n\n  /**\n   * Toggles the coupling on or off.\n   */\n  toggleDecoupling(): void {\n    this.isCoupled = !this.isCoupled;\n    const lastEventValue = this.widgetEventService.getLastValue('TIME_CONTEXT');\n    const { realtime, aggregation, interval } = lastEventValue;\n    let date: DateTimeContext;\n    if (interval) {\n      date = this.helperService.getDateTimeContextByInterval(interval);\n    } else {\n      date = lastEventValue.dateTimeContext;\n    }\n    this.updateFormValues({ date, interval, realtime, aggregation });\n\n    if (this.isCoupled) {\n      this.subscribeToGlobalContext();\n      this.dateContextChange.emit({ date, realtime, aggregation });\n    } else {\n      this.unsubscribeFromGlobalContext();\n    }\n  }\n\n  /**\n   * Applies form value to global or local date context.\n   */\n  applyDatetimeContext(): void {\n    this.update({\n      date: [\n        new Date(this.form.value.temporaryUserSelectedFromDate),\n        new Date(this.form.value.temporaryUserSelectedToDate)\n      ],\n      interval: null,\n      realtime: this.form.value.realtime,\n      aggregation: this.form.value.aggregation\n    });\n  }\n\n  /**\n   * Resets form to initial value and update context.\n   */\n  reset(): void {\n    this.stopRealtime();\n    this.update(this.getDefaultContext());\n  }\n\n  /**\n   * @ignore unsubscribing.\n   */\n  ngOnDestroy(): void {\n    this.unsubscribeFromGlobalContext();\n    this.clearQueryParamsIfNeeded();\n    this.widgetEventService.setRealtimeTimeContextSetting();\n    this.widgetEventService.emitAutoRefresh(false);\n    this.destroy$.next();\n    this.destroy$.complete();\n  }\n\n  private subscribeToIntervalChange(): void {\n    this.form.controls.currentDateContextInterval.valueChanges\n      .pipe(takeUntil(this.destroy$))\n      .subscribe(interval => {\n        let date: DateTimeContext;\n        if (interval === 'custom') {\n          date = [\n            new Date(this.form.controls.currentDateContextFromDate.value),\n            new Date(this.form.controls.currentDateContextToDate.value)\n          ];\n        } else {\n          date = this.helperService.getDateTimeContextByInterval(interval);\n          this.dropdown.isOpen = false;\n        }\n        this.update({\n          date,\n          interval,\n          realtime: this.form.value.realtime,\n          aggregation: this.form.value.aggregation\n        });\n      });\n  }\n\n  private subscribeToRealtimeChange(): void {\n    this.form.controls.realtime.valueChanges.pipe(takeUntil(this.destroy$)).subscribe(realtime => {\n      this.onRealtimeValueChange(realtime);\n\n      if (realtime) {\n        this.startRealtime();\n      } else {\n        this.stopRealtime();\n      }\n    });\n  }\n\n  private subscribeToAggregationChange() {\n    this.form.controls.aggregation.valueChanges\n      .pipe(takeUntil(this.destroy$))\n      .subscribe(aggregation => {\n        if (this.sliderChange) {\n          this.sliderChange = false;\n          return;\n        }\n        this.update({\n          date: [\n            new Date(this.form.value.currentDateContextFromDate),\n            new Date(this.form.value.currentDateContextToDate)\n          ],\n          interval: this.form.value.currentDateContextInterval,\n          realtime: this.form.value.realtime,\n          aggregation\n        });\n      });\n  }\n\n  private createForm(context: WidgetTimeContextState) {\n    return this.formBuilder.group({\n      temporaryUserSelectedFromDate: context.date[0].toISOString(),\n      temporaryUserSelectedToDate: context.date[1].toISOString(),\n      currentDateContextFromDate: context.date[0].toISOString(),\n      currentDateContextToDate: context.date[1].toISOString(),\n      currentDateContextInterval: context.interval || 'custom',\n      realtime: context.realtime,\n      aggregation: context.aggregation\n    });\n  }\n\n  /**\n   * Fires a new WidgetChangeEvent either on the local change emitter or on the global one.\n   * @param widgetTimeContextState New widget time context value.*/\n  private update({ date, interval, realtime, aggregation }: WidgetTimeContextState): void {\n    const validAggregation = this.calculateAggregation(date, aggregation);\n    if (this.isCoupled) {\n      const eventData: WidgetTimeContext =\n        interval && interval !== 'custom'\n          ? { interval, realtime, aggregation: validAggregation }\n          : { dateTimeContext: date, realtime, aggregation: validAggregation };\n      this.widgetEventService.emit({ type: 'TIME_CONTEXT', data: eventData });\n    } else {\n      this.updateFormValues({ date, interval, realtime, aggregation: validAggregation });\n      this.dateContextChange.emit({ date, realtime, aggregation: validAggregation });\n    }\n  }\n\n  private subscribeToGlobalContext(): void {\n    const event$ = this.widgetEventService.getObservable<TimeContextEvent>('TIME_CONTEXT');\n    this.subscription = event$.subscribe((context: WidgetTimeContext) => {\n      let date: DateTimeContext;\n      const { realtime, interval, aggregation } = context;\n      if (interval) {\n        date = this.helperService.getDateTimeContextByInterval(context.interval);\n      } else {\n        date = context.dateTimeContext;\n      }\n\n      this.dateContextChange.emit({\n        date,\n        sliderChange: false,\n        interval,\n        realtime,\n        aggregation\n      });\n      this.updateFormValues({ date, interval, realtime, aggregation });\n      this.queryService.setDateContextQueryParams({ interval, date, realtime, aggregation });\n    });\n  }\n\n  private updateFormValues({\n    date,\n    interval,\n    realtime,\n    aggregation\n  }: WidgetTimeContextState): void {\n    this.form.patchValue(\n      {\n        temporaryUserSelectedFromDate: date[0].toISOString(),\n        temporaryUserSelectedToDate: date[1].toISOString(),\n        currentDateContextFromDate: date[0].toISOString(),\n        currentDateContextToDate: date[1].toISOString(),\n        realtime,\n        currentDateContextInterval: interval || 'custom',\n        aggregation: aggregation || null\n      },\n      {\n        emitEvent: false\n      }\n    );\n  }\n\n  private unsubscribeFromGlobalContext(): void {\n    if (this.subscription) {\n      this.subscription.unsubscribe();\n    }\n  }\n\n  private getInitialContext(): WidgetTimeContextState | null {\n    const dateTimeContextFromQueryParams = this.queryService.dateTimeContextFromQueryParams();\n    if (dateTimeContextFromQueryParams) {\n      return {\n        ...dateTimeContextFromQueryParams,\n        realtime: dateTimeContextFromQueryParams.realtime ?? false,\n        aggregation: dateTimeContextFromQueryParams.realtime\n          ? null\n          : dateTimeContextFromQueryParams.aggregation || null\n      };\n    }\n    // get value from last value of events service\n    const lastEventValue = this.widgetEventService.getLastValue('TIME_CONTEXT');\n    const realtime = lastEventValue?.realtime ?? false;\n    if (lastEventValue && lastEventValue.dateTimeContext) {\n      return {\n        date: lastEventValue.dateTimeContext,\n        interval: 'custom',\n        realtime,\n        aggregation: realtime ? null : lastEventValue.aggregation\n      };\n    }\n    if (lastEventValue && lastEventValue.interval) {\n      return {\n        date: this.helperService.getDateTimeContextByInterval(lastEventValue.interval),\n        interval: lastEventValue.interval,\n        realtime,\n        aggregation: realtime ? null : lastEventValue.aggregation\n      };\n    }\n\n    return null;\n  }\n\n  private subscribeToQueryParamsChange(): void {\n    this.queryService\n      .queryParamsChange$()\n      .pipe(takeUntil(this.destroy$))\n      .subscribe(\n        ({\n          dateContextFrom,\n          dateContextTo,\n          dateContextInterval,\n          dateContextRealtime,\n          dateContextAggregation\n        }: InputDateContextQueryParams) => {\n          const realtime = dateContextRealtime ?? this.form.value.realtime;\n          if (dateContextInterval) {\n            this.widgetEventService.emit({\n              type: 'TIME_CONTEXT',\n              data: {\n                interval: dateContextInterval,\n                realtime,\n                aggregation: dateContextAggregation\n              }\n            });\n          } else {\n            const dateContext: DateTimeContext = [\n              new Date(dateContextFrom),\n              new Date(dateContextTo)\n            ];\n            this.widgetEventService.emit({\n              type: 'TIME_CONTEXT',\n              data: {\n                dateTimeContext: dateContext,\n                realtime,\n                aggregation: dateContextAggregation\n              }\n            });\n          }\n        }\n      );\n  }\n\n  private clearQueryParamsIfNeeded(): void {\n    // If navigation is in progress, router will take care of clearing query params. This way we avoid unnecessary manipulation of browser history\n    if (this.navigationInProgress) {\n      return;\n    }\n    // check if any other WidgetTimeContextComponent action in action bar exists\n    const anyWidgetTimeContextActionLeft = Array.from(this.actionBarService.state).some(\n      action => action.groupId === this.ACTION_BAR_GROUP_ID\n    );\n    if (!anyWidgetTimeContextActionLeft) {\n      this.queryService.clearQueryParams();\n    }\n  }\n\n  private subscribeToRouterEvents(): void {\n    this.router.events\n      .pipe(\n        filter(\n          e =>\n            e instanceof NavigationStart || e instanceof NavigationEnd || e instanceof ActivationEnd\n        ),\n        takeUntil(this.destroy$)\n      )\n      .subscribe(e => {\n        this.navigationInProgress = e instanceof NavigationStart;\n      });\n  }\n\n  private getDefaultContext(): WidgetTimeContextState {\n    return {\n      date: this.helperService.getDateTimeContextByInterval(this.DEFAULT_INTERVAL),\n      interval: this.DEFAULT_INTERVAL,\n      realtime: false,\n      aggregation: aggregationType.MINUTELY\n    };\n  }\n\n  private startRealtime(): void {\n    this.disableDateRangeAndAggregation();\n\n    this.realtimeSubscription = interval(this.REALTIME_INTERVAL)\n      .pipe(takeUntil(this.destroy$))\n      .subscribe(() => {\n        const newDateFrom = new Date(\n          new Date(this.form.value.currentDateContextFromDate).valueOf() + this.REALTIME_INTERVAL\n        );\n        const newDateTo = new Date(\n          new Date(this.form.value.currentDateContextToDate).valueOf() + this.REALTIME_INTERVAL\n        );\n        this.updateFormValues({\n          date: [newDateFrom, newDateTo],\n          interval: this.form.value.currentDateContextInterval,\n          realtime: true,\n          aggregation: null\n        });\n      });\n  }\n\n  private onDisableAutoRefresh(): void {\n    this.form.controls.aggregation.setValue(null);\n    this.disableDateRangeAndAggregation();\n  }\n\n  private disableDateRangeAndAggregation(): void {\n    this.form.controls.temporaryUserSelectedFromDate.disable();\n    this.form.controls.temporaryUserSelectedToDate.disable();\n    this.form.controls.aggregation.disable();\n  }\n\n  private enableDateRangeAndAggregation(): void {\n    if (this.form.controls.realtime.value || this.isAutoRefreshEnabled) {\n      return;\n    }\n    this.form.controls.temporaryUserSelectedFromDate.enable();\n    this.form.controls.temporaryUserSelectedToDate.enable();\n    this.form.controls.aggregation.enable();\n  }\n\n  private stopRealtime(): void {\n    this.realtimeSubscription?.unsubscribe();\n    this.enableDateRangeAndAggregation();\n  }\n\n  private onRealtimeValueChange(realtime: boolean): void {\n    let dateTimeContext: DateTimeContext;\n    if (this.form.value.currentDateContextInterval !== 'custom') {\n      dateTimeContext = this.helperService.getDateTimeContextByInterval(\n        this.form.value.currentDateContextInterval\n      );\n    } else {\n      const currentTimeSpanInMs =\n        new Date(this.form.value.currentDateContextToDate).valueOf() -\n        new Date(this.form.value.currentDateContextFromDate).valueOf();\n      const dateTo = new Date();\n      const dateFrom = new Date(dateTo.valueOf() - currentTimeSpanInMs);\n      dateTimeContext = [dateFrom, dateTo];\n    }\n\n    this.update({\n      date: dateTimeContext,\n      interval: this.form.value.currentDateContextInterval,\n      realtime,\n      aggregation: null\n    });\n  }\n\n  private calculateAggregation(\n    [dateFrom, dateTo]: DateTimeContext,\n    aggregation: aggregationType\n  ): aggregationType {\n    this.disabledAggregations = this.aggregationService.getDisabledAggregationOptions(\n      dateFrom,\n      dateTo\n    );\n    const timeRangeInMs = dateTo.valueOf() - dateFrom.valueOf();\n    const isProperAggregation = !this.disabledAggregations[aggregation] || aggregation === null;\n\n    if (isProperAggregation) {\n      return aggregation;\n    }\n    if (timeRangeInMs >= AGGREGATION_LIMITS.DAILY_LIMIT) {\n      return aggregationType.DAILY;\n    } else if (timeRangeInMs >= AGGREGATION_LIMITS.HOURLY_LIMIT) {\n      return aggregationType.HOURLY;\n    } else if (timeRangeInMs >= AGGREGATION_LIMITS.MINUTELY_LIMIT) {\n      return aggregationType.MINUTELY;\n    } else {\n      return null;\n    }\n  }\n}\n","<c8y-action-bar-item\n  *ngIf=\"isCoupled && !hidden\"\n  [priority]=\"ACTION_BAR_PRIORITY\"\n  [groupId]=\"ACTION_BAR_GROUP_ID\"\n  [inGroupPriority]=\"actionBarInGroupPriority\"\n  [placement]=\"'left'\"\n>\n  <ng-container\n    [ngTemplateOutlet]=\"dateTimePicker\"\n    [ngTemplateOutletContext]=\"{\n      date: [form.value.currentDateContextFromDate, form.value.currentDateContextToDate]\n    }\"\n  ></ng-container>\n</c8y-action-bar-item>\n\n<ng-container\n  *ngIf=\"!isCoupled\"\n  [ngTemplateOutlet]=\"dateTimePicker\"\n  [ngTemplateOutletContext]=\"{\n    date: [form.value.currentDateContextFromDate, form.value.currentDateContextToDate]\n  }\"\n></ng-container>\n\n<ng-template\n  #dateTimePicker\n  let-date=\"date\"\n>\n  <form\n    class=\"d-flex gap-16 p-l-xs-16 p-r-xs-16 m-t-xs-8 m-b-xs-8\"\n    [formGroup]=\"form\"\n  >\n    <ng-container *ngIf=\"displaySettings.globalTimeContext\">\n      <div>\n        <div\n          class=\"dropdown flex-grow\"\n          #dropdown=\"bs-dropdown\"\n          dropdown\n          [insideClick]=\"true\"\n          *ngIf=\"date\"\n        >\n          <button\n            class=\"dropdown-toggle form-control l-h-tight d-flex a-i-center\"\n            attr.aria-label=\"{{ date[0] | c8yDate: DATE_FORMAT }} — {{\n              date[1] | c8yDate: DATE_FORMAT\n            }}\"\n            tooltip=\"{{ date[0] | c8yDate: DATE_FORMAT }} — {{ date[1] | c8yDate: DATE_FORMAT }}\"\n            placement=\"top\"\n            container=\"body\"\n            data-cy=\"widget-time-context--date-picker-dropdown-button\"\n            [adaptivePosition]=\"false\"\n            [delay]=\"500\"\n            dropdownToggle\n          >\n            <i\n              class=\"m-r-4\"\n              c8yIcon=\"schedule1\"\n            ></i>\n            <div class=\"d-col text-left fit-w\">\n              <span\n                class=\"text-12\"\n                data-cy=\"widget-time-context--selected-interval\"\n              >\n                {{ INTERVAL_TITLES[form.controls.currentDateContextInterval.value] | translate }}\n              </span>\n              <span\n                class=\"text-10 text-muted text-truncate\"\n                data-cy=\"widget-time-context--selected-time-range\"\n              >\n                {{ date[0] | c8yDate: DATE_FORMAT }} — {{ date[1] | c8yDate: DATE_FORMAT }}\n              </span>\n            </div>\n            <span class=\"caret m-r-16 m-l-4\"></span>\n          </button>\n\n          <ul\n            class=\"dropdown-menu dropdown-menu--date-range\"\n            *dropdownMenu\n          >\n            <c8y-interval-picker\n              class=\"d-contents\"\n              formControlName=\"currentDateContextInterval\"\n            ></c8y-interval-picker>\n\n            <ng-container *ngIf=\"form.controls.currentDateContextInterval.value === 'custom'\">\n              <div class=\"p-l-16 p-r-16\">\n                <c8y-form-group\n                  [ngClass]=\"form.controls.temporaryUserSelectedFromDate.errors ? 'has-error' : ''\"\n                >\n                  <label\n                    [title]=\"'From`date`' | translate\"\n                    for=\"temporaryUserSelectedFromDate\"\n                    translate\n                  >\n                    From`date`\n                  </label>\n                  <c8y-date-time-picker\n                    id=\"temporaryUserSelectedFromDate\"\n                    [maxDate]=\"form.value.temporaryUserSelectedToDate\"\n                    [placeholder]=\"'From`date`' | translate\"\n                    [formControl]=\"form.controls.temporaryUserSelectedFromDate\"\n                    [ngClass]=\"\n                      form.controls.temporaryUserSelectedFromDate.errors ? 'has-error' : ''\n                    \"\n                  ></c8y-date-time-picker>\n                  <c8y-messages [show]=\"form.controls.temporaryUserSelectedFromDate.errors\">\n                    <c8y-message\n                      name=\"dateAfterRangeMax\"\n                      [text]=\"'This date is after the latest allowed date.' | translate\"\n                    ></c8y-message>\n                    <c8y-message\n                      name=\"invalidDateTime\"\n                      [text]=\"'This date is invalid.' | translate\"\n                    ></c8y-message>\n                  </c8y-messages>\n                </c8y-form-group>\n\n                <c8y-form-group\n                  [ngClass]=\"form.controls.temporaryUserSelectedToDate.errors ? 'has-error' : ''\"\n                >\n                  <label\n                    [title]=\"'To`date`' | translate\"\n                    for=\"temporaryUserSelectedToDate\"\n                    translate\n                  >\n                    To`date`\n                  </label>\n                  <c8y-date-time-picker\n                    id=\"temporaryUserSelectedToDate\"\n                    [minDate]=\"form.value.temporaryUserSelectedFromDate\"\n                    [placeholder]=\"'To`date`' | translate\"\n                    [formControl]=\"form.controls.temporaryUserSelectedToDate\"\n                    [ngClass]=\"form.controls.temporaryUserSelectedToDate.errors ? 'has-error' : ''\"\n                  ></c8y-date-time-picker>\n                  <c8y-messages [show]=\"form.controls.temporaryUserSelectedToDate.errors\">\n                    <c8y-message\n                      name=\"dateBeforeRangeMin\"\n                      [text]=\"'This date is before the earliest allowed date.' | translate\"\n                    ></c8y-message>\n                    <c8y-message\n                      name=\"invalidDateTime\"\n                      [text]=\"'This date is invalid.' | translate\"\n                    ></c8y-message>\n                  </c8y-messages>\n                </c8y-form-group>\n              </div>\n\n              <div class=\"p-16 d-flex gap-8 separator-top\">\n                <button\n                  class=\"btn btn-default btn-sm flex-grow\"\n                  title=\"{{ 'Reset' | translate }}\"\n                  type=\"button\"\n                  (click)=\"reset(); dropdown.isOpen = false\"\n                  [disabled]=\"form.value.realtime\"\n                  translate\n                >\n                  Reset\n                </button>\n\n                <button\n                  class=\"btn btn-primary btn-sm flex-grow\"\n                  title=\"{{ 'Apply' | translate }}\"\n                  type=\"button\"\n                  (click)=\"applyDatetimeContext(); dropdown.isOpen = false\"\n                  [disabled]=\"\n                    (form.pristine && form.untouched) || form.invalid || form.value.realtime\n                  \"\n                  translate\n                >\n                  Apply\n                </button>\n              </div>\n            </ng-container>\n          </ul>\n        </div>\n      </div>\n    </ng-container>\n\n    <div class=\"input-group w-auto\">\n      <c8y-realtime-control\n        class=\"form-control p-0 flex-no-grow w-auto\"\n        *ngIf=\"displaySettings.globalRealtimeContext\"\n        formControlName=\"realtime\"\n      ></c8y-realtime-control>\n\n      <c8y-aggregation-picker\n        *ngIf=\"displaySettings.globalAggregationContext\"\n        formControlName=\"aggregation\"\n        [disabledAggregations]=\"disabledAggregations\"\n      ></c8y-aggregation-picker>\n    </div>\n  </form>\n</ng-template>\n\n<c8y-dashboard-child-action>\n  <button\n    type=\"button\"\n    (click)=\"toggleDecoupling()\"\n  >\n    <i [c8yIcon]=\"isCoupled ? 'schedule1' : 'today'\"></i>\n    <span class=\"m-l-4\">\n      {{ (isCoupled ? decoupleTimeContextLabel : coupleTimeContextLabel) | translate }}\n    </span>\n  </button>\n</c8y-dashboard-child-action>\n"]}
@@ -39,9 +39,7 @@ export class WorkspaceConfigComponent {
39
39
  }
40
40
  }
41
41
  addConfig(duplicatedConfig) {
42
- const name = uniqueNamesGenerator({
43
- dictionaries: [adjectives, nouns]
44
- });
42
+ const name = uniqueNamesGenerator({ dictionaries: [adjectives, nouns] });
45
43
  const workspace = {
46
44
  id: new Date().toISOString(),
47
45
  label: name,
@@ -50,11 +48,9 @@ export class WorkspaceConfigComponent {
50
48
  if (duplicatedConfig) {
51
49
  workspace.config = duplicatedConfig;
52
50
  }
53
- this.currentConfiguration = { ...workspace };
54
- this.configurations.unshift(workspace);
51
+ this.configurations = [workspace, ...this.configurations];
55
52
  this.initWorkspaceForm();
56
- this.workspaceConfigurationService.saveConfigurations(this.configurations, this.currentConfiguration.id);
57
- this.onConfigurationChange.emit(this.currentConfiguration.config);
53
+ this.changeConfiguration(true, workspace);
58
54
  }
59
55
  changeConfiguration(selected, configuration) {
60
56
  if (!selected) {
@@ -97,6 +93,15 @@ export class WorkspaceConfigComponent {
97
93
  config: JSON.stringify(this.updatedConfig)
98
94
  };
99
95
  this.workspaceConfigurationService.saveConfigurations(this.configurations, this.currentConfiguration.id);
96
+ const control = this.configurationsFormGroup.controls['configurations'];
97
+ const index = this.configurations.findIndex(c => c.id === this.currentConfiguration.id);
98
+ if (index !== -1) {
99
+ control.at(index).patchValue({
100
+ label: this.currentConfiguration.label,
101
+ config: this.currentConfiguration.config,
102
+ id: this.currentConfiguration.id
103
+ });
104
+ }
100
105
  this.router.navigate([], { queryParams });
101
106
  }
102
107
  initializeConfigurations() {
@@ -166,4 +171,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
166
171
  }], onConfigurationChange: [{
167
172
  type: Output
168
173
  }] } });
169
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"workspace-configuration.component.js","sourceRoot":"","sources":["../../../../../datapoint-explorer/view/configuration/workspace-configuration.component.ts","../../../../../datapoint-explorer/view/configuration/workspace-configuration.component.html"],"names":[],"mappings":"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","sourcesContent":["import { A11yModule } from '@angular/cdk/a11y';\nimport {\n  Component,\n  EventEmitter,\n  inject,\n  Input,\n  OnChanges,\n  OnInit,\n  Output,\n  SimpleChanges\n} from '@angular/core';\nimport { FormArray, FormBuilder, FormGroup, FormsModule } from '@angular/forms';\nimport {\n  ClipboardService,\n  ContextRouteService,\n  CoreModule,\n  gettext,\n  ViewContext\n} from '@c8y/ngx-components';\nimport { BsDropdownModule } from 'ngx-bootstrap/dropdown';\nimport { TooltipModule } from 'ngx-bootstrap/tooltip';\nimport { WorkspaceConfiguration } from './workspace-configuration.model';\nimport { DatapointsGraphWidgetConfig } from '@c8y/ngx-components/echart';\nimport { WorkspaceConfigurationService } from './workspace-configuration.service';\nimport { ActivatedRoute, Router } from '@angular/router';\nimport { uniqueNamesGenerator } from 'unique-names-generator';\nimport { adjectives, nouns } from './naming-dictionary';\n\n@Component({\n  selector: 'c8y-workspace-config',\n  templateUrl: './workspace-configuration.component.html',\n  standalone: true,\n  imports: [CoreModule, BsDropdownModule, FormsModule, A11yModule, TooltipModule]\n})\nexport class WorkspaceConfigComponent implements OnInit, OnChanges {\n  @Input() updatedConfig: DatapointsGraphWidgetConfig;\n  @Output() onConfigurationChange = new EventEmitter<DatapointsGraphWidgetConfig>();\n\n  currentConfiguration: WorkspaceConfiguration;\n  configurations: WorkspaceConfiguration[] = [];\n  configurationsFormGroup: FormGroup;\n  activeConfigTooltip = gettext('Active configuration cannot be removed');\n  removeConfigTooltip = gettext('Remove configuration');\n\n  private readonly formBuilder = inject(FormBuilder);\n  private readonly workspaceConfigurationService = inject(WorkspaceConfigurationService);\n  private readonly contextRouteService = inject(ContextRouteService);\n  private readonly clipboardService = inject(ClipboardService);\n  private readonly activatedRoute = inject(ActivatedRoute);\n  private readonly router = inject(Router);\n\n  ngOnInit(): void {\n    this.initializeContextSourceId();\n    this.initializeConfigurations();\n    this.initWorkspaceForm();\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes.updatedConfig && !changes.updatedConfig.firstChange) {\n      this.updateConfigurations();\n    }\n  }\n\n  addConfig(duplicatedConfig?: DatapointsGraphWidgetConfig): void {\n    const name = uniqueNamesGenerator({\n      dictionaries: [adjectives, nouns]\n    });\n    const workspace: WorkspaceConfiguration = {\n      id: new Date().toISOString(),\n      label: name,\n      config: { datapoints: [], alarmsEventsConfigs: [] }\n    };\n    if (duplicatedConfig) {\n      workspace.config = duplicatedConfig;\n    }\n    this.currentConfiguration = { ...workspace };\n    this.configurations.unshift(workspace);\n    this.initWorkspaceForm();\n    this.workspaceConfigurationService.saveConfigurations(\n      this.configurations,\n      this.currentConfiguration.id\n    );\n    this.onConfigurationChange.emit(this.currentConfiguration.config);\n  }\n\n  changeConfiguration(selected: boolean, configuration: WorkspaceConfiguration): void {\n    if (!selected) {\n      return;\n    }\n    this.currentConfiguration = configuration;\n    localStorage.setItem(\n      this.workspaceConfigurationService.LOCAL_STORAGE_DEFAULT_ID_KEY,\n      this.currentConfiguration.id\n    );\n    this.onConfigurationChange.emit(configuration.config);\n  }\n\n  updateConfigurationLabel(configuration: WorkspaceConfiguration): void {\n    this.configurations = this.configurations.map(c =>\n      c.id === configuration.id ? configuration : c\n    );\n    this.workspaceConfigurationService.saveConfigurations(\n      this.configurations,\n      this.currentConfiguration?.id || ''\n    );\n    this.currentConfiguration = configuration;\n    this.onConfigurationChange.emit(configuration.config);\n  }\n\n  deleteConfiguration(configuration: WorkspaceConfiguration): void {\n    this.configurations = this.configurations.filter(c => c.id !== configuration.id);\n    this.initWorkspaceForm();\n    this.workspaceConfigurationService.saveConfigurations(\n      this.configurations,\n      this.currentConfiguration?.id || ''\n    );\n  }\n\n  clearAll(): void {\n    this.configurations = [this.currentConfiguration];\n    this.initWorkspaceForm();\n    this.workspaceConfigurationService.saveConfigurations(\n      this.configurations,\n      this.currentConfiguration?.id || ''\n    );\n  }\n\n  async shareConfig(configuration: WorkspaceConfiguration): Promise<void> {\n    await this.clipboardService.writeText(JSON.stringify(configuration.config));\n  }\n\n  private addConfigFromUrl(queryParams: any): void {\n    this.addConfig();\n    const config = JSON.parse(queryParams.config);\n    this.onConfigurationChange.emit(config);\n  }\n\n  private updateConfigurations(): void {\n    this.currentConfiguration.config = this.updatedConfig;\n    this.configurations = this.configurations.map(currentConfig =>\n      currentConfig.id === this.currentConfiguration.id ? this.currentConfiguration : currentConfig\n    );\n    const queryParams = {\n      configId: this.currentConfiguration.id,\n      label: this.currentConfiguration.label,\n      config: JSON.stringify(this.updatedConfig)\n    };\n    this.workspaceConfigurationService.saveConfigurations(\n      this.configurations,\n      this.currentConfiguration.id\n    );\n    this.router.navigate([], { queryParams });\n  }\n\n  private initializeConfigurations(): void {\n    const configurations = this.workspaceConfigurationService.getConfigurations();\n    const defaultId = this.workspaceConfigurationService.getDefaultConfigurationId();\n    const queryParams = this.router.parseUrl(this.router.url).queryParams;\n    if (configurations.length) {\n      this.configurations = configurations;\n      this.currentConfiguration =\n        this.configurations.find(c => c.id === defaultId) || this.configurations[0];\n\n      this.onConfigurationChange.emit(this.currentConfiguration.config);\n      if (queryParams?.configId && !this.configurations.find(c => c.id === queryParams.configId)) {\n        this.addConfigFromUrl(queryParams);\n      } else if (\n        queryParams?.configId &&\n        this.configurations.find(c => c.id === queryParams.configId) &&\n        this.currentConfiguration.id !== queryParams.configId\n      ) {\n        this.currentConfiguration = this.configurations.find(c => c.id === queryParams.configId);\n        this.changeConfiguration(true, this.currentConfiguration);\n      }\n    }\n\n    if (!this.currentConfiguration) {\n      if (Object.keys(queryParams).length === 0) {\n        this.addConfig();\n        return;\n      }\n      this.addConfigFromUrl(queryParams);\n    }\n  }\n\n  private initWorkspaceForm(): void {\n    this.configurationsFormGroup = this.formBuilder.group({\n      configurations: this.formBuilder.array([])\n    });\n\n    this.patchForm();\n  }\n\n  private patchForm(): void {\n    const control = <FormArray>this.configurationsFormGroup.controls['configurations'];\n    this.configurations.forEach(workspace => {\n      control.push(this.patchValues(workspace));\n    });\n  }\n\n  private patchValues(workspace: WorkspaceConfiguration): FormGroup {\n    return this.formBuilder.group({\n      label: [workspace.label],\n      config: [workspace.config],\n      id: [workspace.id]\n    });\n  }\n\n  private initializeContextSourceId(): void {\n    const routeContext = this.contextRouteService.getContextData(this.activatedRoute);\n    if (!routeContext) {\n      return;\n    }\n    const { context, contextData } = routeContext;\n    if ([ViewContext.Device, ViewContext.Group].includes(context)) {\n      this.workspaceConfigurationService.contextIdSignal.set(contextData?.id);\n    }\n  }\n}\n","<div\n  class=\"dropdown\"\n  #actionbar_dropdown=\"bs-dropdown\"\n  [cdkTrapFocus]=\"actionbar_dropdown.isOpen\"\n  dropdown\n  [insideClick]=\"true\"\n>\n\n  <button\n    class=\"dropdown-toggle form-control l-h-tight d-flex a-i-center\"\n    attr.aria-label=\"{{ currentConfiguration.label }}\"\n    tooltip=\"{{ 'Selected configuration' | translate }}\"\n    placement=\"top\"\n    container=\"body\"\n    data-cy=\"current-configuration-dropdown-button\"\n    [adaptivePosition]=\"false\"\n    [delay]=\"500\"\n    dropdownToggle\n  >\n    <i\n      class=\"m-r-4\"\n      c8yIcon=\"list\"\n    ></i>\n    <div class=\"d-col text-left fit-w\">\n      <span class=\"text-12\">\n        {{ 'Configuration' | translate }}\n      </span>\n      <span class=\"text-10 text-muted text-truncate\">\n        {{ currentConfiguration.label }}\n      </span>\n    </div>\n    <span class=\"caret m-r-16 m-l-4\"></span>\n  </button>\n  <div\n    class=\"dropdown-menu dropdown-menu-wide dropdown-menu-action-bar\"\n    *dropdownMenu\n  >\n    <div class=\"sticky-top separator-bottom p-t-8 p-b-8 p-l-16 p-r-16\">\n      <p>\n        <strong>{{ 'Data explorer configurations' | translate }}</strong>\n      </p>\n      <p>\n        <small>{{ 'Easily switch and manage configurations.' | translate }}</small>\n      </p>\n    </div>\n    <c8y-list-group class=\"no-border-last\">\n      <form [formGroup]=\"configurationsFormGroup\">\n        <div formArrayName=\"configurations\">\n          <c8y-li\n            class=\"p-0\"\n            *ngFor=\"\n              let configuration of configurationsFormGroup.controls.configurations['controls'];\n              let i = index\n            \"\n            [dense]=\"true\"\n          >\n            <c8y-li-radio\n              [selected]=\"configuration.value.id === currentConfiguration.id\"\n              (onSelect)=\"changeConfiguration($event, configuration.value)\"\n            ></c8y-li-radio>\n            <div class=\"d-flex a-i-center gap-8\">\n              <div\n                class=\"flex-grow min-width-0\"\n                [formGroupName]=\"i\"\n              >\n                <label\n                  class=\"editable\"\n                  [ngClass]=\"{\n                    updated:\n                      configuration.controls.label.touched && configuration.controls.label.dirty\n                  }\"\n                >\n                  <input\n                    class=\"form-control\"\n                    [style.width.ch]=\"configuration.value.label || 25\"\n                    [attr.aria-label]=\"'Configuration label' | translate\"\n                    placeholder=\"{{ 'Configuration 1' | translate }}\"\n                    type=\"text\"\n                    autocomplete=\"off\"\n                    required\n                    formControlName=\"label\"\n                    (blur)=\"updateConfigurationLabel(configuration.value)\"\n                  />\n                </label>\n              </div>\n              <div class=\"flex-nogrow d-flex gap-8\">\n                <button\n                  class=\"btn-dot btn\"\n                  [attr.aria-label]=\"'Duplicate configuration' | translate\"\n                  tooltip=\"{{ 'Duplicate configuration' | translate }}\"\n                  placement=\"left\"\n                  (click)=\"addConfig(configuration.value.config)\"\n                  [delay]=\"500\"\n                >\n                  <i c8yIcon=\"copy\"></i>\n                </button>\n\n                <button\n                  class=\"btn-dot btn btn-dot--danger\"\n                  [attr.aria-label]=\"'Remove configurations' | translate\"\n                  tooltip=\"{{\n                    (configuration.value.id === currentConfiguration.id\n                      ? activeConfigTooltip\n                      : removeConfigTooltip\n                    ) | translate\n                  }}\"\n                  placement=\"left\"\n                  [delay]=\"500\"\n                  (click)=\"$event.stopPropagation(); deleteConfiguration(configuration.value)\"\n                  [disabled]=\"configuration.value.id === currentConfiguration.id\"\n                >\n                  <i c8yIcon=\"minus-circle\"></i>\n                </button>\n              </div>\n            </div>\n          </c8y-li>\n        </div>\n      </form>\n    </c8y-list-group>\n    <div class=\"sticky-bottom separator-top\">\n      <div class=\"d-flex p-l-16 p-r-16 p-t-8 p-b-8\">\n        <button\n          class=\"btn btn-danger btn-sm flex-grow\"\n          (click)=\"clearAll()\"\n          [disabled]=\"configurations.length < 2\"\n        >\n          <i [c8yIcon]=\"'delete'\"></i>\n          {{ 'Delete all configurations' | translate }}\n        </button>\n        <button\n          class=\"btn btn-default btn-sm flex-grow\"\n          type=\"button\"\n          (click)=\"addConfig()\"\n        >\n          <i [c8yIcon]=\"'add-circle-outline'\"></i>\n          {{ 'Add configuration' | translate }}\n        </button>\n      </div>\n    </div>\n  </div>\n</div>\n"]}
174
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"workspace-configuration.component.js","sourceRoot":"","sources":["../../../../../datapoint-explorer/view/configuration/workspace-configuration.component.ts","../../../../../datapoint-explorer/view/configuration/workspace-configuration.component.html"],"names":[],"mappings":"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","sourcesContent":["import { A11yModule } from '@angular/cdk/a11y';\nimport {\n  Component,\n  EventEmitter,\n  inject,\n  Input,\n  OnChanges,\n  OnInit,\n  Output,\n  SimpleChanges\n} from '@angular/core';\nimport { FormArray, FormBuilder, FormGroup, FormsModule } from '@angular/forms';\nimport {\n  ClipboardService,\n  ContextRouteService,\n  CoreModule,\n  gettext,\n  ViewContext\n} from '@c8y/ngx-components';\nimport { BsDropdownModule } from 'ngx-bootstrap/dropdown';\nimport { TooltipModule } from 'ngx-bootstrap/tooltip';\nimport { WorkspaceConfiguration } from './workspace-configuration.model';\nimport { DatapointsGraphWidgetConfig } from '@c8y/ngx-components/echart';\nimport { WorkspaceConfigurationService } from './workspace-configuration.service';\nimport { ActivatedRoute, Router } from '@angular/router';\nimport { uniqueNamesGenerator } from 'unique-names-generator';\nimport { adjectives, nouns } from './naming-dictionary';\n\n@Component({\n  selector: 'c8y-workspace-config',\n  templateUrl: './workspace-configuration.component.html',\n  standalone: true,\n  imports: [CoreModule, BsDropdownModule, FormsModule, A11yModule, TooltipModule]\n})\nexport class WorkspaceConfigComponent implements OnInit, OnChanges {\n  @Input() updatedConfig: DatapointsGraphWidgetConfig;\n  @Output() onConfigurationChange = new EventEmitter<DatapointsGraphWidgetConfig>();\n\n  currentConfiguration: WorkspaceConfiguration;\n  configurations: WorkspaceConfiguration[] = [];\n  configurationsFormGroup: FormGroup;\n  activeConfigTooltip = gettext('Active configuration cannot be removed');\n  removeConfigTooltip = gettext('Remove configuration');\n\n  private readonly formBuilder = inject(FormBuilder);\n  private readonly workspaceConfigurationService = inject(WorkspaceConfigurationService);\n  private readonly contextRouteService = inject(ContextRouteService);\n  private readonly clipboardService = inject(ClipboardService);\n  private readonly activatedRoute = inject(ActivatedRoute);\n  private readonly router = inject(Router);\n\n  ngOnInit(): void {\n    this.initializeContextSourceId();\n    this.initializeConfigurations();\n    this.initWorkspaceForm();\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes.updatedConfig && !changes.updatedConfig.firstChange) {\n      this.updateConfigurations();\n    }\n  }\n\n  addConfig(duplicatedConfig?: DatapointsGraphWidgetConfig): void {\n    const name = uniqueNamesGenerator({ dictionaries: [adjectives, nouns] });\n    const workspace: WorkspaceConfiguration = {\n      id: new Date().toISOString(),\n      label: name,\n      config: { datapoints: [], alarmsEventsConfigs: [] }\n    };\n    if (duplicatedConfig) {\n      workspace.config = duplicatedConfig;\n    }\n    this.configurations = [workspace, ...this.configurations];\n    this.initWorkspaceForm();\n    this.changeConfiguration(true, workspace);\n  }\n\n  changeConfiguration(selected: boolean, configuration: WorkspaceConfiguration): void {\n    if (!selected) {\n      return;\n    }\n    this.currentConfiguration = configuration;\n    localStorage.setItem(\n      this.workspaceConfigurationService.LOCAL_STORAGE_DEFAULT_ID_KEY,\n      this.currentConfiguration.id\n    );\n    this.onConfigurationChange.emit(configuration.config);\n  }\n\n  updateConfigurationLabel(configuration: WorkspaceConfiguration): void {\n    this.configurations = this.configurations.map(c =>\n      c.id === configuration.id ? configuration : c\n    );\n    this.workspaceConfigurationService.saveConfigurations(\n      this.configurations,\n      this.currentConfiguration?.id || ''\n    );\n    this.currentConfiguration = configuration;\n    this.onConfigurationChange.emit(configuration.config);\n  }\n\n  deleteConfiguration(configuration: WorkspaceConfiguration): void {\n    this.configurations = this.configurations.filter(c => c.id !== configuration.id);\n    this.initWorkspaceForm();\n    this.workspaceConfigurationService.saveConfigurations(\n      this.configurations,\n      this.currentConfiguration?.id || ''\n    );\n  }\n\n  clearAll(): void {\n    this.configurations = [this.currentConfiguration];\n    this.initWorkspaceForm();\n    this.workspaceConfigurationService.saveConfigurations(\n      this.configurations,\n      this.currentConfiguration?.id || ''\n    );\n  }\n\n  async shareConfig(configuration: WorkspaceConfiguration): Promise<void> {\n    await this.clipboardService.writeText(JSON.stringify(configuration.config));\n  }\n\n  private addConfigFromUrl(queryParams: any): void {\n    this.addConfig();\n    const config = JSON.parse(queryParams.config);\n    this.onConfigurationChange.emit(config);\n  }\n\n  private updateConfigurations(): void {\n    this.currentConfiguration.config = this.updatedConfig;\n    this.configurations = this.configurations.map(currentConfig =>\n      currentConfig.id === this.currentConfiguration.id ? this.currentConfiguration : currentConfig\n    );\n    const queryParams = {\n      configId: this.currentConfiguration.id,\n      label: this.currentConfiguration.label,\n      config: JSON.stringify(this.updatedConfig)\n    };\n    this.workspaceConfigurationService.saveConfigurations(\n      this.configurations,\n      this.currentConfiguration.id\n    );\n    const control = <FormArray>this.configurationsFormGroup.controls['configurations'];\n    const index = this.configurations.findIndex(c => c.id === this.currentConfiguration.id);\n    if (index !== -1) {\n      control.at(index).patchValue({\n        label: this.currentConfiguration.label,\n        config: this.currentConfiguration.config,\n        id: this.currentConfiguration.id\n      });\n    }\n    this.router.navigate([], { queryParams });\n  }\n\n  private initializeConfigurations(): void {\n    const configurations = this.workspaceConfigurationService.getConfigurations();\n    const defaultId = this.workspaceConfigurationService.getDefaultConfigurationId();\n    const queryParams = this.router.parseUrl(this.router.url).queryParams;\n    if (configurations.length) {\n      this.configurations = configurations;\n      this.currentConfiguration =\n        this.configurations.find(c => c.id === defaultId) || this.configurations[0];\n\n      this.onConfigurationChange.emit(this.currentConfiguration.config);\n      if (queryParams?.configId && !this.configurations.find(c => c.id === queryParams.configId)) {\n        this.addConfigFromUrl(queryParams);\n      } else if (\n        queryParams?.configId &&\n        this.configurations.find(c => c.id === queryParams.configId) &&\n        this.currentConfiguration.id !== queryParams.configId\n      ) {\n        this.currentConfiguration = this.configurations.find(c => c.id === queryParams.configId);\n        this.changeConfiguration(true, this.currentConfiguration);\n      }\n    }\n\n    if (!this.currentConfiguration) {\n      if (Object.keys(queryParams).length === 0) {\n        this.addConfig();\n        return;\n      }\n      this.addConfigFromUrl(queryParams);\n    }\n  }\n\n  private initWorkspaceForm(): void {\n    this.configurationsFormGroup = this.formBuilder.group({\n      configurations: this.formBuilder.array([])\n    });\n\n    this.patchForm();\n  }\n\n  private patchForm(): void {\n    const control = <FormArray>this.configurationsFormGroup.controls['configurations'];\n    this.configurations.forEach(workspace => {\n      control.push(this.patchValues(workspace));\n    });\n  }\n\n  private patchValues(workspace: WorkspaceConfiguration): FormGroup {\n    return this.formBuilder.group({\n      label: [workspace.label],\n      config: [workspace.config],\n      id: [workspace.id]\n    });\n  }\n\n  private initializeContextSourceId(): void {\n    const routeContext = this.contextRouteService.getContextData(this.activatedRoute);\n    if (!routeContext) {\n      return;\n    }\n    const { context, contextData } = routeContext;\n    if ([ViewContext.Device, ViewContext.Group].includes(context)) {\n      this.workspaceConfigurationService.contextIdSignal.set(contextData?.id);\n    }\n  }\n}\n","<div\n  class=\"dropdown\"\n  #actionbar_dropdown=\"bs-dropdown\"\n  [cdkTrapFocus]=\"actionbar_dropdown.isOpen\"\n  dropdown\n  [insideClick]=\"true\"\n>\n\n  <button\n    class=\"dropdown-toggle form-control l-h-tight d-flex a-i-center\"\n    attr.aria-label=\"{{ currentConfiguration.label }}\"\n    tooltip=\"{{ 'Selected configuration' | translate }}\"\n    placement=\"top\"\n    container=\"body\"\n    data-cy=\"current-configuration-dropdown-button\"\n    [adaptivePosition]=\"false\"\n    [delay]=\"500\"\n    dropdownToggle\n  >\n    <i\n      class=\"m-r-4\"\n      c8yIcon=\"list\"\n    ></i>\n    <div class=\"d-col text-left fit-w\">\n      <span class=\"text-12\">\n        {{ 'Configuration' | translate }}\n      </span>\n      <span class=\"text-10 text-muted text-truncate\">\n        {{ currentConfiguration.label }}\n      </span>\n    </div>\n    <span class=\"caret m-r-16 m-l-4\"></span>\n  </button>\n  <div\n    class=\"dropdown-menu dropdown-menu-wide dropdown-menu-action-bar\"\n    *dropdownMenu\n  >\n    <div class=\"sticky-top separator-bottom p-t-8 p-b-8 p-l-16 p-r-16\">\n      <p>\n        <strong>{{ 'Data explorer configurations' | translate }}</strong>\n      </p>\n      <p>\n        <small>{{ 'Easily switch and manage configurations.' | translate }}</small>\n      </p>\n    </div>\n    <c8y-list-group class=\"no-border-last\">\n      <form [formGroup]=\"configurationsFormGroup\">\n        <div formArrayName=\"configurations\">\n          <c8y-li\n            class=\"p-0\"\n            *ngFor=\"\n              let configuration of configurationsFormGroup.controls.configurations['controls'];\n              let i = index\n            \"\n            [dense]=\"true\"\n          >\n            <c8y-li-radio\n              [selected]=\"configuration.value.id === currentConfiguration.id\"\n              (onSelect)=\"changeConfiguration($event, configuration.value)\"\n            ></c8y-li-radio>\n            <div class=\"d-flex a-i-center gap-8\">\n              <div\n                class=\"flex-grow min-width-0\"\n                [formGroupName]=\"i\"\n              >\n                <label\n                  class=\"editable\"\n                  [ngClass]=\"{\n                    updated:\n                      configuration.controls.label.touched && configuration.controls.label.dirty\n                  }\"\n                >\n                  <input\n                    class=\"form-control\"\n                    [style.width.ch]=\"configuration.value.label || 25\"\n                    [attr.aria-label]=\"'Configuration label' | translate\"\n                    placeholder=\"{{ 'Configuration 1' | translate }}\"\n                    type=\"text\"\n                    autocomplete=\"off\"\n                    required\n                    formControlName=\"label\"\n                    (blur)=\"updateConfigurationLabel(configuration.value)\"\n                  />\n                </label>\n              </div>\n              <div class=\"flex-nogrow d-flex gap-8\">\n                <button\n                  class=\"btn-dot btn\"\n                  [attr.aria-label]=\"'Duplicate configuration' | translate\"\n                  tooltip=\"{{ 'Duplicate configuration' | translate }}\"\n                  placement=\"left\"\n                  (click)=\"addConfig(configuration.value.config)\"\n                  [delay]=\"500\"\n                >\n                  <i c8yIcon=\"copy\"></i>\n                </button>\n\n                <button\n                  class=\"btn-dot btn btn-dot--danger\"\n                  [attr.aria-label]=\"'Remove configurations' | translate\"\n                  tooltip=\"{{\n                    (configuration.value.id === currentConfiguration.id\n                      ? activeConfigTooltip\n                      : removeConfigTooltip\n                    ) | translate\n                  }}\"\n                  placement=\"left\"\n                  [delay]=\"500\"\n                  (click)=\"$event.stopPropagation(); deleteConfiguration(configuration.value)\"\n                  [disabled]=\"configuration.value.id === currentConfiguration.id\"\n                >\n                  <i c8yIcon=\"minus-circle\"></i>\n                </button>\n              </div>\n            </div>\n          </c8y-li>\n        </div>\n      </form>\n    </c8y-list-group>\n    <div class=\"sticky-bottom separator-top\">\n      <div class=\"d-flex p-l-16 p-r-16 p-t-8 p-b-8\">\n        <button\n          class=\"btn btn-danger btn-sm flex-grow\"\n          (click)=\"clearAll()\"\n          [disabled]=\"configurations.length < 2\"\n        >\n          <i [c8yIcon]=\"'delete'\"></i>\n          {{ 'Delete all configurations' | translate }}\n        </button>\n        <button\n          class=\"btn btn-default btn-sm flex-grow\"\n          type=\"button\"\n          (click)=\"addConfig()\"\n        >\n          <i [c8yIcon]=\"'add-circle-outline'\"></i>\n          {{ 'Add configuration' | translate }}\n        </button>\n      </div>\n    </div>\n  </div>\n</div>\n"]}