@valtimo/zgw 12.0.0 → 12.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (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,29 +13,71 @@
13
13
  * See the License for the specific language governing permissions and
14
14
  * limitations under the License.
15
15
  */
16
- import { Component, EventEmitter, Input, Output, ViewChild } from '@angular/core';
17
- import { BehaviorSubject, combineLatest, filter, from, map, of, Subject, switchMap, take, } from 'rxjs';
16
+ import { Component, EventEmitter, Input, Output } from '@angular/core';
17
+ import { BehaviorSubject, combineLatest, filter, from, map, of, startWith, Subject, Subscription, switchMap, take, } from 'rxjs';
18
18
  import { TranslateModule } from '@ngx-translate/core';
19
19
  import { tap } from 'rxjs/operators';
20
20
  import { CommonModule } from '@angular/common';
21
- import { ButtonModule, DatePickerModule, FormModule, InputLabelModule, InputModule, SelectModule, TitleModule, VModalModule, } from '@valtimo/components';
21
+ import { ReactiveFormsModule, Validators, } from '@angular/forms';
22
+ import { InputLabelModule, InputModule, SelectModule, } from '@valtimo/components';
23
+ import { ButtonModule, ComboBoxModule, DatePickerModule, DropdownModule, IconModule, InputModule as CarbonInputModule, ModalModule, RadioModule, TagModule, TooltipModule, } from 'carbon-components-angular';
22
24
  import * as i0 from "@angular/core";
23
- import * as i1 from "@valtimo/components";
24
- import * as i2 from "@ngx-translate/core";
25
- import * as i3 from "@angular/router";
26
- import * as i4 from "@valtimo/document";
27
- import * as i5 from "keycloak-angular";
28
- import * as i6 from "@angular/common";
25
+ import * as i1 from "@angular/router";
26
+ import * as i2 from "@valtimo/document";
27
+ import * as i3 from "../../services";
28
+ import * as i4 from "../../services/documenten-api-tag.service";
29
+ import * as i5 from "@angular/forms";
30
+ import * as i6 from "keycloak-angular";
31
+ import * as i7 from "@valtimo/components";
32
+ import * as i8 from "@ngx-translate/core";
33
+ import * as i9 from "carbon-components-angular";
34
+ import * as i10 from "@angular/common";
29
35
  export class DocumentenApiMetadataModalComponent {
30
- constructor(modalService, translateService, route, documentService, keycloakService, valtimoModalService) {
31
- this.modalService = modalService;
32
- this.translateService = translateService;
36
+ get confidentialityLevelFormControl() {
37
+ return this.documentenApiMetadataForm.get('vertrouwelijkheidaanduiding');
38
+ }
39
+ get informatieobjecttypeFormControl() {
40
+ return this.documentenApiMetadataForm.get('informatieobjecttype');
41
+ }
42
+ get languageFormControl() {
43
+ return this.documentenApiMetadataForm.get('taal');
44
+ }
45
+ get statusFormControl() {
46
+ return this.documentenApiMetadataForm.get('status');
47
+ }
48
+ get tagFormControl() {
49
+ return this.documentenApiMetadataForm.get('trefwoorden');
50
+ }
51
+ constructor(route, documentService, documentenApiDocumentService, documentenApiTagService, fb, keycloakService, modalService, translateService, valtimoModalService) {
33
52
  this.route = route;
34
53
  this.documentService = documentService;
54
+ this.documentenApiDocumentService = documentenApiDocumentService;
55
+ this.documentenApiTagService = documentenApiTagService;
56
+ this.fb = fb;
35
57
  this.keycloakService = keycloakService;
58
+ this.modalService = modalService;
59
+ this.translateService = translateService;
36
60
  this.valtimoModalService = valtimoModalService;
37
61
  this.documentTitle = '';
62
+ this.open = false;
63
+ this.supportsTrefwoorden = false;
38
64
  this.metadata = new EventEmitter();
65
+ this.modalClose = new EventEmitter();
66
+ this.documentenApiMetadataForm = this.fb.group({
67
+ bestandsnaam: this.fb.control('', Validators.required),
68
+ titel: this.fb.control('', Validators.required),
69
+ auteur: this.fb.control('', Validators.required),
70
+ beschrijving: this.fb.control('', Validators.required),
71
+ taal: this.fb.control('', Validators.required),
72
+ informatieobjecttype: this.fb.control('', Validators.required),
73
+ status: this.fb.control('', Validators.required),
74
+ vertrouwelijkheidaanduiding: this.fb.control('', Validators.required),
75
+ creatiedatum: this.fb.control('', Validators.required),
76
+ ontvangstdatum: this.fb.control(''),
77
+ verzenddatum: this.fb.control(''),
78
+ trefwoorden: this.fb.control([]),
79
+ });
80
+ this.isDefinitiveStatus$ = new BehaviorSubject(false);
39
81
  this.CONFIDENTIALITY_LEVELS = [
40
82
  'openbaar',
41
83
  'beperkt_openbaar',
@@ -46,11 +88,13 @@ export class DocumentenApiMetadataModalComponent {
46
88
  'geheim',
47
89
  'zeer_geheim',
48
90
  ];
49
- this.confidentialityLevelItems$ = this.translateService
50
- .stream('key')
51
- .pipe(map(() => this.CONFIDENTIALITY_LEVELS.map(confidentialityLevel => ({
91
+ this.confidentialityLevelItems$ = combineLatest([
92
+ this.confidentialityLevelFormControl.valueChanges.pipe(startWith(this.confidentialityLevelFormControl.value)),
93
+ this.translateService.stream('key'),
94
+ ]).pipe(map(([currentConfidentialityLevel]) => this.CONFIDENTIALITY_LEVELS.map(confidentialityLevel => ({
52
95
  id: confidentialityLevel,
53
- text: this.translateService.instant(`document.${confidentialityLevel}`),
96
+ content: this.translateService.instant(`document.${confidentialityLevel}`),
97
+ selected: currentConfidentialityLevel === confidentialityLevel,
54
98
  }))));
55
99
  this.ADDITONAL_DOCUMENT_DATE_OPTIONS = [
56
100
  {
@@ -78,156 +122,250 @@ export class DocumentenApiMetadataModalComponent {
78
122
  this.formData$ = new BehaviorSubject(null);
79
123
  this.statusItems$ = combineLatest([
80
124
  this.additionalDocumentDate$,
125
+ this.statusFormControl.valueChanges.pipe(startWith(this.statusFormControl.value)),
81
126
  this.translateService.stream('key'),
82
- ]).pipe(tap(([additionalDocumentDate]) => {
127
+ ]).pipe(tap(([additionalDocumentDate, currentStatus]) => {
83
128
  this.formData$.pipe(take(1)).subscribe(formData => {
84
129
  if (additionalDocumentDate === 'received' &&
85
130
  (formData.status === 'in_bewerking' || formData.status === 'ter_vaststelling')) {
86
131
  this.clearStatusSelection$.next(null);
87
132
  }
88
133
  });
89
- }), map(([additionalDocumentDate]) => (additionalDocumentDate === 'received' ? this.RECEIPT_STATUSES : this.STATUSES).map(status => ({
134
+ }), map(([additionalDocumentDate, currentStatus]) => (additionalDocumentDate === 'received' ? this.RECEIPT_STATUSES : this.STATUSES).map(status => ({
90
135
  id: status,
91
- text: this.translateService.instant(`document.${status}`),
136
+ content: this.translateService.instant(`document.${status}`),
137
+ selected: currentStatus === status,
92
138
  }))));
93
- this.LANGUAGES = ['nld', 'eng', 'deu'];
94
- this.languageItems$ = this.translateService.stream('key').pipe(map(() => this.LANGUAGES.map(language => ({
95
- id: language,
96
- text: this.translateService.instant(`document.${language}`),
139
+ this.documentDefinitionName$ = from(this.route.params.pipe(map(params => params?.documentDefinitionName)));
140
+ this.tagItems$ = combineLatest([
141
+ this.documentDefinitionName$,
142
+ this.tagFormControl.valueChanges.pipe(startWith(this.tagFormControl.value)),
143
+ ]).pipe(filter(([documentDefinitionName]) => !!documentDefinitionName), switchMap(([documentDefinitionName, tagFormControlValue]) => combineLatest([
144
+ this.documentenApiTagService.getTags(documentDefinitionName),
145
+ of(tagFormControlValue),
146
+ ])), map(([tags, tagFormControlValue]) => tags.map(tag => ({
147
+ id: tag.value,
148
+ content: tag.value,
149
+ selected: !!tagFormControlValue ? tagFormControlValue.includes(tag.value) : false,
97
150
  }))));
151
+ this.LANGUAGES = ['nld', 'eng', 'deu'];
152
+ this.languageItems$ = combineLatest([
153
+ this.languageFormControl.valueChanges.pipe(startWith(this.languageFormControl.value)),
154
+ this.translateService.stream('key'),
155
+ ]).pipe(map(([currentLanguage]) => {
156
+ return this.LANGUAGES.map((language) => ({
157
+ content: this.translateService.instant(`document.${language}`),
158
+ id: language,
159
+ selected: currentLanguage === language,
160
+ }));
161
+ }));
98
162
  this.documentTypeItems$ = combineLatest([
99
163
  this.route?.params || of(null),
100
164
  this.route?.firstChild?.params || of(null),
101
165
  this.valtimoModalService.documentDefinitionName$,
166
+ this.informatieobjecttypeFormControl.valueChanges.pipe(startWith(this.informatieobjecttypeFormControl.value)),
102
167
  ]).pipe(filter(([params, firstChildParams, documentDefinitionName]) => !!(params?.documentDefinitionName ||
103
168
  firstChildParams?.documentDefinitionName ||
104
- documentDefinitionName)), switchMap(([params, firstChildParams, documentDefinitionName]) => this.documentService.getDocumentTypes(params?.documentDefinitionName ||
105
- firstChildParams?.documentDefinitionName ||
106
- documentDefinitionName)), map(documentTypes => documentTypes.map(type => ({ id: type.url, text: type.name }))));
107
- this.showForm$ = this.modalService.modalVisible$;
108
- this.valid$ = new BehaviorSubject(false);
169
+ documentDefinitionName)), switchMap(([params, firstChildParams, documentDefinitionName, informatieobjecttypeValue]) => combineLatest([
170
+ this.documentService.getDocumentTypes(params?.documentDefinitionName ||
171
+ firstChildParams?.documentDefinitionName ||
172
+ documentDefinitionName),
173
+ of(informatieobjecttypeValue),
174
+ ])), map(([documentTypes, informatieobjecttypeValue]) => documentTypes.map((type) => ({
175
+ id: type.url,
176
+ content: type.name,
177
+ selected: informatieobjecttypeValue === type.url,
178
+ }))));
109
179
  this.userEmail$ = from(this.keycloakService.loadUserProfile()).pipe(map(userProfile => userProfile?.email || ''));
180
+ this.modalSize = 'lg';
181
+ this._subscriptions = new Subscription();
110
182
  }
111
183
  ngOnInit() {
112
- this.openShowSubscription();
113
- this.openHideSubscription();
184
+ this.openFileSubscription();
185
+ }
186
+ ngOnChanges() {
187
+ this.openFileSubscription();
114
188
  }
115
189
  ngOnDestroy() {
116
- this.showSubscription?.unsubscribe();
117
- this.hideSubscription?.unsubscribe();
190
+ this._subscriptions.unsubscribe();
191
+ this.isDefinitiveStatus$.next(false);
118
192
  }
119
- hide() {
120
- this.formData$.next(null);
121
- this.valid$.next(false);
122
- this.additionalDocumentDate$.next('neither');
123
- this.modalService.closeModal();
193
+ languageSelected(event) {
194
+ if (event.item.id) {
195
+ this.documentenApiMetadataForm.patchValue({
196
+ taal: event.item.id,
197
+ });
198
+ }
124
199
  }
125
- cancel() {
126
- this.hide();
200
+ tagsSelected(event) {
201
+ this.tagFormControl.patchValue(event.filter(tag => tag.selected).map(tag => tag.id));
202
+ }
203
+ confidentialityLevelSelected(event) {
204
+ if (event.item.id) {
205
+ this.documentenApiMetadataForm.patchValue({
206
+ vertrouwelijkheidaanduiding: event.item.id,
207
+ });
208
+ }
209
+ }
210
+ statusSelected(event) {
211
+ if (event.item.id) {
212
+ this.documentenApiMetadataForm.patchValue({
213
+ status: event.item.id,
214
+ });
215
+ }
216
+ }
217
+ informatieobjecttypeSelected(event) {
218
+ if (event.item.id) {
219
+ this.documentenApiMetadataForm.patchValue({
220
+ informatieobjecttype: event.item.id,
221
+ });
222
+ }
223
+ }
224
+ prefillForm(file) {
225
+ this.prefillFilenameAndAuthor();
226
+ if (file) {
227
+ const { bestandsnaam, titel, auteur, beschrijving, taal, informatieobjecttype, status, vertrouwelijkheidaanduiding, creatiedatum, ontvangstdatum, verzenddatum, trefwoorden, } = file;
228
+ if (verzenddatum)
229
+ this.additionalDocumentDate$.next('sent');
230
+ else if (ontvangstdatum)
231
+ this.additionalDocumentDate$.next('received');
232
+ else
233
+ this.additionalDocumentDate$.next('neither');
234
+ this.documentenApiMetadataForm.patchValue({
235
+ bestandsnaam,
236
+ titel,
237
+ auteur,
238
+ beschrijving,
239
+ taal,
240
+ informatieobjecttype,
241
+ status,
242
+ vertrouwelijkheidaanduiding,
243
+ creatiedatum,
244
+ ontvangstdatum,
245
+ verzenddatum,
246
+ trefwoorden,
247
+ });
248
+ }
127
249
  }
128
250
  save() {
129
- combineLatest([this.valid$, this.formData$])
130
- .pipe(take(1))
131
- .subscribe(([valid, formData]) => {
132
- if (valid) {
133
- this.metadata.emit(formData);
134
- }
135
- });
251
+ this.formatDate('creatiedatum');
252
+ this.formatDate('verzenddatum');
253
+ this.formatDate('ontvangstdatum');
254
+ if (this.documentenApiMetadataForm.valid)
255
+ this.metadata.emit(this.documentenApiMetadataForm.value);
256
+ this.closeModal();
136
257
  }
137
- formValueChange(data) {
138
- this.formData$.next(data);
139
- this.setValid(data);
258
+ closeModal() {
259
+ this.additionalDocumentDate$.next('neither');
260
+ this.modalClose.emit();
261
+ this.clearForm();
140
262
  }
141
- setAdditionalDate(value) {
142
- this.additionalDocumentDate$.next(value);
263
+ clearForm() {
264
+ this.documentenApiMetadataForm.reset();
143
265
  }
144
- setValid(data) {
145
- this.valid$.next(!!(data.filename &&
146
- data.title &&
147
- data.author &&
148
- data.creationDate &&
149
- data.status &&
150
- data.language &&
151
- data.informatieobjecttype &&
152
- data.description &&
153
- data.confidentialityLevel));
154
- }
155
- openShowSubscription() {
156
- this.showSubscription = this.show$.subscribe(() => {
157
- this.modalService.openModal(this.documentenApiMetadataModal);
158
- });
266
+ prefillFilenameAndAuthor() {
267
+ this._subscriptions.add(combineLatest([this.file$, this.userEmail$])
268
+ .pipe(tap(([file, userEmail]) => {
269
+ this.documentenApiMetadataForm.patchValue({
270
+ bestandsnaam: file?.name || file?.bestandsnaam,
271
+ auteur: userEmail,
272
+ });
273
+ }))
274
+ .subscribe());
159
275
  }
160
- openHideSubscription() {
161
- this.hideSubscription = this.hide$.subscribe(() => {
162
- this.hide();
163
- });
276
+ formatDate(controlName) {
277
+ const control = this.documentenApiMetadataForm.controls[controlName];
278
+ if (control.value) {
279
+ const date = new Date(control.value);
280
+ this.documentenApiMetadataForm.patchValue({
281
+ [controlName]: `${date.getFullYear()}-${(date.getMonth() + 1).toString().padStart(2, '0')}-${date.getDate().toString().padStart(2, '0')}`,
282
+ });
283
+ }
284
+ }
285
+ openFileSubscription() {
286
+ this._fileSubscription?.unsubscribe();
287
+ if (this.file$) {
288
+ this._fileSubscription = this.file$.subscribe(file => {
289
+ if (file) {
290
+ this.prefillForm(file);
291
+ this.isDefinitiveStatus$.next(file.status === 'definitief' && this.isEditMode ? true : false);
292
+ }
293
+ });
294
+ }
164
295
  }
165
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.3", ngImport: i0, type: DocumentenApiMetadataModalComponent, deps: [{ token: i1.ModalService }, { token: i2.TranslateService }, { token: i3.ActivatedRoute }, { token: i4.DocumentService }, { token: i5.KeycloakService }, { token: i1.ValtimoModalService }], target: i0.ɵɵFactoryTarget.Component }); }
166
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.3", type: DocumentenApiMetadataModalComponent, isStandalone: true, selector: "valtimo-documenten-api-metadata-modal", inputs: { show$: "show$", hide$: "hide$", disabled$: "disabled$", file$: "file$", documentTitle: "documentTitle", disableDocumentTitle: "disableDocumentTitle", filename: "filename", disableFilename: "disableFilename", author: "author", disableAuthor: "disableAuthor", status: "status", disableStatus: "disableStatus", language: "language", disableLanguage: "disableLanguage", documentType: "documentType", disableDocumentType: "disableDocumentType", description: "description", disableDescription: "disableDescription", confidentialityLevel: "confidentialityLevel", disableConfidentialityLevel: "disableConfidentialityLevel", trefwoorden: "trefwoorden", disableTrefwoorden: "disableTrefwoorden" }, outputs: { metadata: "metadata" }, viewQueries: [{ propertyName: "documentenApiMetadataModal", first: true, predicate: ["documentenApiMetadataModal"], descendants: true }], 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<v-modal\n #documentenApiMetadataModal\n (closeEvent)=\"hide()\"\n *ngIf=\"{file: file$ | async, disabled: disabled$ | async, valid: valid$ | async} as obs\"\n>\n <div role=\"header\">\n <div class=\"edit-configuration-title\">\n <v-title [center]=\"true\" [fullWidth]=\"true\" [margin]=\"false\" type=\"h2\">{{\n 'document.fillInMetadata' | translate\n }}</v-title>\n </div>\n </div>\n <div role=\"content\">\n <ng-container *ngTemplateOutlet=\"metadataForm; context: {obs: obs}\"></ng-container>\n </div>\n <div role=\"footer\">\n <div class=\"buttons\">\n <v-button (clickEvent)=\"cancel()\" [disabled]=\"obs.disabled\" type=\"secondary\">{{\n 'document.cancel' | translate\n }}</v-button>\n <v-button\n (clickEvent)=\"save()\"\n [disabled]=\"obs.disabled || !obs.valid\"\n mdiIcon=\"upload\"\n type=\"success\"\n >{{ 'document.upload' | translate }}</v-button\n >\n </div>\n </div>\n</v-modal>\n\n<ng-template #metadataForm let-obs=\"obs\">\n <ng-container *ngIf=\"showForm$ | async\">\n <v-form\n (valueChange)=\"formValueChange($event)\"\n *ngIf=\"additionalDocumentDate$ | async as additionalDate\"\n >\n <v-input\n [defaultValue]=\"filename || obs.file?.name\"\n [disabled]=\"obs.disabled || disableFilename\"\n [fullWidth]=\"true\"\n [margin]=\"true\"\n [required]=\"true\"\n [title]=\"'document.filename' | translate\"\n [tooltip]=\"'document.filenameTooltip' | translate\"\n name=\"filename\"\n >\n </v-input>\n <v-input\n [defaultValue]=\"documentTitle\"\n [disabled]=\"obs.disabled || disableDocumentTitle\"\n [margin]=\"true\"\n [required]=\"true\"\n [title]=\"'document.inputTitle' | translate\"\n [tooltip]=\"'document.inputTitleTooltip' | translate\"\n [widthPx]=\"400\"\n name=\"title\"\n >\n </v-input>\n <v-input\n [defaultValue]=\"author || (userEmail$ | async)\"\n [disabled]=\"obs.disabled || disableAuthor\"\n [margin]=\"true\"\n [required]=\"true\"\n [title]=\"'document.author' | translate\"\n [tooltip]=\"'document.authorTooltip' | translate\"\n [widthPx]=\"300\"\n name=\"author\"\n >\n </v-input>\n <v-select\n *ngIf=\"languageItems$ | async as languageItems\"\n [defaultSelectionId]=\"language || languageItems[0].id\"\n [disabled]=\"obs.disabled || disableLanguage\"\n [items]=\"languageItems\"\n [margin]=\"true\"\n [required]=\"true\"\n [title]=\"'document.language' | translate\"\n [tooltip]=\"'document.languageTooltip' | translate\"\n [widthInPx]=\"200\"\n name=\"language\"\n ></v-select>\n <ng-container *ngIf=\"{documentTypeItems: documentTypeItems$ | async} as obs\">\n <v-select\n [defaultSelectionId]=\"documentType\"\n [disabled]=\"obs.disabled || disableDocumentType\"\n [items]=\"obs.documentTypeItems\"\n [loading]=\"!obs.documentTypeItems\"\n [margin]=\"true\"\n [required]=\"true\"\n [title]=\"'document.informatieobjecttype' | translate\"\n [tooltip]=\"'document.informatieobjecttypeTooltip' | translate\"\n [widthInPx]=\"200\"\n name=\"informatieobjecttype\"\n ></v-select>\n </ng-container>\n <v-date-picker\n [defaultDateIsToday]=\"true\"\n [disabled]=\"obs.disabled\"\n [margin]=\"true\"\n [required]=\"true\"\n [title]=\"'document.creationDate' | translate\"\n [tooltip]=\"'document.creationDateTooltip' | translate\"\n [widthPx]=\"100\"\n name=\"creationDate\"\n ></v-date-picker>\n <ng-container\n *ngTemplateOutlet=\"additionalDatePicker; context: {additionalDate: additionalDate}\"\n ></ng-container>\n <v-date-picker\n *ngIf=\"additionalDate === 'received'\"\n [defaultDateIsToday]=\"true\"\n [disabled]=\"obs.disabled\"\n [margin]=\"true\"\n [title]=\"'document.receiptDate' | translate\"\n [tooltip]=\"'document.receiptDateTooltip' | translate\"\n [widthPx]=\"100\"\n name=\"receiptDate\"\n ></v-date-picker>\n <v-date-picker\n *ngIf=\"additionalDate === 'sent'\"\n [defaultDateIsToday]=\"true\"\n [disabled]=\"obs.disabled\"\n [margin]=\"true\"\n [title]=\"'document.sendDate' | translate\"\n [tooltip]=\"'document.sendDateTooltip' | translate\"\n [widthPx]=\"100\"\n name=\"sendDate\"\n ></v-date-picker>\n <v-select\n [defaultSelectionId]=\"status\"\n [disabled]=\"obs.disabled || disableStatus\"\n [items]=\"statusItems$ | async\"\n [margin]=\"true\"\n [required]=\"true\"\n [title]=\"'document.status' | translate\"\n [tooltip]=\"'document.statusTooltip' | translate\"\n [widthInPx]=\"200\"\n [clearSelectionSubject$]=\"clearStatusSelection$\"\n name=\"status\"\n ></v-select>\n <v-input\n [defaultValue]=\"description\"\n [disabled]=\"obs.disabled || disableDescription\"\n [fullWidth]=\"true\"\n [margin]=\"true\"\n [title]=\"'document.inputDescription' | translate\"\n [tooltip]=\"'document.inputDescriptionTooltip' | translate\"\n [required]=\"true\"\n name=\"description\"\n >\n </v-input>\n <v-select\n [defaultSelectionId]=\"confidentialityLevel\"\n [disabled]=\"obs.disabled || disableConfidentialityLevel\"\n [items]=\"confidentialityLevelItems$ | async\"\n [margin]=\"true\"\n [title]=\"'document.confidentialityLevel' | translate\"\n [tooltip]=\"'document.confidentialityLevelTooltip' | translate\"\n [widthInPx]=\"200\"\n [required]=\"true\"\n name=\"confidentialityLevel\"\n ></v-select>\n </v-form>\n </ng-container>\n</ng-template>\n\n<ng-template #additionalDatePicker let-additionalDate=\"additionalDate\">\n <v-input-label\n [title]=\"'document.additionalDate' | translate\"\n [name]=\"'additionalDate'\"\n [tooltip]=\"'document.additionalDateTooltip' | translate\"\n [required]=\"true\"\n >\n </v-input-label>\n <div class=\"col-12 col-sm-8 col-lg-6 form-check mt-1 additional-date\">\n <label\n class=\"custom-control custom-radio custom-control-inline\"\n *ngFor=\"let option of ADDITONAL_DOCUMENT_DATE_OPTIONS\"\n (click)=\"setAdditionalDate(option.value)\"\n >\n <input\n class=\"custom-control-input\"\n type=\"radio\"\n name=\"radio-inline\"\n [checked]=\"additionalDate === option.value\"\n /><span class=\"custom-control-label\">{{ option.translationKey | translate }}</span>\n </label>\n </div>\n</ng-template>\n", styles: [".buttons{display:flex;flex-direction:row;width:100%;justify-content:space-between}.additional-date{padding:0;width:100%;max-width:100%;margin:0;margin-block-end:var(--v-input-margin)}.additional-date .custom-control{margin-bottom:0}\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: i6.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i6.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "pipe", type: i6.AsyncPipe, name: "async" }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i2.TranslatePipe, name: "translate" }, { kind: "ngmodule", type: VModalModule }, { kind: "component", type: i1.VModalComponent, selector: "v-modal", inputs: ["appearingDelayMs", "maxWidthPx", "hideFooter"], outputs: ["closeEvent"] }, { kind: "ngmodule", type: TitleModule }, { kind: "component", type: i1.TitleComponent, selector: "v-title", inputs: ["type", "margin", "fullWidth", "center"] }, { kind: "ngmodule", type: ButtonModule }, { kind: "component", type: i1.ButtonComponent, selector: "v-button", inputs: ["type", "mdiIcon", "disabled", "title", "titleTranslationKey"], outputs: ["clickEvent"] }, { kind: "ngmodule", type: FormModule }, { kind: "component", type: i1.FormComponent, selector: "v-form", inputs: ["className"], outputs: ["valueChange"] }, { kind: "ngmodule", type: InputModule }, { kind: "component", type: i1.InputComponent, selector: "v-input", inputs: ["name", "type", "title", "titleTranslationKey", "defaultValue", "widthPx", "fullWidth", "margin", "smallMargin", "disabled", "step", "min", "maxLength", "tooltip", "required", "hideNumberSpinBox", "smallLabel", "rows", "clear$", "carbonTheme", "placeholder"], outputs: ["valueChange"] }, { kind: "ngmodule", type: SelectModule }, { kind: "component", type: i1.SelectComponent, selector: "v-select", inputs: ["items", "defaultSelection", "defaultSelectionId", "defaultSelectionIds", "disabled", "dropUp", "multiple", "margin", "widthInPx", "notFoundText", "clearAllText", "clearText", "name", "title", "titleTranslationKey", "clearSelectionSubject$", "tooltip", "required", "loading", "loadingText", "placeholder", "smallMargin", "carbonTheme", "appendInline"], outputs: ["selectedChange"] }, { kind: "ngmodule", type: DatePickerModule }, { kind: "component", type: i1.DatePickerComponent, selector: "v-date-picker", inputs: ["name", "title", "titleTranslationKey", "widthPx", "fullWidth", "margin", "disabled", "tooltip", "required", "defaultDate", "defaultDateIsToday", "smallLabel", "clear$", "enableTime", "carbonTheme"], outputs: ["valueChange"] }, { kind: "ngmodule", type: InputLabelModule }, { kind: "component", type: i1.InputLabelComponent, selector: "v-input-label", inputs: ["name", "tooltip", "largeMargin", "small", "title", "titleTranslationKey", "required", "disabled", "carbonTheme"] }] }); }
296
+ setAdditionalDate(value) {
297
+ this.additionalDocumentDate$.next(value);
298
+ }
299
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.3", ngImport: i0, type: DocumentenApiMetadataModalComponent, deps: [{ token: i1.ActivatedRoute }, { token: i2.DocumentService }, { token: i3.DocumentenApiDocumentService }, { token: i4.DocumentenApiTagService }, { token: i5.FormBuilder }, { token: i6.KeycloakService }, { token: i7.ModalService }, { token: i8.TranslateService }, { token: i7.ValtimoModalService }], target: i0.ɵɵFactoryTarget.Component }); }
300
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.3", type: DocumentenApiMetadataModalComponent, isStandalone: true, selector: "valtimo-documenten-api-metadata-modal", inputs: { disabled$: "disabled$", file$: "file$", author: "author", confidentialityLevel: "confidentialityLevel", description: "description", disableAuthor: "disableAuthor", disableConfidentialityLevel: "disableConfidentialityLevel", disableDescription: "disableDescription", disableDocumentTitle: "disableDocumentTitle", disableDocumentType: "disableDocumentType", disableFilename: "disableFilename", disableLanguage: "disableLanguage", disableStatus: "disableStatus", documentTitle: "documentTitle", documentType: "documentType", disableTrefwoorden: "disableTrefwoorden", filename: "filename", isEditMode: "isEditMode", language: "language", open: "open", status: "status", supportsTrefwoorden: "supportsTrefwoorden" }, outputs: { metadata: "metadata", modalClose: "modalClose" }, usesOnChanges: true, 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 #documentenApiMetadataModal\n [open]=\"open\"\n [size]=\"modalSize\"\n *ngIf=\"{\n file: file$ | async,\n disabled: disabled$ | async,\n isDefinitiveStatus: isDefinitiveStatus$ | async,\n languageItems: languageItems$ | async,\n statusItems: statusItems$ | async,\n tagItems: tagItems$ | async,\n userEmail: userEmail$ | async\n } as obs\"\n>\n <cds-modal-header [showCloseButton]=\"true\" (closeSelect)=\"closeModal()\">\n @if (isEditMode) {\n <h3 cdsModalHeaderHeading>\n {{ 'document.editMetadata' | translate }}\n </h3>\n } @else {\n <h3 cdsModalHeaderHeading>\n {{ 'document.fillInMetadata' | translate }}\n </h3>\n }\n </cds-modal-header>\n <section cdsModalContent class=\"cds--modal-content\">\n <ng-container *ngTemplateOutlet=\"metadataForm; context: {obs: obs}\"></ng-container>\n </section>\n <cds-modal-footer>\n <button cdsButton=\"ghost\" (click)=\"closeModal()\" [disabled]=\"obs.disabled\">\n {{ 'document.cancel' | translate }}\n </button>\n <button\n cdsButton=\"primary\"\n type=\"submit\"\n [disabled]=\"obs.disabled || !documentenApiMetadataForm.valid || obs.isDefinitiveStatus\"\n (click)=\"save()\"\n >\n {{ 'document.save' | translate }}\n </button>\n </cds-modal-footer>\n</cds-modal>\n\n<ng-template #metadataForm let-obs=\"obs\">\n <ng-container>\n <form\n *ngIf=\"additionalDocumentDate$ | async as additionalDate\"\n [formGroup]=\"documentenApiMetadataForm\"\n >\n <div class=\"documenten-metadata-form-columns-container\">\n <div class=\"documenten-metadata-form-column\">\n <cds-text-label class=\"documenten-metada-form-input\">\n {{ 'document.filename' | translate }}\n <cds-tooltip\n [isOpen]=\"false\"\n [description]=\"'document.filenameTooltip' | translate\"\n [align]=\"'bottom-left'\"\n >\n <i class=\"mdi mdi-help-circle-outline\"></i>\n </cds-tooltip>\n <input\n [value]=\"filename\"\n [disabled]=\"obs.disabled || disableFilename\"\n [placeholder]=\"'document.filenamePlaceholder' | translate\"\n [required]=\"true\"\n cdsText\n type=\"text\"\n id=\"bestandsnaam\"\n formControlName=\"bestandsnaam\"\n />\n </cds-text-label>\n <cds-text-label class=\"documenten-metada-form-input\">\n {{ 'document.author' | translate }}\n <cds-tooltip\n [isOpen]=\"false\"\n [description]=\"'document.authorTooltip' | translate\"\n [align]=\"'bottom-left'\"\n >\n <i class=\"mdi mdi-help-circle-outline\"></i>\n </cds-tooltip>\n <input\n [value]=\"author\"\n [disabled]=\"obs.disabled || disableAuthor\"\n [placeholder]=\"'document.authorPlaceholder' | translate\"\n [required]=\"true\"\n cdsText\n id=\"auteur\"\n formControlName=\"auteur\"\n />\n </cds-text-label>\n <cds-text-label>\n {{ 'document.language' | translate }}\n <cds-tooltip\n [isOpen]=\"false\"\n [description]=\"'document.languageTooltip' | translate\"\n [align]=\"'bottom-left'\"\n >\n <i class=\"mdi mdi-help-circle-outline\"></i>\n </cds-tooltip>\n </cds-text-label>\n <div class=\"documenten-metada-form-input\">\n <cds-dropdown\n *ngIf=\"obs.languageItems\"\n [placeholder]=\"'document.languagePlaceholder' | translate\"\n [disabled]=\"obs.disabled || disableLanguage\"\n id=\"language\"\n (selected)=\"languageSelected($event)\"\n >\n <cds-dropdown-list [items]=\"obs.languageItems || []\"></cds-dropdown-list>\n </cds-dropdown>\n </div>\n <cds-label>\n {{ 'document.confidentialityLevel' | translate }}\n <cds-tooltip\n [isOpen]=\"false\"\n [description]=\"'document.confidentialityLevelTooltip' | translate\"\n [align]=\"'bottom-left'\"\n >\n <i class=\"mdi mdi-help-circle-outline\"></i>\n </cds-tooltip>\n </cds-label>\n <div class=\"documenten-metada-form-input\">\n <cds-dropdown\n [placeholder]=\"'document.confidentialityPlaceholder' | translate\"\n [disabled]=\"obs.disabled || disableConfidentialityLevel\"\n id=\"vertrouwelijkheidaanduiding\"\n (selected)=\"confidentialityLevelSelected($event)\"\n >\n <cds-dropdown-list [items]=\"confidentialityLevelItems$ | async\"></cds-dropdown-list>\n </cds-dropdown>\n </div>\n <ng-container *ngIf=\"{documentTypeItems: documentTypeItems$ | async} as obs\">\n <cds-label>\n {{ 'document.informatieobjecttype' | translate }}\n <cds-tooltip\n [isOpen]=\"false\"\n [description]=\"'document.informatieobjecttypeTooltip' | translate\"\n [align]=\"'bottom-left'\"\n >\n <i class=\"mdi mdi-help-circle-outline\"></i>\n </cds-tooltip>\n </cds-label>\n <div class=\"documenten-metada-form-input\">\n <cds-dropdown\n [placeholder]=\"'document.informatieobjecttypePlaceholder' | translate\"\n [disabled]=\"obs.disabled || disableDocumentType\"\n id=\"informatieobjecttype\"\n (selected)=\"informatieobjecttypeSelected($event)\"\n >\n <cds-dropdown-list [items]=\"obs.documentTypeItems || []\"></cds-dropdown-list>\n </cds-dropdown>\n </div>\n </ng-container>\n <cds-text-label name=\"'additionalDate'\">\n {{ 'document.additionalDate' | translate }}\n <cds-tooltip\n [isOpen]=\"false\"\n [description]=\"'document.additionalDateTooltip' | translate\"\n [align]=\"'bottom-left'\"\n >\n <i class=\"mdi mdi-help-circle-outline\"></i>\n </cds-tooltip>\n </cds-text-label>\n <cds-radio-group [orientation]=\"'horizontal'\" class=\"documenten-metada-form-input\">\n <cds-radio\n *ngFor=\"let option of ADDITONAL_DOCUMENT_DATE_OPTIONS\"\n [value]=\"option.value\"\n [checked]=\"additionalDate === option.value\"\n [required]=\"true\"\n (click)=\"setAdditionalDate(option.value)\"\n name=\"radio-inline\"\n >\n {{ option.translationKey | translate }}\n </cds-radio>\n </cds-radio-group>\n @if (supportsTrefwoorden) {\n <cds-text-label>\n {{ 'document.tags' | translate }}\n <cds-tooltip\n [isOpen]=\"false\"\n [description]=\"'document.tagsTooltip' | translate\"\n [align]=\"'bottom-left'\"\n >\n <i class=\"mdi mdi-help-circle-outline\"></i>\n </cds-tooltip>\n </cds-text-label>\n <div class=\"documenten-metada-form-input\">\n <cds-combo-box\n [type]=\"'multi'\"\n [placeholder]=\"'document.tagsPlaceholder' | translate\"\n [disabled]=\"obs.disabled || obs.tagItems.length === 0\"\n (selected)=\"tagsSelected($event)\"\n >\n >\n <cds-dropdown-list [items]=\"obs.tagItems || []\"></cds-dropdown-list>\n </cds-combo-box>\n </div>\n }\n </div>\n\n <div class=\"documenten-metadata-form-column\">\n <cds-text-label>\n {{ 'document.inputTitle' | translate }}\n <input\n [disabled]=\"obs.disabled || disableDocumentTitle\"\n [placeholder]=\"'document.inputTitlePlaceholder' | translate\"\n [required]=\"true\"\n cdsText\n class=\"documenten-metada-form-input\"\n id=\"titel\"\n formControlName=\"titel\"\n />\n <cds-tooltip\n [isOpen]=\"false\"\n [description]=\"'document.inputTitleTooltip' | translate\"\n [align]=\"'bottom'\"\n >\n <i class=\"mdi mdi-help-circle-outline\"></i>\n </cds-tooltip>\n </cds-text-label>\n <cds-textarea-label>\n {{ 'document.inputDescription' | translate }}\n <textarea\n [disabled]=\"obs.disabled || disableDescription\"\n [placeholder]=\"'document.inputDescriptionPlaceholder' | translate\"\n [required]=\"true\"\n [rows]=\"5\"\n cdsTextArea\n class=\"documenten-metada-form-description-input documenten-metada-form-input\"\n id=\"beschrijving\"\n formControlName=\"beschrijving\"\n ></textarea>\n <cds-tooltip\n [isOpen]=\"false\"\n [description]=\"'document.inputDescriptionTooltip' | translate\"\n [align]=\"'bottom'\"\n >\n <i class=\"mdi mdi-help-circle-outline\"></i>\n </cds-tooltip>\n </cds-textarea-label>\n <cds-label>\n {{ 'document.creationDate' | translate }}\n <cds-tooltip\n [isOpen]=\"false\"\n [description]=\"'document.creationDateTooltip' | translate\"\n [align]=\"'bottom'\"\n >\n <i class=\"mdi mdi-help-circle-outline\"></i>\n </cds-tooltip>\n <div class=\"documenten-metada-form-input\">\n <cds-date-picker\n [disabled]=\"obs.disabled\"\n [placeholder]=\"'DD-MM-YYYY'\"\n [dateFormat]=\"'d-m-Y'\"\n id=\"creatiedatum\"\n formControlName=\"creatiedatum\"\n >\n </cds-date-picker>\n </div>\n </cds-label>\n <cds-label>\n {{ 'document.status' | translate }}\n <cds-tooltip\n [isOpen]=\"false\"\n [description]=\"'document.statusTooltip' | translate\"\n [align]=\"'bottom'\"\n >\n <i class=\"mdi mdi-help-circle-outline\"></i>\n </cds-tooltip>\n </cds-label>\n <div class=\"documenten-metada-form-input\">\n <cds-dropdown\n [placeholder]=\"'document.statusPlaceholder' | translate\"\n [disabled]=\"obs.disabled || disableStatus\"\n id=\"status\"\n (selected)=\"statusSelected($event)\"\n >\n <cds-dropdown-list [items]=\"obs.statusItems || []\"></cds-dropdown-list>\n </cds-dropdown>\n </div>\n <cds-date-picker\n *ngIf=\"additionalDate === 'received'\"\n [disabled]=\"obs.disabled\"\n [label]=\"'document.additionalDate' | translate\"\n [placeholder]=\"'DD-MM-YYYY'\"\n [dateFormat]=\"'d-m-Y'\"\n id=\"ontvangstdatum\"\n formControlName=\"ontvangstdatum\"\n ></cds-date-picker>\n <cds-date-picker\n *ngIf=\"additionalDate === 'sent'\"\n [disabled]=\"obs.disabled\"\n [label]=\"'document.additionalDate' | translate\"\n [placeholder]=\"'DD-MM-YYYY'\"\n [dateFormat]=\"'d-m-Y'\"\n id=\"verzenddatum\"\n formControlName=\"verzenddatum\"\n ></cds-date-picker>\n </div>\n </div>\n </form>\n </ng-container>\n</ng-template>\n", styles: [".documenten-metadata-form-columns-container{display:flex;justify-content:space-between}.documenten-metadata-form-column{flex:1;margin-right:1rem}.documenten-metada-form-input{margin-bottom:18px!important;width:100%!important}.documenten-metada-form-description-input{width:100%}::ng-deep .cds--date-picker,::ng-deep .cds--date-picker-container,::ng-deep .cds--date-picker__input,::ng-deep .cds--date-picker-input__wrapper,::ng-deep .cds--date-picker-input__wrapper>span{width:100%}::ng-deep .cds--date-picker.cds--date-picker--single .cds--date-picker__input{inline-size:100%}\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: ButtonModule }, { kind: "directive", type: i9.Button, selector: "[cdsButton], [ibmButton]", inputs: ["ibmButton", "cdsButton", "size", "skeleton", "iconOnly", "isExpressive"] }, { kind: "ngmodule", type: CarbonInputModule }, { kind: "component", type: i9.Label, selector: "cds-label, ibm-label", inputs: ["labelInputID", "disabled", "skeleton", "helperText", "invalidText", "invalid", "warn", "warnText", "ariaLabel"] }, { kind: "component", type: i9.TextareaLabelComponent, selector: "cds-textarea-label, ibm-textarea-label", inputs: ["labelInputID", "disabled", "skeleton", "labelTemplate", "textAreaTemplate", "helperText", "invalidText", "invalid", "warn", "warnText", "ariaLabel"] }, { kind: "component", type: i9.TextInputLabelComponent, selector: "cds-text-label, ibm-text-label", inputs: ["labelInputID", "disabled", "skeleton", "labelTemplate", "textInputTemplate", "helperText", "invalidText", "invalid", "warn", "warnText", "ariaLabel"] }, { kind: "directive", type: i9.TextInput, selector: "[cdsText], [ibmText]", inputs: ["theme", "size", "invalid", "warn", "skeleton"] }, { kind: "directive", type: i9.TextArea, selector: "[cdsTextArea], [ibmTextArea]", inputs: ["theme", "invalid", "skeleton"] }, { kind: "ngmodule", type: ComboBoxModule }, { kind: "component", type: i9.ComboBox, selector: "cds-combo-box, ibm-combo-box", inputs: ["placeholder", "openMenuAria", "closeMenuAria", "clearSelectionsTitle", "clearSelectionsAria", "clearSelectionTitle", "clearSelectionAria", "id", "items", "type", "size", "itemValueKey", "label", "helperText", "appendInline", "invalid", "invalidText", "warn", "warnText", "maxLength", "theme", "selectionFeedback", "autocomplete", "dropUp", "disabled"], outputs: ["selected", "submit", "close", "search", "clear"] }, { kind: "component", type: i9.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: i9.DropdownList, selector: "cds-dropdown-list, ibm-dropdown-list", inputs: ["ariaLabel", "items", "listTpl", "type", "showTitles"], outputs: ["select", "scroll", "blurIntent"] }, { kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i10.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i10.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i10.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "pipe", type: i10.AsyncPipe, name: "async" }, { kind: "ngmodule", type: DatePickerModule }, { kind: "component", type: i9.DatePicker, selector: "cds-date-picker, ibm-date-picker", inputs: ["range", "dateFormat", "language", "label", "helperText", "rangeHelperText", "rangeLabel", "placeholder", "ariaLabel", "inputPattern", "id", "value", "theme", "disabled", "invalid", "invalidText", "warn", "warnText", "size", "rangeInvalid", "rangeInvalidText", "rangeWarn", "rangeWarnText", "skeleton", "plugins", "flatpickrOptions"], outputs: ["valueChange", "onClose"] }, { kind: "ngmodule", type: DropdownModule }, { kind: "ngmodule", type: IconModule }, { kind: "ngmodule", type: InputLabelModule }, { kind: "ngmodule", type: InputModule }, { kind: "ngmodule", type: ModalModule }, { kind: "component", type: i9.Modal, selector: "cds-modal, ibm-modal", inputs: ["size", "theme", "ariaLabel", "open", "trigger", "hasScrollingContent"], outputs: ["overlaySelected", "close"] }, { kind: "component", type: i9.ModalHeader, selector: "cds-modal-header, ibm-modal-header", inputs: ["theme", "closeLabel", "showCloseButton"], outputs: ["closeSelect"] }, { kind: "component", type: i9.ModalFooter, selector: "cds-modal-footer, ibm-modal-footer" }, { kind: "directive", type: i9.ModalContent, selector: "[cdsModalContent], [ibmModalContent]", inputs: ["hasForm"] }, { kind: "directive", type: i9.ModalHeaderHeading, selector: "[cdsModalHeaderHeading], [ibmModalHeaderHeading]" }, { kind: "ngmodule", type: RadioModule }, { kind: "component", type: i9.Radio, selector: "cds-radio, ibm-radio", inputs: ["checked", "name", "disabled", "labelPlacement", "ariaLabelledby", "ariaLabel", "required", "value", "skeleton", "id"], outputs: ["change"] }, { kind: "component", type: i9.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: ReactiveFormsModule }, { kind: "directive", type: i5.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i5.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: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i5.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i5.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i5.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i5.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "ngmodule", type: SelectModule }, { kind: "ngmodule", type: TagModule }, { kind: "ngmodule", type: TooltipModule }, { kind: "component", type: i9.Tooltip, selector: "cds-tooltip, ibm-tooltip", inputs: ["id", "enterDelayMs", "leaveDelayMs", "disabled", "description"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i8.TranslatePipe, name: "translate" }] }); }
167
301
  }
168
302
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.3", ngImport: i0, type: DocumentenApiMetadataModalComponent, decorators: [{
169
303
  type: Component,
170
304
  args: [{ selector: 'valtimo-documenten-api-metadata-modal', standalone: true, imports: [
171
- CommonModule,
172
- TranslateModule,
173
- VModalModule,
174
- TitleModule,
175
305
  ButtonModule,
176
- TranslateModule,
177
- FormModule,
178
- InputModule,
179
- SelectModule,
306
+ CarbonInputModule,
307
+ ComboBoxModule,
308
+ CommonModule,
180
309
  DatePickerModule,
310
+ DropdownModule,
311
+ IconModule,
181
312
  InputLabelModule,
182
- ], 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<v-modal\n #documentenApiMetadataModal\n (closeEvent)=\"hide()\"\n *ngIf=\"{file: file$ | async, disabled: disabled$ | async, valid: valid$ | async} as obs\"\n>\n <div role=\"header\">\n <div class=\"edit-configuration-title\">\n <v-title [center]=\"true\" [fullWidth]=\"true\" [margin]=\"false\" type=\"h2\">{{\n 'document.fillInMetadata' | translate\n }}</v-title>\n </div>\n </div>\n <div role=\"content\">\n <ng-container *ngTemplateOutlet=\"metadataForm; context: {obs: obs}\"></ng-container>\n </div>\n <div role=\"footer\">\n <div class=\"buttons\">\n <v-button (clickEvent)=\"cancel()\" [disabled]=\"obs.disabled\" type=\"secondary\">{{\n 'document.cancel' | translate\n }}</v-button>\n <v-button\n (clickEvent)=\"save()\"\n [disabled]=\"obs.disabled || !obs.valid\"\n mdiIcon=\"upload\"\n type=\"success\"\n >{{ 'document.upload' | translate }}</v-button\n >\n </div>\n </div>\n</v-modal>\n\n<ng-template #metadataForm let-obs=\"obs\">\n <ng-container *ngIf=\"showForm$ | async\">\n <v-form\n (valueChange)=\"formValueChange($event)\"\n *ngIf=\"additionalDocumentDate$ | async as additionalDate\"\n >\n <v-input\n [defaultValue]=\"filename || obs.file?.name\"\n [disabled]=\"obs.disabled || disableFilename\"\n [fullWidth]=\"true\"\n [margin]=\"true\"\n [required]=\"true\"\n [title]=\"'document.filename' | translate\"\n [tooltip]=\"'document.filenameTooltip' | translate\"\n name=\"filename\"\n >\n </v-input>\n <v-input\n [defaultValue]=\"documentTitle\"\n [disabled]=\"obs.disabled || disableDocumentTitle\"\n [margin]=\"true\"\n [required]=\"true\"\n [title]=\"'document.inputTitle' | translate\"\n [tooltip]=\"'document.inputTitleTooltip' | translate\"\n [widthPx]=\"400\"\n name=\"title\"\n >\n </v-input>\n <v-input\n [defaultValue]=\"author || (userEmail$ | async)\"\n [disabled]=\"obs.disabled || disableAuthor\"\n [margin]=\"true\"\n [required]=\"true\"\n [title]=\"'document.author' | translate\"\n [tooltip]=\"'document.authorTooltip' | translate\"\n [widthPx]=\"300\"\n name=\"author\"\n >\n </v-input>\n <v-select\n *ngIf=\"languageItems$ | async as languageItems\"\n [defaultSelectionId]=\"language || languageItems[0].id\"\n [disabled]=\"obs.disabled || disableLanguage\"\n [items]=\"languageItems\"\n [margin]=\"true\"\n [required]=\"true\"\n [title]=\"'document.language' | translate\"\n [tooltip]=\"'document.languageTooltip' | translate\"\n [widthInPx]=\"200\"\n name=\"language\"\n ></v-select>\n <ng-container *ngIf=\"{documentTypeItems: documentTypeItems$ | async} as obs\">\n <v-select\n [defaultSelectionId]=\"documentType\"\n [disabled]=\"obs.disabled || disableDocumentType\"\n [items]=\"obs.documentTypeItems\"\n [loading]=\"!obs.documentTypeItems\"\n [margin]=\"true\"\n [required]=\"true\"\n [title]=\"'document.informatieobjecttype' | translate\"\n [tooltip]=\"'document.informatieobjecttypeTooltip' | translate\"\n [widthInPx]=\"200\"\n name=\"informatieobjecttype\"\n ></v-select>\n </ng-container>\n <v-date-picker\n [defaultDateIsToday]=\"true\"\n [disabled]=\"obs.disabled\"\n [margin]=\"true\"\n [required]=\"true\"\n [title]=\"'document.creationDate' | translate\"\n [tooltip]=\"'document.creationDateTooltip' | translate\"\n [widthPx]=\"100\"\n name=\"creationDate\"\n ></v-date-picker>\n <ng-container\n *ngTemplateOutlet=\"additionalDatePicker; context: {additionalDate: additionalDate}\"\n ></ng-container>\n <v-date-picker\n *ngIf=\"additionalDate === 'received'\"\n [defaultDateIsToday]=\"true\"\n [disabled]=\"obs.disabled\"\n [margin]=\"true\"\n [title]=\"'document.receiptDate' | translate\"\n [tooltip]=\"'document.receiptDateTooltip' | translate\"\n [widthPx]=\"100\"\n name=\"receiptDate\"\n ></v-date-picker>\n <v-date-picker\n *ngIf=\"additionalDate === 'sent'\"\n [defaultDateIsToday]=\"true\"\n [disabled]=\"obs.disabled\"\n [margin]=\"true\"\n [title]=\"'document.sendDate' | translate\"\n [tooltip]=\"'document.sendDateTooltip' | translate\"\n [widthPx]=\"100\"\n name=\"sendDate\"\n ></v-date-picker>\n <v-select\n [defaultSelectionId]=\"status\"\n [disabled]=\"obs.disabled || disableStatus\"\n [items]=\"statusItems$ | async\"\n [margin]=\"true\"\n [required]=\"true\"\n [title]=\"'document.status' | translate\"\n [tooltip]=\"'document.statusTooltip' | translate\"\n [widthInPx]=\"200\"\n [clearSelectionSubject$]=\"clearStatusSelection$\"\n name=\"status\"\n ></v-select>\n <v-input\n [defaultValue]=\"description\"\n [disabled]=\"obs.disabled || disableDescription\"\n [fullWidth]=\"true\"\n [margin]=\"true\"\n [title]=\"'document.inputDescription' | translate\"\n [tooltip]=\"'document.inputDescriptionTooltip' | translate\"\n [required]=\"true\"\n name=\"description\"\n >\n </v-input>\n <v-select\n [defaultSelectionId]=\"confidentialityLevel\"\n [disabled]=\"obs.disabled || disableConfidentialityLevel\"\n [items]=\"confidentialityLevelItems$ | async\"\n [margin]=\"true\"\n [title]=\"'document.confidentialityLevel' | translate\"\n [tooltip]=\"'document.confidentialityLevelTooltip' | translate\"\n [widthInPx]=\"200\"\n [required]=\"true\"\n name=\"confidentialityLevel\"\n ></v-select>\n </v-form>\n </ng-container>\n</ng-template>\n\n<ng-template #additionalDatePicker let-additionalDate=\"additionalDate\">\n <v-input-label\n [title]=\"'document.additionalDate' | translate\"\n [name]=\"'additionalDate'\"\n [tooltip]=\"'document.additionalDateTooltip' | translate\"\n [required]=\"true\"\n >\n </v-input-label>\n <div class=\"col-12 col-sm-8 col-lg-6 form-check mt-1 additional-date\">\n <label\n class=\"custom-control custom-radio custom-control-inline\"\n *ngFor=\"let option of ADDITONAL_DOCUMENT_DATE_OPTIONS\"\n (click)=\"setAdditionalDate(option.value)\"\n >\n <input\n class=\"custom-control-input\"\n type=\"radio\"\n name=\"radio-inline\"\n [checked]=\"additionalDate === option.value\"\n /><span class=\"custom-control-label\">{{ option.translationKey | translate }}</span>\n </label>\n </div>\n</ng-template>\n", styles: [".buttons{display:flex;flex-direction:row;width:100%;justify-content:space-between}.additional-date{padding:0;width:100%;max-width:100%;margin:0;margin-block-end:var(--v-input-margin)}.additional-date .custom-control{margin-bottom:0}\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"] }]
183
- }], ctorParameters: () => [{ type: i1.ModalService }, { type: i2.TranslateService }, { type: i3.ActivatedRoute }, { type: i4.DocumentService }, { type: i5.KeycloakService }, { type: i1.ValtimoModalService }], propDecorators: { documentenApiMetadataModal: [{
184
- type: ViewChild,
185
- args: ['documentenApiMetadataModal']
186
- }], show$: [{
187
- type: Input
188
- }], hide$: [{
189
- type: Input
190
- }], disabled$: [{
313
+ InputModule,
314
+ ModalModule,
315
+ RadioModule,
316
+ ReactiveFormsModule,
317
+ SelectModule,
318
+ TagModule,
319
+ TooltipModule,
320
+ TranslateModule,
321
+ ], 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 #documentenApiMetadataModal\n [open]=\"open\"\n [size]=\"modalSize\"\n *ngIf=\"{\n file: file$ | async,\n disabled: disabled$ | async,\n isDefinitiveStatus: isDefinitiveStatus$ | async,\n languageItems: languageItems$ | async,\n statusItems: statusItems$ | async,\n tagItems: tagItems$ | async,\n userEmail: userEmail$ | async\n } as obs\"\n>\n <cds-modal-header [showCloseButton]=\"true\" (closeSelect)=\"closeModal()\">\n @if (isEditMode) {\n <h3 cdsModalHeaderHeading>\n {{ 'document.editMetadata' | translate }}\n </h3>\n } @else {\n <h3 cdsModalHeaderHeading>\n {{ 'document.fillInMetadata' | translate }}\n </h3>\n }\n </cds-modal-header>\n <section cdsModalContent class=\"cds--modal-content\">\n <ng-container *ngTemplateOutlet=\"metadataForm; context: {obs: obs}\"></ng-container>\n </section>\n <cds-modal-footer>\n <button cdsButton=\"ghost\" (click)=\"closeModal()\" [disabled]=\"obs.disabled\">\n {{ 'document.cancel' | translate }}\n </button>\n <button\n cdsButton=\"primary\"\n type=\"submit\"\n [disabled]=\"obs.disabled || !documentenApiMetadataForm.valid || obs.isDefinitiveStatus\"\n (click)=\"save()\"\n >\n {{ 'document.save' | translate }}\n </button>\n </cds-modal-footer>\n</cds-modal>\n\n<ng-template #metadataForm let-obs=\"obs\">\n <ng-container>\n <form\n *ngIf=\"additionalDocumentDate$ | async as additionalDate\"\n [formGroup]=\"documentenApiMetadataForm\"\n >\n <div class=\"documenten-metadata-form-columns-container\">\n <div class=\"documenten-metadata-form-column\">\n <cds-text-label class=\"documenten-metada-form-input\">\n {{ 'document.filename' | translate }}\n <cds-tooltip\n [isOpen]=\"false\"\n [description]=\"'document.filenameTooltip' | translate\"\n [align]=\"'bottom-left'\"\n >\n <i class=\"mdi mdi-help-circle-outline\"></i>\n </cds-tooltip>\n <input\n [value]=\"filename\"\n [disabled]=\"obs.disabled || disableFilename\"\n [placeholder]=\"'document.filenamePlaceholder' | translate\"\n [required]=\"true\"\n cdsText\n type=\"text\"\n id=\"bestandsnaam\"\n formControlName=\"bestandsnaam\"\n />\n </cds-text-label>\n <cds-text-label class=\"documenten-metada-form-input\">\n {{ 'document.author' | translate }}\n <cds-tooltip\n [isOpen]=\"false\"\n [description]=\"'document.authorTooltip' | translate\"\n [align]=\"'bottom-left'\"\n >\n <i class=\"mdi mdi-help-circle-outline\"></i>\n </cds-tooltip>\n <input\n [value]=\"author\"\n [disabled]=\"obs.disabled || disableAuthor\"\n [placeholder]=\"'document.authorPlaceholder' | translate\"\n [required]=\"true\"\n cdsText\n id=\"auteur\"\n formControlName=\"auteur\"\n />\n </cds-text-label>\n <cds-text-label>\n {{ 'document.language' | translate }}\n <cds-tooltip\n [isOpen]=\"false\"\n [description]=\"'document.languageTooltip' | translate\"\n [align]=\"'bottom-left'\"\n >\n <i class=\"mdi mdi-help-circle-outline\"></i>\n </cds-tooltip>\n </cds-text-label>\n <div class=\"documenten-metada-form-input\">\n <cds-dropdown\n *ngIf=\"obs.languageItems\"\n [placeholder]=\"'document.languagePlaceholder' | translate\"\n [disabled]=\"obs.disabled || disableLanguage\"\n id=\"language\"\n (selected)=\"languageSelected($event)\"\n >\n <cds-dropdown-list [items]=\"obs.languageItems || []\"></cds-dropdown-list>\n </cds-dropdown>\n </div>\n <cds-label>\n {{ 'document.confidentialityLevel' | translate }}\n <cds-tooltip\n [isOpen]=\"false\"\n [description]=\"'document.confidentialityLevelTooltip' | translate\"\n [align]=\"'bottom-left'\"\n >\n <i class=\"mdi mdi-help-circle-outline\"></i>\n </cds-tooltip>\n </cds-label>\n <div class=\"documenten-metada-form-input\">\n <cds-dropdown\n [placeholder]=\"'document.confidentialityPlaceholder' | translate\"\n [disabled]=\"obs.disabled || disableConfidentialityLevel\"\n id=\"vertrouwelijkheidaanduiding\"\n (selected)=\"confidentialityLevelSelected($event)\"\n >\n <cds-dropdown-list [items]=\"confidentialityLevelItems$ | async\"></cds-dropdown-list>\n </cds-dropdown>\n </div>\n <ng-container *ngIf=\"{documentTypeItems: documentTypeItems$ | async} as obs\">\n <cds-label>\n {{ 'document.informatieobjecttype' | translate }}\n <cds-tooltip\n [isOpen]=\"false\"\n [description]=\"'document.informatieobjecttypeTooltip' | translate\"\n [align]=\"'bottom-left'\"\n >\n <i class=\"mdi mdi-help-circle-outline\"></i>\n </cds-tooltip>\n </cds-label>\n <div class=\"documenten-metada-form-input\">\n <cds-dropdown\n [placeholder]=\"'document.informatieobjecttypePlaceholder' | translate\"\n [disabled]=\"obs.disabled || disableDocumentType\"\n id=\"informatieobjecttype\"\n (selected)=\"informatieobjecttypeSelected($event)\"\n >\n <cds-dropdown-list [items]=\"obs.documentTypeItems || []\"></cds-dropdown-list>\n </cds-dropdown>\n </div>\n </ng-container>\n <cds-text-label name=\"'additionalDate'\">\n {{ 'document.additionalDate' | translate }}\n <cds-tooltip\n [isOpen]=\"false\"\n [description]=\"'document.additionalDateTooltip' | translate\"\n [align]=\"'bottom-left'\"\n >\n <i class=\"mdi mdi-help-circle-outline\"></i>\n </cds-tooltip>\n </cds-text-label>\n <cds-radio-group [orientation]=\"'horizontal'\" class=\"documenten-metada-form-input\">\n <cds-radio\n *ngFor=\"let option of ADDITONAL_DOCUMENT_DATE_OPTIONS\"\n [value]=\"option.value\"\n [checked]=\"additionalDate === option.value\"\n [required]=\"true\"\n (click)=\"setAdditionalDate(option.value)\"\n name=\"radio-inline\"\n >\n {{ option.translationKey | translate }}\n </cds-radio>\n </cds-radio-group>\n @if (supportsTrefwoorden) {\n <cds-text-label>\n {{ 'document.tags' | translate }}\n <cds-tooltip\n [isOpen]=\"false\"\n [description]=\"'document.tagsTooltip' | translate\"\n [align]=\"'bottom-left'\"\n >\n <i class=\"mdi mdi-help-circle-outline\"></i>\n </cds-tooltip>\n </cds-text-label>\n <div class=\"documenten-metada-form-input\">\n <cds-combo-box\n [type]=\"'multi'\"\n [placeholder]=\"'document.tagsPlaceholder' | translate\"\n [disabled]=\"obs.disabled || obs.tagItems.length === 0\"\n (selected)=\"tagsSelected($event)\"\n >\n >\n <cds-dropdown-list [items]=\"obs.tagItems || []\"></cds-dropdown-list>\n </cds-combo-box>\n </div>\n }\n </div>\n\n <div class=\"documenten-metadata-form-column\">\n <cds-text-label>\n {{ 'document.inputTitle' | translate }}\n <input\n [disabled]=\"obs.disabled || disableDocumentTitle\"\n [placeholder]=\"'document.inputTitlePlaceholder' | translate\"\n [required]=\"true\"\n cdsText\n class=\"documenten-metada-form-input\"\n id=\"titel\"\n formControlName=\"titel\"\n />\n <cds-tooltip\n [isOpen]=\"false\"\n [description]=\"'document.inputTitleTooltip' | translate\"\n [align]=\"'bottom'\"\n >\n <i class=\"mdi mdi-help-circle-outline\"></i>\n </cds-tooltip>\n </cds-text-label>\n <cds-textarea-label>\n {{ 'document.inputDescription' | translate }}\n <textarea\n [disabled]=\"obs.disabled || disableDescription\"\n [placeholder]=\"'document.inputDescriptionPlaceholder' | translate\"\n [required]=\"true\"\n [rows]=\"5\"\n cdsTextArea\n class=\"documenten-metada-form-description-input documenten-metada-form-input\"\n id=\"beschrijving\"\n formControlName=\"beschrijving\"\n ></textarea>\n <cds-tooltip\n [isOpen]=\"false\"\n [description]=\"'document.inputDescriptionTooltip' | translate\"\n [align]=\"'bottom'\"\n >\n <i class=\"mdi mdi-help-circle-outline\"></i>\n </cds-tooltip>\n </cds-textarea-label>\n <cds-label>\n {{ 'document.creationDate' | translate }}\n <cds-tooltip\n [isOpen]=\"false\"\n [description]=\"'document.creationDateTooltip' | translate\"\n [align]=\"'bottom'\"\n >\n <i class=\"mdi mdi-help-circle-outline\"></i>\n </cds-tooltip>\n <div class=\"documenten-metada-form-input\">\n <cds-date-picker\n [disabled]=\"obs.disabled\"\n [placeholder]=\"'DD-MM-YYYY'\"\n [dateFormat]=\"'d-m-Y'\"\n id=\"creatiedatum\"\n formControlName=\"creatiedatum\"\n >\n </cds-date-picker>\n </div>\n </cds-label>\n <cds-label>\n {{ 'document.status' | translate }}\n <cds-tooltip\n [isOpen]=\"false\"\n [description]=\"'document.statusTooltip' | translate\"\n [align]=\"'bottom'\"\n >\n <i class=\"mdi mdi-help-circle-outline\"></i>\n </cds-tooltip>\n </cds-label>\n <div class=\"documenten-metada-form-input\">\n <cds-dropdown\n [placeholder]=\"'document.statusPlaceholder' | translate\"\n [disabled]=\"obs.disabled || disableStatus\"\n id=\"status\"\n (selected)=\"statusSelected($event)\"\n >\n <cds-dropdown-list [items]=\"obs.statusItems || []\"></cds-dropdown-list>\n </cds-dropdown>\n </div>\n <cds-date-picker\n *ngIf=\"additionalDate === 'received'\"\n [disabled]=\"obs.disabled\"\n [label]=\"'document.additionalDate' | translate\"\n [placeholder]=\"'DD-MM-YYYY'\"\n [dateFormat]=\"'d-m-Y'\"\n id=\"ontvangstdatum\"\n formControlName=\"ontvangstdatum\"\n ></cds-date-picker>\n <cds-date-picker\n *ngIf=\"additionalDate === 'sent'\"\n [disabled]=\"obs.disabled\"\n [label]=\"'document.additionalDate' | translate\"\n [placeholder]=\"'DD-MM-YYYY'\"\n [dateFormat]=\"'d-m-Y'\"\n id=\"verzenddatum\"\n formControlName=\"verzenddatum\"\n ></cds-date-picker>\n </div>\n </div>\n </form>\n </ng-container>\n</ng-template>\n", styles: [".documenten-metadata-form-columns-container{display:flex;justify-content:space-between}.documenten-metadata-form-column{flex:1;margin-right:1rem}.documenten-metada-form-input{margin-bottom:18px!important;width:100%!important}.documenten-metada-form-description-input{width:100%}::ng-deep .cds--date-picker,::ng-deep .cds--date-picker-container,::ng-deep .cds--date-picker__input,::ng-deep .cds--date-picker-input__wrapper,::ng-deep .cds--date-picker-input__wrapper>span{width:100%}::ng-deep .cds--date-picker.cds--date-picker--single .cds--date-picker__input{inline-size:100%}\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"] }]
322
+ }], ctorParameters: () => [{ type: i1.ActivatedRoute }, { type: i2.DocumentService }, { type: i3.DocumentenApiDocumentService }, { type: i4.DocumentenApiTagService }, { type: i5.FormBuilder }, { type: i6.KeycloakService }, { type: i7.ModalService }, { type: i8.TranslateService }, { type: i7.ValtimoModalService }], propDecorators: { disabled$: [{
191
323
  type: Input
192
324
  }], file$: [{
193
325
  type: Input
194
- }], documentTitle: [{
326
+ }], author: [{
195
327
  type: Input
196
- }], disableDocumentTitle: [{
328
+ }], confidentialityLevel: [{
197
329
  type: Input
198
- }], filename: [{
330
+ }], description: [{
199
331
  type: Input
200
- }], disableFilename: [{
332
+ }], disableAuthor: [{
201
333
  type: Input
202
- }], author: [{
334
+ }], disableConfidentialityLevel: [{
203
335
  type: Input
204
- }], disableAuthor: [{
336
+ }], disableDescription: [{
205
337
  type: Input
206
- }], status: [{
338
+ }], disableDocumentTitle: [{
207
339
  type: Input
208
- }], disableStatus: [{
340
+ }], disableDocumentType: [{
209
341
  type: Input
210
- }], language: [{
342
+ }], disableFilename: [{
211
343
  type: Input
212
344
  }], disableLanguage: [{
213
345
  type: Input
346
+ }], disableStatus: [{
347
+ type: Input
348
+ }], documentTitle: [{
349
+ type: Input
214
350
  }], documentType: [{
215
351
  type: Input
216
- }], disableDocumentType: [{
352
+ }], disableTrefwoorden: [{
217
353
  type: Input
218
- }], description: [{
354
+ }], filename: [{
219
355
  type: Input
220
- }], disableDescription: [{
356
+ }], isEditMode: [{
221
357
  type: Input
222
- }], confidentialityLevel: [{
358
+ }], language: [{
223
359
  type: Input
224
- }], disableConfidentialityLevel: [{
360
+ }], open: [{
225
361
  type: Input
226
- }], trefwoorden: [{
362
+ }], status: [{
227
363
  type: Input
228
- }], disableTrefwoorden: [{
364
+ }], supportsTrefwoorden: [{
229
365
  type: Input
230
366
  }], metadata: [{
231
367
  type: Output
368
+ }], modalClose: [{
369
+ type: Output
232
370
  }] } });
233
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"documenten-api-metadata-modal.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/valtimo/zgw/src/lib/modules/documenten-api/components/documenten-api-metadata-modal/documenten-api-metadata-modal.component.ts","../../../../../../../../../projects/valtimo/zgw/src/lib/modules/documenten-api/components/documenten-api-metadata-modal/documenten-api-metadata-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 {Component, EventEmitter, Input, OnDestroy, OnInit, Output, ViewChild} from '@angular/core';\n\nimport {\n  AdditionalDocumentDate,\n  ConfidentialityLevel,\n  DocumentenApiMetadata,\n  DocumentLanguage,\n  DocumentStatus,\n} from '../../models';\nimport {\n  BehaviorSubject,\n  combineLatest,\n  filter,\n  from,\n  map,\n  Observable,\n  of,\n  Subject,\n  Subscription,\n  switchMap,\n  take,\n} from 'rxjs';\nimport {TranslateModule, TranslateService} from '@ngx-translate/core';\nimport {ActivatedRoute} from '@angular/router';\nimport {DocumentService} from '@valtimo/document';\nimport {KeycloakService} from 'keycloak-angular';\nimport {tap} from 'rxjs/operators';\nimport {CommonModule} from '@angular/common';\nimport {\n  ButtonModule,\n  DatePickerModule,\n  FormModule,\n  InputLabelModule,\n  InputModule,\n  ModalService,\n  SelectItem,\n  SelectModule,\n  TitleModule,\n  ValtimoModalService,\n  VModalComponent,\n  VModalModule,\n} from '@valtimo/components';\n\n@Component({\n  selector: 'valtimo-documenten-api-metadata-modal',\n  templateUrl: './documenten-api-metadata-modal.component.html',\n  styleUrls: ['./documenten-api-metadata-modal.component.scss'],\n  standalone: true,\n  imports: [\n    CommonModule,\n    TranslateModule,\n    VModalModule,\n    TitleModule,\n    ButtonModule,\n    TranslateModule,\n    FormModule,\n    InputModule,\n    SelectModule,\n    DatePickerModule,\n    InputLabelModule,\n  ],\n})\nexport class DocumentenApiMetadataModalComponent implements OnInit, OnDestroy {\n  @ViewChild('documentenApiMetadataModal') documentenApiMetadataModal: VModalComponent;\n\n  @Input() show$!: Observable<null>;\n  @Input() hide$!: Observable<null>;\n  @Input() disabled$!: Observable<boolean>;\n  @Input() file$!: Observable<File>;\n\n  @Input() documentTitle = '';\n  @Input() disableDocumentTitle: boolean;\n  @Input() filename: string;\n  @Input() disableFilename: boolean;\n  @Input() author: string;\n  @Input() disableAuthor: boolean;\n  @Input() status: string;\n  @Input() disableStatus: boolean;\n  @Input() language: string;\n  @Input() disableLanguage: boolean;\n  @Input() documentType: string;\n  @Input() disableDocumentType: boolean;\n  @Input() description: string;\n  @Input() disableDescription: boolean;\n  @Input() confidentialityLevel: string;\n  @Input() disableConfidentialityLevel: boolean;\n  @Input() trefwoorden: boolean;\n  @Input() disableTrefwoorden: boolean;\n\n  @Output() metadata: EventEmitter<DocumentenApiMetadata> = new EventEmitter();\n\n  readonly CONFIDENTIALITY_LEVELS: Array<ConfidentialityLevel> = [\n    'openbaar',\n    'beperkt_openbaar',\n    'intern',\n    'zaakvertrouwelijk',\n    'vertrouwelijk',\n    'confidentieel',\n    'geheim',\n    'zeer_geheim',\n  ];\n  readonly confidentialityLevelItems$: Observable<Array<SelectItem>> = this.translateService\n    .stream('key')\n    .pipe(\n      map(() =>\n        this.CONFIDENTIALITY_LEVELS.map(confidentialityLevel => ({\n          id: confidentialityLevel,\n          text: this.translateService.instant(`document.${confidentialityLevel}`),\n        }))\n      )\n    );\n  readonly ADDITONAL_DOCUMENT_DATE_OPTIONS: Array<{\n    value: AdditionalDocumentDate;\n    translationKey: string;\n  }> = [\n    {\n      value: 'neither',\n      translationKey: 'document.noAdditionalDate',\n    },\n    {\n      value: 'sent',\n      translationKey: 'document.sendDate',\n    },\n    {\n      value: 'received',\n      translationKey: 'document.receiptDate',\n    },\n  ];\n  readonly clearStatusSelection$ = new Subject<null>();\n  readonly additionalDocumentDate$ = new BehaviorSubject<AdditionalDocumentDate>('neither');\n  readonly STATUSES: Array<DocumentStatus> = [\n    'in_bewerking',\n    'ter_vaststelling',\n    'definitief',\n    'gearchiveerd',\n  ];\n  readonly RECEIPT_STATUSES: Array<DocumentStatus> = ['definitief', 'gearchiveerd'];\n  readonly formData$ = new BehaviorSubject<DocumentenApiMetadata>(null);\n  readonly statusItems$: Observable<Array<SelectItem>> = combineLatest([\n    this.additionalDocumentDate$,\n    this.translateService.stream('key'),\n  ]).pipe(\n    tap(([additionalDocumentDate]) => {\n      this.formData$.pipe(take(1)).subscribe(formData => {\n        if (\n          additionalDocumentDate === 'received' &&\n          (formData.status === 'in_bewerking' || formData.status === 'ter_vaststelling')\n        ) {\n          this.clearStatusSelection$.next(null);\n        }\n      });\n    }),\n    map(([additionalDocumentDate]) =>\n      (additionalDocumentDate === 'received' ? this.RECEIPT_STATUSES : this.STATUSES).map(\n        status => ({\n          id: status,\n          text: this.translateService.instant(`document.${status}`),\n        })\n      )\n    )\n  );\n  readonly LANGUAGES: Array<DocumentLanguage> = ['nld', 'eng', 'deu'];\n  readonly languageItems$: Observable<Array<SelectItem>> = this.translateService.stream('key').pipe(\n    map(() =>\n      this.LANGUAGES.map(language => ({\n        id: language,\n        text: this.translateService.instant(`document.${language}`),\n      }))\n    )\n  );\n  readonly documentTypeItems$: Observable<Array<SelectItem>> = combineLatest([\n    this.route?.params || of(null),\n    this.route?.firstChild?.params || of(null),\n    this.valtimoModalService.documentDefinitionName$,\n  ]).pipe(\n    filter(\n      ([params, firstChildParams, documentDefinitionName]) =>\n        !!(\n          params?.documentDefinitionName ||\n          firstChildParams?.documentDefinitionName ||\n          documentDefinitionName\n        )\n    ),\n    switchMap(([params, firstChildParams, documentDefinitionName]) =>\n      this.documentService.getDocumentTypes(\n        params?.documentDefinitionName ||\n          firstChildParams?.documentDefinitionName ||\n          documentDefinitionName\n      )\n    ),\n    map(documentTypes => documentTypes.map(type => ({id: type.url, text: type.name})))\n  );\n  readonly showForm$: Observable<boolean> = this.modalService.modalVisible$;\n  readonly valid$ = new BehaviorSubject<boolean>(false);\n  readonly userEmail$ = from(this.keycloakService.loadUserProfile()).pipe(\n    map(userProfile => userProfile?.email || '')\n  );\n\n  private showSubscription!: Subscription;\n  private hideSubscription!: Subscription;\n\n  constructor(\n    private readonly modalService: ModalService,\n    private readonly translateService: TranslateService,\n    private readonly route: ActivatedRoute,\n    private readonly documentService: DocumentService,\n    private readonly keycloakService: KeycloakService,\n    private readonly valtimoModalService: ValtimoModalService\n  ) {}\n\n  ngOnInit(): void {\n    this.openShowSubscription();\n    this.openHideSubscription();\n  }\n\n  ngOnDestroy(): void {\n    this.showSubscription?.unsubscribe();\n    this.hideSubscription?.unsubscribe();\n  }\n\n  hide(): void {\n    this.formData$.next(null);\n    this.valid$.next(false);\n    this.additionalDocumentDate$.next('neither');\n    this.modalService.closeModal();\n  }\n\n  cancel(): void {\n    this.hide();\n  }\n\n  save(): void {\n    combineLatest([this.valid$, this.formData$])\n      .pipe(take(1))\n      .subscribe(([valid, formData]) => {\n        if (valid) {\n          this.metadata.emit(formData);\n        }\n      });\n  }\n\n  formValueChange(data: DocumentenApiMetadata): void {\n    this.formData$.next(data);\n    this.setValid(data);\n  }\n\n  setAdditionalDate(value: AdditionalDocumentDate): void {\n    this.additionalDocumentDate$.next(value);\n  }\n\n  private setValid(data: DocumentenApiMetadata): void {\n    this.valid$.next(\n      !!(\n        data.filename &&\n        data.title &&\n        data.author &&\n        data.creationDate &&\n        data.status &&\n        data.language &&\n        data.informatieobjecttype &&\n        data.description &&\n        data.confidentialityLevel\n      )\n    );\n  }\n\n  private openShowSubscription(): void {\n    this.showSubscription = this.show$.subscribe(() => {\n      this.modalService.openModal(this.documentenApiMetadataModal);\n    });\n  }\n\n  private openHideSubscription(): void {\n    this.hideSubscription = this.hide$.subscribe(() => {\n      this.hide();\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<v-modal\n  #documentenApiMetadataModal\n  (closeEvent)=\"hide()\"\n  *ngIf=\"{file: file$ | async, disabled: disabled$ | async, valid: valid$ | async} as obs\"\n>\n  <div role=\"header\">\n    <div class=\"edit-configuration-title\">\n      <v-title [center]=\"true\" [fullWidth]=\"true\" [margin]=\"false\" type=\"h2\">{{\n        'document.fillInMetadata' | translate\n      }}</v-title>\n    </div>\n  </div>\n  <div role=\"content\">\n    <ng-container *ngTemplateOutlet=\"metadataForm; context: {obs: obs}\"></ng-container>\n  </div>\n  <div role=\"footer\">\n    <div class=\"buttons\">\n      <v-button (clickEvent)=\"cancel()\" [disabled]=\"obs.disabled\" type=\"secondary\">{{\n        'document.cancel' | translate\n      }}</v-button>\n      <v-button\n        (clickEvent)=\"save()\"\n        [disabled]=\"obs.disabled || !obs.valid\"\n        mdiIcon=\"upload\"\n        type=\"success\"\n        >{{ 'document.upload' | translate }}</v-button\n      >\n    </div>\n  </div>\n</v-modal>\n\n<ng-template #metadataForm let-obs=\"obs\">\n  <ng-container *ngIf=\"showForm$ | async\">\n    <v-form\n      (valueChange)=\"formValueChange($event)\"\n      *ngIf=\"additionalDocumentDate$ | async as additionalDate\"\n    >\n      <v-input\n        [defaultValue]=\"filename || obs.file?.name\"\n        [disabled]=\"obs.disabled || disableFilename\"\n        [fullWidth]=\"true\"\n        [margin]=\"true\"\n        [required]=\"true\"\n        [title]=\"'document.filename' | translate\"\n        [tooltip]=\"'document.filenameTooltip' | translate\"\n        name=\"filename\"\n      >\n      </v-input>\n      <v-input\n        [defaultValue]=\"documentTitle\"\n        [disabled]=\"obs.disabled || disableDocumentTitle\"\n        [margin]=\"true\"\n        [required]=\"true\"\n        [title]=\"'document.inputTitle' | translate\"\n        [tooltip]=\"'document.inputTitleTooltip' | translate\"\n        [widthPx]=\"400\"\n        name=\"title\"\n      >\n      </v-input>\n      <v-input\n        [defaultValue]=\"author || (userEmail$ | async)\"\n        [disabled]=\"obs.disabled || disableAuthor\"\n        [margin]=\"true\"\n        [required]=\"true\"\n        [title]=\"'document.author' | translate\"\n        [tooltip]=\"'document.authorTooltip' | translate\"\n        [widthPx]=\"300\"\n        name=\"author\"\n      >\n      </v-input>\n      <v-select\n        *ngIf=\"languageItems$ | async as languageItems\"\n        [defaultSelectionId]=\"language || languageItems[0].id\"\n        [disabled]=\"obs.disabled || disableLanguage\"\n        [items]=\"languageItems\"\n        [margin]=\"true\"\n        [required]=\"true\"\n        [title]=\"'document.language' | translate\"\n        [tooltip]=\"'document.languageTooltip' | translate\"\n        [widthInPx]=\"200\"\n        name=\"language\"\n      ></v-select>\n      <ng-container *ngIf=\"{documentTypeItems: documentTypeItems$ | async} as obs\">\n        <v-select\n          [defaultSelectionId]=\"documentType\"\n          [disabled]=\"obs.disabled || disableDocumentType\"\n          [items]=\"obs.documentTypeItems\"\n          [loading]=\"!obs.documentTypeItems\"\n          [margin]=\"true\"\n          [required]=\"true\"\n          [title]=\"'document.informatieobjecttype' | translate\"\n          [tooltip]=\"'document.informatieobjecttypeTooltip' | translate\"\n          [widthInPx]=\"200\"\n          name=\"informatieobjecttype\"\n        ></v-select>\n      </ng-container>\n      <v-date-picker\n        [defaultDateIsToday]=\"true\"\n        [disabled]=\"obs.disabled\"\n        [margin]=\"true\"\n        [required]=\"true\"\n        [title]=\"'document.creationDate' | translate\"\n        [tooltip]=\"'document.creationDateTooltip' | translate\"\n        [widthPx]=\"100\"\n        name=\"creationDate\"\n      ></v-date-picker>\n      <ng-container\n        *ngTemplateOutlet=\"additionalDatePicker; context: {additionalDate: additionalDate}\"\n      ></ng-container>\n      <v-date-picker\n        *ngIf=\"additionalDate === 'received'\"\n        [defaultDateIsToday]=\"true\"\n        [disabled]=\"obs.disabled\"\n        [margin]=\"true\"\n        [title]=\"'document.receiptDate' | translate\"\n        [tooltip]=\"'document.receiptDateTooltip' | translate\"\n        [widthPx]=\"100\"\n        name=\"receiptDate\"\n      ></v-date-picker>\n      <v-date-picker\n        *ngIf=\"additionalDate === 'sent'\"\n        [defaultDateIsToday]=\"true\"\n        [disabled]=\"obs.disabled\"\n        [margin]=\"true\"\n        [title]=\"'document.sendDate' | translate\"\n        [tooltip]=\"'document.sendDateTooltip' | translate\"\n        [widthPx]=\"100\"\n        name=\"sendDate\"\n      ></v-date-picker>\n      <v-select\n        [defaultSelectionId]=\"status\"\n        [disabled]=\"obs.disabled || disableStatus\"\n        [items]=\"statusItems$ | async\"\n        [margin]=\"true\"\n        [required]=\"true\"\n        [title]=\"'document.status' | translate\"\n        [tooltip]=\"'document.statusTooltip' | translate\"\n        [widthInPx]=\"200\"\n        [clearSelectionSubject$]=\"clearStatusSelection$\"\n        name=\"status\"\n      ></v-select>\n      <v-input\n        [defaultValue]=\"description\"\n        [disabled]=\"obs.disabled || disableDescription\"\n        [fullWidth]=\"true\"\n        [margin]=\"true\"\n        [title]=\"'document.inputDescription' | translate\"\n        [tooltip]=\"'document.inputDescriptionTooltip' | translate\"\n        [required]=\"true\"\n        name=\"description\"\n      >\n      </v-input>\n      <v-select\n        [defaultSelectionId]=\"confidentialityLevel\"\n        [disabled]=\"obs.disabled || disableConfidentialityLevel\"\n        [items]=\"confidentialityLevelItems$ | async\"\n        [margin]=\"true\"\n        [title]=\"'document.confidentialityLevel' | translate\"\n        [tooltip]=\"'document.confidentialityLevelTooltip' | translate\"\n        [widthInPx]=\"200\"\n        [required]=\"true\"\n        name=\"confidentialityLevel\"\n      ></v-select>\n    </v-form>\n  </ng-container>\n</ng-template>\n\n<ng-template #additionalDatePicker let-additionalDate=\"additionalDate\">\n  <v-input-label\n    [title]=\"'document.additionalDate' | translate\"\n    [name]=\"'additionalDate'\"\n    [tooltip]=\"'document.additionalDateTooltip' | translate\"\n    [required]=\"true\"\n  >\n  </v-input-label>\n  <div class=\"col-12 col-sm-8 col-lg-6 form-check mt-1 additional-date\">\n    <label\n      class=\"custom-control custom-radio custom-control-inline\"\n      *ngFor=\"let option of ADDITONAL_DOCUMENT_DATE_OPTIONS\"\n      (click)=\"setAdditionalDate(option.value)\"\n    >\n      <input\n        class=\"custom-control-input\"\n        type=\"radio\"\n        name=\"radio-inline\"\n        [checked]=\"additionalDate === option.value\"\n      /><span class=\"custom-control-label\">{{ option.translationKey | translate }}</span>\n    </label>\n  </div>\n</ng-template>\n"]}
371
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"documenten-api-metadata-modal.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/valtimo/zgw/src/lib/modules/documenten-api/components/documenten-api-metadata-modal/documenten-api-metadata-modal.component.ts","../../../../../../../../../projects/valtimo/zgw/src/lib/modules/documenten-api/components/documenten-api-metadata-modal/documenten-api-metadata-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 {Component, EventEmitter, Input, OnChanges, OnDestroy, OnInit, Output} from '@angular/core';\n\nimport {\n  AdditionalDocumentDate,\n  ConfidentialityLevel,\n  DocumentenApiMetadata,\n  DocumentLanguage,\n  DocumentStatus,\n} from '../../models';\nimport {\n  BehaviorSubject,\n  combineLatest,\n  filter,\n  from,\n  map,\n  Observable,\n  of,\n  startWith,\n  Subject,\n  Subscription,\n  switchMap,\n  take,\n} from 'rxjs';\nimport {TranslateModule, TranslateService} from '@ngx-translate/core';\nimport {ActivatedRoute} from '@angular/router';\nimport {DocumentService} from '@valtimo/document';\nimport {KeycloakService} from 'keycloak-angular';\nimport {tap} from 'rxjs/operators';\nimport {CommonModule} from '@angular/common';\nimport {\n  AbstractControl,\n  FormBuilder,\n  FormGroup,\n  ReactiveFormsModule,\n  Validators,\n} from '@angular/forms';\nimport {\n  InputLabelModule,\n  InputModule,\n  ModalService,\n  SelectModule,\n  ValtimoModalService,\n} from '@valtimo/components';\n\nimport {\n  ButtonModule,\n  ComboBoxModule,\n  DatePickerModule,\n  DropdownModule,\n  IconModule,\n  InputModule as CarbonInputModule,\n  ListItem,\n  ModalModule,\n  RadioModule,\n  TagModule,\n  TooltipModule,\n} from 'carbon-components-angular';\nimport {DocumentenApiDocumentService} from '../../services';\nimport {DocumentenApiTagService} from '../../services/documenten-api-tag.service';\n\n@Component({\n  selector: 'valtimo-documenten-api-metadata-modal',\n  templateUrl: './documenten-api-metadata-modal.component.html',\n  styleUrls: ['./documenten-api-metadata-modal.component.scss'],\n  standalone: true,\n  imports: [\n    ButtonModule,\n    CarbonInputModule,\n    ComboBoxModule,\n    CommonModule,\n    DatePickerModule,\n    DropdownModule,\n    IconModule,\n    InputLabelModule,\n    InputModule,\n    ModalModule,\n    RadioModule,\n    ReactiveFormsModule,\n    SelectModule,\n    TagModule,\n    TooltipModule,\n    TranslateModule,\n  ],\n})\nexport class DocumentenApiMetadataModalComponent implements OnInit, OnChanges, OnDestroy {\n  @Input() disabled$!: Observable<boolean>;\n  @Input() file$!: Observable<any>;\n\n  @Input() author: string;\n  @Input() confidentialityLevel: string;\n  @Input() description: string;\n  @Input() disableAuthor: boolean;\n  @Input() disableConfidentialityLevel: boolean;\n  @Input() disableDescription: boolean;\n  @Input() disableDocumentTitle: boolean;\n  @Input() disableDocumentType: boolean;\n  @Input() disableFilename: boolean;\n  @Input() disableLanguage: boolean;\n  @Input() disableStatus: boolean;\n  @Input() documentTitle = '';\n  @Input() documentType: string;\n  @Input() disableTrefwoorden: boolean;\n  @Input() filename: string;\n  @Input() isEditMode: boolean;\n  @Input() language: string;\n  @Input() open = false;\n  @Input() status: string;\n  @Input() supportsTrefwoorden = false;\n\n  @Output() metadata: EventEmitter<DocumentenApiMetadata> = new EventEmitter();\n  @Output() modalClose: EventEmitter<boolean> = new EventEmitter();\n\n  public documentenApiMetadataForm: FormGroup = this.fb.group({\n    bestandsnaam: this.fb.control('', Validators.required),\n    titel: this.fb.control('', Validators.required),\n    auteur: this.fb.control('', Validators.required),\n    beschrijving: this.fb.control('', Validators.required),\n    taal: this.fb.control('', Validators.required),\n    informatieobjecttype: this.fb.control('', Validators.required),\n    status: this.fb.control('', Validators.required),\n    vertrouwelijkheidaanduiding: this.fb.control('', Validators.required),\n    creatiedatum: this.fb.control('', Validators.required),\n    ontvangstdatum: this.fb.control(''),\n    verzenddatum: this.fb.control(''),\n    trefwoorden: this.fb.control([]),\n  });\n\n  public get confidentialityLevelFormControl(): AbstractControl<string> {\n    return this.documentenApiMetadataForm.get('vertrouwelijkheidaanduiding');\n  }\n\n  public get informatieobjecttypeFormControl(): AbstractControl<string> {\n    return this.documentenApiMetadataForm.get('informatieobjecttype');\n  }\n\n  public get languageFormControl(): AbstractControl<string> {\n    return this.documentenApiMetadataForm.get('taal');\n  }\n\n  public get statusFormControl(): AbstractControl<string> {\n    return this.documentenApiMetadataForm.get('status');\n  }\n\n  public get tagFormControl(): AbstractControl<string[]> {\n    return this.documentenApiMetadataForm.get('trefwoorden');\n  }\n\n  public readonly isDefinitiveStatus$ = new BehaviorSubject<boolean>(false);\n\n  public readonly CONFIDENTIALITY_LEVELS: Array<ConfidentialityLevel> = [\n    'openbaar',\n    'beperkt_openbaar',\n    'intern',\n    'zaakvertrouwelijk',\n    'vertrouwelijk',\n    'confidentieel',\n    'geheim',\n    'zeer_geheim',\n  ];\n  public readonly confidentialityLevelItems$: Observable<Array<ListItem>> = combineLatest([\n    this.confidentialityLevelFormControl.valueChanges.pipe(\n      startWith(this.confidentialityLevelFormControl.value)\n    ),\n    this.translateService.stream('key'),\n  ]).pipe(\n    map(([currentConfidentialityLevel]) =>\n      this.CONFIDENTIALITY_LEVELS.map(confidentialityLevel => ({\n        id: confidentialityLevel,\n        content: this.translateService.instant(`document.${confidentialityLevel}`),\n        selected: currentConfidentialityLevel === confidentialityLevel,\n      }))\n    )\n  );\n\n  public readonly ADDITONAL_DOCUMENT_DATE_OPTIONS: Array<{\n    value: AdditionalDocumentDate;\n    translationKey: string;\n  }> = [\n    {\n      value: 'neither',\n      translationKey: 'document.noAdditionalDate',\n    },\n    {\n      value: 'sent',\n      translationKey: 'document.sendDate',\n    },\n    {\n      value: 'received',\n      translationKey: 'document.receiptDate',\n    },\n  ];\n  public readonly clearStatusSelection$ = new Subject<null>();\n  public readonly additionalDocumentDate$ = new BehaviorSubject<AdditionalDocumentDate>('neither');\n  public readonly STATUSES: Array<DocumentStatus> = [\n    'in_bewerking',\n    'ter_vaststelling',\n    'definitief',\n    'gearchiveerd',\n  ];\n  public readonly RECEIPT_STATUSES: Array<DocumentStatus> = ['definitief', 'gearchiveerd'];\n  public readonly formData$ = new BehaviorSubject<DocumentenApiMetadata>(null);\n  public readonly statusItems$: Observable<Array<ListItem>> = combineLatest([\n    this.additionalDocumentDate$,\n    this.statusFormControl.valueChanges.pipe(startWith(this.statusFormControl.value)),\n    this.translateService.stream('key'),\n  ]).pipe(\n    tap(([additionalDocumentDate, currentStatus]) => {\n      this.formData$.pipe(take(1)).subscribe(formData => {\n        if (\n          additionalDocumentDate === 'received' &&\n          (formData.status === 'in_bewerking' || formData.status === 'ter_vaststelling')\n        ) {\n          this.clearStatusSelection$.next(null);\n        }\n      });\n    }),\n    map(([additionalDocumentDate, currentStatus]) =>\n      (additionalDocumentDate === 'received' ? this.RECEIPT_STATUSES : this.STATUSES).map(\n        status => ({\n          id: status,\n          content: this.translateService.instant(`document.${status}`),\n          selected: currentStatus === status,\n        })\n      )\n    )\n  );\n\n  public readonly documentDefinitionName$: Observable<string> = from(\n    this.route.params.pipe(map(params => params?.documentDefinitionName))\n  );\n\n  public readonly tagItems$: Observable<Array<ListItem>> = combineLatest([\n    this.documentDefinitionName$,\n    this.tagFormControl.valueChanges.pipe(startWith(this.tagFormControl.value)),\n  ]).pipe(\n    filter(([documentDefinitionName]) => !!documentDefinitionName),\n    switchMap(([documentDefinitionName, tagFormControlValue]) =>\n      combineLatest([\n        this.documentenApiTagService.getTags(documentDefinitionName),\n        of(tagFormControlValue),\n      ])\n    ),\n    map(([tags, tagFormControlValue]) =>\n      tags.map(tag => ({\n        id: tag.value,\n        content: tag.value,\n        selected: !!tagFormControlValue ? tagFormControlValue.includes(tag.value) : false,\n      }))\n    )\n  );\n\n  public readonly LANGUAGES: Array<DocumentLanguage> = ['nld', 'eng', 'deu'];\n  public languageItems$: Observable<Array<ListItem>> = combineLatest([\n    this.languageFormControl.valueChanges.pipe(startWith(this.languageFormControl.value)),\n    this.translateService.stream('key'),\n  ]).pipe(\n    map(([currentLanguage]) => {\n      return this.LANGUAGES.map(\n        (language: any) =>\n          ({\n            content: this.translateService.instant(`document.${language}`),\n            id: language,\n            selected: currentLanguage === language,\n          }) as ListItem\n      );\n    })\n  );\n\n  public readonly documentTypeItems$: Observable<Array<ListItem>> = combineLatest([\n    this.route?.params || of(null),\n    this.route?.firstChild?.params || of(null),\n    this.valtimoModalService.documentDefinitionName$,\n    this.informatieobjecttypeFormControl.valueChanges.pipe(\n      startWith(this.informatieobjecttypeFormControl.value)\n    ),\n  ]).pipe(\n    filter(\n      ([params, firstChildParams, documentDefinitionName]) =>\n        !!(\n          params?.documentDefinitionName ||\n          firstChildParams?.documentDefinitionName ||\n          documentDefinitionName\n        )\n    ),\n    switchMap(([params, firstChildParams, documentDefinitionName, informatieobjecttypeValue]) =>\n      combineLatest([\n        this.documentService.getDocumentTypes(\n          params?.documentDefinitionName ||\n            firstChildParams?.documentDefinitionName ||\n            documentDefinitionName\n        ),\n        of(informatieobjecttypeValue),\n      ])\n    ),\n    map(([documentTypes, informatieobjecttypeValue]) =>\n      documentTypes.map((type: any) => ({\n        id: type.url,\n        content: type.name,\n        selected: informatieobjecttypeValue === type.url,\n      }))\n    )\n  );\n  public readonly userEmail$ = from(this.keycloakService.loadUserProfile()).pipe(\n    map(userProfile => userProfile?.email || '')\n  );\n\n  private readonly modalSize = 'lg';\n  private _subscriptions = new Subscription();\n  private _fileSubscription!: Subscription;\n\n  constructor(\n    private readonly route: ActivatedRoute,\n    private readonly documentService: DocumentService,\n    private readonly documentenApiDocumentService: DocumentenApiDocumentService,\n    private readonly documentenApiTagService: DocumentenApiTagService,\n    private readonly fb: FormBuilder,\n    private readonly keycloakService: KeycloakService,\n    private readonly modalService: ModalService,\n    private readonly translateService: TranslateService,\n    private readonly valtimoModalService: ValtimoModalService\n  ) {}\n\n  public ngOnInit(): void {\n    this.openFileSubscription();\n  }\n\n  public ngOnChanges(): void {\n    this.openFileSubscription();\n  }\n\n  public ngOnDestroy(): void {\n    this._subscriptions.unsubscribe();\n    this.isDefinitiveStatus$.next(false);\n  }\n\n  public languageSelected(event: {item: {id: string}}) {\n    if (event.item.id) {\n      this.documentenApiMetadataForm.patchValue({\n        taal: event.item.id,\n      });\n    }\n  }\n\n  public tagsSelected(event: Array<ListItem>) {\n    this.tagFormControl.patchValue(event.filter(tag => tag.selected).map(tag => tag.id));\n  }\n\n  public confidentialityLevelSelected(event: {item: {id: string}}) {\n    if (event.item.id) {\n      this.documentenApiMetadataForm.patchValue({\n        vertrouwelijkheidaanduiding: event.item.id,\n      });\n    }\n  }\n\n  public statusSelected(event: {item: {id: string}}) {\n    if (event.item.id) {\n      this.documentenApiMetadataForm.patchValue({\n        status: event.item.id,\n      });\n    }\n  }\n\n  public informatieobjecttypeSelected(event: {item: {id: string}}) {\n    if (event.item.id) {\n      this.documentenApiMetadataForm.patchValue({\n        informatieobjecttype: event.item.id,\n      });\n    }\n  }\n\n  public prefillForm(file) {\n    this.prefillFilenameAndAuthor();\n    if (file) {\n      const {\n        bestandsnaam,\n        titel,\n        auteur,\n        beschrijving,\n        taal,\n        informatieobjecttype,\n        status,\n        vertrouwelijkheidaanduiding,\n        creatiedatum,\n        ontvangstdatum,\n        verzenddatum,\n        trefwoorden,\n      } = file;\n\n      if (verzenddatum) this.additionalDocumentDate$.next('sent');\n      else if (ontvangstdatum) this.additionalDocumentDate$.next('received');\n      else this.additionalDocumentDate$.next('neither');\n\n      this.documentenApiMetadataForm.patchValue({\n        bestandsnaam,\n        titel,\n        auteur,\n        beschrijving,\n        taal,\n        informatieobjecttype,\n        status,\n        vertrouwelijkheidaanduiding,\n        creatiedatum,\n        ontvangstdatum,\n        verzenddatum,\n        trefwoorden,\n      });\n    }\n  }\n\n  public save(): void {\n    this.formatDate('creatiedatum');\n    this.formatDate('verzenddatum');\n    this.formatDate('ontvangstdatum');\n\n    if (this.documentenApiMetadataForm.valid)\n      this.metadata.emit(this.documentenApiMetadataForm.value);\n\n    this.closeModal();\n  }\n\n  public closeModal(): void {\n    this.additionalDocumentDate$.next('neither');\n    this.modalClose.emit();\n    this.clearForm();\n  }\n\n  private clearForm(): void {\n    this.documentenApiMetadataForm.reset();\n  }\n\n  private prefillFilenameAndAuthor() {\n    this._subscriptions.add(\n      combineLatest([this.file$, this.userEmail$])\n        .pipe(\n          tap(([file, userEmail]) => {\n            this.documentenApiMetadataForm.patchValue({\n              bestandsnaam: file?.name || file?.bestandsnaam,\n              auteur: userEmail,\n            });\n          })\n        )\n        .subscribe()\n    );\n  }\n\n  private formatDate(controlName: string) {\n    const control = this.documentenApiMetadataForm.controls[controlName];\n    if (control.value) {\n      const date = new Date(control.value);\n      this.documentenApiMetadataForm.patchValue({\n        [controlName]: `${date.getFullYear()}-${(date.getMonth() + 1).toString().padStart(2, '0')}-${date.getDate().toString().padStart(2, '0')}`,\n      });\n    }\n  }\n\n  private openFileSubscription(): void {\n    this._fileSubscription?.unsubscribe();\n    if (this.file$) {\n      this._fileSubscription = this.file$.subscribe(file => {\n        if (file) {\n          this.prefillForm(file);\n          this.isDefinitiveStatus$.next(\n            file.status === 'definitief' && this.isEditMode ? true : false\n          );\n        }\n      });\n    }\n  }\n\n  private setAdditionalDate(value: AdditionalDocumentDate): void {\n    this.additionalDocumentDate$.next(value);\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  #documentenApiMetadataModal\n  [open]=\"open\"\n  [size]=\"modalSize\"\n  *ngIf=\"{\n    file: file$ | async,\n    disabled: disabled$ | async,\n    isDefinitiveStatus: isDefinitiveStatus$ | async,\n    languageItems: languageItems$ | async,\n    statusItems: statusItems$ | async,\n    tagItems: tagItems$ | async,\n    userEmail: userEmail$ | async\n  } as obs\"\n>\n  <cds-modal-header [showCloseButton]=\"true\" (closeSelect)=\"closeModal()\">\n    @if (isEditMode) {\n      <h3 cdsModalHeaderHeading>\n        {{ 'document.editMetadata' | translate }}\n      </h3>\n    } @else {\n      <h3 cdsModalHeaderHeading>\n        {{ 'document.fillInMetadata' | translate }}\n      </h3>\n    }\n  </cds-modal-header>\n  <section cdsModalContent class=\"cds--modal-content\">\n    <ng-container *ngTemplateOutlet=\"metadataForm; context: {obs: obs}\"></ng-container>\n  </section>\n  <cds-modal-footer>\n    <button cdsButton=\"ghost\" (click)=\"closeModal()\" [disabled]=\"obs.disabled\">\n      {{ 'document.cancel' | translate }}\n    </button>\n    <button\n      cdsButton=\"primary\"\n      type=\"submit\"\n      [disabled]=\"obs.disabled || !documentenApiMetadataForm.valid || obs.isDefinitiveStatus\"\n      (click)=\"save()\"\n    >\n      {{ 'document.save' | translate }}\n    </button>\n  </cds-modal-footer>\n</cds-modal>\n\n<ng-template #metadataForm let-obs=\"obs\">\n  <ng-container>\n    <form\n      *ngIf=\"additionalDocumentDate$ | async as additionalDate\"\n      [formGroup]=\"documentenApiMetadataForm\"\n    >\n      <div class=\"documenten-metadata-form-columns-container\">\n        <div class=\"documenten-metadata-form-column\">\n          <cds-text-label class=\"documenten-metada-form-input\">\n            {{ 'document.filename' | translate }}\n            <cds-tooltip\n              [isOpen]=\"false\"\n              [description]=\"'document.filenameTooltip' | translate\"\n              [align]=\"'bottom-left'\"\n            >\n              <i class=\"mdi mdi-help-circle-outline\"></i>\n            </cds-tooltip>\n            <input\n              [value]=\"filename\"\n              [disabled]=\"obs.disabled || disableFilename\"\n              [placeholder]=\"'document.filenamePlaceholder' | translate\"\n              [required]=\"true\"\n              cdsText\n              type=\"text\"\n              id=\"bestandsnaam\"\n              formControlName=\"bestandsnaam\"\n            />\n          </cds-text-label>\n          <cds-text-label class=\"documenten-metada-form-input\">\n            {{ 'document.author' | translate }}\n            <cds-tooltip\n              [isOpen]=\"false\"\n              [description]=\"'document.authorTooltip' | translate\"\n              [align]=\"'bottom-left'\"\n            >\n              <i class=\"mdi mdi-help-circle-outline\"></i>\n            </cds-tooltip>\n            <input\n              [value]=\"author\"\n              [disabled]=\"obs.disabled || disableAuthor\"\n              [placeholder]=\"'document.authorPlaceholder' | translate\"\n              [required]=\"true\"\n              cdsText\n              id=\"auteur\"\n              formControlName=\"auteur\"\n            />\n          </cds-text-label>\n          <cds-text-label>\n            {{ 'document.language' | translate }}\n            <cds-tooltip\n              [isOpen]=\"false\"\n              [description]=\"'document.languageTooltip' | translate\"\n              [align]=\"'bottom-left'\"\n            >\n              <i class=\"mdi mdi-help-circle-outline\"></i>\n            </cds-tooltip>\n          </cds-text-label>\n          <div class=\"documenten-metada-form-input\">\n            <cds-dropdown\n              *ngIf=\"obs.languageItems\"\n              [placeholder]=\"'document.languagePlaceholder' | translate\"\n              [disabled]=\"obs.disabled || disableLanguage\"\n              id=\"language\"\n              (selected)=\"languageSelected($event)\"\n            >\n              <cds-dropdown-list [items]=\"obs.languageItems || []\"></cds-dropdown-list>\n            </cds-dropdown>\n          </div>\n          <cds-label>\n            {{ 'document.confidentialityLevel' | translate }}\n            <cds-tooltip\n              [isOpen]=\"false\"\n              [description]=\"'document.confidentialityLevelTooltip' | translate\"\n              [align]=\"'bottom-left'\"\n            >\n              <i class=\"mdi mdi-help-circle-outline\"></i>\n            </cds-tooltip>\n          </cds-label>\n          <div class=\"documenten-metada-form-input\">\n            <cds-dropdown\n              [placeholder]=\"'document.confidentialityPlaceholder' | translate\"\n              [disabled]=\"obs.disabled || disableConfidentialityLevel\"\n              id=\"vertrouwelijkheidaanduiding\"\n              (selected)=\"confidentialityLevelSelected($event)\"\n            >\n              <cds-dropdown-list [items]=\"confidentialityLevelItems$ | async\"></cds-dropdown-list>\n            </cds-dropdown>\n          </div>\n          <ng-container *ngIf=\"{documentTypeItems: documentTypeItems$ | async} as obs\">\n            <cds-label>\n              {{ 'document.informatieobjecttype' | translate }}\n              <cds-tooltip\n                [isOpen]=\"false\"\n                [description]=\"'document.informatieobjecttypeTooltip' | translate\"\n                [align]=\"'bottom-left'\"\n              >\n                <i class=\"mdi mdi-help-circle-outline\"></i>\n              </cds-tooltip>\n            </cds-label>\n            <div class=\"documenten-metada-form-input\">\n              <cds-dropdown\n                [placeholder]=\"'document.informatieobjecttypePlaceholder' | translate\"\n                [disabled]=\"obs.disabled || disableDocumentType\"\n                id=\"informatieobjecttype\"\n                (selected)=\"informatieobjecttypeSelected($event)\"\n              >\n                <cds-dropdown-list [items]=\"obs.documentTypeItems || []\"></cds-dropdown-list>\n              </cds-dropdown>\n            </div>\n          </ng-container>\n          <cds-text-label name=\"'additionalDate'\">\n            {{ 'document.additionalDate' | translate }}\n            <cds-tooltip\n              [isOpen]=\"false\"\n              [description]=\"'document.additionalDateTooltip' | translate\"\n              [align]=\"'bottom-left'\"\n            >\n              <i class=\"mdi mdi-help-circle-outline\"></i>\n            </cds-tooltip>\n          </cds-text-label>\n          <cds-radio-group [orientation]=\"'horizontal'\" class=\"documenten-metada-form-input\">\n            <cds-radio\n              *ngFor=\"let option of ADDITONAL_DOCUMENT_DATE_OPTIONS\"\n              [value]=\"option.value\"\n              [checked]=\"additionalDate === option.value\"\n              [required]=\"true\"\n              (click)=\"setAdditionalDate(option.value)\"\n              name=\"radio-inline\"\n            >\n              {{ option.translationKey | translate }}\n            </cds-radio>\n          </cds-radio-group>\n          @if (supportsTrefwoorden) {\n            <cds-text-label>\n              {{ 'document.tags' | translate }}\n              <cds-tooltip\n                [isOpen]=\"false\"\n                [description]=\"'document.tagsTooltip' | translate\"\n                [align]=\"'bottom-left'\"\n              >\n                <i class=\"mdi mdi-help-circle-outline\"></i>\n              </cds-tooltip>\n            </cds-text-label>\n            <div class=\"documenten-metada-form-input\">\n              <cds-combo-box\n                [type]=\"'multi'\"\n                [placeholder]=\"'document.tagsPlaceholder' | translate\"\n                [disabled]=\"obs.disabled || obs.tagItems.length === 0\"\n                (selected)=\"tagsSelected($event)\"\n              >\n                >\n                <cds-dropdown-list [items]=\"obs.tagItems || []\"></cds-dropdown-list>\n              </cds-combo-box>\n            </div>\n          }\n        </div>\n\n        <div class=\"documenten-metadata-form-column\">\n          <cds-text-label>\n            {{ 'document.inputTitle' | translate }}\n            <input\n              [disabled]=\"obs.disabled || disableDocumentTitle\"\n              [placeholder]=\"'document.inputTitlePlaceholder' | translate\"\n              [required]=\"true\"\n              cdsText\n              class=\"documenten-metada-form-input\"\n              id=\"titel\"\n              formControlName=\"titel\"\n            />\n            <cds-tooltip\n              [isOpen]=\"false\"\n              [description]=\"'document.inputTitleTooltip' | translate\"\n              [align]=\"'bottom'\"\n            >\n              <i class=\"mdi mdi-help-circle-outline\"></i>\n            </cds-tooltip>\n          </cds-text-label>\n          <cds-textarea-label>\n            {{ 'document.inputDescription' | translate }}\n            <textarea\n              [disabled]=\"obs.disabled || disableDescription\"\n              [placeholder]=\"'document.inputDescriptionPlaceholder' | translate\"\n              [required]=\"true\"\n              [rows]=\"5\"\n              cdsTextArea\n              class=\"documenten-metada-form-description-input documenten-metada-form-input\"\n              id=\"beschrijving\"\n              formControlName=\"beschrijving\"\n            ></textarea>\n            <cds-tooltip\n              [isOpen]=\"false\"\n              [description]=\"'document.inputDescriptionTooltip' | translate\"\n              [align]=\"'bottom'\"\n            >\n              <i class=\"mdi mdi-help-circle-outline\"></i>\n            </cds-tooltip>\n          </cds-textarea-label>\n          <cds-label>\n            {{ 'document.creationDate' | translate }}\n            <cds-tooltip\n              [isOpen]=\"false\"\n              [description]=\"'document.creationDateTooltip' | translate\"\n              [align]=\"'bottom'\"\n            >\n              <i class=\"mdi mdi-help-circle-outline\"></i>\n            </cds-tooltip>\n            <div class=\"documenten-metada-form-input\">\n              <cds-date-picker\n                [disabled]=\"obs.disabled\"\n                [placeholder]=\"'DD-MM-YYYY'\"\n                [dateFormat]=\"'d-m-Y'\"\n                id=\"creatiedatum\"\n                formControlName=\"creatiedatum\"\n              >\n              </cds-date-picker>\n            </div>\n          </cds-label>\n          <cds-label>\n            {{ 'document.status' | translate }}\n            <cds-tooltip\n              [isOpen]=\"false\"\n              [description]=\"'document.statusTooltip' | translate\"\n              [align]=\"'bottom'\"\n            >\n              <i class=\"mdi mdi-help-circle-outline\"></i>\n            </cds-tooltip>\n          </cds-label>\n          <div class=\"documenten-metada-form-input\">\n            <cds-dropdown\n              [placeholder]=\"'document.statusPlaceholder' | translate\"\n              [disabled]=\"obs.disabled || disableStatus\"\n              id=\"status\"\n              (selected)=\"statusSelected($event)\"\n            >\n              <cds-dropdown-list [items]=\"obs.statusItems || []\"></cds-dropdown-list>\n            </cds-dropdown>\n          </div>\n          <cds-date-picker\n            *ngIf=\"additionalDate === 'received'\"\n            [disabled]=\"obs.disabled\"\n            [label]=\"'document.additionalDate' | translate\"\n            [placeholder]=\"'DD-MM-YYYY'\"\n            [dateFormat]=\"'d-m-Y'\"\n            id=\"ontvangstdatum\"\n            formControlName=\"ontvangstdatum\"\n          ></cds-date-picker>\n          <cds-date-picker\n            *ngIf=\"additionalDate === 'sent'\"\n            [disabled]=\"obs.disabled\"\n            [label]=\"'document.additionalDate' | translate\"\n            [placeholder]=\"'DD-MM-YYYY'\"\n            [dateFormat]=\"'d-m-Y'\"\n            id=\"verzenddatum\"\n            formControlName=\"verzenddatum\"\n          ></cds-date-picker>\n        </div>\n      </div>\n    </form>\n  </ng-container>\n</ng-template>\n"]}