@eo-sdk/client 11.8.1 → 11.9.0-rc.2
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/app/eo-client/about-state/about-state.component.d.ts.map +1 -1
- package/app/eo-client/inbox-state/inbox-state/inbox-state.component.d.ts +11 -1
- package/app/eo-client/inbox-state/inbox-state/inbox-state.component.d.ts.map +1 -1
- package/app/eo-client/settings/settings.component.d.ts +4 -2
- package/app/eo-client/settings/settings.component.d.ts.map +1 -1
- package/app/eo-framework/actions/action-menu/action-menu.component.d.ts +12 -3
- package/app/eo-framework/actions/action-menu/action-menu.component.d.ts.map +1 -1
- package/app/eo-framework/actions/action-service/action.service.d.ts +39 -3
- package/app/eo-framework/actions/action-service/action.service.d.ts.map +1 -1
- package/app/eo-framework/actions/action.module.d.ts +16 -13
- package/app/eo-framework/actions/action.module.d.ts.map +1 -1
- package/app/eo-framework/actions/actions/return-task-action/return-task/return-task.component.d.ts +39 -0
- package/app/eo-framework/actions/actions/return-task-action/return-task/return-task.component.d.ts.map +1 -0
- package/app/eo-framework/actions/actions/return-task-action/return-task-action.d.ts +32 -0
- package/app/eo-framework/actions/actions/return-task-action/return-task-action.d.ts.map +1 -0
- package/app/eo-framework/app-shell/app-bar/app-search/app-search.component.d.ts +1 -0
- package/app/eo-framework/app-shell/app-bar/app-search/app-search.component.d.ts.map +1 -1
- package/app/eo-framework/form-elements/datetime-range/datetime-range.component.d.ts +15 -1
- package/app/eo-framework/form-elements/datetime-range/datetime-range.component.d.ts.map +1 -1
- package/app/eo-framework/form-elements/dynamic-list/dynamic-list.component.d.ts +1 -2
- package/app/eo-framework/form-elements/dynamic-list/dynamic-list.component.d.ts.map +1 -1
- package/app/eo-framework/object-form/object-form-helper.service.d.ts.map +1 -1
- package/app/eo-framework/ui/indexdata-summary/indexdata-summary.component.d.ts.map +1 -1
- package/app/eo-framework-core/api/grid.service.d.ts.map +1 -1
- package/assets/_default/i18n/de.json +24 -9
- package/assets/_default/i18n/en.json +24 -9
- package/assets/_default/svg/ic_rollback.svg +1 -0
- package/esm2022/app/eo-client/about-state/about-state.component.mjs +3 -3
- package/esm2022/app/eo-client/dashboard/widgets/charts-widget/charts-widget.component.mjs +6 -6
- package/esm2022/app/eo-client/inbox-state/inbox-state/inbox-state.component.mjs +70 -23
- package/esm2022/app/eo-client/process-state/process-state.component.mjs +1 -1
- package/esm2022/app/eo-client/settings/settings.component.mjs +9 -6
- package/esm2022/app/eo-framework/actions/action-menu/action-menu.component.mjs +51 -32
- package/esm2022/app/eo-framework/actions/action-service/action.service.mjs +54 -3
- package/esm2022/app/eo-framework/actions/action.module.mjs +10 -4
- package/esm2022/app/eo-framework/actions/actions/return-task-action/return-task/return-task.component.mjs +75 -0
- package/esm2022/app/eo-framework/actions/actions/return-task-action/return-task-action.mjs +43 -0
- package/esm2022/app/eo-framework/app-shell/app-bar/app-search/app-search.component.mjs +1 -1
- package/esm2022/app/eo-framework/form-elements/datetime-range/datetime-range.component.mjs +150 -11
- package/esm2022/app/eo-framework/form-elements/dynamic-list/dynamic-list.component.mjs +3 -4
- package/esm2022/app/eo-framework/object-form/object-form/form-element/form-element.component.mjs +3 -3
- package/esm2022/app/eo-framework/object-form/object-form-edit/object-form-edit.component.mjs +2 -2
- package/esm2022/app/eo-framework/object-form/object-form-helper.service.mjs +14 -2
- package/esm2022/app/eo-framework/shortcuts/global-shortcuts/global-shortcuts-section/global-shortcuts-section.component.mjs +2 -2
- package/esm2022/app/eo-framework/ui/indexdata-summary/indexdata-summary-entry/indexdata-summary-entry.component.mjs +2 -2
- package/esm2022/app/eo-framework/ui/indexdata-summary/indexdata-summary.component.mjs +20 -10
- package/esm2022/app/eo-framework-core/api/grid.service.mjs +4 -1
- package/fesm2022/eo-sdk-client.mjs +591 -203
- package/fesm2022/eo-sdk-client.mjs.map +1 -1
- package/package.json +2 -2
|
@@ -10,7 +10,8 @@ import * as i3 from "@angular/common";
|
|
|
10
10
|
import * as i4 from "@ngx-translate/core";
|
|
11
11
|
import * as i5 from "../../ui/eo-icon/eo-icon.component";
|
|
12
12
|
import * as i6 from "@yuuvis/components/dropdown";
|
|
13
|
-
import * as i7 from "../
|
|
13
|
+
import * as i7 from "../codesystem/codesystem.component";
|
|
14
|
+
import * as i8 from "../date/date.component";
|
|
14
15
|
export class DatetimeRangeComponent {
|
|
15
16
|
constructor(fb, translate) {
|
|
16
17
|
this.fb = fb;
|
|
@@ -19,7 +20,8 @@ export class DatetimeRangeComponent {
|
|
|
19
20
|
this.swapInputs = false;
|
|
20
21
|
this.rangeForm = this.fb.group({
|
|
21
22
|
dateValue: [],
|
|
22
|
-
dateValueFrom: []
|
|
23
|
+
dateValueFrom: [],
|
|
24
|
+
datePickerValue: []
|
|
23
25
|
});
|
|
24
26
|
this.isValid = true;
|
|
25
27
|
// options for search situation
|
|
@@ -27,10 +29,15 @@ export class DatetimeRangeComponent {
|
|
|
27
29
|
{ label: RangeValue.getOperatorLabel(SearchFilter.OPERATOR.EQUAL), value: SearchFilter.OPERATOR.EQUAL },
|
|
28
30
|
{ label: RangeValue.getOperatorLabel(SearchFilter.OPERATOR.GREATER_OR_EQUAL), value: SearchFilter.OPERATOR.GREATER_OR_EQUAL },
|
|
29
31
|
{ label: RangeValue.getOperatorLabel(SearchFilter.OPERATOR.LESS_OR_EQUAL), value: SearchFilter.OPERATOR.LESS_OR_EQUAL },
|
|
30
|
-
{ label: RangeValue.getOperatorLabel(SearchFilter.OPERATOR.INTERVAL_INCLUDE_BOTH), value: SearchFilter.OPERATOR.INTERVAL_INCLUDE_BOTH }
|
|
32
|
+
{ label: RangeValue.getOperatorLabel(SearchFilter.OPERATOR.INTERVAL_INCLUDE_BOTH), value: SearchFilter.OPERATOR.INTERVAL_INCLUDE_BOTH },
|
|
33
|
+
{ label: RangeValue.getOperatorLabel(SearchFilter.OPERATOR.MORE), value: SearchFilter.OPERATOR.MORE }
|
|
31
34
|
];
|
|
32
35
|
this.previousDateValue = null;
|
|
33
36
|
this.previousDateValueFrom = null;
|
|
37
|
+
this.datePicker = {
|
|
38
|
+
title: this.translate.instant('eo.search.agg.time.span'),
|
|
39
|
+
codesystem: null,
|
|
40
|
+
};
|
|
34
41
|
this.propagateChange = (_) => { };
|
|
35
42
|
this.validationChange = () => { };
|
|
36
43
|
this.datePipe = new LocaleDatePipe(translate);
|
|
@@ -39,6 +46,11 @@ export class DatetimeRangeComponent {
|
|
|
39
46
|
writeValue(value) {
|
|
40
47
|
this._setValue(value);
|
|
41
48
|
}
|
|
49
|
+
onSearchSituation() {
|
|
50
|
+
if (this.situation !== 'SEARCH') {
|
|
51
|
+
this.availableSearchOptions = this.availableSearchOptions.filter(option => option.value !== SearchFilter.OPERATOR.MORE);
|
|
52
|
+
}
|
|
53
|
+
}
|
|
42
54
|
registerOnChange(fn) {
|
|
43
55
|
this.propagateChange = fn;
|
|
44
56
|
}
|
|
@@ -52,6 +64,7 @@ export class DatetimeRangeComponent {
|
|
|
52
64
|
}
|
|
53
65
|
onValueChange(searchOption = this.searchOption) {
|
|
54
66
|
let dateValue = this.formatDate(this.rangeForm.get('dateValue').value);
|
|
67
|
+
let datePickerValue = this.rangeForm.get('datePickerValue').value;
|
|
55
68
|
if (searchOption === SearchFilter.OPERATOR.INTERVAL_INCLUDE_BOTH) {
|
|
56
69
|
const dateValueFrom = this.formatDate(this.rangeForm.get('dateValueFrom').value);
|
|
57
70
|
if (dateValueFrom && dateValue) {
|
|
@@ -65,19 +78,31 @@ export class DatetimeRangeComponent {
|
|
|
65
78
|
}
|
|
66
79
|
}
|
|
67
80
|
}
|
|
81
|
+
else if (searchOption === SearchFilter.OPERATOR.MORE) {
|
|
82
|
+
this.swapInputs = false;
|
|
83
|
+
this.isValid = this.rangeForm.valid;
|
|
84
|
+
const oldSearchOption = this.searchOption;
|
|
85
|
+
this._setValue(!datePickerValue ? null : new RangeValue(searchOption, datePickerValue));
|
|
86
|
+
if (this.previousDateValue !== datePickerValue || oldSearchOption !== searchOption) {
|
|
87
|
+
this.propagateChange(this.value);
|
|
88
|
+
this.previousDateValue = datePickerValue;
|
|
89
|
+
}
|
|
90
|
+
}
|
|
68
91
|
else {
|
|
69
92
|
this.swapInputs = false;
|
|
70
93
|
this.isValid = this.rangeForm.valid;
|
|
71
94
|
if (searchOption === SearchFilter.OPERATOR.LESS_OR_EQUAL && dateValue) {
|
|
72
95
|
const newDateValue = new Date(dateValue);
|
|
73
|
-
if (!this.withTime)
|
|
96
|
+
if (!this.withTime) {
|
|
74
97
|
newDateValue.setHours(23, 59);
|
|
98
|
+
}
|
|
75
99
|
dateValue = newDateValue.toISOString();
|
|
76
100
|
}
|
|
77
101
|
else if (searchOption === SearchFilter.OPERATOR.GREATER_OR_EQUAL && dateValue) {
|
|
78
102
|
const newDateValue = new Date(dateValue);
|
|
79
|
-
if (!this.withTime)
|
|
103
|
+
if (!this.withTime) {
|
|
80
104
|
newDateValue.setHours(0, 0);
|
|
105
|
+
}
|
|
81
106
|
dateValue = newDateValue.toISOString();
|
|
82
107
|
}
|
|
83
108
|
if (this.isValid) {
|
|
@@ -92,8 +117,10 @@ export class DatetimeRangeComponent {
|
|
|
92
117
|
this.searchOption = searchOption;
|
|
93
118
|
}
|
|
94
119
|
_setValue(value, emitEvent = false) {
|
|
95
|
-
|
|
120
|
+
this.getPlaceholderCodesystem();
|
|
121
|
+
if (JSON.stringify(this.value) === JSON.stringify(value)) {
|
|
96
122
|
return;
|
|
123
|
+
}
|
|
97
124
|
if (value && value instanceof RangeValue && (value.firstValue || value.secondValue)) {
|
|
98
125
|
// This prevents the value change event from being fired twice during initialization or when there is already a value
|
|
99
126
|
if (this.rangeForm.pristine && this.value != null && value != this.value) {
|
|
@@ -102,13 +129,19 @@ export class DatetimeRangeComponent {
|
|
|
102
129
|
const fV = value.firstValue ? new Date(value.firstValue) : null;
|
|
103
130
|
const sV = value.secondValue ? new Date(value.secondValue) : null;
|
|
104
131
|
this.value = value;
|
|
105
|
-
this.searchOption = value.operator || SearchFilter.OPERATOR.EQUAL;
|
|
132
|
+
this.searchOption = (value.operator === 'rg' ? 'mr' : value.operator) || SearchFilter.OPERATOR.EQUAL;
|
|
106
133
|
if (!value.secondValue) {
|
|
107
134
|
if (JSON.stringify(this.rangeForm.value.dateValue) !== JSON.stringify(fV)) {
|
|
108
135
|
this.rangeForm.patchValue({
|
|
109
136
|
dateValue: fV
|
|
110
137
|
}, { emitEvent });
|
|
111
138
|
}
|
|
139
|
+
if (JSON.stringify(this.rangeForm.value.datePickerValue) !== JSON.stringify(fV)) {
|
|
140
|
+
this.value.firstValue;
|
|
141
|
+
}
|
|
142
|
+
this.rangeForm.patchValue({
|
|
143
|
+
datePickerValue: this.value.firstValue
|
|
144
|
+
}, { emitEvent });
|
|
112
145
|
}
|
|
113
146
|
else {
|
|
114
147
|
if (JSON.stringify(this.rangeForm.value.dateValueFrom) !== JSON.stringify(fV)) {
|
|
@@ -132,8 +165,111 @@ export class DatetimeRangeComponent {
|
|
|
132
165
|
return !value ? null :
|
|
133
166
|
this.withTime ? value.toISOString().replace(':00.000', '') : this.datePipe.transform(value, 'yyyy-MM-dd');
|
|
134
167
|
}
|
|
168
|
+
getPlaceholderCodesystem() {
|
|
169
|
+
let entries = [
|
|
170
|
+
{
|
|
171
|
+
id: 'yesterday',
|
|
172
|
+
defaultrepresentation: this.translate.instant('eo.search.agg.time.yesterday'),
|
|
173
|
+
label: this.translate.instant('eo.search.agg.time.yesterday'),
|
|
174
|
+
value: 'yesterday'
|
|
175
|
+
},
|
|
176
|
+
{
|
|
177
|
+
id: 'today',
|
|
178
|
+
defaultrepresentation: this.translate.instant('eo.search.agg.time.today'),
|
|
179
|
+
label: this.translate.instant('eo.search.agg.time.today'),
|
|
180
|
+
value: 'today'
|
|
181
|
+
},
|
|
182
|
+
{
|
|
183
|
+
id: 'tomorrow',
|
|
184
|
+
defaultrepresentation: this.translate.instant('eo.search.agg.time.tomorrow'),
|
|
185
|
+
label: this.translate.instant('eo.search.agg.time.tomorrow'),
|
|
186
|
+
value: 'tomorrow'
|
|
187
|
+
},
|
|
188
|
+
{
|
|
189
|
+
id: 'lastweek',
|
|
190
|
+
defaultrepresentation: this.translate.instant('eo.search.agg.time.lastweek'),
|
|
191
|
+
label: this.translate.instant('eo.search.agg.time.lastweek'),
|
|
192
|
+
value: 'lastweek'
|
|
193
|
+
},
|
|
194
|
+
{
|
|
195
|
+
id: 'thisweek',
|
|
196
|
+
defaultrepresentation: this.translate.instant('eo.search.agg.time.thisweek'),
|
|
197
|
+
label: this.translate.instant('eo.search.agg.time.thisweek'),
|
|
198
|
+
value: 'thisweek'
|
|
199
|
+
},
|
|
200
|
+
{
|
|
201
|
+
id: 'nextweek',
|
|
202
|
+
defaultrepresentation: this.translate.instant('eo.search.agg.time.nextweek'),
|
|
203
|
+
label: this.translate.instant('eo.search.agg.time.nextweek'),
|
|
204
|
+
value: 'nextweek'
|
|
205
|
+
},
|
|
206
|
+
{
|
|
207
|
+
id: 'lastmonth',
|
|
208
|
+
defaultrepresentation: this.translate.instant('eo.search.agg.time.lastmonth'),
|
|
209
|
+
label: this.translate.instant('eo.search.agg.time.lastmonth'),
|
|
210
|
+
value: 'lastmonth'
|
|
211
|
+
},
|
|
212
|
+
{
|
|
213
|
+
id: 'thismonth',
|
|
214
|
+
defaultrepresentation: this.translate.instant('eo.search.agg.time.thismonth'),
|
|
215
|
+
label: this.translate.instant('eo.search.agg.time.thismonth'),
|
|
216
|
+
value: 'thismonth'
|
|
217
|
+
},
|
|
218
|
+
{
|
|
219
|
+
id: 'nextmonth',
|
|
220
|
+
defaultrepresentation: this.translate.instant('eo.search.agg.time.nextmonth'),
|
|
221
|
+
label: this.translate.instant('eo.search.agg.time.nextmonth'),
|
|
222
|
+
value: 'nextmonth'
|
|
223
|
+
},
|
|
224
|
+
{
|
|
225
|
+
id: 'thisquarter',
|
|
226
|
+
defaultrepresentation: this.translate.instant('eo.search.agg.time.thisquarter'),
|
|
227
|
+
label: this.translate.instant('eo.search.agg.time.thisquarter'),
|
|
228
|
+
value: 'thisquarter'
|
|
229
|
+
},
|
|
230
|
+
{
|
|
231
|
+
id: 'lastquarter',
|
|
232
|
+
defaultrepresentation: this.translate.instant('eo.search.agg.time.lastquarter'),
|
|
233
|
+
label: this.translate.instant('eo.search.agg.time.lastquarter'),
|
|
234
|
+
value: 'lastquarter'
|
|
235
|
+
},
|
|
236
|
+
{
|
|
237
|
+
id: 'nextquarter',
|
|
238
|
+
defaultrepresentation: this.translate.instant('eo.search.agg.time.nextquarter'),
|
|
239
|
+
label: this.translate.instant('eo.search.agg.time.nextquarter'),
|
|
240
|
+
value: 'nextquarter'
|
|
241
|
+
},
|
|
242
|
+
{
|
|
243
|
+
id: 'lastyear',
|
|
244
|
+
defaultrepresentation: this.translate.instant('eo.search.agg.time.lastyear'),
|
|
245
|
+
label: this.translate.instant('eo.search.agg.time.lastyear'),
|
|
246
|
+
value: 'lastyear'
|
|
247
|
+
},
|
|
248
|
+
{
|
|
249
|
+
id: 'thisyear',
|
|
250
|
+
defaultrepresentation: this.translate.instant('eo.search.agg.time.thisyear'),
|
|
251
|
+
label: this.translate.instant('eo.search.agg.time.thisyear'),
|
|
252
|
+
value: 'thisyear'
|
|
253
|
+
},
|
|
254
|
+
{
|
|
255
|
+
id: 'nextyear',
|
|
256
|
+
defaultrepresentation: this.translate.instant('eo.search.agg.time.nextyear'),
|
|
257
|
+
label: this.translate.instant('eo.search.agg.time.nextyear'),
|
|
258
|
+
value: 'nextyear'
|
|
259
|
+
}
|
|
260
|
+
];
|
|
261
|
+
return this.datePicker.codesystem = {
|
|
262
|
+
entries: entries.map((res) => ({
|
|
263
|
+
id: res.id,
|
|
264
|
+
label: res.label,
|
|
265
|
+
defaultrepresentation: res.defaultrepresentation,
|
|
266
|
+
data: res.value
|
|
267
|
+
})),
|
|
268
|
+
};
|
|
269
|
+
}
|
|
135
270
|
// returns null when valid else the validation object
|
|
136
271
|
validate(c) {
|
|
272
|
+
this.onSearchSituation();
|
|
137
273
|
let err;
|
|
138
274
|
if (this.searchOption === SearchFilter.OPERATOR.EQUAL) {
|
|
139
275
|
err = {
|
|
@@ -152,10 +288,11 @@ export class DatetimeRangeComponent {
|
|
|
152
288
|
return (this.isValid) ? null : err;
|
|
153
289
|
}
|
|
154
290
|
ngOnInit() {
|
|
291
|
+
this.getPlaceholderCodesystem();
|
|
155
292
|
this.searchOption = this.operator;
|
|
156
293
|
}
|
|
157
294
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.4", ngImport: i0, type: DatetimeRangeComponent, deps: [{ token: i1.UntypedFormBuilder }, { token: i2.TranslateService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
158
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "
|
|
295
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.4", type: DatetimeRangeComponent, selector: "eo-datetime-range", inputs: { withTime: "withTime", pickerTitle: "pickerTitle", operator: "operator", situation: "situation" }, host: { properties: { "class.swap": "this.swapInputs" }, classAttribute: "form-element-range" }, providers: [
|
|
159
296
|
{
|
|
160
297
|
provide: NG_VALUE_ACCESSOR,
|
|
161
298
|
useExisting: forwardRef(() => DatetimeRangeComponent),
|
|
@@ -166,7 +303,7 @@ export class DatetimeRangeComponent {
|
|
|
166
303
|
useExisting: forwardRef(() => DatetimeRangeComponent),
|
|
167
304
|
multi: true,
|
|
168
305
|
}
|
|
169
|
-
], ngImport: i0, template: "<form class=\"eo-datetime-range\" [formGroup]=\"rangeForm\">\n <eo-date *ngIf=\"searchOption === 'gtelte'\" [withTime]=\"withTime\"\n formControlName=\"dateValueFrom\"></eo-date>\n\n <yvc-dropdown [ngModel]=\"searchOption\" (ngModelChange)=\"onValueChange($event)\" [ngModelOptions]=\"{standalone: true}\"\n [options]=\"availableSearchOptions\"></yvc-dropdown>\n\n
|
|
306
|
+
], ngImport: i0, template: "<form class=\"eo-datetime-range\" [formGroup]=\"rangeForm\">\n <eo-date *ngIf=\"searchOption === 'gtelte'\" [withTime]=\"withTime\"\n formControlName=\"dateValueFrom\"></eo-date>\n\n <yvc-dropdown [ngModel]=\"searchOption\" (ngModelChange)=\"onValueChange($event)\" [ngModelOptions]=\"{standalone: true}\"\n [options]=\"availableSearchOptions\"></yvc-dropdown>\n \n @if(searchOption === 'mr'){\n <eo-codesystem formControlName=\"datePickerValue\" [pickerTitle]=\"datePicker.title\"\n [emptyMessage]=\"'eo.workspace.widget.stored.queries.list.notAvailable'\"\n [codesystem]=\"datePicker.codesystem\"></eo-codesystem>\n }\n @else{\n <eo-date [withTime]=\"withTime\" formControlName=\"dateValue\"></eo-date>\n }\n</form>\n\n<div class=\"errors\" *ngIf=\"rangeForm.invalid\">\n <div class=\"err-msg\" translate>eo.form.property.date.invalid</div>\n <eo-icon class=\"button\" [iconSrc]=\"'assets/_default/svg/ic_clear.svg'\" (click)=\"reset()\"></eo-icon>\n</div>\n", styles: [".eo-datetime-range{display:flex;flex-flow:row nowrap;align-items:stretch;gap:2px}.eo-datetime-range yvc-dropdown{border-radius:2px;outline:1px solid rgba(0,0,0,.2);background-color:var(--list-item-hover-background)}.eo-datetime-range yvc-dropdown:hover{background-color:var(--list-item-selected-background)}.eo-datetime-range eo-date{flex:1 1 auto}.err-msg{color:var(--color-error);margin:calc(var(--app-pane-padding) / 4) 0;padding:calc(var(--app-pane-padding) / 4)}.errors{display:flex;align-items:center;justify-content:space-between;gap:.5em}.errors .err-msg:before{content:\"!\";padding:0 calc(var(--app-pane-padding) / 4)}.errors eo-icon{color:var(--color-error);width:18px;height:18px}eo-codesystem{width:100%}::ng-deep yvc-dropdown[aria-expanded=true],::ng-deep .yvc-dropdown:focus{background-color:var(--color-primary-4)!important}\n"], dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { 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: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { 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: "directive", type: i4.TranslateDirective, selector: "[translate],[ngx-translate]", inputs: ["translate", "translateParams"] }, { kind: "component", type: i5.EoIconComponent, selector: "eo-icon", inputs: ["objectType", "iconId", "iconSrc", "badge", "iconTitle"] }, { kind: "component", type: i6.Dropdown, selector: "yvc-dropdown", inputs: ["options", "filter", "disabled", "multiple", "disableClearButton"] }, { kind: "component", type: i7.CodesystemComponent, selector: "eo-codesystem", inputs: ["situation", "pickerTitle", "placeholder", "codesystem", "multiselect", "readonly", "inputStyleClass", "emptyMessage", "filterFunction", "disablingFilterFunction"] }, { kind: "component", type: i8.DateComponent, selector: "eo-date", inputs: ["withTime", "readonly", "onlyFutureDates"] }] }); }
|
|
170
307
|
}
|
|
171
308
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.4", ngImport: i0, type: DatetimeRangeComponent, decorators: [{
|
|
172
309
|
type: Component,
|
|
@@ -183,15 +320,17 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.4", ngImpor
|
|
|
183
320
|
}
|
|
184
321
|
], host: {
|
|
185
322
|
class: 'form-element-range'
|
|
186
|
-
}, template: "<form class=\"eo-datetime-range\" [formGroup]=\"rangeForm\">\n <eo-date *ngIf=\"searchOption === 'gtelte'\" [withTime]=\"withTime\"\n formControlName=\"dateValueFrom\"></eo-date>\n\n <yvc-dropdown [ngModel]=\"searchOption\" (ngModelChange)=\"onValueChange($event)\" [ngModelOptions]=\"{standalone: true}\"\n [options]=\"availableSearchOptions\"></yvc-dropdown>\n\n
|
|
323
|
+
}, template: "<form class=\"eo-datetime-range\" [formGroup]=\"rangeForm\">\n <eo-date *ngIf=\"searchOption === 'gtelte'\" [withTime]=\"withTime\"\n formControlName=\"dateValueFrom\"></eo-date>\n\n <yvc-dropdown [ngModel]=\"searchOption\" (ngModelChange)=\"onValueChange($event)\" [ngModelOptions]=\"{standalone: true}\"\n [options]=\"availableSearchOptions\"></yvc-dropdown>\n \n @if(searchOption === 'mr'){\n <eo-codesystem formControlName=\"datePickerValue\" [pickerTitle]=\"datePicker.title\"\n [emptyMessage]=\"'eo.workspace.widget.stored.queries.list.notAvailable'\"\n [codesystem]=\"datePicker.codesystem\"></eo-codesystem>\n }\n @else{\n <eo-date [withTime]=\"withTime\" formControlName=\"dateValue\"></eo-date>\n }\n</form>\n\n<div class=\"errors\" *ngIf=\"rangeForm.invalid\">\n <div class=\"err-msg\" translate>eo.form.property.date.invalid</div>\n <eo-icon class=\"button\" [iconSrc]=\"'assets/_default/svg/ic_clear.svg'\" (click)=\"reset()\"></eo-icon>\n</div>\n", styles: [".eo-datetime-range{display:flex;flex-flow:row nowrap;align-items:stretch;gap:2px}.eo-datetime-range yvc-dropdown{border-radius:2px;outline:1px solid rgba(0,0,0,.2);background-color:var(--list-item-hover-background)}.eo-datetime-range yvc-dropdown:hover{background-color:var(--list-item-selected-background)}.eo-datetime-range eo-date{flex:1 1 auto}.err-msg{color:var(--color-error);margin:calc(var(--app-pane-padding) / 4) 0;padding:calc(var(--app-pane-padding) / 4)}.errors{display:flex;align-items:center;justify-content:space-between;gap:.5em}.errors .err-msg:before{content:\"!\";padding:0 calc(var(--app-pane-padding) / 4)}.errors eo-icon{color:var(--color-error);width:18px;height:18px}eo-codesystem{width:100%}::ng-deep yvc-dropdown[aria-expanded=true],::ng-deep .yvc-dropdown:focus{background-color:var(--color-primary-4)!important}\n"] }]
|
|
187
324
|
}], ctorParameters: () => [{ type: i1.UntypedFormBuilder }, { type: i2.TranslateService }], propDecorators: { withTime: [{
|
|
188
325
|
type: Input
|
|
189
326
|
}], pickerTitle: [{
|
|
190
327
|
type: Input
|
|
191
328
|
}], operator: [{
|
|
192
329
|
type: Input
|
|
330
|
+
}], situation: [{
|
|
331
|
+
type: Input
|
|
193
332
|
}], swapInputs: [{
|
|
194
333
|
type: HostBinding,
|
|
195
334
|
args: ['class.swap']
|
|
196
335
|
}] } });
|
|
197
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datetime-range.component.js","sourceRoot":"","sources":["../../../../../../../../src/app/eo-framework/form-elements/datetime-range/datetime-range.component.ts","../../../../../../../../src/app/eo-framework/form-elements/datetime-range/datetime-range.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, Input, OnInit, forwardRef, HostBinding} from '@angular/core';\nimport {\n  FormGroup,\n  UntypedFormControl,\n  ControlValueAccessor,\n  Validator,\n  UntypedFormBuilder,\n  NG_VALUE_ACCESSOR,\n  NG_VALIDATORS\n} from '@angular/forms';\nimport {takeUntilDestroyed} from '@angular/core/rxjs-interop';\nimport {RangeValue, SearchFilter, TranslateService} from '@eo-sdk/core';\nimport {LocaleDatePipe} from '../../../eo-framework-core/pipes/locale-date.pipe';\n\n@Component({\n  selector: 'eo-datetime-range',\n  templateUrl: './datetime-range.component.html',\n  styleUrls: ['./datetime-range.component.scss'],\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => DatetimeRangeComponent),\n      multi: true\n    },\n    {\n      provide: NG_VALIDATORS,\n      useExisting: forwardRef(() => DatetimeRangeComponent),\n      multi: true,\n    }\n  ],\n  host: {\n    class: 'form-element-range'\n  }\n})\nexport class DatetimeRangeComponent implements OnInit, ControlValueAccessor, Validator {\n\n  @Input() withTime: boolean;\n  @Input() pickerTitle: string;\n  @Input() operator = 'eq';\n\n  @HostBinding('class.swap') swapInputs: boolean = false;\n\n  rangeForm: FormGroup = this.fb.group({\n    dateValue: [],\n    dateValueFrom: []\n  });\n  value: RangeValue;\n  private isValid = true;\n\n  // options for search situation\n  public availableSearchOptions = [\n    {label: RangeValue.getOperatorLabel(SearchFilter.OPERATOR.EQUAL), value: SearchFilter.OPERATOR.EQUAL},\n    {label: RangeValue.getOperatorLabel(SearchFilter.OPERATOR.GREATER_OR_EQUAL), value: SearchFilter.OPERATOR.GREATER_OR_EQUAL},\n    {label: RangeValue.getOperatorLabel(SearchFilter.OPERATOR.LESS_OR_EQUAL), value: SearchFilter.OPERATOR.LESS_OR_EQUAL},\n    {label: RangeValue.getOperatorLabel(SearchFilter.OPERATOR.INTERVAL_INCLUDE_BOTH), value: SearchFilter.OPERATOR.INTERVAL_INCLUDE_BOTH}\n  ];\n  // the selected search option\n  public searchOption: string;\n  datePipe: LocaleDatePipe;\n  previousDateValue = null;\n  previousDateValueFrom = null;\n\n  constructor(private fb: UntypedFormBuilder, public translate: TranslateService) {\n    this.datePipe = new LocaleDatePipe(translate);\n    this.rangeForm.valueChanges.pipe(\n      takeUntilDestroyed()\n    ).subscribe(() => this.onValueChange());\n  }\n\n  propagateChange = (_: any) => { }\n  validationChange = () => { };\n\n  writeValue(value: RangeValue): void {\n    this._setValue(value);\n  }\n\n  registerOnChange(fn: any): void {\n    this.propagateChange = fn;\n  }\n\n  registerOnValidatorChange?(fn: () => void): void {\n    this.validationChange = fn;\n  }\n\n  registerOnTouched(fn: any): void {\n  }\n\n  reset() {\n    this._setValue(new RangeValue(\n      this.searchOption,\n      null, null\n    ));\n  }\n\n  onValueChange(searchOption = this.searchOption) {\n    let dateValue = this.formatDate(this.rangeForm.get('dateValue').value);\n    if (searchOption === SearchFilter.OPERATOR.INTERVAL_INCLUDE_BOTH) {\n      const dateValueFrom = this.formatDate(this.rangeForm.get('dateValueFrom').value);\n\n      if (dateValueFrom && dateValue) {\n        this.isValid = this.rangeForm.valid && !!dateValueFrom && !!dateValue;\n        this.swapInputs = dateValueFrom && dateValue && dateValueFrom > dateValue;\n        this._setValue(new RangeValue(\n          searchOption,\n          this.swapInputs ? dateValue : dateValueFrom,\n          this.swapInputs ? dateValueFrom : dateValue\n        ));\n        if (this.previousDateValue !== dateValue || this.previousDateValueFrom !== dateValueFrom || this.searchOption !== searchOption) {\n          this.propagateChange(this.value);\n          this.previousDateValue = dateValue;\n          this.previousDateValueFrom = dateValueFrom;\n        }\n      }\n    } else {\n      this.swapInputs = false;\n      this.isValid = this.rangeForm.valid;\n      if (searchOption === SearchFilter.OPERATOR.LESS_OR_EQUAL && dateValue) {\n        const newDateValue = new Date(dateValue);\n        if (!this.withTime) newDateValue.setHours(23, 59);\n        dateValue = newDateValue.toISOString();\n      } else if (searchOption === SearchFilter.OPERATOR.GREATER_OR_EQUAL && dateValue) {\n        const newDateValue = new Date(dateValue);\n        if (!this.withTime) newDateValue.setHours(0, 0);\n        dateValue = newDateValue.toISOString();\n      }\n      if (this.isValid) {\n        const oldSearchOption = this.searchOption;\n        this._setValue(!dateValue ? null : new RangeValue(searchOption, dateValue));\n        if (this.previousDateValue !== dateValue || oldSearchOption !== searchOption) {\n          this.propagateChange(this.value);\n          this.previousDateValue = dateValue;\n        }\n      }\n    }\n    this.searchOption = searchOption;\n  }\n\n  private _setValue(value: RangeValue, emitEvent = false) {\n    if (JSON.stringify(this.value) === JSON.stringify(value)) return;\n    if (value && value instanceof RangeValue && (value.firstValue || value.secondValue)) {\n\n      // This prevents the value change event from being fired twice during initialization or when there is already a value\n      if (this.rangeForm.pristine && this.value != null && value != this.value) {\n        return;\n      }\n\n      const fV = value.firstValue ? new Date(value.firstValue) : null;\n      const sV = value.secondValue ? new Date(value.secondValue) : null;\n      this.value = value;\n      this.searchOption = value.operator || SearchFilter.OPERATOR.EQUAL;\n\n      if (!value.secondValue) {\n        if (JSON.stringify(this.rangeForm.value.dateValue) !== JSON.stringify(fV)) {\n          this.rangeForm.patchValue({\n            dateValue: fV\n          }, {emitEvent});\n        }\n      } else {\n        if (JSON.stringify(this.rangeForm.value.dateValueFrom) !== JSON.stringify(fV)) {\n          this.rangeForm.patchValue({\n            dateValueFrom: fV\n          }, {emitEvent});\n        }\n        if (JSON.stringify(this.rangeForm.value.dateValue) !== JSON.stringify(sV)) {\n          this.rangeForm.patchValue({\n            dateValue: sV\n          }, {emitEvent});\n        }\n      }\n\n    } else {\n      this.value = null;\n      this.rangeForm.reset();\n    }\n  }\n\n  formatDate(value: Date): string {\n    return !value ? null :\n      this.withTime ? value.toISOString().replace(':00.000', '') : this.datePipe.transform(value, 'yyyy-MM-dd');\n  }\n\n  // returns null when valid else the validation object\n  public validate(c: UntypedFormControl) {\n\n    let err;\n    if (this.searchOption === SearchFilter.OPERATOR.EQUAL) {\n      err = {\n        datecontrol: {\n          valid: false,\n        }\n      };\n    } else {\n      err = {\n        daterange: {\n          valid: false,\n        }\n      };\n    }\n    return (this.isValid) ? null : err;\n  }\n\n  ngOnInit() {\n    this.searchOption = this.operator;\n  }\n}\n","<form class=\"eo-datetime-range\" [formGroup]=\"rangeForm\">\n  <eo-date *ngIf=\"searchOption === 'gtelte'\" [withTime]=\"withTime\"\n    formControlName=\"dateValueFrom\"></eo-date>\n\n  <yvc-dropdown [ngModel]=\"searchOption\" (ngModelChange)=\"onValueChange($event)\" [ngModelOptions]=\"{standalone: true}\"\n    [options]=\"availableSearchOptions\"></yvc-dropdown>\n\n  <eo-date [withTime]=\"withTime\" formControlName=\"dateValue\"></eo-date>\n</form>\n\n<div class=\"errors\" *ngIf=\"rangeForm.invalid\">\n  <div class=\"err-msg\" translate>eo.form.property.date.invalid</div>\n  <eo-icon class=\"button\" [iconSrc]=\"'assets/_default/svg/ic_clear.svg'\" (click)=\"reset()\"></eo-icon>\n</div>\n"]}
|
|
336
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datetime-range.component.js","sourceRoot":"","sources":["../../../../../../../../src/app/eo-framework/form-elements/datetime-range/datetime-range.component.ts","../../../../../../../../src/app/eo-framework/form-elements/datetime-range/datetime-range.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, Input, OnInit, forwardRef, HostBinding} from '@angular/core';\nimport {\n  FormGroup,\n  UntypedFormControl,\n  ControlValueAccessor,\n  Validator,\n  UntypedFormBuilder,\n  NG_VALUE_ACCESSOR,\n  NG_VALIDATORS\n} from '@angular/forms';\nimport {takeUntilDestroyed} from '@angular/core/rxjs-interop';\nimport {RangeValue, SearchFilter, TranslateService} from '@eo-sdk/core';\nimport {LocaleDatePipe} from '../../../eo-framework-core/pipes/locale-date.pipe';\n\n@Component({\n  selector: 'eo-datetime-range',\n  templateUrl: './datetime-range.component.html',\n  styleUrls: ['./datetime-range.component.scss'],\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => DatetimeRangeComponent),\n      multi: true\n    },\n    {\n      provide: NG_VALIDATORS,\n      useExisting: forwardRef(() => DatetimeRangeComponent),\n      multi: true,\n    }\n  ],\n  host: {\n    class: 'form-element-range'\n  }\n})\nexport class DatetimeRangeComponent implements OnInit, ControlValueAccessor, Validator {\n\n  @Input() withTime: boolean;\n  @Input() pickerTitle: string;\n  @Input() operator = 'eq';\n  @Input() situation: string;\n\n\n  @HostBinding('class.swap') swapInputs = false;\n\n  rangeForm: FormGroup = this.fb.group({\n    dateValue: [],\n    dateValueFrom: [],\n    datePickerValue: []\n  });\n  value: RangeValue;\n  private isValid = true;\n\n  // options for search situation\n  public availableSearchOptions = [\n    {label: RangeValue.getOperatorLabel(SearchFilter.OPERATOR.EQUAL), value: SearchFilter.OPERATOR.EQUAL},\n    {label: RangeValue.getOperatorLabel(SearchFilter.OPERATOR.GREATER_OR_EQUAL), value: SearchFilter.OPERATOR.GREATER_OR_EQUAL},\n    {label: RangeValue.getOperatorLabel(SearchFilter.OPERATOR.LESS_OR_EQUAL), value: SearchFilter.OPERATOR.LESS_OR_EQUAL},\n    {label: RangeValue.getOperatorLabel(SearchFilter.OPERATOR.INTERVAL_INCLUDE_BOTH), value: SearchFilter.OPERATOR.INTERVAL_INCLUDE_BOTH},\n    {label: RangeValue.getOperatorLabel(SearchFilter.OPERATOR.MORE), value: SearchFilter.OPERATOR.MORE}\n  ];\n\n  // the selected search option\n  public searchOption: string;\n  datePipe: LocaleDatePipe;\n  previousDateValue = null;\n  previousDateValueFrom = null;\n  datePicker = {\n    title: this.translate.instant('eo.search.agg.time.span'),\n    codesystem: null,\n  };\n\n  constructor(private fb: UntypedFormBuilder,\n    public translate: TranslateService,\n  ) {\n    this.datePipe = new LocaleDatePipe(translate);\n    this.rangeForm.valueChanges.pipe(\n      takeUntilDestroyed()\n    ).subscribe(() => this.onValueChange());\n  }\n\n  propagateChange = (_: any) => { };\n  validationChange = () => { };\n\n  writeValue(value: RangeValue): void {\n    this._setValue(value);\n  }\n\n  onSearchSituation() {\n    if (this.situation !== 'SEARCH') {\n      this.availableSearchOptions = this.availableSearchOptions.filter(option => option.value !== SearchFilter.OPERATOR.MORE);\n    }\n  }\n\n  registerOnChange(fn: any): void {\n    this.propagateChange = fn;\n  }\n\n  registerOnValidatorChange?(fn: () => void): void {\n    this.validationChange = fn;\n  }\n\n  registerOnTouched(fn: any): void {\n  }\n\n  reset() {\n    this._setValue(new RangeValue(\n      this.searchOption,\n      null, null\n    ));\n  }\n\n  onValueChange(searchOption = this.searchOption) {\n    let dateValue = this.formatDate(this.rangeForm.get('dateValue').value);\n    let datePickerValue = this.rangeForm.get('datePickerValue').value;\n\n    if (searchOption === SearchFilter.OPERATOR.INTERVAL_INCLUDE_BOTH) {\n      const dateValueFrom = this.formatDate(this.rangeForm.get('dateValueFrom').value);\n\n      if (dateValueFrom && dateValue) {\n        this.isValid = this.rangeForm.valid && !!dateValueFrom && !!dateValue;\n        this.swapInputs = dateValueFrom && dateValue && dateValueFrom > dateValue;\n        this._setValue(new RangeValue(\n          searchOption,\n          this.swapInputs ? dateValue : dateValueFrom,\n          this.swapInputs ? dateValueFrom : dateValue\n        ));\n        if (this.previousDateValue !== dateValue || this.previousDateValueFrom !== dateValueFrom || this.searchOption !== searchOption) {\n          this.propagateChange(this.value);\n          this.previousDateValue = dateValue;\n          this.previousDateValueFrom = dateValueFrom;\n        }\n      }\n    } else if (searchOption === SearchFilter.OPERATOR.MORE) {\n      this.swapInputs = false;\n      this.isValid = this.rangeForm.valid;\n      const oldSearchOption = this.searchOption;\n      this._setValue(!datePickerValue ? null : new RangeValue(searchOption, datePickerValue));\n\n      if (this.previousDateValue !== datePickerValue || oldSearchOption !== searchOption) {\n        this.propagateChange(this.value);\n        this.previousDateValue = datePickerValue;\n      }\n    } else {\n      this.swapInputs = false;\n      this.isValid = this.rangeForm.valid;\n      if (searchOption === SearchFilter.OPERATOR.LESS_OR_EQUAL && dateValue) {\n        const newDateValue = new Date(dateValue);\n        if (!this.withTime) {\n          newDateValue.setHours(23, 59);\n        }\n        dateValue = newDateValue.toISOString();\n      } else if (searchOption === SearchFilter.OPERATOR.GREATER_OR_EQUAL && dateValue) {\n        const newDateValue = new Date(dateValue);\n        if (!this.withTime) {\n          newDateValue.setHours(0, 0);\n        }\n        dateValue = newDateValue.toISOString();\n      }\n      if (this.isValid) {\n        const oldSearchOption = this.searchOption;\n        this._setValue(!dateValue ? null : new RangeValue(searchOption, dateValue));\n        if (this.previousDateValue !== dateValue || oldSearchOption !== searchOption) {\n          this.propagateChange(this.value);\n          this.previousDateValue = dateValue;\n        }\n      }\n    }\n    this.searchOption = searchOption;\n  }\n\n  private _setValue(value: RangeValue, emitEvent = false) {\n    this.getPlaceholderCodesystem();\n    if (JSON.stringify(this.value) === JSON.stringify(value)) {\n      return;\n    }\n\n    if (value && value instanceof RangeValue && (value.firstValue || value.secondValue)) {\n\n      // This prevents the value change event from being fired twice during initialization or when there is already a value\n      if (this.rangeForm.pristine && this.value != null && value != this.value) {\n        return;\n      }\n\n      const fV = value.firstValue ? new Date(value.firstValue) : null;\n      const sV = value.secondValue ? new Date(value.secondValue) : null;\n      this.value = value;\n\n      this.searchOption = (value.operator === 'rg' ? 'mr' : value.operator) || SearchFilter.OPERATOR.EQUAL;\n\n      if (!value.secondValue) {\n        if (JSON.stringify(this.rangeForm.value.dateValue) !== JSON.stringify(fV)) {\n          this.rangeForm.patchValue({\n            dateValue: fV\n          }, {emitEvent});\n        }\n        if (JSON.stringify(this.rangeForm.value.datePickerValue) !== JSON.stringify(fV)) {\n          this.value.firstValue;\n        }\n        this.rangeForm.patchValue({\n          datePickerValue: this.value.firstValue\n        }, {emitEvent});\n\n\n      } else {\n        if (JSON.stringify(this.rangeForm.value.dateValueFrom) !== JSON.stringify(fV)) {\n          this.rangeForm.patchValue({\n            dateValueFrom: fV\n          }, {emitEvent});\n        }\n        if (JSON.stringify(this.rangeForm.value.dateValue) !== JSON.stringify(sV)) {\n          this.rangeForm.patchValue({\n            dateValue: sV\n          }, {emitEvent});\n        }\n      }\n\n    } else {\n      this.value = null;\n      this.rangeForm.reset();\n    }\n  }\n\n  formatDate(value: Date): string {\n    return !value ? null :\n      this.withTime ? value.toISOString().replace(':00.000', '') : this.datePipe.transform(value, 'yyyy-MM-dd');\n  }\n\n  \n  getPlaceholderCodesystem() {\n    let entries = [\n      {\n        id: 'yesterday',\n        defaultrepresentation: this.translate.instant(\n          'eo.search.agg.time.yesterday'),\n        label: this.translate.instant(\n          'eo.search.agg.time.yesterday'\n        ),\n        value: 'yesterday'\n      },\n      {\n        id: 'today',\n        defaultrepresentation: this.translate.instant(\n          'eo.search.agg.time.today'),\n        label: this.translate.instant(\n          'eo.search.agg.time.today'\n        ),\n        value: 'today'\n      },\n      {\n        id: 'tomorrow',\n        defaultrepresentation: this.translate.instant(\n          'eo.search.agg.time.tomorrow'),\n        label: this.translate.instant(\n          'eo.search.agg.time.tomorrow'\n        ),\n        value: 'tomorrow'\n      },\n      {\n        id: 'lastweek',\n        defaultrepresentation: this.translate.instant(\n          'eo.search.agg.time.lastweek'),\n        label: this.translate.instant(\n          'eo.search.agg.time.lastweek'\n        ),\n        value: 'lastweek'\n      },\n      {\n        id: 'thisweek',\n        defaultrepresentation: this.translate.instant(\n          'eo.search.agg.time.thisweek'),\n        label: this.translate.instant(\n          'eo.search.agg.time.thisweek'\n        ),\n        value: 'thisweek'\n      },\n      {\n        id: 'nextweek',\n        defaultrepresentation: this.translate.instant(\n          'eo.search.agg.time.nextweek'),\n        label: this.translate.instant(\n          'eo.search.agg.time.nextweek'\n        ),\n        value: 'nextweek'\n      },\n      {\n        id: 'lastmonth',\n        defaultrepresentation: this.translate.instant(\n          'eo.search.agg.time.lastmonth'),\n        label: this.translate.instant(\n          'eo.search.agg.time.lastmonth'\n        ),\n        value: 'lastmonth'\n      },\n      {\n        id: 'thismonth',\n        defaultrepresentation: this.translate.instant(\n          'eo.search.agg.time.thismonth'),\n        label: this.translate.instant(\n          'eo.search.agg.time.thismonth'\n        ),\n        value: 'thismonth'\n      },\n\n      {\n        id: 'nextmonth',\n        defaultrepresentation: this.translate.instant(\n          'eo.search.agg.time.nextmonth'),\n        label: this.translate.instant(\n          'eo.search.agg.time.nextmonth'\n        ),\n        value: 'nextmonth'\n      },\n      {\n        id: 'thisquarter',\n        defaultrepresentation: this.translate.instant(\n          'eo.search.agg.time.thisquarter'),\n        label: this.translate.instant(\n          'eo.search.agg.time.thisquarter'\n        ),\n        value: 'thisquarter'\n      },\n      {\n        id: 'lastquarter',\n        defaultrepresentation: this.translate.instant(\n          'eo.search.agg.time.lastquarter'),\n        label: this.translate.instant(\n          'eo.search.agg.time.lastquarter'\n        ),\n        value: 'lastquarter'\n      },\n      {\n        id: 'nextquarter',\n        defaultrepresentation: this.translate.instant(\n          'eo.search.agg.time.nextquarter'),\n        label: this.translate.instant(\n          'eo.search.agg.time.nextquarter'\n        ),\n        value: 'nextquarter'\n      },\n      {\n        id: 'lastyear',\n        defaultrepresentation: this.translate.instant(\n          'eo.search.agg.time.lastyear'\n        ),\n        label: this.translate.instant(\n          'eo.search.agg.time.lastyear'\n        ),\n        value: 'lastyear'\n      },\n      {\n        id: 'thisyear',\n        defaultrepresentation: this.translate.instant(\n          'eo.search.agg.time.thisyear'\n        ),\n        label: this.translate.instant(\n          'eo.search.agg.time.thisyear'\n        ),\n        value: 'thisyear'\n      },\n      {\n        id: 'nextyear',\n        defaultrepresentation: this.translate.instant(\n          'eo.search.agg.time.nextyear'),\n        label: this.translate.instant(\n          'eo.search.agg.time.nextyear'\n        ),\n        value: 'nextyear'\n      }\n    ];\n    return this.datePicker.codesystem = {\n      entries: entries.map((res) => ({\n        id: res.id,\n        label: res.label,\n        defaultrepresentation: res.defaultrepresentation,\n        data: res.value\n      })),\n    };\n  }\n\n  // returns null when valid else the validation object\n  public validate(c: UntypedFormControl) {\n    this.onSearchSituation();\n\n    let err;\n    if (this.searchOption === SearchFilter.OPERATOR.EQUAL) {\n      err = {\n        datecontrol: {\n          valid: false,\n        }\n      };\n    } else {\n      err = {\n        daterange: {\n          valid: false,\n        }\n      };\n    }\n    return (this.isValid) ? null : err;\n  }\n\n  ngOnInit() {\n    this.getPlaceholderCodesystem();\n    this.searchOption = this.operator;\n  }\n}\n","<form class=\"eo-datetime-range\" [formGroup]=\"rangeForm\">\n  <eo-date *ngIf=\"searchOption === 'gtelte'\" [withTime]=\"withTime\"\n    formControlName=\"dateValueFrom\"></eo-date>\n\n  <yvc-dropdown [ngModel]=\"searchOption\" (ngModelChange)=\"onValueChange($event)\" [ngModelOptions]=\"{standalone: true}\"\n    [options]=\"availableSearchOptions\"></yvc-dropdown>\n \n    @if(searchOption === 'mr'){\n      <eo-codesystem formControlName=\"datePickerValue\" [pickerTitle]=\"datePicker.title\"\n        [emptyMessage]=\"'eo.workspace.widget.stored.queries.list.notAvailable'\"\n        [codesystem]=\"datePicker.codesystem\"></eo-codesystem>\n    }\n    @else{\n      <eo-date [withTime]=\"withTime\" formControlName=\"dateValue\"></eo-date>\n    }\n</form>\n\n<div class=\"errors\" *ngIf=\"rangeForm.invalid\">\n  <div class=\"err-msg\" translate>eo.form.property.date.invalid</div>\n  <eo-icon class=\"button\" [iconSrc]=\"'assets/_default/svg/ic_clear.svg'\" (click)=\"reset()\"></eo-icon>\n</div>\n"]}
|