@valtimo/object-management 10.3.0 → 10.5.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/esm2020/lib/components/object-management-detail-container/object-management-detail-container.component.mjs +7 -6
- package/esm2020/lib/components/object-management-detail-container/tabs/object-management-detail/object-management-detail.component.mjs +13 -7
- package/esm2020/lib/components/object-management-detail-container/tabs/object-management-list-columns/object-management-list-columns.component.mjs +434 -0
- package/esm2020/lib/components/object-management-detail-container/tabs/object-management-list-search-fields/object-management-list-search-fields.component.mjs +324 -0
- package/esm2020/lib/components/object-management-list/object-management-list.component.mjs +4 -4
- package/esm2020/lib/components/object-management-modal/object-management-modal.component.mjs +7 -6
- package/esm2020/lib/components/object-management-upload-modal/object-management-upload-modal.component.mjs +5 -4
- package/esm2020/lib/models/object-management.model.mjs +16 -1
- package/esm2020/lib/object-management-routing.module.mjs +2 -2
- package/esm2020/lib/object-management.module.mjs +63 -13
- package/esm2020/lib/services/object-management-state.service.mjs +2 -2
- package/esm2020/lib/services/object-management.service.mjs +29 -2
- package/esm2020/lib/services/tab.enum.mjs +17 -1
- package/esm2020/lib/services/tab.service.mjs +2 -2
- package/esm2020/public-api.mjs +2 -2
- package/fesm2015/valtimo-object-management.mjs +823 -59
- package/fesm2015/valtimo-object-management.mjs.map +1 -1
- package/fesm2020/valtimo-object-management.mjs +877 -59
- package/fesm2020/valtimo-object-management.mjs.map +1 -1
- package/lib/components/object-management-detail-container/tabs/object-management-detail/object-management-detail.component.d.ts +2 -1
- package/lib/components/object-management-detail-container/tabs/object-management-list-columns/object-management-list-columns.component.d.ts +91 -0
- package/lib/components/object-management-detail-container/tabs/object-management-list-search-fields/object-management-list-search-fields.component.d.ts +76 -0
- package/lib/models/object-management.model.d.ts +42 -0
- package/lib/object-management.module.d.ts +10 -7
- package/lib/services/object-management.service.d.ts +10 -2
- package/lib/services/tab.enum.d.ts +2 -1
- package/package.json +1 -1
- package/esm2020/lib/components/object-management-detail-container/tabs/object-management-list-tab/object-management-list-tab.component.mjs +0 -30
- package/lib/components/object-management-detail-container/tabs/object-management-list-tab/object-management-list-tab.component.d.ts +0 -9
|
@@ -0,0 +1,324 @@
|
|
|
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, ViewChild } from '@angular/core';
|
|
17
|
+
import { BehaviorSubject, combineLatest, filter, map, of, startWith, Subject, switchMap, tap, } from 'rxjs';
|
|
18
|
+
import { catchError, take } from 'rxjs/operators';
|
|
19
|
+
import { FormControl, FormGroup, Validators } from '@angular/forms';
|
|
20
|
+
import * as i0 from "@angular/core";
|
|
21
|
+
import * as i1 from "../../../../services/object-management.service";
|
|
22
|
+
import * as i2 from "@angular/router";
|
|
23
|
+
import * as i3 from "@ngx-translate/core";
|
|
24
|
+
import * as i4 from "@valtimo/config";
|
|
25
|
+
import * as i5 from "@angular/platform-browser";
|
|
26
|
+
import * as i6 from "@angular/common";
|
|
27
|
+
import * as i7 from "@valtimo/components";
|
|
28
|
+
import * as i8 from "carbon-components-angular";
|
|
29
|
+
import * as i9 from "@valtimo/user-interface";
|
|
30
|
+
import * as i10 from "@angular/forms";
|
|
31
|
+
export class ObjectManagementListSearchFieldsComponent {
|
|
32
|
+
constructor(objectManagementService, route, translateService, configService, sanitizer) {
|
|
33
|
+
this.objectManagementService = objectManagementService;
|
|
34
|
+
this.route = route;
|
|
35
|
+
this.translateService = translateService;
|
|
36
|
+
this.configService = configService;
|
|
37
|
+
this.sanitizer = sanitizer;
|
|
38
|
+
this.downloadName$ = new BehaviorSubject('');
|
|
39
|
+
this.downloadUrl$ = new BehaviorSubject(undefined);
|
|
40
|
+
this.loading$ = new BehaviorSubject(true);
|
|
41
|
+
this.currentModalType$ = new BehaviorSubject('create');
|
|
42
|
+
this.showModal$ = new BehaviorSubject(false);
|
|
43
|
+
this.disableInput$ = new BehaviorSubject(false);
|
|
44
|
+
this.showDeleteModal$ = new Subject();
|
|
45
|
+
this.deleteRowIndex$ = new BehaviorSubject(0);
|
|
46
|
+
this.INVALID_KEY = 'invalid';
|
|
47
|
+
this.formGroup = new FormGroup({
|
|
48
|
+
title: new FormControl(''),
|
|
49
|
+
key: new FormControl('', Validators.required),
|
|
50
|
+
path: new FormControl('', Validators.required),
|
|
51
|
+
dataType: new FormControl({
|
|
52
|
+
key: this.INVALID_KEY,
|
|
53
|
+
}),
|
|
54
|
+
fieldType: new FormControl({
|
|
55
|
+
key: this.INVALID_KEY,
|
|
56
|
+
}),
|
|
57
|
+
});
|
|
58
|
+
this.COLUMNS = [
|
|
59
|
+
{
|
|
60
|
+
viewType: 'string',
|
|
61
|
+
sortable: false,
|
|
62
|
+
propertyName: 'title',
|
|
63
|
+
translationKey: 'title',
|
|
64
|
+
},
|
|
65
|
+
{
|
|
66
|
+
viewType: 'string',
|
|
67
|
+
sortable: false,
|
|
68
|
+
propertyName: 'key',
|
|
69
|
+
translationKey: 'key',
|
|
70
|
+
},
|
|
71
|
+
{
|
|
72
|
+
viewType: 'string',
|
|
73
|
+
sortable: false,
|
|
74
|
+
propertyName: 'path',
|
|
75
|
+
translationKey: 'path',
|
|
76
|
+
},
|
|
77
|
+
{
|
|
78
|
+
viewType: 'string',
|
|
79
|
+
sortable: false,
|
|
80
|
+
propertyName: 'dataType',
|
|
81
|
+
translationKey: 'dataType',
|
|
82
|
+
},
|
|
83
|
+
{
|
|
84
|
+
viewType: 'string',
|
|
85
|
+
sortable: false,
|
|
86
|
+
propertyName: 'fieldType',
|
|
87
|
+
translationKey: 'fieldType',
|
|
88
|
+
},
|
|
89
|
+
];
|
|
90
|
+
this.DATA_TYPES = [
|
|
91
|
+
'text',
|
|
92
|
+
'number',
|
|
93
|
+
'date',
|
|
94
|
+
'datetime',
|
|
95
|
+
'boolean',
|
|
96
|
+
];
|
|
97
|
+
this.FIELD_TYPES = ['single', 'range'];
|
|
98
|
+
this.cachedObjectManagementListSearchFields = [];
|
|
99
|
+
this.refreshObjectManagementListSearchFields$ = new BehaviorSubject(null);
|
|
100
|
+
this.objectManagementFields$ = this.translateService
|
|
101
|
+
.stream('key')
|
|
102
|
+
.pipe(map(() => this.COLUMNS.map(column => ({
|
|
103
|
+
key: column.propertyName,
|
|
104
|
+
label: this.translateService.instant(`searchFieldsOverview.${column.translationKey}`),
|
|
105
|
+
sortable: column.sortable,
|
|
106
|
+
...(column.viewType && { viewType: column.viewType }),
|
|
107
|
+
}))));
|
|
108
|
+
this.objectId$ = this.route.params.pipe(map(params => params.id || ''), filter(objectId => !!objectId));
|
|
109
|
+
this.objectManagementListSearchFields$ = combineLatest([
|
|
110
|
+
this.objectId$,
|
|
111
|
+
this.refreshObjectManagementListSearchFields$,
|
|
112
|
+
]).pipe(switchMap(([objectId]) => this.objectManagementService.getSearchField(objectId)), tap(objectManagementListSearchFields => {
|
|
113
|
+
this.objectId$.pipe(take(1)).subscribe(objectId => {
|
|
114
|
+
if (objectManagementListSearchFields &&
|
|
115
|
+
Array.isArray(objectManagementListSearchFields) &&
|
|
116
|
+
objectManagementListSearchFields.length > 0) {
|
|
117
|
+
this.setDownload(objectId, objectManagementListSearchFields);
|
|
118
|
+
}
|
|
119
|
+
});
|
|
120
|
+
}), tap(objectManagementListSearchFields => {
|
|
121
|
+
this.cachedObjectManagementListSearchFields = objectManagementListSearchFields;
|
|
122
|
+
this.loading$.next(false);
|
|
123
|
+
this.enableInput();
|
|
124
|
+
}));
|
|
125
|
+
this.translatedObjectManagementListSearchFields$ = combineLatest([
|
|
126
|
+
this.objectManagementListSearchFields$,
|
|
127
|
+
this.translateService.stream('key'),
|
|
128
|
+
]).pipe(map(([columns]) => columns.map(column => ({
|
|
129
|
+
...column,
|
|
130
|
+
title: column.title || '-',
|
|
131
|
+
dataType: this.translateService.instant(`searchFields.${column?.dataType?.toLowerCase()}`),
|
|
132
|
+
fieldType: this.translateService.instant(`searchFieldsOverview.${column?.fieldType?.toLowerCase()}`),
|
|
133
|
+
}))));
|
|
134
|
+
this.selectedDataTypeItemIndex$ = new BehaviorSubject(0);
|
|
135
|
+
this.dataTypeItems$ = combineLatest([
|
|
136
|
+
this.selectedDataTypeItemIndex$,
|
|
137
|
+
this.translateService.stream('key'),
|
|
138
|
+
]).pipe(map(([selectedDataTypeItemIndex]) => [
|
|
139
|
+
{
|
|
140
|
+
content: this.translateService.instant(`searchFieldDataType.select`),
|
|
141
|
+
key: this.INVALID_KEY,
|
|
142
|
+
},
|
|
143
|
+
...this.DATA_TYPES.map(type => ({
|
|
144
|
+
content: this.translateService.instant(`searchFields.${type}`),
|
|
145
|
+
key: type.toUpperCase(),
|
|
146
|
+
})),
|
|
147
|
+
].map((item, index) => ({
|
|
148
|
+
...item,
|
|
149
|
+
selected: index === selectedDataTypeItemIndex,
|
|
150
|
+
}))));
|
|
151
|
+
this.selectedFieldTypeItemIndex$ = new BehaviorSubject(0);
|
|
152
|
+
this.fieldTypeItems$ = combineLatest([
|
|
153
|
+
this.selectedFieldTypeItemIndex$,
|
|
154
|
+
this.translateService.stream('key'),
|
|
155
|
+
]).pipe(map(([selectedFieldTypeItemIndex]) => [
|
|
156
|
+
{
|
|
157
|
+
content: this.translateService.instant(`searchFieldFieldType.select`),
|
|
158
|
+
key: this.INVALID_KEY,
|
|
159
|
+
},
|
|
160
|
+
...this.FIELD_TYPES.map(type => ({
|
|
161
|
+
content: this.translateService.instant(`searchFieldsOverview.${type}`),
|
|
162
|
+
key: type.toUpperCase(),
|
|
163
|
+
})),
|
|
164
|
+
].map((item, index) => ({
|
|
165
|
+
...item,
|
|
166
|
+
selected: index === selectedFieldTypeItemIndex,
|
|
167
|
+
}))));
|
|
168
|
+
this.validKey$ = combineLatest([this.formGroup.valueChanges, this.currentModalType$]).pipe(map(([formValues, currentModalType]) => {
|
|
169
|
+
const existingKeys = this.cachedObjectManagementListSearchFields.map(column => column.key);
|
|
170
|
+
return currentModalType === 'create' ? !existingKeys.includes(formValues.key) : true;
|
|
171
|
+
}), startWith(false));
|
|
172
|
+
this.valid$ = combineLatest([this.formGroup.valueChanges, this.validKey$]).pipe(map(([formValues, validKey]) => !!(formValues.path && validKey)), startWith(false));
|
|
173
|
+
}
|
|
174
|
+
openModal(modalType) {
|
|
175
|
+
this.showModal$.next(true);
|
|
176
|
+
this.currentModalType$.next(modalType);
|
|
177
|
+
if (modalType === 'create') {
|
|
178
|
+
this.formGroup.controls['key'].enable();
|
|
179
|
+
this.resetFormGroup();
|
|
180
|
+
}
|
|
181
|
+
else if (modalType === 'edit') {
|
|
182
|
+
this.formGroup.controls['key'].disable();
|
|
183
|
+
}
|
|
184
|
+
}
|
|
185
|
+
closeModal() {
|
|
186
|
+
this.showModal$.next(false);
|
|
187
|
+
}
|
|
188
|
+
deleteRow(listSearchFieldRowIndex, clickEvent) {
|
|
189
|
+
clickEvent.stopPropagation();
|
|
190
|
+
this.showDeleteModal$.next(true);
|
|
191
|
+
this.deleteRowIndex$.next(listSearchFieldRowIndex);
|
|
192
|
+
}
|
|
193
|
+
deleteRowConfirmation(listSearchFieldRowIndex) {
|
|
194
|
+
const columnKey = this.getColumnKey(listSearchFieldRowIndex);
|
|
195
|
+
if (columnKey) {
|
|
196
|
+
this.disableInput();
|
|
197
|
+
this.objectId$
|
|
198
|
+
.pipe(take(1), switchMap(objectId => this.objectManagementService.deleteSearchField(objectId, columnKey)), tap(() => this.refreshObjectManagementListSearchFields()), catchError(() => {
|
|
199
|
+
this.enableInput();
|
|
200
|
+
return of(null);
|
|
201
|
+
}))
|
|
202
|
+
.subscribe();
|
|
203
|
+
}
|
|
204
|
+
}
|
|
205
|
+
getColumnKey(listSearchFieldRowIndex) {
|
|
206
|
+
return this.cachedObjectManagementListSearchFields[listSearchFieldRowIndex]?.key;
|
|
207
|
+
}
|
|
208
|
+
moveRow(listSearchFieldRowIndex, moveUp, clickEvent, objectId) {
|
|
209
|
+
const objectManagementListSearchFields = [...this.cachedObjectManagementListSearchFields];
|
|
210
|
+
const listSearchFieldRow = objectManagementListSearchFields[listSearchFieldRowIndex];
|
|
211
|
+
clickEvent.stopPropagation();
|
|
212
|
+
}
|
|
213
|
+
saveListSearchFields() {
|
|
214
|
+
this.disableInput();
|
|
215
|
+
this.currentModalType$.pipe(take(1)).subscribe(currentModalType => {
|
|
216
|
+
if (currentModalType === 'create') {
|
|
217
|
+
this.addSearchField();
|
|
218
|
+
}
|
|
219
|
+
else {
|
|
220
|
+
this.updateSearchField();
|
|
221
|
+
}
|
|
222
|
+
});
|
|
223
|
+
}
|
|
224
|
+
columnRowClicked(row) {
|
|
225
|
+
this.resetFormGroup();
|
|
226
|
+
combineLatest([this.dataTypeItems$, this.fieldTypeItems$])
|
|
227
|
+
.pipe(take(1))
|
|
228
|
+
.subscribe(([dataTypeItems, fieldTypeItems]) => {
|
|
229
|
+
const column = this.cachedObjectManagementListSearchFields.find(cachedColumn => cachedColumn.key === row.key);
|
|
230
|
+
const dataTypeItem = dataTypeItems.find(item => item.key === column.dataType);
|
|
231
|
+
const dataTypeItemIndex = dataTypeItems.findIndex(item => item.key === column.dataType);
|
|
232
|
+
const fieldTypeItem = fieldTypeItems.find(item => item.key === column.fieldType);
|
|
233
|
+
const fieldTypeItemIndex = fieldTypeItems.findIndex(item => item.key === column.fieldType);
|
|
234
|
+
this.selectedDataTypeItemIndex$.next(dataTypeItemIndex);
|
|
235
|
+
this.selectedFieldTypeItemIndex$.next(fieldTypeItemIndex);
|
|
236
|
+
this.formGroup.patchValue({
|
|
237
|
+
key: column.key,
|
|
238
|
+
title: column.title,
|
|
239
|
+
path: column.path,
|
|
240
|
+
// @ts-ignore
|
|
241
|
+
dataType: { ...dataTypeItem },
|
|
242
|
+
// @ts-ignore
|
|
243
|
+
fieldType: { ...fieldTypeItem },
|
|
244
|
+
});
|
|
245
|
+
this.openModal('edit');
|
|
246
|
+
});
|
|
247
|
+
}
|
|
248
|
+
updateObjectManagementListSearchField(objectId, searchField) {
|
|
249
|
+
this.disableInput();
|
|
250
|
+
this.objectManagementService
|
|
251
|
+
.putSearchField(objectId, this.formGroup.value.key, searchField)
|
|
252
|
+
.pipe(tap(() => {
|
|
253
|
+
this.refreshObjectManagementListSearchFields();
|
|
254
|
+
localStorage.setItem(`list-search-fields${objectId}`, null);
|
|
255
|
+
}), catchError(() => {
|
|
256
|
+
this.enableInput();
|
|
257
|
+
return of(null);
|
|
258
|
+
}))
|
|
259
|
+
.subscribe();
|
|
260
|
+
}
|
|
261
|
+
addSearchField() {
|
|
262
|
+
const formValue = this.formGroup.value;
|
|
263
|
+
this.objectId$
|
|
264
|
+
.pipe(take(1), switchMap(objectId => this.objectManagementService.postSearchField(objectId, this.mapFormValuesToColumn(formValue))), tap(() => {
|
|
265
|
+
this.closeModal();
|
|
266
|
+
this.refreshObjectManagementListSearchFields();
|
|
267
|
+
}), catchError(() => {
|
|
268
|
+
this.enableInput();
|
|
269
|
+
return of(null);
|
|
270
|
+
}))
|
|
271
|
+
.subscribe();
|
|
272
|
+
}
|
|
273
|
+
updateSearchField() {
|
|
274
|
+
this.objectId$
|
|
275
|
+
.pipe(take(1), switchMap(objectId => this.objectManagementService.putSearchField(objectId, this.formGroup.value.key, this.mapFormValuesToColumn(this.formGroup.value))), tap(() => {
|
|
276
|
+
this.closeModal();
|
|
277
|
+
this.refreshObjectManagementListSearchFields();
|
|
278
|
+
}), catchError(() => {
|
|
279
|
+
this.enableInput();
|
|
280
|
+
return of(null);
|
|
281
|
+
}))
|
|
282
|
+
.subscribe();
|
|
283
|
+
}
|
|
284
|
+
setDownload(objectId, ObjectManagementSearchFields) {
|
|
285
|
+
this.downloadName$.next(`${objectId}.json`);
|
|
286
|
+
this.downloadUrl$.next(this.sanitizer.bypassSecurityTrustUrl('data:text/json;charset=UTF-8,' +
|
|
287
|
+
encodeURIComponent(JSON.stringify(ObjectManagementSearchFields, null, 2))));
|
|
288
|
+
}
|
|
289
|
+
disableInput() {
|
|
290
|
+
this.disableInput$.next(true);
|
|
291
|
+
this.formGroup.disable();
|
|
292
|
+
}
|
|
293
|
+
enableInput() {
|
|
294
|
+
this.disableInput$.next(false);
|
|
295
|
+
this.formGroup.enable();
|
|
296
|
+
}
|
|
297
|
+
refreshObjectManagementListSearchFields() {
|
|
298
|
+
this.refreshObjectManagementListSearchFields$.next(null);
|
|
299
|
+
}
|
|
300
|
+
resetFormGroup() {
|
|
301
|
+
this.formGroup.reset();
|
|
302
|
+
this.selectedDataTypeItemIndex$.next(0);
|
|
303
|
+
this.selectedFieldTypeItemIndex$.next(0);
|
|
304
|
+
}
|
|
305
|
+
mapFormValuesToColumn(formValue) {
|
|
306
|
+
return {
|
|
307
|
+
key: formValue.key,
|
|
308
|
+
title: formValue.title || '',
|
|
309
|
+
path: formValue.path,
|
|
310
|
+
dataType: formValue.dataType.key,
|
|
311
|
+
fieldType: formValue.fieldType.key,
|
|
312
|
+
};
|
|
313
|
+
}
|
|
314
|
+
}
|
|
315
|
+
ObjectManagementListSearchFieldsComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: ObjectManagementListSearchFieldsComponent, deps: [{ token: i1.ObjectManagementService }, { token: i2.ActivatedRoute }, { token: i3.TranslateService }, { token: i4.ConfigService }, { token: i5.DomSanitizer }], target: i0.ɵɵFactoryTarget.Component });
|
|
316
|
+
ObjectManagementListSearchFieldsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: ObjectManagementListSearchFieldsComponent, selector: "valtimo-object-management-list-search-fields", viewQueries: [{ propertyName: "moveRowButtonsTemplateRef", first: true, predicate: ["moveRowButtons"], 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<ng-container\n *ngIf=\"{\n searchFields: translatedObjectManagementListSearchFields$ | async,\n fields: objectManagementFields$ | async,\n objectId: objectId$ | async,\n downloadUrl: downloadUrl$ | async,\n downloadName: downloadName$ | async,\n loading: loading$ | async\n } as obs\"\n>\n <div class=\"container-fluid pr-0 pl-0\">\n <div class=\"text-right\">\n <div class=\"btn-group mt-m3px mb-3 mr-2\">\n <ng-container *ngTemplateOutlet=\"buttons; context: {obs: obs}\"></ng-container>\n </div>\n </div>\n <ng-container *ngIf=\"!obs.loading; else loading\">\n <ng-container *ngIf=\"obs.searchFields?.length > 0; else noConfigWarning\">\n <ng-container *ngTemplateOutlet=\"list; context: {obs: obs}\"></ng-container>\n </ng-container>\n </ng-container>\n <ng-container *ngTemplateOutlet=\"createEditModal\"></ng-container>\n <ng-container *ngTemplateOutlet=\"deleteModal\"></ng-container>\n </div>\n</ng-container>\n\n<ng-template #buttons let-obs=\"obs\">\n <a\n ibmLink\n class=\"center-link\"\n [href]=\"obs.downloadUrl\"\n [download]=\"obs.downloadName\"\n [disabled]=\"\n !obs.downloadUrl ||\n !obs.downloadName ||\n obs.searchFields?.length < 1 ||\n obs.disableInput ||\n obs.loading\n \"\n >\n {{ 'searchFieldsOverview.download' | translate }}\n </a>\n <button\n (click)=\"openModal('create')\"\n ibmButton=\"primary\"\n size=\"md\"\n [disabled]=\"obs.loading\"\n class=\"ml-3\"\n >\n {{ 'searchFieldsOverview.add' | translate }}\n <svg class=\"cds--btn__icon\" ibmIcon=\"add\" size=\"16\"></svg>\n </button>\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 objectId: objectId$ | async\n } as obs\"\n >\n <i\n class=\"mdi mdi-delete btn btn-outline-danger mr-1\"\n (click)=\"deleteRow(index, $event)\"\n [ngClass]=\"{'disabled disabled-move-row-button': obs.disableInput}\"\n ></i>\n <i\n class=\"mdi mdi-arrow-up-bold btn btn-outline-primary mr-1\"\n (click)=\"moveRow(index, true, $event, obs.objectId)\"\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.objectId)\"\n [ngClass]=\"{'disabled disabled-move-row-button': index === length - 1 || obs.disableInput}\"\n ></i>\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 *ngIf=\"obs.searchFields; else loading\"\n [lastColumnTemplate]=\"moveRowButtonsTemplateRef\"\n (rowClicked)=\"columnRowClicked($event)\"\n >\n </valtimo-list>\n</ng-template>\n\n<ng-template #createEditModal>\n <ibm-modal\n *ngIf=\"{\n type: currentModalType$ | async,\n show: showModal$ | async,\n valid: valid$ | async,\n disableInput: disableInput$ | async,\n validKey: validKey$ | async\n } as modalObs\"\n [open]=\"modalObs.show\"\n >\n <ibm-modal-header [showCloseButton]=\"true\" (closeSelect)=\"closeModal()\">\n <h3 ibmModalHeaderHeading>\n {{\n modalObs.type === 'create'\n ? ('searchFieldsOverview.add' | translate)\n : ('searchFieldsOverview.edit' | translate)\n }}\n </h3>\n </ibm-modal-header>\n <section ibmModalContent>\n <ng-container *ngTemplateOutlet=\"modalContent; context: {modalObs: modalObs}\"></ng-container>\n </section>\n <ng-container *ngTemplateOutlet=\"modalFooter; context: {modalObs: modalObs}\"></ng-container>\n </ibm-modal>\n</ng-template>\n\n<ng-template #modalContent let-modalObs=\"modalObs\">\n <form [formGroup]=\"formGroup\" class=\"list-column-form\">\n <div class=\"cds--text-input__field-wrapper\">\n <ibm-label [disabled]=\"modalObs.disableInput\">\n <span class=\"label-with-tooltip\">\n {{ 'searchFieldsOverview.title' | translate }}\n <v-tooltip-icon\n [tooltip]=\"'searchFieldsOverviewTooltips.title' | translate\"\n [disabled]=\"modalObs.disableInput\"\n ></v-tooltip-icon>\n </span>\n <input ibmText formControlName=\"title\" />\n </ibm-label>\n </div>\n <div class=\"cds--text-input__field-wrapper\">\n <ibm-label\n [disabled]=\"modalObs.disableInput || modalObs.type === 'edit'\"\n [invalid]=\"modalObs.validKey === false\"\n [invalidText]=\"'searchFieldsOverview.uniqueKeyWarning' | translate\"\n >\n <span class=\"label-with-tooltip\">\n {{ 'searchFieldsOverview.key' | translate }}\n <v-tooltip-icon\n [tooltip]=\"'searchFieldsOverviewTooltips.key' | translate\"\n [disabled]=\"modalObs.disableInput\"\n ></v-tooltip-icon>\n </span>\n <input ibmText formControlName=\"key\" [invalid]=\"modalObs.validKey === false\" />\n </ibm-label>\n </div>\n <div class=\"cds--text-input__field-wrapper\">\n <ibm-label [disabled]=\"modalObs.disableInput\">\n <span class=\"label-with-tooltip\">\n {{ 'searchFieldsOverview.path' | translate }}\n <v-tooltip-icon\n [tooltip]=\"'searchFieldsOverviewTooltips.path' | translate\"\n [disabled]=\"modalObs.disableInput\"\n ></v-tooltip-icon>\n </span>\n <input ibmText formControlName=\"path\" />\n </ibm-label>\n </div>\n <div class=\"cds--text-input__field-wrapper\">\n <ibm-label [disabled]=\"modalObs.disableInput\">\n <span class=\"label-with-tooltip select-label\">\n {{ 'searchFieldsOverview.dataType' | translate }}\n <v-tooltip-icon\n [tooltip]=\"'searchFieldsOverviewTooltips.dataType' | translate\"\n [disabled]=\"modalObs.disableInput\"\n ></v-tooltip-icon>\n </span>\n <ibm-dropdown formControlName=\"dataType\" [disabled]=\"modalObs.disableInput\">\n <ibm-dropdown-list [items]=\"dataTypeItems$ | async\"></ibm-dropdown-list>\n </ibm-dropdown>\n </ibm-label>\n </div>\n <div class=\"cds--text-input__field-wrapper\">\n <ibm-label [disabled]=\"modalObs.disableInput\">\n <span class=\"label-with-tooltip select-label\">\n {{ 'searchFieldsOverview.fieldType' | translate }}\n <v-tooltip-icon\n [tooltip]=\"'searchFieldsOverviewTooltips.fieldType' | translate\"\n [disabled]=\"modalObs.disableInput\"\n ></v-tooltip-icon>\n </span>\n <ibm-dropdown formControlName=\"fieldType\" [disabled]=\"modalObs.disableInput\">\n <ibm-dropdown-list [items]=\"fieldTypeItems$ | async\"></ibm-dropdown-list>\n </ibm-dropdown>\n </ibm-label>\n </div>\n </form>\n</ng-template>\n\n<ng-template #modalFooter let-modalObs=\"modalObs\">\n <ibm-modal-footer>\n <ng-container>\n <button\n ibmButton=\"secondary\"\n [attr.modal-primary-focus]=\"true\"\n (click)=\"closeModal()\"\n [disabled]=\"modalObs.disableInput\"\n >\n {{ 'searchFieldsOverview.close' | translate }}\n </button>\n <button\n ibmButton=\"primary\"\n [attr.modal-primary-focus]=\"true\"\n [disabled]=\"modalObs.valid === false\"\n (click)=\"saveListSearchFields()\"\n [disabled]=\"\n modalObs.disableInput || modalObs.valid === false || modalObs.validKey === false\n \"\n >\n {{ 'searchFieldsOverview.save' | translate }}\n </button>\n </ng-container>\n </ibm-modal-footer>\n</ng-template>\n\n<ng-template #deleteModal>\n <valtimo-confirmation-modal\n [showModalSubject$]=\"showDeleteModal$\"\n [outputOnConfirm]=\"deleteRowIndex$ | async\"\n (confirmEvent)=\"deleteRowConfirmation($event)\"\n confirmButtonTextTranslationKey=\"searchFieldsOverview.deleteSearchField\"\n titleTranslationKey=\"searchFieldsOverview.searchField\"\n contentTranslationKey=\"searchFieldsOverview.deleteSearchFieldConfirmation\"\n ></valtimo-confirmation-modal>\n</ng-template>\n\n<ng-template #noConfigWarning>\n <div class=\"pl-2 pr-2 pb-2\">\n <ibm-notification\n [notificationObj]=\"{\n type: 'info',\n title: 'searchFieldsOverview.noSearchFieldsConfiguredWarningTitle' | translate,\n showClose: false\n }\"\n >\n </ibm-notification>\n </div>\n</ng-template>\n\n<ng-template #loading>\n <div class=\"loading-icon\"><ibm-loading></ibm-loading></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 */::ng-deep .tab-container{min-height:unset!important}::ng-deep .cds--inline-notification{max-width:100%}.label-with-tooltip{display:flex;align-items:center}.cds--text-input__field-wrapper:not(:last-child){margin-bottom:1rem}.display-type-dropdown{width:300px}.list-column-form{margin-bottom:3rem}.select-label{padding-bottom:.5rem;width:250px}.loading-icon{width:100%;display:flex;align-items:center;justify-content:center}.center-link{display:flex;align-items:center}::ng-deep .move-row-buttons{display:flex;flex-direction:row;justify-content:flex-end;padding-right:13px}\n"], dependencies: [{ kind: "directive", type: i6.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i6.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i7.ListComponent, selector: "valtimo-list", inputs: ["items", "fields", "pagination", "viewMode", "isSearchable", "header", "actions", "paginationIdentifier", "initialSortState", "lastColumnTemplate"], outputs: ["rowClicked", "paginationClicked", "paginationSet", "search", "sortChanged"] }, { kind: "component", type: i8.Label, selector: "ibm-label", inputs: ["labelInputID", "disabled", "labelState", "skeleton", "helperText", "invalidText", "invalid", "warn", "warnText", "ariaLabel"] }, { kind: "directive", type: i8.TextInput, selector: "[ibmText]", inputs: ["theme", "size", "invalid", "warn", "skeleton"] }, { kind: "directive", type: i8.Button, selector: "[ibmButton]", inputs: ["ibmButton", "size", "skeleton", "iconOnly", "isExpressive"] }, { kind: "component", type: i9.TooltipIconComponent, selector: "v-tooltip-icon", inputs: ["tooltip", "disabled"] }, { kind: "component", type: i8.Modal, selector: "ibm-modal", inputs: ["size", "theme", "ariaLabel", "open", "trigger", "hasScrollingContent"], outputs: ["overlaySelected", "close"] }, { kind: "component", type: i8.ModalHeader, selector: "ibm-modal-header", inputs: ["theme", "closeLabel", "showCloseButton"], outputs: ["closeSelect"] }, { kind: "component", type: i8.ModalFooter, selector: "ibm-modal-footer" }, { kind: "directive", type: i8.ModalContent, selector: "[ibmModalContent]", inputs: ["hasForm"] }, { kind: "directive", type: i8.ModalHeaderHeading, selector: "[ibmModalHeaderHeading]" }, { kind: "component", type: i8.Notification, selector: "ibm-notification,ibm-inline-notification", inputs: ["notificationObj"] }, { kind: "component", type: i8.Loading, selector: "ibm-loading", inputs: ["title", "isActive", "size", "overlay"] }, { kind: "component", type: i8.Dropdown, selector: "ibm-dropdown", inputs: ["id", "label", "helperText", "placeholder", "displayValue", "clearText", "size", "type", "theme", "disabled", "skeleton", "inline", "disableArrowKeys", "invalid", "invalidText", "warn", "warnText", "appendInline", "scrollableContainer", "itemValueKey", "selectionFeedback", "menuButtonLabel", "selectedLabel", "dropUp"], outputs: ["selected", "onClose", "close"] }, { kind: "component", type: i8.DropdownList, selector: "ibm-dropdown-list", inputs: ["ariaLabel", "items", "listTpl", "type", "showTitles"], outputs: ["select", "scroll", "blurIntent"] }, { kind: "directive", type: i8.Link, selector: "[ibmLink]", inputs: ["inline", "disabled"] }, { kind: "directive", type: i8.IconDirective, selector: "[ibmIcon]", inputs: ["ibmIcon", "size", "title", "ariaLabel", "ariaLabelledBy", "ariaHidden", "isFocusable"] }, { kind: "directive", type: i10.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i10.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i10.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i10.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i10.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i10.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "component", type: i7.ConfirmationModalComponent, selector: "valtimo-confirmation-modal", inputs: ["titleTranslationKey", "title", "content", "contentTranslationKey", "confirmButtonText", "confirmButtonTextTranslationKey", "cancelButtonText", "cancelButtonTextTranslationKey", "showModalSubject$", "outputOnConfirm"], outputs: ["confirmEvent"] }, { kind: "pipe", type: i6.AsyncPipe, name: "async" }, { kind: "pipe", type: i3.TranslatePipe, name: "translate" }] });
|
|
317
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: ObjectManagementListSearchFieldsComponent, decorators: [{
|
|
318
|
+
type: Component,
|
|
319
|
+
args: [{ selector: 'valtimo-object-management-list-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<ng-container\n *ngIf=\"{\n searchFields: translatedObjectManagementListSearchFields$ | async,\n fields: objectManagementFields$ | async,\n objectId: objectId$ | async,\n downloadUrl: downloadUrl$ | async,\n downloadName: downloadName$ | async,\n loading: loading$ | async\n } as obs\"\n>\n <div class=\"container-fluid pr-0 pl-0\">\n <div class=\"text-right\">\n <div class=\"btn-group mt-m3px mb-3 mr-2\">\n <ng-container *ngTemplateOutlet=\"buttons; context: {obs: obs}\"></ng-container>\n </div>\n </div>\n <ng-container *ngIf=\"!obs.loading; else loading\">\n <ng-container *ngIf=\"obs.searchFields?.length > 0; else noConfigWarning\">\n <ng-container *ngTemplateOutlet=\"list; context: {obs: obs}\"></ng-container>\n </ng-container>\n </ng-container>\n <ng-container *ngTemplateOutlet=\"createEditModal\"></ng-container>\n <ng-container *ngTemplateOutlet=\"deleteModal\"></ng-container>\n </div>\n</ng-container>\n\n<ng-template #buttons let-obs=\"obs\">\n <a\n ibmLink\n class=\"center-link\"\n [href]=\"obs.downloadUrl\"\n [download]=\"obs.downloadName\"\n [disabled]=\"\n !obs.downloadUrl ||\n !obs.downloadName ||\n obs.searchFields?.length < 1 ||\n obs.disableInput ||\n obs.loading\n \"\n >\n {{ 'searchFieldsOverview.download' | translate }}\n </a>\n <button\n (click)=\"openModal('create')\"\n ibmButton=\"primary\"\n size=\"md\"\n [disabled]=\"obs.loading\"\n class=\"ml-3\"\n >\n {{ 'searchFieldsOverview.add' | translate }}\n <svg class=\"cds--btn__icon\" ibmIcon=\"add\" size=\"16\"></svg>\n </button>\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 objectId: objectId$ | async\n } as obs\"\n >\n <i\n class=\"mdi mdi-delete btn btn-outline-danger mr-1\"\n (click)=\"deleteRow(index, $event)\"\n [ngClass]=\"{'disabled disabled-move-row-button': obs.disableInput}\"\n ></i>\n <i\n class=\"mdi mdi-arrow-up-bold btn btn-outline-primary mr-1\"\n (click)=\"moveRow(index, true, $event, obs.objectId)\"\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.objectId)\"\n [ngClass]=\"{'disabled disabled-move-row-button': index === length - 1 || obs.disableInput}\"\n ></i>\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 *ngIf=\"obs.searchFields; else loading\"\n [lastColumnTemplate]=\"moveRowButtonsTemplateRef\"\n (rowClicked)=\"columnRowClicked($event)\"\n >\n </valtimo-list>\n</ng-template>\n\n<ng-template #createEditModal>\n <ibm-modal\n *ngIf=\"{\n type: currentModalType$ | async,\n show: showModal$ | async,\n valid: valid$ | async,\n disableInput: disableInput$ | async,\n validKey: validKey$ | async\n } as modalObs\"\n [open]=\"modalObs.show\"\n >\n <ibm-modal-header [showCloseButton]=\"true\" (closeSelect)=\"closeModal()\">\n <h3 ibmModalHeaderHeading>\n {{\n modalObs.type === 'create'\n ? ('searchFieldsOverview.add' | translate)\n : ('searchFieldsOverview.edit' | translate)\n }}\n </h3>\n </ibm-modal-header>\n <section ibmModalContent>\n <ng-container *ngTemplateOutlet=\"modalContent; context: {modalObs: modalObs}\"></ng-container>\n </section>\n <ng-container *ngTemplateOutlet=\"modalFooter; context: {modalObs: modalObs}\"></ng-container>\n </ibm-modal>\n</ng-template>\n\n<ng-template #modalContent let-modalObs=\"modalObs\">\n <form [formGroup]=\"formGroup\" class=\"list-column-form\">\n <div class=\"cds--text-input__field-wrapper\">\n <ibm-label [disabled]=\"modalObs.disableInput\">\n <span class=\"label-with-tooltip\">\n {{ 'searchFieldsOverview.title' | translate }}\n <v-tooltip-icon\n [tooltip]=\"'searchFieldsOverviewTooltips.title' | translate\"\n [disabled]=\"modalObs.disableInput\"\n ></v-tooltip-icon>\n </span>\n <input ibmText formControlName=\"title\" />\n </ibm-label>\n </div>\n <div class=\"cds--text-input__field-wrapper\">\n <ibm-label\n [disabled]=\"modalObs.disableInput || modalObs.type === 'edit'\"\n [invalid]=\"modalObs.validKey === false\"\n [invalidText]=\"'searchFieldsOverview.uniqueKeyWarning' | translate\"\n >\n <span class=\"label-with-tooltip\">\n {{ 'searchFieldsOverview.key' | translate }}\n <v-tooltip-icon\n [tooltip]=\"'searchFieldsOverviewTooltips.key' | translate\"\n [disabled]=\"modalObs.disableInput\"\n ></v-tooltip-icon>\n </span>\n <input ibmText formControlName=\"key\" [invalid]=\"modalObs.validKey === false\" />\n </ibm-label>\n </div>\n <div class=\"cds--text-input__field-wrapper\">\n <ibm-label [disabled]=\"modalObs.disableInput\">\n <span class=\"label-with-tooltip\">\n {{ 'searchFieldsOverview.path' | translate }}\n <v-tooltip-icon\n [tooltip]=\"'searchFieldsOverviewTooltips.path' | translate\"\n [disabled]=\"modalObs.disableInput\"\n ></v-tooltip-icon>\n </span>\n <input ibmText formControlName=\"path\" />\n </ibm-label>\n </div>\n <div class=\"cds--text-input__field-wrapper\">\n <ibm-label [disabled]=\"modalObs.disableInput\">\n <span class=\"label-with-tooltip select-label\">\n {{ 'searchFieldsOverview.dataType' | translate }}\n <v-tooltip-icon\n [tooltip]=\"'searchFieldsOverviewTooltips.dataType' | translate\"\n [disabled]=\"modalObs.disableInput\"\n ></v-tooltip-icon>\n </span>\n <ibm-dropdown formControlName=\"dataType\" [disabled]=\"modalObs.disableInput\">\n <ibm-dropdown-list [items]=\"dataTypeItems$ | async\"></ibm-dropdown-list>\n </ibm-dropdown>\n </ibm-label>\n </div>\n <div class=\"cds--text-input__field-wrapper\">\n <ibm-label [disabled]=\"modalObs.disableInput\">\n <span class=\"label-with-tooltip select-label\">\n {{ 'searchFieldsOverview.fieldType' | translate }}\n <v-tooltip-icon\n [tooltip]=\"'searchFieldsOverviewTooltips.fieldType' | translate\"\n [disabled]=\"modalObs.disableInput\"\n ></v-tooltip-icon>\n </span>\n <ibm-dropdown formControlName=\"fieldType\" [disabled]=\"modalObs.disableInput\">\n <ibm-dropdown-list [items]=\"fieldTypeItems$ | async\"></ibm-dropdown-list>\n </ibm-dropdown>\n </ibm-label>\n </div>\n </form>\n</ng-template>\n\n<ng-template #modalFooter let-modalObs=\"modalObs\">\n <ibm-modal-footer>\n <ng-container>\n <button\n ibmButton=\"secondary\"\n [attr.modal-primary-focus]=\"true\"\n (click)=\"closeModal()\"\n [disabled]=\"modalObs.disableInput\"\n >\n {{ 'searchFieldsOverview.close' | translate }}\n </button>\n <button\n ibmButton=\"primary\"\n [attr.modal-primary-focus]=\"true\"\n [disabled]=\"modalObs.valid === false\"\n (click)=\"saveListSearchFields()\"\n [disabled]=\"\n modalObs.disableInput || modalObs.valid === false || modalObs.validKey === false\n \"\n >\n {{ 'searchFieldsOverview.save' | translate }}\n </button>\n </ng-container>\n </ibm-modal-footer>\n</ng-template>\n\n<ng-template #deleteModal>\n <valtimo-confirmation-modal\n [showModalSubject$]=\"showDeleteModal$\"\n [outputOnConfirm]=\"deleteRowIndex$ | async\"\n (confirmEvent)=\"deleteRowConfirmation($event)\"\n confirmButtonTextTranslationKey=\"searchFieldsOverview.deleteSearchField\"\n titleTranslationKey=\"searchFieldsOverview.searchField\"\n contentTranslationKey=\"searchFieldsOverview.deleteSearchFieldConfirmation\"\n ></valtimo-confirmation-modal>\n</ng-template>\n\n<ng-template #noConfigWarning>\n <div class=\"pl-2 pr-2 pb-2\">\n <ibm-notification\n [notificationObj]=\"{\n type: 'info',\n title: 'searchFieldsOverview.noSearchFieldsConfiguredWarningTitle' | translate,\n showClose: false\n }\"\n >\n </ibm-notification>\n </div>\n</ng-template>\n\n<ng-template #loading>\n <div class=\"loading-icon\"><ibm-loading></ibm-loading></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 */::ng-deep .tab-container{min-height:unset!important}::ng-deep .cds--inline-notification{max-width:100%}.label-with-tooltip{display:flex;align-items:center}.cds--text-input__field-wrapper:not(:last-child){margin-bottom:1rem}.display-type-dropdown{width:300px}.list-column-form{margin-bottom:3rem}.select-label{padding-bottom:.5rem;width:250px}.loading-icon{width:100%;display:flex;align-items:center;justify-content:center}.center-link{display:flex;align-items:center}::ng-deep .move-row-buttons{display:flex;flex-direction:row;justify-content:flex-end;padding-right:13px}\n"] }]
|
|
320
|
+
}], ctorParameters: function () { return [{ type: i1.ObjectManagementService }, { type: i2.ActivatedRoute }, { type: i3.TranslateService }, { type: i4.ConfigService }, { type: i5.DomSanitizer }]; }, propDecorators: { moveRowButtonsTemplateRef: [{
|
|
321
|
+
type: ViewChild,
|
|
322
|
+
args: ['moveRowButtons']
|
|
323
|
+
}] } });
|
|
324
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"object-management-list-search-fields.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/valtimo/object-management/src/lib/components/object-management-detail-container/tabs/object-management-list-search-fields/object-management-list-search-fields.component.ts","../../../../../../../../../projects/valtimo/object-management/src/lib/components/object-management-detail-container/tabs/object-management-list-search-fields/object-management-list-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 */\n\nimport {Component, TemplateRef, ViewChild} from '@angular/core';\nimport {\n  BehaviorSubject,\n  combineLatest,\n  filter,\n  map,\n  Observable,\n  of,\n  startWith,\n  Subject,\n  switchMap,\n  tap,\n} from 'rxjs';\nimport {DomSanitizer, SafeUrl} from '@angular/platform-browser';\nimport {\n  ConfigService,\n  DefinitionColumn,\n  SearchField,\n  SearchFieldColumnView,\n  SearchFieldDataType,\n  SearchFieldFieldType,\n} from '@valtimo/config';\nimport {ListField} from '@valtimo/components';\nimport {catchError, take} from 'rxjs/operators';\nimport {FormControl, FormGroup, Validators} from '@angular/forms';\nimport {ListItem} from 'carbon-components-angular/dropdown/list-item.interface';\nimport {ActivatedRoute} from '@angular/router';\nimport {TranslateService} from '@ngx-translate/core';\nimport {ObjectManagementService} from '../../../../services/object-management.service';\n\n@Component({\n  selector: 'valtimo-object-management-list-search-fields',\n  templateUrl: './object-management-list-search-fields.component.html',\n  styleUrls: ['./object-management-list-search-fields.component.scss'],\n})\nexport class ObjectManagementListSearchFieldsComponent {\n  @ViewChild('moveRowButtons') public moveRowButtonsTemplateRef: TemplateRef<any>;\n  readonly downloadName$ = new BehaviorSubject<string>('');\n  readonly downloadUrl$ = new BehaviorSubject<SafeUrl>(undefined);\n  readonly loading$ = new BehaviorSubject<boolean>(true);\n  readonly currentModalType$ = new BehaviorSubject<string>('create');\n  readonly showModal$ = new BehaviorSubject<boolean>(false);\n  readonly disableInput$ = new BehaviorSubject<boolean>(false);\n  readonly showDeleteModal$ = new Subject<boolean>();\n  readonly deleteRowIndex$ = new BehaviorSubject<number>(0);\n\n  readonly INVALID_KEY = 'invalid';\n  readonly formGroup = new FormGroup({\n    title: new FormControl(''),\n    key: new FormControl('', Validators.required),\n    path: new FormControl('', Validators.required),\n    dataType: new FormControl({\n      key: this.INVALID_KEY,\n    }),\n    fieldType: new FormControl({\n      key: this.INVALID_KEY,\n    }),\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  readonly DATA_TYPES: Array<SearchFieldDataType> = [\n    'text',\n    'number',\n    'date',\n    'datetime',\n    'boolean',\n  ];\n  private readonly FIELD_TYPES: Array<SearchFieldFieldType> = ['single', 'range'];\n  private cachedObjectManagementListSearchFields: Array<SearchField> = [];\n  private readonly refreshObjectManagementListSearchFields$ = new BehaviorSubject<null>(null);\n\n  readonly objectManagementFields$: Observable<Array<ListField>> = this.translateService\n    .stream('key')\n    .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        }))\n      )\n    );\n\n  readonly objectId$: Observable<string> = this.route.params.pipe(\n    map(params => params.id || ''),\n    filter(objectId => !!objectId)\n  );\n\n  private readonly objectManagementListSearchFields$: Observable<Array<any>> = combineLatest([\n    this.objectId$,\n    this.refreshObjectManagementListSearchFields$,\n  ]).pipe(\n    switchMap(([objectId]) => this.objectManagementService.getSearchField(objectId)),\n    tap(objectManagementListSearchFields => {\n      this.objectId$.pipe(take(1)).subscribe(objectId => {\n        if (\n          objectManagementListSearchFields &&\n          Array.isArray(objectManagementListSearchFields) &&\n          objectManagementListSearchFields.length > 0\n        ) {\n          this.setDownload(objectId, objectManagementListSearchFields);\n        }\n      });\n    }),\n    tap(objectManagementListSearchFields => {\n      this.cachedObjectManagementListSearchFields = objectManagementListSearchFields;\n      this.loading$.next(false);\n      this.enableInput();\n    })\n  );\n\n  readonly translatedObjectManagementListSearchFields$: Observable<Array<SearchFieldColumnView>> =\n    combineLatest([\n      this.objectManagementListSearchFields$,\n      this.translateService.stream('key'),\n    ]).pipe(\n      map(([columns]) =>\n        columns.map(column => ({\n          ...column,\n          title: column.title || '-',\n          dataType: this.translateService.instant(\n            `searchFields.${column?.dataType?.toLowerCase()}`\n          ),\n          fieldType: this.translateService.instant(\n            `searchFieldsOverview.${column?.fieldType?.toLowerCase()}`\n          ),\n        }))\n      )\n    );\n\n  readonly selectedDataTypeItemIndex$ = new BehaviorSubject<number>(0);\n\n  readonly dataTypeItems$: Observable<Array<ListItem>> = combineLatest([\n    this.selectedDataTypeItemIndex$,\n    this.translateService.stream('key'),\n  ]).pipe(\n    map(([selectedDataTypeItemIndex]) =>\n      [\n        {\n          content: this.translateService.instant(`searchFieldDataType.select`),\n          key: this.INVALID_KEY,\n        },\n        ...this.DATA_TYPES.map(type => ({\n          content: this.translateService.instant(`searchFields.${type}`),\n          key: type.toUpperCase(),\n        })),\n      ].map((item, index) => ({\n        ...item,\n        selected: index === selectedDataTypeItemIndex,\n      }))\n    )\n  );\n\n  readonly selectedFieldTypeItemIndex$ = new BehaviorSubject<number>(0);\n  readonly fieldTypeItems$: Observable<Array<ListItem>> = combineLatest([\n    this.selectedFieldTypeItemIndex$,\n    this.translateService.stream('key'),\n  ]).pipe(\n    map(([selectedFieldTypeItemIndex]) =>\n      [\n        {\n          content: this.translateService.instant(`searchFieldFieldType.select`),\n          key: this.INVALID_KEY,\n        },\n        ...this.FIELD_TYPES.map(type => ({\n          content: this.translateService.instant(`searchFieldsOverview.${type}`),\n          key: type.toUpperCase(),\n        })),\n      ].map((item, index) => ({\n        ...item,\n        selected: index === selectedFieldTypeItemIndex,\n      }))\n    )\n  );\n\n  readonly validKey$ = combineLatest([this.formGroup.valueChanges, this.currentModalType$]).pipe(\n    map(([formValues, currentModalType]) => {\n      const existingKeys = this.cachedObjectManagementListSearchFields.map(column => column.key);\n      return currentModalType === 'create' ? !existingKeys.includes(formValues.key) : true;\n    }),\n    startWith(false)\n  );\n\n  readonly valid$ = combineLatest([this.formGroup.valueChanges, this.validKey$]).pipe(\n    map(([formValues, validKey]) => !!(formValues.path && validKey)),\n    startWith(false)\n  );\n\n  constructor(\n    private readonly objectManagementService: ObjectManagementService,\n    private readonly route: ActivatedRoute,\n    private readonly translateService: TranslateService,\n    private readonly configService: ConfigService,\n    private readonly sanitizer: DomSanitizer\n  ) {}\n\n  openModal(modalType: string): void {\n    this.showModal$.next(true);\n    this.currentModalType$.next(modalType);\n\n    if (modalType === 'create') {\n      this.formGroup.controls['key'].enable();\n      this.resetFormGroup();\n    } else if (modalType === 'edit') {\n      this.formGroup.controls['key'].disable();\n    }\n  }\n\n  closeModal(): void {\n    this.showModal$.next(false);\n  }\n\n  deleteRow(listSearchFieldRowIndex: number, clickEvent: MouseEvent): void {\n    clickEvent.stopPropagation();\n\n    this.showDeleteModal$.next(true);\n    this.deleteRowIndex$.next(listSearchFieldRowIndex);\n  }\n\n  deleteRowConfirmation(listSearchFieldRowIndex: number): void {\n    const columnKey = this.getColumnKey(listSearchFieldRowIndex);\n\n    if (columnKey) {\n      this.disableInput();\n\n      this.objectId$\n        .pipe(\n          take(1),\n          switchMap(objectId =>\n            this.objectManagementService.deleteSearchField(objectId, columnKey)\n          ),\n          tap(() => this.refreshObjectManagementListSearchFields()),\n          catchError(() => {\n            this.enableInput();\n            return of(null);\n          })\n        )\n        .subscribe();\n    }\n  }\n\n  getColumnKey(listSearchFieldRowIndex: number) {\n    return this.cachedObjectManagementListSearchFields[listSearchFieldRowIndex]?.key;\n  }\n\n  moveRow(\n    listSearchFieldRowIndex: number,\n    moveUp: boolean,\n    clickEvent: MouseEvent,\n    objectId: string\n  ): void {\n    const objectManagementListSearchFields = [...this.cachedObjectManagementListSearchFields];\n    const listSearchFieldRow = objectManagementListSearchFields[listSearchFieldRowIndex];\n\n    clickEvent.stopPropagation();\n  }\n\n  saveListSearchFields(): void {\n    this.disableInput();\n\n    this.currentModalType$.pipe(take(1)).subscribe(currentModalType => {\n      if (currentModalType === 'create') {\n        this.addSearchField();\n      } else {\n        this.updateSearchField();\n      }\n    });\n  }\n\n  columnRowClicked(row: {key: string}): void {\n    this.resetFormGroup();\n\n    combineLatest([this.dataTypeItems$, this.fieldTypeItems$])\n      .pipe(take(1))\n      .subscribe(([dataTypeItems, fieldTypeItems]) => {\n        const column = this.cachedObjectManagementListSearchFields.find(\n          cachedColumn => cachedColumn.key === row.key\n        );\n        const dataTypeItem = dataTypeItems.find(item => item.key === column.dataType);\n        const dataTypeItemIndex = dataTypeItems.findIndex(item => item.key === column.dataType);\n\n        const fieldTypeItem = fieldTypeItems.find(item => item.key === column.fieldType);\n        const fieldTypeItemIndex = fieldTypeItems.findIndex(item => item.key === column.fieldType);\n\n        this.selectedDataTypeItemIndex$.next(dataTypeItemIndex);\n        this.selectedFieldTypeItemIndex$.next(fieldTypeItemIndex);\n\n        this.formGroup.patchValue({\n          key: column.key,\n          title: column.title,\n          path: column.path,\n          // @ts-ignore\n          dataType: {...dataTypeItem},\n          // @ts-ignore\n          fieldType: {...fieldTypeItem},\n        });\n\n        this.openModal('edit');\n      });\n  }\n\n  private updateObjectManagementListSearchField(objectId: string, searchField: SearchField): void {\n    this.disableInput();\n    this.objectManagementService\n      .putSearchField(objectId, this.formGroup.value.key, searchField)\n      .pipe(\n        tap(() => {\n          this.refreshObjectManagementListSearchFields();\n          localStorage.setItem(`list-search-fields${objectId}`, null);\n        }),\n        catchError(() => {\n          this.enableInput();\n          return of(null);\n        })\n      )\n      .subscribe();\n  }\n\n  private addSearchField(): void {\n    const formValue = this.formGroup.value;\n\n    this.objectId$\n      .pipe(\n        take(1),\n        switchMap(objectId =>\n          this.objectManagementService.postSearchField(\n            objectId,\n            this.mapFormValuesToColumn(formValue)\n          )\n        ),\n        tap(() => {\n          this.closeModal();\n          this.refreshObjectManagementListSearchFields();\n        }),\n        catchError(() => {\n          this.enableInput();\n          return of(null);\n        })\n      )\n      .subscribe();\n  }\n\n  private updateSearchField(): void {\n    this.objectId$\n      .pipe(\n        take(1),\n        switchMap(objectId =>\n          this.objectManagementService.putSearchField(\n            objectId,\n            this.formGroup.value.key,\n            this.mapFormValuesToColumn(this.formGroup.value)\n          )\n        ),\n        tap(() => {\n          this.closeModal();\n          this.refreshObjectManagementListSearchFields();\n        }),\n        catchError(() => {\n          this.enableInput();\n          return of(null);\n        })\n      )\n      .subscribe();\n  }\n\n  private setDownload(objectId: string, ObjectManagementSearchFields: Array<SearchField>): void {\n    this.downloadName$.next(`${objectId}.json`);\n    this.downloadUrl$.next(\n      this.sanitizer.bypassSecurityTrustUrl(\n        'data:text/json;charset=UTF-8,' +\n          encodeURIComponent(JSON.stringify(ObjectManagementSearchFields, null, 2))\n      )\n    );\n  }\n\n  private disableInput(): void {\n    this.disableInput$.next(true);\n    this.formGroup.disable();\n  }\n\n  private enableInput(): void {\n    this.disableInput$.next(false);\n    this.formGroup.enable();\n  }\n\n  private refreshObjectManagementListSearchFields(): void {\n    this.refreshObjectManagementListSearchFields$.next(null);\n  }\n\n  private resetFormGroup(): void {\n    this.formGroup.reset();\n    this.selectedDataTypeItemIndex$.next(0);\n    this.selectedFieldTypeItemIndex$.next(0);\n  }\n\n  private mapFormValuesToColumn(formValue: any): SearchField {\n    return {\n      key: formValue.key,\n      title: formValue.title || '',\n      path: formValue.path,\n      dataType: formValue.dataType.key,\n      fieldType: formValue.fieldType.key,\n    };\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<ng-container\n  *ngIf=\"{\n    searchFields: translatedObjectManagementListSearchFields$ | async,\n    fields: objectManagementFields$ | async,\n    objectId: objectId$ | async,\n    downloadUrl: downloadUrl$ | async,\n    downloadName: downloadName$ | async,\n    loading: loading$ | async\n  } as obs\"\n>\n  <div class=\"container-fluid pr-0 pl-0\">\n    <div class=\"text-right\">\n      <div class=\"btn-group mt-m3px mb-3 mr-2\">\n        <ng-container *ngTemplateOutlet=\"buttons; context: {obs: obs}\"></ng-container>\n      </div>\n    </div>\n    <ng-container *ngIf=\"!obs.loading; else loading\">\n      <ng-container *ngIf=\"obs.searchFields?.length > 0; else noConfigWarning\">\n        <ng-container *ngTemplateOutlet=\"list; context: {obs: obs}\"></ng-container>\n      </ng-container>\n    </ng-container>\n    <ng-container *ngTemplateOutlet=\"createEditModal\"></ng-container>\n    <ng-container *ngTemplateOutlet=\"deleteModal\"></ng-container>\n  </div>\n</ng-container>\n\n<ng-template #buttons let-obs=\"obs\">\n  <a\n    ibmLink\n    class=\"center-link\"\n    [href]=\"obs.downloadUrl\"\n    [download]=\"obs.downloadName\"\n    [disabled]=\"\n      !obs.downloadUrl ||\n      !obs.downloadName ||\n      obs.searchFields?.length < 1 ||\n      obs.disableInput ||\n      obs.loading\n    \"\n  >\n    {{ 'searchFieldsOverview.download' | translate }}\n  </a>\n  <button\n    (click)=\"openModal('create')\"\n    ibmButton=\"primary\"\n    size=\"md\"\n    [disabled]=\"obs.loading\"\n    class=\"ml-3\"\n  >\n    {{ 'searchFieldsOverview.add' | translate }}\n    <svg class=\"cds--btn__icon\" ibmIcon=\"add\" size=\"16\"></svg>\n  </button>\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      objectId: objectId$ | async\n    } as obs\"\n  >\n    <i\n      class=\"mdi mdi-delete btn btn-outline-danger mr-1\"\n      (click)=\"deleteRow(index, $event)\"\n      [ngClass]=\"{'disabled disabled-move-row-button': obs.disableInput}\"\n    ></i>\n    <i\n      class=\"mdi mdi-arrow-up-bold btn btn-outline-primary mr-1\"\n      (click)=\"moveRow(index, true, $event, obs.objectId)\"\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.objectId)\"\n      [ngClass]=\"{'disabled disabled-move-row-button': index === length - 1 || obs.disableInput}\"\n    ></i>\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    *ngIf=\"obs.searchFields; else loading\"\n    [lastColumnTemplate]=\"moveRowButtonsTemplateRef\"\n    (rowClicked)=\"columnRowClicked($event)\"\n  >\n  </valtimo-list>\n</ng-template>\n\n<ng-template #createEditModal>\n  <ibm-modal\n    *ngIf=\"{\n      type: currentModalType$ | async,\n      show: showModal$ | async,\n      valid: valid$ | async,\n      disableInput: disableInput$ | async,\n      validKey: validKey$ | async\n    } as modalObs\"\n    [open]=\"modalObs.show\"\n  >\n    <ibm-modal-header [showCloseButton]=\"true\" (closeSelect)=\"closeModal()\">\n      <h3 ibmModalHeaderHeading>\n        {{\n          modalObs.type === 'create'\n            ? ('searchFieldsOverview.add' | translate)\n            : ('searchFieldsOverview.edit' | translate)\n        }}\n      </h3>\n    </ibm-modal-header>\n    <section ibmModalContent>\n      <ng-container *ngTemplateOutlet=\"modalContent; context: {modalObs: modalObs}\"></ng-container>\n    </section>\n    <ng-container *ngTemplateOutlet=\"modalFooter; context: {modalObs: modalObs}\"></ng-container>\n  </ibm-modal>\n</ng-template>\n\n<ng-template #modalContent let-modalObs=\"modalObs\">\n  <form [formGroup]=\"formGroup\" class=\"list-column-form\">\n    <div class=\"cds--text-input__field-wrapper\">\n      <ibm-label [disabled]=\"modalObs.disableInput\">\n        <span class=\"label-with-tooltip\">\n          {{ 'searchFieldsOverview.title' | translate }}\n          <v-tooltip-icon\n            [tooltip]=\"'searchFieldsOverviewTooltips.title' | translate\"\n            [disabled]=\"modalObs.disableInput\"\n          ></v-tooltip-icon>\n        </span>\n        <input ibmText formControlName=\"title\" />\n      </ibm-label>\n    </div>\n    <div class=\"cds--text-input__field-wrapper\">\n      <ibm-label\n        [disabled]=\"modalObs.disableInput || modalObs.type === 'edit'\"\n        [invalid]=\"modalObs.validKey === false\"\n        [invalidText]=\"'searchFieldsOverview.uniqueKeyWarning' | translate\"\n      >\n        <span class=\"label-with-tooltip\">\n          {{ 'searchFieldsOverview.key' | translate }}\n          <v-tooltip-icon\n            [tooltip]=\"'searchFieldsOverviewTooltips.key' | translate\"\n            [disabled]=\"modalObs.disableInput\"\n          ></v-tooltip-icon>\n        </span>\n        <input ibmText formControlName=\"key\" [invalid]=\"modalObs.validKey === false\" />\n      </ibm-label>\n    </div>\n    <div class=\"cds--text-input__field-wrapper\">\n      <ibm-label [disabled]=\"modalObs.disableInput\">\n        <span class=\"label-with-tooltip\">\n          {{ 'searchFieldsOverview.path' | translate }}\n          <v-tooltip-icon\n            [tooltip]=\"'searchFieldsOverviewTooltips.path' | translate\"\n            [disabled]=\"modalObs.disableInput\"\n          ></v-tooltip-icon>\n        </span>\n        <input ibmText formControlName=\"path\" />\n      </ibm-label>\n    </div>\n    <div class=\"cds--text-input__field-wrapper\">\n      <ibm-label [disabled]=\"modalObs.disableInput\">\n        <span class=\"label-with-tooltip select-label\">\n          {{ 'searchFieldsOverview.dataType' | translate }}\n          <v-tooltip-icon\n            [tooltip]=\"'searchFieldsOverviewTooltips.dataType' | translate\"\n            [disabled]=\"modalObs.disableInput\"\n          ></v-tooltip-icon>\n        </span>\n        <ibm-dropdown formControlName=\"dataType\" [disabled]=\"modalObs.disableInput\">\n          <ibm-dropdown-list [items]=\"dataTypeItems$ | async\"></ibm-dropdown-list>\n        </ibm-dropdown>\n      </ibm-label>\n    </div>\n    <div class=\"cds--text-input__field-wrapper\">\n      <ibm-label [disabled]=\"modalObs.disableInput\">\n        <span class=\"label-with-tooltip select-label\">\n          {{ 'searchFieldsOverview.fieldType' | translate }}\n          <v-tooltip-icon\n            [tooltip]=\"'searchFieldsOverviewTooltips.fieldType' | translate\"\n            [disabled]=\"modalObs.disableInput\"\n          ></v-tooltip-icon>\n        </span>\n        <ibm-dropdown formControlName=\"fieldType\" [disabled]=\"modalObs.disableInput\">\n          <ibm-dropdown-list [items]=\"fieldTypeItems$ | async\"></ibm-dropdown-list>\n        </ibm-dropdown>\n      </ibm-label>\n    </div>\n  </form>\n</ng-template>\n\n<ng-template #modalFooter let-modalObs=\"modalObs\">\n  <ibm-modal-footer>\n    <ng-container>\n      <button\n        ibmButton=\"secondary\"\n        [attr.modal-primary-focus]=\"true\"\n        (click)=\"closeModal()\"\n        [disabled]=\"modalObs.disableInput\"\n      >\n        {{ 'searchFieldsOverview.close' | translate }}\n      </button>\n      <button\n        ibmButton=\"primary\"\n        [attr.modal-primary-focus]=\"true\"\n        [disabled]=\"modalObs.valid === false\"\n        (click)=\"saveListSearchFields()\"\n        [disabled]=\"\n          modalObs.disableInput || modalObs.valid === false || modalObs.validKey === false\n        \"\n      >\n        {{ 'searchFieldsOverview.save' | translate }}\n      </button>\n    </ng-container>\n  </ibm-modal-footer>\n</ng-template>\n\n<ng-template #deleteModal>\n  <valtimo-confirmation-modal\n    [showModalSubject$]=\"showDeleteModal$\"\n    [outputOnConfirm]=\"deleteRowIndex$ | async\"\n    (confirmEvent)=\"deleteRowConfirmation($event)\"\n    confirmButtonTextTranslationKey=\"searchFieldsOverview.deleteSearchField\"\n    titleTranslationKey=\"searchFieldsOverview.searchField\"\n    contentTranslationKey=\"searchFieldsOverview.deleteSearchFieldConfirmation\"\n  ></valtimo-confirmation-modal>\n</ng-template>\n\n<ng-template #noConfigWarning>\n  <div class=\"pl-2 pr-2 pb-2\">\n    <ibm-notification\n      [notificationObj]=\"{\n        type: 'info',\n        title: 'searchFieldsOverview.noSearchFieldsConfiguredWarningTitle' | translate,\n        showClose: false\n      }\"\n    >\n    </ibm-notification>\n  </div>\n</ng-template>\n\n<ng-template #loading>\n  <div class=\"loading-icon\"><ibm-loading></ibm-loading></div>\n</ng-template>\n"]}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
/*
|
|
2
|
-
* Copyright 2015-
|
|
2
|
+
* Copyright 2015-2023 Ritense BV, the Netherlands.
|
|
3
3
|
*
|
|
4
4
|
* Licensed under EUPL, Version 1.2 (the "License");
|
|
5
5
|
* you may not use this file except in compliance with the License.
|
|
@@ -58,9 +58,9 @@ export class ObjectManagementListComponent {
|
|
|
58
58
|
}
|
|
59
59
|
}
|
|
60
60
|
ObjectManagementListComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: ObjectManagementListComponent, deps: [{ token: i1.ObjectManagementService }, { token: i2.ObjectManagementStateService }, { token: i3.TranslateService }, { token: i4.Router }], target: i0.ɵɵFactoryTarget.Component });
|
|
61
|
-
ObjectManagementListComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: ObjectManagementListComponent, selector: "valtimo-object-management-list", ngImport: i0, template: "<!--\n ~ Copyright 2015-
|
|
61
|
+
ObjectManagementListComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: ObjectManagementListComponent, selector: "valtimo-object-management-list", 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<div class=\"main-content pt-0\" *ngIf=\"{loading: loading$ | async} as obs\">\n <div class=\"container-fluid\">\n <div class=\"col-12 px-0 mb-5\">\n <div class=\"text-right mt-m3px mb-3\">\n <button (click)=\"showUploadModal()\" class=\"btn btn-secondary btn-space\">\n <i class=\"icon mdi mdi-upload mr-1\"></i>\n {{ 'objectManagement.uploadObjecttype' | translate }}\n </button>\n <button (click)=\"showAddModal()\" type=\"button\" class=\"btn btn-space btn-primary mr-0\">\n <i class=\"icon mdi mdi-plus mr-1\"></i>\n {{ 'objectManagement.createObjecttype' | translate }}\n </button>\n </div>\n <ng-container *ngTemplateOutlet=\"list; context: {obs: obs}\"></ng-container>\n </div>\n </div>\n</div>\n\n<ng-template #list let-obs=\"obs\">\n <ng-container *ngIf=\"fields$ | async as fields\">\n <ng-container *ngIf=\"objecttypesInstances$ | async as objecttypesInstances\">\n <valtimo-widget *ngIf=\"obs.loading === false\">\n <valtimo-list\n [items]=\"objecttypesInstances\"\n [fields]=\"fields\"\n [viewMode]=\"true\"\n [header]=\"true\"\n paginationIdentifier=\"objecttypesList\"\n (rowClicked)=\"redirectToDetails($event)\"\n >\n <div header>\n <h3 class=\"list-header-title\">\n {{ 'objectManagement.title' | translate }}\n <sup class=\"ml-1 badge badge-pill badge-primary\">{{\n objecttypesInstances?.length || 0\n }}</sup>\n </h3>\n </div>\n </valtimo-list>\n </valtimo-widget>\n </ng-container>\n </ng-container>\n</ng-template>\n\n<valtimo-object-management-upload-modal\n [objecttypes]=\"objecttypesInstances$ | async\"\n></valtimo-object-management-upload-modal>\n<valtimo-object-management-modal></valtimo-object-management-modal>\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 */\n"], dependencies: [{ 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.WidgetComponent, selector: "valtimo-widget", inputs: ["type", "name", "icon", "contrast", "divider", "title", "subtitle", "collapseAble", "collapse", "additionalClasses"] }, { 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: i7.ObjectManagementModalComponent, selector: "valtimo-object-management-modal", inputs: ["prefillObject$"] }, { kind: "component", type: i8.ObjectManagementUploadModalComponent, selector: "valtimo-object-management-upload-modal", inputs: ["objecttypes"] }, { kind: "pipe", type: i5.AsyncPipe, name: "async" }, { kind: "pipe", type: i3.TranslatePipe, name: "translate" }] });
|
|
62
62
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: ObjectManagementListComponent, decorators: [{
|
|
63
63
|
type: Component,
|
|
64
|
-
args: [{ selector: 'valtimo-object-management-list', template: "<!--\n ~ Copyright 2015-
|
|
64
|
+
args: [{ selector: 'valtimo-object-management-list', 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<div class=\"main-content pt-0\" *ngIf=\"{loading: loading$ | async} as obs\">\n <div class=\"container-fluid\">\n <div class=\"col-12 px-0 mb-5\">\n <div class=\"text-right mt-m3px mb-3\">\n <button (click)=\"showUploadModal()\" class=\"btn btn-secondary btn-space\">\n <i class=\"icon mdi mdi-upload mr-1\"></i>\n {{ 'objectManagement.uploadObjecttype' | translate }}\n </button>\n <button (click)=\"showAddModal()\" type=\"button\" class=\"btn btn-space btn-primary mr-0\">\n <i class=\"icon mdi mdi-plus mr-1\"></i>\n {{ 'objectManagement.createObjecttype' | translate }}\n </button>\n </div>\n <ng-container *ngTemplateOutlet=\"list; context: {obs: obs}\"></ng-container>\n </div>\n </div>\n</div>\n\n<ng-template #list let-obs=\"obs\">\n <ng-container *ngIf=\"fields$ | async as fields\">\n <ng-container *ngIf=\"objecttypesInstances$ | async as objecttypesInstances\">\n <valtimo-widget *ngIf=\"obs.loading === false\">\n <valtimo-list\n [items]=\"objecttypesInstances\"\n [fields]=\"fields\"\n [viewMode]=\"true\"\n [header]=\"true\"\n paginationIdentifier=\"objecttypesList\"\n (rowClicked)=\"redirectToDetails($event)\"\n >\n <div header>\n <h3 class=\"list-header-title\">\n {{ 'objectManagement.title' | translate }}\n <sup class=\"ml-1 badge badge-pill badge-primary\">{{\n objecttypesInstances?.length || 0\n }}</sup>\n </h3>\n </div>\n </valtimo-list>\n </valtimo-widget>\n </ng-container>\n </ng-container>\n</ng-template>\n\n<valtimo-object-management-upload-modal\n [objecttypes]=\"objecttypesInstances$ | async\"\n></valtimo-object-management-upload-modal>\n<valtimo-object-management-modal></valtimo-object-management-modal>\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 */\n"] }]
|
|
65
65
|
}], ctorParameters: function () { return [{ type: i1.ObjectManagementService }, { type: i2.ObjectManagementStateService }, { type: i3.TranslateService }, { type: i4.Router }]; } });
|
|
66
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
66
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"object-management-list.component.js","sourceRoot":"","sources":["../../../../../../../projects/valtimo/object-management/src/lib/components/object-management-list/object-management-list.component.ts","../../../../../../../projects/valtimo/object-management/src/lib/components/object-management-list/object-management-list.component.html"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;GAcG;AAEH,OAAO,EAAC,SAAS,EAAC,MAAM,eAAe,CAAC;AACxC,OAAO,EAAC,eAAe,EAAE,aAAa,EAAa,MAAM,MAAM,CAAC;AAChE,OAAO,EAAC,SAAS,EAAE,GAAG,EAAC,MAAM,gBAAgB,CAAC;;;;;;;;;;AAY9C,MAAM,OAAO,6BAA6B;IAcxC,YACmB,uBAAgD,EAChD,qBAAmD,EACnD,gBAAkC,EAC3C,MAAc;QAHL,4BAAuB,GAAvB,uBAAuB,CAAyB;QAChD,0BAAqB,GAArB,qBAAqB,CAA8B;QACnD,qBAAgB,GAAhB,gBAAgB,CAAkB;QAC3C,WAAM,GAAN,MAAM,CAAQ;QAjBf,aAAQ,GAAG,IAAI,eAAe,CAAU,IAAI,CAAC,CAAC;QAE9C,YAAO,GAAG,IAAI,eAAe,CAAsC,EAAE,CAAC,CAAC;QAEvE,0BAAqB,GAAkC,aAAa,CAAC;YAC5E,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,KAAK,CAAC;YACnC,IAAI,CAAC,qBAAqB,CAAC,QAAQ;SACpC,CAAC,CAAC,IAAI,CACL,GAAG,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,SAAS,EAAE,CAAC,EAC3B,SAAS,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,uBAAuB,CAAC,aAAa,EAAE,CAAC,EAC7D,GAAG,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CACrC,CAAC;IAOC,CAAC;IAEJ,YAAY;QACV,IAAI,CAAC,qBAAqB,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC;QAC/C,IAAI,CAAC,qBAAqB,CAAC,SAAS,EAAE,CAAC;IACzC,CAAC;IAED,eAAe;QACb,IAAI,CAAC,qBAAqB,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC;QAClD,IAAI,CAAC,qBAAqB,CAAC,SAAS,EAAE,CAAC;IACzC,CAAC;IAED,iBAAiB,CAAC,gBAA4B;QAC5C,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,2BAA2B,EAAE,gBAAgB,CAAC,EAAE,CAAC,CAAC,CAAC;IAC3E,CAAC;IAEO,SAAS;QACf,MAAM,IAAI,GAAkB,CAAC,OAAO,CAAC,CAAC;QACtC,IAAI,CAAC,OAAO,CAAC,IAAI,CACf,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;YACf,KAAK,EAAE,GAAG,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,2BAA2B,GAAG,EAAE,CAAC,EAAE;YAC3E,GAAG;SACJ,CAAC,CAAC,CACJ,CAAC;IACJ,CAAC;;2HA3CU,6BAA6B;+GAA7B,6BAA6B,sEC9B1C,mhFAgEA;4FDlCa,6BAA6B;kBALzC,SAAS;+BACE,gCAAgC","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 */\n\nimport {Component} from '@angular/core';\nimport {BehaviorSubject, combineLatest, Observable} from 'rxjs';\nimport {switchMap, tap} from 'rxjs/operators';\nimport {TranslateService} from '@ngx-translate/core';\nimport {ObjectManagementService} from '../../services/object-management.service';\nimport {Objecttype} from '../../models/object-management.model';\nimport {ObjectManagementStateService} from '../../services/object-management-state.service';\nimport {Router} from '@angular/router';\n\n@Component({\n  selector: 'valtimo-object-management-list',\n  templateUrl: './object-management-list.component.html',\n  styleUrls: ['./object-management-list.component.scss'],\n})\nexport class ObjectManagementListComponent {\n  readonly loading$ = new BehaviorSubject<boolean>(true);\n\n  readonly fields$ = new BehaviorSubject<Array<{key: string; label: string}>>([]);\n\n  readonly objecttypesInstances$: Observable<Array<Objecttype>> = combineLatest([\n    this.translateService.stream('key'),\n    this.objectManagementState.refresh$,\n  ]).pipe(\n    tap(() => this.setFields()),\n    switchMap(() => this.objectManagementService.getAllObjects()),\n    tap(() => this.loading$.next(false))\n  );\n\n  constructor(\n    private readonly objectManagementService: ObjectManagementService,\n    private readonly objectManagementState: ObjectManagementStateService,\n    private readonly translateService: TranslateService,\n    private router: Router\n  ) {}\n\n  showAddModal(): void {\n    this.objectManagementState.setModalType('add');\n    this.objectManagementState.showModal();\n  }\n\n  showUploadModal(): void {\n    this.objectManagementState.setModalType('upload');\n    this.objectManagementState.showModal();\n  }\n\n  redirectToDetails(objectManagement: Objecttype) {\n    this.router.navigate(['/object-management/object', objectManagement.id]);\n  }\n\n  private setFields(): void {\n    const keys: Array<string> = ['title'];\n    this.fields$.next(\n      keys.map(key => ({\n        label: `${this.translateService.instant(`objectManagement.labels.${key}`)}`,\n        key,\n      }))\n    );\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<div class=\"main-content pt-0\" *ngIf=\"{loading: loading$ | async} as obs\">\n  <div class=\"container-fluid\">\n    <div class=\"col-12 px-0 mb-5\">\n      <div class=\"text-right mt-m3px mb-3\">\n        <button (click)=\"showUploadModal()\" class=\"btn btn-secondary btn-space\">\n          <i class=\"icon mdi mdi-upload mr-1\"></i>\n          {{ 'objectManagement.uploadObjecttype' | translate }}\n        </button>\n        <button (click)=\"showAddModal()\" type=\"button\" class=\"btn btn-space btn-primary mr-0\">\n          <i class=\"icon mdi mdi-plus mr-1\"></i>\n          {{ 'objectManagement.createObjecttype' | translate }}\n        </button>\n      </div>\n      <ng-container *ngTemplateOutlet=\"list; context: {obs: obs}\"></ng-container>\n    </div>\n  </div>\n</div>\n\n<ng-template #list let-obs=\"obs\">\n  <ng-container *ngIf=\"fields$ | async as fields\">\n    <ng-container *ngIf=\"objecttypesInstances$ | async as objecttypesInstances\">\n      <valtimo-widget *ngIf=\"obs.loading === false\">\n        <valtimo-list\n          [items]=\"objecttypesInstances\"\n          [fields]=\"fields\"\n          [viewMode]=\"true\"\n          [header]=\"true\"\n          paginationIdentifier=\"objecttypesList\"\n          (rowClicked)=\"redirectToDetails($event)\"\n        >\n          <div header>\n            <h3 class=\"list-header-title\">\n              {{ 'objectManagement.title' | translate }}\n              <sup class=\"ml-1 badge badge-pill badge-primary\">{{\n                objecttypesInstances?.length || 0\n              }}</sup>\n            </h3>\n          </div>\n        </valtimo-list>\n      </valtimo-widget>\n    </ng-container>\n  </ng-container>\n</ng-template>\n\n<valtimo-object-management-upload-modal\n  [objecttypes]=\"objecttypesInstances$ | async\"\n></valtimo-object-management-upload-modal>\n<valtimo-object-management-modal></valtimo-object-management-modal>\n"]}
|