@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
@@ -0,0 +1,174 @@
1
+ import { CommonModule } from '@angular/common';
2
+ import { ChangeDetectionStrategy, Component, EventEmitter, Output, ViewChild, } from '@angular/core';
3
+ import { ReactiveFormsModule } from '@angular/forms';
4
+ import { TrashCan16 } from '@carbon/icons';
5
+ import { TranslateModule } from '@ngx-translate/core';
6
+ import { ButtonModule, DatePickerInputModule, DatePickerModule, DropdownModule, IconModule, InputModule, } from 'carbon-components-angular';
7
+ import flatpickr from 'flatpickr';
8
+ import { combineLatest, debounceTime, filter, map, startWith, Subscription, switchMap, } from 'rxjs';
9
+ import * as i0 from "@angular/core";
10
+ import * as i1 from "@valtimo/document";
11
+ import * as i2 from "@angular/forms";
12
+ import * as i3 from "carbon-components-angular";
13
+ import * as i4 from "@angular/router";
14
+ import * as i5 from "@ngx-translate/core";
15
+ import * as i6 from "../../services";
16
+ import * as i7 from "@angular/common";
17
+ export class DocumentenApiFilterComponent {
18
+ constructor(documentService, fb, iconService, route, translateService, documentenApiTagService) {
19
+ this.documentService = documentService;
20
+ this.fb = fb;
21
+ this.iconService = iconService;
22
+ this.route = route;
23
+ this.translateService = translateService;
24
+ this.documentenApiTagService = documentenApiTagService;
25
+ this.filterEvent = new EventEmitter();
26
+ this._subscriptions = new Subscription();
27
+ this._confidentialityLevels = [
28
+ 'openbaar',
29
+ 'beperkt_openbaar',
30
+ 'intern',
31
+ 'zaakvertrouwelijk',
32
+ 'vertrouwelijk',
33
+ 'confidentieel',
34
+ 'geheim',
35
+ 'zeer_geheim',
36
+ ];
37
+ this._filter$ = this.route.queryParamMap.pipe(map(queryParams => {
38
+ let { sort, ...filter } = queryParams['params'];
39
+ if (this.formGroup) {
40
+ if (!!filter.trefwoorden) {
41
+ filter = { ...filter, trefwoorden: this.convertTrefwoordenParam(filter.trefwoorden) };
42
+ }
43
+ this.formGroup.patchValue(filter, { emitEvent: false });
44
+ }
45
+ return filter;
46
+ }));
47
+ this.confidentialityLevels$ = combineLatest([
48
+ this._filter$,
49
+ this.translateService.stream('key'),
50
+ ]).pipe(map(([filter]) => this._confidentialityLevels.map((confidentialityLevel) => ({
51
+ content: this.translateService.instant(`document.${confidentialityLevel}`),
52
+ selected: filter?.vertrouwelijkheidaanduiding === confidentialityLevel,
53
+ id: confidentialityLevel,
54
+ }))), startWith([]));
55
+ this.informationObjectTypes$ = this.route.paramMap.pipe(filter((paramMap) => !!paramMap.get('documentDefinitionName')), switchMap((paramMap) => combineLatest([
56
+ this.documentService.getDocumentTypes(paramMap.get('documentDefinitionName') ?? ''),
57
+ this._filter$,
58
+ ])), map(([types, filter]) => types.map((type) => ({
59
+ content: type.name,
60
+ selected: filter?.informatieobjecttype === type.url,
61
+ id: type.url,
62
+ }))), startWith([]));
63
+ this.tags$ = this.route.paramMap.pipe(filter((paramMap) => !!paramMap.get('documentDefinitionName')), switchMap((paramMap) => combineLatest([
64
+ this.documentenApiTagService.getTags(paramMap.get('documentDefinitionName') ?? ''),
65
+ this.route.queryParamMap,
66
+ ])), map(([tags, queryParamMap]) => {
67
+ const selectedTags = this.convertTrefwoordenParam(queryParamMap['params']?.trefwoorden).map((item) => item.content);
68
+ return tags.map((tag) => ({
69
+ content: tag.value,
70
+ selected: selectedTags.includes(tag.value),
71
+ }));
72
+ }), startWith([]));
73
+ this.formGroup = this.fb.group({
74
+ auteur: this.fb.control(''),
75
+ vertrouwelijkHeidaanduiding: this.fb.control({}),
76
+ creatiedatumFrom: this.fb.control(''),
77
+ creatiedatumTo: this.fb.control(''),
78
+ informatieObjectType: this.fb.control({}),
79
+ trefwoorden: this.fb.control([]),
80
+ titel: this.fb.control(''),
81
+ });
82
+ this.iconService.register(TrashCan16);
83
+ }
84
+ ngOnInit() {
85
+ this.openFormValueSubscription();
86
+ }
87
+ ngOnDestroy() {
88
+ this._subscriptions.unsubscribe();
89
+ }
90
+ ngAfterViewInit() {
91
+ const creationDateFromControlValue = this.formGroup.get('creatiedatumFrom')?.value;
92
+ const creationDateToControlValue = this.formGroup.get('creatiedatumTo')?.value;
93
+ if (!!creationDateFromControlValue) {
94
+ this.creationDateFromPicker.writeValue([
95
+ flatpickr.formatDate(new Date(creationDateFromControlValue), 'd-m-Y'),
96
+ ]);
97
+ }
98
+ if (!!creationDateToControlValue) {
99
+ this.creationDateToPicker.writeValue([
100
+ flatpickr.formatDate(new Date(creationDateToControlValue), 'd-m-Y'),
101
+ ]);
102
+ }
103
+ }
104
+ resetFilter() {
105
+ this.creationDateFromPicker.writeValue([]);
106
+ this.creationDateToPicker.writeValue([]);
107
+ this.formGroup.reset();
108
+ }
109
+ onDateSelected(control, event) {
110
+ if (control === 'createdFrom') {
111
+ this.formGroup.get('creatiedatumFrom')?.patchValue(event);
112
+ return;
113
+ }
114
+ this.formGroup.get('creatiedatumTo')?.patchValue(event);
115
+ }
116
+ openFormValueSubscription() {
117
+ this._subscriptions.add(this.formGroup.valueChanges.pipe(debounceTime(500)).subscribe(formValue => {
118
+ this.filterEvent.emit({
119
+ ...(!!formValue.auteur && { auteur: formValue.auteur }),
120
+ ...(!!formValue.titel && { titel: formValue.titel }),
121
+ ...(!!formValue.creatiedatumFrom && {
122
+ creatiedatumFrom: flatpickr.formatDate(new Date(formValue.creatiedatumFrom), 'Y-m-d'),
123
+ }),
124
+ ...(!!formValue.creatiedatumTo && {
125
+ creatiedatumTo: flatpickr.formatDate(new Date(formValue.creatiedatumTo), 'Y-m-d'),
126
+ }),
127
+ ...(!!formValue.vertrouwelijkHeidaanduiding?.id && {
128
+ vertrouwelijkheidaanduiding: formValue.vertrouwelijkHeidaanduiding.id,
129
+ }),
130
+ ...(!!formValue.informatieObjectType?.id && {
131
+ informatieobjecttype: formValue.informatieObjectType.id,
132
+ }),
133
+ ...(!!formValue.trefwoorden &&
134
+ formValue.trefwoorden.length > 0 && {
135
+ trefwoorden: formValue.trefwoorden.reduce((acc, curr, index) => (index === 0 ? curr.content : `${acc},${curr.content}`), ''),
136
+ }),
137
+ });
138
+ }));
139
+ }
140
+ convertTrefwoordenParam(stringArray) {
141
+ if (!stringArray)
142
+ return [];
143
+ const array = stringArray.split(',');
144
+ return array.map((content) => ({
145
+ content,
146
+ selected: true,
147
+ }));
148
+ }
149
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.3", ngImport: i0, type: DocumentenApiFilterComponent, deps: [{ token: i1.DocumentService }, { token: i2.FormBuilder }, { token: i3.IconService }, { token: i4.ActivatedRoute }, { token: i5.TranslateService }, { token: i6.DocumentenApiTagService }], target: i0.ɵɵFactoryTarget.Component }); }
150
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.3", type: DocumentenApiFilterComponent, isStandalone: true, selector: "valtimo-dossier-detail-tab-documenten-api-filter", outputs: { filterEvent: "filterEvent" }, viewQueries: [{ propertyName: "creationDateFromPicker", first: true, predicate: ["creationDateFrom"], descendants: true }, { propertyName: "creationDateToPicker", first: true, predicate: ["creationDateTo"], descendants: true }], ngImport: i0, template: "<div class=\"valtimo-documenten-api-filter\" (click)=\"$event.stopImmediatePropagation()\">\n <form\n *ngIf=\"{\n confidentialityLevels: confidentialityLevels$ | async,\n informationObjectTypes: informationObjectTypes$ | async,\n tags: tags$ | async\n } as obs\"\n class=\"valtimo-documenten-api-filter__form\"\n [formGroup]=\"formGroup\"\n >\n <cds-text-label>\n {{ 'zgw.documentColumns.titel' | translate }}\n\n <input cdsText formControlName=\"titel\" />\n </cds-text-label>\n\n <cds-dropdown\n [disabled]=\"!obs.informationObjectTypes?.length\"\n [dropUp]=\"false\"\n [label]=\"'zgw.documentColumns.informatieobjecttype' | translate\"\n formControlName=\"informatieObjectType\"\n >\n <cds-dropdown-list [items]=\"obs.informationObjectTypes\"></cds-dropdown-list>\n </cds-dropdown>\n\n <div class=\"valtimo-documenten-api-filter__dates\">\n <cds-date-picker\n #creationDateFrom\n [label]=\"'interface.labels.dateCreationFrom' | translate\"\n placeholder=\"DD-MM-YYYY\"\n [dateFormat]=\"'d-m-Y'\"\n (valueChange)=\"onDateSelected('createdFrom', $event)\"\n ></cds-date-picker>\n\n <cds-date-picker\n #creationDateTo\n [label]=\"'interface.labels.dateCreationTo' | translate\"\n placeholder=\"DD-MM-YYYY\"\n [dateFormat]=\"'d-m-Y'\"\n (valueChange)=\"onDateSelected('createdTo', $event)\"\n ></cds-date-picker>\n </div>\n\n <cds-text-label>\n {{ 'zgw.documentColumns.auteur' | translate }}\n\n <input cdsText formControlName=\"auteur\" />\n </cds-text-label>\n\n <cds-dropdown\n [dropUp]=\"false\"\n [label]=\"'zgw.documentColumns.vertrouwelijkheidaanduiding' | translate\"\n formControlName=\"vertrouwelijkHeidaanduiding\"\n >\n <cds-dropdown-list [items]=\"obs.confidentialityLevels\"></cds-dropdown-list>\n </cds-dropdown>\n\n <cds-dropdown\n [label]=\"'zgw.documentColumns.trefwoorden' | translate\"\n formControlName=\"trefwoorden\"\n type=\"multi\"\n >\n <cds-dropdown-list [items]=\"obs.tags\"></cds-dropdown-list>\n </cds-dropdown>\n </form>\n\n <footer class=\"valtimo-documenten-api-filter__footer\">\n <button cdsButton=\"tertiary\" (click)=\"resetFilter()\">\n {{ 'Reset filter' | translate }}\n\n <svg class=\"cds--btn__icon\" cdsIcon=\"trash-can\" size=\"16\"></svg>\n </button>\n </footer>\n</div>\n", styles: [":host .valtimo-documenten-api-filter{display:flex;flex-direction:column;max-width:880px}:host .valtimo-documenten-api-filter__form{display:grid;grid-template-columns:repeat(3,1fr);align-items:flex-end;padding:16px;gap:16px}:host .valtimo-documenten-api-filter__dates{display:flex;gap:16px}:host .valtimo-documenten-api-filter__footer{display:flex;padding:0 16px 16px}::ng-deep .cds--date-picker.cds--date-picker--single .cds--date-picker__input{inline-size:unset!important;padding:0!important}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i7.AsyncPipe, name: "async" }, { kind: "ngmodule", type: ButtonModule }, { kind: "directive", type: i3.Button, selector: "[cdsButton], [ibmButton]", inputs: ["ibmButton", "cdsButton", "size", "skeleton", "iconOnly", "isExpressive"] }, { kind: "ngmodule", type: DatePickerInputModule }, { kind: "ngmodule", type: DatePickerModule }, { kind: "component", type: i3.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: "component", type: i3.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: i3.DropdownList, selector: "cds-dropdown-list, ibm-dropdown-list", inputs: ["ariaLabel", "items", "listTpl", "type", "showTitles"], outputs: ["select", "scroll", "blurIntent"] }, { kind: "ngmodule", type: IconModule }, { kind: "directive", type: i3.IconDirective, selector: "[cdsIcon], [ibmIcon]", inputs: ["ibmIcon", "cdsIcon", "size", "title", "ariaLabel", "ariaLabelledBy", "ariaHidden", "isFocusable"] }, { kind: "ngmodule", type: InputModule }, { kind: "component", type: i3.TextInputLabelComponent, selector: "cds-text-label, ibm-text-label", inputs: ["labelInputID", "disabled", "skeleton", "labelTemplate", "textInputTemplate", "helperText", "invalidText", "invalid", "warn", "warnText", "ariaLabel"] }, { kind: "directive", type: i3.TextInput, selector: "[cdsText], [ibmText]", inputs: ["theme", "size", "invalid", "warn", "skeleton"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i5.TranslatePipe, name: "translate" }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i2.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i2.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: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i2.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i2.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
151
+ }
152
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.3", ngImport: i0, type: DocumentenApiFilterComponent, decorators: [{
153
+ type: Component,
154
+ args: [{ selector: 'valtimo-dossier-detail-tab-documenten-api-filter', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [
155
+ CommonModule,
156
+ ButtonModule,
157
+ DatePickerInputModule,
158
+ DatePickerModule,
159
+ DropdownModule,
160
+ IconModule,
161
+ InputModule,
162
+ TranslateModule,
163
+ ReactiveFormsModule,
164
+ ], template: "<div class=\"valtimo-documenten-api-filter\" (click)=\"$event.stopImmediatePropagation()\">\n <form\n *ngIf=\"{\n confidentialityLevels: confidentialityLevels$ | async,\n informationObjectTypes: informationObjectTypes$ | async,\n tags: tags$ | async\n } as obs\"\n class=\"valtimo-documenten-api-filter__form\"\n [formGroup]=\"formGroup\"\n >\n <cds-text-label>\n {{ 'zgw.documentColumns.titel' | translate }}\n\n <input cdsText formControlName=\"titel\" />\n </cds-text-label>\n\n <cds-dropdown\n [disabled]=\"!obs.informationObjectTypes?.length\"\n [dropUp]=\"false\"\n [label]=\"'zgw.documentColumns.informatieobjecttype' | translate\"\n formControlName=\"informatieObjectType\"\n >\n <cds-dropdown-list [items]=\"obs.informationObjectTypes\"></cds-dropdown-list>\n </cds-dropdown>\n\n <div class=\"valtimo-documenten-api-filter__dates\">\n <cds-date-picker\n #creationDateFrom\n [label]=\"'interface.labels.dateCreationFrom' | translate\"\n placeholder=\"DD-MM-YYYY\"\n [dateFormat]=\"'d-m-Y'\"\n (valueChange)=\"onDateSelected('createdFrom', $event)\"\n ></cds-date-picker>\n\n <cds-date-picker\n #creationDateTo\n [label]=\"'interface.labels.dateCreationTo' | translate\"\n placeholder=\"DD-MM-YYYY\"\n [dateFormat]=\"'d-m-Y'\"\n (valueChange)=\"onDateSelected('createdTo', $event)\"\n ></cds-date-picker>\n </div>\n\n <cds-text-label>\n {{ 'zgw.documentColumns.auteur' | translate }}\n\n <input cdsText formControlName=\"auteur\" />\n </cds-text-label>\n\n <cds-dropdown\n [dropUp]=\"false\"\n [label]=\"'zgw.documentColumns.vertrouwelijkheidaanduiding' | translate\"\n formControlName=\"vertrouwelijkHeidaanduiding\"\n >\n <cds-dropdown-list [items]=\"obs.confidentialityLevels\"></cds-dropdown-list>\n </cds-dropdown>\n\n <cds-dropdown\n [label]=\"'zgw.documentColumns.trefwoorden' | translate\"\n formControlName=\"trefwoorden\"\n type=\"multi\"\n >\n <cds-dropdown-list [items]=\"obs.tags\"></cds-dropdown-list>\n </cds-dropdown>\n </form>\n\n <footer class=\"valtimo-documenten-api-filter__footer\">\n <button cdsButton=\"tertiary\" (click)=\"resetFilter()\">\n {{ 'Reset filter' | translate }}\n\n <svg class=\"cds--btn__icon\" cdsIcon=\"trash-can\" size=\"16\"></svg>\n </button>\n </footer>\n</div>\n", styles: [":host .valtimo-documenten-api-filter{display:flex;flex-direction:column;max-width:880px}:host .valtimo-documenten-api-filter__form{display:grid;grid-template-columns:repeat(3,1fr);align-items:flex-end;padding:16px;gap:16px}:host .valtimo-documenten-api-filter__dates{display:flex;gap:16px}:host .valtimo-documenten-api-filter__footer{display:flex;padding:0 16px 16px}::ng-deep .cds--date-picker.cds--date-picker--single .cds--date-picker__input{inline-size:unset!important;padding:0!important}\n"] }]
165
+ }], ctorParameters: () => [{ type: i1.DocumentService }, { type: i2.FormBuilder }, { type: i3.IconService }, { type: i4.ActivatedRoute }, { type: i5.TranslateService }, { type: i6.DocumentenApiTagService }], propDecorators: { creationDateFromPicker: [{
166
+ type: ViewChild,
167
+ args: ['creationDateFrom']
168
+ }], creationDateToPicker: [{
169
+ type: ViewChild,
170
+ args: ['creationDateTo']
171
+ }], filterEvent: [{
172
+ type: Output
173
+ }] } });
174
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"documenten-api-filter.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/valtimo/zgw/src/lib/modules/documenten-api/components/documenten-api-filter/documenten-api-filter.component.ts","../../../../../../../../../projects/valtimo/zgw/src/lib/modules/documenten-api/components/documenten-api-filter/documenten-api-filter.component.html"],"names":[],"mappings":"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","sourcesContent":["import {CommonModule} from '@angular/common';\nimport {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  Component,\n  EventEmitter,\n  OnDestroy,\n  OnInit,\n  Output,\n  ViewChild,\n} from '@angular/core';\nimport {FormBuilder, ReactiveFormsModule} from '@angular/forms';\nimport {ActivatedRoute, ParamMap} from '@angular/router';\nimport {TrashCan16} from '@carbon/icons';\nimport {TranslateModule, TranslateService} from '@ngx-translate/core';\nimport {ConfidentialityLevel} from '@valtimo/components';\nimport {DocumentService, DocumentType} from '@valtimo/document';\nimport {\n  ButtonModule,\n  DatePicker,\n  DatePickerInputModule,\n  DatePickerModule,\n  DropdownModule,\n  IconModule,\n  IconService,\n  InputModule,\n  ListItem,\n} from 'carbon-components-angular';\nimport flatpickr from 'flatpickr';\nimport {\n  combineLatest,\n  debounceTime,\n  filter,\n  map,\n  Observable,\n  startWith,\n  Subscription,\n  switchMap,\n} from 'rxjs';\nimport {DocumentenApiFilterModel} from '../../models';\nimport {DocumentenApiTag} from '../../models/documenten-api-tag.model';\nimport {DocumentenApiTagService} from '../../services';\n\n@Component({\n  selector: 'valtimo-dossier-detail-tab-documenten-api-filter',\n  templateUrl: './documenten-api-filter.component.html',\n  styleUrls: ['./documenten-api-filter.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [\n    CommonModule,\n    ButtonModule,\n    DatePickerInputModule,\n    DatePickerModule,\n    DropdownModule,\n    IconModule,\n    InputModule,\n    TranslateModule,\n    ReactiveFormsModule,\n  ],\n})\nexport class DocumentenApiFilterComponent implements OnInit, OnDestroy, AfterViewInit {\n  @ViewChild('creationDateFrom') public readonly creationDateFromPicker: DatePicker;\n  @ViewChild('creationDateTo') public readonly creationDateToPicker: DatePicker;\n  @Output() public filterEvent = new EventEmitter<DocumentenApiFilterModel>();\n\n  private readonly _subscriptions = new Subscription();\n  private readonly _confidentialityLevels: Array<ConfidentialityLevel> = [\n    'openbaar',\n    'beperkt_openbaar',\n    'intern',\n    'zaakvertrouwelijk',\n    'vertrouwelijk',\n    'confidentieel',\n    'geheim',\n    'zeer_geheim',\n  ];\n\n  private readonly _filter$ = this.route.queryParamMap.pipe(\n    map(queryParams => {\n      let {sort, ...filter} = queryParams['params'];\n      if (this.formGroup) {\n        if (!!filter.trefwoorden) {\n          filter = {...filter, trefwoorden: this.convertTrefwoordenParam(filter.trefwoorden)};\n        }\n        this.formGroup.patchValue(filter, {emitEvent: false});\n      }\n      return filter;\n    })\n  );\n\n  public readonly confidentialityLevels$: Observable<ListItem[]> = combineLatest([\n    this._filter$,\n    this.translateService.stream('key'),\n  ]).pipe(\n    map(([filter]) =>\n      this._confidentialityLevels.map((confidentialityLevel: ConfidentialityLevel) => ({\n        content: this.translateService.instant(`document.${confidentialityLevel}`),\n        selected: filter?.vertrouwelijkheidaanduiding === confidentialityLevel,\n        id: confidentialityLevel,\n      }))\n    ),\n    startWith([])\n  );\n\n  public readonly informationObjectTypes$: Observable<ListItem[]> = this.route.paramMap.pipe(\n    filter((paramMap: ParamMap) => !!paramMap.get('documentDefinitionName')),\n    switchMap((paramMap: ParamMap) =>\n      combineLatest([\n        this.documentService.getDocumentTypes(paramMap.get('documentDefinitionName') ?? ''),\n        this._filter$,\n      ])\n    ),\n    map(([types, filter]) =>\n      types.map((type: DocumentType) => ({\n        content: type.name,\n        selected: filter?.informatieobjecttype === type.url,\n        id: type.url,\n      }))\n    ),\n    startWith([])\n  );\n\n  public readonly tags$: Observable<ListItem[]> = this.route.paramMap.pipe(\n    filter((paramMap: ParamMap) => !!paramMap.get('documentDefinitionName')),\n    switchMap((paramMap: ParamMap) =>\n      combineLatest([\n        this.documentenApiTagService.getTags(paramMap.get('documentDefinitionName') ?? ''),\n        this.route.queryParamMap,\n      ])\n    ),\n    map(([tags, queryParamMap]) => {\n      const selectedTags = this.convertTrefwoordenParam(queryParamMap['params']?.trefwoorden).map(\n        (item: ListItem) => item.content\n      );\n      return tags.map((tag: DocumentenApiTag) => ({\n        content: tag.value,\n        selected: selectedTags.includes(tag.value),\n      }));\n    }),\n    startWith([])\n  );\n\n  public readonly formGroup = this.fb.group({\n    auteur: this.fb.control(''),\n    vertrouwelijkHeidaanduiding: this.fb.control({}),\n    creatiedatumFrom: this.fb.control(''),\n    creatiedatumTo: this.fb.control(''),\n    informatieObjectType: this.fb.control({}),\n    trefwoorden: this.fb.control([]),\n    titel: this.fb.control(''),\n  });\n\n  constructor(\n    private readonly documentService: DocumentService,\n    private readonly fb: FormBuilder,\n    private readonly iconService: IconService,\n    private readonly route: ActivatedRoute,\n    private readonly translateService: TranslateService,\n    private readonly documentenApiTagService: DocumentenApiTagService\n  ) {\n    this.iconService.register(TrashCan16);\n  }\n\n  public ngOnInit(): void {\n    this.openFormValueSubscription();\n  }\n\n  public ngOnDestroy(): void {\n    this._subscriptions.unsubscribe();\n  }\n\n  public ngAfterViewInit(): void {\n    const creationDateFromControlValue = this.formGroup.get('creatiedatumFrom')?.value;\n    const creationDateToControlValue = this.formGroup.get('creatiedatumTo')?.value;\n\n    if (!!creationDateFromControlValue) {\n      this.creationDateFromPicker.writeValue([\n        flatpickr.formatDate(new Date(creationDateFromControlValue), 'd-m-Y'),\n      ]);\n    }\n\n    if (!!creationDateToControlValue) {\n      this.creationDateToPicker.writeValue([\n        flatpickr.formatDate(new Date(creationDateToControlValue), 'd-m-Y'),\n      ]);\n    }\n  }\n\n  public resetFilter(): void {\n    this.creationDateFromPicker.writeValue([]);\n    this.creationDateToPicker.writeValue([]);\n    this.formGroup.reset();\n  }\n\n  public onDateSelected(control: 'createdTo' | 'createdFrom', event: any): void {\n    if (control === 'createdFrom') {\n      this.formGroup.get('creatiedatumFrom')?.patchValue(event);\n      return;\n    }\n\n    this.formGroup.get('creatiedatumTo')?.patchValue(event);\n  }\n\n  private openFormValueSubscription(): void {\n    this._subscriptions.add(\n      this.formGroup.valueChanges.pipe(debounceTime(500)).subscribe(formValue => {\n        this.filterEvent.emit({\n          ...(!!formValue.auteur && {auteur: formValue.auteur}),\n          ...(!!formValue.titel && {titel: formValue.titel}),\n          ...(!!formValue.creatiedatumFrom && {\n            creatiedatumFrom: flatpickr.formatDate(new Date(formValue.creatiedatumFrom), 'Y-m-d'),\n          }),\n          ...(!!formValue.creatiedatumTo && {\n            creatiedatumTo: flatpickr.formatDate(new Date(formValue.creatiedatumTo), 'Y-m-d'),\n          }),\n          ...(!!(formValue.vertrouwelijkHeidaanduiding as ListItem)?.id && {\n            vertrouwelijkheidaanduiding: (formValue.vertrouwelijkHeidaanduiding as ListItem).id,\n          }),\n          ...(!!(formValue.informatieObjectType as ListItem)?.id && {\n            informatieobjecttype: (formValue.informatieObjectType as ListItem).id,\n          }),\n          ...(!!formValue.trefwoorden &&\n            formValue.trefwoorden.length > 0 && {\n              trefwoorden: (formValue.trefwoorden as ListItem[]).reduce(\n                (acc, curr, index) => (index === 0 ? curr.content : `${acc},${curr.content}`),\n                ''\n              ),\n            }),\n        });\n      })\n    );\n  }\n\n  private convertTrefwoordenParam(stringArray: string | undefined): ListItem[] {\n    if (!stringArray) return [];\n    const array = stringArray.split(',');\n\n    return array.map((content: string) => ({\n      content,\n      selected: true,\n    }));\n  }\n}\n","<div class=\"valtimo-documenten-api-filter\" (click)=\"$event.stopImmediatePropagation()\">\n  <form\n    *ngIf=\"{\n      confidentialityLevels: confidentialityLevels$ | async,\n      informationObjectTypes: informationObjectTypes$ | async,\n      tags: tags$ | async\n    } as obs\"\n    class=\"valtimo-documenten-api-filter__form\"\n    [formGroup]=\"formGroup\"\n  >\n    <cds-text-label>\n      {{ 'zgw.documentColumns.titel' | translate }}\n\n      <input cdsText formControlName=\"titel\" />\n    </cds-text-label>\n\n    <cds-dropdown\n      [disabled]=\"!obs.informationObjectTypes?.length\"\n      [dropUp]=\"false\"\n      [label]=\"'zgw.documentColumns.informatieobjecttype' | translate\"\n      formControlName=\"informatieObjectType\"\n    >\n      <cds-dropdown-list [items]=\"obs.informationObjectTypes\"></cds-dropdown-list>\n    </cds-dropdown>\n\n    <div class=\"valtimo-documenten-api-filter__dates\">\n      <cds-date-picker\n        #creationDateFrom\n        [label]=\"'interface.labels.dateCreationFrom' | translate\"\n        placeholder=\"DD-MM-YYYY\"\n        [dateFormat]=\"'d-m-Y'\"\n        (valueChange)=\"onDateSelected('createdFrom', $event)\"\n      ></cds-date-picker>\n\n      <cds-date-picker\n        #creationDateTo\n        [label]=\"'interface.labels.dateCreationTo' | translate\"\n        placeholder=\"DD-MM-YYYY\"\n        [dateFormat]=\"'d-m-Y'\"\n        (valueChange)=\"onDateSelected('createdTo', $event)\"\n      ></cds-date-picker>\n    </div>\n\n    <cds-text-label>\n      {{ 'zgw.documentColumns.auteur' | translate }}\n\n      <input cdsText formControlName=\"auteur\" />\n    </cds-text-label>\n\n    <cds-dropdown\n      [dropUp]=\"false\"\n      [label]=\"'zgw.documentColumns.vertrouwelijkheidaanduiding' | translate\"\n      formControlName=\"vertrouwelijkHeidaanduiding\"\n    >\n      <cds-dropdown-list [items]=\"obs.confidentialityLevels\"></cds-dropdown-list>\n    </cds-dropdown>\n\n    <cds-dropdown\n      [label]=\"'zgw.documentColumns.trefwoorden' | translate\"\n      formControlName=\"trefwoorden\"\n      type=\"multi\"\n    >\n      <cds-dropdown-list [items]=\"obs.tags\"></cds-dropdown-list>\n    </cds-dropdown>\n  </form>\n\n  <footer class=\"valtimo-documenten-api-filter__footer\">\n    <button cdsButton=\"tertiary\" (click)=\"resetFilter()\">\n      {{ 'Reset filter' | translate }}\n\n      <svg class=\"cds--btn__icon\" cdsIcon=\"trash-can\" size=\"16\"></svg>\n    </button>\n  </footer>\n</div>\n"]}