@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.
Files changed (50) hide show
  1. package/app/eo-client/about-state/about-state.component.d.ts.map +1 -1
  2. package/app/eo-client/inbox-state/inbox-state/inbox-state.component.d.ts +11 -1
  3. package/app/eo-client/inbox-state/inbox-state/inbox-state.component.d.ts.map +1 -1
  4. package/app/eo-client/settings/settings.component.d.ts +4 -2
  5. package/app/eo-client/settings/settings.component.d.ts.map +1 -1
  6. package/app/eo-framework/actions/action-menu/action-menu.component.d.ts +12 -3
  7. package/app/eo-framework/actions/action-menu/action-menu.component.d.ts.map +1 -1
  8. package/app/eo-framework/actions/action-service/action.service.d.ts +39 -3
  9. package/app/eo-framework/actions/action-service/action.service.d.ts.map +1 -1
  10. package/app/eo-framework/actions/action.module.d.ts +16 -13
  11. package/app/eo-framework/actions/action.module.d.ts.map +1 -1
  12. package/app/eo-framework/actions/actions/return-task-action/return-task/return-task.component.d.ts +39 -0
  13. package/app/eo-framework/actions/actions/return-task-action/return-task/return-task.component.d.ts.map +1 -0
  14. package/app/eo-framework/actions/actions/return-task-action/return-task-action.d.ts +32 -0
  15. package/app/eo-framework/actions/actions/return-task-action/return-task-action.d.ts.map +1 -0
  16. package/app/eo-framework/app-shell/app-bar/app-search/app-search.component.d.ts +1 -0
  17. package/app/eo-framework/app-shell/app-bar/app-search/app-search.component.d.ts.map +1 -1
  18. package/app/eo-framework/form-elements/datetime-range/datetime-range.component.d.ts +15 -1
  19. package/app/eo-framework/form-elements/datetime-range/datetime-range.component.d.ts.map +1 -1
  20. package/app/eo-framework/form-elements/dynamic-list/dynamic-list.component.d.ts +1 -2
  21. package/app/eo-framework/form-elements/dynamic-list/dynamic-list.component.d.ts.map +1 -1
  22. package/app/eo-framework/object-form/object-form-helper.service.d.ts.map +1 -1
  23. package/app/eo-framework/ui/indexdata-summary/indexdata-summary.component.d.ts.map +1 -1
  24. package/app/eo-framework-core/api/grid.service.d.ts.map +1 -1
  25. package/assets/_default/i18n/de.json +24 -9
  26. package/assets/_default/i18n/en.json +24 -9
  27. package/assets/_default/svg/ic_rollback.svg +1 -0
  28. package/esm2022/app/eo-client/about-state/about-state.component.mjs +3 -3
  29. package/esm2022/app/eo-client/dashboard/widgets/charts-widget/charts-widget.component.mjs +6 -6
  30. package/esm2022/app/eo-client/inbox-state/inbox-state/inbox-state.component.mjs +70 -23
  31. package/esm2022/app/eo-client/process-state/process-state.component.mjs +1 -1
  32. package/esm2022/app/eo-client/settings/settings.component.mjs +9 -6
  33. package/esm2022/app/eo-framework/actions/action-menu/action-menu.component.mjs +51 -32
  34. package/esm2022/app/eo-framework/actions/action-service/action.service.mjs +54 -3
  35. package/esm2022/app/eo-framework/actions/action.module.mjs +10 -4
  36. package/esm2022/app/eo-framework/actions/actions/return-task-action/return-task/return-task.component.mjs +75 -0
  37. package/esm2022/app/eo-framework/actions/actions/return-task-action/return-task-action.mjs +43 -0
  38. package/esm2022/app/eo-framework/app-shell/app-bar/app-search/app-search.component.mjs +1 -1
  39. package/esm2022/app/eo-framework/form-elements/datetime-range/datetime-range.component.mjs +150 -11
  40. package/esm2022/app/eo-framework/form-elements/dynamic-list/dynamic-list.component.mjs +3 -4
  41. package/esm2022/app/eo-framework/object-form/object-form/form-element/form-element.component.mjs +3 -3
  42. package/esm2022/app/eo-framework/object-form/object-form-edit/object-form-edit.component.mjs +2 -2
  43. package/esm2022/app/eo-framework/object-form/object-form-helper.service.mjs +14 -2
  44. package/esm2022/app/eo-framework/shortcuts/global-shortcuts/global-shortcuts-section/global-shortcuts-section.component.mjs +2 -2
  45. package/esm2022/app/eo-framework/ui/indexdata-summary/indexdata-summary-entry/indexdata-summary-entry.component.mjs +2 -2
  46. package/esm2022/app/eo-framework/ui/indexdata-summary/indexdata-summary.component.mjs +20 -10
  47. package/esm2022/app/eo-framework-core/api/grid.service.mjs +4 -1
  48. package/fesm2022/eo-sdk-client.mjs +591 -203
  49. package/fesm2022/eo-sdk-client.mjs.map +1 -1
  50. 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 "../date/date.component";
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
- if (JSON.stringify(this.value) === JSON.stringify(value))
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: "14.0.0", version: "18.0.4", type: DatetimeRangeComponent, selector: "eo-datetime-range", inputs: { withTime: "withTime", pickerTitle: "pickerTitle", operator: "operator" }, host: { properties: { "class.swap": "this.swapInputs" }, classAttribute: "form-element-range" }, providers: [
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 <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", 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}\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.DateComponent, selector: "eo-date", inputs: ["withTime", "readonly", "onlyFutureDates"] }] }); }
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 <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", 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}\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"]}