@eo-sdk/client 11.8.0-rc.1 → 11.8.0-rc.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/app/eo-client/dashboard/widgets/signature-statistics-widget/signature-statistics-widget.component.d.ts.map +1 -1
- package/app/eo-framework/app-shell/app-bar/app-search/app-search.component.d.ts.map +1 -1
- package/app/eo-framework/form-elements/datetime-range/datetime-range.component.d.ts.map +1 -1
- package/app/eo-framework/form-elements/dynamic-list/dynamic-list.component.d.ts +78 -23
- package/app/eo-framework/form-elements/dynamic-list/dynamic-list.component.d.ts.map +1 -1
- package/app/eo-framework/form-elements/dynamic-list/dynamic-list.service.d.ts +24 -0
- package/app/eo-framework/form-elements/dynamic-list/dynamic-list.service.d.ts.map +1 -0
- package/app/eo-framework/form-elements/id-reference/id-reference.component.d.ts +6 -0
- package/app/eo-framework/form-elements/id-reference/id-reference.component.d.ts.map +1 -1
- package/app/eo-framework/grid/filters/dynamic-list-filter.component.d.ts +5 -5
- package/app/eo-framework/grid/filters/dynamic-list-filter.component.d.ts.map +1 -1
- package/app/eo-framework/inbox-details/inbox-details.component.d.ts.map +1 -1
- package/app/eo-framework/object-form/object-form-helper.service.d.ts +31 -11
- package/app/eo-framework/object-form/object-form-helper.service.d.ts.map +1 -1
- package/app/eo-framework/ui/eo-dialog/eo-dialog.component.d.ts +7 -0
- package/app/eo-framework/ui/eo-dialog/eo-dialog.component.d.ts.map +1 -1
- package/app/eo-framework/upload-overlay/upload-overlay.component.d.ts +1 -0
- package/app/eo-framework/upload-overlay/upload-overlay.component.d.ts.map +1 -1
- package/assets/_default/i18n/de.json +3 -2
- package/assets/_default/i18n/en.json +7 -6
- package/esm2022/app/eo-client/about-state/about-state.component.mjs +3 -3
- package/esm2022/app/eo-client/dashboard/widgets/signature-statistics-widget/signature-statistics-widget.component.mjs +2 -1
- package/esm2022/app/eo-client/process-state/process-state.component.mjs +1 -1
- package/esm2022/app/eo-client/settings/settings.component.mjs +3 -3
- package/esm2022/app/eo-framework/app-shell/app-bar/app-search/app-search.component.mjs +4 -3
- package/esm2022/app/eo-framework/form-elements/datetime-range/datetime-range.component.mjs +3 -2
- package/esm2022/app/eo-framework/form-elements/dynamic-list/dynamic-list.component.mjs +215 -94
- package/esm2022/app/eo-framework/form-elements/dynamic-list/dynamic-list.service.mjs +39 -0
- package/esm2022/app/eo-framework/form-elements/id-reference/id-reference.component.mjs +19 -10
- package/esm2022/app/eo-framework/form-elements/string/string.component.mjs +2 -2
- package/esm2022/app/eo-framework/grid/filters/dynamic-list-filter.component.mjs +16 -22
- package/esm2022/app/eo-framework/inbox-details/inbox-details.component.mjs +8 -3
- package/esm2022/app/eo-framework/object-form/object-form/form-element/form-element.component.mjs +3 -3
- package/esm2022/app/eo-framework/object-form/object-form/object-form-group/object-form-group.component.mjs +3 -3
- package/esm2022/app/eo-framework/object-form/object-form-edit/object-form-edit.component.mjs +3 -3
- package/esm2022/app/eo-framework/object-form/object-form-helper.service.mjs +43 -16
- package/esm2022/app/eo-framework/ui/eo-dialog/eo-dialog.component.mjs +14 -2
- package/esm2022/app/eo-framework/upload-overlay/upload-overlay.component.mjs +9 -3
- package/esm2022/app/eo-framework-core/agent/agent.service.mjs +3 -3
- package/fesm2022/eo-sdk-client.mjs +523 -318
- package/fesm2022/eo-sdk-client.mjs.map +1 -1
- package/package.json +2 -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 "
|
|
5
|
-
import * as i2 from "@
|
|
6
|
-
import * as i3 from "
|
|
7
|
-
import * as i4 from "
|
|
8
|
-
import * as i5 from "
|
|
9
|
-
import * as i6 from "
|
|
10
|
-
import * as i7 from "
|
|
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.
|
|
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
|
-
|
|
47
|
-
|
|
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
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
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
|
-
|
|
126
|
-
|
|
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
|
-
|
|
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
|
|
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
|
-
|
|
246
|
-
|
|
247
|
-
|
|
248
|
-
|
|
249
|
-
|
|
250
|
-
|
|
251
|
-
|
|
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
|
-
|
|
255
|
-
|
|
256
|
-
|
|
257
|
-
|
|
258
|
-
this.
|
|
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,
|
|
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,
|
|
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==
|