@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.
- package/esm2022/lib/components/dossier-management-zgw/dossier-management-zgw.component.mjs +61 -13
- package/esm2022/lib/models/dossier-management-zgw.model.mjs +5 -3
- package/esm2022/lib/modules/documenten-api/components/documenten-api-column-modal/documenten-api-column-modal.component.mjs +115 -242
- package/esm2022/lib/modules/documenten-api/components/documenten-api-columns/documenten-api-columns.component.mjs +57 -85
- package/esm2022/lib/modules/documenten-api/components/documenten-api-documents/documenten-api-documents.component.mjs +171 -100
- package/esm2022/lib/modules/documenten-api/components/documenten-api-filter/documenten-api-filter.component.mjs +174 -0
- package/esm2022/lib/modules/documenten-api/components/documenten-api-metadata-modal/documenten-api-metadata-modal.component.mjs +244 -106
- package/esm2022/lib/modules/documenten-api/components/documenten-api-tag-modal/documenten-api-tag-modal.component.mjs +115 -0
- package/esm2022/lib/modules/documenten-api/components/documenten-api-tags/documenten-api-tags.component.mjs +164 -0
- package/esm2022/lib/modules/documenten-api/components/index.mjs +5 -2
- package/esm2022/lib/modules/documenten-api/formio/documenten-api-uploader/documenten-api-uploader.component.mjs +3 -3
- package/esm2022/lib/modules/documenten-api/models/configured-column.model.mjs +12 -2
- package/esm2022/lib/modules/documenten-api/models/documenten-api-filter.model.mjs +17 -0
- package/esm2022/lib/modules/documenten-api/models/documenten-api-metadata.model.mjs +1 -1
- package/esm2022/lib/modules/documenten-api/models/documenten-api-tag.model.mjs +17 -0
- package/esm2022/lib/modules/documenten-api/models/documenten-api-version.model.mjs +1 -1
- package/esm2022/lib/modules/documenten-api/models/documenten-api.model.mjs +22 -2
- package/esm2022/lib/modules/documenten-api/models/index.mjs +2 -1
- package/esm2022/lib/modules/documenten-api/services/documenten-api-column.service.mjs +10 -9
- package/esm2022/lib/modules/documenten-api/services/documenten-api-document.service.mjs +10 -3
- package/esm2022/lib/modules/documenten-api/services/documenten-api-link-process.service.mjs +1 -16
- package/esm2022/lib/modules/documenten-api/services/documenten-api-tag.service.mjs +36 -0
- package/esm2022/lib/modules/documenten-api/services/documenten-api-version.service.mjs +4 -1
- package/esm2022/lib/modules/documenten-api/services/index.mjs +3 -2
- package/esm2022/lib/modules/objecten-api/components/zaakobjecten/zaakobjecten.component.mjs +2 -2
- package/esm2022/lib/modules/zaakdetails/components/document-objecten-api-sync/document-objecten-api-sync.component.mjs +1 -1
- package/esm2022/lib/services/dossier-management-zgw.service.mjs +8 -4
- package/esm2022/lib/zgw.module.mjs +22 -5
- package/fesm2022/valtimo-zgw.mjs +1378 -781
- package/fesm2022/valtimo-zgw.mjs.map +1 -1
- package/lib/components/dossier-management-zgw/dossier-management-zgw.component.d.ts +16 -5
- package/lib/components/dossier-management-zgw/dossier-management-zgw.component.d.ts.map +1 -1
- package/lib/models/dossier-management-zgw.model.d.ts +12 -2
- package/lib/models/dossier-management-zgw.model.d.ts.map +1 -1
- package/lib/modules/documenten-api/components/documenten-api-column-modal/documenten-api-column-modal.component.d.ts +33 -63
- package/lib/modules/documenten-api/components/documenten-api-column-modal/documenten-api-column-modal.component.d.ts.map +1 -1
- package/lib/modules/documenten-api/components/documenten-api-columns/documenten-api-columns.component.d.ts +18 -20
- package/lib/modules/documenten-api/components/documenten-api-columns/documenten-api-columns.component.d.ts.map +1 -1
- package/lib/modules/documenten-api/components/documenten-api-documents/documenten-api-documents.component.d.ts +38 -20
- package/lib/modules/documenten-api/components/documenten-api-documents/documenten-api-documents.component.d.ts.map +1 -1
- package/lib/modules/documenten-api/components/documenten-api-filter/documenten-api-filter.component.d.ts +47 -0
- package/lib/modules/documenten-api/components/documenten-api-filter/documenten-api-filter.component.d.ts.map +1 -0
- package/lib/modules/documenten-api/components/documenten-api-metadata-modal/documenten-api-metadata-modal.component.d.ts +76 -39
- package/lib/modules/documenten-api/components/documenten-api-metadata-modal/documenten-api-metadata-modal.component.d.ts.map +1 -1
- package/lib/modules/documenten-api/components/documenten-api-tag-modal/documenten-api-tag-modal.component.d.ts +33 -0
- package/lib/modules/documenten-api/components/documenten-api-tag-modal/documenten-api-tag-modal.component.d.ts.map +1 -0
- package/lib/modules/documenten-api/components/documenten-api-tags/documenten-api-tags.component.d.ts +46 -0
- package/lib/modules/documenten-api/components/documenten-api-tags/documenten-api-tags.component.d.ts.map +1 -0
- package/lib/modules/documenten-api/components/index.d.ts +4 -1
- package/lib/modules/documenten-api/components/index.d.ts.map +1 -1
- package/lib/modules/documenten-api/models/configured-column.model.d.ts +8 -2
- package/lib/modules/documenten-api/models/configured-column.model.d.ts.map +1 -1
- package/lib/modules/documenten-api/models/documenten-api-filter.model.d.ts +10 -0
- package/lib/modules/documenten-api/models/documenten-api-filter.model.d.ts.map +1 -0
- package/lib/modules/documenten-api/models/documenten-api-metadata.model.d.ts +10 -9
- package/lib/modules/documenten-api/models/documenten-api-metadata.model.d.ts.map +1 -1
- package/lib/modules/documenten-api/models/documenten-api-tag.model.d.ts +5 -0
- package/lib/modules/documenten-api/models/documenten-api-tag.model.d.ts.map +1 -0
- package/lib/modules/documenten-api/models/documenten-api-version.model.d.ts +7 -1
- package/lib/modules/documenten-api/models/documenten-api-version.model.d.ts.map +1 -1
- package/lib/modules/documenten-api/models/documenten-api.model.d.ts +37 -12
- package/lib/modules/documenten-api/models/documenten-api.model.d.ts.map +1 -1
- package/lib/modules/documenten-api/models/index.d.ts +1 -0
- package/lib/modules/documenten-api/models/index.d.ts.map +1 -1
- package/lib/modules/documenten-api/services/documenten-api-column.service.d.ts +3 -2
- package/lib/modules/documenten-api/services/documenten-api-column.service.d.ts.map +1 -1
- package/lib/modules/documenten-api/services/documenten-api-document.service.d.ts +3 -2
- package/lib/modules/documenten-api/services/documenten-api-document.service.d.ts.map +1 -1
- package/lib/modules/documenten-api/services/documenten-api-link-process.service.d.ts.map +1 -1
- package/lib/modules/documenten-api/services/documenten-api-tag.service.d.ts +17 -0
- package/lib/modules/documenten-api/services/documenten-api-tag.service.d.ts.map +1 -0
- package/lib/modules/documenten-api/services/documenten-api-version.service.d.ts +2 -1
- package/lib/modules/documenten-api/services/documenten-api-version.service.d.ts.map +1 -1
- package/lib/modules/documenten-api/services/index.d.ts +2 -1
- package/lib/modules/documenten-api/services/index.d.ts.map +1 -1
- package/lib/modules/zaakdetails/components/document-objecten-api-sync/document-objecten-api-sync.component.d.ts.map +1 -1
- package/lib/services/dossier-management-zgw.service.d.ts +2 -0
- package/lib/services/dossier-management-zgw.service.d.ts.map +1 -1
- package/lib/zgw.module.d.ts.map +1 -1
- package/package.json +1 -1
|
@@ -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"]}
|