@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.
- package/esm2022/lib/dossier-management-assignee/dossier-management-assignee.component.mjs +75 -0
- package/{esm2020 → esm2022}/lib/dossier-management-connect-modal/dossier-management-connect-modal.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/dossier-management-detail-container/dossier-management-detail-container.component.mjs +5 -5
- package/esm2022/lib/dossier-management-detail-container/tabs/dossier-management-detail/dossier-management-detail.component.mjs +100 -0
- package/esm2022/lib/dossier-management-detail-container/tabs/dossier-management-list-columns/dossier-management-list-columns.component.mjs +458 -0
- package/esm2022/lib/dossier-management-detail-container/tabs/dossier-management-search-fields/dossier-management-search-fields.component.mjs +416 -0
- package/esm2022/lib/dossier-management-link-process/dossier-management-link-process.component.mjs +84 -0
- package/esm2022/lib/dossier-management-list/dossier-management-list.component.mjs +75 -0
- package/esm2022/lib/dossier-management-remove-modal/dossier-management-remove-modal.component.mjs +59 -0
- package/{esm2020 → esm2022}/lib/dossier-management-routing.module.mjs +5 -5
- package/{esm2020 → esm2022}/lib/dossier-management-upload/dossier-management-upload.component.mjs +5 -5
- package/esm2022/lib/dossier-management.module.mjs +167 -0
- package/{esm2020 → esm2022}/lib/tab.service.mjs +4 -4
- package/{fesm2020 → fesm2022}/valtimo-dossier-management.mjs +158 -247
- package/fesm2022/valtimo-dossier-management.mjs.map +1 -0
- package/lib/dossier-management-assignee/dossier-management-assignee.component.d.ts +1 -1
- package/lib/dossier-management-assignee/dossier-management-assignee.component.d.ts.map +1 -1
- package/lib/dossier-management-connect-modal/dossier-management-connect-modal.component.d.ts +1 -1
- package/lib/dossier-management-detail-container/dossier-management-detail-container.component.d.ts +1 -1
- package/lib/dossier-management-detail-container/tabs/dossier-management-detail/dossier-management-detail.component.d.ts +1 -3
- package/lib/dossier-management-detail-container/tabs/dossier-management-detail/dossier-management-detail.component.d.ts.map +1 -1
- package/lib/dossier-management-detail-container/tabs/dossier-management-list-columns/dossier-management-list-columns.component.d.ts +9 -10
- package/lib/dossier-management-detail-container/tabs/dossier-management-list-columns/dossier-management-list-columns.component.d.ts.map +1 -1
- package/lib/dossier-management-detail-container/tabs/dossier-management-search-fields/dossier-management-search-fields.component.d.ts +2 -2
- package/lib/dossier-management-detail-container/tabs/dossier-management-search-fields/dossier-management-search-fields.component.d.ts.map +1 -1
- package/lib/dossier-management-link-process/dossier-management-link-process.component.d.ts +2 -2
- package/lib/dossier-management-link-process/dossier-management-link-process.component.d.ts.map +1 -1
- package/lib/dossier-management-list/dossier-management-list.component.d.ts +1 -2
- package/lib/dossier-management-list/dossier-management-list.component.d.ts.map +1 -1
- package/lib/dossier-management-remove-modal/dossier-management-remove-modal.component.d.ts +1 -1
- package/lib/dossier-management-remove-modal/dossier-management-remove-modal.component.d.ts.map +1 -1
- package/lib/dossier-management-upload/dossier-management-upload.component.d.ts +1 -1
- package/lib/dossier-management.module.d.ts +14 -16
- package/lib/dossier-management.module.d.ts.map +1 -1
- package/lib/models/list-column.model.d.ts +1 -1
- package/lib/models/list-column.model.d.ts.map +1 -1
- package/package.json +8 -14
- package/esm2020/lib/dossier-management-assignee/dossier-management-assignee.component.mjs +0 -73
- package/esm2020/lib/dossier-management-detail-container/tabs/dossier-management-detail/dossier-management-detail.component.mjs +0 -104
- package/esm2020/lib/dossier-management-detail-container/tabs/dossier-management-list-columns/dossier-management-list-columns.component.mjs +0 -456
- package/esm2020/lib/dossier-management-detail-container/tabs/dossier-management-search-fields/dossier-management-search-fields.component.mjs +0 -417
- package/esm2020/lib/dossier-management-link-process/dossier-management-link-process.component.mjs +0 -84
- package/esm2020/lib/dossier-management-list/dossier-management-list.component.mjs +0 -76
- package/esm2020/lib/dossier-management-remove-modal/dossier-management-remove-modal.component.mjs +0 -57
- package/esm2020/lib/dossier-management-roles/dossier-management-roles.component.mjs +0 -97
- package/esm2020/lib/dossier-management.module.mjs +0 -171
- package/fesm2015/valtimo-dossier-management.mjs +0 -1846
- package/fesm2015/valtimo-dossier-management.mjs.map +0 -1
- package/fesm2020/valtimo-dossier-management.mjs.map +0 -1
- package/lib/dossier-management-roles/dossier-management-roles.component.d.ts +0 -33
- package/lib/dossier-management-roles/dossier-management-roles.component.d.ts.map +0 -1
- /package/{esm2020 → esm2022}/lib/models/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/models/list-column.model.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/tab.enum.mjs +0 -0
- /package/{esm2020 → esm2022}/public-api.mjs +0 -0
- /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"]}
|