@c8y/ngx-components 1021.55.2 → 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 (58) 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/datapoints-export-selector/datapoints-export-selector-modal/datapoints-export-selector-file-exporter/data-fetching.service.d.ts.map +1 -1
  12. package/datapoints-export-selector/datapoints-export-selector.component.d.ts +3 -1
  13. package/datapoints-export-selector/datapoints-export-selector.component.d.ts.map +1 -1
  14. package/esm2022/core/aggregation/aggregation.model.mjs +2 -2
  15. package/esm2022/core/common/interval-based-reload.abstract.mjs +13 -13
  16. package/esm2022/core/dashboard/dashboard-child.component.mjs +3 -3
  17. package/esm2022/core/dashboard/widget-auto-refresh-context/auto-refresh-control.component.mjs +6 -8
  18. package/esm2022/core/dashboard/widget-auto-refresh-context/widget-auto-refresh-context.component.mjs +9 -1
  19. package/esm2022/core/dashboard/widgets-dashboard-event.service.mjs +19 -2
  20. package/esm2022/core/dashboard/widgets-dashboard.component.mjs +3 -3
  21. package/esm2022/core/dashboard/wiget-time-context/widget-time-context-icon-bar/widget-time-context-icon-bar.component.mjs +3 -3
  22. package/esm2022/core/dashboard/wiget-time-context/widget-time-context.component.mjs +48 -23
  23. package/esm2022/datapoint-explorer/view/datapoint-explorer.component.mjs +2 -2
  24. package/esm2022/datapoints-export-selector/datapoints-export-selector-modal/datapoints-export-selector-file-exporter/data-fetching.service.mjs +1 -3
  25. package/esm2022/datapoints-export-selector/datapoints-export-selector.component.mjs +9 -5
  26. package/esm2022/widgets/definitions/datapoints-table/index.mjs +3 -2
  27. package/esm2022/widgets/implementations/alarms/alarm-list-widget-view/alarm-list-widget.component.mjs +3 -3
  28. package/esm2022/widgets/implementations/alarms/alarm-widget-alarms-reload.component.mjs +17 -100
  29. package/esm2022/widgets/implementations/datapoints-table/datapoints-table-config/datapoints-table-config.component.mjs +47 -34
  30. package/esm2022/widgets/implementations/datapoints-table/datapoints-table-view/datapoints-reload/datapoints-reload.component.mjs +35 -13
  31. package/esm2022/widgets/implementations/datapoints-table/datapoints-table-view/datapoints-table/datapoints-table.component.mjs +3 -3
  32. package/esm2022/widgets/implementations/datapoints-table/datapoints-table-view/datapoints-table-view.component.mjs +75 -35
  33. package/esm2022/widgets/implementations/datapoints-table/datapoints-table-widget.model.mjs +3 -5
  34. package/fesm2022/c8y-ngx-components-datapoint-explorer-view.mjs +1 -1
  35. package/fesm2022/c8y-ngx-components-datapoint-explorer-view.mjs.map +1 -1
  36. package/fesm2022/c8y-ngx-components-datapoints-export-selector.mjs +7 -6
  37. package/fesm2022/c8y-ngx-components-datapoints-export-selector.mjs.map +1 -1
  38. package/fesm2022/c8y-ngx-components-widgets-definitions-datapoints-table.mjs +2 -1
  39. package/fesm2022/c8y-ngx-components-widgets-definitions-datapoints-table.mjs.map +1 -1
  40. package/fesm2022/c8y-ngx-components-widgets-implementations-alarms.mjs +18 -101
  41. package/fesm2022/c8y-ngx-components-widgets-implementations-alarms.mjs.map +1 -1
  42. package/fesm2022/c8y-ngx-components-widgets-implementations-datapoints-table.mjs +147 -76
  43. package/fesm2022/c8y-ngx-components-widgets-implementations-datapoints-table.mjs.map +1 -1
  44. package/fesm2022/c8y-ngx-components.mjs +209 -162
  45. package/fesm2022/c8y-ngx-components.mjs.map +1 -1
  46. package/locales/locales.pot +3 -4
  47. package/package.json +1 -1
  48. package/widgets/definitions/datapoints-table/index.d.ts.map +1 -1
  49. package/widgets/implementations/alarms/alarm-widget-alarms-reload.component.d.ts +18 -63
  50. package/widgets/implementations/alarms/alarm-widget-alarms-reload.component.d.ts.map +1 -1
  51. package/widgets/implementations/datapoints-table/datapoints-table-config/datapoints-table-config.component.d.ts +4 -2
  52. package/widgets/implementations/datapoints-table/datapoints-table-config/datapoints-table-config.component.d.ts.map +1 -1
  53. package/widgets/implementations/datapoints-table/datapoints-table-view/datapoints-reload/datapoints-reload.component.d.ts +16 -8
  54. package/widgets/implementations/datapoints-table/datapoints-table-view/datapoints-reload/datapoints-reload.component.d.ts.map +1 -1
  55. package/widgets/implementations/datapoints-table/datapoints-table-view/datapoints-table-view.component.d.ts +21 -4
  56. package/widgets/implementations/datapoints-table/datapoints-table-view/datapoints-table-view.component.d.ts.map +1 -1
  57. package/widgets/implementations/datapoints-table/datapoints-table-widget.model.d.ts +4 -1
  58. 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"]}