@c8y/ngx-components 1021.22.0 → 1021.25.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/alarms/alarms-date-filter.component.d.ts +22 -10
- package/alarms/alarms-date-filter.component.d.ts.map +1 -1
- package/alarms/alarms-type-filter.component.d.ts +21 -14
- package/alarms/alarms-type-filter.component.d.ts.map +1 -1
- package/alarms/alarms-view.service.d.ts +7 -0
- package/alarms/alarms-view.service.d.ts.map +1 -1
- package/alarms/alarms.model.d.ts +1 -6
- package/alarms/alarms.model.d.ts.map +1 -1
- package/alarms/alarms.module.d.ts +1 -1
- package/alarms/index.d.ts +1 -0
- package/alarms/index.d.ts.map +1 -1
- package/context-dashboard/context-dashboard.service.d.ts.map +1 -1
- package/core/router/scoped-context-route.service.d.ts.map +1 -1
- package/datapoints-export-selector/datapoints-export-selector-modal/datapoints-export-selector-file-exporter/datapoints-export-selector-file-exporter.component.d.ts +4 -2
- package/datapoints-export-selector/datapoints-export-selector-modal/datapoints-export-selector-file-exporter/datapoints-export-selector-file-exporter.component.d.ts.map +1 -1
- package/datapoints-export-selector/datapoints-export-selector.component.d.ts +3 -1
- package/datapoints-export-selector/datapoints-export-selector.component.d.ts.map +1 -1
- package/datapoints-export-selector/datapoints-export-selector.model.d.ts +17 -0
- package/datapoints-export-selector/datapoints-export-selector.model.d.ts.map +1 -1
- package/esm2022/alarms/alarm-info.component.mjs +3 -3
- package/esm2022/alarms/alarm-severity-to-label.pipe.mjs +2 -2
- package/esm2022/alarms/alarms-date-filter.component.mjs +92 -42
- package/esm2022/alarms/alarms-type-filter.component.mjs +102 -72
- package/esm2022/alarms/alarms-view.service.mjs +16 -2
- package/esm2022/alarms/alarms.component.mjs +3 -3
- package/esm2022/alarms/alarms.model.mjs +1 -1
- package/esm2022/alarms/alarms.module.mjs +3 -3
- package/esm2022/alarms/index.mjs +2 -1
- package/esm2022/context-dashboard/context-dashboard.service.mjs +18 -5
- package/esm2022/core/router/scoped-context-route.service.mjs +9 -4
- package/esm2022/core/tabs/tabs-outlet.component.mjs +3 -3
- package/esm2022/datapoints-export-selector/datapoints-export-selector-modal/datapoints-export-selector-file-exporter/datapoints-export-selector-file-exporter.component.mjs +29 -6
- package/esm2022/datapoints-export-selector/datapoints-export-selector.component.mjs +11 -5
- package/esm2022/datapoints-export-selector/datapoints-export-selector.model.mjs +18 -1
- package/esm2022/interval-picker/interval-picker.component.mjs +1 -1
- package/esm2022/interval-picker/interval-picker.model.mjs +1 -1
- package/esm2022/widgets/definitions/alarms/alarm-list/index.mjs +2 -1
- package/esm2022/widgets/implementations/alarms/alarm-list-widget-config/alarm-list-widget-config.component.mjs +73 -4
- package/esm2022/widgets/implementations/alarms/alarm-list-widget-view/alarm-list-widget.component.mjs +29 -5
- package/esm2022/widgets/implementations/alarms/alarm-list-widget.model.mjs +7 -1
- package/esm2022/widgets/implementations/alarms/alarm-widget.service.mjs +11 -1
- package/fesm2022/c8y-ngx-components-alarms.mjs +199 -107
- package/fesm2022/c8y-ngx-components-alarms.mjs.map +1 -1
- package/fesm2022/c8y-ngx-components-context-dashboard.mjs +17 -4
- package/fesm2022/c8y-ngx-components-context-dashboard.mjs.map +1 -1
- package/fesm2022/c8y-ngx-components-datapoints-export-selector.mjs +52 -7
- package/fesm2022/c8y-ngx-components-datapoints-export-selector.mjs.map +1 -1
- package/fesm2022/c8y-ngx-components-interval-picker.mjs.map +1 -1
- package/fesm2022/c8y-ngx-components-widgets-definitions-alarms-alarm-list.mjs +1 -0
- package/fesm2022/c8y-ngx-components-widgets-definitions-alarms-alarm-list.mjs.map +1 -1
- package/fesm2022/c8y-ngx-components-widgets-implementations-alarms.mjs +123 -14
- package/fesm2022/c8y-ngx-components-widgets-implementations-alarms.mjs.map +1 -1
- package/fesm2022/c8y-ngx-components.mjs +10 -5
- package/fesm2022/c8y-ngx-components.mjs.map +1 -1
- package/interval-picker/interval-picker.component.d.ts +2 -2
- package/interval-picker/interval-picker.component.d.ts.map +1 -1
- package/interval-picker/interval-picker.model.d.ts +5 -0
- package/interval-picker/interval-picker.model.d.ts.map +1 -1
- package/locales/de.po +2 -2
- package/locales/locales.pot +18 -6
- package/package.json +1 -1
- package/widgets/definitions/alarms/alarm-list/index.d.ts.map +1 -1
- package/widgets/implementations/alarms/alarm-list-widget-config/alarm-list-widget-config.component.d.ts +12 -1
- package/widgets/implementations/alarms/alarm-list-widget-config/alarm-list-widget-config.component.d.ts.map +1 -1
- package/widgets/implementations/alarms/alarm-list-widget-view/alarm-list-widget.component.d.ts +12 -1
- package/widgets/implementations/alarms/alarm-list-widget-view/alarm-list-widget.component.d.ts.map +1 -1
- package/widgets/implementations/alarms/alarm-list-widget.model.d.ts +11 -1
- package/widgets/implementations/alarms/alarm-list-widget.model.d.ts.map +1 -1
- package/widgets/implementations/alarms/alarm-widget.service.d.ts.map +1 -1
|
@@ -1,30 +1,36 @@
|
|
|
1
|
-
import { Component, EventEmitter, Output, ViewChild } from '@angular/core';
|
|
2
|
-
import { FormBuilder } from '@angular/forms';
|
|
1
|
+
import { Component, EventEmitter, forwardRef, Input, Output, ViewChild } from '@angular/core';
|
|
2
|
+
import { FormBuilder, NG_VALUE_ACCESSOR } from '@angular/forms';
|
|
3
3
|
import { ActivatedRoute, Router } from '@angular/router';
|
|
4
4
|
import { Severity } from '@c8y/client';
|
|
5
|
-
import { Subject, takeUntil } from 'rxjs';
|
|
5
|
+
import { Subject, take, takeUntil } from 'rxjs';
|
|
6
6
|
import { INTERVAL_TITLES_EXTENDED, INTERVALS_EXTENDED } from './alarms.model';
|
|
7
7
|
import { BsDropdownDirective } from 'ngx-bootstrap/dropdown';
|
|
8
|
+
import { AlarmsViewService } from './alarms-view.service';
|
|
8
9
|
import * as i0 from "@angular/core";
|
|
9
10
|
import * as i1 from "@angular/forms";
|
|
10
11
|
import * as i2 from "@angular/router";
|
|
11
|
-
import * as i3 from "
|
|
12
|
-
import * as i4 from "
|
|
13
|
-
import * as i5 from "@
|
|
14
|
-
import * as i6 from "
|
|
15
|
-
import * as i7 from "
|
|
16
|
-
import * as i8 from "@
|
|
12
|
+
import * as i3 from "./alarms-view.service";
|
|
13
|
+
import * as i4 from "ngx-bootstrap/dropdown";
|
|
14
|
+
import * as i5 from "@c8y/ngx-components";
|
|
15
|
+
import * as i6 from "@angular/common";
|
|
16
|
+
import * as i7 from "ngx-bootstrap/tooltip";
|
|
17
|
+
import * as i8 from "@ngx-translate/core";
|
|
18
|
+
import * as i9 from "@c8y/ngx-components/interval-picker";
|
|
17
19
|
export class AlarmsDateFilterComponent {
|
|
18
|
-
constructor(formBuilder, router, activatedRoute) {
|
|
20
|
+
constructor(formBuilder, router, activatedRoute, alarmsViewService) {
|
|
19
21
|
this.formBuilder = formBuilder;
|
|
20
22
|
this.router = router;
|
|
21
23
|
this.activatedRoute = activatedRoute;
|
|
22
|
-
this.
|
|
24
|
+
this.alarmsViewService = alarmsViewService;
|
|
23
25
|
this.INTERVALS = INTERVALS_EXTENDED;
|
|
24
26
|
this.INTERVAL_TITLES = INTERVAL_TITLES_EXTENDED;
|
|
25
27
|
this.DATE_FORMAT = 'short';
|
|
28
|
+
this.DEFAULT_INTERVAL = 'none';
|
|
29
|
+
this.updateQueryParams = true;
|
|
26
30
|
this.destroy$ = new Subject();
|
|
27
31
|
this.dateFilterChange = new EventEmitter();
|
|
32
|
+
// eslint-disable-next-line @typescript-eslint/no-empty-function
|
|
33
|
+
this.onTouched = () => { };
|
|
28
34
|
}
|
|
29
35
|
ngOnInit() {
|
|
30
36
|
const context = this.getDefaultContext();
|
|
@@ -33,7 +39,7 @@ export class AlarmsDateFilterComponent {
|
|
|
33
39
|
this.form.value.currentDateContextFromDate,
|
|
34
40
|
this.form.value.currentDateContextToDate
|
|
35
41
|
];
|
|
36
|
-
this.activatedRoute.queryParams.pipe(takeUntil(this.destroy$)).subscribe(params => {
|
|
42
|
+
this.activatedRoute.queryParams.pipe(take(1), takeUntil(this.destroy$)).subscribe(params => {
|
|
37
43
|
this.showCleared = params.showCleared === 'true';
|
|
38
44
|
this.severityOptions = {
|
|
39
45
|
[Severity.CRITICAL]: params.critical === 'true',
|
|
@@ -44,6 +50,20 @@ export class AlarmsDateFilterComponent {
|
|
|
44
50
|
if (params.typeFilters) {
|
|
45
51
|
this.typeFilters = params.typeFilters;
|
|
46
52
|
}
|
|
53
|
+
if (!params.interval) {
|
|
54
|
+
return;
|
|
55
|
+
}
|
|
56
|
+
if (params.interval !== 'custom') {
|
|
57
|
+
this.updateDateTime(params.interval);
|
|
58
|
+
}
|
|
59
|
+
else {
|
|
60
|
+
this.form.patchValue({
|
|
61
|
+
currentDateContextInterval: params.interval,
|
|
62
|
+
temporaryUserSelectedFromDate: params.lastUpdatedFrom,
|
|
63
|
+
temporaryUserSelectedToDate: params.createdTo
|
|
64
|
+
});
|
|
65
|
+
this.date = [params.lastUpdatedFrom, params.createdTo];
|
|
66
|
+
}
|
|
47
67
|
});
|
|
48
68
|
this.subscribeToIntervalChange();
|
|
49
69
|
}
|
|
@@ -56,6 +76,7 @@ export class AlarmsDateFilterComponent {
|
|
|
56
76
|
showCleared: this.showCleared,
|
|
57
77
|
severityOptions: this.severityOptions,
|
|
58
78
|
typeFilters: this.typeFilters,
|
|
79
|
+
interval: this.form.value.currentDateContextInterval,
|
|
59
80
|
selectedDates: [
|
|
60
81
|
new Date(this.form.value.temporaryUserSelectedFromDate),
|
|
61
82
|
new Date(this.form.value.temporaryUserSelectedToDate)
|
|
@@ -69,50 +90,61 @@ export class AlarmsDateFilterComponent {
|
|
|
69
90
|
this.router.navigate([], {
|
|
70
91
|
relativeTo: this.activatedRoute,
|
|
71
92
|
queryParams: {
|
|
72
|
-
|
|
73
|
-
...combinedFormEvent.severityOptions,
|
|
74
|
-
typeFilters: this.typeFilters,
|
|
93
|
+
interval: this.form.value.currentDateContextInterval,
|
|
75
94
|
lastUpdatedFrom: combinedFormEvent.selectedDates[0].toISOString(),
|
|
76
95
|
createdTo: combinedFormEvent.selectedDates[1].toISOString()
|
|
77
|
-
}
|
|
96
|
+
},
|
|
97
|
+
queryParamsHandling: 'merge'
|
|
78
98
|
});
|
|
79
99
|
this.dateFilterChange.emit(combinedFormEvent);
|
|
80
100
|
}
|
|
101
|
+
writeValue(value) {
|
|
102
|
+
if (value) {
|
|
103
|
+
this.form.patchValue({
|
|
104
|
+
currentDateContextFromDate: typeof value[0] === 'string' ? value[0] : value[0].toISOString(),
|
|
105
|
+
currentDateContextToDate: typeof value[1] === 'string' ? value[1] : value[1].toISOString()
|
|
106
|
+
});
|
|
107
|
+
}
|
|
108
|
+
}
|
|
109
|
+
registerOnChange(fn) {
|
|
110
|
+
this.onChange = fn;
|
|
111
|
+
}
|
|
112
|
+
registerOnTouched(onTouched) {
|
|
113
|
+
this.onTouched = onTouched;
|
|
114
|
+
}
|
|
115
|
+
updateDateTime(interval) {
|
|
116
|
+
const date = this.alarmsViewService.getDateTimeContextByInterval(interval);
|
|
117
|
+
if (this.dropdown) {
|
|
118
|
+
this.dropdown.isOpen = false;
|
|
119
|
+
}
|
|
120
|
+
this.date = date.map(d => d.toISOString());
|
|
121
|
+
this.form.patchValue({
|
|
122
|
+
temporaryUserSelectedFromDate: date[0].toISOString(),
|
|
123
|
+
temporaryUserSelectedToDate: date[1].toISOString(),
|
|
124
|
+
currentDateContextInterval: interval
|
|
125
|
+
}, { emitEvent: false });
|
|
126
|
+
this.applyDateFilter();
|
|
127
|
+
}
|
|
81
128
|
getDefaultContext() {
|
|
82
|
-
const defaultStartDate = 'months';
|
|
83
129
|
return {
|
|
84
|
-
date: this.getDateTimeContextByInterval(
|
|
130
|
+
date: this.alarmsViewService.getDateTimeContextByInterval(this.DEFAULT_INTERVAL),
|
|
85
131
|
interval: this.DEFAULT_INTERVAL
|
|
86
132
|
};
|
|
87
133
|
}
|
|
88
|
-
getDateTimeContextByInterval(intervalId) {
|
|
89
|
-
const interval = INTERVALS_EXTENDED.find(({ id }) => id === intervalId);
|
|
90
|
-
if (interval.id === 'none') {
|
|
91
|
-
return [new Date(0), new Date()];
|
|
92
|
-
}
|
|
93
|
-
const dateTo = new Date();
|
|
94
|
-
const dateFrom = new Date(dateTo.valueOf() - interval.timespanInMs);
|
|
95
|
-
return [dateFrom, dateTo];
|
|
96
|
-
}
|
|
97
134
|
subscribeToIntervalChange() {
|
|
98
135
|
this.form.controls.currentDateContextInterval.valueChanges
|
|
99
136
|
.pipe(takeUntil(this.destroy$))
|
|
100
137
|
.subscribe(interval => {
|
|
101
138
|
if (interval === 'custom') {
|
|
102
139
|
this.form.patchValue({
|
|
103
|
-
temporaryUserSelectedFromDate: this.form.controls.
|
|
140
|
+
temporaryUserSelectedFromDate: this.form.controls.temporaryUserSelectedFromDate.value === new Date(0).toISOString()
|
|
141
|
+
? this.form.controls.currentDateContextToDate.value
|
|
142
|
+
: this.form.controls.temporaryUserSelectedFromDate.value,
|
|
143
|
+
currentDateContextInterval: interval
|
|
104
144
|
}, { emitEvent: false });
|
|
105
145
|
return;
|
|
106
146
|
}
|
|
107
|
-
|
|
108
|
-
this.dropdown.isOpen = false;
|
|
109
|
-
this.date = date.map(d => d.toISOString());
|
|
110
|
-
this.form.patchValue({
|
|
111
|
-
temporaryUserSelectedFromDate: date[0].toISOString(),
|
|
112
|
-
temporaryUserSelectedToDate: date[1].toISOString(),
|
|
113
|
-
currentDateContextInterval: interval
|
|
114
|
-
}, { emitEvent: false });
|
|
115
|
-
this.applyDateFilter();
|
|
147
|
+
this.updateDateTime(interval);
|
|
116
148
|
});
|
|
117
149
|
}
|
|
118
150
|
createForm(context) {
|
|
@@ -124,16 +156,34 @@ export class AlarmsDateFilterComponent {
|
|
|
124
156
|
currentDateContextInterval: context.interval || 'custom'
|
|
125
157
|
});
|
|
126
158
|
}
|
|
127
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: AlarmsDateFilterComponent, deps: [{ token: i1.FormBuilder }, { token: i2.Router }, { token: i2.ActivatedRoute }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
128
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.9", type: AlarmsDateFilterComponent, selector: "c8y-alarms-date-filter",
|
|
159
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: AlarmsDateFilterComponent, deps: [{ token: i1.FormBuilder }, { token: i2.Router }, { token: i2.ActivatedRoute }, { token: i3.AlarmsViewService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
160
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.9", type: AlarmsDateFilterComponent, selector: "c8y-alarms-date-filter", inputs: { DEFAULT_INTERVAL: "DEFAULT_INTERVAL", updateQueryParams: "updateQueryParams", date: "date" }, outputs: { dateFilterChange: "dateFilterChange" }, providers: [
|
|
161
|
+
{
|
|
162
|
+
provide: NG_VALUE_ACCESSOR,
|
|
163
|
+
useExisting: forwardRef(() => AlarmsDateFilterComponent),
|
|
164
|
+
multi: true
|
|
165
|
+
}
|
|
166
|
+
], viewQueries: [{ propertyName: "dropdown", first: true, predicate: BsDropdownDirective, descendants: true }], ngImport: i0, template: "<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 <div\n class=\"dropdown flex-grow\"\n c8yDropdownDirection\n #dropDirection=\"bs-dropdown\"\n dropdown\n [insideClick]=\"true\"\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 }} \u2014 {{ date[1] | c8yDate: DATE_FORMAT }}\"\n tooltip=\"{{\n form.value.currentDateContextInterval === 'none'\n ? 'No date filter'\n : (date[0] | c8yDate: DATE_FORMAT) + ' \u2014 ' + (date[1] | c8yDate: DATE_FORMAT)\n }}\"\n placement=\"top\"\n container=\"body\"\n data-cy=\"alarms-date-filter--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=\"alarms-date-filter--selected-time-range\"\n *ngIf=\"form.controls.currentDateContextInterval.value !== 'none'\"\n >\n {{ date[0] | c8yDate: DATE_FORMAT }} \u2014 {{ 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 [INTERVALS]=\"INTERVALS\"\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 class=\"m-b-8\"\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]=\"form.controls.temporaryUserSelectedFromDate.errors ? 'has-error' : ''\"\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 class=\"m-b-8\"\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-primary btn-sm flex-grow\"\n title=\"{{ 'Apply' | translate }}\"\n type=\"button\"\n (click)=\"applyDateFilter(); dropdown.isOpen = false\"\n [disabled]=\"(form.pristine && form.untouched) || form.invalid\"\n translate\n >\n Apply\n </button>\n </div>\n </ng-container>\n </ul>\n </div>\n</form>\n", dependencies: [{ kind: "directive", type: i4.BsDropdownMenuDirective, selector: "[bsDropdownMenu],[dropdownMenu]", exportAs: ["bs-dropdown-menu"] }, { kind: "directive", type: i4.BsDropdownToggleDirective, selector: "[bsDropdownToggle],[dropdownToggle]", exportAs: ["bs-dropdown-toggle"] }, { kind: "directive", type: i4.BsDropdownDirective, selector: "[bsDropdown], [dropdown]", inputs: ["placement", "triggers", "container", "dropup", "autoClose", "isAnimated", "insideClick", "isDisabled", "isOpen"], outputs: ["isOpenChange", "onShown", "onHidden"], exportAs: ["bs-dropdown"] }, { kind: "directive", type: i5.IconDirective, selector: "[c8yIcon]", inputs: ["c8yIcon"] }, { kind: "directive", type: i5.C8yTranslateDirective, selector: "[translate],[ngx-translate]" }, { kind: "directive", type: i6.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i5.DropdownDirectionDirective, selector: "[dropdown][c8yBsDropdownDirection],[dropdown][c8yDropdownDirection]" }, { kind: "directive", type: i1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "component", type: i5.FormGroupComponent, selector: "c8y-form-group", inputs: ["hasError", "hasWarning", "hasSuccess", "novalidation", "status"] }, { kind: "directive", type: i5.MessageDirective, selector: "c8y-message", inputs: ["name", "text"] }, { kind: "component", type: i5.MessagesComponent, selector: "c8y-messages", inputs: ["show", "defaults", "helpMessage"] }, { kind: "directive", type: i1.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "directive", type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i1.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "component", type: i5.DateTimePickerComponent, selector: "c8y-date-time-picker", inputs: ["minDate", "maxDate", "placeholder", "dateInputFormat", "adaptivePosition", "size", "dateType", "config"], outputs: ["onDateSelected"] }, { kind: "directive", type: i7.TooltipDirective, selector: "[tooltip], [tooltipHtml]", inputs: ["adaptivePosition", "tooltip", "placement", "triggers", "container", "containerClass", "boundariesElement", "isOpen", "isDisabled", "delay", "tooltipHtml", "tooltipPlacement", "tooltipIsOpen", "tooltipEnable", "tooltipAppendToBody", "tooltipAnimation", "tooltipClass", "tooltipContext", "tooltipPopupDelay", "tooltipFadeDuration", "tooltipTrigger"], outputs: ["tooltipChange", "onShown", "onHidden", "tooltipStateChanged"], exportAs: ["bs-tooltip"] }, { kind: "directive", type: i8.TranslateDirective, selector: "[translate],[ngx-translate]", inputs: ["translate", "translateParams"] }, { kind: "component", type: i9.IntervalPickerComponent, selector: "c8y-interval-picker", inputs: ["INTERVALS"] }, { kind: "pipe", type: i5.DatePipe, name: "c8yDate" }, { kind: "pipe", type: i8.TranslatePipe, name: "translate" }] }); }
|
|
129
167
|
}
|
|
130
168
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: AlarmsDateFilterComponent, decorators: [{
|
|
131
169
|
type: Component,
|
|
132
|
-
args: [{ selector: 'c8y-alarms-date-filter',
|
|
133
|
-
|
|
170
|
+
args: [{ selector: 'c8y-alarms-date-filter', providers: [
|
|
171
|
+
{
|
|
172
|
+
provide: NG_VALUE_ACCESSOR,
|
|
173
|
+
useExisting: forwardRef(() => AlarmsDateFilterComponent),
|
|
174
|
+
multi: true
|
|
175
|
+
}
|
|
176
|
+
], template: "<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 <div\n class=\"dropdown flex-grow\"\n c8yDropdownDirection\n #dropDirection=\"bs-dropdown\"\n dropdown\n [insideClick]=\"true\"\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 }} \u2014 {{ date[1] | c8yDate: DATE_FORMAT }}\"\n tooltip=\"{{\n form.value.currentDateContextInterval === 'none'\n ? 'No date filter'\n : (date[0] | c8yDate: DATE_FORMAT) + ' \u2014 ' + (date[1] | c8yDate: DATE_FORMAT)\n }}\"\n placement=\"top\"\n container=\"body\"\n data-cy=\"alarms-date-filter--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=\"alarms-date-filter--selected-time-range\"\n *ngIf=\"form.controls.currentDateContextInterval.value !== 'none'\"\n >\n {{ date[0] | c8yDate: DATE_FORMAT }} \u2014 {{ 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 [INTERVALS]=\"INTERVALS\"\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 class=\"m-b-8\"\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]=\"form.controls.temporaryUserSelectedFromDate.errors ? 'has-error' : ''\"\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 class=\"m-b-8\"\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-primary btn-sm flex-grow\"\n title=\"{{ 'Apply' | translate }}\"\n type=\"button\"\n (click)=\"applyDateFilter(); dropdown.isOpen = false\"\n [disabled]=\"(form.pristine && form.untouched) || form.invalid\"\n translate\n >\n Apply\n </button>\n </div>\n </ng-container>\n </ul>\n </div>\n</form>\n" }]
|
|
177
|
+
}], ctorParameters: () => [{ type: i1.FormBuilder }, { type: i2.Router }, { type: i2.ActivatedRoute }, { type: i3.AlarmsViewService }], propDecorators: { DEFAULT_INTERVAL: [{
|
|
178
|
+
type: Input
|
|
179
|
+
}], updateQueryParams: [{
|
|
180
|
+
type: Input
|
|
181
|
+
}], date: [{
|
|
182
|
+
type: Input
|
|
183
|
+
}], dateFilterChange: [{
|
|
134
184
|
type: Output
|
|
135
185
|
}], dropdown: [{
|
|
136
186
|
type: ViewChild,
|
|
137
187
|
args: [BsDropdownDirective]
|
|
138
188
|
}] } });
|
|
139
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"alarms-date-filter.component.js","sourceRoot":"","sources":["../../../alarms/alarms-date-filter.component.ts","../../../alarms/alarms-date-filter.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, OnDestroy, Output, ViewChild } from '@angular/core';\nimport { FormBuilder } from '@angular/forms';\nimport { ActivatedRoute, Router } from '@angular/router';\nimport { Severity, SeverityType } from '@c8y/client';\nimport { DateTimeContext } from '@c8y/ngx-components';\nimport { Subject, takeUntil } from 'rxjs';\nimport {\n  AlarmListFormFilters,\n  AlarmFilterInterval,\n  INTERVAL_TITLES_EXTENDED,\n  INTERVALS_EXTENDED,\n  WidgetTimeContextStateExtended\n} from './alarms.model';\nimport { BsDropdownDirective } from 'ngx-bootstrap/dropdown';\n\n@Component({\n  selector: 'c8y-alarms-date-filter',\n  templateUrl: './alarms-date-filter.component.html'\n})\nexport class AlarmsDateFilterComponent implements OnDestroy {\n  readonly DEFAULT_INTERVAL: AlarmFilterInterval['id'] = 'none';\n  readonly INTERVALS = INTERVALS_EXTENDED;\n  readonly INTERVAL_TITLES = INTERVAL_TITLES_EXTENDED;\n  readonly DATE_FORMAT = 'short';\n  private destroy$: Subject<void> = new Subject<void>();\n  private showCleared: boolean;\n  private severityOptions: { [key in SeverityType]: boolean };\n  private typeFilters: string;\n\n  @Output() dateFilterChange = new EventEmitter<AlarmListFormFilters>();\n  @ViewChild(BsDropdownDirective) dropdown: BsDropdownDirective;\n\n  form: ReturnType<AlarmsDateFilterComponent['createForm']>;\n  date: [string, string];\n\n  constructor(\n    private formBuilder: FormBuilder,\n    private router: Router,\n    private activatedRoute: ActivatedRoute\n  ) {}\n\n  ngOnInit() {\n    const context = this.getDefaultContext();\n    this.form = this.createForm(context);\n    this.date = [\n      this.form.value.currentDateContextFromDate,\n      this.form.value.currentDateContextToDate\n    ];\n    this.activatedRoute.queryParams.pipe(takeUntil(this.destroy$)).subscribe(params => {\n      this.showCleared = params.showCleared === 'true';\n      this.severityOptions = {\n        [Severity.CRITICAL]: params.critical === 'true',\n        [Severity.MAJOR]: params.major === 'true',\n        [Severity.MINOR]: params.minor === 'true',\n        [Severity.WARNING]: params.warning === 'true'\n      };\n      if (params.typeFilters) {\n        this.typeFilters = params.typeFilters;\n      }\n    });\n\n    this.subscribeToIntervalChange();\n  }\n\n  ngOnDestroy(): void {\n    this.destroy$.next();\n    this.destroy$.complete();\n  }\n\n  applyDateFilter(): void {\n    const combinedFormEvent = {\n      showCleared: this.showCleared,\n      severityOptions: this.severityOptions,\n      typeFilters: this.typeFilters,\n      selectedDates: [\n        new Date(this.form.value.temporaryUserSelectedFromDate),\n        new Date(this.form.value.temporaryUserSelectedToDate)\n      ] as DateTimeContext\n    };\n\n    // needed for custom interval\n    this.date = [\n      this.form.value.temporaryUserSelectedFromDate,\n      this.form.value.temporaryUserSelectedToDate\n    ];\n\n    this.router.navigate([], {\n      relativeTo: this.activatedRoute,\n      queryParams: {\n        showCleared: combinedFormEvent.showCleared,\n        ...combinedFormEvent.severityOptions,\n        typeFilters: this.typeFilters,\n        lastUpdatedFrom: combinedFormEvent.selectedDates[0].toISOString(),\n        createdTo: combinedFormEvent.selectedDates[1].toISOString()\n      }\n    });\n    this.dateFilterChange.emit(combinedFormEvent);\n  }\n\n  private getDefaultContext() {\n    const defaultStartDate: AlarmFilterInterval['id'] = 'months';\n    return {\n      date: this.getDateTimeContextByInterval(defaultStartDate),\n      interval: this.DEFAULT_INTERVAL\n    };\n  }\n\n  private getDateTimeContextByInterval(intervalId: AlarmFilterInterval['id']): DateTimeContext {\n    const interval = INTERVALS_EXTENDED.find(({ id }) => id === intervalId);\n    if (interval.id === 'none') {\n      return [new Date(0), new Date()];\n    }\n\n    const dateTo = new Date();\n    const dateFrom = new Date(dateTo.valueOf() - interval.timespanInMs);\n    return [dateFrom, dateTo];\n  }\n\n  private subscribeToIntervalChange(): void {\n    this.form.controls.currentDateContextInterval.valueChanges\n      .pipe(takeUntil(this.destroy$))\n      .subscribe(interval => {\n        if (interval === 'custom') {\n          this.form.patchValue(\n            {\n              temporaryUserSelectedFromDate: this.form.controls.currentDateContextFromDate.value\n            },\n            { emitEvent: false }\n          );\n          return;\n        }\n        const date = this.getDateTimeContextByInterval(interval);\n        this.dropdown.isOpen = false;\n        this.date = date.map(d => d.toISOString()) as [string, string];\n        this.form.patchValue(\n          {\n            temporaryUserSelectedFromDate: date[0].toISOString(),\n            temporaryUserSelectedToDate: date[1].toISOString(),\n            currentDateContextInterval: interval\n          },\n          { emitEvent: false }\n        );\n        this.applyDateFilter();\n      });\n  }\n\n  private createForm(context: WidgetTimeContextStateExtended) {\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    });\n  }\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  <div>\n    <div\n      class=\"dropdown flex-grow\"\n      #dropdown=\"bs-dropdown\"\n      dropdown\n      [insideClick]=\"true\"\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=\"{{\n          form.value.currentDateContextInterval === 'none'\n            ? 'No date filter'\n            : (date[0] | c8yDate: DATE_FORMAT) + ' — ' + (date[1] | c8yDate: DATE_FORMAT)\n        }}\"\n        placement=\"top\"\n        container=\"body\"\n        data-cy=\"alarms-date-filter--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 class=\"text-12 text-truncate\">\n            {{ INTERVAL_TITLES[form.controls.currentDateContextInterval.value] | translate }}\n          </span>\n          <span\n            class=\"text-10 text-muted text-truncate\"\n            data-cy=\"alarms-date-filter--selected-time-range\"\n            *ngIf=\"form.controls.currentDateContextInterval.value !== 'none'\"\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          [INTERVALS]=\"INTERVALS\"\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 class=\"m-b-8\"\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]=\"form.controls.temporaryUserSelectedFromDate.errors ? 'has-error' : ''\"\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 class=\"m-b-8\"\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-primary btn-sm flex-grow\"\n              title=\"{{ 'Apply' | translate }}\"\n              type=\"button\"\n              (click)=\"applyDateFilter(); dropdown.isOpen = false\"\n              [disabled]=\"(form.pristine && form.untouched) || form.invalid || form.value.realtime\"\n              translate\n            >\n              Apply\n            </button>\n          </div>\n        </ng-container>\n      </ul>\n    </div>\n  </div>\n</form>\n"]}
|
|
189
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"alarms-date-filter.component.js","sourceRoot":"","sources":["../../../alarms/alarms-date-filter.component.ts","../../../alarms/alarms-date-filter.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  EventEmitter,\n  forwardRef,\n  Input,\n  OnDestroy,\n  Output,\n  ViewChild\n} from '@angular/core';\nimport { ControlValueAccessor, FormBuilder, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { ActivatedRoute, Router } from '@angular/router';\nimport { Severity, SeverityType } from '@c8y/client';\nimport { DateTimeContext } from '@c8y/ngx-components';\nimport { Subject, take, takeUntil } from 'rxjs';\nimport {\n  AlarmListFormFilters,\n  INTERVAL_TITLES_EXTENDED,\n  INTERVALS_EXTENDED,\n  WidgetTimeContextStateExtended\n} from './alarms.model';\nimport { BsDropdownDirective } from 'ngx-bootstrap/dropdown';\nimport { AlarmsViewService } from './alarms-view.service';\nimport { AlarmFilterInterval } from '@c8y/ngx-components/interval-picker';\n\n@Component({\n  selector: 'c8y-alarms-date-filter',\n  templateUrl: './alarms-date-filter.component.html',\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => AlarmsDateFilterComponent),\n      multi: true\n    }\n  ]\n})\nexport class AlarmsDateFilterComponent implements OnDestroy, ControlValueAccessor {\n  readonly INTERVALS = INTERVALS_EXTENDED;\n  readonly INTERVAL_TITLES = INTERVAL_TITLES_EXTENDED;\n  readonly DATE_FORMAT = 'short';\n\n  @Input() DEFAULT_INTERVAL: AlarmFilterInterval['id'] = 'none';\n  @Input() updateQueryParams = true;\n  /**\n   * Date range to be displayed in the date picker.\n   */\n  @Input() date: [string, string];\n  private showCleared: boolean;\n  private severityOptions: { [key in SeverityType]: boolean };\n  private typeFilters: string;\n  private destroy$: Subject<void> = new Subject<void>();\n\n  @Output() dateFilterChange = new EventEmitter<AlarmListFormFilters>();\n  @ViewChild(BsDropdownDirective) dropdown: BsDropdownDirective;\n\n  form: ReturnType<AlarmsDateFilterComponent['createForm']>;\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  onChange: (value: any) => void;\n\n  constructor(\n    private formBuilder: FormBuilder,\n    private router: Router,\n    private activatedRoute: ActivatedRoute,\n    private alarmsViewService: AlarmsViewService\n  ) {}\n\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  onTouched = () => {};\n\n  ngOnInit() {\n    const context = this.getDefaultContext();\n    this.form = this.createForm(context);\n    this.date = [\n      this.form.value.currentDateContextFromDate,\n      this.form.value.currentDateContextToDate\n    ];\n    this.activatedRoute.queryParams.pipe(take(1), takeUntil(this.destroy$)).subscribe(params => {\n      this.showCleared = params.showCleared === 'true';\n      this.severityOptions = {\n        [Severity.CRITICAL]: params.critical === 'true',\n        [Severity.MAJOR]: params.major === 'true',\n        [Severity.MINOR]: params.minor === 'true',\n        [Severity.WARNING]: params.warning === 'true'\n      };\n      if (params.typeFilters) {\n        this.typeFilters = params.typeFilters;\n      }\n      if (!params.interval) {\n        return;\n      }\n      if (params.interval !== 'custom') {\n        this.updateDateTime(params.interval);\n      } else {\n        this.form.patchValue({\n          currentDateContextInterval: params.interval,\n          temporaryUserSelectedFromDate: params.lastUpdatedFrom,\n          temporaryUserSelectedToDate: params.createdTo\n        });\n        this.date = [params.lastUpdatedFrom, params.createdTo];\n      }\n    });\n\n    this.subscribeToIntervalChange();\n  }\n\n  ngOnDestroy(): void {\n    this.destroy$.next();\n    this.destroy$.complete();\n  }\n\n  applyDateFilter(): void {\n    const combinedFormEvent = {\n      showCleared: this.showCleared,\n      severityOptions: this.severityOptions,\n      typeFilters: this.typeFilters,\n      interval: this.form.value.currentDateContextInterval,\n      selectedDates: [\n        new Date(this.form.value.temporaryUserSelectedFromDate),\n        new Date(this.form.value.temporaryUserSelectedToDate)\n      ] as DateTimeContext\n    };\n\n    // needed for custom interval\n    this.date = [\n      this.form.value.temporaryUserSelectedFromDate,\n      this.form.value.temporaryUserSelectedToDate\n    ];\n\n    this.router.navigate([], {\n      relativeTo: this.activatedRoute,\n      queryParams: {\n        interval: this.form.value.currentDateContextInterval,\n        lastUpdatedFrom: combinedFormEvent.selectedDates[0].toISOString(),\n        createdTo: combinedFormEvent.selectedDates[1].toISOString()\n      },\n      queryParamsHandling: 'merge'\n    });\n    this.dateFilterChange.emit(combinedFormEvent);\n  }\n\n  writeValue(value: any): void {\n    if (value) {\n      this.form.patchValue({\n        currentDateContextFromDate:\n          typeof value[0] === 'string' ? value[0] : value[0].toISOString(),\n        currentDateContextToDate: typeof value[1] === 'string' ? value[1] : value[1].toISOString()\n      });\n    }\n  }\n\n  registerOnChange(fn: any): void {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(onTouched: any) {\n    this.onTouched = onTouched;\n  }\n\n  private updateDateTime(interval: AlarmFilterInterval['id']): void {\n    const date = this.alarmsViewService.getDateTimeContextByInterval(interval);\n    if (this.dropdown) {\n      this.dropdown.isOpen = false;\n    }\n    this.date = date.map(d => d.toISOString()) as [string, string];\n    this.form.patchValue(\n      {\n        temporaryUserSelectedFromDate: date[0].toISOString(),\n        temporaryUserSelectedToDate: date[1].toISOString(),\n        currentDateContextInterval: interval\n      },\n      { emitEvent: false }\n    );\n    this.applyDateFilter();\n  }\n\n  private getDefaultContext() {\n    return {\n      date: this.alarmsViewService.getDateTimeContextByInterval(this.DEFAULT_INTERVAL),\n      interval: this.DEFAULT_INTERVAL\n    };\n  }\n\n  private subscribeToIntervalChange(): void {\n    this.form.controls.currentDateContextInterval.valueChanges\n      .pipe(takeUntil(this.destroy$))\n      .subscribe(interval => {\n        if (interval === 'custom') {\n          this.form.patchValue(\n            {\n              temporaryUserSelectedFromDate:\n                this.form.controls.temporaryUserSelectedFromDate.value === new Date(0).toISOString()\n                  ? this.form.controls.currentDateContextToDate.value\n                  : this.form.controls.temporaryUserSelectedFromDate.value,\n              currentDateContextInterval: interval\n            },\n            { emitEvent: false }\n          );\n          return;\n        }\n        this.updateDateTime(interval);\n      });\n  }\n\n  private createForm(context: WidgetTimeContextStateExtended) {\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    });\n  }\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  <div\n    class=\"dropdown flex-grow\"\n    c8yDropdownDirection\n    #dropDirection=\"bs-dropdown\"\n    dropdown\n    [insideClick]=\"true\"\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 }} — {{ date[1] | c8yDate: DATE_FORMAT }}\"\n      tooltip=\"{{\n        form.value.currentDateContextInterval === 'none'\n          ? 'No date filter'\n          : (date[0] | c8yDate: DATE_FORMAT) + ' — ' + (date[1] | c8yDate: DATE_FORMAT)\n      }}\"\n      placement=\"top\"\n      container=\"body\"\n      data-cy=\"alarms-date-filter--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=\"alarms-date-filter--selected-time-range\"\n          *ngIf=\"form.controls.currentDateContextInterval.value !== 'none'\"\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        [INTERVALS]=\"INTERVALS\"\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            class=\"m-b-8\"\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]=\"form.controls.temporaryUserSelectedFromDate.errors ? 'has-error' : ''\"\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            class=\"m-b-8\"\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-primary btn-sm flex-grow\"\n            title=\"{{ 'Apply' | translate }}\"\n            type=\"button\"\n            (click)=\"applyDateFilter(); dropdown.isOpen = false\"\n            [disabled]=\"(form.pristine && form.untouched) || form.invalid\"\n            translate\n          >\n            Apply\n          </button>\n        </div>\n      </ng-container>\n    </ul>\n  </div>\n</form>\n"]}
|