@eo-sdk/client 11.7.0-rc.1 → 11.8.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 (61) hide show
  1. package/app/eo-client/about-state/about-state.component.d.ts.map +1 -1
  2. package/app/eo-client/dashboard/dashboard.component.d.ts +3 -2
  3. package/app/eo-client/dashboard/dashboard.component.d.ts.map +1 -1
  4. package/app/eo-client/dashboard/widgets/signature-statistics-widget/signature-statistics-setup/signature-statistics-setup.component.d.ts +30 -0
  5. package/app/eo-client/dashboard/widgets/signature-statistics-widget/signature-statistics-setup/signature-statistics-setup.component.d.ts.map +1 -0
  6. package/app/eo-client/dashboard/widgets/signature-statistics-widget/signature-statistics-widget.component.d.ts +23 -0
  7. package/app/eo-client/dashboard/widgets/signature-statistics-widget/signature-statistics-widget.component.d.ts.map +1 -0
  8. package/app/eo-client/dashboard/widgets/signature-statistics-widget/signature-statistics.interface.d.ts +20 -0
  9. package/app/eo-client/dashboard/widgets/signature-statistics-widget/signature-statistics.interface.d.ts.map +1 -0
  10. package/app/eo-client/eo-client.module.d.ts +32 -29
  11. package/app/eo-client/eo-client.module.d.ts.map +1 -1
  12. package/app/eo-client/settings/settings.component.d.ts +15 -16
  13. package/app/eo-client/settings/settings.component.d.ts.map +1 -1
  14. package/app/eo-client/settings/settings.interface.d.ts +25 -0
  15. package/app/eo-client/settings/settings.interface.d.ts.map +1 -0
  16. package/app/eo-framework/app-shell/app-bar/app-search/app-search.component.d.ts +0 -1
  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.map +1 -1
  19. package/app/eo-framework/form-elements/dynamic-list/dynamic-list.component.d.ts +78 -23
  20. package/app/eo-framework/form-elements/dynamic-list/dynamic-list.component.d.ts.map +1 -1
  21. package/app/eo-framework/form-elements/dynamic-list/dynamic-list.service.d.ts +24 -0
  22. package/app/eo-framework/form-elements/dynamic-list/dynamic-list.service.d.ts.map +1 -0
  23. package/app/eo-framework/grid/filters/dynamic-list-filter.component.d.ts +5 -5
  24. package/app/eo-framework/grid/filters/dynamic-list-filter.component.d.ts.map +1 -1
  25. package/app/eo-framework/inbox-details/inbox-details.component.d.ts.map +1 -1
  26. package/app/eo-framework/object-form/object-form-helper.service.d.ts +31 -11
  27. package/app/eo-framework/object-form/object-form-helper.service.d.ts.map +1 -1
  28. package/app/eo-framework/upload-overlay/upload-overlay.component.d.ts +51 -26
  29. package/app/eo-framework/upload-overlay/upload-overlay.component.d.ts.map +1 -1
  30. package/app/eo-framework-core/agent/agent.service.d.ts +7 -2
  31. package/app/eo-framework-core/agent/agent.service.d.ts.map +1 -1
  32. package/assets/_default/i18n/de.json +21 -3
  33. package/assets/_default/i18n/en.json +21 -3
  34. package/esm2022/app/eo-client/about-state/about-state.component.mjs +3 -3
  35. package/esm2022/app/eo-client/dashboard/dashboard.component.mjs +20 -6
  36. package/esm2022/app/eo-client/dashboard/widgets/signature-statistics-widget/signature-statistics-setup/signature-statistics-setup.component.mjs +114 -0
  37. package/esm2022/app/eo-client/dashboard/widgets/signature-statistics-widget/signature-statistics-widget.component.mjs +80 -0
  38. package/esm2022/app/eo-client/dashboard/widgets/signature-statistics-widget/signature-statistics.interface.mjs +2 -0
  39. package/esm2022/app/eo-client/eo-client.module.mjs +11 -1
  40. package/esm2022/app/eo-client/process-state/process-state.component.mjs +1 -1
  41. package/esm2022/app/eo-client/settings/settings.component.mjs +42 -24
  42. package/esm2022/app/eo-client/settings/settings.interface.mjs +2 -0
  43. package/esm2022/app/eo-framework/actions/actions/open-document-action/open-document-action.mjs +2 -2
  44. package/esm2022/app/eo-framework/app-shell/app-bar/app-search/app-search.component.mjs +7 -9
  45. package/esm2022/app/eo-framework/form-elements/datetime-range/datetime-range.component.mjs +3 -2
  46. package/esm2022/app/eo-framework/form-elements/dynamic-list/dynamic-list.component.mjs +215 -94
  47. package/esm2022/app/eo-framework/form-elements/dynamic-list/dynamic-list.service.mjs +39 -0
  48. package/esm2022/app/eo-framework/form-elements/string/string.component.mjs +2 -2
  49. package/esm2022/app/eo-framework/grid/filters/dynamic-list-filter.component.mjs +16 -22
  50. package/esm2022/app/eo-framework/inbox-details/inbox-details.component.mjs +8 -3
  51. package/esm2022/app/eo-framework/object-details/object-history/object-history.component.mjs +2 -2
  52. package/esm2022/app/eo-framework/object-form/object-form/form-element/form-element.component.mjs +3 -3
  53. package/esm2022/app/eo-framework/object-form/object-form/object-form-group/object-form-group.component.mjs +3 -3
  54. package/esm2022/app/eo-framework/object-form/object-form-edit/object-form-edit.component.mjs +3 -3
  55. package/esm2022/app/eo-framework/object-form/object-form-helper.service.mjs +43 -16
  56. package/esm2022/app/eo-framework/stored-query/stored-query-details/dynamic-property-switch/dynamic-property-switch.component.mjs +4 -3
  57. package/esm2022/app/eo-framework/upload-overlay/upload-overlay.component.mjs +163 -92
  58. package/esm2022/app/eo-framework-core/agent/agent.service.mjs +13 -2
  59. package/fesm2022/eo-sdk-client.mjs +727 -266
  60. package/fesm2022/eo-sdk-client.mjs.map +1 -1
  61. package/package.json +3 -2
@@ -1,50 +1,71 @@
1
1
  import { Component, forwardRef, Input, ViewChild } from '@angular/core';
2
2
  import { NG_VALUE_ACCESSOR, NG_VALIDATORS } from '@angular/forms';
3
+ import { debounceTime, Subject } from 'rxjs';
3
4
  import * as i0 from "@angular/core";
4
- import * as i1 from "@angular/common";
5
- import * as i2 from "@angular/forms";
6
- import * as i3 from "@ngx-translate/core";
7
- import * as i4 from "../../ui/eo-icon/eo-icon.component";
8
- import * as i5 from "../../ui/eo-dialog/eo-dialog.component";
9
- import * as i6 from "../../tree/tree.component";
10
- import * as i7 from "@yuuvis/components/autocomplete";
5
+ import * as i1 from "./dynamic-list.service";
6
+ import * as i2 from "@eo-sdk/core";
7
+ import * as i3 from "../../object-form/object-form-helper.service";
8
+ import * as i4 from "@angular/common";
9
+ import * as i5 from "@angular/forms";
10
+ import * as i6 from "@ngx-translate/core";
11
+ import * as i7 from "../../ui/eo-icon/eo-icon.component";
12
+ import * as i8 from "../../ui/eo-dialog/eo-dialog.component";
13
+ import * as i9 from "../../tree/tree.component";
14
+ import * as i10 from "@yuuvis/components/autocomplete";
11
15
  export class DynamicListComponent {
16
+ constructor(dynamicListService, localStorageService, objectFormHelperService) {
17
+ this.dynamicListService = dynamicListService;
18
+ this.localStorageService = localStorageService;
19
+ this.objectFormHelperService = objectFormHelperService;
20
+ this.hasAutocompleteUrl = false;
21
+ this.hasAutocompleteValuesCached = false;
22
+ this.autocompleteUrlValue = null;
23
+ this.valueField = 'value';
24
+ this.subEntriesField = 'entries';
25
+ this.projectsEntriesField = 'projects';
26
+ this.descriptionField = 'description';
27
+ this.display = false;
28
+ this.autocompleteValues = [];
29
+ this.previousSearchValue = "";
30
+ this.hasFormElementChanged = false;
31
+ this.autocompleteSearchValue$ = new Subject();
32
+ this.isValid = true;
33
+ this.propagateChange = (_) => {
34
+ };
35
+ // Check if the new search value is different from the previous search value and the current value.
36
+ this.autocompleteSearchValue$.pipe(debounceTime(300)).subscribe(value => {
37
+ if (value !== this.previousSearchValue && value !== this.value) {
38
+ this.previousSearchValue = value;
39
+ this.fetchAutocompleteData(value);
40
+ }
41
+ });
42
+ // Subscribe to the latest form element changes observable and the flag indicating that the form element has changed.
43
+ this.objectFormHelperService.latestFormElementChanges$
44
+ .subscribe(latestChanges => {
45
+ this.hasFormElementChanged = true;
46
+ });
47
+ }
48
+ get list() {
49
+ return this._list;
50
+ }
51
+ get selectedNodes() {
52
+ return this._selectedNodes;
53
+ }
12
54
  set filterFunction(func) {
13
- this._filterFunc = func;
14
55
  if (this._list) {
15
56
  this.buildTree();
16
57
  }
17
58
  }
18
59
  set listObject(lo) {
19
60
  if (lo) {
20
- this._list = lo;
21
- if (lo.config && lo.config.valueField) {
22
- if (this.selectedNodes) {
23
- if (this.multiselect) {
24
- this.selectedNodes = this.selectedNodes.map(sn => {
25
- sn[lo.config.valueField] = sn[this.valueField];
26
- sn['value'] = sn[this.valueField];
27
- return sn;
28
- });
29
- }
30
- else {
31
- this.selectedNodes[lo.config.valueField] = this.selectedNodes[this.valueField];
32
- this.selectedNodes['value'] = this.selectedNodes[this.valueField];
33
- }
34
- }
35
- this.valueField = lo.config.valueField;
36
- }
37
- if (lo.config && lo.config.descriptionField) {
38
- this.descriptionField = lo.config.descriptionField;
39
- }
40
- if (lo.config && lo.config.subEntriesField) {
41
- this.subEntriesField = lo.config.subEntriesField;
42
- }
43
- this.buildTree();
61
+ this.processListObject(lo);
44
62
  }
45
63
  }
46
- get list() {
47
- return this._list;
64
+ set autocompleteUrl(url) {
65
+ if (url) {
66
+ this.hasAutocompleteUrl = true;
67
+ this.autocompleteUrlValue = url;
68
+ }
48
69
  }
49
70
  set selectedNodes(n) {
50
71
  if (n && !Array.isArray(n)) {
@@ -52,23 +73,46 @@ export class DynamicListComponent {
52
73
  }
53
74
  this._selectedNodes = structuredClone(n);
54
75
  }
55
- get selectedNodes() {
56
- return this._selectedNodes;
57
- }
58
- constructor() {
59
- this.valueField = 'value';
60
- this.subEntriesField = 'entries';
61
- this.projectsEntriesField = 'projects';
62
- this.descriptionField = 'description';
63
- this.display = false;
64
- this.dirty = false;
65
- this.isValid = true;
66
- this.autocompleteValues = [];
67
- this.propagateChange = (_) => {
68
- };
76
+ /**
77
+ * Fetches autocomplete data based on the provided search value.
78
+ *
79
+ * If the autocomplete values are cached and there is no search value or form element change,
80
+ * it retrieves the cached values from local storage. Otherwise, it makes an HTTP request to fetch
81
+ * the autocomplete data.
82
+ *
83
+ * @param {string} [searchValue=null] - The search value used to filter the autocomplete results.
84
+ * @returns {void}
85
+ */
86
+ fetchAutocompleteData(searchValue = null) {
87
+ let autocompelteListValues = {};
88
+ let url = this.autocompleteUrlValue;
89
+ if (this.hasAutocompleteValuesCached && !searchValue && !this.hasFormElementChanged) {
90
+ autocompelteListValues = this.localStorageService.getItem('autocomplete_' + this.formControlName);
91
+ this.processListObject(autocompelteListValues);
92
+ }
93
+ else {
94
+ let params = {};
95
+ if (searchValue) {
96
+ params['query'] = searchValue;
97
+ }
98
+ if (this.situation) {
99
+ params['situation'] = this.situation;
100
+ }
101
+ this.dynamicListService.getAutocompleteData(url, params).subscribe((data) => {
102
+ this.setFormControlValue();
103
+ if (!searchValue) {
104
+ this.hasAutocompleteValuesCached = true;
105
+ this.localStorageService.setItem('autocomplete_' + this.formControlName, data);
106
+ }
107
+ this.processListObject(data);
108
+ if (searchValue) {
109
+ this.filterAutocompleteResults(searchValue);
110
+ }
111
+ this.hasFormElementChanged = false;
112
+ });
113
+ }
69
114
  }
70
115
  writeValue(value) {
71
- this.dirty = false;
72
116
  this.value = value || null;
73
117
  const values = !this.value || Array.isArray(this.value) ? this.value || [] : [this.value];
74
118
  if (value === null || value === undefined) {
@@ -122,11 +166,97 @@ export class DynamicListComponent {
122
166
  this.isValid = true;
123
167
  this.setFormControlValue(wasInvalid);
124
168
  }
125
- onClear() {
126
- if (!this.multiselect) {
169
+ /**
170
+ * Handles the autocomplete functionality based on the provided search term.
171
+ *
172
+ * If `selectedNodes` is set, it resets and updates `selectedNodes` with the search term.
173
+ * If `hasAutocompleteUrl` is true, it triggers an autocomplete search via an observable.
174
+ * Otherwise, it filters the autocomplete results locally.
175
+ *
176
+ * @param {string} term - The search term used for autocomplete.
177
+ * @returns {void}
178
+ */
179
+ autocompleteFn(term) {
180
+ if (this.selectedNodes) {
127
181
  this.selectedNodes = null;
182
+ this.selectedNodes = {
183
+ value: term,
184
+ data: {}
185
+ };
186
+ }
187
+ if (this.hasAutocompleteUrl) {
188
+ this.autocompleteSearchValue$.next(term);
189
+ }
190
+ else {
191
+ this.filterAutocompleteResults(term);
192
+ }
193
+ }
194
+ showDialog(event, display = true) {
195
+ if (event) {
196
+ event.stopPropagation();
197
+ event.preventDefault();
198
+ //ignore synthetized events on enter
199
+ if (event.type === 'click' && event.detail === 0) {
200
+ return;
201
+ }
202
+ if (this.hasAutocompleteUrl) {
203
+ this.fetchAutocompleteData();
204
+ }
205
+ }
206
+ this.display = !!display;
207
+ }
208
+ ngOnInit() {
209
+ if (this.situation === 'SEARCH' && !this.hasAutocompleteUrl) {
210
+ this.multiselect = true;
211
+ }
212
+ }
213
+ validate(c) {
214
+ return (this.isValid) ? null : {
215
+ dynamiclist: {
216
+ valid: false,
217
+ },
218
+ };
219
+ }
220
+ ngOnDestroy() {
221
+ this.localStorageService.removeItem('autocomplete_' + this.formControlName);
222
+ if (this.formElementChangesSubscription) {
223
+ this.formElementChangesSubscription.unsubscribe();
128
224
  }
129
- this.setFormControlValue();
225
+ }
226
+ /**
227
+ * Processes the given list object and updates the component's state accordingly.
228
+ *
229
+ * This method updates the internal list, selected nodes, and various configuration fields
230
+ * based on the provided list object. It also triggers the building of the tree structure.
231
+ *
232
+ * @param {AutocompleteResponse} listObject - The list object containing configuration and data.
233
+ * @private
234
+ */
235
+ processListObject(listObject) {
236
+ this._list = listObject;
237
+ if (listObject.config && listObject.config.valueField) {
238
+ if (this.selectedNodes) {
239
+ if (this.multiselect) {
240
+ this.selectedNodes = this.selectedNodes.map(sn => {
241
+ sn[listObject.config.valueField] = sn[this.valueField];
242
+ sn['value'] = sn[this.valueField];
243
+ return sn;
244
+ });
245
+ }
246
+ else {
247
+ this.selectedNodes[listObject.config.valueField] = this.selectedNodes[this.valueField];
248
+ this.selectedNodes['value'] = this.selectedNodes[this.valueField];
249
+ }
250
+ }
251
+ this.valueField = listObject.config.valueField;
252
+ }
253
+ if (listObject.config && listObject.config.descriptionField) {
254
+ this.descriptionField = listObject.config.descriptionField;
255
+ }
256
+ if (listObject.config && listObject.config.subEntriesField) {
257
+ this.subEntriesField = listObject.config.subEntriesField;
258
+ }
259
+ this.buildTree();
130
260
  }
131
261
  /**
132
262
  * Sets and propagates the form controls value based on the components inner values. Propagates only
@@ -205,22 +335,8 @@ export class DynamicListComponent {
205
335
  }
206
336
  }
207
337
  }
208
- autocompleteFn(term) {
209
- this.autocompleteRes = this.autocompleteValues.filter((acNode) => {
210
- if (this.filterFunction && !this.filterFunction(acNode.data)) {
211
- return false;
212
- }
213
- if (this.multiselect) {
214
- if (this.selectedNodes.find((node) => acNode.data[this.valueField] === node.data[this.valueField])) {
215
- return false;
216
- }
217
- }
218
- return acNode.data[this.valueField].toString().toLowerCase().indexOf(term.toString().toLowerCase()) !== -1 ||
219
- (acNode.data[this.descriptionField] && acNode.data[this.descriptionField].toString().toLowerCase().indexOf(term.toString().toLowerCase()) !== -1);
220
- }).slice(0, 10);
221
- }
222
338
  listEntryToTreeNode(listEntry) {
223
- let selectable = false;
339
+ let selectable;
224
340
  if (this._list && this._list.config && this._list.config.allelementsselectable) {
225
341
  selectable = true;
226
342
  }
@@ -242,31 +358,30 @@ export class DynamicListComponent {
242
358
  treeNode[this.subEntriesField] = listEntry[this.subEntriesField];
243
359
  return treeNode;
244
360
  }
245
- showDialog(event, display = true) {
246
- if (event) {
247
- event.stopPropagation();
248
- event.preventDefault();
249
- //ignore synthetized events on enter
250
- if (event.type === 'click' && event.detail === 0) {
251
- return;
361
+ /**
362
+ * Filters the autocomplete results based on the provided search term.
363
+ *
364
+ * The method filters the `autocompleteValues` array to find nodes that match the search term.
365
+ * It also applies additional filtering based on the `filterFunction` and `multiselect` properties.
366
+ *
367
+ * @param {string} term - The search term used to filter the autocomplete results.
368
+ */
369
+ filterAutocompleteResults(term) {
370
+ this.autocompleteRes = this.autocompleteValues.filter((acNode) => {
371
+ if (this.filterFunction && !this.filterFunction(acNode.data)) {
372
+ return false;
252
373
  }
253
- }
254
- this.display = !!display;
255
- }
256
- ngOnInit() {
257
- if (this.situation === 'SEARCH') {
258
- this.multiselect = true;
259
- }
260
- }
261
- validate(c) {
262
- return (this.isValid) ? null : {
263
- dynamiclist: {
264
- valid: false,
265
- },
266
- };
374
+ if (this.multiselect) {
375
+ if (this.selectedNodes.find((node) => acNode.data[this.valueField] === node.data[this.valueField])) {
376
+ return false;
377
+ }
378
+ }
379
+ return acNode.data[this.valueField].toString().toLowerCase().indexOf(term.toString().toLowerCase()) !== -1 ||
380
+ (acNode.data[this.descriptionField] && acNode.data[this.descriptionField].toString().toLowerCase().indexOf(term.toString().toLowerCase()) !== -1);
381
+ }).slice(0, 10);
267
382
  }
268
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.4", ngImport: i0, type: DynamicListComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
269
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.0.4", type: DynamicListComponent, selector: "eo-dynamic-list", inputs: { situation: "situation", multiselect: "multiselect", pickerTitle: "pickerTitle", readonly: "readonly", filterFunction: "filterFunction", listObject: "listObject" }, providers: [
383
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.4", ngImport: i0, type: DynamicListComponent, deps: [{ token: i1.DynamicListService }, { token: i2.LocalStorageService }, { token: i3.ObjectFormHelperService }], target: i0.ɵɵFactoryTarget.Component }); }
384
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.0.4", type: DynamicListComponent, selector: "eo-dynamic-list", inputs: { situation: "situation", multiselect: "multiselect", pickerTitle: "pickerTitle", readonly: "readonly", formControlName: "formControlName", formElementChanges: "formElementChanges", filterFunction: "filterFunction", listObject: "listObject", autocompleteUrl: "autocompleteUrl" }, providers: [
270
385
  {
271
386
  provide: NG_VALUE_ACCESSOR,
272
387
  useExisting: forwardRef(() => DynamicListComponent),
@@ -277,7 +392,7 @@ export class DynamicListComponent {
277
392
  useExisting: forwardRef(() => DynamicListComponent),
278
393
  multi: true,
279
394
  }
280
- ], viewQueries: [{ propertyName: "autoCompleteInput", first: true, predicate: ["autocomplete"], descendants: true }, { propertyName: "autoCompleteButton", first: true, predicate: ["button"], descendants: true }], ngImport: i0, template: "<eo-dialog #listDialog [title]=\"pickerTitle\" [visible]=\"display\" [ngClass]=\"{empty: !(list?.entries?.length)}\"\n [styleClass]=\"'dynlist-dialog'\" (hide)=\"display = false\">\n\n <eo-tree [tree]=\"tree\" *ngIf=\"display && tree\" [isDisplayed]=\"display\" [options]=\"{multiselect: multiselect}\"\n [(ngModel)]=\"selectedNodes\" (keyup.enter)=\"showDialog($event, false)\"\n (ngModelChange)=\"onTreeSelectionChanged($event)\">\n </eo-tree>\n\n <div class=\"empty\" *ngIf=\"!(list?.entries?.length)\">\n <div translate>eo.form.property.dynamic.list.empty</div>\n </div>\n</eo-dialog>\n\n<div class=\"eo-dynamic-list\" [ngClass]=\"{full: selectedNodes && selectedNodes.length === autocompleteValues.length}\">\n\n <yvc-autocomplete [(ngModel)]=\"selectedNodes\" #autocomplete (suggestionSelect)=\"onAutoCompleteSelect($event)\"\n [disabled]=\"readonly\" (suggestionUnselect)=\"onAutoCompleteUnselect($event)\" [forceSelection]=\"true\"\n [autocompleteValues]=\"autocompleteRes\" (ngModelChange)=\"onTreeSelectionChanged($event)\" field=\"{{valueField}}\" (autocompleteFnc)=\"autocompleteFn($event)\"\n [multiple]=\"multiselect\">\n\n <ng-template let-item #chipTemplate>\n <div>\n <div class=\"value\">{{item[valueField]}}</div>\n </div>\n </ng-template>\n\n <ng-template #autocompleteOptionTemplate let-item>\n <div>\n <div class=\"value\">{{item[valueField]}}</div>\n <div class=\"description\" style=\"font-style: italic; color: var(--text-color-caption)\">{{item[descriptionField]}}</div>\n </div>\n </ng-template>\n </yvc-autocomplete>\n\n <button #button class=\"ui-button\" *ngIf=\"!readonly\" [disabled]=\"readonly\" (click)=\"showDialog($event, $event.detail)\"\n (keyup.arrowDown)=\"showDialog($event)\" (keyup.enter)=\"showDialog($event)\" (keyup.space)=\"showDialog($event)\">\n <eo-icon [iconSrc]=\"'assets/_default/svg/ic_arrow_down.svg'\"></eo-icon>\n </button>\n</div>", styles: [".rtl .form-element .form-field>div label{text-align:left!important}:host .eo-dynamic-list{display:flex;align-items:center;justify-content:space-between}:host .eo-dynamic-list .description{padding-left:0!important}:host .eo-dynamic-list yvc-autocomplete{flex:1 1 auto;border:0;outline:0}:host .eo-dynamic-list>button{flex:0 0 auto;padding:0}:host .eo-dynamic-list>button eo-icon{width:16px;height:16px;margin:auto}:host .eo-dynamic-list.full ::ng-deep yvc-autocomplete .inputToken{display:none}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i3.TranslateDirective, selector: "[translate],[ngx-translate]", inputs: ["translate", "translateParams"] }, { kind: "component", type: i4.EoIconComponent, selector: "eo-icon", inputs: ["objectType", "iconId", "iconSrc", "badge", "iconTitle"] }, { kind: "component", type: i5.EoDialogComponent, selector: "eo-dialog", inputs: ["hasPreviewFile", "title", "subtitle", "styleClass", "dirtyCheck", "minWidth", "minHeight", "height", "width", "focusOnShow", "align", "isFormTable", "showPreview", "visible"], outputs: ["onTogglePreview", "visibleChange", "hide", "show"] }, { kind: "component", type: i6.TreeComponent, selector: "eo-tree", inputs: ["options", "isDisplayed", "readonly", "emptyMessage", "selectionKey", "highlightedNodes", "tree", "treeUpdate"], outputs: ["expandedNodesChanged", "onSelected"] }, { kind: "component", type: i7.AutoComplete, selector: "yvc-autocomplete", inputs: ["field", "placeholder", "minLength", "multiple", "typeahead", "distinctValues", "forceSelection", "autocompleteValues", "disabled"], outputs: ["autocompleteFnc", "blur", "focus", "suggestionUnselect", "suggestionSelect"] }] }); }
395
+ ], viewQueries: [{ propertyName: "autoCompleteInput", first: true, predicate: ["autocomplete"], descendants: true }, { propertyName: "autoCompleteButton", first: true, predicate: ["button"], descendants: true }], ngImport: i0, template: "<eo-dialog #listDialog [title]=\"pickerTitle\" [visible]=\"display\" [ngClass]=\"{empty: !(list?.entries?.length)}\"\n [styleClass]=\"'dynlist-dialog'\" (hide)=\"display = false\">\n\n <eo-tree [tree]=\"tree\" *ngIf=\"display && tree\" [isDisplayed]=\"display\" [options]=\"{multiselect: multiselect}\"\n [(ngModel)]=\"selectedNodes\" (keyup.enter)=\"showDialog($event, false)\"\n (ngModelChange)=\"onTreeSelectionChanged($event)\">\n </eo-tree>\n\n <div class=\"empty\" *ngIf=\"!(list?.entries?.length)\">\n <div translate>eo.form.property.dynamic.list.empty</div>\n </div>\n</eo-dialog>\n\n<div class=\"eo-dynamic-list\" [ngClass]=\"{full: selectedNodes && selectedNodes.length === autocompleteValues.length}\">\n\n <yvc-autocomplete [(ngModel)]=\"selectedNodes\" #autocomplete (suggestionSelect)=\"onAutoCompleteSelect($event)\"\n [disabled]=\"readonly\" (suggestionUnselect)=\"onAutoCompleteUnselect($event)\" [forceSelection]=\"true\"\n [autocompleteValues]=\"autocompleteRes\" (ngModelChange)=\"onTreeSelectionChanged($event)\" field=\"{{valueField}}\" (autocompleteFnc)=\"autocompleteFn($event)\"\n [multiple]=\"multiselect\">\n\n <ng-template let-item #chipTemplate>\n <div>\n <div class=\"value\">{{item[valueField]}}</div>\n </div>\n </ng-template>\n\n <ng-template #autocompleteOptionTemplate let-item>\n <div>\n <div class=\"value\">{{item[valueField]}}</div>\n <div class=\"description\" style=\"font-style: italic; color: var(--text-color-caption)\">{{item[descriptionField]}}</div>\n </div>\n </ng-template>\n </yvc-autocomplete>\n\n <button #button class=\"ui-button\" *ngIf=\"!readonly\" [disabled]=\"readonly\" (click)=\"showDialog($event, !!$event.detail)\"\n (keyup.arrowDown)=\"showDialog($event)\" (keyup.enter)=\"showDialog($event)\" (keyup.space)=\"showDialog($event)\">\n <eo-icon [iconSrc]=\"'assets/_default/svg/ic_arrow_down.svg'\"></eo-icon>\n </button>\n</div>\n", styles: [".rtl .form-element .form-field>div label{text-align:left!important}:host .eo-dynamic-list{display:flex;align-items:center;justify-content:space-between}:host .eo-dynamic-list .description{padding-left:0!important}:host .eo-dynamic-list yvc-autocomplete{flex:1 1 auto;border:0;outline:0}:host .eo-dynamic-list>button{flex:0 0 auto;padding:0}:host .eo-dynamic-list>button eo-icon{width:16px;height:16px;margin:auto}:host .eo-dynamic-list.full ::ng-deep yvc-autocomplete .inputToken{display:none}\n"], dependencies: [{ kind: "directive", type: i4.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i5.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i6.TranslateDirective, selector: "[translate],[ngx-translate]", inputs: ["translate", "translateParams"] }, { kind: "component", type: i7.EoIconComponent, selector: "eo-icon", inputs: ["objectType", "iconId", "iconSrc", "badge", "iconTitle"] }, { kind: "component", type: i8.EoDialogComponent, selector: "eo-dialog", inputs: ["hasPreviewFile", "title", "subtitle", "styleClass", "dirtyCheck", "minWidth", "minHeight", "height", "width", "focusOnShow", "align", "isFormTable", "showPreview", "visible"], outputs: ["onTogglePreview", "visibleChange", "hide", "show"] }, { kind: "component", type: i9.TreeComponent, selector: "eo-tree", inputs: ["options", "isDisplayed", "readonly", "emptyMessage", "selectionKey", "highlightedNodes", "tree", "treeUpdate"], outputs: ["expandedNodesChanged", "onSelected"] }, { kind: "component", type: i10.AutoComplete, selector: "yvc-autocomplete", inputs: ["field", "placeholder", "minLength", "multiple", "typeahead", "distinctValues", "forceSelection", "autocompleteValues", "disabled"], outputs: ["autocompleteFnc", "blur", "focus", "suggestionUnselect", "suggestionSelect"] }] }); }
281
396
  }
282
397
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.4", ngImport: i0, type: DynamicListComponent, decorators: [{
283
398
  type: Component,
@@ -292,8 +407,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.4", ngImpor
292
407
  useExisting: forwardRef(() => DynamicListComponent),
293
408
  multi: true,
294
409
  }
295
- ], template: "<eo-dialog #listDialog [title]=\"pickerTitle\" [visible]=\"display\" [ngClass]=\"{empty: !(list?.entries?.length)}\"\n [styleClass]=\"'dynlist-dialog'\" (hide)=\"display = false\">\n\n <eo-tree [tree]=\"tree\" *ngIf=\"display && tree\" [isDisplayed]=\"display\" [options]=\"{multiselect: multiselect}\"\n [(ngModel)]=\"selectedNodes\" (keyup.enter)=\"showDialog($event, false)\"\n (ngModelChange)=\"onTreeSelectionChanged($event)\">\n </eo-tree>\n\n <div class=\"empty\" *ngIf=\"!(list?.entries?.length)\">\n <div translate>eo.form.property.dynamic.list.empty</div>\n </div>\n</eo-dialog>\n\n<div class=\"eo-dynamic-list\" [ngClass]=\"{full: selectedNodes && selectedNodes.length === autocompleteValues.length}\">\n\n <yvc-autocomplete [(ngModel)]=\"selectedNodes\" #autocomplete (suggestionSelect)=\"onAutoCompleteSelect($event)\"\n [disabled]=\"readonly\" (suggestionUnselect)=\"onAutoCompleteUnselect($event)\" [forceSelection]=\"true\"\n [autocompleteValues]=\"autocompleteRes\" (ngModelChange)=\"onTreeSelectionChanged($event)\" field=\"{{valueField}}\" (autocompleteFnc)=\"autocompleteFn($event)\"\n [multiple]=\"multiselect\">\n\n <ng-template let-item #chipTemplate>\n <div>\n <div class=\"value\">{{item[valueField]}}</div>\n </div>\n </ng-template>\n\n <ng-template #autocompleteOptionTemplate let-item>\n <div>\n <div class=\"value\">{{item[valueField]}}</div>\n <div class=\"description\" style=\"font-style: italic; color: var(--text-color-caption)\">{{item[descriptionField]}}</div>\n </div>\n </ng-template>\n </yvc-autocomplete>\n\n <button #button class=\"ui-button\" *ngIf=\"!readonly\" [disabled]=\"readonly\" (click)=\"showDialog($event, $event.detail)\"\n (keyup.arrowDown)=\"showDialog($event)\" (keyup.enter)=\"showDialog($event)\" (keyup.space)=\"showDialog($event)\">\n <eo-icon [iconSrc]=\"'assets/_default/svg/ic_arrow_down.svg'\"></eo-icon>\n </button>\n</div>", styles: [".rtl .form-element .form-field>div label{text-align:left!important}:host .eo-dynamic-list{display:flex;align-items:center;justify-content:space-between}:host .eo-dynamic-list .description{padding-left:0!important}:host .eo-dynamic-list yvc-autocomplete{flex:1 1 auto;border:0;outline:0}:host .eo-dynamic-list>button{flex:0 0 auto;padding:0}:host .eo-dynamic-list>button eo-icon{width:16px;height:16px;margin:auto}:host .eo-dynamic-list.full ::ng-deep yvc-autocomplete .inputToken{display:none}\n"] }]
296
- }], ctorParameters: () => [], propDecorators: { autoCompleteInput: [{
410
+ ], template: "<eo-dialog #listDialog [title]=\"pickerTitle\" [visible]=\"display\" [ngClass]=\"{empty: !(list?.entries?.length)}\"\n [styleClass]=\"'dynlist-dialog'\" (hide)=\"display = false\">\n\n <eo-tree [tree]=\"tree\" *ngIf=\"display && tree\" [isDisplayed]=\"display\" [options]=\"{multiselect: multiselect}\"\n [(ngModel)]=\"selectedNodes\" (keyup.enter)=\"showDialog($event, false)\"\n (ngModelChange)=\"onTreeSelectionChanged($event)\">\n </eo-tree>\n\n <div class=\"empty\" *ngIf=\"!(list?.entries?.length)\">\n <div translate>eo.form.property.dynamic.list.empty</div>\n </div>\n</eo-dialog>\n\n<div class=\"eo-dynamic-list\" [ngClass]=\"{full: selectedNodes && selectedNodes.length === autocompleteValues.length}\">\n\n <yvc-autocomplete [(ngModel)]=\"selectedNodes\" #autocomplete (suggestionSelect)=\"onAutoCompleteSelect($event)\"\n [disabled]=\"readonly\" (suggestionUnselect)=\"onAutoCompleteUnselect($event)\" [forceSelection]=\"true\"\n [autocompleteValues]=\"autocompleteRes\" (ngModelChange)=\"onTreeSelectionChanged($event)\" field=\"{{valueField}}\" (autocompleteFnc)=\"autocompleteFn($event)\"\n [multiple]=\"multiselect\">\n\n <ng-template let-item #chipTemplate>\n <div>\n <div class=\"value\">{{item[valueField]}}</div>\n </div>\n </ng-template>\n\n <ng-template #autocompleteOptionTemplate let-item>\n <div>\n <div class=\"value\">{{item[valueField]}}</div>\n <div class=\"description\" style=\"font-style: italic; color: var(--text-color-caption)\">{{item[descriptionField]}}</div>\n </div>\n </ng-template>\n </yvc-autocomplete>\n\n <button #button class=\"ui-button\" *ngIf=\"!readonly\" [disabled]=\"readonly\" (click)=\"showDialog($event, !!$event.detail)\"\n (keyup.arrowDown)=\"showDialog($event)\" (keyup.enter)=\"showDialog($event)\" (keyup.space)=\"showDialog($event)\">\n <eo-icon [iconSrc]=\"'assets/_default/svg/ic_arrow_down.svg'\"></eo-icon>\n </button>\n</div>\n", styles: [".rtl .form-element .form-field>div label{text-align:left!important}:host .eo-dynamic-list{display:flex;align-items:center;justify-content:space-between}:host .eo-dynamic-list .description{padding-left:0!important}:host .eo-dynamic-list yvc-autocomplete{flex:1 1 auto;border:0;outline:0}:host .eo-dynamic-list>button{flex:0 0 auto;padding:0}:host .eo-dynamic-list>button eo-icon{width:16px;height:16px;margin:auto}:host .eo-dynamic-list.full ::ng-deep yvc-autocomplete .inputToken{display:none}\n"] }]
411
+ }], ctorParameters: () => [{ type: i1.DynamicListService }, { type: i2.LocalStorageService }, { type: i3.ObjectFormHelperService }], propDecorators: { autoCompleteInput: [{
297
412
  type: ViewChild,
298
413
  args: ['autocomplete']
299
414
  }], autoCompleteButton: [{
@@ -307,11 +422,17 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.4", ngImpor
307
422
  type: Input
308
423
  }], readonly: [{
309
424
  type: Input
425
+ }], formControlName: [{
426
+ type: Input
427
+ }], formElementChanges: [{
428
+ type: Input
310
429
  }], filterFunction: [{
311
430
  type: Input,
312
431
  args: ['filterFunction']
313
432
  }], listObject: [{
314
433
  type: Input,
315
434
  args: ['listObject']
435
+ }], autocompleteUrl: [{
436
+ type: Input
316
437
  }] } });
317
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic-list.component.js","sourceRoot":"","sources":["../../../../../../../../src/app/eo-framework/form-elements/dynamic-list/dynamic-list.component.ts","../../../../../../../../src/app/eo-framework/form-elements/dynamic-list/dynamic-list.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, forwardRef, OnInit, Input, ViewChild, ElementRef} from '@angular/core';\nimport {\n  UntypedFormControl,\n  ControlValueAccessor,\n  Validator,\n  NG_VALUE_ACCESSOR,\n  NG_VALIDATORS\n} from '@angular/forms';\nimport {AutoComplete} from '@yuuvis/components/autocomplete';\nimport {TreeNode} from '../../tree/tree.component.interface';\n\n\n@Component({\n  selector: 'eo-dynamic-list',\n  templateUrl: './dynamic-list.component.html',\n  styleUrls: ['./dynamic-list.component.scss'],\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => DynamicListComponent),\n      multi: true\n    },\n    {\n      provide: NG_VALIDATORS,\n      useExisting: forwardRef(() => DynamicListComponent),\n      multi: true,\n    }\n  ]\n})\nexport class DynamicListComponent implements ControlValueAccessor, Validator, OnInit {\n\n  @ViewChild('autocomplete') autoCompleteInput: AutoComplete;\n  @ViewChild('button') autoCompleteButton;\n\n  @Input() situation: string;\n  @Input() multiselect: boolean;\n  @Input() pickerTitle: string;\n  @Input() readonly: boolean;\n\n  private _filterFunc: Function;\n\n  @Input('filterFunction')\n  set filterFunction(func: Function) {\n    this._filterFunc = func;\n    if (this._list) {\n      this.buildTree();\n    }\n  }\n\n  private _list: any;\n\n  @Input('listObject')\n  set listObject(lo: any) {\n    if (lo) {\n      this._list = lo;\n      if (lo.config && lo.config.valueField) {\n        if (this.selectedNodes) {\n          if (this.multiselect) {\n            this.selectedNodes = this.selectedNodes.map(sn => {\n              sn[lo.config.valueField] = sn[this.valueField];\n              sn['value'] = sn[this.valueField];\n              return sn;\n            });\n          } else {\n            this.selectedNodes[lo.config.valueField] = this.selectedNodes[this.valueField];\n            this.selectedNodes['value'] = this.selectedNodes[this.valueField];\n          }\n        }\n        this.valueField = lo.config.valueField;\n      }\n      if (lo.config && lo.config.descriptionField) {\n        this.descriptionField = lo.config.descriptionField;\n      }\n      if (lo.config && lo.config.subEntriesField) {\n        this.subEntriesField = lo.config.subEntriesField;\n      }\n      this.buildTree();\n    }\n  }\n\n  get list() {\n    return this._list;\n  }\n\n  valueField = 'value';\n  subEntriesField = 'entries';\n  projectsEntriesField = 'projects';\n  descriptionField = 'description';\n  display = false;\n  private dirty = false;\n  private isValid = true;\n  value;\n  tree: TreeNode[];\n  private _selectedNodes: any;\n  set selectedNodes(n: any) {\n    if (n && !Array.isArray(n)) {\n      this.autocompleteFn(n[this._list?.config?.valueField || 'value'] || n.name);\n    }\n    this._selectedNodes = structuredClone(n);\n  }\n  get selectedNodes() {\n    return this._selectedNodes;\n  }\n  autocompleteRes;\n  autocompleteValues: TreeNode[] = [];\n\n  constructor() {\n  }\n\n  propagateChange = (_: any) => {\n  }\n\n  writeValue(value: any): void {\n    this.dirty = false;\n    this.value = value || null;\n    const values = !this.value || Array.isArray(this.value) ? this.value || [] : [this.value];\n    if (value === null || value === undefined) {\n      if (this.multiselect) {\n        this.selectedNodes = [];\n      } else {\n        this.selectedNodes = null;\n      }\n    } else {\n      if (this.multiselect) {\n        this.selectedNodes = values.map(v => {\n          let node = {};\n          node[this.valueField] = v;\n          node['value'] = v;\n          return node;\n        });\n      } else {\n        let node = {};\n        node[this.valueField] = value;\n        node['value'] = value;\n        this.selectedNodes = node;\n      }\n    }\n    const nodes = !this.selectedNodes || Array.isArray(this.selectedNodes) ? this.selectedNodes || [] : [this.selectedNodes];\n\n    if (this._list && (nodes.length !== values.length || nodes.some((n, i) => n[this.valueField] !== values[i]))) {\n      this.buildTree();\n    }\n  }\n\n  registerOnChange(fn: any): void {\n    this.propagateChange = fn;\n  }\n\n  registerOnTouched(fn: any): void {\n  }\n\n  onAutoCompleteSelect(node?) {\n    const wasInvalid = !this.isValid;\n    this.isValid = true;\n    this.setFormControlValue(wasInvalid);\n  }\n\n  onAutoCompleteUnselect(node?) {\n    this.selectedNodes = this.selectedNodes.filter((sNode) => sNode.value !== node.value);\n    this.setFormControlValue();\n  }\n\n  onTreeSelectionChanged(evt) {\n    if (!this.multiselect) {\n      this.display = false;\n    }\n    const wasInvalid = !this.isValid;\n    this.isValid = true;\n    this.setFormControlValue(wasInvalid);\n  }\n\n  onClear() {\n    if (!this.multiselect) {\n      this.selectedNodes = null;\n    }\n    this.setFormControlValue();\n  }\n\n  /**\n   * Sets and propagates the form controls value based on the components inner values. Propagates only\n   * when the value has changed.\n   * @param forcePropagation - forces propagation even if the value hasn't been changed\n   */\n  private setFormControlValue(forcePropagation?: boolean) {\n    let v;\n    let changed: boolean;\n    if (this.multiselect) {\n      v = this.selectedNodes ? this.selectedNodes.map((node) => node[this.valueField]) : [];\n      changed = !this.value || !(v.length === this.value.length && v.every((val) => this.value.some((curVal) => curVal === val)));\n    } else {\n      v = this.selectedNodes ? this.selectedNodes.data[this.valueField] : null;\n      changed = v !== this.value;\n    }\n    if (changed || forcePropagation) {\n      this.value = v;\n      this.propagateChange(this.value);\n    }\n  }\n\n  private buildTree() {\n    this.autocompleteValues = [];\n    let tree: TreeNode[] = [];\n    for (let i = 0; i < this._list.entries.length; i++) {\n      this.addTreeNode(tree, this._list.entries[i]);\n    }\n    this.tree = tree;\n  }\n\n  private addTreeNode(parentNode: TreeNode[], listEntry) {\n    if (this.filterFunction && !this.filterFunction(listEntry)) {\n      return;\n    }\n    let node: TreeNode = this.listEntryToTreeNode(listEntry);\n    if (node.selectable) {\n      this.autocompleteValues.push(node);\n    }\n    if (listEntry[this.subEntriesField]) {\n      node.children = [];\n      for (let i = 0; i < listEntry[this.subEntriesField].length; i++) {\n        this.addTreeNode(node.children, listEntry[this.subEntriesField][i]);\n      }\n    }\n    if (listEntry[this.projectsEntriesField]) {\n      for (let i = 0; i < listEntry[this.projectsEntriesField].length; i++) {\n        this.addTreeNode(node.children, listEntry[this.projectsEntriesField][i]);\n      }\n    }\n    this.checkSelected(node);\n    parentNode.push(node);\n  }\n\n  private checkSelected(node: TreeNode) {\n    if (!this.value) {\n      return;\n    }\n    if (this.multiselect) {\n      for (let i = 0; i < this.value.length; i++) {\n        const isTreeNodeValueInValue = node.data[this.valueField] === this.value[i];\n        if (isTreeNodeValueInValue) {\n          const selectedNodeThatHasValue = this.selectedNodes.find(sN => sN[this.valueField] === this.value[i]);\n          if (!selectedNodeThatHasValue) {\n            node.selected = true;\n            this.selectedNodes.push(node);\n          } else {\n            selectedNodeThatHasValue.selected = true;\n          }\n        }\n      }\n    } else {\n      if (node.data[this.valueField] === this.value) {\n        node.selected = true;\n        this.selectedNodes = node;\n      }\n    }\n  }\n\n  autocompleteFn(term: string) {\n\n    this.autocompleteRes = this.autocompleteValues.filter((acNode) => {\n      if (this.filterFunction && !this.filterFunction(acNode.data)) {\n        return false;\n      }\n      if (this.multiselect) {\n        if (this.selectedNodes.find((node) => acNode.data[this.valueField] === node.data[this.valueField])) {\n          return false;\n        }\n      }\n      return acNode.data[this.valueField].toString().toLowerCase().indexOf(term.toString().toLowerCase()) !== -1 ||\n        (acNode.data[this.descriptionField] && acNode.data[this.descriptionField].toString().toLowerCase().indexOf(term.toString().toLowerCase()) !== -1);\n    }).slice(0, 10);\n  }\n\n  private listEntryToTreeNode(listEntry): TreeNode {\n    let selectable = false;\n    if (this._list && this._list.config && this._list.config.allelementsselectable) {\n      selectable = true;\n    } else {\n      selectable = !(listEntry[this.subEntriesField] && listEntry[this.subEntriesField].length > 0);\n    }\n\n    let treeNode = {\n      id: listEntry.id ? listEntry.id : listEntry[this.valueField],\n      name: listEntry[this.descriptionField] ? listEntry[this.valueField] + ' (' + listEntry[this.descriptionField] + ')' : listEntry[this.valueField],\n      children: [],\n      expanded: false,\n      selected: false,\n      selectable: selectable,\n      data: listEntry\n    };\n    treeNode[this.valueField] = listEntry[this.valueField];\n    treeNode.data['value'] = listEntry[this.valueField];\n    treeNode[this.descriptionField] = listEntry[this.descriptionField];\n    treeNode[this.subEntriesField] = listEntry[this.subEntriesField];\n\n    return treeNode;\n  }\n\n  showDialog(event?, display = true) {\n    if (event) {\n      event.stopPropagation();\n      event.preventDefault();\n      //ignore synthetized events on enter\n      if (event.type === 'click' && event.detail === 0) {\n        return;\n      }\n    }\n    this.display = !!display;\n  }\n\n  ngOnInit() {\n    if (this.situation === 'SEARCH') {\n      this.multiselect = true;\n    }\n  }\n\n  public validate(c: UntypedFormControl) {\n    return (this.isValid) ? null : {\n      dynamiclist: {\n        valid: false,\n      },\n    };\n  }\n}\n","<eo-dialog #listDialog [title]=\"pickerTitle\" [visible]=\"display\" [ngClass]=\"{empty: !(list?.entries?.length)}\"\n  [styleClass]=\"'dynlist-dialog'\" (hide)=\"display = false\">\n\n  <eo-tree [tree]=\"tree\" *ngIf=\"display && tree\" [isDisplayed]=\"display\" [options]=\"{multiselect: multiselect}\"\n    [(ngModel)]=\"selectedNodes\" (keyup.enter)=\"showDialog($event, false)\"\n    (ngModelChange)=\"onTreeSelectionChanged($event)\">\n  </eo-tree>\n\n  <div class=\"empty\" *ngIf=\"!(list?.entries?.length)\">\n    <div translate>eo.form.property.dynamic.list.empty</div>\n  </div>\n</eo-dialog>\n\n<div class=\"eo-dynamic-list\" [ngClass]=\"{full: selectedNodes && selectedNodes.length === autocompleteValues.length}\">\n\n  <yvc-autocomplete [(ngModel)]=\"selectedNodes\" #autocomplete (suggestionSelect)=\"onAutoCompleteSelect($event)\"\n    [disabled]=\"readonly\" (suggestionUnselect)=\"onAutoCompleteUnselect($event)\" [forceSelection]=\"true\"\n    [autocompleteValues]=\"autocompleteRes\" (ngModelChange)=\"onTreeSelectionChanged($event)\" field=\"{{valueField}}\" (autocompleteFnc)=\"autocompleteFn($event)\"\n    [multiple]=\"multiselect\">\n\n    <ng-template let-item #chipTemplate>\n      <div>\n        <div class=\"value\">{{item[valueField]}}</div>\n      </div>\n    </ng-template>\n\n    <ng-template #autocompleteOptionTemplate let-item>\n      <div>\n        <div class=\"value\">{{item[valueField]}}</div>\n        <div class=\"description\" style=\"font-style: italic; color: var(--text-color-caption)\">{{item[descriptionField]}}</div>\n      </div>\n    </ng-template>\n  </yvc-autocomplete>\n\n  <button #button class=\"ui-button\" *ngIf=\"!readonly\" [disabled]=\"readonly\" (click)=\"showDialog($event, $event.detail)\"\n    (keyup.arrowDown)=\"showDialog($event)\" (keyup.enter)=\"showDialog($event)\" (keyup.space)=\"showDialog($event)\">\n    <eo-icon [iconSrc]=\"'assets/_default/svg/ic_arrow_down.svg'\"></eo-icon>\n  </button>\n</div>"]}
438
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic-list.component.js","sourceRoot":"","sources":["../../../../../../../../src/app/eo-framework/form-elements/dynamic-list/dynamic-list.component.ts","../../../../../../../../src/app/eo-framework/form-elements/dynamic-list/dynamic-list.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, forwardRef, OnInit, Input, ViewChild, OnDestroy} from '@angular/core';\nimport {\n  UntypedFormControl,\n  ControlValueAccessor,\n  Validator,\n  NG_VALUE_ACCESSOR,\n  NG_VALIDATORS\n} from '@angular/forms';\nimport {AutoComplete} from '@yuuvis/components/autocomplete';\nimport {TreeNode} from '../../tree/tree.component.interface';\nimport {LocalStorageService, AutocompleteResponse} from '@eo-sdk/core';\nimport {debounceTime, Observable, Subject, Subscription} from 'rxjs';\nimport {ObjectFormHelperService} from '../../object-form/object-form-helper.service';\nimport {DynamicListService} from './dynamic-list.service';\n\n@Component({\n  selector: 'eo-dynamic-list',\n  templateUrl: './dynamic-list.component.html',\n  styleUrls: ['./dynamic-list.component.scss'],\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => DynamicListComponent),\n      multi: true\n    },\n    {\n      provide: NG_VALIDATORS,\n      useExisting: forwardRef(() => DynamicListComponent),\n      multi: true,\n    }\n  ]\n})\nexport class DynamicListComponent implements ControlValueAccessor, Validator, OnInit, OnDestroy {\n\n  @ViewChild('autocomplete') autoCompleteInput: AutoComplete;\n  @ViewChild('button') autoCompleteButton;\n\n  @Input() situation: string;\n  @Input() multiselect: boolean;\n  @Input() pickerTitle: string;\n  @Input() readonly: boolean;\n  @Input() formControlName: string;\n  @Input() formElementChanges: Observable<any>;\n\n  hasAutocompleteUrl = false;\n  hasAutocompleteValuesCached = false;\n  autocompleteUrlValue: string = null;\n  valueField = 'value';\n  subEntriesField = 'entries';\n  projectsEntriesField = 'projects';\n  descriptionField = 'description';\n  display = false;\n  value;\n  tree: TreeNode[];\n  autocompleteRes;\n  autocompleteValues: TreeNode[] = [];\n  previousSearchValue = \"\";\n  hasFormElementChanged = false;\n\n  private autocompleteSearchValue$ = new Subject<string>();\n  private _selectedNodes: any;\n  private isValid = true;\n  private formElementChangesSubscription: Subscription;\n  private _list: any;\n\n  constructor(private dynamicListService: DynamicListService, private localStorageService: LocalStorageService, private objectFormHelperService: ObjectFormHelperService) {\n\n    // Check if the new search value is different from the previous search value and the current value.\n    this.autocompleteSearchValue$.pipe(\n      debounceTime(300)\n    ).subscribe(value => {\n      if (value !== this.previousSearchValue && value !== this.value) {\n        this.previousSearchValue = value;\n        this.fetchAutocompleteData(value);\n      }\n    });\n\n    // Subscribe to the latest form element changes observable and  the flag indicating that the form element has changed.\n    this.objectFormHelperService.latestFormElementChanges$\n      .subscribe(latestChanges => {\n        this.hasFormElementChanged = true;\n      });\n  }\n\n  get list() {\n    return this._list;\n  }\n\n  get selectedNodes() {\n    return this._selectedNodes;\n  }\n\n  @Input('filterFunction')\n  set filterFunction(func: Function) {\n    if (this._list) {\n      this.buildTree();\n    }\n  }\n\n  @Input('listObject')\n  set listObject(lo: AutocompleteResponse) {\n    if (lo) {\n      this.processListObject(lo);\n    }\n  }\n\n  @Input()\n  set autocompleteUrl(url: string) {\n    if (url) {\n      this.hasAutocompleteUrl = true;\n      this.autocompleteUrlValue = url;\n    }\n  }\n\n  set selectedNodes(n: any) {\n    if (n && !Array.isArray(n)) {\n      this.autocompleteFn(n[this._list?.config?.valueField || 'value'] || n.name);\n    }\n    this._selectedNodes = structuredClone(n);\n  }\n\n  /**\n   * Fetches autocomplete data based on the provided search value.\n   *\n   * If the autocomplete values are cached and there is no search value or form element change,\n   * it retrieves the cached values from local storage. Otherwise, it makes an HTTP request to fetch\n   * the autocomplete data.\n   *\n   * @param {string} [searchValue=null] - The search value used to filter the autocomplete results.\n   * @returns {void}\n   */\n  fetchAutocompleteData(searchValue: string = null): void {\n    let autocompelteListValues: AutocompleteResponse = {} as AutocompleteResponse;\n    let url = this.autocompleteUrlValue;\n    if (this.hasAutocompleteValuesCached && !searchValue && !this.hasFormElementChanged) {\n      autocompelteListValues = this.localStorageService.getItem('autocomplete_' + this.formControlName);\n      this.processListObject(autocompelteListValues);\n    } else {\n\n      let params = {};\n\n      if (searchValue) {\n        params['query'] = searchValue;\n      }\n\n      if (this.situation) {\n        params['situation'] = this.situation;\n      }\n\n      this.dynamicListService.getAutocompleteData(url, params).subscribe((data: AutocompleteResponse) => {\n        this.setFormControlValue();\n        if (!searchValue) {\n          this.hasAutocompleteValuesCached = true;\n          this.localStorageService.setItem('autocomplete_' + this.formControlName, data);\n        }\n        this.processListObject(data);\n        if (searchValue) {\n          this.filterAutocompleteResults(searchValue);\n        }\n        this.hasFormElementChanged = false;\n      });\n    }\n  }\n\n  propagateChange = (_: any) => {\n  }\n\n  writeValue(value: any): void {\n    this.value = value || null;\n    const values = !this.value || Array.isArray(this.value) ? this.value || [] : [this.value];\n    if (value === null || value === undefined) {\n      if (this.multiselect) {\n        this.selectedNodes = [];\n      } else {\n        this.selectedNodes = null;\n      }\n    } else {\n      if (this.multiselect) {\n        this.selectedNodes = values.map(v => {\n          let node = {};\n          node[this.valueField] = v;\n          node['value'] = v;\n          return node;\n        });\n      } else {\n        let node = {};\n        node[this.valueField] = value;\n        node['value'] = value;\n        this.selectedNodes = node;\n      }\n    }\n    const nodes = !this.selectedNodes || Array.isArray(this.selectedNodes) ? this.selectedNodes || [] : [this.selectedNodes];\n\n    if (this._list && (nodes.length !== values.length || nodes.some((n, i) => n[this.valueField] !== values[i]))) {\n      this.buildTree();\n    }\n  }\n\n  registerOnChange(fn: any): void {\n    this.propagateChange = fn;\n  }\n\n  registerOnTouched(fn: any): void {\n  }\n\n  onAutoCompleteSelect(node?): void {\n    const wasInvalid = !this.isValid;\n    this.isValid = true;\n    this.setFormControlValue(wasInvalid);\n  }\n\n  onAutoCompleteUnselect(node?): void {\n    this.selectedNodes = this.selectedNodes.filter((sNode) => sNode.value !== node.value);\n    this.setFormControlValue();\n  }\n\n  onTreeSelectionChanged(evt): void {\n    if (!this.multiselect) {\n      this.display = false;\n    }\n    const wasInvalid = !this.isValid;\n    this.isValid = true;\n    this.setFormControlValue(wasInvalid);\n  }\n\n  /**\n   * Handles the autocomplete functionality based on the provided search term.\n   *\n   * If `selectedNodes` is set, it resets and updates `selectedNodes` with the search term.\n   * If `hasAutocompleteUrl` is true, it triggers an autocomplete search via an observable.\n   * Otherwise, it filters the autocomplete results locally.\n   *\n   * @param {string} term - The search term used for autocomplete.\n   * @returns {void}\n   */\n  autocompleteFn(term: string): void {\n    if (this.selectedNodes) {\n      this.selectedNodes = null;\n\n      this.selectedNodes = {\n        value: term,\n        data: {}\n      };\n    }\n\n    if (this.hasAutocompleteUrl) {\n      this.autocompleteSearchValue$.next(term);\n    } else {\n      this.filterAutocompleteResults(term);\n    }\n  }\n\n  showDialog(event?, display = true): void {\n    if (event) {\n      event.stopPropagation();\n      event.preventDefault();\n      //ignore synthetized events on enter\n      if (event.type === 'click' && event.detail === 0) {\n        return;\n      }\n\n      if (this.hasAutocompleteUrl) {\n        this.fetchAutocompleteData();\n      }\n    }\n    this.display = !!display;\n  }\n\n  ngOnInit(): void {\n    if (this.situation === 'SEARCH' && !this.hasAutocompleteUrl) {\n      this.multiselect = true;\n    }\n  }\n\n  public validate(c: UntypedFormControl): {[key: string]: string | boolean | {valid: boolean}} {\n    return (this.isValid) ? null : {\n      dynamiclist: {\n        valid: false,\n      },\n    };\n  }\n\n  ngOnDestroy(): void {\n    this.localStorageService.removeItem('autocomplete_' + this.formControlName);\n    if (this.formElementChangesSubscription) {\n      this.formElementChangesSubscription.unsubscribe();\n    }\n  }\n\n  /**\n   * Processes the given list object and updates the component's state accordingly.\n   *\n   * This method updates the internal list, selected nodes, and various configuration fields\n   * based on the provided list object. It also triggers the building of the tree structure.\n   *\n   * @param {AutocompleteResponse} listObject - The list object containing configuration and data.\n   * @private\n   */\n  private processListObject(listObject: AutocompleteResponse): void {\n    this._list = listObject;\n    if (listObject.config && listObject.config.valueField) {\n      if (this.selectedNodes) {\n        if (this.multiselect) {\n          this.selectedNodes = this.selectedNodes.map(sn => {\n            sn[listObject.config.valueField] = sn[this.valueField];\n            sn['value'] = sn[this.valueField];\n            return sn;\n          });\n        } else {\n          this.selectedNodes[listObject.config.valueField] = this.selectedNodes[this.valueField];\n          this.selectedNodes['value'] = this.selectedNodes[this.valueField];\n        }\n      }\n      this.valueField = listObject.config.valueField;\n    }\n    if (listObject.config && listObject.config.descriptionField) {\n      this.descriptionField = listObject.config.descriptionField;\n    }\n    if (listObject.config && listObject.config.subEntriesField) {\n      this.subEntriesField = listObject.config.subEntriesField;\n    }\n    this.buildTree();\n  }\n\n  /**\n   * Sets and propagates the form controls value based on the components inner values. Propagates only\n   * when the value has changed.\n   * @param forcePropagation - forces propagation even if the value hasn't been changed\n   */\n  private setFormControlValue(forcePropagation?: boolean) {\n    let v;\n    let changed: boolean;\n    if (this.multiselect) {\n      v = this.selectedNodes ? this.selectedNodes.map((node) => node[this.valueField]) : [];\n      changed = !this.value || !(v.length === this.value.length && v.every((val) => this.value.some((curVal) => curVal === val)));\n    } else {\n      v = this.selectedNodes ? this.selectedNodes.data[this.valueField] : null;\n      changed = v !== this.value;\n    }\n    if (changed || forcePropagation) {\n      this.value = v;\n      this.propagateChange(this.value);\n    }\n  }\n\n  private buildTree() {\n    this.autocompleteValues = [];\n    let tree: TreeNode[] = [];\n    for (let i = 0; i < this._list.entries.length; i++) {\n      this.addTreeNode(tree, this._list.entries[i]);\n    }\n    this.tree = tree;\n  }\n\n  private addTreeNode(parentNode: TreeNode[], listEntry) {\n    if (this.filterFunction && !this.filterFunction(listEntry)) {\n      return;\n    }\n    let node: TreeNode = this.listEntryToTreeNode(listEntry);\n    if (node.selectable) {\n      this.autocompleteValues.push(node);\n    }\n    if (listEntry[this.subEntriesField]) {\n      node.children = [];\n      for (let i = 0; i < listEntry[this.subEntriesField].length; i++) {\n        this.addTreeNode(node.children, listEntry[this.subEntriesField][i]);\n      }\n    }\n    if (listEntry[this.projectsEntriesField]) {\n      for (let i = 0; i < listEntry[this.projectsEntriesField].length; i++) {\n        this.addTreeNode(node.children, listEntry[this.projectsEntriesField][i]);\n      }\n    }\n    this.checkSelected(node);\n    parentNode.push(node);\n  }\n\n  private checkSelected(node: TreeNode) {\n    if (!this.value) {\n      return;\n    }\n    if (this.multiselect) {\n      for (let i = 0; i < this.value.length; i++) {\n        const isTreeNodeValueInValue = node.data[this.valueField] === this.value[i];\n        if (isTreeNodeValueInValue) {\n          const selectedNodeThatHasValue = this.selectedNodes.find(sN => sN[this.valueField] === this.value[i]);\n          if (!selectedNodeThatHasValue) {\n            node.selected = true;\n            this.selectedNodes.push(node);\n          } else {\n            selectedNodeThatHasValue.selected = true;\n          }\n        }\n      }\n    } else {\n      if (node.data[this.valueField] === this.value) {\n        node.selected = true;\n        this.selectedNodes = node;\n      }\n    }\n  }\n\n\n  private listEntryToTreeNode(listEntry): TreeNode {\n    let selectable: boolean;\n    if (this._list && this._list.config && this._list.config.allelementsselectable) {\n      selectable = true;\n    } else {\n      selectable = !(listEntry[this.subEntriesField] && listEntry[this.subEntriesField].length > 0);\n    }\n\n    let treeNode = {\n      id: listEntry.id ? listEntry.id : listEntry[this.valueField],\n      name: listEntry[this.descriptionField] ? listEntry[this.valueField] + ' (' + listEntry[this.descriptionField] + ')' : listEntry[this.valueField],\n      children: [],\n      expanded: false,\n      selected: false,\n      selectable: selectable,\n      data: listEntry\n    };\n    treeNode[this.valueField] = listEntry[this.valueField];\n    treeNode.data['value'] = listEntry[this.valueField];\n    treeNode[this.descriptionField] = listEntry[this.descriptionField];\n    treeNode[this.subEntriesField] = listEntry[this.subEntriesField];\n\n    return treeNode;\n  }\n\n  /**\n   * Filters the autocomplete results based on the provided search term.\n   *\n   * The method filters the `autocompleteValues` array to find nodes that match the search term.\n   * It also applies additional filtering based on the `filterFunction` and `multiselect` properties.\n   *\n   * @param {string} term - The search term used to filter the autocomplete results.\n   */\n  private filterAutocompleteResults(term: string): void {\n    this.autocompleteRes = this.autocompleteValues.filter((acNode) => {\n      if (this.filterFunction && !this.filterFunction(acNode.data)) {\n        return false;\n      }\n      if (this.multiselect) {\n        if (this.selectedNodes.find((node) => acNode.data[this.valueField] === node.data[this.valueField])) {\n          return false;\n        }\n      }\n      return acNode.data[this.valueField].toString().toLowerCase().indexOf(term.toString().toLowerCase()) !== -1 ||\n        (acNode.data[this.descriptionField] && acNode.data[this.descriptionField].toString().toLowerCase().indexOf(term.toString().toLowerCase()) !== -1);\n    }).slice(0, 10);\n  }\n\n}\n","<eo-dialog #listDialog [title]=\"pickerTitle\" [visible]=\"display\" [ngClass]=\"{empty: !(list?.entries?.length)}\"\n  [styleClass]=\"'dynlist-dialog'\" (hide)=\"display = false\">\n\n  <eo-tree [tree]=\"tree\" *ngIf=\"display && tree\" [isDisplayed]=\"display\" [options]=\"{multiselect: multiselect}\"\n    [(ngModel)]=\"selectedNodes\" (keyup.enter)=\"showDialog($event, false)\"\n    (ngModelChange)=\"onTreeSelectionChanged($event)\">\n  </eo-tree>\n\n  <div class=\"empty\" *ngIf=\"!(list?.entries?.length)\">\n    <div translate>eo.form.property.dynamic.list.empty</div>\n  </div>\n</eo-dialog>\n\n<div class=\"eo-dynamic-list\" [ngClass]=\"{full: selectedNodes && selectedNodes.length === autocompleteValues.length}\">\n\n  <yvc-autocomplete [(ngModel)]=\"selectedNodes\" #autocomplete (suggestionSelect)=\"onAutoCompleteSelect($event)\"\n    [disabled]=\"readonly\" (suggestionUnselect)=\"onAutoCompleteUnselect($event)\" [forceSelection]=\"true\"\n    [autocompleteValues]=\"autocompleteRes\" (ngModelChange)=\"onTreeSelectionChanged($event)\" field=\"{{valueField}}\" (autocompleteFnc)=\"autocompleteFn($event)\"\n    [multiple]=\"multiselect\">\n\n    <ng-template let-item #chipTemplate>\n      <div>\n        <div class=\"value\">{{item[valueField]}}</div>\n      </div>\n    </ng-template>\n\n    <ng-template #autocompleteOptionTemplate let-item>\n      <div>\n        <div class=\"value\">{{item[valueField]}}</div>\n        <div class=\"description\" style=\"font-style: italic; color: var(--text-color-caption)\">{{item[descriptionField]}}</div>\n      </div>\n    </ng-template>\n  </yvc-autocomplete>\n\n  <button #button class=\"ui-button\" *ngIf=\"!readonly\" [disabled]=\"readonly\" (click)=\"showDialog($event, !!$event.detail)\"\n    (keyup.arrowDown)=\"showDialog($event)\" (keyup.enter)=\"showDialog($event)\" (keyup.space)=\"showDialog($event)\">\n    <eo-icon [iconSrc]=\"'assets/_default/svg/ic_arrow_down.svg'\"></eo-icon>\n  </button>\n</div>\n"]}
@@ -0,0 +1,39 @@
1
+ import { Injectable } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ import * as i1 from "@eo-sdk/core";
4
+ import * as i2 from "../../object-form/object-form-helper.service";
5
+ export class DynamicListService {
6
+ constructor(autocompleteService, objectFormHelperService) {
7
+ this.autocompleteService = autocompleteService;
8
+ this.objectFormHelperService = objectFormHelperService;
9
+ this.formElements = {};
10
+ // Subscribe to the latest form element changes observable and update the form elements with the latest changes.
11
+ this.objectFormHelperService.latestFormElementChanges$
12
+ .subscribe(latestChanges => {
13
+ this.formElements = latestChanges;
14
+ });
15
+ }
16
+ /**
17
+ * Fetches autocomplete data from the given URL with the specified search parameters.
18
+ *
19
+ * This method processes the URL with the provided parameters and form elements,
20
+ * then makes an HTTP request to fetch the autocomplete data.
21
+ *
22
+ * @param {string} url - The base URL for the autocomplete request.
23
+ * @param {SearchParams} params - The search parameters to be included in the request.
24
+ * @returns {Observable<AutocompleteResponse>} - An observable containing the autocomplete response data.
25
+ */
26
+ getAutocompleteData(url, params) {
27
+ const processedUrl = this.autocompleteService.getProcessedUrl(url, params, this.formElements);
28
+ return this.autocompleteService.getAutocompleteUrlData(processedUrl);
29
+ }
30
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.4", ngImport: i0, type: DynamicListService, deps: [{ token: i1.AutocompleteService }, { token: i2.ObjectFormHelperService }], target: i0.ɵɵFactoryTarget.Injectable }); }
31
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.0.4", ngImport: i0, type: DynamicListService, providedIn: 'root' }); }
32
+ }
33
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.4", ngImport: i0, type: DynamicListService, decorators: [{
34
+ type: Injectable,
35
+ args: [{
36
+ providedIn: 'root'
37
+ }]
38
+ }], ctorParameters: () => [{ type: i1.AutocompleteService }, { type: i2.ObjectFormHelperService }] });
39
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHluYW1pYy1saXN0LnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9zcmMvYXBwL2VvLWZyYW1ld29yay9mb3JtLWVsZW1lbnRzL2R5bmFtaWMtbGlzdC9keW5hbWljLWxpc3Quc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsVUFBVSxFQUFDLE1BQU0sZUFBZSxDQUFDOzs7O0FBUXpDLE1BQU0sT0FBTyxrQkFBa0I7SUFHN0IsWUFBb0IsbUJBQXdDLEVBQVUsdUJBQWdEO1FBQWxHLHdCQUFtQixHQUFuQixtQkFBbUIsQ0FBcUI7UUFBVSw0QkFBdUIsR0FBdkIsdUJBQXVCLENBQXlCO1FBRjlHLGlCQUFZLEdBQTRCLEVBQUUsQ0FBQztRQUlqRCxnSEFBZ0g7UUFDaEgsSUFBSSxDQUFDLHVCQUF1QixDQUFDLHlCQUF5QjthQUNuRCxTQUFTLENBQUMsYUFBYSxDQUFDLEVBQUU7WUFDekIsSUFBSSxDQUFDLFlBQVksR0FBRyxhQUFhLENBQUM7UUFDcEMsQ0FBQyxDQUFDLENBQUM7SUFDUCxDQUFDO0lBRUQ7Ozs7Ozs7OztPQVNHO0lBQ0gsbUJBQW1CLENBQUMsR0FBVyxFQUFFLE1BQW9CO1FBQ25ELE1BQU0sWUFBWSxHQUFHLElBQUksQ0FBQyxtQkFBbUIsQ0FBQyxlQUFlLENBQUMsR0FBRyxFQUFFLE1BQU0sRUFBRSxJQUFJLENBQUMsWUFBWSxDQUFDLENBQUM7UUFDOUYsT0FBTyxJQUFJLENBQUMsbUJBQW1CLENBQUMsc0JBQXNCLENBQUMsWUFBWSxDQUFDLENBQUM7SUFDdkUsQ0FBQzs4R0F6QlUsa0JBQWtCO2tIQUFsQixrQkFBa0IsY0FGakIsTUFBTTs7MkZBRVAsa0JBQWtCO2tCQUg5QixVQUFVO21CQUFDO29CQUNWLFVBQVUsRUFBRSxNQUFNO2lCQUNuQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7SW5qZWN0YWJsZX0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge0F1dG9jb21wbGV0ZVJlc3BvbnNlLCBBdXRvY29tcGxldGVTZXJ2aWNlLCBTZWFyY2hQYXJhbXN9IGZyb20gJ0Blby1zZGsvY29yZSc7XG5pbXBvcnQge09ic2VydmFibGV9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHtPYmplY3RGb3JtSGVscGVyU2VydmljZX0gZnJvbSAnLi4vLi4vb2JqZWN0LWZvcm0vb2JqZWN0LWZvcm0taGVscGVyLnNlcnZpY2UnO1xuXG5ASW5qZWN0YWJsZSh7XG4gIHByb3ZpZGVkSW46ICdyb290J1xufSlcbmV4cG9ydCBjbGFzcyBEeW5hbWljTGlzdFNlcnZpY2Uge1xuICBwcml2YXRlIGZvcm1FbGVtZW50czoge1trZXk6IHN0cmluZ106IHN0cmluZ30gPSB7fTtcblxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIGF1dG9jb21wbGV0ZVNlcnZpY2U6IEF1dG9jb21wbGV0ZVNlcnZpY2UsIHByaXZhdGUgb2JqZWN0Rm9ybUhlbHBlclNlcnZpY2U6IE9iamVjdEZvcm1IZWxwZXJTZXJ2aWNlKSB7XG5cbiAgICAvLyBTdWJzY3JpYmUgdG8gdGhlIGxhdGVzdCBmb3JtIGVsZW1lbnQgY2hhbmdlcyBvYnNlcnZhYmxlIGFuZCB1cGRhdGUgdGhlIGZvcm0gZWxlbWVudHMgd2l0aCB0aGUgbGF0ZXN0IGNoYW5nZXMuXG4gICAgdGhpcy5vYmplY3RGb3JtSGVscGVyU2VydmljZS5sYXRlc3RGb3JtRWxlbWVudENoYW5nZXMkXG4gICAgICAuc3Vic2NyaWJlKGxhdGVzdENoYW5nZXMgPT4ge1xuICAgICAgICB0aGlzLmZvcm1FbGVtZW50cyA9IGxhdGVzdENoYW5nZXM7XG4gICAgICB9KTtcbiAgfVxuXG4gIC8qKlxuICAgKiBGZXRjaGVzIGF1dG9jb21wbGV0ZSBkYXRhIGZyb20gdGhlIGdpdmVuIFVSTCB3aXRoIHRoZSBzcGVjaWZpZWQgc2VhcmNoIHBhcmFtZXRlcnMuXG4gICAqXG4gICAqIFRoaXMgbWV0aG9kIHByb2Nlc3NlcyB0aGUgVVJMIHdpdGggdGhlIHByb3ZpZGVkIHBhcmFtZXRlcnMgYW5kIGZvcm0gZWxlbWVudHMsXG4gICAqIHRoZW4gbWFrZXMgYW4gSFRUUCByZXF1ZXN0IHRvIGZldGNoIHRoZSBhdXRvY29tcGxldGUgZGF0YS5cbiAgICpcbiAgICogQHBhcmFtIHtzdHJpbmd9IHVybCAtIFRoZSBiYXNlIFVSTCBmb3IgdGhlIGF1dG9jb21wbGV0ZSByZXF1ZXN0LlxuICAgKiBAcGFyYW0ge1NlYXJjaFBhcmFtc30gcGFyYW1zIC0gVGhlIHNlYXJjaCBwYXJhbWV0ZXJzIHRvIGJlIGluY2x1ZGVkIGluIHRoZSByZXF1ZXN0LlxuICAgKiBAcmV0dXJucyB7T2JzZXJ2YWJsZTxBdXRvY29tcGxldGVSZXNwb25zZT59IC0gQW4gb2JzZXJ2YWJsZSBjb250YWluaW5nIHRoZSBhdXRvY29tcGxldGUgcmVzcG9uc2UgZGF0YS5cbiAgICovXG4gIGdldEF1dG9jb21wbGV0ZURhdGEodXJsOiBzdHJpbmcsIHBhcmFtczogU2VhcmNoUGFyYW1zKTogT2JzZXJ2YWJsZTxBdXRvY29tcGxldGVSZXNwb25zZT4ge1xuICAgIGNvbnN0IHByb2Nlc3NlZFVybCA9IHRoaXMuYXV0b2NvbXBsZXRlU2VydmljZS5nZXRQcm9jZXNzZWRVcmwodXJsLCBwYXJhbXMsIHRoaXMuZm9ybUVsZW1lbnRzKTtcbiAgICByZXR1cm4gdGhpcy5hdXRvY29tcGxldGVTZXJ2aWNlLmdldEF1dG9jb21wbGV0ZVVybERhdGEocHJvY2Vzc2VkVXJsKTtcbiAgfVxuXG5cbn1cbiJdfQ==