@valtimo/dossier-management 10.8.0 → 11.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (56) hide show
  1. package/esm2022/lib/dossier-management-assignee/dossier-management-assignee.component.mjs +75 -0
  2. package/{esm2020 → esm2022}/lib/dossier-management-connect-modal/dossier-management-connect-modal.component.mjs +4 -4
  3. package/{esm2020 → esm2022}/lib/dossier-management-detail-container/dossier-management-detail-container.component.mjs +5 -5
  4. package/esm2022/lib/dossier-management-detail-container/tabs/dossier-management-detail/dossier-management-detail.component.mjs +100 -0
  5. package/esm2022/lib/dossier-management-detail-container/tabs/dossier-management-list-columns/dossier-management-list-columns.component.mjs +458 -0
  6. package/esm2022/lib/dossier-management-detail-container/tabs/dossier-management-search-fields/dossier-management-search-fields.component.mjs +416 -0
  7. package/esm2022/lib/dossier-management-link-process/dossier-management-link-process.component.mjs +84 -0
  8. package/esm2022/lib/dossier-management-list/dossier-management-list.component.mjs +75 -0
  9. package/esm2022/lib/dossier-management-remove-modal/dossier-management-remove-modal.component.mjs +59 -0
  10. package/{esm2020 → esm2022}/lib/dossier-management-routing.module.mjs +5 -5
  11. package/{esm2020 → esm2022}/lib/dossier-management-upload/dossier-management-upload.component.mjs +5 -5
  12. package/esm2022/lib/dossier-management.module.mjs +167 -0
  13. package/{esm2020 → esm2022}/lib/tab.service.mjs +4 -4
  14. package/{fesm2020 → fesm2022}/valtimo-dossier-management.mjs +158 -247
  15. package/fesm2022/valtimo-dossier-management.mjs.map +1 -0
  16. package/lib/dossier-management-assignee/dossier-management-assignee.component.d.ts +1 -1
  17. package/lib/dossier-management-assignee/dossier-management-assignee.component.d.ts.map +1 -1
  18. package/lib/dossier-management-connect-modal/dossier-management-connect-modal.component.d.ts +1 -1
  19. package/lib/dossier-management-detail-container/dossier-management-detail-container.component.d.ts +1 -1
  20. package/lib/dossier-management-detail-container/tabs/dossier-management-detail/dossier-management-detail.component.d.ts +1 -3
  21. package/lib/dossier-management-detail-container/tabs/dossier-management-detail/dossier-management-detail.component.d.ts.map +1 -1
  22. package/lib/dossier-management-detail-container/tabs/dossier-management-list-columns/dossier-management-list-columns.component.d.ts +9 -10
  23. package/lib/dossier-management-detail-container/tabs/dossier-management-list-columns/dossier-management-list-columns.component.d.ts.map +1 -1
  24. package/lib/dossier-management-detail-container/tabs/dossier-management-search-fields/dossier-management-search-fields.component.d.ts +2 -2
  25. package/lib/dossier-management-detail-container/tabs/dossier-management-search-fields/dossier-management-search-fields.component.d.ts.map +1 -1
  26. package/lib/dossier-management-link-process/dossier-management-link-process.component.d.ts +2 -2
  27. package/lib/dossier-management-link-process/dossier-management-link-process.component.d.ts.map +1 -1
  28. package/lib/dossier-management-list/dossier-management-list.component.d.ts +1 -2
  29. package/lib/dossier-management-list/dossier-management-list.component.d.ts.map +1 -1
  30. package/lib/dossier-management-remove-modal/dossier-management-remove-modal.component.d.ts +1 -1
  31. package/lib/dossier-management-remove-modal/dossier-management-remove-modal.component.d.ts.map +1 -1
  32. package/lib/dossier-management-upload/dossier-management-upload.component.d.ts +1 -1
  33. package/lib/dossier-management.module.d.ts +14 -16
  34. package/lib/dossier-management.module.d.ts.map +1 -1
  35. package/lib/models/list-column.model.d.ts +1 -1
  36. package/lib/models/list-column.model.d.ts.map +1 -1
  37. package/package.json +8 -14
  38. package/esm2020/lib/dossier-management-assignee/dossier-management-assignee.component.mjs +0 -73
  39. package/esm2020/lib/dossier-management-detail-container/tabs/dossier-management-detail/dossier-management-detail.component.mjs +0 -104
  40. package/esm2020/lib/dossier-management-detail-container/tabs/dossier-management-list-columns/dossier-management-list-columns.component.mjs +0 -456
  41. package/esm2020/lib/dossier-management-detail-container/tabs/dossier-management-search-fields/dossier-management-search-fields.component.mjs +0 -417
  42. package/esm2020/lib/dossier-management-link-process/dossier-management-link-process.component.mjs +0 -84
  43. package/esm2020/lib/dossier-management-list/dossier-management-list.component.mjs +0 -76
  44. package/esm2020/lib/dossier-management-remove-modal/dossier-management-remove-modal.component.mjs +0 -57
  45. package/esm2020/lib/dossier-management-roles/dossier-management-roles.component.mjs +0 -97
  46. package/esm2020/lib/dossier-management.module.mjs +0 -171
  47. package/fesm2015/valtimo-dossier-management.mjs +0 -1846
  48. package/fesm2015/valtimo-dossier-management.mjs.map +0 -1
  49. package/fesm2020/valtimo-dossier-management.mjs.map +0 -1
  50. package/lib/dossier-management-roles/dossier-management-roles.component.d.ts +0 -33
  51. package/lib/dossier-management-roles/dossier-management-roles.component.d.ts.map +0 -1
  52. /package/{esm2020 → esm2022}/lib/models/index.mjs +0 -0
  53. /package/{esm2020 → esm2022}/lib/models/list-column.model.mjs +0 -0
  54. /package/{esm2020 → esm2022}/lib/tab.enum.mjs +0 -0
  55. /package/{esm2020 → esm2022}/public-api.mjs +0 -0
  56. /package/{esm2020 → esm2022}/valtimo-dossier-management.mjs +0 -0
@@ -0,0 +1,416 @@
1
+ /*
2
+ * Copyright 2015-2023 Ritense BV, the Netherlands.
3
+ *
4
+ * Licensed under EUPL, Version 1.2 (the "License");
5
+ * you may not use this file except in compliance with the License.
6
+ * You may obtain a copy of the License at
7
+ *
8
+ * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12
9
+ *
10
+ * Unless required by applicable law or agreed to in writing, software
11
+ * distributed under the License is distributed on an "AS IS" basis,
12
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13
+ * See the License for the specific language governing permissions and
14
+ * limitations under the License.
15
+ */
16
+ import { Component, EventEmitter, Output, ViewChild, } from '@angular/core';
17
+ import { BehaviorSubject, combineLatest, distinctUntilChanged, filter, map, of, Subscription, switchMap, take, tap, } from 'rxjs';
18
+ import * as i0 from "@angular/core";
19
+ import * as i1 from "@valtimo/document";
20
+ import * as i2 from "@angular/router";
21
+ import * as i3 from "@ngx-translate/core";
22
+ import * as i4 from "@angular/platform-browser";
23
+ import * as i5 from "@angular/common";
24
+ import * as i6 from "@valtimo/components";
25
+ export class DossierManagementSearchFieldsComponent {
26
+ constructor(documentService, route, translateService, sanitizer) {
27
+ this.documentService = documentService;
28
+ this.route = route;
29
+ this.translateService = translateService;
30
+ this.sanitizer = sanitizer;
31
+ this.searchField = new EventEmitter();
32
+ this.downloadName$ = new BehaviorSubject('');
33
+ this.downloadUrl$ = new BehaviorSubject(undefined);
34
+ this.disableInput$ = new BehaviorSubject(false);
35
+ this.selectedSearchField$ = new BehaviorSubject(null);
36
+ this.formData$ = new BehaviorSubject(null);
37
+ this.valid$ = new BehaviorSubject(false);
38
+ this.subscriptions = new Subscription();
39
+ this.COLUMNS = [
40
+ {
41
+ viewType: 'string',
42
+ sortable: false,
43
+ propertyName: 'title',
44
+ translationKey: 'title',
45
+ },
46
+ {
47
+ viewType: 'string',
48
+ sortable: false,
49
+ propertyName: 'key',
50
+ translationKey: 'key',
51
+ },
52
+ {
53
+ viewType: 'string',
54
+ sortable: false,
55
+ propertyName: 'path',
56
+ translationKey: 'path',
57
+ },
58
+ {
59
+ viewType: 'string',
60
+ sortable: false,
61
+ propertyName: 'dataType',
62
+ translationKey: 'dataType',
63
+ },
64
+ {
65
+ viewType: 'string',
66
+ sortable: false,
67
+ propertyName: 'fieldType',
68
+ translationKey: 'fieldType',
69
+ },
70
+ ];
71
+ this.dropdownColumns$ = new BehaviorSubject([
72
+ {
73
+ labelTranslationKey: 'searchFieldsOverview.id',
74
+ dataKey: 'key',
75
+ },
76
+ {
77
+ labelTranslationKey: 'searchFieldsOverview.text',
78
+ dataKey: 'value',
79
+ },
80
+ ]);
81
+ this.DATA_TYPES = [
82
+ 'text',
83
+ 'number',
84
+ 'date',
85
+ 'datetime',
86
+ 'boolean',
87
+ ];
88
+ this.dataTypeItems$ = this.translateService.stream('key').pipe(map(() => this.DATA_TYPES.map(dataType => ({
89
+ id: dataType,
90
+ text: this.translateService.instant(`searchFields.${dataType}`),
91
+ }))));
92
+ this.dataTypeIsBoolean$ = new BehaviorSubject(false);
93
+ this.dataTypeIsText$ = new BehaviorSubject(false);
94
+ this.ALL_FIELD_TYPES = [
95
+ 'single',
96
+ 'range',
97
+ 'single-select-dropdown',
98
+ 'multi-select-dropdown',
99
+ ];
100
+ this.NON_TEXT_FIELD_TYPES = ['single', 'range'];
101
+ this.BOOLEAN_FIELD_TYPES = ['single'];
102
+ this.fieldTypeItems$ = combineLatest([
103
+ this.dataTypeIsBoolean$,
104
+ this.dataTypeIsText$,
105
+ this.translateService.stream('key'),
106
+ ]).pipe(map(([dataTypeIsBoolean, dataTypeIsText]) => {
107
+ if (dataTypeIsBoolean) {
108
+ return this.BOOLEAN_FIELD_TYPES.map(fieldType => ({
109
+ id: fieldType,
110
+ text: this.translateService.instant(`searchFieldsOverview.${fieldType}`),
111
+ }));
112
+ }
113
+ else if (!dataTypeIsText) {
114
+ return this.NON_TEXT_FIELD_TYPES.map(fieldType => ({
115
+ id: fieldType,
116
+ text: this.translateService.instant(`searchFieldsOverview.${fieldType}`),
117
+ }));
118
+ }
119
+ return this.ALL_FIELD_TYPES.map(fieldType => ({
120
+ id: fieldType,
121
+ text: this.translateService.instant(`searchFieldsOverview.${fieldType}`),
122
+ }));
123
+ }));
124
+ this.MATCH_TYPES = ['exact', 'like'];
125
+ this.matchTypeItems$ = this.translateService
126
+ .stream('key')
127
+ .pipe(map(() => this.MATCH_TYPES.map(matchType => ({
128
+ id: matchType,
129
+ text: this.translateService.instant(`searchFieldsOverview.${matchType}`),
130
+ }))));
131
+ this.fields$ = this.translateService.stream('key').pipe(map(() => this.COLUMNS.map(column => ({
132
+ key: column.propertyName,
133
+ label: this.translateService.instant(`searchFieldsOverview.${column.translationKey}`),
134
+ sortable: column.sortable,
135
+ ...(column.viewType && { viewType: column.viewType }),
136
+ ...(column.enum && { enum: column.enum }),
137
+ }))));
138
+ this.documentDefinitionName$ = this.route.params.pipe(map(params => params.name || ''), filter(docDefName => !!docDefName));
139
+ this.loadingSearchFields = true;
140
+ this.showSearchFieldsForm = false;
141
+ this.refreshSearchFields$ = new BehaviorSubject(null);
142
+ this.searchFields$ = combineLatest([
143
+ this.documentDefinitionName$,
144
+ this.refreshSearchFields$,
145
+ ]).pipe(switchMap(([documentDefinitionName]) => this.documentService.getDocumentSearchFields(documentDefinitionName)), tap(searchFields => {
146
+ this.documentDefinitionName$.pipe(take(1)).subscribe(documentDefinitionName => {
147
+ if (searchFields && Array.isArray(searchFields) && searchFields.length > 0) {
148
+ this.setDownload(documentDefinitionName, searchFields);
149
+ }
150
+ });
151
+ }), tap(searchFields => {
152
+ this.cachedSearchFields = searchFields;
153
+ this.loadingSearchFields = false;
154
+ }));
155
+ this.translatedSearchFields$ = combineLatest([
156
+ this.searchFields$,
157
+ this.translateService.stream('key'),
158
+ ]).pipe(map(([searchFields]) => searchFields.map(searchField => ({
159
+ ...searchField,
160
+ title: searchField.title ? searchField.title : '',
161
+ dataType: this.translateService.instant(`searchFields.${searchField.dataType}`),
162
+ matchType: this.translateService.instant(`searchFieldsOverview.${searchField.matchType}`),
163
+ fieldType: this.translateService.instant(`searchFieldsOverview.${searchField.fieldType}`),
164
+ }))));
165
+ this.fieldTypeIsDropdown$ = new BehaviorSubject(false);
166
+ this.dropdownDataProviderNames$ = combineLatest([
167
+ this.documentService.getDropdownDataProviders(),
168
+ this.translateService.stream('key'),
169
+ ]).pipe(map(([providers]) => providers.map(provider => ({
170
+ id: provider,
171
+ text: this.translateService.instant(`searchFieldsOverview.${provider}`),
172
+ }))));
173
+ this.modifiedDropdownValues$ = new BehaviorSubject([]);
174
+ this.initialDropdownValues$ = combineLatest([
175
+ this.documentDefinitionName$,
176
+ this.formData$,
177
+ ]).pipe(distinctUntilChanged(([prevDocumentDefinitionName, prevFormData], [currDocumentDefinitionName, currFormData]) => prevDocumentDefinitionName === currDocumentDefinitionName &&
178
+ prevFormData?.dropdownDataProvider === currFormData?.dropdownDataProvider &&
179
+ prevFormData?.key === currFormData?.key), switchMap(([documentDefinitionName, formData]) => {
180
+ if (!formData || !formData.dropdownDataProvider) {
181
+ return of([]);
182
+ }
183
+ return this.documentService
184
+ .getDropdownData(formData.dropdownDataProvider, documentDefinitionName, formData.key)
185
+ .pipe(map(dropdownData => {
186
+ if (dropdownData) {
187
+ return Object.keys(dropdownData).map(dropdownFieldKey => ({
188
+ key: dropdownFieldKey,
189
+ value: dropdownData[dropdownFieldKey],
190
+ }));
191
+ }
192
+ return [];
193
+ }));
194
+ }));
195
+ this.showMatchTypes$ = combineLatest([
196
+ this.dataTypeIsText$,
197
+ this.fieldTypeIsDropdown$,
198
+ ]).pipe(map(([dataTypeIsText, fieldTypeIsDropdown]) => dataTypeIsText && !fieldTypeIsDropdown));
199
+ this.showReadonlyDropdownTable$ = combineLatest([
200
+ this.dataTypeIsText$,
201
+ this.fieldTypeIsDropdown$,
202
+ this.formData$,
203
+ ]).pipe(map(([dataTypeIsText, fieldTypeIsDropdown, formData]) => dataTypeIsText &&
204
+ fieldTypeIsDropdown &&
205
+ formData?.dropdownDataProvider &&
206
+ !this.dropdownDataProviderSupportsUpdates(formData?.dropdownDataProvider)));
207
+ this.showInputDropdownTable$ = combineLatest([
208
+ this.dataTypeIsText$,
209
+ this.fieldTypeIsDropdown$,
210
+ this.formData$,
211
+ ]).pipe(map(([dataTypeIsText, fieldTypeIsDropdown, formData]) => dataTypeIsText &&
212
+ fieldTypeIsDropdown &&
213
+ formData?.dropdownDataProvider &&
214
+ this.dropdownDataProviderSupportsUpdates(formData?.dropdownDataProvider)));
215
+ }
216
+ ngOnInit() {
217
+ this.openSelectedSearchFieldSubscription();
218
+ }
219
+ ngAfterViewInit() {
220
+ this.openModalShowingSubscription();
221
+ }
222
+ ngOnDestroy() {
223
+ this.subscriptions.unsubscribe();
224
+ }
225
+ searchFieldClicked(searchField, searchFieldActionTypeIsAdd) {
226
+ this.disableInput$.pipe(take(1)).subscribe(inputDisabled => {
227
+ if (!inputDisabled) {
228
+ this.searchFieldActionTypeIsAdd = searchFieldActionTypeIsAdd;
229
+ const searchFieldToSelect = this.cachedSearchFields.find(field => field.key === searchField.key);
230
+ this.selectedSearchField$.next(searchFieldToSelect);
231
+ }
232
+ });
233
+ }
234
+ formValueChange(data) {
235
+ setTimeout(() => {
236
+ this.nextIfChanged(this.dataTypeIsText$, data.dataType === 'text');
237
+ this.nextIfChanged(this.dataTypeIsBoolean$, data.dataType === 'boolean');
238
+ this.nextIfChanged(this.fieldTypeIsDropdown$, this.isFieldTypeDropdown(data.fieldType));
239
+ this.nextIfChanged(this.formData$, data);
240
+ this.nextIfChanged(this.valid$, this.isValid(data));
241
+ }, 0);
242
+ }
243
+ dropdownDatalistChange(data) {
244
+ this.modifiedDropdownValues$.next(data);
245
+ }
246
+ moveRow(searchFieldRowIndex, moveUp, clickEvent, documentDefinitionName) {
247
+ const searchFields = [...this.cachedSearchFields];
248
+ const searchFieldRow = searchFields[searchFieldRowIndex];
249
+ clickEvent.stopPropagation();
250
+ const searchFieldIndex = searchFields.findIndex(field => field.key === searchFieldRow.key);
251
+ const foundSearchField = { ...searchFields[searchFieldIndex] };
252
+ const filteredSearchFields = searchFields.filter(field => field.key !== searchFieldRow.key);
253
+ const multipleSearchFields = searchFields.length > 1;
254
+ if (multipleSearchFields && moveUp && searchFieldIndex > 0) {
255
+ const searchFieldBeforeKey = `${searchFields[searchFieldIndex - 1].key}`;
256
+ const searchFieldBeforeIndex = filteredSearchFields.findIndex(field => field.key === searchFieldBeforeKey);
257
+ filteredSearchFields.splice(searchFieldBeforeIndex, 0, foundSearchField);
258
+ this.updateSearchFields(documentDefinitionName, filteredSearchFields);
259
+ }
260
+ else if (multipleSearchFields && !moveUp && searchFieldIndex < searchFields.length) {
261
+ const searchFieldAfterKey = `${searchFields[searchFieldIndex + 1].key}`;
262
+ const searchFieldAfterIndex = filteredSearchFields.findIndex(field => field.key === searchFieldAfterKey);
263
+ filteredSearchFields.splice(searchFieldAfterIndex + 1, 0, foundSearchField);
264
+ this.updateSearchFields(documentDefinitionName, filteredSearchFields);
265
+ }
266
+ }
267
+ deleteSelectedSearchField(documentDefinitionName, selectedSearchField) {
268
+ this.disableInput();
269
+ if (this.dropdownDataProviderSupportsUpdates(selectedSearchField?.dropdownDataProvider)) {
270
+ this.documentService
271
+ .deleteDropdownData(selectedSearchField.dropdownDataProvider, documentDefinitionName, selectedSearchField.key)
272
+ .subscribe();
273
+ }
274
+ this.documentService
275
+ .deleteDocumentSearch(documentDefinitionName, selectedSearchField.key)
276
+ .subscribe(() => {
277
+ this.enableInput();
278
+ this.hideModal();
279
+ this.refreshSearchFields();
280
+ }, () => {
281
+ this.enableInput();
282
+ });
283
+ }
284
+ saveSearchField(documentDefinitionName) {
285
+ this.disableInput();
286
+ this.formData$.pipe(take(1)).subscribe(formData => {
287
+ const mappedFormData = {
288
+ ...formData,
289
+ matchType: !this.isFieldTypeDropdown(formData.fieldType) && formData.dataType === 'text'
290
+ ? formData.matchType
291
+ : 'exact',
292
+ fieldType: formData.dataType !== 'boolean' ? formData.fieldType : 'single',
293
+ };
294
+ const prevFormData = this.selectedSearchField$.value;
295
+ if (this.dropdownDataProviderSupportsUpdates(prevFormData?.dropdownDataProvider) &&
296
+ prevFormData.dropdownDataProvider !== mappedFormData?.dropdownDataProvider) {
297
+ this.documentService
298
+ .deleteDropdownData(prevFormData.dropdownDataProvider, documentDefinitionName, prevFormData.key)
299
+ .subscribe();
300
+ }
301
+ if (this.dropdownDataProviderSupportsUpdates(mappedFormData.dropdownDataProvider)) {
302
+ this.modifiedDropdownValues$.pipe(take(1)).subscribe(dropdownValues => {
303
+ const request = dropdownValues.reduce((acc, keyValue) => ({ ...acc, [keyValue.key]: keyValue.value }), {});
304
+ this.documentService
305
+ .postDropdownData(mappedFormData.dropdownDataProvider, documentDefinitionName, mappedFormData.key, request)
306
+ .subscribe();
307
+ });
308
+ }
309
+ if (this.searchFieldActionTypeIsAdd) {
310
+ this.documentService.postDocumentSearch(documentDefinitionName, mappedFormData).subscribe(() => {
311
+ this.enableInput();
312
+ this.hideModal();
313
+ this.refreshSearchFields();
314
+ }, () => {
315
+ this.enableInput();
316
+ });
317
+ }
318
+ else {
319
+ const newFields = [...this.cachedSearchFields];
320
+ const indexToReplace = newFields.findIndex(field => field.key === mappedFormData.key);
321
+ const filteredFields = newFields.filter(field => field.key !== mappedFormData.key);
322
+ filteredFields.splice(indexToReplace, 0, mappedFormData);
323
+ this.updateSearchFields(documentDefinitionName, filteredFields);
324
+ }
325
+ });
326
+ }
327
+ updateSearchFields(documentDefinitionName, newSearchFields) {
328
+ this.disableInput();
329
+ this.documentService.putDocumentSearch(documentDefinitionName, newSearchFields).subscribe(() => {
330
+ this.enableInput();
331
+ this.hideModal();
332
+ this.refreshSearchFields();
333
+ }, () => {
334
+ this.enableInput();
335
+ });
336
+ }
337
+ nextIfChanged(behaviourSubject$, value) {
338
+ if (JSON.stringify(behaviourSubject$.value) !== JSON.stringify(value)) {
339
+ behaviourSubject$.next(value);
340
+ }
341
+ }
342
+ isValid(data) {
343
+ const validMatchType = data.dataType === 'text' && !this.isFieldTypeDropdown(data.fieldType) ? data.matchType : true;
344
+ const validDropdownDataProvider = this.isFieldTypeDropdown(data.fieldType)
345
+ ? data.dropdownDataProvider
346
+ : true;
347
+ const containsAllValues = !!(data.key &&
348
+ data.dataType &&
349
+ validMatchType &&
350
+ validDropdownDataProvider &&
351
+ data.path);
352
+ const keyIsUnique = !this.searchFieldActionTypeIsAdd ||
353
+ this.cachedSearchFields.findIndex(field => field.key === data.key) === -1;
354
+ return containsAllValues && keyIsUnique;
355
+ }
356
+ isFieldTypeDropdown(fieldType) {
357
+ return fieldType === 'single-select-dropdown' || fieldType === 'multi-select-dropdown';
358
+ }
359
+ dropdownDataProviderSupportsUpdates(dropdownDataProvider) {
360
+ return dropdownDataProvider === 'dropdownDatabaseDataProvider';
361
+ }
362
+ openSelectedSearchFieldSubscription() {
363
+ this.subscriptions.add(this.selectedSearchField$.subscribe(() => {
364
+ this.showModal();
365
+ }));
366
+ }
367
+ openModalShowingSubscription() {
368
+ this.subscriptions.add(this.modal.modalShowing$.subscribe(modalShowing => {
369
+ if (modalShowing) {
370
+ setTimeout(() => {
371
+ this.showSearchFieldsForm = true;
372
+ }, 0);
373
+ }
374
+ else {
375
+ setTimeout(() => {
376
+ this.showSearchFieldsForm = false;
377
+ }, 150);
378
+ }
379
+ }));
380
+ }
381
+ setDownload(documentDefinitionName, searchFields) {
382
+ this.downloadName$.next(`${documentDefinitionName}.json`);
383
+ this.downloadUrl$.next(this.sanitizer.bypassSecurityTrustUrl('data:text/json;charset=UTF-8,' +
384
+ encodeURIComponent(JSON.stringify({ searchFields }, null, 2))));
385
+ }
386
+ disableInput() {
387
+ this.disableInput$.next(true);
388
+ }
389
+ enableInput() {
390
+ this.disableInput$.next(false);
391
+ }
392
+ showModal() {
393
+ this.modal?.show();
394
+ }
395
+ hideModal() {
396
+ this.modal?.hide();
397
+ }
398
+ refreshSearchFields() {
399
+ this.refreshSearchFields$.next(null);
400
+ }
401
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DossierManagementSearchFieldsComponent, deps: [{ token: i1.DocumentService }, { token: i2.ActivatedRoute }, { token: i3.TranslateService }, { token: i4.DomSanitizer }], target: i0.ɵɵFactoryTarget.Component }); }
402
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: DossierManagementSearchFieldsComponent, selector: "valtimo-dossier-management-search-fields", outputs: { searchField: "searchField" }, viewQueries: [{ propertyName: "moveRowButtonsTemplateRef", first: true, predicate: ["moveRowButtons"], descendants: true }, { propertyName: "modal", first: true, predicate: ["searchFieldModal"], descendants: true }], ngImport: i0, template: "<!--\n ~ Copyright 2015-2023 Ritense BV, the Netherlands.\n ~\n ~ Licensed under EUPL, Version 1.2 (the \"License\");\n ~ you may not use this file except in compliance with the License.\n ~ You may obtain a copy of the License at\n ~\n ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n ~\n ~ Unless required by applicable law or agreed to in writing, software\n ~ distributed under the License is distributed on an \"AS IS\" basis,\n ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n ~ See the License for the specific language governing permissions and\n ~ limitations under the License.\n -->\n\n<ng-container\n *ngIf=\"{\n searchFields: translatedSearchFields$ | async,\n fields: fields$ | async,\n downloadUrl: downloadUrl$ | async,\n downloadName: downloadName$ | async,\n documentDefinitionName: documentDefinitionName$ | async,\n valid: valid$ | async,\n disableInput: disableInput$ | async\n } as obs\"\n>\n <ng-container *ngTemplateOutlet=\"buttons; context: {obs: obs}\"></ng-container>\n <ng-container *ngTemplateOutlet=\"list; context: {obs: obs}\"></ng-container>\n <ng-container *ngTemplateOutlet=\"modal; context: {obs: obs}\"></ng-container>\n</ng-container>\n\n<ng-template #buttons let-obs=\"obs\">\n <div class=\"btn-group mt-m3px mb-3 pr-2 float-right\">\n <a\n class=\"btn btn-secondary btn-space\"\n [href]=\"obs.downloadUrl\"\n [download]=\"obs.downloadName\"\n [ngClass]=\"{\n disabled:\n !obs.downloadUrl || !obs.downloadName || obs.searchFields.length <= 0 || obs.disableInput\n }\"\n >\n <i class=\"icon mdi mdi-download mr-1\"></i>\n {{ 'searchFields.downloadButtonText' | translate }}\n </a>\n <button\n (click)=\"searchFieldClicked($event, true)\"\n class=\"btn btn-primary btn-space\"\n [ngClass]=\"{disabled: loadingSearchFields || obs.disableInput}\"\n >\n <i class=\"icon mdi mdi-plus mr-1\"></i>\n {{ 'searchFieldsOverview.addRow' | translate }}\n </button>\n </div>\n</ng-template>\n\n<ng-template #list let-obs=\"obs\">\n <valtimo-list\n [items]=\"obs.searchFields\"\n [fields]=\"obs.fields\"\n [viewMode]=\"false\"\n [header]=\"false\"\n (rowClicked)=\"searchFieldClicked($event, false)\"\n *ngIf=\"obs.searchFields; else loading\"\n [lastColumnTemplate]=\"moveRowButtonsTemplateRef\"\n >\n </valtimo-list>\n</ng-template>\n\n<ng-template #moveRowButtons let-index=\"index\" let-length=\"length\">\n <div\n class=\"move-row-buttons\"\n *ngIf=\"{\n disableInput: disableInput$ | async,\n documentDefinitionName: documentDefinitionName$ | async\n } as obs\"\n >\n <i\n class=\"mdi mdi-arrow-up-bold btn btn-outline-primary mr-1\"\n (click)=\"moveRow(index, true, $event, obs.documentDefinitionName)\"\n [ngClass]=\"{'disabled disabled-move-row-button': index === 0 || obs.disableInput}\"\n ></i>\n <i\n class=\"mdi mdi-arrow-down-bold btn btn-outline-secondary\"\n (click)=\"moveRow(index, false, $event, obs.documentDefinitionName)\"\n [ngClass]=\"{\n 'disabled disabled-move-row-button': index === length - 1 || obs.disableInput\n }\"\n ></i>\n </div>\n</ng-template>\n\n<ng-template #modal let-obs=\"obs\">\n <valtimo-modal\n #searchFieldModal\n elementId=\"searchFieldModal\"\n [title]=\"\n searchFieldActionTypeIsAdd\n ? ('searchFieldsOverview.addRow' | translate)\n : ('searchFieldsOverview.edit' | translate)\n \"\n [showFooter]=\"true\"\n >\n <div body class=\"mt-2\">\n <v-form\n (valueChange)=\"formValueChange($event)\"\n *ngIf=\"showSearchFieldsForm && {searchField: selectedSearchField$ | async} as searchObs\"\n >\n <v-input\n name=\"title\"\n [title]=\"'searchFieldsOverview.title' | translate\"\n [margin]=\"true\"\n [defaultValue]=\"searchObs.searchField?.title\"\n [disabled]=\"obs.disableInput\"\n [required]=\"false\"\n [fullWidth]=\"true\"\n [tooltip]=\"'searchFieldsOverviewTooltips.title' | translate\"\n >\n </v-input>\n <v-input\n name=\"key\"\n [title]=\"'searchFieldsOverview.key' | translate\"\n [margin]=\"true\"\n [defaultValue]=\"searchObs.searchField?.key\"\n [disabled]=\"obs.disableInput || !searchFieldActionTypeIsAdd\"\n [required]=\"true\"\n [widthPx]=\"200\"\n [tooltip]=\"'searchFieldsOverviewTooltips.key' | translate\"\n >\n </v-input>\n <v-input\n name=\"path\"\n [title]=\"'searchFieldsOverview.path' | translate\"\n [margin]=\"true\"\n [defaultValue]=\"searchObs.searchField?.path\"\n [disabled]=\"obs.disableInput\"\n [required]=\"true\"\n [fullWidth]=\"true\"\n [tooltip]=\"'searchFieldsOverviewTooltips.path' | translate\"\n >\n </v-input>\n <v-select\n *ngIf=\"dataTypeItems$ | async as dataTypeItems\"\n [items]=\"dataTypeItems\"\n [placeholder]=\"'searchFieldsOverview.searchFieldPlaceholder' | translate\"\n [title]=\"'searchFieldsOverview.dataType' | translate\"\n [disabled]=\"obs.disableInput\"\n [margin]=\"true\"\n [required]=\"true\"\n name=\"dataType\"\n [defaultSelectionId]=\"searchObs.searchField?.dataType\"\n [widthInPx]=\"200\"\n [tooltip]=\"'searchFieldsOverviewTooltips.dataType' | translate\"\n ></v-select>\n <v-select\n *ngIf=\"(showMatchTypes$ | async) && (matchTypeItems$ | async) as matchTypeItems\"\n [items]=\"matchTypeItems\"\n [placeholder]=\"'searchFieldsOverview.searchFieldPlaceholder' | translate\"\n [title]=\"'searchFieldsOverview.matchType' | translate\"\n [disabled]=\"obs.disableInput\"\n [margin]=\"true\"\n [required]=\"true\"\n name=\"matchType\"\n [defaultSelectionId]=\"searchObs.searchField?.matchType\"\n [widthInPx]=\"200\"\n [tooltip]=\"'searchFieldsOverviewTooltips.matchType' | translate\"\n ></v-select>\n <v-select\n *ngIf=\"fieldTypeItems$ | async as fieldTypeItems\"\n [items]=\"fieldTypeItems\"\n [placeholder]=\"'searchFieldsOverview.searchFieldPlaceholder' | translate\"\n [title]=\"'searchFieldsOverview.fieldType' | translate\"\n [disabled]=\"obs.disableInput\"\n [margin]=\"true\"\n [required]=\"true\"\n name=\"fieldType\"\n [defaultSelectionId]=\"searchObs.searchField?.fieldType\"\n [widthInPx]=\"200\"\n [tooltip]=\"'searchFieldsOverviewTooltips.fieldType' | translate\"\n ></v-select>\n <v-select\n *ngIf=\"\n (fieldTypeIsDropdown$ | async) &&\n (dropdownDataProviderNames$ | async) as dropdownDataProviderNames\n \"\n [items]=\"dropdownDataProviderNames\"\n [placeholder]=\"'searchFieldsOverview.searchFieldPlaceholder' | translate\"\n [title]=\"'searchFieldsOverview.dropdownDataProvider' | translate\"\n [disabled]=\"obs.disableInput\"\n [margin]=\"true\"\n [required]=\"false\"\n name=\"dropdownDataProvider\"\n [defaultSelectionId]=\"searchObs.searchField?.dropdownDataProvider\"\n [widthInPx]=\"200\"\n [tooltip]=\"'searchFieldsOverviewTooltips.dropdownDataProvider' | translate\"\n ></v-select>\n <valtimo-carbon-multi-input\n *ngIf=\"\n (showInputDropdownTable$ | async) &&\n (initialDropdownValues$ | async) as initialDropdownValues\n \"\n name=\"dropdownValues\"\n [title]=\"'searchFieldsOverview.dropdownListValues' | translate\"\n type=\"keyValue\"\n [disabled]=\"obs.disableInput\"\n [defaultValues]=\"initialDropdownValues\"\n [margin]=\"true\"\n [required]=\"false\"\n [tooltip]=\"'searchFieldsOverviewTooltips.dropdownListValues' | translate\"\n (valueChange)=\"dropdownDatalistChange($event)\"\n >\n </valtimo-carbon-multi-input>\n <v-table\n *ngIf=\"\n (showReadonlyDropdownTable$ | async) &&\n (initialDropdownValues$ | async) as initialDropdownValues\n \"\n [items]=\"initialDropdownValues\"\n [columns]=\"dropdownColumns$ | async\"\n [showEditButtons]=\"false\"\n [itemsTranslationKey]=\"'searchFieldsOverview'\"\n [showPagination]=\"false\"\n [mobileBreakpointPx]=\"200\"\n ></v-table>\n </v-form>\n </div>\n <div footer>\n <div class=\"col-12 p-0\">\n <ng-container *ngTemplateOutlet=\"buttonsFooterModal; context: {obs: obs}\"></ng-container>\n </div>\n </div>\n </valtimo-modal>\n</ng-template>\n\n<ng-template #buttonsFooterModal let-obs=\"obs\">\n <div class=\"buttons-container\" *ngIf=\"{searchField: selectedSearchField$ | async} as searchObs\">\n <div class=\"right-buttons\">\n <button\n class=\"btn btn-space btn-secondary\"\n *ngIf=\"!searchFieldActionTypeIsAdd\"\n [disabled]=\"obs.disableInput\"\n (click)=\"deleteSelectedSearchField(obs.documentDefinitionName, searchObs.searchField)\"\n >\n {{ 'searchFieldsOverview.delete' | translate }}\n </button>\n <button\n (click)=\"saveSearchField(obs.documentDefinitionName)\"\n type=\"button\"\n class=\"btn btn-primary btn-space mr-0\"\n [disabled]=\"obs.disableInput || !obs.valid\"\n >\n {{ 'searchFieldsOverview.submit' | translate }}\n </button>\n </div>\n </div>\n</ng-template>\n\n<ng-template #loading>\n <div class=\"mb-3\">\n <valtimo-spinner></valtimo-spinner>\n </div>\n</ng-template>\n", styles: ["/*!\n * Copyright 2015-2023 Ritense BV, the Netherlands.\n *\n * Licensed under EUPL, Version 1.2 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" basis,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */valtimo-list::ng-deep table{border-top:1px solid rgba(0,0,0,.125)}.modal-header::ng-deep{background-color:#f3f4f7}::ng-deep .disabled-move-row-button{cursor:default!important;filter:grayscale(1);opacity:.5}::ng-deep .move-row-buttons{display:flex;flex-direction:row;justify-content:flex-end;padding-right:13px}::ng-deep .tab-container{min-height:unset!important}\n"], dependencies: [{ kind: "directive", type: i5.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i5.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i6.ListComponent, selector: "valtimo-list", inputs: ["items", "fields", "pagination", "viewMode", "isSearchable", "header", "actions", "paginationIdentifier", "initialSortState", "lastColumnTemplate"], outputs: ["rowClicked", "paginationClicked", "paginationSet", "search", "sortChanged"] }, { kind: "component", type: i6.ModalComponent, selector: "valtimo-modal", inputs: ["elementId", "title", "subtitle", "templateBelowSubtitle", "showFooter"] }, { kind: "component", type: i6.SelectComponent, selector: "v-select", inputs: ["items", "defaultSelection", "defaultSelectionId", "defaultSelectionIds", "disabled", "multiple", "margin", "widthInPx", "notFoundText", "clearAllText", "clearText", "name", "title", "titleTranslationKey", "clearSelectionSubject$", "tooltip", "required", "loading", "loadingText", "placeholder", "smallMargin", "carbonTheme"], outputs: ["selectedChange"] }, { kind: "component", type: i6.SpinnerComponent, selector: "valtimo-spinner", inputs: ["useBootstrapSpinner", "name", "type", "size", "color", "bdColor", "fullScreen", "noMarginTop"] }, { kind: "component", type: i6.InputComponent, selector: "v-input", inputs: ["name", "type", "title", "titleTranslationKey", "defaultValue", "widthPx", "fullWidth", "margin", "smallMargin", "disabled", "step", "min", "maxLength", "tooltip", "required", "hideNumberSpinBox", "smallLabel", "rows", "clear$", "carbonTheme", "placeholder"], outputs: ["valueChange"] }, { kind: "component", type: i6.FormComponent, selector: "v-form", inputs: ["className"], outputs: ["valueChange"] }, { kind: "component", type: i6.CarbonMultiInputComponent, selector: "valtimo-carbon-multi-input", inputs: ["name", "title", "titleTranslationKey", "type", "initialAmountOfRows", "minimumAmountOfRows", "maxRows", "addRowText", "addRowTranslationKey", "deleteRowText", "deleteRowTranslationKey", "disabled", "defaultValues", "margin", "tooltip", "required", "keyColumnTitle", "valueColumnTitle", "dropdownColumnTitle", "hideDeleteButton", "hideAddButton", "dropdownItems", "dropdownWidth", "fullWidth"], outputs: ["valueChange", "allValuesValidEvent"] }, { kind: "component", type: i6.TableComponent, selector: "v-table", inputs: ["items", "columns", "loading", "showEditButtons", "showPagination", "editButtonTranslationKey", "itemsTranslationKey", "noResultsTranslationKey", "mobileBreakpointPx", "amountOfLoadingRows", "collectionSize", "page", "size"], outputs: ["editButtonClicked", "paginationSizeSet", "paginationPageSet"] }, { kind: "pipe", type: i5.AsyncPipe, name: "async" }, { kind: "pipe", type: i3.TranslatePipe, name: "translate" }] }); }
403
+ }
404
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DossierManagementSearchFieldsComponent, decorators: [{
405
+ type: Component,
406
+ args: [{ selector: 'valtimo-dossier-management-search-fields', template: "<!--\n ~ Copyright 2015-2023 Ritense BV, the Netherlands.\n ~\n ~ Licensed under EUPL, Version 1.2 (the \"License\");\n ~ you may not use this file except in compliance with the License.\n ~ You may obtain a copy of the License at\n ~\n ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n ~\n ~ Unless required by applicable law or agreed to in writing, software\n ~ distributed under the License is distributed on an \"AS IS\" basis,\n ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n ~ See the License for the specific language governing permissions and\n ~ limitations under the License.\n -->\n\n<ng-container\n *ngIf=\"{\n searchFields: translatedSearchFields$ | async,\n fields: fields$ | async,\n downloadUrl: downloadUrl$ | async,\n downloadName: downloadName$ | async,\n documentDefinitionName: documentDefinitionName$ | async,\n valid: valid$ | async,\n disableInput: disableInput$ | async\n } as obs\"\n>\n <ng-container *ngTemplateOutlet=\"buttons; context: {obs: obs}\"></ng-container>\n <ng-container *ngTemplateOutlet=\"list; context: {obs: obs}\"></ng-container>\n <ng-container *ngTemplateOutlet=\"modal; context: {obs: obs}\"></ng-container>\n</ng-container>\n\n<ng-template #buttons let-obs=\"obs\">\n <div class=\"btn-group mt-m3px mb-3 pr-2 float-right\">\n <a\n class=\"btn btn-secondary btn-space\"\n [href]=\"obs.downloadUrl\"\n [download]=\"obs.downloadName\"\n [ngClass]=\"{\n disabled:\n !obs.downloadUrl || !obs.downloadName || obs.searchFields.length <= 0 || obs.disableInput\n }\"\n >\n <i class=\"icon mdi mdi-download mr-1\"></i>\n {{ 'searchFields.downloadButtonText' | translate }}\n </a>\n <button\n (click)=\"searchFieldClicked($event, true)\"\n class=\"btn btn-primary btn-space\"\n [ngClass]=\"{disabled: loadingSearchFields || obs.disableInput}\"\n >\n <i class=\"icon mdi mdi-plus mr-1\"></i>\n {{ 'searchFieldsOverview.addRow' | translate }}\n </button>\n </div>\n</ng-template>\n\n<ng-template #list let-obs=\"obs\">\n <valtimo-list\n [items]=\"obs.searchFields\"\n [fields]=\"obs.fields\"\n [viewMode]=\"false\"\n [header]=\"false\"\n (rowClicked)=\"searchFieldClicked($event, false)\"\n *ngIf=\"obs.searchFields; else loading\"\n [lastColumnTemplate]=\"moveRowButtonsTemplateRef\"\n >\n </valtimo-list>\n</ng-template>\n\n<ng-template #moveRowButtons let-index=\"index\" let-length=\"length\">\n <div\n class=\"move-row-buttons\"\n *ngIf=\"{\n disableInput: disableInput$ | async,\n documentDefinitionName: documentDefinitionName$ | async\n } as obs\"\n >\n <i\n class=\"mdi mdi-arrow-up-bold btn btn-outline-primary mr-1\"\n (click)=\"moveRow(index, true, $event, obs.documentDefinitionName)\"\n [ngClass]=\"{'disabled disabled-move-row-button': index === 0 || obs.disableInput}\"\n ></i>\n <i\n class=\"mdi mdi-arrow-down-bold btn btn-outline-secondary\"\n (click)=\"moveRow(index, false, $event, obs.documentDefinitionName)\"\n [ngClass]=\"{\n 'disabled disabled-move-row-button': index === length - 1 || obs.disableInput\n }\"\n ></i>\n </div>\n</ng-template>\n\n<ng-template #modal let-obs=\"obs\">\n <valtimo-modal\n #searchFieldModal\n elementId=\"searchFieldModal\"\n [title]=\"\n searchFieldActionTypeIsAdd\n ? ('searchFieldsOverview.addRow' | translate)\n : ('searchFieldsOverview.edit' | translate)\n \"\n [showFooter]=\"true\"\n >\n <div body class=\"mt-2\">\n <v-form\n (valueChange)=\"formValueChange($event)\"\n *ngIf=\"showSearchFieldsForm && {searchField: selectedSearchField$ | async} as searchObs\"\n >\n <v-input\n name=\"title\"\n [title]=\"'searchFieldsOverview.title' | translate\"\n [margin]=\"true\"\n [defaultValue]=\"searchObs.searchField?.title\"\n [disabled]=\"obs.disableInput\"\n [required]=\"false\"\n [fullWidth]=\"true\"\n [tooltip]=\"'searchFieldsOverviewTooltips.title' | translate\"\n >\n </v-input>\n <v-input\n name=\"key\"\n [title]=\"'searchFieldsOverview.key' | translate\"\n [margin]=\"true\"\n [defaultValue]=\"searchObs.searchField?.key\"\n [disabled]=\"obs.disableInput || !searchFieldActionTypeIsAdd\"\n [required]=\"true\"\n [widthPx]=\"200\"\n [tooltip]=\"'searchFieldsOverviewTooltips.key' | translate\"\n >\n </v-input>\n <v-input\n name=\"path\"\n [title]=\"'searchFieldsOverview.path' | translate\"\n [margin]=\"true\"\n [defaultValue]=\"searchObs.searchField?.path\"\n [disabled]=\"obs.disableInput\"\n [required]=\"true\"\n [fullWidth]=\"true\"\n [tooltip]=\"'searchFieldsOverviewTooltips.path' | translate\"\n >\n </v-input>\n <v-select\n *ngIf=\"dataTypeItems$ | async as dataTypeItems\"\n [items]=\"dataTypeItems\"\n [placeholder]=\"'searchFieldsOverview.searchFieldPlaceholder' | translate\"\n [title]=\"'searchFieldsOverview.dataType' | translate\"\n [disabled]=\"obs.disableInput\"\n [margin]=\"true\"\n [required]=\"true\"\n name=\"dataType\"\n [defaultSelectionId]=\"searchObs.searchField?.dataType\"\n [widthInPx]=\"200\"\n [tooltip]=\"'searchFieldsOverviewTooltips.dataType' | translate\"\n ></v-select>\n <v-select\n *ngIf=\"(showMatchTypes$ | async) && (matchTypeItems$ | async) as matchTypeItems\"\n [items]=\"matchTypeItems\"\n [placeholder]=\"'searchFieldsOverview.searchFieldPlaceholder' | translate\"\n [title]=\"'searchFieldsOverview.matchType' | translate\"\n [disabled]=\"obs.disableInput\"\n [margin]=\"true\"\n [required]=\"true\"\n name=\"matchType\"\n [defaultSelectionId]=\"searchObs.searchField?.matchType\"\n [widthInPx]=\"200\"\n [tooltip]=\"'searchFieldsOverviewTooltips.matchType' | translate\"\n ></v-select>\n <v-select\n *ngIf=\"fieldTypeItems$ | async as fieldTypeItems\"\n [items]=\"fieldTypeItems\"\n [placeholder]=\"'searchFieldsOverview.searchFieldPlaceholder' | translate\"\n [title]=\"'searchFieldsOverview.fieldType' | translate\"\n [disabled]=\"obs.disableInput\"\n [margin]=\"true\"\n [required]=\"true\"\n name=\"fieldType\"\n [defaultSelectionId]=\"searchObs.searchField?.fieldType\"\n [widthInPx]=\"200\"\n [tooltip]=\"'searchFieldsOverviewTooltips.fieldType' | translate\"\n ></v-select>\n <v-select\n *ngIf=\"\n (fieldTypeIsDropdown$ | async) &&\n (dropdownDataProviderNames$ | async) as dropdownDataProviderNames\n \"\n [items]=\"dropdownDataProviderNames\"\n [placeholder]=\"'searchFieldsOverview.searchFieldPlaceholder' | translate\"\n [title]=\"'searchFieldsOverview.dropdownDataProvider' | translate\"\n [disabled]=\"obs.disableInput\"\n [margin]=\"true\"\n [required]=\"false\"\n name=\"dropdownDataProvider\"\n [defaultSelectionId]=\"searchObs.searchField?.dropdownDataProvider\"\n [widthInPx]=\"200\"\n [tooltip]=\"'searchFieldsOverviewTooltips.dropdownDataProvider' | translate\"\n ></v-select>\n <valtimo-carbon-multi-input\n *ngIf=\"\n (showInputDropdownTable$ | async) &&\n (initialDropdownValues$ | async) as initialDropdownValues\n \"\n name=\"dropdownValues\"\n [title]=\"'searchFieldsOverview.dropdownListValues' | translate\"\n type=\"keyValue\"\n [disabled]=\"obs.disableInput\"\n [defaultValues]=\"initialDropdownValues\"\n [margin]=\"true\"\n [required]=\"false\"\n [tooltip]=\"'searchFieldsOverviewTooltips.dropdownListValues' | translate\"\n (valueChange)=\"dropdownDatalistChange($event)\"\n >\n </valtimo-carbon-multi-input>\n <v-table\n *ngIf=\"\n (showReadonlyDropdownTable$ | async) &&\n (initialDropdownValues$ | async) as initialDropdownValues\n \"\n [items]=\"initialDropdownValues\"\n [columns]=\"dropdownColumns$ | async\"\n [showEditButtons]=\"false\"\n [itemsTranslationKey]=\"'searchFieldsOverview'\"\n [showPagination]=\"false\"\n [mobileBreakpointPx]=\"200\"\n ></v-table>\n </v-form>\n </div>\n <div footer>\n <div class=\"col-12 p-0\">\n <ng-container *ngTemplateOutlet=\"buttonsFooterModal; context: {obs: obs}\"></ng-container>\n </div>\n </div>\n </valtimo-modal>\n</ng-template>\n\n<ng-template #buttonsFooterModal let-obs=\"obs\">\n <div class=\"buttons-container\" *ngIf=\"{searchField: selectedSearchField$ | async} as searchObs\">\n <div class=\"right-buttons\">\n <button\n class=\"btn btn-space btn-secondary\"\n *ngIf=\"!searchFieldActionTypeIsAdd\"\n [disabled]=\"obs.disableInput\"\n (click)=\"deleteSelectedSearchField(obs.documentDefinitionName, searchObs.searchField)\"\n >\n {{ 'searchFieldsOverview.delete' | translate }}\n </button>\n <button\n (click)=\"saveSearchField(obs.documentDefinitionName)\"\n type=\"button\"\n class=\"btn btn-primary btn-space mr-0\"\n [disabled]=\"obs.disableInput || !obs.valid\"\n >\n {{ 'searchFieldsOverview.submit' | translate }}\n </button>\n </div>\n </div>\n</ng-template>\n\n<ng-template #loading>\n <div class=\"mb-3\">\n <valtimo-spinner></valtimo-spinner>\n </div>\n</ng-template>\n", styles: ["/*!\n * Copyright 2015-2023 Ritense BV, the Netherlands.\n *\n * Licensed under EUPL, Version 1.2 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" basis,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */valtimo-list::ng-deep table{border-top:1px solid rgba(0,0,0,.125)}.modal-header::ng-deep{background-color:#f3f4f7}::ng-deep .disabled-move-row-button{cursor:default!important;filter:grayscale(1);opacity:.5}::ng-deep .move-row-buttons{display:flex;flex-direction:row;justify-content:flex-end;padding-right:13px}::ng-deep .tab-container{min-height:unset!important}\n"] }]
407
+ }], ctorParameters: function () { return [{ type: i1.DocumentService }, { type: i2.ActivatedRoute }, { type: i3.TranslateService }, { type: i4.DomSanitizer }]; }, propDecorators: { moveRowButtonsTemplateRef: [{
408
+ type: ViewChild,
409
+ args: ['moveRowButtons']
410
+ }], modal: [{
411
+ type: ViewChild,
412
+ args: ['searchFieldModal']
413
+ }], searchField: [{
414
+ type: Output
415
+ }] } });
416
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dossier-management-search-fields.component.js","sourceRoot":"","sources":["../../../../../../../../projects/valtimo/dossier-management/src/lib/dossier-management-detail-container/tabs/dossier-management-search-fields/dossier-management-search-fields.component.ts","../../../../../../../../projects/valtimo/dossier-management/src/lib/dossier-management-detail-container/tabs/dossier-management-search-fields/dossier-management-search-fields.component.html"],"names":[],"mappings":"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","sourcesContent":["/*\n * Copyright 2015-2023 Ritense BV, the Netherlands.\n *\n * Licensed under EUPL, Version 1.2 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" basis,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\nimport {\n  AfterViewInit,\n  Component,\n  EventEmitter,\n  OnDestroy,\n  OnInit,\n  Output,\n  TemplateRef,\n  ViewChild,\n} from '@angular/core';\nimport {DocumentService} from '@valtimo/document';\nimport {\n  BehaviorSubject,\n  combineLatest,\n  distinctUntilChanged,\n  filter,\n  map,\n  Observable,\n  of,\n  Subscription,\n  switchMap,\n  take,\n  tap,\n} from 'rxjs';\nimport {ActivatedRoute} from '@angular/router';\nimport {ListField, ModalComponent} from '@valtimo/components';\nimport {TranslateService} from '@ngx-translate/core';\nimport {\n  DefinitionColumn,\n  SearchField,\n  SearchFieldDataType,\n  SearchFieldFieldType,\n  SearchFieldMatchType,\n} from '@valtimo/config';\nimport {DomSanitizer, SafeUrl} from '@angular/platform-browser';\nimport {MultiInputOutput, MultiInputValues, SelectItem, TableColumn} from '@valtimo/components';\n\n@Component({\n  selector: 'valtimo-dossier-management-search-fields',\n  templateUrl: './dossier-management-search-fields.component.html',\n  styleUrls: ['./dossier-management-search-fields.component.scss'],\n})\nexport class DossierManagementSearchFieldsComponent implements OnInit, OnDestroy, AfterViewInit {\n  @ViewChild('moveRowButtons') public moveRowButtonsTemplateRef: TemplateRef<any>;\n  @ViewChild('searchFieldModal') modal: ModalComponent;\n\n  @Output() searchField: EventEmitter<SearchField> = new EventEmitter();\n\n  readonly downloadName$ = new BehaviorSubject<string>('');\n  readonly downloadUrl$ = new BehaviorSubject<SafeUrl>(undefined);\n  readonly disableInput$ = new BehaviorSubject<boolean>(false);\n  readonly selectedSearchField$ = new BehaviorSubject<SearchField | null>(null);\n  readonly formData$ = new BehaviorSubject<SearchField>(null);\n  readonly valid$ = new BehaviorSubject<boolean>(false);\n\n  private subscriptions = new Subscription();\n\n  private readonly COLUMNS: Array<DefinitionColumn> = [\n    {\n      viewType: 'string',\n      sortable: false,\n      propertyName: 'title',\n      translationKey: 'title',\n    },\n    {\n      viewType: 'string',\n      sortable: false,\n      propertyName: 'key',\n      translationKey: 'key',\n    },\n    {\n      viewType: 'string',\n      sortable: false,\n      propertyName: 'path',\n      translationKey: 'path',\n    },\n    {\n      viewType: 'string',\n      sortable: false,\n      propertyName: 'dataType',\n      translationKey: 'dataType',\n    },\n    {\n      viewType: 'string',\n      sortable: false,\n      propertyName: 'fieldType',\n      translationKey: 'fieldType',\n    },\n  ];\n\n  readonly dropdownColumns$ = new BehaviorSubject<Array<TableColumn>>([\n    {\n      labelTranslationKey: 'searchFieldsOverview.id',\n      dataKey: 'key',\n    },\n    {\n      labelTranslationKey: 'searchFieldsOverview.text',\n      dataKey: 'value',\n    },\n  ]);\n\n  private readonly DATA_TYPES: Array<SearchFieldDataType> = [\n    'text',\n    'number',\n    'date',\n    'datetime',\n    'boolean',\n  ];\n  readonly dataTypeItems$: Observable<Array<SelectItem>> = this.translateService.stream('key').pipe(\n    map(() =>\n      this.DATA_TYPES.map(dataType => ({\n        id: dataType,\n        text: this.translateService.instant(`searchFields.${dataType}`),\n      }))\n    )\n  );\n\n  readonly dataTypeIsBoolean$ = new BehaviorSubject<boolean>(false);\n  private readonly dataTypeIsText$ = new BehaviorSubject<boolean>(false);\n  private readonly ALL_FIELD_TYPES: Array<SearchFieldFieldType> = [\n    'single',\n    'range',\n    'single-select-dropdown',\n    'multi-select-dropdown',\n  ];\n  private readonly NON_TEXT_FIELD_TYPES: Array<SearchFieldFieldType> = ['single', 'range'];\n  private readonly BOOLEAN_FIELD_TYPES: Array<SearchFieldFieldType> = ['single'];\n  readonly fieldTypeItems$: Observable<Array<SelectItem>> = combineLatest([\n    this.dataTypeIsBoolean$,\n    this.dataTypeIsText$,\n    this.translateService.stream('key'),\n  ]).pipe(\n    map(([dataTypeIsBoolean, dataTypeIsText]) => {\n      if (dataTypeIsBoolean) {\n        return this.BOOLEAN_FIELD_TYPES.map(fieldType => ({\n          id: fieldType,\n          text: this.translateService.instant(`searchFieldsOverview.${fieldType}`),\n        }));\n      } else if (!dataTypeIsText) {\n        return this.NON_TEXT_FIELD_TYPES.map(fieldType => ({\n          id: fieldType,\n          text: this.translateService.instant(`searchFieldsOverview.${fieldType}`),\n        }));\n      }\n\n      return this.ALL_FIELD_TYPES.map(fieldType => ({\n        id: fieldType,\n        text: this.translateService.instant(`searchFieldsOverview.${fieldType}`),\n      }));\n    })\n  );\n\n  private readonly MATCH_TYPES: Array<SearchFieldMatchType> = ['exact', 'like'];\n  readonly matchTypeItems$: Observable<Array<SelectItem>> = this.translateService\n    .stream('key')\n    .pipe(\n      map(() =>\n        this.MATCH_TYPES.map(matchType => ({\n          id: matchType,\n          text: this.translateService.instant(`searchFieldsOverview.${matchType}`),\n        }))\n      )\n    );\n\n  readonly fields$: Observable<Array<ListField>> = this.translateService.stream('key').pipe(\n    map(() =>\n      this.COLUMNS.map(column => ({\n        key: column.propertyName,\n        label: this.translateService.instant(`searchFieldsOverview.${column.translationKey}`),\n        sortable: column.sortable,\n        ...(column.viewType && {viewType: column.viewType}),\n        ...(column.enum && {enum: column.enum}),\n      }))\n    )\n  );\n\n  readonly documentDefinitionName$: Observable<string> = this.route.params.pipe(\n    map(params => params.name || ''),\n    filter(docDefName => !!docDefName)\n  );\n\n  private cachedSearchFields!: Array<SearchField>;\n  searchFieldActionTypeIsAdd: boolean;\n  loadingSearchFields = true;\n  showSearchFieldsForm = false;\n\n  private readonly refreshSearchFields$ = new BehaviorSubject<null>(null);\n\n  private readonly searchFields$: Observable<Array<SearchField>> = combineLatest([\n    this.documentDefinitionName$,\n    this.refreshSearchFields$,\n  ]).pipe(\n    switchMap(([documentDefinitionName]) =>\n      this.documentService.getDocumentSearchFields(documentDefinitionName)\n    ),\n    tap(searchFields => {\n      this.documentDefinitionName$.pipe(take(1)).subscribe(documentDefinitionName => {\n        if (searchFields && Array.isArray(searchFields) && searchFields.length > 0) {\n          this.setDownload(documentDefinitionName, searchFields);\n        }\n      });\n    }),\n    tap(searchFields => {\n      this.cachedSearchFields = searchFields;\n      this.loadingSearchFields = false;\n    })\n  );\n\n  readonly translatedSearchFields$: Observable<Array<SearchField>> = combineLatest([\n    this.searchFields$,\n    this.translateService.stream('key'),\n  ]).pipe(\n    map(([searchFields]) =>\n      searchFields.map(searchField => ({\n        ...searchField,\n        title: searchField.title ? searchField.title : '',\n        dataType: this.translateService.instant(`searchFields.${searchField.dataType}`),\n        matchType: this.translateService.instant(`searchFieldsOverview.${searchField.matchType}`),\n        fieldType: this.translateService.instant(`searchFieldsOverview.${searchField.fieldType}`),\n      }))\n    )\n  );\n\n  readonly fieldTypeIsDropdown$ = new BehaviorSubject<boolean>(false);\n\n  readonly dropdownDataProviderNames$: Observable<Array<SelectItem>> = combineLatest([\n    this.documentService.getDropdownDataProviders(),\n    this.translateService.stream('key'),\n  ]).pipe(\n    map(([providers]) =>\n      providers.map(provider => ({\n        id: provider,\n        text: this.translateService.instant(`searchFieldsOverview.${provider}`),\n      }))\n    )\n  );\n\n  private readonly modifiedDropdownValues$ = new BehaviorSubject<MultiInputValues>([]);\n\n  readonly initialDropdownValues$: Observable<MultiInputValues> = combineLatest([\n    this.documentDefinitionName$,\n    this.formData$,\n  ]).pipe(\n    distinctUntilChanged(\n      ([prevDocumentDefinitionName, prevFormData], [currDocumentDefinitionName, currFormData]) =>\n        prevDocumentDefinitionName === currDocumentDefinitionName &&\n        prevFormData?.dropdownDataProvider === currFormData?.dropdownDataProvider &&\n        prevFormData?.key === currFormData?.key\n    ),\n    switchMap(([documentDefinitionName, formData]) => {\n      if (!formData || !formData.dropdownDataProvider) {\n        return of([]);\n      }\n\n      return this.documentService\n        .getDropdownData(formData.dropdownDataProvider, documentDefinitionName, formData.key)\n        .pipe(\n          map(dropdownData => {\n            if (dropdownData) {\n              return Object.keys(dropdownData).map(dropdownFieldKey => ({\n                key: dropdownFieldKey,\n                value: dropdownData[dropdownFieldKey],\n              }));\n            }\n\n            return [];\n          })\n        );\n    })\n  );\n\n  readonly showMatchTypes$: Observable<boolean> = combineLatest([\n    this.dataTypeIsText$,\n    this.fieldTypeIsDropdown$,\n  ]).pipe(map(([dataTypeIsText, fieldTypeIsDropdown]) => dataTypeIsText && !fieldTypeIsDropdown));\n\n  readonly showReadonlyDropdownTable$: Observable<boolean> = combineLatest([\n    this.dataTypeIsText$,\n    this.fieldTypeIsDropdown$,\n    this.formData$,\n  ]).pipe(\n    map(\n      ([dataTypeIsText, fieldTypeIsDropdown, formData]) =>\n        dataTypeIsText &&\n        fieldTypeIsDropdown &&\n        formData?.dropdownDataProvider &&\n        !this.dropdownDataProviderSupportsUpdates(formData?.dropdownDataProvider)\n    )\n  );\n\n  readonly showInputDropdownTable$: Observable<boolean> = combineLatest([\n    this.dataTypeIsText$,\n    this.fieldTypeIsDropdown$,\n    this.formData$,\n  ]).pipe(\n    map(\n      ([dataTypeIsText, fieldTypeIsDropdown, formData]) =>\n        dataTypeIsText &&\n        fieldTypeIsDropdown &&\n        formData?.dropdownDataProvider &&\n        this.dropdownDataProviderSupportsUpdates(formData?.dropdownDataProvider)\n    )\n  );\n\n  constructor(\n    private readonly documentService: DocumentService,\n    private readonly route: ActivatedRoute,\n    private readonly translateService: TranslateService,\n    private readonly sanitizer: DomSanitizer\n  ) {}\n\n  ngOnInit(): void {\n    this.openSelectedSearchFieldSubscription();\n  }\n\n  ngAfterViewInit(): void {\n    this.openModalShowingSubscription();\n  }\n\n  ngOnDestroy(): void {\n    this.subscriptions.unsubscribe();\n  }\n\n  searchFieldClicked(searchField: SearchField, searchFieldActionTypeIsAdd: boolean): void {\n    this.disableInput$.pipe(take(1)).subscribe(inputDisabled => {\n      if (!inputDisabled) {\n        this.searchFieldActionTypeIsAdd = searchFieldActionTypeIsAdd;\n        const searchFieldToSelect = this.cachedSearchFields.find(\n          field => field.key === searchField.key\n        );\n        this.selectedSearchField$.next(searchFieldToSelect);\n      }\n    });\n  }\n\n  formValueChange(data: SearchField): void {\n    setTimeout(() => {\n      this.nextIfChanged(this.dataTypeIsText$, data.dataType === 'text');\n      this.nextIfChanged(this.dataTypeIsBoolean$, data.dataType === 'boolean');\n      this.nextIfChanged(this.fieldTypeIsDropdown$, this.isFieldTypeDropdown(data.fieldType));\n      this.nextIfChanged(this.formData$, data);\n      this.nextIfChanged(this.valid$, this.isValid(data));\n    }, 0);\n  }\n\n  dropdownDatalistChange(data: MultiInputOutput): void {\n    this.modifiedDropdownValues$.next(data as MultiInputValues);\n  }\n\n  moveRow(\n    searchFieldRowIndex: number,\n    moveUp: boolean,\n    clickEvent: MouseEvent,\n    documentDefinitionName: string\n  ): void {\n    const searchFields = [...this.cachedSearchFields];\n    const searchFieldRow = searchFields[searchFieldRowIndex];\n\n    clickEvent.stopPropagation();\n\n    const searchFieldIndex = searchFields.findIndex(field => field.key === searchFieldRow.key);\n    const foundSearchField = {...searchFields[searchFieldIndex]};\n    const filteredSearchFields = searchFields.filter(field => field.key !== searchFieldRow.key);\n    const multipleSearchFields = searchFields.length > 1;\n\n    if (multipleSearchFields && moveUp && searchFieldIndex > 0) {\n      const searchFieldBeforeKey = `${searchFields[searchFieldIndex - 1].key}`;\n      const searchFieldBeforeIndex = filteredSearchFields.findIndex(\n        field => field.key === searchFieldBeforeKey\n      );\n      filteredSearchFields.splice(searchFieldBeforeIndex, 0, foundSearchField);\n      this.updateSearchFields(documentDefinitionName, filteredSearchFields);\n    } else if (multipleSearchFields && !moveUp && searchFieldIndex < searchFields.length) {\n      const searchFieldAfterKey = `${searchFields[searchFieldIndex + 1].key}`;\n      const searchFieldAfterIndex = filteredSearchFields.findIndex(\n        field => field.key === searchFieldAfterKey\n      );\n      filteredSearchFields.splice(searchFieldAfterIndex + 1, 0, foundSearchField);\n      this.updateSearchFields(documentDefinitionName, filteredSearchFields);\n    }\n  }\n\n  deleteSelectedSearchField(\n    documentDefinitionName: string,\n    selectedSearchField: SearchField\n  ): void {\n    this.disableInput();\n\n    if (this.dropdownDataProviderSupportsUpdates(selectedSearchField?.dropdownDataProvider)) {\n      this.documentService\n        .deleteDropdownData(\n          selectedSearchField.dropdownDataProvider,\n          documentDefinitionName,\n          selectedSearchField.key\n        )\n        .subscribe();\n    }\n\n    this.documentService\n      .deleteDocumentSearch(documentDefinitionName, selectedSearchField.key)\n      .subscribe(\n        () => {\n          this.enableInput();\n          this.hideModal();\n          this.refreshSearchFields();\n        },\n        () => {\n          this.enableInput();\n        }\n      );\n  }\n\n  saveSearchField(documentDefinitionName: string): void {\n    this.disableInput();\n\n    this.formData$.pipe(take(1)).subscribe(formData => {\n      const mappedFormData: SearchField = {\n        ...formData,\n        matchType:\n          !this.isFieldTypeDropdown(formData.fieldType) && formData.dataType === 'text'\n            ? formData.matchType\n            : 'exact',\n        fieldType: formData.dataType !== 'boolean' ? formData.fieldType : 'single',\n      };\n\n      const prevFormData = this.selectedSearchField$.value;\n      if (\n        this.dropdownDataProviderSupportsUpdates(prevFormData?.dropdownDataProvider) &&\n        prevFormData.dropdownDataProvider !== mappedFormData?.dropdownDataProvider\n      ) {\n        this.documentService\n          .deleteDropdownData(\n            prevFormData.dropdownDataProvider,\n            documentDefinitionName,\n            prevFormData.key\n          )\n          .subscribe();\n      }\n      if (this.dropdownDataProviderSupportsUpdates(mappedFormData.dropdownDataProvider)) {\n        this.modifiedDropdownValues$.pipe(take(1)).subscribe(dropdownValues => {\n          const request = dropdownValues.reduce(\n            (acc, keyValue) => ({...acc, [keyValue.key]: keyValue.value}),\n            {}\n          );\n          this.documentService\n            .postDropdownData(\n              mappedFormData.dropdownDataProvider,\n              documentDefinitionName,\n              mappedFormData.key,\n              request\n            )\n            .subscribe();\n        });\n      }\n\n      if (this.searchFieldActionTypeIsAdd) {\n        this.documentService.postDocumentSearch(documentDefinitionName, mappedFormData).subscribe(\n          () => {\n            this.enableInput();\n            this.hideModal();\n            this.refreshSearchFields();\n          },\n          () => {\n            this.enableInput();\n          }\n        );\n      } else {\n        const newFields = [...this.cachedSearchFields];\n        const indexToReplace = newFields.findIndex(field => field.key === mappedFormData.key);\n        const filteredFields = newFields.filter(field => field.key !== mappedFormData.key);\n\n        filteredFields.splice(indexToReplace, 0, mappedFormData);\n        this.updateSearchFields(documentDefinitionName, filteredFields);\n      }\n    });\n  }\n\n  updateSearchFields(documentDefinitionName: string, newSearchFields: Array<SearchField>): void {\n    this.disableInput();\n\n    this.documentService.putDocumentSearch(documentDefinitionName, newSearchFields).subscribe(\n      () => {\n        this.enableInput();\n        this.hideModal();\n        this.refreshSearchFields();\n      },\n      () => {\n        this.enableInput();\n      }\n    );\n  }\n\n  private nextIfChanged(behaviourSubject$: BehaviorSubject<any>, value: any) {\n    if (JSON.stringify(behaviourSubject$.value) !== JSON.stringify(value)) {\n      behaviourSubject$.next(value);\n    }\n  }\n\n  private isValid(data: SearchField): boolean {\n    const validMatchType =\n      data.dataType === 'text' && !this.isFieldTypeDropdown(data.fieldType) ? data.matchType : true;\n    const validDropdownDataProvider = this.isFieldTypeDropdown(data.fieldType)\n      ? data.dropdownDataProvider\n      : true;\n    const containsAllValues = !!(\n      data.key &&\n      data.dataType &&\n      validMatchType &&\n      validDropdownDataProvider &&\n      data.path\n    );\n    const keyIsUnique =\n      !this.searchFieldActionTypeIsAdd ||\n      this.cachedSearchFields.findIndex(field => field.key === data.key) === -1;\n\n    return containsAllValues && keyIsUnique;\n  }\n\n  private isFieldTypeDropdown(fieldType?: SearchFieldFieldType): boolean {\n    return fieldType === 'single-select-dropdown' || fieldType === 'multi-select-dropdown';\n  }\n\n  private dropdownDataProviderSupportsUpdates(dropdownDataProvider?: string): boolean {\n    return dropdownDataProvider === 'dropdownDatabaseDataProvider';\n  }\n\n  private openSelectedSearchFieldSubscription(): void {\n    this.subscriptions.add(\n      this.selectedSearchField$.subscribe(() => {\n        this.showModal();\n      })\n    );\n  }\n\n  private openModalShowingSubscription(): void {\n    this.subscriptions.add(\n      this.modal.modalShowing$.subscribe(modalShowing => {\n        if (modalShowing) {\n          setTimeout(() => {\n            this.showSearchFieldsForm = true;\n          }, 0);\n        } else {\n          setTimeout(() => {\n            this.showSearchFieldsForm = false;\n          }, 150);\n        }\n      })\n    );\n  }\n\n  private setDownload(documentDefinitionName: string, searchFields: Array<SearchField>): void {\n    this.downloadName$.next(`${documentDefinitionName}.json`);\n    this.downloadUrl$.next(\n      this.sanitizer.bypassSecurityTrustUrl(\n        'data:text/json;charset=UTF-8,' +\n          encodeURIComponent(JSON.stringify({searchFields}, null, 2))\n      )\n    );\n  }\n\n  private disableInput(): void {\n    this.disableInput$.next(true);\n  }\n\n  private enableInput(): void {\n    this.disableInput$.next(false);\n  }\n\n  private showModal(): void {\n    this.modal?.show();\n  }\n\n  private hideModal(): void {\n    this.modal?.hide();\n  }\n\n  private refreshSearchFields(): void {\n    this.refreshSearchFields$.next(null);\n  }\n}\n","<!--\n  ~ Copyright 2015-2023 Ritense BV, the Netherlands.\n  ~\n  ~ Licensed under EUPL, Version 1.2 (the \"License\");\n  ~ you may not use this file except in compliance with the License.\n  ~ You may obtain a copy of the License at\n  ~\n  ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n  ~\n  ~ Unless required by applicable law or agreed to in writing, software\n  ~ distributed under the License is distributed on an \"AS IS\" basis,\n  ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n  ~ See the License for the specific language governing permissions and\n  ~ limitations under the License.\n  -->\n\n<ng-container\n  *ngIf=\"{\n    searchFields: translatedSearchFields$ | async,\n    fields: fields$ | async,\n    downloadUrl: downloadUrl$ | async,\n    downloadName: downloadName$ | async,\n    documentDefinitionName: documentDefinitionName$ | async,\n    valid: valid$ | async,\n    disableInput: disableInput$ | async\n  } as obs\"\n>\n  <ng-container *ngTemplateOutlet=\"buttons; context: {obs: obs}\"></ng-container>\n  <ng-container *ngTemplateOutlet=\"list; context: {obs: obs}\"></ng-container>\n  <ng-container *ngTemplateOutlet=\"modal; context: {obs: obs}\"></ng-container>\n</ng-container>\n\n<ng-template #buttons let-obs=\"obs\">\n  <div class=\"btn-group mt-m3px mb-3 pr-2 float-right\">\n    <a\n      class=\"btn btn-secondary btn-space\"\n      [href]=\"obs.downloadUrl\"\n      [download]=\"obs.downloadName\"\n      [ngClass]=\"{\n        disabled:\n          !obs.downloadUrl || !obs.downloadName || obs.searchFields.length <= 0 || obs.disableInput\n      }\"\n    >\n      <i class=\"icon mdi mdi-download mr-1\"></i>\n      {{ 'searchFields.downloadButtonText' | translate }}\n    </a>\n    <button\n      (click)=\"searchFieldClicked($event, true)\"\n      class=\"btn btn-primary btn-space\"\n      [ngClass]=\"{disabled: loadingSearchFields || obs.disableInput}\"\n    >\n      <i class=\"icon mdi mdi-plus mr-1\"></i>\n      {{ 'searchFieldsOverview.addRow' | translate }}\n    </button>\n  </div>\n</ng-template>\n\n<ng-template #list let-obs=\"obs\">\n  <valtimo-list\n    [items]=\"obs.searchFields\"\n    [fields]=\"obs.fields\"\n    [viewMode]=\"false\"\n    [header]=\"false\"\n    (rowClicked)=\"searchFieldClicked($event, false)\"\n    *ngIf=\"obs.searchFields; else loading\"\n    [lastColumnTemplate]=\"moveRowButtonsTemplateRef\"\n  >\n  </valtimo-list>\n</ng-template>\n\n<ng-template #moveRowButtons let-index=\"index\" let-length=\"length\">\n  <div\n    class=\"move-row-buttons\"\n    *ngIf=\"{\n      disableInput: disableInput$ | async,\n      documentDefinitionName: documentDefinitionName$ | async\n    } as obs\"\n  >\n    <i\n      class=\"mdi mdi-arrow-up-bold btn btn-outline-primary mr-1\"\n      (click)=\"moveRow(index, true, $event, obs.documentDefinitionName)\"\n      [ngClass]=\"{'disabled disabled-move-row-button': index === 0 || obs.disableInput}\"\n    ></i>\n    <i\n      class=\"mdi mdi-arrow-down-bold btn btn-outline-secondary\"\n      (click)=\"moveRow(index, false, $event, obs.documentDefinitionName)\"\n      [ngClass]=\"{\n        'disabled disabled-move-row-button': index === length - 1 || obs.disableInput\n      }\"\n    ></i>\n  </div>\n</ng-template>\n\n<ng-template #modal let-obs=\"obs\">\n  <valtimo-modal\n    #searchFieldModal\n    elementId=\"searchFieldModal\"\n    [title]=\"\n      searchFieldActionTypeIsAdd\n        ? ('searchFieldsOverview.addRow' | translate)\n        : ('searchFieldsOverview.edit' | translate)\n    \"\n    [showFooter]=\"true\"\n  >\n    <div body class=\"mt-2\">\n      <v-form\n        (valueChange)=\"formValueChange($event)\"\n        *ngIf=\"showSearchFieldsForm && {searchField: selectedSearchField$ | async} as searchObs\"\n      >\n        <v-input\n          name=\"title\"\n          [title]=\"'searchFieldsOverview.title' | translate\"\n          [margin]=\"true\"\n          [defaultValue]=\"searchObs.searchField?.title\"\n          [disabled]=\"obs.disableInput\"\n          [required]=\"false\"\n          [fullWidth]=\"true\"\n          [tooltip]=\"'searchFieldsOverviewTooltips.title' | translate\"\n        >\n        </v-input>\n        <v-input\n          name=\"key\"\n          [title]=\"'searchFieldsOverview.key' | translate\"\n          [margin]=\"true\"\n          [defaultValue]=\"searchObs.searchField?.key\"\n          [disabled]=\"obs.disableInput || !searchFieldActionTypeIsAdd\"\n          [required]=\"true\"\n          [widthPx]=\"200\"\n          [tooltip]=\"'searchFieldsOverviewTooltips.key' | translate\"\n        >\n        </v-input>\n        <v-input\n          name=\"path\"\n          [title]=\"'searchFieldsOverview.path' | translate\"\n          [margin]=\"true\"\n          [defaultValue]=\"searchObs.searchField?.path\"\n          [disabled]=\"obs.disableInput\"\n          [required]=\"true\"\n          [fullWidth]=\"true\"\n          [tooltip]=\"'searchFieldsOverviewTooltips.path' | translate\"\n        >\n        </v-input>\n        <v-select\n          *ngIf=\"dataTypeItems$ | async as dataTypeItems\"\n          [items]=\"dataTypeItems\"\n          [placeholder]=\"'searchFieldsOverview.searchFieldPlaceholder' | translate\"\n          [title]=\"'searchFieldsOverview.dataType' | translate\"\n          [disabled]=\"obs.disableInput\"\n          [margin]=\"true\"\n          [required]=\"true\"\n          name=\"dataType\"\n          [defaultSelectionId]=\"searchObs.searchField?.dataType\"\n          [widthInPx]=\"200\"\n          [tooltip]=\"'searchFieldsOverviewTooltips.dataType' | translate\"\n        ></v-select>\n        <v-select\n          *ngIf=\"(showMatchTypes$ | async) && (matchTypeItems$ | async) as matchTypeItems\"\n          [items]=\"matchTypeItems\"\n          [placeholder]=\"'searchFieldsOverview.searchFieldPlaceholder' | translate\"\n          [title]=\"'searchFieldsOverview.matchType' | translate\"\n          [disabled]=\"obs.disableInput\"\n          [margin]=\"true\"\n          [required]=\"true\"\n          name=\"matchType\"\n          [defaultSelectionId]=\"searchObs.searchField?.matchType\"\n          [widthInPx]=\"200\"\n          [tooltip]=\"'searchFieldsOverviewTooltips.matchType' | translate\"\n        ></v-select>\n        <v-select\n          *ngIf=\"fieldTypeItems$ | async as fieldTypeItems\"\n          [items]=\"fieldTypeItems\"\n          [placeholder]=\"'searchFieldsOverview.searchFieldPlaceholder' | translate\"\n          [title]=\"'searchFieldsOverview.fieldType' | translate\"\n          [disabled]=\"obs.disableInput\"\n          [margin]=\"true\"\n          [required]=\"true\"\n          name=\"fieldType\"\n          [defaultSelectionId]=\"searchObs.searchField?.fieldType\"\n          [widthInPx]=\"200\"\n          [tooltip]=\"'searchFieldsOverviewTooltips.fieldType' | translate\"\n        ></v-select>\n        <v-select\n          *ngIf=\"\n            (fieldTypeIsDropdown$ | async) &&\n            (dropdownDataProviderNames$ | async) as dropdownDataProviderNames\n          \"\n          [items]=\"dropdownDataProviderNames\"\n          [placeholder]=\"'searchFieldsOverview.searchFieldPlaceholder' | translate\"\n          [title]=\"'searchFieldsOverview.dropdownDataProvider' | translate\"\n          [disabled]=\"obs.disableInput\"\n          [margin]=\"true\"\n          [required]=\"false\"\n          name=\"dropdownDataProvider\"\n          [defaultSelectionId]=\"searchObs.searchField?.dropdownDataProvider\"\n          [widthInPx]=\"200\"\n          [tooltip]=\"'searchFieldsOverviewTooltips.dropdownDataProvider' | translate\"\n        ></v-select>\n        <valtimo-carbon-multi-input\n          *ngIf=\"\n            (showInputDropdownTable$ | async) &&\n            (initialDropdownValues$ | async) as initialDropdownValues\n          \"\n          name=\"dropdownValues\"\n          [title]=\"'searchFieldsOverview.dropdownListValues' | translate\"\n          type=\"keyValue\"\n          [disabled]=\"obs.disableInput\"\n          [defaultValues]=\"initialDropdownValues\"\n          [margin]=\"true\"\n          [required]=\"false\"\n          [tooltip]=\"'searchFieldsOverviewTooltips.dropdownListValues' | translate\"\n          (valueChange)=\"dropdownDatalistChange($event)\"\n        >\n        </valtimo-carbon-multi-input>\n        <v-table\n          *ngIf=\"\n            (showReadonlyDropdownTable$ | async) &&\n            (initialDropdownValues$ | async) as initialDropdownValues\n          \"\n          [items]=\"initialDropdownValues\"\n          [columns]=\"dropdownColumns$ | async\"\n          [showEditButtons]=\"false\"\n          [itemsTranslationKey]=\"'searchFieldsOverview'\"\n          [showPagination]=\"false\"\n          [mobileBreakpointPx]=\"200\"\n        ></v-table>\n      </v-form>\n    </div>\n    <div footer>\n      <div class=\"col-12 p-0\">\n        <ng-container *ngTemplateOutlet=\"buttonsFooterModal; context: {obs: obs}\"></ng-container>\n      </div>\n    </div>\n  </valtimo-modal>\n</ng-template>\n\n<ng-template #buttonsFooterModal let-obs=\"obs\">\n  <div class=\"buttons-container\" *ngIf=\"{searchField: selectedSearchField$ | async} as searchObs\">\n    <div class=\"right-buttons\">\n      <button\n        class=\"btn btn-space btn-secondary\"\n        *ngIf=\"!searchFieldActionTypeIsAdd\"\n        [disabled]=\"obs.disableInput\"\n        (click)=\"deleteSelectedSearchField(obs.documentDefinitionName, searchObs.searchField)\"\n      >\n        {{ 'searchFieldsOverview.delete' | translate }}\n      </button>\n      <button\n        (click)=\"saveSearchField(obs.documentDefinitionName)\"\n        type=\"button\"\n        class=\"btn btn-primary btn-space mr-0\"\n        [disabled]=\"obs.disableInput || !obs.valid\"\n      >\n        {{ 'searchFieldsOverview.submit' | translate }}\n      </button>\n    </div>\n  </div>\n</ng-template>\n\n<ng-template #loading>\n  <div class=\"mb-3\">\n    <valtimo-spinner></valtimo-spinner>\n  </div>\n</ng-template>\n"]}