@valtimo/zgw 12.0.0 → 12.1.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/components/dossier-management-zgw/dossier-management-zgw.component.mjs +61 -13
- package/esm2022/lib/models/dossier-management-zgw.model.mjs +5 -3
- package/esm2022/lib/modules/documenten-api/components/documenten-api-column-modal/documenten-api-column-modal.component.mjs +115 -242
- package/esm2022/lib/modules/documenten-api/components/documenten-api-columns/documenten-api-columns.component.mjs +57 -85
- package/esm2022/lib/modules/documenten-api/components/documenten-api-documents/documenten-api-documents.component.mjs +171 -100
- package/esm2022/lib/modules/documenten-api/components/documenten-api-filter/documenten-api-filter.component.mjs +174 -0
- package/esm2022/lib/modules/documenten-api/components/documenten-api-metadata-modal/documenten-api-metadata-modal.component.mjs +244 -106
- package/esm2022/lib/modules/documenten-api/components/documenten-api-tag-modal/documenten-api-tag-modal.component.mjs +115 -0
- package/esm2022/lib/modules/documenten-api/components/documenten-api-tags/documenten-api-tags.component.mjs +164 -0
- package/esm2022/lib/modules/documenten-api/components/index.mjs +5 -2
- package/esm2022/lib/modules/documenten-api/formio/documenten-api-uploader/documenten-api-uploader.component.mjs +3 -3
- package/esm2022/lib/modules/documenten-api/models/configured-column.model.mjs +12 -2
- package/esm2022/lib/modules/documenten-api/models/documenten-api-filter.model.mjs +17 -0
- package/esm2022/lib/modules/documenten-api/models/documenten-api-metadata.model.mjs +1 -1
- package/esm2022/lib/modules/documenten-api/models/documenten-api-tag.model.mjs +17 -0
- package/esm2022/lib/modules/documenten-api/models/documenten-api-version.model.mjs +1 -1
- package/esm2022/lib/modules/documenten-api/models/documenten-api.model.mjs +22 -2
- package/esm2022/lib/modules/documenten-api/models/index.mjs +2 -1
- package/esm2022/lib/modules/documenten-api/services/documenten-api-column.service.mjs +10 -9
- package/esm2022/lib/modules/documenten-api/services/documenten-api-document.service.mjs +10 -3
- package/esm2022/lib/modules/documenten-api/services/documenten-api-link-process.service.mjs +1 -16
- package/esm2022/lib/modules/documenten-api/services/documenten-api-tag.service.mjs +36 -0
- package/esm2022/lib/modules/documenten-api/services/documenten-api-version.service.mjs +4 -1
- package/esm2022/lib/modules/documenten-api/services/index.mjs +3 -2
- package/esm2022/lib/modules/objecten-api/components/zaakobjecten/zaakobjecten.component.mjs +2 -2
- package/esm2022/lib/modules/zaakdetails/components/document-objecten-api-sync/document-objecten-api-sync.component.mjs +1 -1
- package/esm2022/lib/services/dossier-management-zgw.service.mjs +8 -4
- package/esm2022/lib/zgw.module.mjs +22 -5
- package/fesm2022/valtimo-zgw.mjs +1378 -781
- package/fesm2022/valtimo-zgw.mjs.map +1 -1
- package/lib/components/dossier-management-zgw/dossier-management-zgw.component.d.ts +16 -5
- package/lib/components/dossier-management-zgw/dossier-management-zgw.component.d.ts.map +1 -1
- package/lib/models/dossier-management-zgw.model.d.ts +12 -2
- package/lib/models/dossier-management-zgw.model.d.ts.map +1 -1
- package/lib/modules/documenten-api/components/documenten-api-column-modal/documenten-api-column-modal.component.d.ts +33 -63
- package/lib/modules/documenten-api/components/documenten-api-column-modal/documenten-api-column-modal.component.d.ts.map +1 -1
- package/lib/modules/documenten-api/components/documenten-api-columns/documenten-api-columns.component.d.ts +18 -20
- package/lib/modules/documenten-api/components/documenten-api-columns/documenten-api-columns.component.d.ts.map +1 -1
- package/lib/modules/documenten-api/components/documenten-api-documents/documenten-api-documents.component.d.ts +38 -20
- package/lib/modules/documenten-api/components/documenten-api-documents/documenten-api-documents.component.d.ts.map +1 -1
- package/lib/modules/documenten-api/components/documenten-api-filter/documenten-api-filter.component.d.ts +47 -0
- package/lib/modules/documenten-api/components/documenten-api-filter/documenten-api-filter.component.d.ts.map +1 -0
- package/lib/modules/documenten-api/components/documenten-api-metadata-modal/documenten-api-metadata-modal.component.d.ts +76 -39
- package/lib/modules/documenten-api/components/documenten-api-metadata-modal/documenten-api-metadata-modal.component.d.ts.map +1 -1
- package/lib/modules/documenten-api/components/documenten-api-tag-modal/documenten-api-tag-modal.component.d.ts +33 -0
- package/lib/modules/documenten-api/components/documenten-api-tag-modal/documenten-api-tag-modal.component.d.ts.map +1 -0
- package/lib/modules/documenten-api/components/documenten-api-tags/documenten-api-tags.component.d.ts +46 -0
- package/lib/modules/documenten-api/components/documenten-api-tags/documenten-api-tags.component.d.ts.map +1 -0
- package/lib/modules/documenten-api/components/index.d.ts +4 -1
- package/lib/modules/documenten-api/components/index.d.ts.map +1 -1
- package/lib/modules/documenten-api/models/configured-column.model.d.ts +8 -2
- package/lib/modules/documenten-api/models/configured-column.model.d.ts.map +1 -1
- package/lib/modules/documenten-api/models/documenten-api-filter.model.d.ts +10 -0
- package/lib/modules/documenten-api/models/documenten-api-filter.model.d.ts.map +1 -0
- package/lib/modules/documenten-api/models/documenten-api-metadata.model.d.ts +10 -9
- package/lib/modules/documenten-api/models/documenten-api-metadata.model.d.ts.map +1 -1
- package/lib/modules/documenten-api/models/documenten-api-tag.model.d.ts +5 -0
- package/lib/modules/documenten-api/models/documenten-api-tag.model.d.ts.map +1 -0
- package/lib/modules/documenten-api/models/documenten-api-version.model.d.ts +7 -1
- package/lib/modules/documenten-api/models/documenten-api-version.model.d.ts.map +1 -1
- package/lib/modules/documenten-api/models/documenten-api.model.d.ts +37 -12
- package/lib/modules/documenten-api/models/documenten-api.model.d.ts.map +1 -1
- package/lib/modules/documenten-api/models/index.d.ts +1 -0
- package/lib/modules/documenten-api/models/index.d.ts.map +1 -1
- package/lib/modules/documenten-api/services/documenten-api-column.service.d.ts +3 -2
- package/lib/modules/documenten-api/services/documenten-api-column.service.d.ts.map +1 -1
- package/lib/modules/documenten-api/services/documenten-api-document.service.d.ts +3 -2
- package/lib/modules/documenten-api/services/documenten-api-document.service.d.ts.map +1 -1
- package/lib/modules/documenten-api/services/documenten-api-link-process.service.d.ts.map +1 -1
- package/lib/modules/documenten-api/services/documenten-api-tag.service.d.ts +17 -0
- package/lib/modules/documenten-api/services/documenten-api-tag.service.d.ts.map +1 -0
- package/lib/modules/documenten-api/services/documenten-api-version.service.d.ts +2 -1
- package/lib/modules/documenten-api/services/documenten-api-version.service.d.ts.map +1 -1
- package/lib/modules/documenten-api/services/index.d.ts +2 -1
- package/lib/modules/documenten-api/services/index.d.ts.map +1 -1
- package/lib/modules/zaakdetails/components/document-objecten-api-sync/document-objecten-api-sync.component.d.ts.map +1 -1
- package/lib/services/dossier-management-zgw.service.d.ts +2 -0
- package/lib/services/dossier-management-zgw.service.d.ts.map +1 -1
- package/lib/zgw.module.d.ts.map +1 -1
- package/package.json +1 -1
|
@@ -13,29 +13,30 @@
|
|
|
13
13
|
* See the License for the specific language governing permissions and
|
|
14
14
|
* limitations under the License.
|
|
15
15
|
*/
|
|
16
|
+
import { CommonModule } from '@angular/common';
|
|
16
17
|
import { Component, ViewChild } from '@angular/core';
|
|
17
18
|
import { Filter16, TagGroup16, Upload16 } from '@carbon/icons';
|
|
18
19
|
import { TranslateModule } from '@ngx-translate/core';
|
|
19
|
-
import { CarbonListModule, ViewType, } from '@valtimo/components';
|
|
20
|
-
import { ButtonModule, IconModule } from 'carbon-components-angular';
|
|
21
|
-
import
|
|
22
|
-
import { BehaviorSubject, combineLatest, of, Subject } from 'rxjs';
|
|
20
|
+
import { CarbonListModule, ConfirmationModalModule, ViewType, } from '@valtimo/components';
|
|
21
|
+
import { ButtonModule, DialogModule, IconModule } from 'carbon-components-angular';
|
|
22
|
+
import { BehaviorSubject, combineLatest, of, ReplaySubject, Subject } from 'rxjs';
|
|
23
23
|
import { catchError, filter, map, switchMap, take, tap } from 'rxjs/operators';
|
|
24
|
+
import { COLUMN_VIEW_TYPES, DOCUMENTEN_COLUMN_KEYS, } from '../../models';
|
|
25
|
+
import { DocumentenApiFilterComponent } from '../documenten-api-filter/documenten-api-filter.component';
|
|
24
26
|
import { DocumentenApiMetadataModalComponent } from '../documenten-api-metadata-modal/documenten-api-metadata-modal.component';
|
|
25
|
-
import { CommonModule } from '@angular/common';
|
|
26
27
|
import * as i0 from "@angular/core";
|
|
27
28
|
import * as i1 from "@angular/router";
|
|
28
29
|
import * as i2 from "@valtimo/resource";
|
|
29
30
|
import * as i3 from "@ngx-translate/core";
|
|
30
31
|
import * as i4 from "@valtimo/config";
|
|
31
32
|
import * as i5 from "@valtimo/security";
|
|
32
|
-
import * as i6 from "
|
|
33
|
-
import * as i7 from "
|
|
34
|
-
import * as i8 from "../../services
|
|
33
|
+
import * as i6 from "carbon-components-angular";
|
|
34
|
+
import * as i7 from "../../services/documenten-api-document.service";
|
|
35
|
+
import * as i8 from "../../services";
|
|
35
36
|
import * as i9 from "@angular/common";
|
|
36
37
|
import * as i10 from "@valtimo/components";
|
|
37
38
|
export class DossierDetailTabDocumentenApiDocumentsComponent {
|
|
38
|
-
constructor(route, router, uploadProviderService, downloadService, translateService, configService, userProviderService,
|
|
39
|
+
constructor(route, router, uploadProviderService, downloadService, translateService, configService, userProviderService, iconService, documentenApiDocumentService, documentenApiColumnService, documentenApiVersionService) {
|
|
39
40
|
this.route = route;
|
|
40
41
|
this.router = router;
|
|
41
42
|
this.uploadProviderService = uploadProviderService;
|
|
@@ -43,110 +44,129 @@ export class DossierDetailTabDocumentenApiDocumentsComponent {
|
|
|
43
44
|
this.translateService = translateService;
|
|
44
45
|
this.configService = configService;
|
|
45
46
|
this.userProviderService = userProviderService;
|
|
46
|
-
this.fileSortService = fileSortService;
|
|
47
47
|
this.iconService = iconService;
|
|
48
48
|
this.documentenApiDocumentService = documentenApiDocumentService;
|
|
49
|
+
this.documentenApiColumnService = documentenApiColumnService;
|
|
50
|
+
this.documentenApiVersionService = documentenApiVersionService;
|
|
51
|
+
this._documentDefinitionName$ = this.route.params.pipe(map(params => params?.documentDefinitionName), filter(caseDefinitionName => !!caseDefinitionName));
|
|
52
|
+
this.supportedDocumentenApiFeatures$ = new BehaviorSubject(null);
|
|
53
|
+
this._supportedDocumentenApiFeatures$ = this._documentDefinitionName$.pipe(switchMap(caseDefinitionName => this.documentenApiVersionService.getSupportedApiFeatures(caseDefinitionName)), tap(supportedDocumentenApiFeatures => this.supportedDocumentenApiFeatures$.next(supportedDocumentenApiFeatures)));
|
|
54
|
+
this.fields$ = this._documentDefinitionName$.pipe(tap(() => this.fieldsLoading$.next(true)), switchMap(documentDefinitionName => combineLatest([
|
|
55
|
+
this.documentenApiColumnService.getConfiguredColumns(documentDefinitionName),
|
|
56
|
+
this._supportedDocumentenApiFeatures$,
|
|
57
|
+
])), map(([columns, supportedDocumentenApiFeatures]) => {
|
|
58
|
+
const defaultSortColumn = columns.find((column) => !!column.defaultSort);
|
|
59
|
+
if (!!defaultSortColumn && supportedDocumentenApiFeatures.supportsSortableColumns) {
|
|
60
|
+
this._sort$.next({ sort: `${defaultSortColumn.key},${defaultSortColumn.defaultSort}` });
|
|
61
|
+
}
|
|
62
|
+
return columns.map((column) => ({
|
|
63
|
+
key: column.key === DOCUMENTEN_COLUMN_KEYS.BESTANDSOMVANG ? 'size' : column.key,
|
|
64
|
+
label: `zgw.documentColumns.${column.key}`,
|
|
65
|
+
viewType: !COLUMN_VIEW_TYPES[column.key] ? ViewType.TEXT : COLUMN_VIEW_TYPES[column.key],
|
|
66
|
+
...(COLUMN_VIEW_TYPES[column.key] === ViewType.TEMPLATE && {
|
|
67
|
+
template: this.translationTemplate,
|
|
68
|
+
templateData: { key: column.key },
|
|
69
|
+
}),
|
|
70
|
+
...(column.key === DOCUMENTEN_COLUMN_KEYS.CREATIEDATUM && { format: 'DD-MM-YYYY' }),
|
|
71
|
+
sortable: column.sortable && supportedDocumentenApiFeatures.supportsSortableColumns,
|
|
72
|
+
}));
|
|
73
|
+
}), tap(() => this.fieldsLoading$.next(false)));
|
|
49
74
|
this.actionItems = [
|
|
50
75
|
{
|
|
51
76
|
label: 'document.download',
|
|
52
77
|
callback: this.onDownloadActionClick.bind(this),
|
|
53
78
|
type: 'normal',
|
|
54
79
|
},
|
|
80
|
+
{
|
|
81
|
+
label: 'document.edit',
|
|
82
|
+
callback: this.onEditMetadata.bind(this),
|
|
83
|
+
disabledCallback: this.editDisabled.bind(this),
|
|
84
|
+
type: 'normal',
|
|
85
|
+
},
|
|
55
86
|
{
|
|
56
87
|
label: 'document.delete',
|
|
57
88
|
callback: this.onDeleteActionClick.bind(this),
|
|
58
89
|
type: 'danger',
|
|
59
90
|
},
|
|
60
91
|
];
|
|
61
|
-
this.
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
'
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
92
|
+
this.documentDefinitionName$ = this.route.params.pipe(map(params => params?.documentDefinitionName), filter(documentDefinitionName => !!documentDefinitionName));
|
|
93
|
+
this.documentId$ = this.route.params.pipe(map(params => params?.documentId), filter(documentId => !!documentId));
|
|
94
|
+
this.initialSortState$ = this.route.queryParamMap.pipe(map(params => params['params']), map(params => {
|
|
95
|
+
if (!!params['sort']) {
|
|
96
|
+
const paramsSplit = params['sort'].split(',');
|
|
97
|
+
const state = {
|
|
98
|
+
name: paramsSplit[0],
|
|
99
|
+
direction: paramsSplit[1],
|
|
100
|
+
};
|
|
101
|
+
return {
|
|
102
|
+
isSorting: true,
|
|
103
|
+
state,
|
|
104
|
+
};
|
|
105
|
+
}
|
|
106
|
+
return null;
|
|
107
|
+
}));
|
|
76
108
|
this.uploadProcessLinkedSet = false;
|
|
109
|
+
this.isEditMode$ = new BehaviorSubject(false);
|
|
77
110
|
this.acceptedFiles = this.configService?.config?.caseFileUploadAcceptedFiles || null;
|
|
78
111
|
this.maxFileSize = this.configService?.config?.caseFileSizeUploadLimitMB || 5;
|
|
79
112
|
this.fileToBeUploaded$ = new BehaviorSubject(null);
|
|
80
|
-
this.hideModal$ = new Subject();
|
|
81
113
|
this.modalDisabled$ = new BehaviorSubject(false);
|
|
82
114
|
this.showModal$ = new Subject();
|
|
115
|
+
this.showUploadModal$ = new BehaviorSubject(false);
|
|
116
|
+
this.showDeleteConfirmationModal$ = new BehaviorSubject(false);
|
|
83
117
|
this.uploading$ = new BehaviorSubject(false);
|
|
84
|
-
this.
|
|
118
|
+
this._itemsLoading$ = new BehaviorSubject(true);
|
|
119
|
+
this.fieldsLoading$ = new BehaviorSubject(true);
|
|
120
|
+
this.loading$ = combineLatest([this._itemsLoading$, this.fieldsLoading$]).pipe(map(([itemsLoading, fieldsLoading]) => itemsLoading || fieldsLoading));
|
|
121
|
+
this.filter$ = new ReplaySubject();
|
|
85
122
|
this._refetch$ = new BehaviorSubject(null);
|
|
123
|
+
this._sort$ = new ReplaySubject();
|
|
86
124
|
this.relatedFiles$ = combineLatest([
|
|
87
|
-
this.
|
|
125
|
+
this.documentId$,
|
|
126
|
+
this.route.queryParamMap,
|
|
88
127
|
this._refetch$,
|
|
89
|
-
]).pipe(tap(() => this.
|
|
90
|
-
this.documentenApiDocumentService.
|
|
128
|
+
]).pipe(tap(() => this._itemsLoading$.next(true)), switchMap(([documentId, queryParams]) => combineLatest([
|
|
129
|
+
this.documentenApiDocumentService.getFilteredZakenApiDocuments(documentId, queryParams['params']),
|
|
91
130
|
this.translateService.stream('key'),
|
|
92
131
|
])), map(([relatedFiles]) => {
|
|
93
|
-
const translatedFiles = relatedFiles?.map(file => ({
|
|
132
|
+
const translatedFiles = relatedFiles?.content?.map(file => ({
|
|
94
133
|
...file,
|
|
95
134
|
createdBy: file.createdBy || this.translateService.instant('list.automaticallyGenerated'),
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
135
|
+
size: this.bytesToMegabytes(file.bestandsomvang),
|
|
136
|
+
tags: file.trefwoorden?.map((trefwoord) => ({
|
|
137
|
+
content: trefwoord,
|
|
138
|
+
})),
|
|
100
139
|
}));
|
|
101
140
|
return translatedFiles || [];
|
|
102
|
-
}), map(relatedFiles => this.fileSortService.sortRelatedFilesByDateDescending(relatedFiles)), map(relatedFiles => {
|
|
103
|
-
moment.locale(this.translateService.currentLang);
|
|
104
|
-
return relatedFiles.map(file => ({
|
|
105
|
-
...file,
|
|
106
|
-
createdOn: moment(new Date(file.createdOn)).format('L'),
|
|
107
|
-
size: `${this.bytesToMegabytes(file.sizeInBytes)}`,
|
|
108
|
-
}));
|
|
109
141
|
}), tap(() => {
|
|
110
|
-
this.
|
|
142
|
+
this._itemsLoading$.next(false);
|
|
111
143
|
}), catchError(() => {
|
|
112
144
|
this.showZaakLinkWarning = true;
|
|
113
|
-
this.
|
|
145
|
+
this._itemsLoading$.next(false);
|
|
114
146
|
return of([]);
|
|
115
147
|
}));
|
|
148
|
+
this.iconService.register(Filter16);
|
|
116
149
|
}
|
|
117
150
|
ngOnInit() {
|
|
118
|
-
this.
|
|
151
|
+
this.setInitialFilterAndSort();
|
|
152
|
+
this.openQueryParamsSubscription();
|
|
119
153
|
this.setUploadProcessLinked();
|
|
120
154
|
this.isUserAdmin();
|
|
121
155
|
this.iconService.registerAll([Filter16, TagGroup16, Upload16]);
|
|
122
156
|
}
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
template: this.sizeTemplate,
|
|
133
|
-
},
|
|
134
|
-
{ key: 'format', label: 'document.format' },
|
|
135
|
-
{ key: 'createdOn', label: 'document.createdOn' },
|
|
136
|
-
{ key: 'createdBy', label: 'document.createdBy' },
|
|
137
|
-
{ key: 'author', label: 'document.author' },
|
|
138
|
-
{ key: 'keywords', label: 'document.trefwoorden' },
|
|
139
|
-
{ key: 'informatieobjecttype', label: 'document.informatieobjecttype' },
|
|
140
|
-
{ key: 'language', label: 'document.language' },
|
|
141
|
-
{ key: 'identification', label: 'document.id' },
|
|
142
|
-
{ key: 'confidentialityLevel', label: 'document.confidentialityLevel' },
|
|
143
|
-
{ key: 'receiptDate', label: 'document.receiptDate' },
|
|
144
|
-
{ key: 'sendDate', label: 'document.sendDate' },
|
|
145
|
-
{ key: 'status', label: 'document.status' },
|
|
146
|
-
];
|
|
147
|
-
this.fields = [...this.getFields(fieldOptions, this.fieldsConfig)];
|
|
157
|
+
onDeleteActionClick(item) {
|
|
158
|
+
this.document = item;
|
|
159
|
+
this.showDeleteConfirmationModal$.next(true);
|
|
160
|
+
}
|
|
161
|
+
deleteDocument() {
|
|
162
|
+
this._itemsLoading$.next(true);
|
|
163
|
+
this.documentenApiDocumentService.deleteDocument(this.document).subscribe(() => {
|
|
164
|
+
this.refetchDocuments();
|
|
165
|
+
});
|
|
148
166
|
}
|
|
149
167
|
bytesToMegabytes(bytes) {
|
|
168
|
+
if (!bytes)
|
|
169
|
+
return '';
|
|
150
170
|
const megabytes = bytes / (1024 * 1024);
|
|
151
171
|
if (megabytes < 1) {
|
|
152
172
|
return `${Math.ceil(megabytes * 1000)} KB`;
|
|
@@ -168,44 +188,56 @@ export class DossierDetailTabDocumentenApiDocumentsComponent {
|
|
|
168
188
|
isUserAdmin() {
|
|
169
189
|
this.userProviderService.getUserSubject().subscribe(userIdentity => {
|
|
170
190
|
this.isAdmin = userIdentity.roles.includes('ROLE_ADMIN');
|
|
171
|
-
},
|
|
191
|
+
}, () => {
|
|
172
192
|
this.isAdmin = false;
|
|
173
193
|
});
|
|
174
194
|
}
|
|
175
195
|
metadataSet(metadata) {
|
|
176
196
|
this.uploading$.next(true);
|
|
177
|
-
this.
|
|
178
|
-
combineLatest([this.fileToBeUploaded$, this._documentId$])
|
|
197
|
+
combineLatest([this.fileToBeUploaded$, this.documentId$])
|
|
179
198
|
.pipe(take(1))
|
|
180
199
|
.pipe(tap(([file, documentId]) => {
|
|
181
200
|
if (!file)
|
|
182
201
|
return;
|
|
183
|
-
this.
|
|
184
|
-
.
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
}
|
|
202
|
+
if (this.isEditMode$.getValue()) {
|
|
203
|
+
this.documentenApiDocumentService.updateDocument(file, metadata).subscribe(() => {
|
|
204
|
+
this.refetchDocuments();
|
|
205
|
+
this.uploading$.next(false);
|
|
206
|
+
this.fileToBeUploaded$.next(null);
|
|
207
|
+
});
|
|
208
|
+
}
|
|
209
|
+
else {
|
|
210
|
+
this.uploadProviderService
|
|
211
|
+
.uploadFileWithMetadata(file, documentId, metadata)
|
|
212
|
+
.subscribe(() => {
|
|
213
|
+
this.refetchDocuments();
|
|
214
|
+
this.filter$.next(null);
|
|
215
|
+
this.uploading$.next(false);
|
|
216
|
+
this.fileToBeUploaded$.next(null);
|
|
217
|
+
});
|
|
218
|
+
}
|
|
190
219
|
}))
|
|
191
220
|
.subscribe();
|
|
192
221
|
}
|
|
193
|
-
onDeleteActionClick(item) {
|
|
194
|
-
this.loading$.next(true);
|
|
195
|
-
this.documentenApiDocumentService.deleteDocument(item).subscribe(() => {
|
|
196
|
-
// TODO: Use refetchDocuments() or should we just remove the document from relatedFiles$?
|
|
197
|
-
this.refetchDocuments();
|
|
198
|
-
});
|
|
199
|
-
}
|
|
200
222
|
onDownloadActionClick(file) {
|
|
201
223
|
this.downloadDocument(file, true);
|
|
202
224
|
}
|
|
225
|
+
onEditMetadata(file) {
|
|
226
|
+
this.isEditMode$.next(true);
|
|
227
|
+
this.fileToBeUploaded$.next(file);
|
|
228
|
+
this.showUploadModal$.next(true);
|
|
229
|
+
}
|
|
230
|
+
closeMetadataModal() {
|
|
231
|
+
this.showUploadModal$.next(false);
|
|
232
|
+
}
|
|
203
233
|
onFileSelected(event) {
|
|
234
|
+
this.isEditMode$.next(false);
|
|
204
235
|
this.fileToBeUploaded$.next(event.target.files[0]);
|
|
205
|
-
this.
|
|
236
|
+
this.showUploadModal$.next(true);
|
|
237
|
+
this.resetFileInput();
|
|
206
238
|
}
|
|
207
239
|
onNavigateToCaseAdminClick() {
|
|
208
|
-
this.
|
|
240
|
+
this.documentDefinitionName$.pipe(take(1)).subscribe(documentDefinitionName => {
|
|
209
241
|
this.router.navigate([`/dossier-management/dossier/${documentDefinitionName}`]);
|
|
210
242
|
});
|
|
211
243
|
}
|
|
@@ -215,17 +247,42 @@ export class DossierDetailTabDocumentenApiDocumentsComponent {
|
|
|
215
247
|
onUploadButtonClick() {
|
|
216
248
|
this.fileInput.nativeElement.click();
|
|
217
249
|
}
|
|
250
|
+
onFilterEvent(filter) {
|
|
251
|
+
this.filter$.next(filter);
|
|
252
|
+
}
|
|
253
|
+
onSortChanged(sortState) {
|
|
254
|
+
this._sort$.next(sortState.isSorting
|
|
255
|
+
? {
|
|
256
|
+
sort: `${sortState.state.name === 'size' ? DOCUMENTEN_COLUMN_KEYS.BESTANDSOMVANG : sortState.state.name},${sortState.state.direction}`,
|
|
257
|
+
}
|
|
258
|
+
: null);
|
|
259
|
+
}
|
|
218
260
|
refetchDocuments() {
|
|
219
261
|
this._refetch$.next(null);
|
|
220
262
|
}
|
|
263
|
+
editDisabled(file) {
|
|
264
|
+
return file.status === 'definitief';
|
|
265
|
+
}
|
|
221
266
|
downloadDocument(relatedFile, forceDownload) {
|
|
222
|
-
this.downloadService.downloadFile(`/api/v1/documenten-api/${relatedFile.pluginConfigurationId}/files/${relatedFile.fileId}/download`, relatedFile.
|
|
267
|
+
this.downloadService.downloadFile(`/api/v1/documenten-api/${relatedFile.pluginConfigurationId}/files/${relatedFile.fileId}/download`, relatedFile.bestandsnaam ?? '', forceDownload);
|
|
268
|
+
}
|
|
269
|
+
openQueryParamsSubscription() {
|
|
270
|
+
combineLatest([
|
|
271
|
+
this.documentDefinitionName$,
|
|
272
|
+
this.documentId$,
|
|
273
|
+
this.filter$,
|
|
274
|
+
this._sort$,
|
|
275
|
+
]).subscribe(([definitionName, documentId, filter, sort]) => {
|
|
276
|
+
this.router.navigate([`/dossiers/${definitionName}/document/${documentId}/documents`], {
|
|
277
|
+
queryParams: { ...filter, ...sort },
|
|
278
|
+
});
|
|
279
|
+
});
|
|
223
280
|
}
|
|
224
|
-
|
|
225
|
-
|
|
281
|
+
resetFileInput() {
|
|
282
|
+
this.fileInput.nativeElement.value = '';
|
|
226
283
|
}
|
|
227
284
|
setUploadProcessLinked() {
|
|
228
|
-
this.
|
|
285
|
+
this.documentDefinitionName$
|
|
229
286
|
.pipe(switchMap(documentDefinitionName => this.uploadProviderService.checkUploadProcessLink(documentDefinitionName)), take(1), tap(() => {
|
|
230
287
|
this.uploadProcessLinkedSet = true;
|
|
231
288
|
}))
|
|
@@ -233,8 +290,19 @@ export class DossierDetailTabDocumentenApiDocumentsComponent {
|
|
|
233
290
|
this.uploadProcessLinked = linked;
|
|
234
291
|
});
|
|
235
292
|
}
|
|
236
|
-
|
|
237
|
-
|
|
293
|
+
setInitialFilterAndSort() {
|
|
294
|
+
this.route.queryParamMap
|
|
295
|
+
.pipe(take(1), map(queryParams => {
|
|
296
|
+
const { sort, ...filter } = queryParams['params'];
|
|
297
|
+
return { sort, filter };
|
|
298
|
+
}))
|
|
299
|
+
.subscribe(({ filter, sort }) => {
|
|
300
|
+
this._sort$.next({ sort });
|
|
301
|
+
this.filter$.next(filter);
|
|
302
|
+
});
|
|
303
|
+
}
|
|
304
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.3", ngImport: i0, type: DossierDetailTabDocumentenApiDocumentsComponent, deps: [{ token: i1.ActivatedRoute }, { token: i1.Router }, { token: i2.UploadProviderService }, { token: i2.DownloadService }, { token: i3.TranslateService }, { token: i4.ConfigService }, { token: i5.UserProviderService }, { token: i6.IconService }, { token: i7.DocumentenApiDocumentService }, { token: i8.DocumentenApiColumnService }, { token: i8.DocumentenApiVersionService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
305
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.3", type: DossierDetailTabDocumentenApiDocumentsComponent, isStandalone: true, selector: "valtimo-dossier-detail-tab-documenten-api-documents", viewQueries: [{ propertyName: "fileInput", first: true, predicate: ["fileInput"], descendants: true }, { propertyName: "translationTemplate", first: true, predicate: ["translationTemplate"], 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<div\n class=\"carbon-document-table-wrapper\"\n *ngIf=\"{\n loading: loading$ | async,\n fieldsLoading: fieldsLoading$ | async,\n uploading: uploading$ | async,\n relatedFiles: relatedFiles$ | async,\n fields: fields$ | async,\n initialSortState: initialSortState$ | async,\n supportedDocumentenApiFeatures: supportedDocumentenApiFeatures$ | async\n } as obs\"\n>\n @if ((!obs.fieldsLoading && obs.fields.length) || obs.fieldsLoading) {\n <valtimo-carbon-list\n [actionItems]=\"actionItems\"\n [items]=\"obs.relatedFiles\"\n [fields]=\"obs.fields\"\n [loading]=\"obs.loading\"\n [initialSortState]=\"\n obs?.supportedDocumentenApiFeatures?.supportsSortableColumns && obs.initialSortState\n \"\n (rowClicked)=\"onRowClick($event)\"\n (sortChanged)=\"\n obs?.supportedDocumentenApiFeatures?.supportsSortableColumns && onSortChanged($event)\n \"\n hideColumnHeader\n >\n <div carbonToolbarContent>\n <input\n [accept]=\"acceptedFiles\"\n (change)=\"onFileSelected($event)\"\n hidden\n type=\"file\"\n #fileInput\n />\n\n <button\n *ngIf=\"obs?.supportedDocumentenApiFeatures?.supportsFilterableColumns\"\n [cdsOverflowMenu]=\"overflowFilter\"\n [customPane]=\"true\"\n [iconOnly]=\"true\"\n [flip]=\"true\"\n [offset]=\"{x: 0, y: 47}\"\n cdsButton=\"ghost\"\n placement=\"bottom\"\n >\n <svg class=\"cds--btn__icon\" cdsIcon=\"filter\" size=\"16\"></svg>\n </button>\n\n <ng-container *ngTemplateOutlet=\"uploadButton\"></ng-container>\n </div>\n\n <ng-container *ngTemplateOutlet=\"noResults\"></ng-container>\n </valtimo-carbon-list>\n } @else {\n <valtimo-no-results\n [action]=\"navigateToCaseAdminButton\"\n [description]=\"'zgw.documents.noColumns.description' | translate\"\n [title]=\"'zgw.documents.noColumns.title' | translate\"\n ></valtimo-no-results>\n }\n\n <valtimo-documenten-api-metadata-modal\n [open]=\"showUploadModal$ | async\"\n [disabled$]=\"modalDisabled$\"\n [file$]=\"fileToBeUploaded$\"\n [isEditMode]=\"isEditMode$ | async\"\n [supportsTrefwoorden]=\"obs?.supportedDocumentenApiFeatures?.supportsTrefwoorden\"\n (modalClose)=\"closeMetadataModal()\"\n (metadata)=\"metadataSet($event)\"\n ></valtimo-documenten-api-metadata-modal>\n</div>\n\n<valtimo-confirmation-modal\n confirmButtonTextTranslationKey=\"dashboardManagement.deleteModal.confirm\"\n contentTranslationKey=\"dossier.documenten.deleteConfirmationModal.content\"\n confirmButtonType=\"danger\"\n titleTranslationKey=\"dossier.documenten.deleteConfirmationModal.title\"\n [showModalSubject$]=\"showDeleteConfirmationModal$\"\n (confirmEvent)=\"deleteDocument()\"\n>\n</valtimo-confirmation-modal>\n\n<ng-template #downloadButton let-index=\"index\" let-item=\"item\">\n <div\n *ngIf=\"{isDownloading: indexesIncludeIndex(downloadingFileIndexes$ | async, index)} as vars\"\n class=\"download-button-container\"\n >\n <button\n *ngIf=\"!vars.isDownloading\"\n cdsButton=\"primary\"\n size=\"sm\"\n (click)=\"downloadDocument(item, index)\"\n >\n {{ 'interface.download' | translate }}\n\n <svg class=\"cds--btn__icon\" cdsIcon=\"download\" size=\"16\"></svg>\n </button>\n\n <cds-loading size=\"sm\" *ngIf=\"vars.isDownloading\"></cds-loading>\n </div>\n</ng-template>\n\n<ng-template #noResults>\n @if ((filter$ | async | keyvalue)?.length) {\n <valtimo-no-results\n [action]=\"resetFilterButton\"\n [description]=\"'zgw.documents.noResults.filterDescription' | translate\"\n [title]=\"'zgw.documents.noResults.filterTitle' | translate\"\n ></valtimo-no-results>\n } @else if (showZaakLinkWarning && isAdmin) {\n <valtimo-no-results\n [action]=\"navigateToCaseAdminButton\"\n [description]=\"'dossier.documenten.noZaakFound' | translate\"\n [title]=\"'dossier.documenten.noZaakFoundTitle' | translate\"\n ></valtimo-no-results>\n } @else {\n <valtimo-no-results\n [action]=\"uploadButton\"\n [description]=\"'dossier.documenten.noFiles' | translate\"\n [title]=\"'dossier.documenten.noFilesTitle' | translate\"\n ></valtimo-no-results>\n }\n</ng-template>\n\n<ng-template #overflowFilter>\n <valtimo-dossier-detail-tab-documenten-api-filter\n [prefillFilter]=\"filter$ | async\"\n (filterEvent)=\"onFilterEvent($event)\"\n ></valtimo-dossier-detail-tab-documenten-api-filter>\n</ng-template>\n\n<ng-template #resetFilterButton>\n <button cdsButton=\"primary\" (click)=\"onFilterEvent(null)\">\n {{ 'Reset filter' | translate }}\n\n <svg class=\"cds--btn__icon\" cdsIcon=\"trash-can\" size=\"16\"></svg>\n </button>\n</ng-template>\n\n<ng-template #uploadButton let-disabled=\"disabled\">\n <button\n [disabled]=\"(uploadProcessLinkedSet && !uploadProcessLinked) || showZaakLinkWarning || disabled\"\n [vTooltip]=\"getUploadButtonTooltip() | translate\"\n (click)=\"onUploadButtonClick()\"\n cdsButton=\"primary\"\n >\n {{ 'Upload' | translate }}\n <svg class=\"cds--btn__icon\" cdsIcon=\"upload\" size=\"16\"></svg>\n </button>\n</ng-template>\n\n<ng-template #translationTemplate let-data=\"data\">\n {{ 'document.' + data.item[data.key] | translate }}\n</ng-template>\n\n<ng-template #navigateToCaseAdminButton>\n <button (click)=\"onNavigateToCaseAdminClick()\" cdsButton=\"primary\">\n {{ 'dossier.documenten.navigateToCaseAdmin' | translate }}\n\n <svg class=\"cds--btn__icon\" cdsIcon=\"settings\" size=\"16\"></svg>\n </button>\n</ng-template>\n", styles: [".hidden{display:none}.loading-container{padding:var(--cds-grid-margin);display:flex;align-items:center;justify-content:center}.carbon-document-table-wrapper{margin:0}.documenten-api-documents-filesize-template{text-align:right}::ng-deep .cds--overflow-menu-options.cds--overflow-menu-options--open{max-width:max-content!important;width:max-content!important}\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: i9.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i9.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "pipe", type: i9.AsyncPipe, name: "async" }, { kind: "pipe", type: i9.KeyValuePipe, name: "keyvalue" }, { kind: "ngmodule", type: CarbonListModule }, { kind: "component", type: i10.CarbonListComponent, selector: "valtimo-carbon-list", inputs: ["items", "fields", "tableTranslations", "paginatorConfig", "pagination", "loading", "actions", "actionItems", "header", "hideColumnHeader", "initialSortState", "sortState", "isSearchable", "enableSingleSelection", "lastColumnTemplate", "paginationIdentifier", "showSelectionColumn", "striped", "hideToolbar", "lockedTooltipTranslationKey", "movingRowsEnabled", "dragAndDrop", "dragAndDropDisabled"], outputs: ["rowClicked", "paginationClicked", "paginationSet", "search", "sortChanged", "moveRow", "itemsReordered"] }, { kind: "component", type: i10.CarbonNoResultsComponent, selector: "valtimo-no-results", inputs: ["action", "description", "illustration", "title", "smallPadding", "collapseVertically", "alwaysRenderVertically"] }, { kind: "component", type: DocumentenApiMetadataModalComponent, selector: "valtimo-documenten-api-metadata-modal", inputs: ["disabled$", "file$", "author", "confidentialityLevel", "description", "disableAuthor", "disableConfidentialityLevel", "disableDescription", "disableDocumentTitle", "disableDocumentType", "disableFilename", "disableLanguage", "disableStatus", "documentTitle", "documentType", "disableTrefwoorden", "filename", "isEditMode", "language", "open", "status", "supportsTrefwoorden"], outputs: ["metadata", "modalClose"] }, { kind: "ngmodule", type: ButtonModule }, { kind: "directive", type: i6.Button, selector: "[cdsButton], [ibmButton]", inputs: ["ibmButton", "cdsButton", "size", "skeleton", "iconOnly", "isExpressive"] }, { kind: "ngmodule", type: IconModule }, { kind: "directive", type: i6.IconDirective, selector: "[cdsIcon], [ibmIcon]", inputs: ["ibmIcon", "cdsIcon", "size", "title", "ariaLabel", "ariaLabelledBy", "ariaHidden", "isFocusable"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i3.TranslatePipe, name: "translate" }, { kind: "component", type: DocumentenApiFilterComponent, selector: "valtimo-dossier-detail-tab-documenten-api-filter", outputs: ["filterEvent"] }, { kind: "ngmodule", type: DialogModule }, { kind: "directive", type: i6.OverflowMenuDirective, selector: "[cdsOverflowMenu], [ibmOverflowMenu]", inputs: ["ibmOverflowMenu", "cdsOverflowMenu", "flip", "offset", "wrapperClass", "customPane"], exportAs: ["overflowMenu"] }, { kind: "ngmodule", type: ConfirmationModalModule }, { kind: "component", type: i10.ConfirmationModalComponent, selector: "valtimo-confirmation-modal", inputs: ["titleTranslationKey", "title", "content", "contentTranslationKey", "confirmButtonText", "confirmButtonTextTranslationKey", "confirmButtonType", "showOptionalButton", "optionalButtonText", "optionalButtonTextTranslationKey", "optionalButtonType", "cancelButtonText", "cancelButtonTextTranslationKey", "cancelButtonType", "showModalSubject$", "outputOnConfirm", "outputOnOptional", "spacerAfterCancelButton"], outputs: ["confirmEvent", "optionalEvent", "cancelEvent"] }] }); }
|
|
238
306
|
}
|
|
239
307
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.3", ngImport: i0, type: DossierDetailTabDocumentenApiDocumentsComponent, decorators: [{
|
|
240
308
|
type: Component,
|
|
@@ -245,12 +313,15 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.3", ngImpor
|
|
|
245
313
|
ButtonModule,
|
|
246
314
|
IconModule,
|
|
247
315
|
TranslateModule,
|
|
248
|
-
|
|
249
|
-
|
|
316
|
+
DocumentenApiFilterComponent,
|
|
317
|
+
DialogModule,
|
|
318
|
+
ConfirmationModalModule,
|
|
319
|
+
], 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<div\n class=\"carbon-document-table-wrapper\"\n *ngIf=\"{\n loading: loading$ | async,\n fieldsLoading: fieldsLoading$ | async,\n uploading: uploading$ | async,\n relatedFiles: relatedFiles$ | async,\n fields: fields$ | async,\n initialSortState: initialSortState$ | async,\n supportedDocumentenApiFeatures: supportedDocumentenApiFeatures$ | async\n } as obs\"\n>\n @if ((!obs.fieldsLoading && obs.fields.length) || obs.fieldsLoading) {\n <valtimo-carbon-list\n [actionItems]=\"actionItems\"\n [items]=\"obs.relatedFiles\"\n [fields]=\"obs.fields\"\n [loading]=\"obs.loading\"\n [initialSortState]=\"\n obs?.supportedDocumentenApiFeatures?.supportsSortableColumns && obs.initialSortState\n \"\n (rowClicked)=\"onRowClick($event)\"\n (sortChanged)=\"\n obs?.supportedDocumentenApiFeatures?.supportsSortableColumns && onSortChanged($event)\n \"\n hideColumnHeader\n >\n <div carbonToolbarContent>\n <input\n [accept]=\"acceptedFiles\"\n (change)=\"onFileSelected($event)\"\n hidden\n type=\"file\"\n #fileInput\n />\n\n <button\n *ngIf=\"obs?.supportedDocumentenApiFeatures?.supportsFilterableColumns\"\n [cdsOverflowMenu]=\"overflowFilter\"\n [customPane]=\"true\"\n [iconOnly]=\"true\"\n [flip]=\"true\"\n [offset]=\"{x: 0, y: 47}\"\n cdsButton=\"ghost\"\n placement=\"bottom\"\n >\n <svg class=\"cds--btn__icon\" cdsIcon=\"filter\" size=\"16\"></svg>\n </button>\n\n <ng-container *ngTemplateOutlet=\"uploadButton\"></ng-container>\n </div>\n\n <ng-container *ngTemplateOutlet=\"noResults\"></ng-container>\n </valtimo-carbon-list>\n } @else {\n <valtimo-no-results\n [action]=\"navigateToCaseAdminButton\"\n [description]=\"'zgw.documents.noColumns.description' | translate\"\n [title]=\"'zgw.documents.noColumns.title' | translate\"\n ></valtimo-no-results>\n }\n\n <valtimo-documenten-api-metadata-modal\n [open]=\"showUploadModal$ | async\"\n [disabled$]=\"modalDisabled$\"\n [file$]=\"fileToBeUploaded$\"\n [isEditMode]=\"isEditMode$ | async\"\n [supportsTrefwoorden]=\"obs?.supportedDocumentenApiFeatures?.supportsTrefwoorden\"\n (modalClose)=\"closeMetadataModal()\"\n (metadata)=\"metadataSet($event)\"\n ></valtimo-documenten-api-metadata-modal>\n</div>\n\n<valtimo-confirmation-modal\n confirmButtonTextTranslationKey=\"dashboardManagement.deleteModal.confirm\"\n contentTranslationKey=\"dossier.documenten.deleteConfirmationModal.content\"\n confirmButtonType=\"danger\"\n titleTranslationKey=\"dossier.documenten.deleteConfirmationModal.title\"\n [showModalSubject$]=\"showDeleteConfirmationModal$\"\n (confirmEvent)=\"deleteDocument()\"\n>\n</valtimo-confirmation-modal>\n\n<ng-template #downloadButton let-index=\"index\" let-item=\"item\">\n <div\n *ngIf=\"{isDownloading: indexesIncludeIndex(downloadingFileIndexes$ | async, index)} as vars\"\n class=\"download-button-container\"\n >\n <button\n *ngIf=\"!vars.isDownloading\"\n cdsButton=\"primary\"\n size=\"sm\"\n (click)=\"downloadDocument(item, index)\"\n >\n {{ 'interface.download' | translate }}\n\n <svg class=\"cds--btn__icon\" cdsIcon=\"download\" size=\"16\"></svg>\n </button>\n\n <cds-loading size=\"sm\" *ngIf=\"vars.isDownloading\"></cds-loading>\n </div>\n</ng-template>\n\n<ng-template #noResults>\n @if ((filter$ | async | keyvalue)?.length) {\n <valtimo-no-results\n [action]=\"resetFilterButton\"\n [description]=\"'zgw.documents.noResults.filterDescription' | translate\"\n [title]=\"'zgw.documents.noResults.filterTitle' | translate\"\n ></valtimo-no-results>\n } @else if (showZaakLinkWarning && isAdmin) {\n <valtimo-no-results\n [action]=\"navigateToCaseAdminButton\"\n [description]=\"'dossier.documenten.noZaakFound' | translate\"\n [title]=\"'dossier.documenten.noZaakFoundTitle' | translate\"\n ></valtimo-no-results>\n } @else {\n <valtimo-no-results\n [action]=\"uploadButton\"\n [description]=\"'dossier.documenten.noFiles' | translate\"\n [title]=\"'dossier.documenten.noFilesTitle' | translate\"\n ></valtimo-no-results>\n }\n</ng-template>\n\n<ng-template #overflowFilter>\n <valtimo-dossier-detail-tab-documenten-api-filter\n [prefillFilter]=\"filter$ | async\"\n (filterEvent)=\"onFilterEvent($event)\"\n ></valtimo-dossier-detail-tab-documenten-api-filter>\n</ng-template>\n\n<ng-template #resetFilterButton>\n <button cdsButton=\"primary\" (click)=\"onFilterEvent(null)\">\n {{ 'Reset filter' | translate }}\n\n <svg class=\"cds--btn__icon\" cdsIcon=\"trash-can\" size=\"16\"></svg>\n </button>\n</ng-template>\n\n<ng-template #uploadButton let-disabled=\"disabled\">\n <button\n [disabled]=\"(uploadProcessLinkedSet && !uploadProcessLinked) || showZaakLinkWarning || disabled\"\n [vTooltip]=\"getUploadButtonTooltip() | translate\"\n (click)=\"onUploadButtonClick()\"\n cdsButton=\"primary\"\n >\n {{ 'Upload' | translate }}\n <svg class=\"cds--btn__icon\" cdsIcon=\"upload\" size=\"16\"></svg>\n </button>\n</ng-template>\n\n<ng-template #translationTemplate let-data=\"data\">\n {{ 'document.' + data.item[data.key] | translate }}\n</ng-template>\n\n<ng-template #navigateToCaseAdminButton>\n <button (click)=\"onNavigateToCaseAdminClick()\" cdsButton=\"primary\">\n {{ 'dossier.documenten.navigateToCaseAdmin' | translate }}\n\n <svg class=\"cds--btn__icon\" cdsIcon=\"settings\" size=\"16\"></svg>\n </button>\n</ng-template>\n", styles: [".hidden{display:none}.loading-container{padding:var(--cds-grid-margin);display:flex;align-items:center;justify-content:center}.carbon-document-table-wrapper{margin:0}.documenten-api-documents-filesize-template{text-align:right}::ng-deep .cds--overflow-menu-options.cds--overflow-menu-options--open{max-width:max-content!important;width:max-content!important}\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"] }]
|
|
320
|
+
}], ctorParameters: () => [{ type: i1.ActivatedRoute }, { type: i1.Router }, { type: i2.UploadProviderService }, { type: i2.DownloadService }, { type: i3.TranslateService }, { type: i4.ConfigService }, { type: i5.UserProviderService }, { type: i6.IconService }, { type: i7.DocumentenApiDocumentService }, { type: i8.DocumentenApiColumnService }, { type: i8.DocumentenApiVersionService }], propDecorators: { fileInput: [{
|
|
250
321
|
type: ViewChild,
|
|
251
322
|
args: ['fileInput']
|
|
252
|
-
}],
|
|
323
|
+
}], translationTemplate: [{
|
|
253
324
|
type: ViewChild,
|
|
254
|
-
args: ['
|
|
325
|
+
args: ['translationTemplate']
|
|
255
326
|
}] } });
|
|
256
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"documenten-api-documents.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/valtimo/zgw/src/lib/modules/documenten-api/components/documenten-api-documents/documenten-api-documents.component.ts","../../../../../../../../../projects/valtimo/zgw/src/lib/modules/documenten-api/components/documenten-api-documents/documenten-api-documents.component.html"],"names":[],"mappings":"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","sourcesContent":["/*\n * Copyright 2015-2024 Ritense BV, the Netherlands.\n *\n * Licensed under EUPL, Version 1.2 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" basis,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\nimport {AfterViewInit, Component, ElementRef, OnInit, TemplateRef, ViewChild} from '@angular/core';\nimport {ActivatedRoute, Router} from '@angular/router';\nimport {Filter16, TagGroup16, Upload16} from '@carbon/icons';\nimport {TranslateModule, TranslateService} from '@ngx-translate/core';\nimport {\n  ActionItem,\n  CarbonListModule,\n  ColumnConfig,\n  DocumentenApiMetadata,\n  ViewType,\n} from '@valtimo/components';\nimport {ConfigService} from '@valtimo/config';\nimport {FileSortService} from '@valtimo/document';\nimport {DownloadService, UploadProviderService} from '@valtimo/resource';\nimport {UserProviderService} from '@valtimo/security';\nimport {ButtonModule, IconModule, IconService} from 'carbon-components-angular';\nimport moment from 'moment';\nimport {BehaviorSubject, combineLatest, Observable, of, Subject} from 'rxjs';\nimport {catchError, filter, map, switchMap, take, tap} from 'rxjs/operators';\nimport {DocumentenApiRelatedFile, DocumentenApiRelatedFileListItem} from '../../models';\nimport {DocumentenApiDocumentService} from '../../services/documenten-api-document.service';\nimport {DocumentenApiMetadataModalComponent} from '../documenten-api-metadata-modal/documenten-api-metadata-modal.component';\nimport {CommonModule} from '@angular/common';\n\n@Component({\n  selector: 'valtimo-dossier-detail-tab-documenten-api-documents',\n  templateUrl: './documenten-api-documents.component.html',\n  styleUrls: ['./documenten-api-documents.component.scss'],\n  standalone: true,\n  imports: [\n    CommonModule,\n    CarbonListModule,\n    DocumentenApiMetadataModalComponent,\n    ButtonModule,\n    IconModule,\n    TranslateModule,\n  ],\n})\nexport class DossierDetailTabDocumentenApiDocumentsComponent implements OnInit, AfterViewInit {\n  @ViewChild('fileInput') fileInput: ElementRef;\n  @ViewChild('sizeTemplate') public sizeTemplate: TemplateRef<any>;\n\n  public fields: ColumnConfig[];\n  public actionItems: ActionItem[] = [\n    {\n      label: 'document.download',\n      callback: this.onDownloadActionClick.bind(this),\n      type: 'normal',\n    },\n    {\n      label: 'document.delete',\n      callback: this.onDeleteActionClick.bind(this),\n      type: 'danger',\n    },\n  ];\n  public fieldsConfig = [\n    // TODO: Refactor this once admin page config is implemented\n    'title',\n    'fileName',\n    'format',\n    'size',\n    'description',\n    'createdOn',\n    'createdBy',\n    'author',\n    'informatieobjecttype',\n    'actions',\n  ];\n\n  private readonly _documentDefinitionName$: Observable<string> = this.route.params.pipe(\n    map(params => params?.documentDefinitionName),\n    filter(documentDefinitionName => !!documentDefinitionName)\n  );\n\n  private readonly _documentId$: Observable<string> = this.route.params.pipe(\n    map(params => params?.documentId),\n    filter(documentId => !!documentId)\n  );\n\n  public isAdmin: boolean;\n  public showZaakLinkWarning: boolean;\n  public uploadProcessLinkedSet = false;\n  public uploadProcessLinked!: boolean;\n\n  public readonly acceptedFiles: string | null =\n    this.configService?.config?.caseFileUploadAcceptedFiles || null;\n  public readonly maxFileSize: number = this.configService?.config?.caseFileSizeUploadLimitMB || 5;\n\n  public readonly fileToBeUploaded$ = new BehaviorSubject<File | null>(null);\n  public readonly hideModal$ = new Subject<null>();\n  public readonly modalDisabled$ = new BehaviorSubject<boolean>(false);\n  public readonly showModal$ = new Subject<null>();\n\n  public readonly uploading$ = new BehaviorSubject<boolean>(false);\n  public readonly loading$ = new BehaviorSubject<boolean>(true);\n\n  private readonly _refetch$ = new BehaviorSubject<null>(null);\n\n  public relatedFiles$: Observable<Array<DocumentenApiRelatedFileListItem>> = combineLatest([\n    this._documentId$,\n    this._refetch$,\n  ]).pipe(\n    tap(() => this.loading$.next(true)),\n    switchMap(([documentId]) =>\n      combineLatest([\n        this.documentenApiDocumentService.getZakenApiDocuments(documentId),\n        this.translateService.stream('key'),\n      ])\n    ),\n    map(([relatedFiles]) => {\n      const translatedFiles = relatedFiles?.map(file => ({\n        ...file,\n        createdBy: file.createdBy || this.translateService.instant('list.automaticallyGenerated'),\n        language: this.translateService.instant(`document.${file.language}`),\n        confidentialityLevel: this.translateService.instant(\n          `document.${file.confidentialityLevel}`\n        ),\n        status: this.translateService.instant(`document.${file.status}`),\n        format: this.translateService.instant(`document.${file.format}`),\n      }));\n      return translatedFiles || [];\n    }),\n    map(relatedFiles => this.fileSortService.sortRelatedFilesByDateDescending(relatedFiles)),\n    map(relatedFiles => {\n      moment.locale(this.translateService.currentLang);\n      return relatedFiles.map(file => ({\n        ...file,\n        createdOn: moment(new Date(file.createdOn)).format('L'),\n        size: `${this.bytesToMegabytes(file.sizeInBytes)}`,\n      }));\n    }),\n    tap(() => {\n      this.loading$.next(false);\n    }),\n    catchError(() => {\n      this.showZaakLinkWarning = true;\n      this.loading$.next(false);\n      return of([]);\n    })\n  );\n\n  constructor(\n    private readonly route: ActivatedRoute,\n    private readonly router: Router,\n    private readonly uploadProviderService: UploadProviderService,\n    private readonly downloadService: DownloadService,\n    private readonly translateService: TranslateService,\n    private readonly configService: ConfigService,\n    private readonly userProviderService: UserProviderService,\n    private readonly fileSortService: FileSortService,\n    private readonly iconService: IconService,\n    private readonly documentenApiDocumentService: DocumentenApiDocumentService\n  ) {}\n\n  ngOnInit(): void {\n    this.refetchDocuments();\n    this.setUploadProcessLinked();\n    this.isUserAdmin();\n    this.iconService.registerAll([Filter16, TagGroup16, Upload16]);\n  }\n\n  public ngAfterViewInit(): void {\n    const fieldOptions = [\n      {key: 'title', label: 'document.inputTitle'},\n      {key: 'description', label: 'document.inputDescription'},\n      {key: 'fileName', label: 'document.filename'},\n      {\n        viewType: ViewType.TEMPLATE,\n        label: 'document.size',\n        key: 'size',\n        template: this.sizeTemplate,\n      },\n      {key: 'format', label: 'document.format'},\n      {key: 'createdOn', label: 'document.createdOn'},\n      {key: 'createdBy', label: 'document.createdBy'},\n      {key: 'author', label: 'document.author'},\n      {key: 'keywords', label: 'document.trefwoorden'},\n      {key: 'informatieobjecttype', label: 'document.informatieobjecttype'},\n      {key: 'language', label: 'document.language'},\n      {key: 'identification', label: 'document.id'},\n      {key: 'confidentialityLevel', label: 'document.confidentialityLevel'},\n      {key: 'receiptDate', label: 'document.receiptDate'},\n      {key: 'sendDate', label: 'document.sendDate'},\n      {key: 'status', label: 'document.status'},\n    ];\n\n    this.fields = [...this.getFields(fieldOptions, this.fieldsConfig)];\n  }\n\n  public bytesToMegabytes(bytes: number): string {\n    const megabytes = bytes / (1024 * 1024);\n    if (megabytes < 1) {\n      return `${Math.ceil(megabytes * 1000)} KB`;\n    } else if (megabytes < 1000) {\n      return megabytes.toFixed(2) + ' MB';\n    }\n\n    return (megabytes / 1000).toFixed(2) + ' GB';\n  }\n\n  public getUploadButtonTooltip(): string {\n    if (this.uploadProcessLinkedSet && this.uploadProcessLinked) {\n      return 'Upload';\n    } else if (this.isAdmin) {\n      return 'dossier.documenten.noProcessLinked.adminRole';\n    }\n\n    return 'dossier.documenten.noProcessLinked.regularUser';\n  }\n\n  public isUserAdmin() {\n    this.userProviderService.getUserSubject().subscribe(\n      userIdentity => {\n        this.isAdmin = userIdentity.roles.includes('ROLE_ADMIN');\n      },\n      error => {\n        this.isAdmin = false;\n      }\n    );\n  }\n\n  public metadataSet(metadata: DocumentenApiMetadata): void {\n    this.uploading$.next(true);\n    this.hideModal$.next(null);\n\n    combineLatest([this.fileToBeUploaded$, this._documentId$])\n      .pipe(take(1))\n      .pipe(\n        tap(([file, documentId]) => {\n          if (!file) return;\n\n          this.uploadProviderService\n            .uploadFileWithMetadata(file, documentId, metadata)\n            .subscribe(() => {\n              this.refetchDocuments();\n              this.uploading$.next(false);\n              this.fileToBeUploaded$.next(null);\n            });\n        })\n      )\n      .subscribe();\n  }\n\n  public onDeleteActionClick(item: DocumentenApiRelatedFile): void {\n    this.loading$.next(true);\n    this.documentenApiDocumentService.deleteDocument(item).subscribe(() => {\n      // TODO: Use refetchDocuments() or should we just remove the document from relatedFiles$?\n      this.refetchDocuments();\n    });\n  }\n\n  public onDownloadActionClick(file: DocumentenApiRelatedFile): void {\n    this.downloadDocument(file, true);\n  }\n\n  public onFileSelected(event: any): void {\n    this.fileToBeUploaded$.next(event.target.files[0]);\n    this.showModal$.next(null);\n  }\n\n  public onNavigateToCaseAdminClick(): void {\n    this._documentDefinitionName$.pipe(take(1)).subscribe(documentDefinitionName => {\n      this.router.navigate([`/dossier-management/dossier/${documentDefinitionName}`]);\n    });\n  }\n\n  public onRowClick(event: any): void {\n    this.downloadDocument(event, false);\n  }\n\n  public onUploadButtonClick(): void {\n    this.fileInput.nativeElement.click();\n  }\n\n  public refetchDocuments(): void {\n    this._refetch$.next(null);\n  }\n\n  private downloadDocument(relatedFile: DocumentenApiRelatedFile, forceDownload: boolean): void {\n    this.downloadService.downloadFile(\n      `/api/v1/documenten-api/${relatedFile.pluginConfigurationId}/files/${relatedFile.fileId}/download`,\n      relatedFile.fileName,\n      forceDownload\n    );\n  }\n\n  private getFields(fieldOptions, fieldsConfig) {\n    return fieldOptions.filter(fieldOption => fieldsConfig.includes(fieldOption.key));\n  }\n\n  private setUploadProcessLinked(): void {\n    this._documentDefinitionName$\n      .pipe(\n        switchMap(documentDefinitionName =>\n          this.uploadProviderService.checkUploadProcessLink(documentDefinitionName)\n        ),\n        take(1),\n        tap(() => {\n          this.uploadProcessLinkedSet = true;\n        })\n      )\n      .subscribe((linked: boolean) => {\n        this.uploadProcessLinked = linked;\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<div\n  class=\"carbon-document-table-wrapper\"\n  *ngIf=\"{\n    loading: loading$ | async,\n    uploading: uploading$ | async,\n    relatedFiles: relatedFiles$ | async\n  } as obs\"\n>\n  @if (!obs.loading && !obs.uploading && obs.relatedFiles) {\n    <ng-container\n      *ngTemplateOutlet=\"list; context: {relatedFiles: obs.relatedFiles}\"\n    ></ng-container>\n  } @else {\n    <ng-container *ngTemplateOutlet=\"listLoading\"></ng-container>\n  }\n</div>\n\n<valtimo-documenten-api-metadata-modal\n  [disabled$]=\"modalDisabled$\"\n  [file$]=\"fileToBeUploaded$\"\n  [hide$]=\"hideModal$\"\n  [show$]=\"showModal$\"\n  (metadata)=\"metadataSet($event)\"\n></valtimo-documenten-api-metadata-modal>\n\n<ng-template #list let-relatedFiles=\"relatedFiles\">\n  <valtimo-carbon-list\n    [actionItems]=\"actionItems\"\n    [items]=\"relatedFiles\"\n    [fields]=\"fields\"\n    (rowClicked)=\"onRowClick($event)\"\n    hideColumnHeader\n  >\n    <div carbonToolbarContent>\n      <input\n        [accept]=\"acceptedFiles\"\n        (change)=\"onFileSelected($event)\"\n        hidden\n        type=\"file\"\n        #fileInput\n      />\n\n      <ng-container *ngTemplateOutlet=\"uploadButton\"></ng-container>\n    </div>\n\n    @if (showZaakLinkWarning && isAdmin) {\n      <valtimo-no-results\n        [action]=\"navigateToCaseAdminButton\"\n        description=\"{{ 'dossier.documenten.noZaakFound' | translate }}\"\n        title=\"{{ 'dossier.documenten.noZaakFoundTitle' | translate }}\"\n      ></valtimo-no-results>\n    } @else {\n      <valtimo-no-results\n        [action]=\"uploadButton\"\n        description=\"{{ 'dossier.documenten.noFiles' | translate }}\"\n        title=\"{{ 'dossier.documenten.noFilesTitle' | translate }}\"\n      ></valtimo-no-results>\n    }\n  </valtimo-carbon-list>\n</ng-template>\n\n<ng-template #listLoading>\n  <valtimo-carbon-list [items]=\"[]\" [fields]=\"fields\" [loading]=\"true\" hideColumnHeader>\n    <div carbonToolbarContent>\n      <ng-container *ngTemplateOutlet=\"uploadButton; context: {disabled: true}\"></ng-container>\n    </div>\n  </valtimo-carbon-list>\n</ng-template>\n\n<ng-template #downloadButton let-index=\"index\" let-item=\"item\">\n  <div\n    *ngIf=\"{isDownloading: indexesIncludeIndex(downloadingFileIndexes$ | async, index)} as vars\"\n    class=\"download-button-container\"\n  >\n    <button\n      *ngIf=\"!vars.isDownloading\"\n      cdsButton=\"primary\"\n      size=\"sm\"\n      (click)=\"downloadDocument(item, index)\"\n    >\n      {{ 'interface.download' | translate }}\n\n      <svg class=\"cds--btn__icon\" cdsIcon=\"download\" size=\"16\"></svg>\n    </button>\n\n    <cds-loading size=\"sm\" *ngIf=\"vars.isDownloading\"></cds-loading>\n  </div>\n</ng-template>\n\n<ng-template #dossierListActions>\n  <input [accept]=\"acceptedFiles\" (change)=\"onFileSelected($event)\" hidden type=\"file\" #fileInput />\n  <ng-container *ngTemplateOutlet=\"uploadButton\"></ng-container>\n</ng-template>\n\n<ng-template #uploadButton let-disabled=\"disabled\">\n  <button\n    [disabled]=\"(uploadProcessLinkedSet && !uploadProcessLinked) || showZaakLinkWarning || disabled\"\n    [vTooltip]=\"getUploadButtonTooltip() | translate\"\n    (click)=\"onUploadButtonClick()\"\n    cdsButton=\"primary\"\n  >\n    {{ 'Upload' | translate }}\n    <svg class=\"cds--btn__icon\" cdsIcon=\"upload\" size=\"16\"></svg>\n  </button>\n</ng-template>\n\n<ng-template #navigateToCaseAdminButton>\n  <button (click)=\"onNavigateToCaseAdminClick()\" cdsButton=\"primary\">\n    {{ 'dossier.documenten.navigateToCaseAdmin' | translate }}\n    <svg class=\"cds--btn__icon\" cdsIcon=\"settings\" size=\"16\"></svg>\n  </button>\n</ng-template>\n\n<ng-template #sizeTemplate let-data=\"data\">\n  <div class=\"documenten-api-documents-filesize-template\">\n    {{ bytesToMegabytes(data.item.sizeInBytes) }}\n  </div>\n</ng-template>\n"]}
|
|
327
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"documenten-api-documents.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/valtimo/zgw/src/lib/modules/documenten-api/components/documenten-api-documents/documenten-api-documents.component.ts","../../../../../../../../../projects/valtimo/zgw/src/lib/modules/documenten-api/components/documenten-api-documents/documenten-api-documents.component.html"],"names":[],"mappings":"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","sourcesContent":["/*\n * Copyright 2015-2024 Ritense BV, the Netherlands.\n *\n * Licensed under EUPL, Version 1.2 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" basis,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\nimport {CommonModule} from '@angular/common';\nimport {Component, ElementRef, OnInit, TemplateRef, ViewChild} from '@angular/core';\nimport {ActivatedRoute, Router} from '@angular/router';\nimport {Filter16, TagGroup16, Upload16} from '@carbon/icons';\nimport {TranslateModule, TranslateService} from '@ngx-translate/core';\nimport {\n  ActionItem,\n  CarbonListModule,\n  ColumnConfig,\n  ConfirmationModalModule,\n  DocumentenApiMetadata,\n  SortState,\n  ViewType,\n} from '@valtimo/components';\nimport {ConfigService} from '@valtimo/config';\nimport {DownloadService, UploadProviderService} from '@valtimo/resource';\nimport {UserProviderService} from '@valtimo/security';\nimport {ButtonModule, DialogModule, IconModule, IconService} from 'carbon-components-angular';\nimport {BehaviorSubject, combineLatest, Observable, of, ReplaySubject, Subject} from 'rxjs';\nimport {catchError, filter, map, switchMap, take, tap} from 'rxjs/operators';\nimport {\n  COLUMN_VIEW_TYPES,\n  ConfiguredColumn,\n  DOCUMENTEN_COLUMN_KEYS,\n  DocumentenApiFilterModel,\n  DocumentenApiRelatedFile,\n  SupportedDocumentenApiFeatures,\n} from '../../models';\nimport {DocumentenApiColumnService, DocumentenApiVersionService} from '../../services';\nimport {DocumentenApiDocumentService} from '../../services/documenten-api-document.service';\nimport {DocumentenApiFilterComponent} from '../documenten-api-filter/documenten-api-filter.component';\nimport {DocumentenApiMetadataModalComponent} from '../documenten-api-metadata-modal/documenten-api-metadata-modal.component';\n\n@Component({\n  selector: 'valtimo-dossier-detail-tab-documenten-api-documents',\n  templateUrl: './documenten-api-documents.component.html',\n  styleUrls: ['./documenten-api-documents.component.scss'],\n  standalone: true,\n  imports: [\n    CommonModule,\n    CarbonListModule,\n    DocumentenApiMetadataModalComponent,\n    ButtonModule,\n    IconModule,\n    TranslateModule,\n    DocumentenApiFilterComponent,\n    DialogModule,\n    ConfirmationModalModule,\n  ],\n})\nexport class DossierDetailTabDocumentenApiDocumentsComponent implements OnInit {\n  @ViewChild('fileInput') fileInput: ElementRef;\n  @ViewChild('translationTemplate') translationTemplate: TemplateRef<any>;\n\n  private readonly _documentDefinitionName$ = this.route.params.pipe(\n    map(params => params?.documentDefinitionName),\n    filter(caseDefinitionName => !!caseDefinitionName)\n  );\n\n  public readonly supportedDocumentenApiFeatures$ =\n    new BehaviorSubject<SupportedDocumentenApiFeatures | null>(null);\n\n  private readonly _supportedDocumentenApiFeatures$: Observable<SupportedDocumentenApiFeatures> =\n    this._documentDefinitionName$.pipe(\n      switchMap(caseDefinitionName =>\n        this.documentenApiVersionService.getSupportedApiFeatures(caseDefinitionName)\n      ),\n      tap(supportedDocumentenApiFeatures =>\n        this.supportedDocumentenApiFeatures$.next(supportedDocumentenApiFeatures)\n      )\n    );\n\n  public readonly fields$: Observable<ColumnConfig[]> = this._documentDefinitionName$.pipe(\n    tap(() => this.fieldsLoading$.next(true)),\n    switchMap(documentDefinitionName =>\n      combineLatest([\n        this.documentenApiColumnService.getConfiguredColumns(documentDefinitionName),\n        this._supportedDocumentenApiFeatures$,\n      ])\n    ),\n    map(([columns, supportedDocumentenApiFeatures]) => {\n      const defaultSortColumn: ConfiguredColumn | undefined = columns.find(\n        (column: ConfiguredColumn) => !!column.defaultSort\n      );\n      if (!!defaultSortColumn && supportedDocumentenApiFeatures.supportsSortableColumns) {\n        this._sort$.next({sort: `${defaultSortColumn.key},${defaultSortColumn.defaultSort}`});\n      }\n\n      return columns.map((column: ConfiguredColumn) => ({\n        key: column.key === DOCUMENTEN_COLUMN_KEYS.BESTANDSOMVANG ? 'size' : column.key,\n        label: `zgw.documentColumns.${column.key}`,\n        viewType: !COLUMN_VIEW_TYPES[column.key] ? ViewType.TEXT : COLUMN_VIEW_TYPES[column.key],\n        ...(COLUMN_VIEW_TYPES[column.key] === ViewType.TEMPLATE && {\n          template: this.translationTemplate,\n          templateData: {key: column.key},\n        }),\n        ...(column.key === DOCUMENTEN_COLUMN_KEYS.CREATIEDATUM && {format: 'DD-MM-YYYY'}),\n        sortable: column.sortable && supportedDocumentenApiFeatures.supportsSortableColumns,\n      }));\n    }),\n    tap(() => this.fieldsLoading$.next(false))\n  );\n  public document: DocumentenApiRelatedFile;\n  public actionItems: ActionItem[] = [\n    {\n      label: 'document.download',\n      callback: this.onDownloadActionClick.bind(this),\n      type: 'normal',\n    },\n    {\n      label: 'document.edit',\n      callback: this.onEditMetadata.bind(this),\n      disabledCallback: this.editDisabled.bind(this),\n      type: 'normal',\n    },\n    {\n      label: 'document.delete',\n      callback: this.onDeleteActionClick.bind(this),\n      type: 'danger',\n    },\n  ];\n\n  public readonly documentDefinitionName$: Observable<string> = this.route.params.pipe(\n    map(params => params?.documentDefinitionName),\n    filter(documentDefinitionName => !!documentDefinitionName)\n  );\n\n  public readonly documentId$: Observable<string> = this.route.params.pipe(\n    map(params => params?.documentId),\n    filter(documentId => !!documentId)\n  );\n\n  public readonly initialSortState$: Observable<SortState | null> = this.route.queryParamMap.pipe(\n    map(params => params['params']),\n    map(params => {\n      if (!!params['sort']) {\n        const paramsSplit = params['sort'].split(',');\n        const state = {\n          name: paramsSplit[0],\n          direction: paramsSplit[1],\n        };\n\n        return {\n          isSorting: true,\n          state,\n        };\n      }\n      return null;\n    })\n  );\n\n  public isAdmin: boolean;\n  public showZaakLinkWarning: boolean;\n  public uploadProcessLinkedSet = false;\n  public uploadProcessLinked!: boolean;\n\n  public isEditMode$ = new BehaviorSubject<boolean>(false);\n\n  public readonly acceptedFiles: string | null =\n    this.configService?.config?.caseFileUploadAcceptedFiles || null;\n  public readonly maxFileSize: number = this.configService?.config?.caseFileSizeUploadLimitMB || 5;\n\n  public readonly fileToBeUploaded$ = new BehaviorSubject<File | null>(null);\n  public readonly modalDisabled$ = new BehaviorSubject<boolean>(false);\n  public readonly showModal$ = new Subject<null>();\n  public readonly showUploadModal$ = new BehaviorSubject<boolean>(false);\n  public readonly showDeleteConfirmationModal$ = new BehaviorSubject<boolean>(false);\n\n  public readonly uploading$ = new BehaviorSubject<boolean>(false);\n  private readonly _itemsLoading$ = new BehaviorSubject<boolean>(true);\n  public readonly fieldsLoading$ = new BehaviorSubject<boolean>(true);\n  public readonly loading$ = combineLatest([this._itemsLoading$, this.fieldsLoading$]).pipe(\n    map(([itemsLoading, fieldsLoading]) => itemsLoading || fieldsLoading)\n  );\n\n  public readonly filter$ = new ReplaySubject<DocumentenApiFilterModel | null>();\n  private readonly _refetch$ = new BehaviorSubject<null>(null);\n  private readonly _sort$ = new ReplaySubject<{sort: string} | null>();\n\n  public relatedFiles$: Observable<Array<DocumentenApiRelatedFile>> = combineLatest([\n    this.documentId$,\n    this.route.queryParamMap,\n    this._refetch$,\n  ]).pipe(\n    tap(() => this._itemsLoading$.next(true)),\n    switchMap(([documentId, queryParams]) =>\n      combineLatest([\n        this.documentenApiDocumentService.getFilteredZakenApiDocuments(\n          documentId,\n          queryParams['params']\n        ),\n        this.translateService.stream('key'),\n      ])\n    ),\n    map(([relatedFiles]) => {\n      const translatedFiles = relatedFiles?.content?.map(file => ({\n        ...file,\n        createdBy: file.createdBy || this.translateService.instant('list.automaticallyGenerated'),\n        size: this.bytesToMegabytes(file.bestandsomvang),\n        tags: file.trefwoorden?.map((trefwoord: string) => ({\n          content: trefwoord,\n        })),\n      }));\n      return translatedFiles || [];\n    }),\n    tap(() => {\n      this._itemsLoading$.next(false);\n    }),\n    catchError(() => {\n      this.showZaakLinkWarning = true;\n      this._itemsLoading$.next(false);\n      return of([]);\n    })\n  );\n\n  constructor(\n    private readonly route: ActivatedRoute,\n    private readonly router: Router,\n    private readonly uploadProviderService: UploadProviderService,\n    private readonly downloadService: DownloadService,\n    private readonly translateService: TranslateService,\n    private readonly configService: ConfigService,\n    private readonly userProviderService: UserProviderService,\n    private readonly iconService: IconService,\n    private readonly documentenApiDocumentService: DocumentenApiDocumentService,\n    private readonly documentenApiColumnService: DocumentenApiColumnService,\n    private readonly documentenApiVersionService: DocumentenApiVersionService\n  ) {\n    this.iconService.register(Filter16);\n  }\n\n  public ngOnInit(): void {\n    this.setInitialFilterAndSort();\n    this.openQueryParamsSubscription();\n    this.setUploadProcessLinked();\n    this.isUserAdmin();\n    this.iconService.registerAll([Filter16, TagGroup16, Upload16]);\n  }\n\n  public onDeleteActionClick(item: DocumentenApiRelatedFile): void {\n    this.document = item;\n    this.showDeleteConfirmationModal$.next(true);\n  }\n\n  public deleteDocument(): void {\n    this._itemsLoading$.next(true);\n    this.documentenApiDocumentService.deleteDocument(this.document).subscribe(() => {\n      this.refetchDocuments();\n    });\n  }\n\n  public bytesToMegabytes(bytes: number | undefined): string {\n    if (!bytes) return '';\n\n    const megabytes = bytes / (1024 * 1024);\n    if (megabytes < 1) {\n      return `${Math.ceil(megabytes * 1000)} KB`;\n    } else if (megabytes < 1000) {\n      return megabytes.toFixed(2) + ' MB';\n    }\n\n    return (megabytes / 1000).toFixed(2) + ' GB';\n  }\n\n  public getUploadButtonTooltip(): string {\n    if (this.uploadProcessLinkedSet && this.uploadProcessLinked) {\n      return 'Upload';\n    } else if (this.isAdmin) {\n      return 'dossier.documenten.noProcessLinked.adminRole';\n    }\n\n    return 'dossier.documenten.noProcessLinked.regularUser';\n  }\n\n  public isUserAdmin() {\n    this.userProviderService.getUserSubject().subscribe(\n      userIdentity => {\n        this.isAdmin = userIdentity.roles.includes('ROLE_ADMIN');\n      },\n      () => {\n        this.isAdmin = false;\n      }\n    );\n  }\n\n  public metadataSet(metadata: DocumentenApiMetadata): void {\n    this.uploading$.next(true);\n\n    combineLatest([this.fileToBeUploaded$, this.documentId$])\n      .pipe(take(1))\n      .pipe(\n        tap(([file, documentId]) => {\n          if (!file) return;\n          if (this.isEditMode$.getValue()) {\n            this.documentenApiDocumentService.updateDocument(file, metadata).subscribe(() => {\n              this.refetchDocuments();\n              this.uploading$.next(false);\n              this.fileToBeUploaded$.next(null);\n            });\n          } else {\n            this.uploadProviderService\n              .uploadFileWithMetadata(file, documentId, metadata)\n              .subscribe(() => {\n                this.refetchDocuments();\n                this.filter$.next(null);\n                this.uploading$.next(false);\n                this.fileToBeUploaded$.next(null);\n              });\n          }\n        })\n      )\n      .subscribe();\n  }\n\n  public onDownloadActionClick(file: DocumentenApiRelatedFile): void {\n    this.downloadDocument(file, true);\n  }\n\n  public onEditMetadata(file: File): void {\n    this.isEditMode$.next(true);\n    this.fileToBeUploaded$.next(file);\n    this.showUploadModal$.next(true);\n  }\n\n  public closeMetadataModal(): void {\n    this.showUploadModal$.next(false);\n  }\n\n  public onFileSelected(event: any): void {\n    this.isEditMode$.next(false);\n    this.fileToBeUploaded$.next(event.target.files[0]);\n    this.showUploadModal$.next(true);\n    this.resetFileInput();\n  }\n\n  public onNavigateToCaseAdminClick(): void {\n    this.documentDefinitionName$.pipe(take(1)).subscribe(documentDefinitionName => {\n      this.router.navigate([`/dossier-management/dossier/${documentDefinitionName}`]);\n    });\n  }\n\n  public onRowClick(event: any): void {\n    this.downloadDocument(event, false);\n  }\n\n  public onUploadButtonClick(): void {\n    this.fileInput.nativeElement.click();\n  }\n\n  public onFilterEvent(filter: DocumentenApiFilterModel | null): void {\n    this.filter$.next(filter);\n  }\n\n  public onSortChanged(sortState: SortState): void {\n    this._sort$.next(\n      sortState.isSorting\n        ? {\n            sort: `${sortState.state.name === 'size' ? DOCUMENTEN_COLUMN_KEYS.BESTANDSOMVANG : sortState.state.name},${sortState.state.direction}`,\n          }\n        : null\n    );\n  }\n\n  public refetchDocuments(): void {\n    this._refetch$.next(null);\n  }\n\n  private editDisabled(file: DocumentenApiRelatedFile): boolean {\n    return file.status === 'definitief';\n  }\n\n  private downloadDocument(relatedFile: DocumentenApiRelatedFile, forceDownload: boolean): void {\n    this.downloadService.downloadFile(\n      `/api/v1/documenten-api/${relatedFile.pluginConfigurationId}/files/${relatedFile.fileId}/download`,\n      relatedFile.bestandsnaam ?? '',\n      forceDownload\n    );\n  }\n\n  private openQueryParamsSubscription(): void {\n    combineLatest([\n      this.documentDefinitionName$,\n      this.documentId$,\n      this.filter$,\n      this._sort$,\n    ]).subscribe(([definitionName, documentId, filter, sort]) => {\n      this.router.navigate([`/dossiers/${definitionName}/document/${documentId}/documents`], {\n        queryParams: {...filter, ...sort},\n      });\n    });\n  }\n\n  private resetFileInput(): void {\n    this.fileInput.nativeElement.value = '';\n  }\n\n  private setUploadProcessLinked(): void {\n    this.documentDefinitionName$\n      .pipe(\n        switchMap(documentDefinitionName =>\n          this.uploadProviderService.checkUploadProcessLink(documentDefinitionName)\n        ),\n        take(1),\n        tap(() => {\n          this.uploadProcessLinkedSet = true;\n        })\n      )\n      .subscribe((linked: boolean) => {\n        this.uploadProcessLinked = linked;\n      });\n  }\n\n  private setInitialFilterAndSort(): void {\n    this.route.queryParamMap\n      .pipe(\n        take(1),\n        map(queryParams => {\n          const {sort, ...filter} = queryParams['params'];\n          return {sort, filter};\n        })\n      )\n      .subscribe(({filter, sort}) => {\n        this._sort$.next({sort});\n        this.filter$.next(filter);\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<div\n  class=\"carbon-document-table-wrapper\"\n  *ngIf=\"{\n    loading: loading$ | async,\n    fieldsLoading: fieldsLoading$ | async,\n    uploading: uploading$ | async,\n    relatedFiles: relatedFiles$ | async,\n    fields: fields$ | async,\n    initialSortState: initialSortState$ | async,\n    supportedDocumentenApiFeatures: supportedDocumentenApiFeatures$ | async\n  } as obs\"\n>\n  @if ((!obs.fieldsLoading && obs.fields.length) || obs.fieldsLoading) {\n    <valtimo-carbon-list\n      [actionItems]=\"actionItems\"\n      [items]=\"obs.relatedFiles\"\n      [fields]=\"obs.fields\"\n      [loading]=\"obs.loading\"\n      [initialSortState]=\"\n        obs?.supportedDocumentenApiFeatures?.supportsSortableColumns && obs.initialSortState\n      \"\n      (rowClicked)=\"onRowClick($event)\"\n      (sortChanged)=\"\n        obs?.supportedDocumentenApiFeatures?.supportsSortableColumns && onSortChanged($event)\n      \"\n      hideColumnHeader\n    >\n      <div carbonToolbarContent>\n        <input\n          [accept]=\"acceptedFiles\"\n          (change)=\"onFileSelected($event)\"\n          hidden\n          type=\"file\"\n          #fileInput\n        />\n\n        <button\n          *ngIf=\"obs?.supportedDocumentenApiFeatures?.supportsFilterableColumns\"\n          [cdsOverflowMenu]=\"overflowFilter\"\n          [customPane]=\"true\"\n          [iconOnly]=\"true\"\n          [flip]=\"true\"\n          [offset]=\"{x: 0, y: 47}\"\n          cdsButton=\"ghost\"\n          placement=\"bottom\"\n        >\n          <svg class=\"cds--btn__icon\" cdsIcon=\"filter\" size=\"16\"></svg>\n        </button>\n\n        <ng-container *ngTemplateOutlet=\"uploadButton\"></ng-container>\n      </div>\n\n      <ng-container *ngTemplateOutlet=\"noResults\"></ng-container>\n    </valtimo-carbon-list>\n  } @else {\n    <valtimo-no-results\n      [action]=\"navigateToCaseAdminButton\"\n      [description]=\"'zgw.documents.noColumns.description' | translate\"\n      [title]=\"'zgw.documents.noColumns.title' | translate\"\n    ></valtimo-no-results>\n  }\n\n  <valtimo-documenten-api-metadata-modal\n    [open]=\"showUploadModal$ | async\"\n    [disabled$]=\"modalDisabled$\"\n    [file$]=\"fileToBeUploaded$\"\n    [isEditMode]=\"isEditMode$ | async\"\n    [supportsTrefwoorden]=\"obs?.supportedDocumentenApiFeatures?.supportsTrefwoorden\"\n    (modalClose)=\"closeMetadataModal()\"\n    (metadata)=\"metadataSet($event)\"\n  ></valtimo-documenten-api-metadata-modal>\n</div>\n\n<valtimo-confirmation-modal\n  confirmButtonTextTranslationKey=\"dashboardManagement.deleteModal.confirm\"\n  contentTranslationKey=\"dossier.documenten.deleteConfirmationModal.content\"\n  confirmButtonType=\"danger\"\n  titleTranslationKey=\"dossier.documenten.deleteConfirmationModal.title\"\n  [showModalSubject$]=\"showDeleteConfirmationModal$\"\n  (confirmEvent)=\"deleteDocument()\"\n>\n</valtimo-confirmation-modal>\n\n<ng-template #downloadButton let-index=\"index\" let-item=\"item\">\n  <div\n    *ngIf=\"{isDownloading: indexesIncludeIndex(downloadingFileIndexes$ | async, index)} as vars\"\n    class=\"download-button-container\"\n  >\n    <button\n      *ngIf=\"!vars.isDownloading\"\n      cdsButton=\"primary\"\n      size=\"sm\"\n      (click)=\"downloadDocument(item, index)\"\n    >\n      {{ 'interface.download' | translate }}\n\n      <svg class=\"cds--btn__icon\" cdsIcon=\"download\" size=\"16\"></svg>\n    </button>\n\n    <cds-loading size=\"sm\" *ngIf=\"vars.isDownloading\"></cds-loading>\n  </div>\n</ng-template>\n\n<ng-template #noResults>\n  @if ((filter$ | async | keyvalue)?.length) {\n    <valtimo-no-results\n      [action]=\"resetFilterButton\"\n      [description]=\"'zgw.documents.noResults.filterDescription' | translate\"\n      [title]=\"'zgw.documents.noResults.filterTitle' | translate\"\n    ></valtimo-no-results>\n  } @else if (showZaakLinkWarning && isAdmin) {\n    <valtimo-no-results\n      [action]=\"navigateToCaseAdminButton\"\n      [description]=\"'dossier.documenten.noZaakFound' | translate\"\n      [title]=\"'dossier.documenten.noZaakFoundTitle' | translate\"\n    ></valtimo-no-results>\n  } @else {\n    <valtimo-no-results\n      [action]=\"uploadButton\"\n      [description]=\"'dossier.documenten.noFiles' | translate\"\n      [title]=\"'dossier.documenten.noFilesTitle' | translate\"\n    ></valtimo-no-results>\n  }\n</ng-template>\n\n<ng-template #overflowFilter>\n  <valtimo-dossier-detail-tab-documenten-api-filter\n    [prefillFilter]=\"filter$ | async\"\n    (filterEvent)=\"onFilterEvent($event)\"\n  ></valtimo-dossier-detail-tab-documenten-api-filter>\n</ng-template>\n\n<ng-template #resetFilterButton>\n  <button cdsButton=\"primary\" (click)=\"onFilterEvent(null)\">\n    {{ 'Reset filter' | translate }}\n\n    <svg class=\"cds--btn__icon\" cdsIcon=\"trash-can\" size=\"16\"></svg>\n  </button>\n</ng-template>\n\n<ng-template #uploadButton let-disabled=\"disabled\">\n  <button\n    [disabled]=\"(uploadProcessLinkedSet && !uploadProcessLinked) || showZaakLinkWarning || disabled\"\n    [vTooltip]=\"getUploadButtonTooltip() | translate\"\n    (click)=\"onUploadButtonClick()\"\n    cdsButton=\"primary\"\n  >\n    {{ 'Upload' | translate }}\n    <svg class=\"cds--btn__icon\" cdsIcon=\"upload\" size=\"16\"></svg>\n  </button>\n</ng-template>\n\n<ng-template #translationTemplate let-data=\"data\">\n  {{ 'document.' + data.item[data.key] | translate }}\n</ng-template>\n\n<ng-template #navigateToCaseAdminButton>\n  <button (click)=\"onNavigateToCaseAdminClick()\" cdsButton=\"primary\">\n    {{ 'dossier.documenten.navigateToCaseAdmin' | translate }}\n\n    <svg class=\"cds--btn__icon\" cdsIcon=\"settings\" size=\"16\"></svg>\n  </button>\n</ng-template>\n"]}
|