@valtimo/dossier-management 10.7.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
@@ -1,417 +0,0 @@
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
- import * as i7 from "@valtimo/user-interface";
26
- export class DossierManagementSearchFieldsComponent {
27
- constructor(documentService, route, translateService, sanitizer) {
28
- this.documentService = documentService;
29
- this.route = route;
30
- this.translateService = translateService;
31
- this.sanitizer = sanitizer;
32
- this.searchField = new EventEmitter();
33
- this.downloadName$ = new BehaviorSubject('');
34
- this.downloadUrl$ = new BehaviorSubject(undefined);
35
- this.disableInput$ = new BehaviorSubject(false);
36
- this.selectedSearchField$ = new BehaviorSubject(null);
37
- this.formData$ = new BehaviorSubject(null);
38
- this.valid$ = new BehaviorSubject(false);
39
- this.subscriptions = new Subscription();
40
- this.COLUMNS = [
41
- {
42
- viewType: 'string',
43
- sortable: false,
44
- propertyName: 'title',
45
- translationKey: 'title',
46
- },
47
- {
48
- viewType: 'string',
49
- sortable: false,
50
- propertyName: 'key',
51
- translationKey: 'key',
52
- },
53
- {
54
- viewType: 'string',
55
- sortable: false,
56
- propertyName: 'path',
57
- translationKey: 'path',
58
- },
59
- {
60
- viewType: 'string',
61
- sortable: false,
62
- propertyName: 'dataType',
63
- translationKey: 'dataType',
64
- },
65
- {
66
- viewType: 'string',
67
- sortable: false,
68
- propertyName: 'fieldType',
69
- translationKey: 'fieldType',
70
- },
71
- ];
72
- this.dropdownColumns$ = new BehaviorSubject([
73
- {
74
- labelTranslationKey: 'searchFieldsOverview.id',
75
- dataKey: 'key',
76
- },
77
- {
78
- labelTranslationKey: 'searchFieldsOverview.text',
79
- dataKey: 'value',
80
- },
81
- ]);
82
- this.DATA_TYPES = [
83
- 'text',
84
- 'number',
85
- 'date',
86
- 'datetime',
87
- 'boolean',
88
- ];
89
- this.dataTypeItems$ = this.translateService.stream('key').pipe(map(() => this.DATA_TYPES.map(dataType => ({
90
- id: dataType,
91
- text: this.translateService.instant(`searchFields.${dataType}`),
92
- }))));
93
- this.dataTypeIsBoolean$ = new BehaviorSubject(false);
94
- this.dataTypeIsText$ = new BehaviorSubject(false);
95
- this.ALL_FIELD_TYPES = [
96
- 'single',
97
- 'range',
98
- 'single-select-dropdown',
99
- 'multi-select-dropdown',
100
- ];
101
- this.NON_TEXT_FIELD_TYPES = ['single', 'range'];
102
- this.BOOLEAN_FIELD_TYPES = ['single'];
103
- this.fieldTypeItems$ = combineLatest([
104
- this.dataTypeIsBoolean$,
105
- this.dataTypeIsText$,
106
- this.translateService.stream('key'),
107
- ]).pipe(map(([dataTypeIsBoolean, dataTypeIsText]) => {
108
- if (dataTypeIsBoolean) {
109
- return this.BOOLEAN_FIELD_TYPES.map(fieldType => ({
110
- id: fieldType,
111
- text: this.translateService.instant(`searchFieldsOverview.${fieldType}`),
112
- }));
113
- }
114
- else if (!dataTypeIsText) {
115
- return this.NON_TEXT_FIELD_TYPES.map(fieldType => ({
116
- id: fieldType,
117
- text: this.translateService.instant(`searchFieldsOverview.${fieldType}`),
118
- }));
119
- }
120
- return this.ALL_FIELD_TYPES.map(fieldType => ({
121
- id: fieldType,
122
- text: this.translateService.instant(`searchFieldsOverview.${fieldType}`),
123
- }));
124
- }));
125
- this.MATCH_TYPES = ['exact', 'like'];
126
- this.matchTypeItems$ = this.translateService
127
- .stream('key')
128
- .pipe(map(() => this.MATCH_TYPES.map(matchType => ({
129
- id: matchType,
130
- text: this.translateService.instant(`searchFieldsOverview.${matchType}`),
131
- }))));
132
- this.fields$ = this.translateService.stream('key').pipe(map(() => this.COLUMNS.map(column => ({
133
- key: column.propertyName,
134
- label: this.translateService.instant(`searchFieldsOverview.${column.translationKey}`),
135
- sortable: column.sortable,
136
- ...(column.viewType && { viewType: column.viewType }),
137
- ...(column.enum && { enum: column.enum }),
138
- }))));
139
- this.documentDefinitionName$ = this.route.params.pipe(map(params => params.name || ''), filter(docDefName => !!docDefName));
140
- this.loadingSearchFields = true;
141
- this.showSearchFieldsForm = false;
142
- this.refreshSearchFields$ = new BehaviorSubject(null);
143
- this.searchFields$ = combineLatest([
144
- this.documentDefinitionName$,
145
- this.refreshSearchFields$,
146
- ]).pipe(switchMap(([documentDefinitionName]) => this.documentService.getDocumentSearchFields(documentDefinitionName)), tap(searchFields => {
147
- this.documentDefinitionName$.pipe(take(1)).subscribe(documentDefinitionName => {
148
- if (searchFields && Array.isArray(searchFields) && searchFields.length > 0) {
149
- this.setDownload(documentDefinitionName, searchFields);
150
- }
151
- });
152
- }), tap(searchFields => {
153
- this.cachedSearchFields = searchFields;
154
- this.loadingSearchFields = false;
155
- }));
156
- this.translatedSearchFields$ = combineLatest([
157
- this.searchFields$,
158
- this.translateService.stream('key'),
159
- ]).pipe(map(([searchFields]) => searchFields.map(searchField => ({
160
- ...searchField,
161
- title: searchField.title ? searchField.title : '',
162
- dataType: this.translateService.instant(`searchFields.${searchField.dataType}`),
163
- matchType: this.translateService.instant(`searchFieldsOverview.${searchField.matchType}`),
164
- fieldType: this.translateService.instant(`searchFieldsOverview.${searchField.fieldType}`),
165
- }))));
166
- this.fieldTypeIsDropdown$ = new BehaviorSubject(false);
167
- this.dropdownDataProviderNames$ = combineLatest([
168
- this.documentService.getDropdownDataProviders(),
169
- this.translateService.stream('key'),
170
- ]).pipe(map(([providers]) => providers.map(provider => ({
171
- id: provider,
172
- text: this.translateService.instant(`searchFieldsOverview.${provider}`),
173
- }))));
174
- this.modifiedDropdownValues$ = new BehaviorSubject([]);
175
- this.initialDropdownValues$ = combineLatest([
176
- this.documentDefinitionName$,
177
- this.formData$,
178
- ]).pipe(distinctUntilChanged(([prevDocumentDefinitionName, prevFormData], [currDocumentDefinitionName, currFormData]) => prevDocumentDefinitionName === currDocumentDefinitionName &&
179
- prevFormData?.dropdownDataProvider === currFormData?.dropdownDataProvider &&
180
- prevFormData?.key === currFormData?.key), switchMap(([documentDefinitionName, formData]) => {
181
- if (!formData || !formData.dropdownDataProvider) {
182
- return of([]);
183
- }
184
- return this.documentService
185
- .getDropdownData(formData.dropdownDataProvider, documentDefinitionName, formData.key)
186
- .pipe(map(dropdownData => {
187
- if (dropdownData) {
188
- return Object.keys(dropdownData).map(dropdownFieldKey => ({
189
- key: dropdownFieldKey,
190
- value: dropdownData[dropdownFieldKey],
191
- }));
192
- }
193
- return [];
194
- }));
195
- }));
196
- this.showMatchTypes$ = combineLatest([
197
- this.dataTypeIsText$,
198
- this.fieldTypeIsDropdown$,
199
- ]).pipe(map(([dataTypeIsText, fieldTypeIsDropdown]) => dataTypeIsText && !fieldTypeIsDropdown));
200
- this.showReadonlyDropdownTable$ = combineLatest([
201
- this.dataTypeIsText$,
202
- this.fieldTypeIsDropdown$,
203
- this.formData$,
204
- ]).pipe(map(([dataTypeIsText, fieldTypeIsDropdown, formData]) => dataTypeIsText &&
205
- fieldTypeIsDropdown &&
206
- formData?.dropdownDataProvider &&
207
- !this.dropdownDataProviderSupportsUpdates(formData?.dropdownDataProvider)));
208
- this.showInputDropdownTable$ = combineLatest([
209
- this.dataTypeIsText$,
210
- this.fieldTypeIsDropdown$,
211
- this.formData$,
212
- ]).pipe(map(([dataTypeIsText, fieldTypeIsDropdown, formData]) => dataTypeIsText &&
213
- fieldTypeIsDropdown &&
214
- formData?.dropdownDataProvider &&
215
- this.dropdownDataProviderSupportsUpdates(formData?.dropdownDataProvider)));
216
- }
217
- ngOnInit() {
218
- this.openSelectedSearchFieldSubscription();
219
- }
220
- ngAfterViewInit() {
221
- this.openModalShowingSubscription();
222
- }
223
- ngOnDestroy() {
224
- this.subscriptions.unsubscribe();
225
- }
226
- searchFieldClicked(searchField, searchFieldActionTypeIsAdd) {
227
- this.disableInput$.pipe(take(1)).subscribe(inputDisabled => {
228
- if (!inputDisabled) {
229
- this.searchFieldActionTypeIsAdd = searchFieldActionTypeIsAdd;
230
- const searchFieldToSelect = this.cachedSearchFields.find(field => field.key === searchField.key);
231
- this.selectedSearchField$.next(searchFieldToSelect);
232
- }
233
- });
234
- }
235
- formValueChange(data) {
236
- setTimeout(() => {
237
- this.nextIfChanged(this.dataTypeIsText$, data.dataType === 'text');
238
- this.nextIfChanged(this.dataTypeIsBoolean$, data.dataType === 'boolean');
239
- this.nextIfChanged(this.fieldTypeIsDropdown$, this.isFieldTypeDropdown(data.fieldType));
240
- this.nextIfChanged(this.formData$, data);
241
- this.nextIfChanged(this.valid$, this.isValid(data));
242
- }, 0);
243
- }
244
- dropdownDatalistChange(data) {
245
- this.modifiedDropdownValues$.next(data);
246
- }
247
- moveRow(searchFieldRowIndex, moveUp, clickEvent, documentDefinitionName) {
248
- const searchFields = [...this.cachedSearchFields];
249
- const searchFieldRow = searchFields[searchFieldRowIndex];
250
- clickEvent.stopPropagation();
251
- const searchFieldIndex = searchFields.findIndex(field => field.key === searchFieldRow.key);
252
- const foundSearchField = { ...searchFields[searchFieldIndex] };
253
- const filteredSearchFields = searchFields.filter(field => field.key !== searchFieldRow.key);
254
- const multipleSearchFields = searchFields.length > 1;
255
- if (multipleSearchFields && moveUp && searchFieldIndex > 0) {
256
- const searchFieldBeforeKey = `${searchFields[searchFieldIndex - 1].key}`;
257
- const searchFieldBeforeIndex = filteredSearchFields.findIndex(field => field.key === searchFieldBeforeKey);
258
- filteredSearchFields.splice(searchFieldBeforeIndex, 0, foundSearchField);
259
- this.updateSearchFields(documentDefinitionName, filteredSearchFields);
260
- }
261
- else if (multipleSearchFields && !moveUp && searchFieldIndex < searchFields.length) {
262
- const searchFieldAfterKey = `${searchFields[searchFieldIndex + 1].key}`;
263
- const searchFieldAfterIndex = filteredSearchFields.findIndex(field => field.key === searchFieldAfterKey);
264
- filteredSearchFields.splice(searchFieldAfterIndex + 1, 0, foundSearchField);
265
- this.updateSearchFields(documentDefinitionName, filteredSearchFields);
266
- }
267
- }
268
- deleteSelectedSearchField(documentDefinitionName, selectedSearchField) {
269
- this.disableInput();
270
- if (this.dropdownDataProviderSupportsUpdates(selectedSearchField?.dropdownDataProvider)) {
271
- this.documentService
272
- .deleteDropdownData(selectedSearchField.dropdownDataProvider, documentDefinitionName, selectedSearchField.key)
273
- .subscribe();
274
- }
275
- this.documentService
276
- .deleteDocumentSearch(documentDefinitionName, selectedSearchField.key)
277
- .subscribe(() => {
278
- this.enableInput();
279
- this.hideModal();
280
- this.refreshSearchFields();
281
- }, () => {
282
- this.enableInput();
283
- });
284
- }
285
- saveSearchField(documentDefinitionName) {
286
- this.disableInput();
287
- this.formData$.pipe(take(1)).subscribe(formData => {
288
- const mappedFormData = {
289
- ...formData,
290
- matchType: !this.isFieldTypeDropdown(formData.fieldType) && formData.dataType === 'text'
291
- ? formData.matchType
292
- : 'exact',
293
- fieldType: formData.dataType !== 'boolean' ? formData.fieldType : 'single',
294
- };
295
- const prevFormData = this.selectedSearchField$.value;
296
- if (this.dropdownDataProviderSupportsUpdates(prevFormData?.dropdownDataProvider) &&
297
- prevFormData.dropdownDataProvider !== mappedFormData?.dropdownDataProvider) {
298
- this.documentService
299
- .deleteDropdownData(prevFormData.dropdownDataProvider, documentDefinitionName, prevFormData.key)
300
- .subscribe();
301
- }
302
- if (this.dropdownDataProviderSupportsUpdates(mappedFormData.dropdownDataProvider)) {
303
- this.modifiedDropdownValues$.pipe(take(1)).subscribe(dropdownValues => {
304
- const request = dropdownValues.reduce((acc, keyValue) => ({ ...acc, [keyValue.key]: keyValue.value }), {});
305
- this.documentService
306
- .postDropdownData(mappedFormData.dropdownDataProvider, documentDefinitionName, mappedFormData.key, request)
307
- .subscribe();
308
- });
309
- }
310
- if (this.searchFieldActionTypeIsAdd) {
311
- this.documentService.postDocumentSearch(documentDefinitionName, mappedFormData).subscribe(() => {
312
- this.enableInput();
313
- this.hideModal();
314
- this.refreshSearchFields();
315
- }, () => {
316
- this.enableInput();
317
- });
318
- }
319
- else {
320
- const newFields = [...this.cachedSearchFields];
321
- const indexToReplace = newFields.findIndex(field => field.key === mappedFormData.key);
322
- const filteredFields = newFields.filter(field => field.key !== mappedFormData.key);
323
- filteredFields.splice(indexToReplace, 0, mappedFormData);
324
- this.updateSearchFields(documentDefinitionName, filteredFields);
325
- }
326
- });
327
- }
328
- updateSearchFields(documentDefinitionName, newSearchFields) {
329
- this.disableInput();
330
- this.documentService.putDocumentSearch(documentDefinitionName, newSearchFields).subscribe(() => {
331
- this.enableInput();
332
- this.hideModal();
333
- this.refreshSearchFields();
334
- }, () => {
335
- this.enableInput();
336
- });
337
- }
338
- nextIfChanged(behaviourSubject$, value) {
339
- if (JSON.stringify(behaviourSubject$.value) !== JSON.stringify(value)) {
340
- behaviourSubject$.next(value);
341
- }
342
- }
343
- isValid(data) {
344
- const validMatchType = data.dataType === 'text' && !this.isFieldTypeDropdown(data.fieldType) ? data.matchType : true;
345
- const validDropdownDataProvider = this.isFieldTypeDropdown(data.fieldType)
346
- ? data.dropdownDataProvider
347
- : true;
348
- const containsAllValues = !!(data.key &&
349
- data.dataType &&
350
- validMatchType &&
351
- validDropdownDataProvider &&
352
- data.path);
353
- const keyIsUnique = !this.searchFieldActionTypeIsAdd ||
354
- this.cachedSearchFields.findIndex(field => field.key === data.key) === -1;
355
- return containsAllValues && keyIsUnique;
356
- }
357
- isFieldTypeDropdown(fieldType) {
358
- return fieldType === 'single-select-dropdown' || fieldType === 'multi-select-dropdown';
359
- }
360
- dropdownDataProviderSupportsUpdates(dropdownDataProvider) {
361
- return dropdownDataProvider === 'dropdownDatabaseDataProvider';
362
- }
363
- openSelectedSearchFieldSubscription() {
364
- this.subscriptions.add(this.selectedSearchField$.subscribe(() => {
365
- this.showModal();
366
- }));
367
- }
368
- openModalShowingSubscription() {
369
- this.subscriptions.add(this.modal.modalShowing$.subscribe(modalShowing => {
370
- if (modalShowing) {
371
- setTimeout(() => {
372
- this.showSearchFieldsForm = true;
373
- }, 0);
374
- }
375
- else {
376
- setTimeout(() => {
377
- this.showSearchFieldsForm = false;
378
- }, 150);
379
- }
380
- }));
381
- }
382
- setDownload(documentDefinitionName, searchFields) {
383
- this.downloadName$.next(`${documentDefinitionName}.json`);
384
- this.downloadUrl$.next(this.sanitizer.bypassSecurityTrustUrl('data:text/json;charset=UTF-8,' +
385
- encodeURIComponent(JSON.stringify({ searchFields }, null, 2))));
386
- }
387
- disableInput() {
388
- this.disableInput$.next(true);
389
- }
390
- enableInput() {
391
- this.disableInput$.next(false);
392
- }
393
- showModal() {
394
- this.modal?.show();
395
- }
396
- hideModal() {
397
- this.modal?.hide();
398
- }
399
- refreshSearchFields() {
400
- this.refreshSearchFields$.next(null);
401
- }
402
- }
403
- DossierManagementSearchFieldsComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: DossierManagementSearchFieldsComponent, deps: [{ token: i1.DocumentService }, { token: i2.ActivatedRoute }, { token: i3.TranslateService }, { token: i4.DomSanitizer }], target: i0.ɵɵFactoryTarget.Component });
404
- DossierManagementSearchFieldsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", 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]=\"{'disabled disabled-move-row-button': index === length - 1 || obs.disableInput}\"\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 <v-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 </v-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: i7.SelectComponent, selector: "v-select", inputs: ["items", "defaultSelection", "defaultSelectionId", "defaultSelectionIds", "clearable", "disabled", "multiple", "margin", "widthInPx", "notFoundText", "clearAllText", "name", "title", "titleTranslationKey", "clearSelectionSubject$", "tooltip", "required", "loading", "loadingText", "placeholder", "smallMargin"], outputs: ["selectedChange", "clear"] }, { kind: "component", type: i6.SpinnerComponent, selector: "valtimo-spinner", inputs: ["useBootstrapSpinner", "name", "type", "size", "color", "bdColor", "fullScreen", "noMarginTop"] }, { kind: "component", type: i7.InputComponent, selector: "v-input", inputs: ["name", "type", "title", "titleTranslationKey", "defaultValue", "widthPx", "fullWidth", "margin", "smallMargin", "disabled", "step", "min", "maxLength", "tooltip", "required", "hideNumberSpinBox", "smallLabel", "rows", "clear$"], outputs: ["valueChange"] }, { kind: "component", type: i7.FormComponent, selector: "v-form", inputs: ["className"], outputs: ["valueChange"] }, { kind: "component", type: i7.MultiInputComponent, selector: "v-multi-input", inputs: ["name", "title", "titleTranslationKey", "type", "initialAmountOfRows", "minimumAmountOfRows", "maxRows", "addRowText", "addRowTranslationKey", "deleteRowText", "deleteRowTranslationKey", "disabled", "defaultValues", "margin", "tooltip", "required"], outputs: ["valueChange"] }, { kind: "component", type: i7.TableComponent, selector: "v-table", inputs: ["items", "columns", "loading", "showEditButtons", "showPagination", "editButtonTranslationKey", "itemsTranslationKey", "noResultsTranslationKey", "mobileBreakpointPx", "amountOfLoadingRows", "collectionSize", "maxPaginationItemSize", "page", "size"], outputs: ["editButtonClicked", "paginationSizeSet", "paginationPageSet"] }, { kind: "pipe", type: i5.AsyncPipe, name: "async" }, { kind: "pipe", type: i3.TranslatePipe, name: "translate" }] });
405
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: DossierManagementSearchFieldsComponent, decorators: [{
406
- type: Component,
407
- 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]=\"{'disabled disabled-move-row-button': index === length - 1 || obs.disableInput}\"\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 <v-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 </v-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"] }]
408
- }], ctorParameters: function () { return [{ type: i1.DocumentService }, { type: i2.ActivatedRoute }, { type: i3.TranslateService }, { type: i4.DomSanitizer }]; }, propDecorators: { moveRowButtonsTemplateRef: [{
409
- type: ViewChild,
410
- args: ['moveRowButtons']
411
- }], modal: [{
412
- type: ViewChild,
413
- args: ['searchFieldModal']
414
- }], searchField: [{
415
- type: Output
416
- }] } });
417
- //# 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/user-interface';\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]=\"{'disabled disabled-move-row-button': index === length - 1 || obs.disableInput}\"\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        <v-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        </v-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"]}