@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.
Files changed (80) hide show
  1. package/esm2022/lib/components/dossier-management-zgw/dossier-management-zgw.component.mjs +61 -13
  2. package/esm2022/lib/models/dossier-management-zgw.model.mjs +5 -3
  3. package/esm2022/lib/modules/documenten-api/components/documenten-api-column-modal/documenten-api-column-modal.component.mjs +115 -242
  4. package/esm2022/lib/modules/documenten-api/components/documenten-api-columns/documenten-api-columns.component.mjs +57 -85
  5. package/esm2022/lib/modules/documenten-api/components/documenten-api-documents/documenten-api-documents.component.mjs +171 -100
  6. package/esm2022/lib/modules/documenten-api/components/documenten-api-filter/documenten-api-filter.component.mjs +174 -0
  7. package/esm2022/lib/modules/documenten-api/components/documenten-api-metadata-modal/documenten-api-metadata-modal.component.mjs +244 -106
  8. package/esm2022/lib/modules/documenten-api/components/documenten-api-tag-modal/documenten-api-tag-modal.component.mjs +115 -0
  9. package/esm2022/lib/modules/documenten-api/components/documenten-api-tags/documenten-api-tags.component.mjs +164 -0
  10. package/esm2022/lib/modules/documenten-api/components/index.mjs +5 -2
  11. package/esm2022/lib/modules/documenten-api/formio/documenten-api-uploader/documenten-api-uploader.component.mjs +3 -3
  12. package/esm2022/lib/modules/documenten-api/models/configured-column.model.mjs +12 -2
  13. package/esm2022/lib/modules/documenten-api/models/documenten-api-filter.model.mjs +17 -0
  14. package/esm2022/lib/modules/documenten-api/models/documenten-api-metadata.model.mjs +1 -1
  15. package/esm2022/lib/modules/documenten-api/models/documenten-api-tag.model.mjs +17 -0
  16. package/esm2022/lib/modules/documenten-api/models/documenten-api-version.model.mjs +1 -1
  17. package/esm2022/lib/modules/documenten-api/models/documenten-api.model.mjs +22 -2
  18. package/esm2022/lib/modules/documenten-api/models/index.mjs +2 -1
  19. package/esm2022/lib/modules/documenten-api/services/documenten-api-column.service.mjs +10 -9
  20. package/esm2022/lib/modules/documenten-api/services/documenten-api-document.service.mjs +10 -3
  21. package/esm2022/lib/modules/documenten-api/services/documenten-api-link-process.service.mjs +1 -16
  22. package/esm2022/lib/modules/documenten-api/services/documenten-api-tag.service.mjs +36 -0
  23. package/esm2022/lib/modules/documenten-api/services/documenten-api-version.service.mjs +4 -1
  24. package/esm2022/lib/modules/documenten-api/services/index.mjs +3 -2
  25. package/esm2022/lib/modules/objecten-api/components/zaakobjecten/zaakobjecten.component.mjs +2 -2
  26. package/esm2022/lib/modules/zaakdetails/components/document-objecten-api-sync/document-objecten-api-sync.component.mjs +1 -1
  27. package/esm2022/lib/services/dossier-management-zgw.service.mjs +8 -4
  28. package/esm2022/lib/zgw.module.mjs +22 -5
  29. package/fesm2022/valtimo-zgw.mjs +1378 -781
  30. package/fesm2022/valtimo-zgw.mjs.map +1 -1
  31. package/lib/components/dossier-management-zgw/dossier-management-zgw.component.d.ts +16 -5
  32. package/lib/components/dossier-management-zgw/dossier-management-zgw.component.d.ts.map +1 -1
  33. package/lib/models/dossier-management-zgw.model.d.ts +12 -2
  34. package/lib/models/dossier-management-zgw.model.d.ts.map +1 -1
  35. package/lib/modules/documenten-api/components/documenten-api-column-modal/documenten-api-column-modal.component.d.ts +33 -63
  36. package/lib/modules/documenten-api/components/documenten-api-column-modal/documenten-api-column-modal.component.d.ts.map +1 -1
  37. package/lib/modules/documenten-api/components/documenten-api-columns/documenten-api-columns.component.d.ts +18 -20
  38. package/lib/modules/documenten-api/components/documenten-api-columns/documenten-api-columns.component.d.ts.map +1 -1
  39. package/lib/modules/documenten-api/components/documenten-api-documents/documenten-api-documents.component.d.ts +38 -20
  40. package/lib/modules/documenten-api/components/documenten-api-documents/documenten-api-documents.component.d.ts.map +1 -1
  41. package/lib/modules/documenten-api/components/documenten-api-filter/documenten-api-filter.component.d.ts +47 -0
  42. package/lib/modules/documenten-api/components/documenten-api-filter/documenten-api-filter.component.d.ts.map +1 -0
  43. package/lib/modules/documenten-api/components/documenten-api-metadata-modal/documenten-api-metadata-modal.component.d.ts +76 -39
  44. package/lib/modules/documenten-api/components/documenten-api-metadata-modal/documenten-api-metadata-modal.component.d.ts.map +1 -1
  45. package/lib/modules/documenten-api/components/documenten-api-tag-modal/documenten-api-tag-modal.component.d.ts +33 -0
  46. package/lib/modules/documenten-api/components/documenten-api-tag-modal/documenten-api-tag-modal.component.d.ts.map +1 -0
  47. package/lib/modules/documenten-api/components/documenten-api-tags/documenten-api-tags.component.d.ts +46 -0
  48. package/lib/modules/documenten-api/components/documenten-api-tags/documenten-api-tags.component.d.ts.map +1 -0
  49. package/lib/modules/documenten-api/components/index.d.ts +4 -1
  50. package/lib/modules/documenten-api/components/index.d.ts.map +1 -1
  51. package/lib/modules/documenten-api/models/configured-column.model.d.ts +8 -2
  52. package/lib/modules/documenten-api/models/configured-column.model.d.ts.map +1 -1
  53. package/lib/modules/documenten-api/models/documenten-api-filter.model.d.ts +10 -0
  54. package/lib/modules/documenten-api/models/documenten-api-filter.model.d.ts.map +1 -0
  55. package/lib/modules/documenten-api/models/documenten-api-metadata.model.d.ts +10 -9
  56. package/lib/modules/documenten-api/models/documenten-api-metadata.model.d.ts.map +1 -1
  57. package/lib/modules/documenten-api/models/documenten-api-tag.model.d.ts +5 -0
  58. package/lib/modules/documenten-api/models/documenten-api-tag.model.d.ts.map +1 -0
  59. package/lib/modules/documenten-api/models/documenten-api-version.model.d.ts +7 -1
  60. package/lib/modules/documenten-api/models/documenten-api-version.model.d.ts.map +1 -1
  61. package/lib/modules/documenten-api/models/documenten-api.model.d.ts +37 -12
  62. package/lib/modules/documenten-api/models/documenten-api.model.d.ts.map +1 -1
  63. package/lib/modules/documenten-api/models/index.d.ts +1 -0
  64. package/lib/modules/documenten-api/models/index.d.ts.map +1 -1
  65. package/lib/modules/documenten-api/services/documenten-api-column.service.d.ts +3 -2
  66. package/lib/modules/documenten-api/services/documenten-api-column.service.d.ts.map +1 -1
  67. package/lib/modules/documenten-api/services/documenten-api-document.service.d.ts +3 -2
  68. package/lib/modules/documenten-api/services/documenten-api-document.service.d.ts.map +1 -1
  69. package/lib/modules/documenten-api/services/documenten-api-link-process.service.d.ts.map +1 -1
  70. package/lib/modules/documenten-api/services/documenten-api-tag.service.d.ts +17 -0
  71. package/lib/modules/documenten-api/services/documenten-api-tag.service.d.ts.map +1 -0
  72. package/lib/modules/documenten-api/services/documenten-api-version.service.d.ts +2 -1
  73. package/lib/modules/documenten-api/services/documenten-api-version.service.d.ts.map +1 -1
  74. package/lib/modules/documenten-api/services/index.d.ts +2 -1
  75. package/lib/modules/documenten-api/services/index.d.ts.map +1 -1
  76. package/lib/modules/zaakdetails/components/document-objecten-api-sync/document-objecten-api-sync.component.d.ts.map +1 -1
  77. package/lib/services/dossier-management-zgw.service.d.ts +2 -0
  78. package/lib/services/dossier-management-zgw.service.d.ts.map +1 -1
  79. package/lib/zgw.module.d.ts.map +1 -1
  80. 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 { BehaviorSubject, combineLatest, map, Subscription, switchMap, take, tap, } from 'rxjs';
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 { CommonModule } from '@angular/common';
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 "carbon-components-angular";
28
- import * as i3 from "@valtimo/document";
29
- import * as i4 from "@ngx-translate/core";
30
- import * as i5 from "@angular/common";
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.next(value);
34
- if (value === 'closed') {
35
- setTimeout(() => {
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
- set prefill(value) {
44
- this._prefillStatus.next(value);
48
+ get type() {
49
+ return this._type;
45
50
  }
46
- get visibleInCaseListByDefault() {
47
- return this.statusFormGroup?.get('visibleInCaseListByDefault');
51
+ set availableColumns(value) {
52
+ if (!value)
53
+ return;
54
+ this._availableColumns$.next(value);
48
55
  }
49
- get key() {
50
- return this.statusFormGroup?.get('key');
56
+ set configuredColumns(value) {
57
+ if (!value)
58
+ return;
59
+ this._defaultSortedColumn = value.find((column) => !!column.defaultSort);
51
60
  }
52
- get title() {
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.closeModalEvent = new EventEmitter();
70
- this._type = new BehaviorSubject(undefined);
71
- this._typeAnimationDelay$ = new BehaviorSubject(undefined);
72
- this._prefillStatus = new BehaviorSubject(undefined);
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(([selectedColor]) => this.COLORS.map(color => ({
108
- selected: color === selectedColor,
109
- content: this.translateService.instant('interface.tagType.' +
110
- InternalCaseStatusUtils.getTagTypeFromInternalCaseStatusColor(color)),
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._editingKey$ = new BehaviorSubject(false);
115
- this.editingKey$ = this._editingKey$.pipe(tap(editing => {
116
- if (editing) {
117
- this.key?.enable();
118
- }
119
- else {
120
- this.key?.disable();
121
- }
122
- }));
123
- this._originalStatusKey$ = new BehaviorSubject('');
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.openAutoKeySubscription();
94
+ this.openDisableRadioSubscription();
129
95
  }
130
96
  ngOnDestroy() {
131
97
  this._subscriptions.unsubscribe();
132
98
  }
133
- onClose() {
134
- this.close();
135
- }
136
- toggleCheckedChange(checked) {
137
- this.statusFormGroup.patchValue({
138
- visibleInCaseListByDefault: checked,
139
- });
140
- this.statusFormGroup.markAsDirty();
141
- }
142
- addStatus() {
143
- this.disable();
144
- this.caseStatusService
145
- .saveInternalCaseStatus(this.documentDefinitionName, this.getFormValue())
146
- .subscribe({
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
- prefillForm(prefillStatus) {
182
- this._originalStatusKey$.next(prefillStatus.key);
183
- this.statusFormGroup.patchValue({
184
- key: prefillStatus.key,
185
- title: prefillStatus.title,
186
- visibleInCaseListByDefault: prefillStatus.visibleInCaseListByDefault,
187
- color: prefillStatus.color,
188
- });
189
- this._selectedColor$.next(prefillStatus.color);
190
- this.statusFormGroup.markAsPristine();
191
- this.resetEditingKey();
192
- }
193
- resetForm() {
194
- this.statusFormGroup.patchValue({
195
- key: '',
196
- title: '',
197
- visibleInCaseListByDefault: true,
198
- color: InternalCaseStatusColor.Blue,
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
- openAutoKeySubscription() {
208
- this._subscriptions.add(combineLatest([this.isAdd$, this.title.valueChanges, this.editingKey$]).subscribe(([isAdd, titleValue, editingKey]) => {
209
- if (isAdd && !editingKey) {
210
- if (titleValue) {
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
- getUniqueKey(title) {
220
- const dashCaseKey = `${title}`
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
- ToggleModule,
289
- ], 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"] }]
290
- }], ctorParameters: () => [{ type: i1.FormBuilder }, { type: i2.IconService }, { type: i3.CaseStatusService }, { type: i4.TranslateService }], propDecorators: { type: [{
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
- }], prefill: [{
165
+ }], type: [{
293
166
  type: Input
294
- }], usedKeys: [{
167
+ }], availableColumns: [{
295
168
  type: Input
296
- }], documentDefinitionName: [{
169
+ }], configuredColumns: [{
297
170
  type: Input
298
- }], closeModalEvent: [{
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":"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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 */\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"]}