@valtimo/zgw 12.0.0 → 12.1.1
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/components/dossier-management-zgw/dossier-management-zgw.component.mjs +61 -13
- package/esm2022/lib/models/dossier-management-zgw.model.mjs +5 -3
- package/esm2022/lib/modules/documenten-api/components/documenten-api-column-modal/documenten-api-column-modal.component.mjs +115 -242
- package/esm2022/lib/modules/documenten-api/components/documenten-api-columns/documenten-api-columns.component.mjs +57 -85
- package/esm2022/lib/modules/documenten-api/components/documenten-api-documents/documenten-api-documents.component.mjs +171 -100
- package/esm2022/lib/modules/documenten-api/components/documenten-api-filter/documenten-api-filter.component.mjs +174 -0
- package/esm2022/lib/modules/documenten-api/components/documenten-api-metadata-modal/documenten-api-metadata-modal.component.mjs +244 -106
- package/esm2022/lib/modules/documenten-api/components/documenten-api-tag-modal/documenten-api-tag-modal.component.mjs +115 -0
- package/esm2022/lib/modules/documenten-api/components/documenten-api-tags/documenten-api-tags.component.mjs +164 -0
- package/esm2022/lib/modules/documenten-api/components/index.mjs +5 -2
- package/esm2022/lib/modules/documenten-api/formio/documenten-api-uploader/documenten-api-uploader.component.mjs +3 -3
- package/esm2022/lib/modules/documenten-api/models/configured-column.model.mjs +12 -2
- package/esm2022/lib/modules/documenten-api/models/documenten-api-filter.model.mjs +17 -0
- package/esm2022/lib/modules/documenten-api/models/documenten-api-metadata.model.mjs +1 -1
- package/esm2022/lib/modules/documenten-api/models/documenten-api-tag.model.mjs +17 -0
- package/esm2022/lib/modules/documenten-api/models/documenten-api-version.model.mjs +1 -1
- package/esm2022/lib/modules/documenten-api/models/documenten-api.model.mjs +22 -2
- package/esm2022/lib/modules/documenten-api/models/index.mjs +2 -1
- package/esm2022/lib/modules/documenten-api/services/documenten-api-column.service.mjs +10 -9
- package/esm2022/lib/modules/documenten-api/services/documenten-api-document.service.mjs +10 -3
- package/esm2022/lib/modules/documenten-api/services/documenten-api-link-process.service.mjs +1 -16
- package/esm2022/lib/modules/documenten-api/services/documenten-api-tag.service.mjs +36 -0
- package/esm2022/lib/modules/documenten-api/services/documenten-api-version.service.mjs +4 -1
- package/esm2022/lib/modules/documenten-api/services/index.mjs +3 -2
- package/esm2022/lib/modules/objecten-api/components/zaakobjecten/zaakobjecten.component.mjs +2 -2
- package/esm2022/lib/modules/zaakdetails/components/document-objecten-api-sync/document-objecten-api-sync.component.mjs +1 -1
- package/esm2022/lib/services/dossier-management-zgw.service.mjs +8 -4
- package/esm2022/lib/zgw.module.mjs +22 -5
- package/fesm2022/valtimo-zgw.mjs +1378 -781
- package/fesm2022/valtimo-zgw.mjs.map +1 -1
- package/lib/components/dossier-management-zgw/dossier-management-zgw.component.d.ts +16 -5
- package/lib/components/dossier-management-zgw/dossier-management-zgw.component.d.ts.map +1 -1
- package/lib/models/dossier-management-zgw.model.d.ts +12 -2
- package/lib/models/dossier-management-zgw.model.d.ts.map +1 -1
- package/lib/modules/documenten-api/components/documenten-api-column-modal/documenten-api-column-modal.component.d.ts +33 -63
- package/lib/modules/documenten-api/components/documenten-api-column-modal/documenten-api-column-modal.component.d.ts.map +1 -1
- package/lib/modules/documenten-api/components/documenten-api-columns/documenten-api-columns.component.d.ts +18 -20
- package/lib/modules/documenten-api/components/documenten-api-columns/documenten-api-columns.component.d.ts.map +1 -1
- package/lib/modules/documenten-api/components/documenten-api-documents/documenten-api-documents.component.d.ts +38 -20
- package/lib/modules/documenten-api/components/documenten-api-documents/documenten-api-documents.component.d.ts.map +1 -1
- package/lib/modules/documenten-api/components/documenten-api-filter/documenten-api-filter.component.d.ts +47 -0
- package/lib/modules/documenten-api/components/documenten-api-filter/documenten-api-filter.component.d.ts.map +1 -0
- package/lib/modules/documenten-api/components/documenten-api-metadata-modal/documenten-api-metadata-modal.component.d.ts +76 -39
- package/lib/modules/documenten-api/components/documenten-api-metadata-modal/documenten-api-metadata-modal.component.d.ts.map +1 -1
- package/lib/modules/documenten-api/components/documenten-api-tag-modal/documenten-api-tag-modal.component.d.ts +33 -0
- package/lib/modules/documenten-api/components/documenten-api-tag-modal/documenten-api-tag-modal.component.d.ts.map +1 -0
- package/lib/modules/documenten-api/components/documenten-api-tags/documenten-api-tags.component.d.ts +46 -0
- package/lib/modules/documenten-api/components/documenten-api-tags/documenten-api-tags.component.d.ts.map +1 -0
- package/lib/modules/documenten-api/components/index.d.ts +4 -1
- package/lib/modules/documenten-api/components/index.d.ts.map +1 -1
- package/lib/modules/documenten-api/models/configured-column.model.d.ts +8 -2
- package/lib/modules/documenten-api/models/configured-column.model.d.ts.map +1 -1
- package/lib/modules/documenten-api/models/documenten-api-filter.model.d.ts +10 -0
- package/lib/modules/documenten-api/models/documenten-api-filter.model.d.ts.map +1 -0
- package/lib/modules/documenten-api/models/documenten-api-metadata.model.d.ts +10 -9
- package/lib/modules/documenten-api/models/documenten-api-metadata.model.d.ts.map +1 -1
- package/lib/modules/documenten-api/models/documenten-api-tag.model.d.ts +5 -0
- package/lib/modules/documenten-api/models/documenten-api-tag.model.d.ts.map +1 -0
- package/lib/modules/documenten-api/models/documenten-api-version.model.d.ts +7 -1
- package/lib/modules/documenten-api/models/documenten-api-version.model.d.ts.map +1 -1
- package/lib/modules/documenten-api/models/documenten-api.model.d.ts +37 -12
- package/lib/modules/documenten-api/models/documenten-api.model.d.ts.map +1 -1
- package/lib/modules/documenten-api/models/index.d.ts +1 -0
- package/lib/modules/documenten-api/models/index.d.ts.map +1 -1
- package/lib/modules/documenten-api/services/documenten-api-column.service.d.ts +3 -2
- package/lib/modules/documenten-api/services/documenten-api-column.service.d.ts.map +1 -1
- package/lib/modules/documenten-api/services/documenten-api-document.service.d.ts +3 -2
- package/lib/modules/documenten-api/services/documenten-api-document.service.d.ts.map +1 -1
- package/lib/modules/documenten-api/services/documenten-api-link-process.service.d.ts.map +1 -1
- package/lib/modules/documenten-api/services/documenten-api-tag.service.d.ts +17 -0
- package/lib/modules/documenten-api/services/documenten-api-tag.service.d.ts.map +1 -0
- package/lib/modules/documenten-api/services/documenten-api-version.service.d.ts +2 -1
- package/lib/modules/documenten-api/services/documenten-api-version.service.d.ts.map +1 -1
- package/lib/modules/documenten-api/services/index.d.ts +2 -1
- package/lib/modules/documenten-api/services/index.d.ts.map +1 -1
- package/lib/modules/zaakdetails/components/document-objecten-api-sync/document-objecten-api-sync.component.d.ts.map +1 -1
- package/lib/services/dossier-management-zgw.service.d.ts +2 -0
- package/lib/services/dossier-management-zgw.service.d.ts.map +1 -1
- package/lib/zgw.module.d.ts.map +1 -1
- package/package.json +1 -1
|
@@ -13,289 +13,162 @@
|
|
|
13
13
|
* See the License for the specific language governing permissions and
|
|
14
14
|
* limitations under the License.
|
|
15
15
|
*/
|
|
16
|
+
import { CommonModule } from '@angular/common';
|
|
16
17
|
import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output, } from '@angular/core';
|
|
17
|
-
import {
|
|
18
|
-
import { CARBON_CONSTANTS } from '@valtimo/components';
|
|
19
|
-
import { ReactiveFormsModule, Validators, } from '@angular/forms';
|
|
20
|
-
import { InternalCaseStatusColor, InternalCaseStatusUtils, } from '@valtimo/document';
|
|
21
|
-
import { ButtonModule, DropdownModule, InputModule, ModalModule, TagModule, ToggleModule, } from 'carbon-components-angular';
|
|
22
|
-
import { Edit16 } from '@carbon/icons';
|
|
18
|
+
import { ReactiveFormsModule, Validators } from '@angular/forms';
|
|
23
19
|
import { TranslateModule } from '@ngx-translate/core';
|
|
24
|
-
import {
|
|
20
|
+
import { ButtonModule, DropdownModule, InputModule, ModalModule, NotificationModule, RadioModule, } from 'carbon-components-angular';
|
|
21
|
+
import { BehaviorSubject, combineLatest, map, Subscription, switchMap } from 'rxjs';
|
|
22
|
+
import { CARBON_CONSTANTS } from '@valtimo/components';
|
|
25
23
|
import * as i0 from "@angular/core";
|
|
26
24
|
import * as i1 from "@angular/forms";
|
|
27
|
-
import * as i2 from "
|
|
28
|
-
import * as i3 from "
|
|
29
|
-
import * as i4 from "@
|
|
30
|
-
import * as i5 from "
|
|
25
|
+
import * as i2 from "@ngx-translate/core";
|
|
26
|
+
import * as i3 from "../../services";
|
|
27
|
+
import * as i4 from "@angular/common";
|
|
28
|
+
import * as i5 from "carbon-components-angular";
|
|
31
29
|
export class DocumentenApiColumnModalComponent {
|
|
30
|
+
set prefillColumn(value) {
|
|
31
|
+
if (!value)
|
|
32
|
+
return;
|
|
33
|
+
const column = { content: value.key, selected: true, column: value };
|
|
34
|
+
const defaultSort = value.defaultSort ?? 'noDefault';
|
|
35
|
+
this.formGroup.patchValue({ column, defaultSort });
|
|
36
|
+
this.formGroup.get('column')?.disable();
|
|
37
|
+
this._prefillColumn = [column];
|
|
38
|
+
}
|
|
39
|
+
get prefillColumn() {
|
|
40
|
+
return this._prefillColumn;
|
|
41
|
+
}
|
|
32
42
|
set type(value) {
|
|
33
|
-
this._type
|
|
34
|
-
if (value === '
|
|
35
|
-
|
|
36
|
-
this._typeAnimationDelay$.next(value);
|
|
37
|
-
}, CARBON_CONSTANTS.modalAnimationMs);
|
|
38
|
-
}
|
|
39
|
-
else {
|
|
40
|
-
this._typeAnimationDelay$.next(value);
|
|
43
|
+
this._type = value;
|
|
44
|
+
if (value === 'edit') {
|
|
45
|
+
this.formGroup.get('column')?.disable;
|
|
41
46
|
}
|
|
42
47
|
}
|
|
43
|
-
|
|
44
|
-
this.
|
|
48
|
+
get type() {
|
|
49
|
+
return this._type;
|
|
45
50
|
}
|
|
46
|
-
|
|
47
|
-
|
|
51
|
+
set availableColumns(value) {
|
|
52
|
+
if (!value)
|
|
53
|
+
return;
|
|
54
|
+
this._availableColumns$.next(value);
|
|
48
55
|
}
|
|
49
|
-
|
|
50
|
-
|
|
56
|
+
set configuredColumns(value) {
|
|
57
|
+
if (!value)
|
|
58
|
+
return;
|
|
59
|
+
this._defaultSortedColumn = value.find((column) => !!column.defaultSort);
|
|
51
60
|
}
|
|
52
|
-
|
|
53
|
-
return this.statusFormGroup?.get('title');
|
|
54
|
-
}
|
|
55
|
-
get color() {
|
|
56
|
-
return this.statusFormGroup?.get('color');
|
|
57
|
-
}
|
|
58
|
-
get invalid() {
|
|
59
|
-
return !!this.statusFormGroup?.invalid;
|
|
60
|
-
}
|
|
61
|
-
get pristine() {
|
|
62
|
-
return !!this.statusFormGroup?.pristine;
|
|
63
|
-
}
|
|
64
|
-
constructor(fb, iconService, caseStatusService, translateService) {
|
|
61
|
+
constructor(fb, translateService, zgwDocumentenApiColumnService) {
|
|
65
62
|
this.fb = fb;
|
|
66
|
-
this.iconService = iconService;
|
|
67
|
-
this.caseStatusService = caseStatusService;
|
|
68
63
|
this.translateService = translateService;
|
|
69
|
-
this.
|
|
70
|
-
this.
|
|
71
|
-
this.
|
|
72
|
-
|
|
73
|
-
this.isClosed$ = this._type.pipe(map(type => type === 'closed'));
|
|
74
|
-
this.statusFormGroup = this.fb.group({
|
|
75
|
-
title: this.fb.control('', Validators.required),
|
|
76
|
-
key: this.fb.control('', [Validators.required, this.uniqueKeyValidator()]),
|
|
77
|
-
visibleInCaseListByDefault: this.fb.control(true, Validators.required),
|
|
78
|
-
color: this.fb.control('', Validators.required),
|
|
79
|
-
});
|
|
80
|
-
this.isEdit$ = combineLatest([this._typeAnimationDelay$, this._prefillStatus]).pipe(tap(([type, prefillStatus]) => {
|
|
81
|
-
if (type === 'edit' && prefillStatus)
|
|
82
|
-
this.prefillForm(prefillStatus);
|
|
83
|
-
}), map(([type]) => type === 'edit'));
|
|
84
|
-
this.isAdd$ = this._typeAnimationDelay$.pipe(map(type => type === 'add'), tap(isAdd => {
|
|
85
|
-
if (isAdd)
|
|
86
|
-
this.resetForm();
|
|
87
|
-
}));
|
|
88
|
-
this.disabled$ = new BehaviorSubject(false);
|
|
89
|
-
this.COLORS = [
|
|
90
|
-
InternalCaseStatusColor.Red,
|
|
91
|
-
InternalCaseStatusColor.Magenta,
|
|
92
|
-
InternalCaseStatusColor.Purple,
|
|
93
|
-
InternalCaseStatusColor.Blue,
|
|
94
|
-
InternalCaseStatusColor.Teal,
|
|
95
|
-
InternalCaseStatusColor.Green,
|
|
96
|
-
InternalCaseStatusColor.Cyan,
|
|
97
|
-
InternalCaseStatusColor.Gray,
|
|
98
|
-
InternalCaseStatusColor.CoolGray,
|
|
99
|
-
InternalCaseStatusColor.WarmGray,
|
|
100
|
-
InternalCaseStatusColor.HighContrast,
|
|
101
|
-
InternalCaseStatusColor.Outline,
|
|
102
|
-
];
|
|
103
|
-
this._selectedColor$ = new BehaviorSubject(undefined);
|
|
104
|
-
this.colorListItems$ = combineLatest([
|
|
105
|
-
this._selectedColor$,
|
|
64
|
+
this.zgwDocumentenApiColumnService = zgwDocumentenApiColumnService;
|
|
65
|
+
this._availableColumns$ = new BehaviorSubject([]);
|
|
66
|
+
this.availableColumns$ = combineLatest([
|
|
67
|
+
this._availableColumns$,
|
|
106
68
|
this.translateService.stream('key'),
|
|
107
|
-
]).pipe(map(([
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
color,
|
|
112
|
-
tagType: InternalCaseStatusUtils.getTagTypeFromInternalCaseStatusColor(color),
|
|
69
|
+
]).pipe(map(([columns]) => columns.map((column) => ({
|
|
70
|
+
content: this.translateService.instant(`zgw.documentColumns.${column.key}`),
|
|
71
|
+
selected: false,
|
|
72
|
+
column,
|
|
113
73
|
}))));
|
|
114
|
-
this.
|
|
115
|
-
this.
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
74
|
+
this.closeModal = new EventEmitter();
|
|
75
|
+
this.formGroup = this.fb.group({
|
|
76
|
+
column: this.fb.control({ content: '', selected: false, column: {} }, Validators.required),
|
|
77
|
+
defaultSort: this.fb.control('noDefault'),
|
|
78
|
+
});
|
|
79
|
+
this._notificationMessage$ = new BehaviorSubject('zgw.columns.defaultWarning');
|
|
80
|
+
this.notificationObj$ = combineLatest([
|
|
81
|
+
this._notificationMessage$,
|
|
82
|
+
this.translateService.stream('key'),
|
|
83
|
+
]).pipe(map(([message]) => ({
|
|
84
|
+
type: 'warning',
|
|
85
|
+
lowContrast: true,
|
|
86
|
+
title: this.translateService.instant('interface.warning'),
|
|
87
|
+
message: this.translateService.instant(message),
|
|
88
|
+
showClose: false,
|
|
89
|
+
})));
|
|
90
|
+
this.showRadioButtons = true;
|
|
124
91
|
this._subscriptions = new Subscription();
|
|
125
|
-
this.iconService.registerAll([Edit16]);
|
|
126
92
|
}
|
|
127
93
|
ngOnInit() {
|
|
128
|
-
this.
|
|
94
|
+
this.openDisableRadioSubscription();
|
|
129
95
|
}
|
|
130
96
|
ngOnDestroy() {
|
|
131
97
|
this._subscriptions.unsubscribe();
|
|
132
98
|
}
|
|
133
|
-
onClose() {
|
|
134
|
-
this.close
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
this.
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
next: () => {
|
|
148
|
-
this.enable();
|
|
149
|
-
this.closeAndRefresh();
|
|
150
|
-
},
|
|
151
|
-
error: () => {
|
|
152
|
-
this.enable(false);
|
|
153
|
-
},
|
|
154
|
-
});
|
|
155
|
-
}
|
|
156
|
-
editStatus() {
|
|
157
|
-
this.disable();
|
|
158
|
-
this._originalStatusKey$
|
|
159
|
-
.pipe(take(1), switchMap(originalStatusKey => this.caseStatusService.updateInternalCaseStatus(this.documentDefinitionName, originalStatusKey, this.getFormValue())))
|
|
160
|
-
.subscribe({
|
|
161
|
-
next: () => {
|
|
162
|
-
this.enable();
|
|
163
|
-
this.closeAndRefresh();
|
|
164
|
-
},
|
|
165
|
-
error: () => {
|
|
166
|
-
this.enable(false);
|
|
167
|
-
},
|
|
168
|
-
});
|
|
169
|
-
}
|
|
170
|
-
editKeyButtonClick() {
|
|
171
|
-
this._editingKey$.next(true);
|
|
172
|
-
}
|
|
173
|
-
colorDropdownChange(event) {
|
|
174
|
-
const newColor = event?.item?.color;
|
|
175
|
-
if (newColor) {
|
|
176
|
-
this._selectedColor$.next(newColor);
|
|
177
|
-
this.statusFormGroup.patchValue({ color: newColor });
|
|
178
|
-
this.statusFormGroup.markAsDirty();
|
|
99
|
+
onClose(refresh = false) {
|
|
100
|
+
this.closeModal.emit(refresh ? 'closeAndRefresh' : 'close');
|
|
101
|
+
setTimeout(() => {
|
|
102
|
+
this.formGroup.reset();
|
|
103
|
+
this.formGroup.enable();
|
|
104
|
+
this.showRadioButtons = true;
|
|
105
|
+
this._notificationMessage$.next('zgw.columns.defaultWarning');
|
|
106
|
+
this._prefillColumn = null;
|
|
107
|
+
}, CARBON_CONSTANTS.modalAnimationMs);
|
|
108
|
+
}
|
|
109
|
+
updateColumn() {
|
|
110
|
+
const columnValue = this.formGroup.get('column')?.value;
|
|
111
|
+
if (!columnValue || !this.definitionName) {
|
|
112
|
+
return;
|
|
179
113
|
}
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
114
|
+
const defaultSortValue = this.formGroup.get('defaultSort')?.value;
|
|
115
|
+
const defaultSort = !defaultSortValue
|
|
116
|
+
? null
|
|
117
|
+
: defaultSortValue === 'noDefault'
|
|
118
|
+
? null
|
|
119
|
+
: defaultSortValue;
|
|
120
|
+
const column = { ...columnValue.column, defaultSort };
|
|
121
|
+
if (!!this._defaultSortedColumn &&
|
|
122
|
+
this._defaultSortedColumn.key !== column.key &&
|
|
123
|
+
!!column.defaultSort) {
|
|
124
|
+
this.zgwDocumentenApiColumnService
|
|
125
|
+
.updateColumn(this.definitionName, {
|
|
126
|
+
...this._defaultSortedColumn,
|
|
127
|
+
defaultSort: null,
|
|
128
|
+
})
|
|
129
|
+
.pipe(switchMap(() => this.zgwDocumentenApiColumnService.updateColumn(this.definitionName, column)))
|
|
130
|
+
.subscribe(() => {
|
|
131
|
+
this.onClose(true);
|
|
132
|
+
});
|
|
133
|
+
return;
|
|
134
|
+
}
|
|
135
|
+
this.zgwDocumentenApiColumnService.updateColumn(this.definitionName, column).subscribe(() => {
|
|
136
|
+
this.onClose(true);
|
|
199
137
|
});
|
|
200
|
-
this._selectedColor$.next(InternalCaseStatusColor.Blue);
|
|
201
|
-
this.statusFormGroup.markAsPristine();
|
|
202
|
-
this.resetEditingKey();
|
|
203
|
-
}
|
|
204
|
-
resetEditingKey() {
|
|
205
|
-
this._editingKey$.next(false);
|
|
206
138
|
}
|
|
207
|
-
|
|
208
|
-
this._subscriptions.add(
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
this.statusFormGroup.patchValue({ key: this.getUniqueKey(titleValue) });
|
|
212
|
-
}
|
|
213
|
-
else {
|
|
214
|
-
this.clearKey();
|
|
215
|
-
}
|
|
216
|
-
}
|
|
139
|
+
openDisableRadioSubscription() {
|
|
140
|
+
this._subscriptions.add(this.formGroup.get('column')?.valueChanges.subscribe(columnValue => {
|
|
141
|
+
this.showRadioButtons = !!columnValue?.column.sortable;
|
|
142
|
+
this._notificationMessage$.next(this.showRadioButtons ? 'zgw.columns.defaultWarning' : 'zgw.columns.notSortable');
|
|
217
143
|
}));
|
|
218
144
|
}
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
.toLowerCase()
|
|
222
|
-
.replace(/[^a-z0-9-_]+|-[^a-z0-9]+/g, '-')
|
|
223
|
-
.replace(/_[-_]+/g, '_')
|
|
224
|
-
.replace(/^[^a-z]+/g, '');
|
|
225
|
-
const usedKeys = this.usedKeys;
|
|
226
|
-
if (!usedKeys.includes(dashCaseKey)) {
|
|
227
|
-
return dashCaseKey;
|
|
228
|
-
}
|
|
229
|
-
return this.getUniqueKeyWithNumber(dashCaseKey, usedKeys);
|
|
230
|
-
}
|
|
231
|
-
getUniqueKeyWithNumber(dashCaseKey, usedKeys) {
|
|
232
|
-
const numbersFromCurrentKey = (dashCaseKey.match(/^\d+|\d+\b|\d+(?=\w)/g) || []).map((numberValue) => +numberValue);
|
|
233
|
-
const lastNumberFromCurrentKey = numbersFromCurrentKey.length > 0 && numbersFromCurrentKey[numbersFromCurrentKey.length - 1];
|
|
234
|
-
const newKey = lastNumberFromCurrentKey
|
|
235
|
-
? `${dashCaseKey.replace(`${lastNumberFromCurrentKey}`, `${lastNumberFromCurrentKey + 1}`)}`
|
|
236
|
-
: `${dashCaseKey}-1`;
|
|
237
|
-
if (usedKeys.includes(newKey)) {
|
|
238
|
-
return this.getUniqueKeyWithNumber(newKey, usedKeys);
|
|
239
|
-
}
|
|
240
|
-
return newKey;
|
|
241
|
-
}
|
|
242
|
-
clearKey() {
|
|
243
|
-
this.statusFormGroup.patchValue({ key: '' });
|
|
244
|
-
}
|
|
245
|
-
uniqueKeyValidator() {
|
|
246
|
-
return (control) => this.usedKeys?.every((key) => key !== control.value)
|
|
247
|
-
? null
|
|
248
|
-
: { uniqueKey: { value: control.value } };
|
|
249
|
-
}
|
|
250
|
-
disable() {
|
|
251
|
-
this.disabled$.next(true);
|
|
252
|
-
this.statusFormGroup.disable();
|
|
253
|
-
}
|
|
254
|
-
enable(delay = true) {
|
|
255
|
-
setTimeout(() => {
|
|
256
|
-
this.disabled$.next(false);
|
|
257
|
-
this.statusFormGroup.enable();
|
|
258
|
-
}, delay ? CARBON_CONSTANTS.modalAnimationMs : 0);
|
|
259
|
-
}
|
|
260
|
-
close() {
|
|
261
|
-
this.closeModalEvent.emit('close');
|
|
262
|
-
}
|
|
263
|
-
closeAndRefresh() {
|
|
264
|
-
this.closeModalEvent.emit('closeAndRefresh');
|
|
265
|
-
}
|
|
266
|
-
getFormValue() {
|
|
267
|
-
return {
|
|
268
|
-
key: this.key.value,
|
|
269
|
-
title: this.title.value,
|
|
270
|
-
visibleInCaseListByDefault: this.visibleInCaseListByDefault.value,
|
|
271
|
-
color: this.color.value,
|
|
272
|
-
};
|
|
273
|
-
}
|
|
274
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.3", ngImport: i0, type: DocumentenApiColumnModalComponent, deps: [{ token: i1.FormBuilder }, { token: i2.IconService }, { token: i3.CaseStatusService }, { token: i4.TranslateService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
275
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.3", type: DocumentenApiColumnModalComponent, isStandalone: true, selector: "valtimo-documenten-api-column-modal", inputs: { type: "type", prefill: "prefill", usedKeys: "usedKeys", documentDefinitionName: "documentDefinitionName" }, outputs: { closeModalEvent: "closeModalEvent" }, ngImport: i0, template: "<!--\n ~ Copyright 2015-2024 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<cds-modal\n valtimoCdsModal\n *ngIf=\"{\n isAdd: isAdd$ | async,\n isEdit: isEdit$ | async,\n isClosed: isClosed$ | async,\n editingKey: editingKey$ | async,\n disabled: disabled$ | async\n } as obs\"\n [open]=\"!obs.isClosed\"\n size=\"sm\"\n>\n <cds-modal-header showCloseButton=\"true\" (closeSelect)=\"onClose()\">\n <h3 cdsModalHeaderHeading>\n {{ obs.isAdd ? ('dossierManagement.statuses.add' | translate) : '' }}\n {{ obs.isEdit ? ('dossierManagement.statuses.edit' | translate) : '' }}\n </h3>\n </cds-modal-header>\n\n <section cdsModalContent>\n <ng-container *ngTemplateOutlet=\"statusForm; context: {obs: obs}\"></ng-container>\n </section>\n\n <cds-modal-footer>\n <ng-container *ngTemplateOutlet=\"buttons; context: {obs: obs}\"></ng-container>\n </cds-modal-footer>\n</cds-modal>\n\n<ng-template #colorDropdownItemTemplate let-item=\"item\">\n <div class=\"dropdown-color-tag\">\n <cds-tag *ngIf=\"item && item.content\" class=\"cds-tag--no-margin\" [type]=\"item?.tagType\">\n {{ 'interface.tagType.' + item?.tagType | translate }}\n </cds-tag>\n </div>\n</ng-template>\n\n<ng-template #statusForm let-obs=\"obs\">\n <form [formGroup]=\"statusFormGroup\" class=\"status-form\">\n <cds-label>\n {{ 'dossierManagement.statuses.columns.title' | translate }}\n\n <input cdsText formControlName=\"title\" [attr.modal-primary-focus]=\"true\" />\n </cds-label>\n\n <cds-label>\n {{ 'dossierManagement.statuses.columns.key' | translate }}\n\n <div class=\"edit-key-input\">\n <input\n cdsText\n formControlName=\"key\"\n [disabled]=\"!obs.editingKey\"\n [placeholder]=\"\n obs.isAdd && !obs.editingKey\n ? ('dossierManagement.statuses.keyAutoGenerated' | translate)\n : ''\n \"\n />\n\n <cds-icon-button\n *ngIf=\"!obs.editingKey && obs.isAdd\"\n [disabled]=\"obs.disabled\"\n (click)=\"editKeyButtonClick()\"\n kind=\"secondary\"\n >\n <svg class=\"cds--btn__icon\" cdsIcon=\"edit\" size=\"16\"></svg>\n </cds-icon-button>\n </div>\n </cds-label>\n\n <div class=\"horizontal-inputs\">\n <cds-label>\n {{ 'dossierManagement.statuses.columns.color' | translate }}\n\n <cds-dropdown\n [appendInline]=\"false\"\n [placeholder]=\"'dossierManagement.statuses.colorPlaceholder' | translate\"\n (selected)=\"colorDropdownChange($event)\"\n >\n <cds-dropdown-list [items]=\"colorListItems$\" [listTpl]=\"colorDropdownItemTemplate\">\n </cds-dropdown-list>\n </cds-dropdown>\n </cds-label>\n\n <cds-toggle\n [label]=\"'dossierManagement.statuses.visibleTitle' | translate\"\n [onText]=\"'dossierManagement.statuses.visible' | translate\"\n [offText]=\"'dossierManagement.statuses.invisible' | translate\"\n [disabled]=\"obs.disabled\"\n [checked]=\"visibleInCaseListByDefault?.value\"\n (checkedChange)=\"toggleCheckedChange($event)\"\n ></cds-toggle>\n </div>\n </form>\n</ng-template>\n\n<ng-template #buttons let-obs=\"obs\">\n <button cdsButton=\"secondary\" (click)=\"onClose()\" [disabled]=\"obs.disabled\">\n {{ 'interface.cancel' | translate }}\n </button>\n\n <button\n *ngIf=\"obs.isAdd\"\n cdsButton=\"primary\"\n [disabled]=\"invalid || pristine || obs.disabled\"\n (click)=\"addStatus()\"\n >\n {{ 'interface.add' | translate }}\n </button>\n\n <button\n *ngIf=\"obs.isEdit\"\n cdsButton=\"primary\"\n [disabled]=\"invalid || pristine || obs.disabled\"\n (click)=\"editStatus()\"\n >\n {{ 'interface.save' | translate }}\n </button>\n</ng-template>\n", styles: [".status-form{display:flex;flex-direction:column;gap:16px}.edit-key-input{height:40px;display:flex;width:100%;flex-direction:row;gap:16px;align-items:flex-end}::ng-deep .horizontal-inputs{display:grid;gap:16px;grid-template-columns:repeat(2,1fr)}::ng-deep .horizontal-inputs .cds--label{width:100%;display:flex;flex-direction:column;gap:8px}::ng-deep .dropdown-color-tag .cds--tag{margin-top:-4px;margin-left:2px}\n/*!\n * Copyright 2015-2024 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: "ngmodule", type: CommonModule }, { kind: "directive", type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i5.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "pipe", type: i5.AsyncPipe, name: "async" }, { kind: "ngmodule", type: ModalModule }, { kind: "component", type: i2.Modal, selector: "cds-modal, ibm-modal", inputs: ["size", "theme", "ariaLabel", "open", "trigger", "hasScrollingContent"], outputs: ["overlaySelected", "close"] }, { kind: "component", type: i2.ModalHeader, selector: "cds-modal-header, ibm-modal-header", inputs: ["theme", "closeLabel", "showCloseButton"], outputs: ["closeSelect"] }, { kind: "component", type: i2.ModalFooter, selector: "cds-modal-footer, ibm-modal-footer" }, { kind: "directive", type: i2.ModalContent, selector: "[cdsModalContent], [ibmModalContent]", inputs: ["hasForm"] }, { kind: "directive", type: i2.ModalHeaderHeading, selector: "[cdsModalHeaderHeading], [ibmModalHeaderHeading]" }, { kind: "ngmodule", type: TagModule }, { kind: "component", type: i2.Tag, selector: "cds-tag, ibm-tag", inputs: ["type", "size", "class"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i4.TranslatePipe, name: "translate" }, { kind: "ngmodule", type: InputModule }, { kind: "component", type: i2.Label, selector: "cds-label, ibm-label", inputs: ["labelInputID", "disabled", "skeleton", "helperText", "invalidText", "invalid", "warn", "warnText", "ariaLabel"] }, { kind: "directive", type: i2.TextInput, selector: "[cdsText], [ibmText]", inputs: ["theme", "size", "invalid", "warn", "skeleton"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i1.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: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i1.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "ngmodule", type: ButtonModule }, { kind: "directive", type: i2.Button, selector: "[cdsButton], [ibmButton]", inputs: ["ibmButton", "cdsButton", "size", "skeleton", "iconOnly", "isExpressive"] }, { kind: "component", type: i2.IconButton, selector: "cds-icon-button, ibm-icon-button", inputs: ["buttonNgClass", "buttonAttributes", "buttonId", "kind", "size", "type", "isExpressive", "disabled", "description"], outputs: ["click", "focus", "blur", "tooltipClick"] }, { kind: "ngmodule", type: DropdownModule }, { kind: "component", type: i2.Dropdown, selector: "cds-dropdown, 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: i2.DropdownList, selector: "cds-dropdown-list, ibm-dropdown-list", inputs: ["ariaLabel", "items", "listTpl", "type", "showTitles"], outputs: ["select", "scroll", "blurIntent"] }, { kind: "ngmodule", type: ToggleModule }, { kind: "component", type: i2.Toggle, selector: "cds-toggle, ibm-toggle", inputs: ["offText", "onText", "label", "size", "hideLabel", "skeleton"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
145
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.3", ngImport: i0, type: DocumentenApiColumnModalComponent, deps: [{ token: i1.FormBuilder }, { token: i2.TranslateService }, { token: i3.DocumentenApiColumnService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
146
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.3", type: DocumentenApiColumnModalComponent, isStandalone: true, selector: "valtimo-documenten-api-column-modal", inputs: { definitionName: "definitionName", prefillColumn: "prefillColumn", type: "type", availableColumns: "availableColumns", configuredColumns: "configuredColumns" }, outputs: { closeModal: "closeModal" }, ngImport: i0, template: "<!--\n ~ Copyright 2015-2024 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<cds-modal valtimoCdsModal [open]=\"type !== 'closed'\" size=\"sm\">\n <cds-modal-header showCloseButton=\"true\" (closeSelect)=\"onClose()\">\n <h3 cdsModalHeaderHeading>\n {{ (type === 'add' ? 'zgw.columns.add' : 'zgw.columns.edit') | translate }}\n </h3>\n </cds-modal-header>\n\n <form\n class=\"valtimo-documenten-api-column-modal__content\"\n cdsModalContent\n [formGroup]=\"formGroup\"\n >\n <cds-dropdown\n formControlName=\"column\"\n [label]=\"'zgw.columns.column' | translate\"\n [dropUp]=\"false\"\n >\n <cds-dropdown-list\n [items]=\"!prefillColumn ? (availableColumns$ | async) : prefillColumn\"\n ></cds-dropdown-list>\n </cds-dropdown>\n\n <cds-radio-group *ngIf=\"showRadioButtons\" legend=\"Default sort\" formControlName=\"defaultSort\">\n <cds-radio value=\"noDefault\"> {{ 'interface.sorting.noDefault' | translate }} </cds-radio>\n\n <cds-radio value=\"DESC\"> {{ 'interface.sorting.descending' | translate }} </cds-radio>\n\n <cds-radio value=\"ASC\"> {{ 'interface.sorting.ascending' | translate }} </cds-radio>\n </cds-radio-group>\n\n <cds-inline-notification [notificationObj]=\"notificationObj$ | async\"></cds-inline-notification>\n </form>\n\n <cds-modal-footer>\n <button cdsButton=\"secondary\" (click)=\"onClose()\">\n {{ 'interface.cancel' | translate }}\n </button>\n\n <button cdsButton=\"primary\" [disabled]=\"formGroup.invalid\" (click)=\"updateColumn()\">\n {{ (type === 'add' ? 'interface.add' : 'interface.save') | translate }}\n </button>\n </cds-modal-footer>\n</cds-modal>\n", styles: [".valtimo-documenten-api-column-modal__content{display:flex;flex-direction:column;gap:16px}\n/*!\n * Copyright 2015-2024 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: "ngmodule", type: CommonModule }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i4.AsyncPipe, name: "async" }, { kind: "ngmodule", type: ModalModule }, { kind: "component", type: i5.Modal, selector: "cds-modal, ibm-modal", inputs: ["size", "theme", "ariaLabel", "open", "trigger", "hasScrollingContent"], outputs: ["overlaySelected", "close"] }, { kind: "component", type: i5.ModalHeader, selector: "cds-modal-header, ibm-modal-header", inputs: ["theme", "closeLabel", "showCloseButton"], outputs: ["closeSelect"] }, { kind: "component", type: i5.ModalFooter, selector: "cds-modal-footer, ibm-modal-footer" }, { kind: "directive", type: i5.ModalContent, selector: "[cdsModalContent], [ibmModalContent]", inputs: ["hasForm"] }, { kind: "directive", type: i5.ModalHeaderHeading, selector: "[cdsModalHeaderHeading], [ibmModalHeaderHeading]" }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i2.TranslatePipe, name: "translate" }, { kind: "ngmodule", type: InputModule }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i1.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "ngmodule", type: ButtonModule }, { kind: "directive", type: i5.Button, selector: "[cdsButton], [ibmButton]", inputs: ["ibmButton", "cdsButton", "size", "skeleton", "iconOnly", "isExpressive"] }, { kind: "ngmodule", type: DropdownModule }, { kind: "component", type: i5.Dropdown, selector: "cds-dropdown, 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: i5.DropdownList, selector: "cds-dropdown-list, ibm-dropdown-list", inputs: ["ariaLabel", "items", "listTpl", "type", "showTitles"], outputs: ["select", "scroll", "blurIntent"] }, { kind: "ngmodule", type: RadioModule }, { kind: "component", type: i5.Radio, selector: "cds-radio, ibm-radio", inputs: ["checked", "name", "disabled", "labelPlacement", "ariaLabelledby", "ariaLabel", "required", "value", "skeleton", "id"], outputs: ["change"] }, { kind: "component", type: i5.RadioGroup, selector: "cds-radio-group, ibm-radio-group", inputs: ["selected", "value", "name", "disabled", "skeleton", "orientation", "labelPlacement", "legend", "ariaLabel", "ariaLabelledby", "helperText", "invalid", "invalidText", "warn", "warnText"], outputs: ["change"] }, { kind: "ngmodule", type: NotificationModule }, { kind: "component", type: i5.Notification, selector: "cds-notification, cds-inline-notification, ibm-notification, ibm-inline-notification", inputs: ["notificationObj"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
276
147
|
}
|
|
277
148
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.3", ngImport: i0, type: DocumentenApiColumnModalComponent, decorators: [{
|
|
278
149
|
type: Component,
|
|
279
150
|
args: [{ selector: 'valtimo-documenten-api-column-modal', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [
|
|
280
151
|
CommonModule,
|
|
281
152
|
ModalModule,
|
|
282
|
-
TagModule,
|
|
283
153
|
TranslateModule,
|
|
284
154
|
InputModule,
|
|
285
155
|
ReactiveFormsModule,
|
|
286
156
|
ButtonModule,
|
|
287
157
|
DropdownModule,
|
|
288
|
-
|
|
289
|
-
|
|
290
|
-
|
|
158
|
+
RadioModule,
|
|
159
|
+
NotificationModule,
|
|
160
|
+
], template: "<!--\n ~ Copyright 2015-2024 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<cds-modal valtimoCdsModal [open]=\"type !== 'closed'\" size=\"sm\">\n <cds-modal-header showCloseButton=\"true\" (closeSelect)=\"onClose()\">\n <h3 cdsModalHeaderHeading>\n {{ (type === 'add' ? 'zgw.columns.add' : 'zgw.columns.edit') | translate }}\n </h3>\n </cds-modal-header>\n\n <form\n class=\"valtimo-documenten-api-column-modal__content\"\n cdsModalContent\n [formGroup]=\"formGroup\"\n >\n <cds-dropdown\n formControlName=\"column\"\n [label]=\"'zgw.columns.column' | translate\"\n [dropUp]=\"false\"\n >\n <cds-dropdown-list\n [items]=\"!prefillColumn ? (availableColumns$ | async) : prefillColumn\"\n ></cds-dropdown-list>\n </cds-dropdown>\n\n <cds-radio-group *ngIf=\"showRadioButtons\" legend=\"Default sort\" formControlName=\"defaultSort\">\n <cds-radio value=\"noDefault\"> {{ 'interface.sorting.noDefault' | translate }} </cds-radio>\n\n <cds-radio value=\"DESC\"> {{ 'interface.sorting.descending' | translate }} </cds-radio>\n\n <cds-radio value=\"ASC\"> {{ 'interface.sorting.ascending' | translate }} </cds-radio>\n </cds-radio-group>\n\n <cds-inline-notification [notificationObj]=\"notificationObj$ | async\"></cds-inline-notification>\n </form>\n\n <cds-modal-footer>\n <button cdsButton=\"secondary\" (click)=\"onClose()\">\n {{ 'interface.cancel' | translate }}\n </button>\n\n <button cdsButton=\"primary\" [disabled]=\"formGroup.invalid\" (click)=\"updateColumn()\">\n {{ (type === 'add' ? 'interface.add' : 'interface.save') | translate }}\n </button>\n </cds-modal-footer>\n</cds-modal>\n", styles: [".valtimo-documenten-api-column-modal__content{display:flex;flex-direction:column;gap:16px}\n/*!\n * Copyright 2015-2024 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"] }]
|
|
161
|
+
}], ctorParameters: () => [{ type: i1.FormBuilder }, { type: i2.TranslateService }, { type: i3.DocumentenApiColumnService }], propDecorators: { definitionName: [{
|
|
162
|
+
type: Input
|
|
163
|
+
}], prefillColumn: [{
|
|
291
164
|
type: Input
|
|
292
|
-
}],
|
|
165
|
+
}], type: [{
|
|
293
166
|
type: Input
|
|
294
|
-
}],
|
|
167
|
+
}], availableColumns: [{
|
|
295
168
|
type: Input
|
|
296
|
-
}],
|
|
169
|
+
}], configuredColumns: [{
|
|
297
170
|
type: Input
|
|
298
|
-
}],
|
|
171
|
+
}], closeModal: [{
|
|
299
172
|
type: Output
|
|
300
173
|
}] } });
|
|
301
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"documenten-api-column-modal.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/valtimo/zgw/src/lib/modules/documenten-api/components/documenten-api-column-modal/documenten-api-column-modal.component.ts","../../../../../../../../../projects/valtimo/zgw/src/lib/modules/documenten-api/components/documenten-api-column-modal/documenten-api-column-modal.component.html"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;GAcG;AAEH,OAAO,EACL,uBAAuB,EACvB,SAAS,EACT,YAAY,EACZ,KAAK,EAGL,MAAM,GACP,MAAM,eAAe,CAAC;AAEvB,OAAO,EACL,eAAe,EACf,aAAa,EACb,GAAG,EAEH,YAAY,EACZ,SAAS,EACT,IAAI,EACJ,GAAG,GACJ,MAAM,MAAM,CAAC;AACd,OAAO,EAAC,gBAAgB,EAAC,MAAM,qBAAqB,CAAC;AACrD,OAAO,EAGL,mBAAmB,EAGnB,UAAU,GACX,MAAM,gBAAgB,CAAC;AACxB,OAAO,EAGL,uBAAuB,EACvB,uBAAuB,GACxB,MAAM,mBAAmB,CAAC;AAC3B,OAAO,EACL,YAAY,EACZ,cAAc,EAEd,WAAW,EAEX,WAAW,EACX,SAAS,EACT,YAAY,GACb,MAAM,2BAA2B,CAAC;AACnC,OAAO,EAAC,MAAM,EAAC,MAAM,eAAe,CAAC;AACrC,OAAO,EAAC,eAAe,EAAmB,MAAM,qBAAqB,CAAC;AACtE,OAAO,EAAC,YAAY,EAAC,MAAM,iBAAiB,CAAC;;;;;;;AAoB7C,MAAM,OAAO,iCAAiC;IAC5C,IAAoB,IAAI,CAAC,KAAmC;QAC1D,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAEvB,IAAI,KAAK,KAAK,QAAQ,EAAE,CAAC;YACvB,UAAU,CAAC,GAAG,EAAE;gBACd,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YACxC,CAAC,EAAE,gBAAgB,CAAC,gBAAgB,CAAC,CAAC;QACxC,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACxC,CAAC;IACH,CAAC;IAED,IAAoB,OAAO,CAAC,KAAyB;QACnD,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAClC,CAAC;IAwED,IAAW,0BAA0B;QACnC,OAAO,IAAI,CAAC,eAAe,EAAE,GAAG,CAAC,4BAA4B,CAAC,CAAC;IACjE,CAAC;IAED,IAAW,GAAG;QACZ,OAAO,IAAI,CAAC,eAAe,EAAE,GAAG,CAAC,KAAK,CAAC,CAAC;IAC1C,CAAC;IAED,IAAW,KAAK;QACd,OAAO,IAAI,CAAC,eAAe,EAAE,GAAG,CAAC,OAAO,CAAC,CAAC;IAC5C,CAAC;IAED,IAAW,KAAK;QACd,OAAO,IAAI,CAAC,eAAe,EAAE,GAAG,CAAC,OAAO,CAAC,CAAC;IAC5C,CAAC;IAED,IAAW,OAAO;QAChB,OAAO,CAAC,CAAC,IAAI,CAAC,eAAe,EAAE,OAAO,CAAC;IACzC,CAAC;IAED,IAAW,QAAQ;QACjB,OAAO,CAAC,CAAC,IAAI,CAAC,eAAe,EAAE,QAAQ,CAAC;IAC1C,CAAC;IAkBD,YACmB,EAAe,EACf,WAAwB,EACxB,iBAAoC,EACpC,gBAAkC;QAHlC,OAAE,GAAF,EAAE,CAAa;QACf,gBAAW,GAAX,WAAW,CAAa;QACxB,sBAAiB,GAAjB,iBAAiB,CAAmB;QACpC,qBAAgB,GAAhB,gBAAgB,CAAkB;QA/GpC,oBAAe,GAAG,IAAI,YAAY,EAA0C,CAAC;QAE7E,UAAK,GAAG,IAAI,eAAe,CAA+B,SAAS,CAAC,CAAC;QACrE,yBAAoB,GAAG,IAAI,eAAe,CACzD,SAAS,CACV,CAAC;QACe,mBAAc,GAAG,IAAI,eAAe,CAAqB,SAAS,CAAC,CAAC;QAErE,cAAS,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,KAAK,QAAQ,CAAC,CAAC,CAAC;QAE5D,oBAAe,GAAG,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC;YAC9C,KAAK,EAAE,IAAI,CAAC,EAAE,CAAC,OAAO,CAAC,EAAE,EAAE,UAAU,CAAC,QAAQ,CAAC;YAC/C,GAAG,EAAE,IAAI,CAAC,EAAE,CAAC,OAAO,CAAC,EAAE,EAAE,CAAC,UAAU,CAAC,QAAQ,EAAE,IAAI,CAAC,kBAAkB,EAAE,CAAC,CAAC;YAC1E,0BAA0B,EAAE,IAAI,CAAC,EAAE,CAAC,OAAO,CAAC,IAAI,EAAE,UAAU,CAAC,QAAQ,CAAC;YACtE,KAAK,EAAE,IAAI,CAAC,EAAE,CAAC,OAAO,CAAC,EAAE,EAAE,UAAU,CAAC,QAAQ,CAAC;SAChD,CAAC,CAAC;QAEa,YAAO,GAAG,aAAa,CAAC,CAAC,IAAI,CAAC,oBAAoB,EAAE,IAAI,CAAC,cAAc,CAAC,CAAC,CAAC,IAAI,CAC5F,GAAG,CAAC,CAAC,CAAC,IAAI,EAAE,aAAa,CAAC,EAAE,EAAE;YAC5B,IAAI,IAAI,KAAK,MAAM,IAAI,aAAa;gBAAE,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,CAAC;QACxE,CAAC,CAAC,EACF,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE,EAAE,CAAC,IAAI,KAAK,MAAM,CAAC,CACjC,CAAC;QAEc,WAAM,GAAG,IAAI,CAAC,oBAAoB,CAAC,IAAI,CACrD,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,KAAK,KAAK,CAAC,EAC3B,GAAG,CAAC,KAAK,CAAC,EAAE;YACV,IAAI,KAAK;gBAAE,IAAI,CAAC,SAAS,EAAE,CAAC;QAC9B,CAAC,CAAC,CACH,CAAC;QAEc,cAAS,GAAG,IAAI,eAAe,CAAU,KAAK,CAAC,CAAC;QAE/C,WAAM,GAA8B;YACnD,uBAAuB,CAAC,GAAG;YAC3B,uBAAuB,CAAC,OAAO;YAC/B,uBAAuB,CAAC,MAAM;YAC9B,uBAAuB,CAAC,IAAI;YAC5B,uBAAuB,CAAC,IAAI;YAC5B,uBAAuB,CAAC,KAAK;YAC7B,uBAAuB,CAAC,IAAI;YAC5B,uBAAuB,CAAC,IAAI;YAC5B,uBAAuB,CAAC,QAAQ;YAChC,uBAAuB,CAAC,QAAQ;YAChC,uBAAuB,CAAC,YAAY;YACpC,uBAAuB,CAAC,OAAO;SAChC,CAAC;QAEe,oBAAe,GAAG,IAAI,eAAe,CAA0B,SAAS,CAAC,CAAC;QAE3E,oBAAe,GAA2B,aAAa,CAAC;YACtE,IAAI,CAAC,eAAe;YACpB,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,KAAK,CAAC;SACpC,CAAC,CAAC,IAAI,CACL,GAAG,CAAC,CAAC,CAAC,aAAa,CAAC,EAAE,EAAE,CACtB,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;YACxB,QAAQ,EAAE,KAAK,KAAK,aAAa;YACjC,OAAO,EAAE,IAAI,CAAC,gBAAgB,CAAC,OAAO,CACpC,oBAAoB;gBAClB,uBAAuB,CAAC,qCAAqC,CAAC,KAAK,CAAC,CACvE;YACD,KAAK;YACL,OAAO,EAAE,uBAAuB,CAAC,qCAAqC,CAAC,KAAK,CAAC;SAC9E,CAAC,CAAC,CACJ,CACF,CAAC;QA0Be,iBAAY,GAAG,IAAI,eAAe,CAAU,KAAK,CAAC,CAAC;QAEpD,gBAAW,GAAG,IAAI,CAAC,YAAY,CAAC,IAAI,CAClD,GAAG,CAAC,OAAO,CAAC,EAAE;YACZ,IAAI,OAAO,EAAE,CAAC;gBACZ,IAAI,CAAC,GAAG,EAAE,MAAM,EAAE,CAAC;YACrB,CAAC;iBAAM,CAAC;gBACN,IAAI,CAAC,GAAG,EAAE,OAAO,EAAE,CAAC;YACtB,CAAC;QACH,CAAC,CAAC,CACH,CAAC;QAEe,wBAAmB,GAAG,IAAI,eAAe,CAAS,EAAE,CAAC,CAAC;QAEtD,mBAAc,GAAG,IAAI,YAAY,EAAE,CAAC;QAQnD,IAAI,CAAC,WAAW,CAAC,WAAW,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC;IACzC,CAAC;IAEM,QAAQ;QACb,IAAI,CAAC,uBAAuB,EAAE,CAAC;IACjC,CAAC;IAEM,WAAW;QAChB,IAAI,CAAC,cAAc,CAAC,WAAW,EAAE,CAAC;IACpC,CAAC;IAEM,OAAO;QACZ,IAAI,CAAC,KAAK,EAAE,CAAC;IACf,CAAC;IAEM,mBAAmB,CAAC,OAAgB;QACzC,IAAI,CAAC,eAAe,CAAC,UAAU,CAAC;YAC9B,0BAA0B,EAAE,OAAO;SACpC,CAAC,CAAC;QACH,IAAI,CAAC,eAAe,CAAC,WAAW,EAAE,CAAC;IACrC,CAAC;IAEM,SAAS;QACd,IAAI,CAAC,OAAO,EAAE,CAAC;QAEf,IAAI,CAAC,iBAAiB;aACnB,sBAAsB,CAAC,IAAI,CAAC,sBAAsB,EAAE,IAAI,CAAC,YAAY,EAAE,CAAC;aACxE,SAAS,CAAC;YACT,IAAI,EAAE,GAAG,EAAE;gBACT,IAAI,CAAC,MAAM,EAAE,CAAC;gBACd,IAAI,CAAC,eAAe,EAAE,CAAC;YACzB,CAAC;YACD,KAAK,EAAE,GAAG,EAAE;gBACV,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;YACrB,CAAC;SACF,CAAC,CAAC;IACP,CAAC;IAEM,UAAU;QACf,IAAI,CAAC,OAAO,EAAE,CAAC;QAEf,IAAI,CAAC,mBAAmB;aACrB,IAAI,CACH,IAAI,CAAC,CAAC,CAAC,EACP,SAAS,CAAC,iBAAiB,CAAC,EAAE,CAC5B,IAAI,CAAC,iBAAiB,CAAC,wBAAwB,CAC7C,IAAI,CAAC,sBAAsB,EAC3B,iBAAiB,EACjB,IAAI,CAAC,YAAY,EAAE,CACpB,CACF,CACF;aACA,SAAS,CAAC;YACT,IAAI,EAAE,GAAG,EAAE;gBACT,IAAI,CAAC,MAAM,EAAE,CAAC;gBACd,IAAI,CAAC,eAAe,EAAE,CAAC;YACzB,CAAC;YACD,KAAK,EAAE,GAAG,EAAE;gBACV,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;YACrB,CAAC;SACF,CAAC,CAAC;IACP,CAAC;IAEM,kBAAkB;QACvB,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC/B,CAAC;IAEM,mBAAmB,CAAC,KAG1B;QACC,MAAM,QAAQ,GAAG,KAAK,EAAE,IAAI,EAAE,KAAgC,CAAC;QAE/D,IAAI,QAAQ,EAAE,CAAC;YACb,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;YACpC,IAAI,CAAC,eAAe,CAAC,UAAU,CAAC,EAAC,KAAK,EAAE,QAAQ,EAAC,CAAC,CAAC;YACnD,IAAI,CAAC,eAAe,CAAC,WAAW,EAAE,CAAC;QACrC,CAAC;IACH,CAAC;IAEO,WAAW,CAAC,aAAiC;QACnD,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC;QACjD,IAAI,CAAC,eAAe,CAAC,UAAU,CAAC;YAC9B,GAAG,EAAE,aAAa,CAAC,GAAG;YACtB,KAAK,EAAE,aAAa,CAAC,KAAK;YAC1B,0BAA0B,EAAE,aAAa,CAAC,0BAA0B;YACpE,KAAK,EAAE,aAAa,CAAC,KAAK;SAC3B,CAAC,CAAC;QACH,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;QAC/C,IAAI,CAAC,eAAe,CAAC,cAAc,EAAE,CAAC;QACtC,IAAI,CAAC,eAAe,EAAE,CAAC;IACzB,CAAC;IAEO,SAAS;QACf,IAAI,CAAC,eAAe,CAAC,UAAU,CAAC;YAC9B,GAAG,EAAE,EAAE;YACP,KAAK,EAAE,EAAE;YACT,0BAA0B,EAAE,IAAI;YAChC,KAAK,EAAE,uBAAuB,CAAC,IAAI;SACpC,CAAC,CAAC;QACH,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,uBAAuB,CAAC,IAAI,CAAC,CAAC;QACxD,IAAI,CAAC,eAAe,CAAC,cAAc,EAAE,CAAC;QACtC,IAAI,CAAC,eAAe,EAAE,CAAC;IACzB,CAAC;IAEO,eAAe;QACrB,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAChC,CAAC;IAEO,uBAAuB;QAC7B,IAAI,CAAC,cAAc,CAAC,GAAG,CACrB,aAAa,CAAC,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,KAAK,CAAC,YAAY,EAAE,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,SAAS,CAC/E,CAAC,CAAC,KAAK,EAAE,UAAU,EAAE,UAAU,CAAC,EAAE,EAAE;YAClC,IAAI,KAAK,IAAI,CAAC,UAAU,EAAE,CAAC;gBACzB,IAAI,UAAU,EAAE,CAAC;oBACf,IAAI,CAAC,eAAe,CAAC,UAAU,CAAC,EAAC,GAAG,EAAE,IAAI,CAAC,YAAY,CAAC,UAAU,CAAC,EAAC,CAAC,CAAC;gBACxE,CAAC;qBAAM,CAAC;oBACN,IAAI,CAAC,QAAQ,EAAE,CAAC;gBAClB,CAAC;YACH,CAAC;QACH,CAAC,CACF,CACF,CAAC;IACJ,CAAC;IAEO,YAAY,CAAC,KAAa;QAChC,MAAM,WAAW,GAAG,GAAG,KAAK,EAAE;aAC3B,WAAW,EAAE;aACb,OAAO,CAAC,2BAA2B,EAAE,GAAG,CAAC;aACzC,OAAO,CAAC,SAAS,EAAE,GAAG,CAAC;aACvB,OAAO,CAAC,WAAW,EAAE,EAAE,CAAC,CAAC;QAC5B,MAAM,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC;QAE/B,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,WAAW,CAAC,EAAE,CAAC;YACpC,OAAO,WAAW,CAAC;QACrB,CAAC;QAED,OAAO,IAAI,CAAC,sBAAsB,CAAC,WAAW,EAAE,QAAQ,CAAC,CAAC;IAC5D,CAAC;IAEO,sBAAsB,CAAC,WAAmB,EAAE,QAAkB;QACpE,MAAM,qBAAqB,GAAG,CAAC,WAAW,CAAC,KAAK,CAAC,uBAAuB,CAAC,IAAI,EAAE,CAAC,CAAC,GAAG,CAClF,CAAC,WAAmB,EAAE,EAAE,CAAC,CAAC,WAAW,CACtC,CAAC;QACF,MAAM,wBAAwB,GAC5B,qBAAqB,CAAC,MAAM,GAAG,CAAC,IAAI,qBAAqB,CAAC,qBAAqB,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;QAC9F,MAAM,MAAM,GAAG,wBAAwB;YACrC,CAAC,CAAC,GAAG,WAAW,CAAC,OAAO,CAAC,GAAG,wBAAwB,EAAE,EAAE,GAAG,wBAAwB,GAAG,CAAC,EAAE,CAAC,EAAE;YAC5F,CAAC,CAAC,GAAG,WAAW,IAAI,CAAC;QAEvB,IAAI,QAAQ,CAAC,QAAQ,CAAC,MAAM,CAAC,EAAE,CAAC;YAC9B,OAAO,IAAI,CAAC,sBAAsB,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC;QACvD,CAAC;QAED,OAAO,MAAM,CAAC;IAChB,CAAC;IAEO,QAAQ;QACd,IAAI,CAAC,eAAe,CAAC,UAAU,CAAC,EAAC,GAAG,EAAE,EAAE,EAAC,CAAC,CAAC;IAC7C,CAAC;IAEO,kBAAkB;QACxB,OAAO,CAAC,OAAwB,EAA2B,EAAE,CAC3D,IAAI,CAAC,QAAQ,EAAE,KAAK,CAAC,CAAC,GAAW,EAAE,EAAE,CAAC,GAAG,KAAK,OAAO,CAAC,KAAK,CAAC;YAC1D,CAAC,CAAC,IAAI;YACN,CAAC,CAAC,EAAC,SAAS,EAAE,EAAC,KAAK,EAAE,OAAO,CAAC,KAAK,EAAC,EAAC,CAAC;IAC5C,CAAC;IAEO,OAAO;QACb,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC1B,IAAI,CAAC,eAAe,CAAC,OAAO,EAAE,CAAC;IACjC,CAAC;IAEO,MAAM,CAAC,KAAK,GAAG,IAAI;QACzB,UAAU,CACR,GAAG,EAAE;YACH,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YAC3B,IAAI,CAAC,eAAe,CAAC,MAAM,EAAE,CAAC;QAChC,CAAC,EACD,KAAK,CAAC,CAAC,CAAC,gBAAgB,CAAC,gBAAgB,CAAC,CAAC,CAAC,CAAC,CAC9C,CAAC;IACJ,CAAC;IAEO,KAAK;QACX,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IACrC,CAAC;IAEO,eAAe;QACrB,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC;IAC/C,CAAC;IAEO,YAAY;QAClB,OAAO;YACL,GAAG,EAAE,IAAI,CAAC,GAAG,CAAC,KAAK;YACnB,KAAK,EAAE,IAAI,CAAC,KAAK,CAAC,KAAK;YACvB,0BAA0B,EAAE,IAAI,CAAC,0BAA0B,CAAC,KAAK;YACjE,KAAK,EAAE,IAAI,CAAC,KAAK,CAAC,KAAgC;SACnD,CAAC;IACJ,CAAC;8GA3UU,iCAAiC;kGAAjC,iCAAiC,sQCnF9C,i3IAuIA,qlCD/DI,YAAY,8VACZ,WAAW,+sBACX,SAAS,oIACT,eAAe,2FACf,WAAW,yWACX,mBAAmB,48BACnB,YAAY,6cACZ,cAAc,mrBACd,YAAY;;2FAGH,iCAAiC;kBAlB7C,SAAS;+BACE,qCAAqC,mBAG9B,uBAAuB,CAAC,MAAM,cACnC,IAAI,WACP;wBACP,YAAY;wBACZ,WAAW;wBACX,SAAS;wBACT,eAAe;wBACf,WAAW;wBACX,mBAAmB;wBACnB,YAAY;wBACZ,cAAc;wBACd,YAAY;qBACb;yKAGmB,IAAI;sBAAvB,KAAK;gBAYc,OAAO;sBAA1B,KAAK;gBAIU,QAAQ;sBAAvB,KAAK;gBACU,sBAAsB;sBAArC,KAAK;gBAEW,eAAe;sBAA/B,MAAM","sourcesContent":["/*\n * Copyright 2015-2024 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 {\n  ChangeDetectionStrategy,\n  Component,\n  EventEmitter,\n  Input,\n  OnDestroy,\n  OnInit,\n  Output,\n} from '@angular/core';\nimport {DocumentenApiColumnModalType, DocumentenApiColumnModalTypeCloseEvent} from '../../models';\nimport {\n  BehaviorSubject,\n  combineLatest,\n  map,\n  Observable,\n  Subscription,\n  switchMap,\n  take,\n  tap,\n} from 'rxjs';\nimport {CARBON_CONSTANTS} from '@valtimo/components';\nimport {\n  AbstractControl,\n  FormBuilder,\n  ReactiveFormsModule,\n  ValidationErrors,\n  ValidatorFn,\n  Validators,\n} from '@angular/forms';\nimport {\n  CaseStatusService,\n  InternalCaseStatus,\n  InternalCaseStatusColor,\n  InternalCaseStatusUtils,\n} from '@valtimo/document';\nimport {\n  ButtonModule,\n  DropdownModule,\n  IconService,\n  InputModule,\n  ListItem,\n  ModalModule,\n  TagModule,\n  ToggleModule,\n} from 'carbon-components-angular';\nimport {Edit16} from '@carbon/icons';\nimport {TranslateModule, TranslateService} from '@ngx-translate/core';\nimport {CommonModule} from '@angular/common';\n\n@Component({\n  selector: 'valtimo-documenten-api-column-modal',\n  templateUrl: './documenten-api-column-modal.component.html',\n  styleUrls: ['./documenten-api-column-modal.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [\n    CommonModule,\n    ModalModule,\n    TagModule,\n    TranslateModule,\n    InputModule,\n    ReactiveFormsModule,\n    ButtonModule,\n    DropdownModule,\n    ToggleModule,\n  ],\n})\nexport class DocumentenApiColumnModalComponent implements OnInit, OnDestroy {\n  @Input() public set type(value: DocumentenApiColumnModalType) {\n    this._type.next(value);\n\n    if (value === 'closed') {\n      setTimeout(() => {\n        this._typeAnimationDelay$.next(value);\n      }, CARBON_CONSTANTS.modalAnimationMs);\n    } else {\n      this._typeAnimationDelay$.next(value);\n    }\n  }\n\n  @Input() public set prefill(value: InternalCaseStatus) {\n    this._prefillStatus.next(value);\n  }\n\n  @Input() public usedKeys!: string[];\n  @Input() public documentDefinitionName!: string;\n\n  @Output() public closeModalEvent = new EventEmitter<DocumentenApiColumnModalTypeCloseEvent>();\n\n  private readonly _type = new BehaviorSubject<DocumentenApiColumnModalType>(undefined);\n  private readonly _typeAnimationDelay$ = new BehaviorSubject<DocumentenApiColumnModalType>(\n    undefined\n  );\n  private readonly _prefillStatus = new BehaviorSubject<InternalCaseStatus>(undefined);\n\n  public readonly isClosed$ = this._type.pipe(map(type => type === 'closed'));\n\n  public readonly statusFormGroup = this.fb.group({\n    title: this.fb.control('', Validators.required),\n    key: this.fb.control('', [Validators.required, this.uniqueKeyValidator()]),\n    visibleInCaseListByDefault: this.fb.control(true, Validators.required),\n    color: this.fb.control('', Validators.required),\n  });\n\n  public readonly isEdit$ = combineLatest([this._typeAnimationDelay$, this._prefillStatus]).pipe(\n    tap(([type, prefillStatus]) => {\n      if (type === 'edit' && prefillStatus) this.prefillForm(prefillStatus);\n    }),\n    map(([type]) => type === 'edit')\n  );\n\n  public readonly isAdd$ = this._typeAnimationDelay$.pipe(\n    map(type => type === 'add'),\n    tap(isAdd => {\n      if (isAdd) this.resetForm();\n    })\n  );\n\n  public readonly disabled$ = new BehaviorSubject<boolean>(false);\n\n  private readonly COLORS: InternalCaseStatusColor[] = [\n    InternalCaseStatusColor.Red,\n    InternalCaseStatusColor.Magenta,\n    InternalCaseStatusColor.Purple,\n    InternalCaseStatusColor.Blue,\n    InternalCaseStatusColor.Teal,\n    InternalCaseStatusColor.Green,\n    InternalCaseStatusColor.Cyan,\n    InternalCaseStatusColor.Gray,\n    InternalCaseStatusColor.CoolGray,\n    InternalCaseStatusColor.WarmGray,\n    InternalCaseStatusColor.HighContrast,\n    InternalCaseStatusColor.Outline,\n  ];\n\n  private readonly _selectedColor$ = new BehaviorSubject<InternalCaseStatusColor>(undefined);\n\n  public readonly colorListItems$: Observable<ListItem[]> = combineLatest([\n    this._selectedColor$,\n    this.translateService.stream('key'),\n  ]).pipe(\n    map(([selectedColor]) =>\n      this.COLORS.map(color => ({\n        selected: color === selectedColor,\n        content: this.translateService.instant(\n          'interface.tagType.' +\n            InternalCaseStatusUtils.getTagTypeFromInternalCaseStatusColor(color)\n        ),\n        color,\n        tagType: InternalCaseStatusUtils.getTagTypeFromInternalCaseStatusColor(color),\n      }))\n    )\n  );\n\n  public get visibleInCaseListByDefault(): AbstractControl<boolean, boolean> {\n    return this.statusFormGroup?.get('visibleInCaseListByDefault');\n  }\n\n  public get key(): AbstractControl<string, string> {\n    return this.statusFormGroup?.get('key');\n  }\n\n  public get title(): AbstractControl<string, string> {\n    return this.statusFormGroup?.get('title');\n  }\n\n  public get color(): AbstractControl<string, string> {\n    return this.statusFormGroup?.get('color');\n  }\n\n  public get invalid(): boolean {\n    return !!this.statusFormGroup?.invalid;\n  }\n\n  public get pristine(): boolean {\n    return !!this.statusFormGroup?.pristine;\n  }\n\n  private readonly _editingKey$ = new BehaviorSubject<boolean>(false);\n\n  public readonly editingKey$ = this._editingKey$.pipe(\n    tap(editing => {\n      if (editing) {\n        this.key?.enable();\n      } else {\n        this.key?.disable();\n      }\n    })\n  );\n\n  private readonly _originalStatusKey$ = new BehaviorSubject<string>('');\n\n  private readonly _subscriptions = new Subscription();\n\n  constructor(\n    private readonly fb: FormBuilder,\n    private readonly iconService: IconService,\n    private readonly caseStatusService: CaseStatusService,\n    private readonly translateService: TranslateService\n  ) {\n    this.iconService.registerAll([Edit16]);\n  }\n\n  public ngOnInit(): void {\n    this.openAutoKeySubscription();\n  }\n\n  public ngOnDestroy(): void {\n    this._subscriptions.unsubscribe();\n  }\n\n  public onClose(): void {\n    this.close();\n  }\n\n  public toggleCheckedChange(checked: boolean): void {\n    this.statusFormGroup.patchValue({\n      visibleInCaseListByDefault: checked,\n    });\n    this.statusFormGroup.markAsDirty();\n  }\n\n  public addStatus(): void {\n    this.disable();\n\n    this.caseStatusService\n      .saveInternalCaseStatus(this.documentDefinitionName, this.getFormValue())\n      .subscribe({\n        next: () => {\n          this.enable();\n          this.closeAndRefresh();\n        },\n        error: () => {\n          this.enable(false);\n        },\n      });\n  }\n\n  public editStatus(): void {\n    this.disable();\n\n    this._originalStatusKey$\n      .pipe(\n        take(1),\n        switchMap(originalStatusKey =>\n          this.caseStatusService.updateInternalCaseStatus(\n            this.documentDefinitionName,\n            originalStatusKey,\n            this.getFormValue()\n          )\n        )\n      )\n      .subscribe({\n        next: () => {\n          this.enable();\n          this.closeAndRefresh();\n        },\n        error: () => {\n          this.enable(false);\n        },\n      });\n  }\n\n  public editKeyButtonClick(): void {\n    this._editingKey$.next(true);\n  }\n\n  public colorDropdownChange(event: {\n    item: {color: string; content: string; selected: boolean};\n    isUpdate: boolean;\n  }): void {\n    const newColor = event?.item?.color as InternalCaseStatusColor;\n\n    if (newColor) {\n      this._selectedColor$.next(newColor);\n      this.statusFormGroup.patchValue({color: newColor});\n      this.statusFormGroup.markAsDirty();\n    }\n  }\n\n  private prefillForm(prefillStatus: InternalCaseStatus): void {\n    this._originalStatusKey$.next(prefillStatus.key);\n    this.statusFormGroup.patchValue({\n      key: prefillStatus.key,\n      title: prefillStatus.title,\n      visibleInCaseListByDefault: prefillStatus.visibleInCaseListByDefault,\n      color: prefillStatus.color,\n    });\n    this._selectedColor$.next(prefillStatus.color);\n    this.statusFormGroup.markAsPristine();\n    this.resetEditingKey();\n  }\n\n  private resetForm(): void {\n    this.statusFormGroup.patchValue({\n      key: '',\n      title: '',\n      visibleInCaseListByDefault: true,\n      color: InternalCaseStatusColor.Blue,\n    });\n    this._selectedColor$.next(InternalCaseStatusColor.Blue);\n    this.statusFormGroup.markAsPristine();\n    this.resetEditingKey();\n  }\n\n  private resetEditingKey(): void {\n    this._editingKey$.next(false);\n  }\n\n  private openAutoKeySubscription(): void {\n    this._subscriptions.add(\n      combineLatest([this.isAdd$, this.title.valueChanges, this.editingKey$]).subscribe(\n        ([isAdd, titleValue, editingKey]) => {\n          if (isAdd && !editingKey) {\n            if (titleValue) {\n              this.statusFormGroup.patchValue({key: this.getUniqueKey(titleValue)});\n            } else {\n              this.clearKey();\n            }\n          }\n        }\n      )\n    );\n  }\n\n  private getUniqueKey(title: string): string {\n    const dashCaseKey = `${title}`\n      .toLowerCase()\n      .replace(/[^a-z0-9-_]+|-[^a-z0-9]+/g, '-')\n      .replace(/_[-_]+/g, '_')\n      .replace(/^[^a-z]+/g, '');\n    const usedKeys = this.usedKeys;\n\n    if (!usedKeys.includes(dashCaseKey)) {\n      return dashCaseKey;\n    }\n\n    return this.getUniqueKeyWithNumber(dashCaseKey, usedKeys);\n  }\n\n  private getUniqueKeyWithNumber(dashCaseKey: string, usedKeys: string[]): string {\n    const numbersFromCurrentKey = (dashCaseKey.match(/^\\d+|\\d+\\b|\\d+(?=\\w)/g) || []).map(\n      (numberValue: string) => +numberValue\n    );\n    const lastNumberFromCurrentKey =\n      numbersFromCurrentKey.length > 0 && numbersFromCurrentKey[numbersFromCurrentKey.length - 1];\n    const newKey = lastNumberFromCurrentKey\n      ? `${dashCaseKey.replace(`${lastNumberFromCurrentKey}`, `${lastNumberFromCurrentKey + 1}`)}`\n      : `${dashCaseKey}-1`;\n\n    if (usedKeys.includes(newKey)) {\n      return this.getUniqueKeyWithNumber(newKey, usedKeys);\n    }\n\n    return newKey;\n  }\n\n  private clearKey(): void {\n    this.statusFormGroup.patchValue({key: ''});\n  }\n\n  private uniqueKeyValidator(): ValidatorFn {\n    return (control: AbstractControl): ValidationErrors | null =>\n      this.usedKeys?.every((key: string) => key !== control.value)\n        ? null\n        : {uniqueKey: {value: control.value}};\n  }\n\n  private disable(): void {\n    this.disabled$.next(true);\n    this.statusFormGroup.disable();\n  }\n\n  private enable(delay = true): void {\n    setTimeout(\n      () => {\n        this.disabled$.next(false);\n        this.statusFormGroup.enable();\n      },\n      delay ? CARBON_CONSTANTS.modalAnimationMs : 0\n    );\n  }\n\n  private close(): void {\n    this.closeModalEvent.emit('close');\n  }\n\n  private closeAndRefresh(): void {\n    this.closeModalEvent.emit('closeAndRefresh');\n  }\n\n  private getFormValue(): InternalCaseStatus {\n    return {\n      key: this.key.value,\n      title: this.title.value,\n      visibleInCaseListByDefault: this.visibleInCaseListByDefault.value,\n      color: this.color.value as InternalCaseStatusColor,\n    };\n  }\n}\n","<!--\n  ~ Copyright 2015-2024 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<cds-modal\n  valtimoCdsModal\n  *ngIf=\"{\n    isAdd: isAdd$ | async,\n    isEdit: isEdit$ | async,\n    isClosed: isClosed$ | async,\n    editingKey: editingKey$ | async,\n    disabled: disabled$ | async\n  } as obs\"\n  [open]=\"!obs.isClosed\"\n  size=\"sm\"\n>\n  <cds-modal-header showCloseButton=\"true\" (closeSelect)=\"onClose()\">\n    <h3 cdsModalHeaderHeading>\n      {{ obs.isAdd ? ('dossierManagement.statuses.add' | translate) : '' }}\n      {{ obs.isEdit ? ('dossierManagement.statuses.edit' | translate) : '' }}\n    </h3>\n  </cds-modal-header>\n\n  <section cdsModalContent>\n    <ng-container *ngTemplateOutlet=\"statusForm; context: {obs: obs}\"></ng-container>\n  </section>\n\n  <cds-modal-footer>\n    <ng-container *ngTemplateOutlet=\"buttons; context: {obs: obs}\"></ng-container>\n  </cds-modal-footer>\n</cds-modal>\n\n<ng-template #colorDropdownItemTemplate let-item=\"item\">\n  <div class=\"dropdown-color-tag\">\n    <cds-tag *ngIf=\"item && item.content\" class=\"cds-tag--no-margin\" [type]=\"item?.tagType\">\n      {{ 'interface.tagType.' + item?.tagType | translate }}\n    </cds-tag>\n  </div>\n</ng-template>\n\n<ng-template #statusForm let-obs=\"obs\">\n  <form [formGroup]=\"statusFormGroup\" class=\"status-form\">\n    <cds-label>\n      {{ 'dossierManagement.statuses.columns.title' | translate }}\n\n      <input cdsText formControlName=\"title\" [attr.modal-primary-focus]=\"true\" />\n    </cds-label>\n\n    <cds-label>\n      {{ 'dossierManagement.statuses.columns.key' | translate }}\n\n      <div class=\"edit-key-input\">\n        <input\n          cdsText\n          formControlName=\"key\"\n          [disabled]=\"!obs.editingKey\"\n          [placeholder]=\"\n            obs.isAdd && !obs.editingKey\n              ? ('dossierManagement.statuses.keyAutoGenerated' | translate)\n              : ''\n          \"\n        />\n\n        <cds-icon-button\n          *ngIf=\"!obs.editingKey && obs.isAdd\"\n          [disabled]=\"obs.disabled\"\n          (click)=\"editKeyButtonClick()\"\n          kind=\"secondary\"\n        >\n          <svg class=\"cds--btn__icon\" cdsIcon=\"edit\" size=\"16\"></svg>\n        </cds-icon-button>\n      </div>\n    </cds-label>\n\n    <div class=\"horizontal-inputs\">\n      <cds-label>\n        {{ 'dossierManagement.statuses.columns.color' | translate }}\n\n        <cds-dropdown\n          [appendInline]=\"false\"\n          [placeholder]=\"'dossierManagement.statuses.colorPlaceholder' | translate\"\n          (selected)=\"colorDropdownChange($event)\"\n        >\n          <cds-dropdown-list [items]=\"colorListItems$\" [listTpl]=\"colorDropdownItemTemplate\">\n          </cds-dropdown-list>\n        </cds-dropdown>\n      </cds-label>\n\n      <cds-toggle\n        [label]=\"'dossierManagement.statuses.visibleTitle' | translate\"\n        [onText]=\"'dossierManagement.statuses.visible' | translate\"\n        [offText]=\"'dossierManagement.statuses.invisible' | translate\"\n        [disabled]=\"obs.disabled\"\n        [checked]=\"visibleInCaseListByDefault?.value\"\n        (checkedChange)=\"toggleCheckedChange($event)\"\n      ></cds-toggle>\n    </div>\n  </form>\n</ng-template>\n\n<ng-template #buttons let-obs=\"obs\">\n  <button cdsButton=\"secondary\" (click)=\"onClose()\" [disabled]=\"obs.disabled\">\n    {{ 'interface.cancel' | translate }}\n  </button>\n\n  <button\n    *ngIf=\"obs.isAdd\"\n    cdsButton=\"primary\"\n    [disabled]=\"invalid || pristine || obs.disabled\"\n    (click)=\"addStatus()\"\n  >\n    {{ 'interface.add' | translate }}\n  </button>\n\n  <button\n    *ngIf=\"obs.isEdit\"\n    cdsButton=\"primary\"\n    [disabled]=\"invalid || pristine || obs.disabled\"\n    (click)=\"editStatus()\"\n  >\n    {{ 'interface.save' | translate }}\n  </button>\n</ng-template>\n"]}
|
|
174
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"documenten-api-column-modal.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/valtimo/zgw/src/lib/modules/documenten-api/components/documenten-api-column-modal/documenten-api-column-modal.component.ts","../../../../../../../../../projects/valtimo/zgw/src/lib/modules/documenten-api/components/documenten-api-column-modal/documenten-api-column-modal.component.html"],"names":[],"mappings":"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","sourcesContent":["/*\n * Copyright 2015-2024 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 {CommonModule} from '@angular/common';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  EventEmitter,\n  Input,\n  OnDestroy,\n  OnInit,\n  Output,\n} from '@angular/core';\nimport {FormBuilder, ReactiveFormsModule, Validators} from '@angular/forms';\nimport {TranslateModule, TranslateService} from '@ngx-translate/core';\nimport {\n  ButtonModule,\n  DropdownModule,\n  InputModule,\n  ListItem,\n  ModalModule,\n  NotificationContent,\n  NotificationModule,\n  RadioModule,\n} from 'carbon-components-angular';\nimport {BehaviorSubject, combineLatest, map, Observable, Subscription, switchMap} from 'rxjs';\nimport {\n  ConfiguredColumn,\n  DocumentenApiColumnModalType,\n  DocumentenApiColumnModalTypeCloseEvent,\n} from '../../models';\nimport {DocumentenApiColumnService} from '../../services';\nimport {CARBON_CONSTANTS} from '@valtimo/components';\n\n@Component({\n  selector: 'valtimo-documenten-api-column-modal',\n  templateUrl: './documenten-api-column-modal.component.html',\n  styleUrls: ['./documenten-api-column-modal.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [\n    CommonModule,\n    ModalModule,\n    TranslateModule,\n    InputModule,\n    ReactiveFormsModule,\n    ButtonModule,\n    DropdownModule,\n    RadioModule,\n    NotificationModule,\n  ],\n})\nexport class DocumentenApiColumnModalComponent implements OnInit, OnDestroy {\n  @Input() public definitionName: string;\n\n  private _prefillColumn!: ListItem[] | null;\n  @Input() public set prefillColumn(value: ConfiguredColumn | undefined) {\n    if (!value) return;\n\n    const column = {content: value.key, selected: true, column: value};\n    const defaultSort = value.defaultSort ?? 'noDefault';\n    this.formGroup.patchValue({column, defaultSort});\n    this.formGroup.get('column')?.disable();\n    this._prefillColumn = [column];\n  }\n  public get prefillColumn(): ListItem[] | null {\n    return this._prefillColumn;\n  }\n\n  private _type!: DocumentenApiColumnModalType;\n  @Input() public set type(value: DocumentenApiColumnModalType) {\n    this._type = value;\n    if (value === 'edit') {\n      this.formGroup.get('column')?.disable;\n    }\n  }\n  public get type(): DocumentenApiColumnModalType {\n    return this._type;\n  }\n\n  private readonly _availableColumns$ = new BehaviorSubject<ConfiguredColumn[]>([]);\n  @Input() public set availableColumns(value: ConfiguredColumn[]) {\n    if (!value) return;\n\n    this._availableColumns$.next(value);\n  }\n\n  public readonly availableColumns$: Observable<ListItem[]> = combineLatest([\n    this._availableColumns$,\n    this.translateService.stream('key'),\n  ]).pipe(\n    map(([columns]) =>\n      columns.map((column: ConfiguredColumn) => ({\n        content: this.translateService.instant(`zgw.documentColumns.${column.key}`),\n        selected: false,\n        column,\n      }))\n    )\n  );\n\n  private _defaultSortedColumn!: ConfiguredColumn | undefined;\n  @Input() public set configuredColumns(value: ConfiguredColumn[]) {\n    if (!value) return;\n\n    this._defaultSortedColumn = value.find((column: ConfiguredColumn) => !!column.defaultSort);\n  }\n\n  @Output() closeModal = new EventEmitter<DocumentenApiColumnModalTypeCloseEvent>();\n\n  public formGroup = this.fb.group({\n    column: this.fb.control(\n      {content: '', selected: false, column: {} as ConfiguredColumn},\n      Validators.required\n    ),\n    defaultSort: this.fb.control<'ASC' | 'DESC' | 'noDefault'>('noDefault'),\n  });\n\n  private readonly _notificationMessage$ = new BehaviorSubject<string>(\n    'zgw.columns.defaultWarning'\n  );\n  public readonly notificationObj$: Observable<NotificationContent> = combineLatest([\n    this._notificationMessage$,\n    this.translateService.stream('key'),\n  ]).pipe(\n    map(([message]) => ({\n      type: 'warning',\n      lowContrast: true,\n      title: this.translateService.instant('interface.warning'),\n      message: this.translateService.instant(message),\n      showClose: false,\n    }))\n  );\n\n  public showRadioButtons = true;\n\n  private readonly _subscriptions = new Subscription();\n\n  constructor(\n    private readonly fb: FormBuilder,\n    private readonly translateService: TranslateService,\n    private readonly zgwDocumentenApiColumnService: DocumentenApiColumnService\n  ) {}\n\n  public ngOnInit(): void {\n    this.openDisableRadioSubscription();\n  }\n\n  public ngOnDestroy(): void {\n    this._subscriptions.unsubscribe();\n  }\n\n  public onClose(refresh = false): void {\n    this.closeModal.emit(refresh ? 'closeAndRefresh' : 'close');\n\n    setTimeout(() => {\n      this.formGroup.reset();\n      this.formGroup.enable();\n      this.showRadioButtons = true;\n      this._notificationMessage$.next('zgw.columns.defaultWarning');\n      this._prefillColumn = null;\n    }, CARBON_CONSTANTS.modalAnimationMs);\n  }\n\n  public updateColumn(): void {\n    const columnValue: ListItem | null | undefined = this.formGroup.get('column')?.value;\n    if (!columnValue || !this.definitionName) {\n      return;\n    }\n    const defaultSortValue = this.formGroup.get('defaultSort')?.value;\n    const defaultSort = !defaultSortValue\n      ? null\n      : defaultSortValue === 'noDefault'\n        ? null\n        : defaultSortValue;\n    const column = {...columnValue.column, defaultSort};\n\n    if (\n      !!this._defaultSortedColumn &&\n      this._defaultSortedColumn.key !== column.key &&\n      !!column.defaultSort\n    ) {\n      this.zgwDocumentenApiColumnService\n        .updateColumn(this.definitionName, {\n          ...this._defaultSortedColumn,\n          defaultSort: null,\n        })\n        .pipe(\n          switchMap(() =>\n            this.zgwDocumentenApiColumnService.updateColumn(this.definitionName, column)\n          )\n        )\n        .subscribe(() => {\n          this.onClose(true);\n        });\n\n      return;\n    }\n\n    this.zgwDocumentenApiColumnService.updateColumn(this.definitionName, column).subscribe(() => {\n      this.onClose(true);\n    });\n  }\n\n  private openDisableRadioSubscription(): void {\n    this._subscriptions.add(\n      this.formGroup.get('column')?.valueChanges.subscribe(columnValue => {\n        this.showRadioButtons = !!columnValue?.column.sortable;\n\n        this._notificationMessage$.next(\n          this.showRadioButtons ? 'zgw.columns.defaultWarning' : 'zgw.columns.notSortable'\n        );\n      })\n    );\n  }\n}\n","<!--\n  ~ Copyright 2015-2024 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<cds-modal valtimoCdsModal [open]=\"type !== 'closed'\" size=\"sm\">\n  <cds-modal-header showCloseButton=\"true\" (closeSelect)=\"onClose()\">\n    <h3 cdsModalHeaderHeading>\n      {{ (type === 'add' ? 'zgw.columns.add' : 'zgw.columns.edit') | translate }}\n    </h3>\n  </cds-modal-header>\n\n  <form\n    class=\"valtimo-documenten-api-column-modal__content\"\n    cdsModalContent\n    [formGroup]=\"formGroup\"\n  >\n    <cds-dropdown\n      formControlName=\"column\"\n      [label]=\"'zgw.columns.column' | translate\"\n      [dropUp]=\"false\"\n    >\n      <cds-dropdown-list\n        [items]=\"!prefillColumn ? (availableColumns$ | async) : prefillColumn\"\n      ></cds-dropdown-list>\n    </cds-dropdown>\n\n    <cds-radio-group *ngIf=\"showRadioButtons\" legend=\"Default sort\" formControlName=\"defaultSort\">\n      <cds-radio value=\"noDefault\"> {{ 'interface.sorting.noDefault' | translate }} </cds-radio>\n\n      <cds-radio value=\"DESC\"> {{ 'interface.sorting.descending' | translate }} </cds-radio>\n\n      <cds-radio value=\"ASC\"> {{ 'interface.sorting.ascending' | translate }} </cds-radio>\n    </cds-radio-group>\n\n    <cds-inline-notification [notificationObj]=\"notificationObj$ | async\"></cds-inline-notification>\n  </form>\n\n  <cds-modal-footer>\n    <button cdsButton=\"secondary\" (click)=\"onClose()\">\n      {{ 'interface.cancel' | translate }}\n    </button>\n\n    <button cdsButton=\"primary\" [disabled]=\"formGroup.invalid\" (click)=\"updateColumn()\">\n      {{ (type === 'add' ? 'interface.add' : 'interface.save') | translate }}\n    </button>\n  </cds-modal-footer>\n</cds-modal>\n"]}
|