@valtimo/dossier 5.9.0 → 5.10.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (23) hide show
  1. package/esm2020/lib/dossier-detail/tab/documenten-api-documents/documenten-api-documents.component.mjs +162 -0
  2. package/esm2020/lib/dossier-detail/tab/documents/documents.component.mjs +17 -91
  3. package/esm2020/lib/dossier-detail/tab/progress/progress.component.mjs +3 -2
  4. package/esm2020/lib/dossier-detail/tab/s3-documents/s3-documents.component.mjs +132 -0
  5. package/esm2020/lib/dossier-process-start-modal/dossier-process-start-modal.component.mjs +1 -2
  6. package/esm2020/lib/dossier.module.mjs +13 -4
  7. package/esm2020/lib/tab.service.mjs +12 -7
  8. package/fesm2015/valtimo-dossier.mjs +277 -68
  9. package/fesm2015/valtimo-dossier.mjs.map +1 -1
  10. package/fesm2020/valtimo-dossier.mjs +280 -70
  11. package/fesm2020/valtimo-dossier.mjs.map +1 -1
  12. package/lib/dossier-detail/tab/documenten-api-documents/documenten-api-documents.component.d.ts +63 -0
  13. package/lib/dossier-detail/tab/documenten-api-documents/documenten-api-documents.component.d.ts.map +1 -0
  14. package/lib/dossier-detail/tab/documents/documents.component.d.ts +6 -40
  15. package/lib/dossier-detail/tab/documents/documents.component.d.ts.map +1 -1
  16. package/lib/dossier-detail/tab/progress/progress.component.d.ts.map +1 -1
  17. package/lib/dossier-detail/tab/s3-documents/s3-documents.component.d.ts +50 -0
  18. package/lib/dossier-detail/tab/s3-documents/s3-documents.component.d.ts.map +1 -0
  19. package/lib/dossier-process-start-modal/dossier-process-start-modal.component.d.ts.map +1 -1
  20. package/lib/dossier.module.d.ts +14 -12
  21. package/lib/dossier.module.d.ts.map +1 -1
  22. package/lib/tab.service.d.ts.map +1 -1
  23. package/package.json +1 -1
@@ -0,0 +1,162 @@
1
+ /*
2
+ * Copyright 2015-2020 Ritense BV, the Netherlands.
3
+ *
4
+ * Licensed under EUPL, Version 1.2 (the "License");
5
+ * you may not use this file except in compliance with the License.
6
+ * You may obtain a copy of the License at
7
+ *
8
+ * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12
9
+ *
10
+ * Unless required by applicable law or agreed to in writing, software
11
+ * distributed under the License is distributed on an "AS IS" basis,
12
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13
+ * See the License for the specific language governing permissions and
14
+ * limitations under the License.
15
+ */
16
+ import { Component } from '@angular/core';
17
+ import { map, switchMap, take, tap } from 'rxjs/operators';
18
+ import { BehaviorSubject, combineLatest, Subject } from 'rxjs';
19
+ import * as i0 from "@angular/core";
20
+ import * as i1 from "@angular/router";
21
+ import * as i2 from "@valtimo/document";
22
+ import * as i3 from "ngx-toastr";
23
+ import * as i4 from "@valtimo/resource";
24
+ import * as i5 from "@valtimo/user-interface";
25
+ import * as i6 from "@ngx-translate/core";
26
+ import * as i7 from "@valtimo/config";
27
+ import * as i8 from "@valtimo/security";
28
+ import * as i9 from "@valtimo/components";
29
+ import * as i10 from "@angular/common";
30
+ export class DossierDetailTabDocumentenApiDocumentsComponent {
31
+ constructor(route, documentService, toastrService, uploadProviderService, downloadService, promptService, translateService, configService, userProviderService) {
32
+ this.route = route;
33
+ this.documentService = documentService;
34
+ this.toastrService = toastrService;
35
+ this.uploadProviderService = uploadProviderService;
36
+ this.downloadService = downloadService;
37
+ this.promptService = promptService;
38
+ this.translateService = translateService;
39
+ this.configService = configService;
40
+ this.userProviderService = userProviderService;
41
+ this.maxFileSize = this.configService?.config?.caseFileSizeUploadLimitMB || 5;
42
+ this.acceptedFiles = this.configService?.config?.caseFileUploadAcceptedFiles || null;
43
+ this.fields = [
44
+ { key: 'fileName', label: 'File name' },
45
+ { key: 'sizeInBytes', label: 'Size in bytes' },
46
+ { key: 'createdOn', label: 'Created on', viewType: 'date' },
47
+ { key: 'createdBy', label: 'Created by' },
48
+ ];
49
+ this.actions = [
50
+ {
51
+ columnName: '',
52
+ iconClass: 'mdi mdi-open-in-new',
53
+ callback: this.downloadDocument.bind(this),
54
+ },
55
+ {
56
+ columnName: '',
57
+ iconClass: 'mdi mdi-delete',
58
+ callback: this.removeRelatedFile.bind(this),
59
+ },
60
+ ];
61
+ this.uploadProcessLinkedSet = false;
62
+ this.uploading$ = new BehaviorSubject(false);
63
+ this.showModal$ = new Subject();
64
+ this.hideModal$ = new Subject();
65
+ this.modalDisabled$ = new BehaviorSubject(false);
66
+ this.fileToBeUploaded$ = new BehaviorSubject(null);
67
+ this.refetch$ = new BehaviorSubject(null);
68
+ this.relatedFiles$ = this.refetch$.pipe(switchMap(() => combineLatest([
69
+ this.documentService.getDocument(this.documentId),
70
+ this.translateService.stream('key'),
71
+ ])), map(([document]) => {
72
+ const relatedFiles = document?.relatedFiles || [];
73
+ const translatedFiles = relatedFiles.map(file => ({
74
+ ...file,
75
+ createdBy: file.createdBy || this.translateService.instant('list.automaticallyGenerated'),
76
+ }));
77
+ return translatedFiles || [];
78
+ }));
79
+ const snapshot = this.route.snapshot.paramMap;
80
+ this.documentId = snapshot.get('documentId') || '';
81
+ this.documentDefinitionName = snapshot.get('documentDefinitionName') || '';
82
+ }
83
+ ngOnInit() {
84
+ this.refetchDocuments();
85
+ this.setUploadProcessLinked();
86
+ this.isUserAdmin();
87
+ }
88
+ fileSelected(file) {
89
+ this.fileToBeUploaded$.next(file);
90
+ this.showModal$.next(null);
91
+ }
92
+ downloadDocument(relatedFile) {
93
+ this.uploadProviderService
94
+ .getResource(relatedFile.fileId)
95
+ .subscribe((resource) => {
96
+ this.downloadService.downloadFile(resource.url, resource.resource.name);
97
+ });
98
+ }
99
+ removeRelatedFile(relatedFile) {
100
+ this.promptService.openPrompt({
101
+ headerText: this.translateService.instant('dossier.deleteConfirmation.title'),
102
+ bodyText: this.translateService.instant('dossier.deleteConfirmation.description'),
103
+ cancelButtonText: this.translateService.instant('dossier.deleteConfirmation.cancel'),
104
+ confirmButtonText: this.translateService.instant('dossier.deleteConfirmation.delete'),
105
+ cancelMdiIcon: 'cancel',
106
+ confirmMdiIcon: 'delete',
107
+ cancelButtonType: 'secondary',
108
+ confirmButtonType: 'primary',
109
+ closeOnConfirm: true,
110
+ closeOnCancel: true,
111
+ confirmCallBackFunction: () => {
112
+ this.documentService.removeResource(this.documentId, relatedFile.fileId).subscribe(() => {
113
+ this.toastrService.success('Successfully removed document from dossier');
114
+ this.refetchDocuments();
115
+ }, () => {
116
+ this.toastrService.error('Failed to remove document from dossier');
117
+ });
118
+ }
119
+ });
120
+ }
121
+ metadataSet(metadata) {
122
+ this.uploading$.next(true);
123
+ this.hideModal$.next(null);
124
+ this.fileToBeUploaded$
125
+ .pipe(take(1))
126
+ .pipe(tap(file => {
127
+ this.uploadProviderService
128
+ .uploadFileWithMetadata(file, this.documentId, metadata)
129
+ .subscribe(res => {
130
+ this.refetchDocuments();
131
+ this.uploading$.next(false);
132
+ this.fileToBeUploaded$.next(null);
133
+ });
134
+ }))
135
+ .subscribe();
136
+ }
137
+ isUserAdmin() {
138
+ this.userProviderService.getUserSubject().subscribe(userIdentity => {
139
+ this.isAdmin = userIdentity.roles.includes('ROLE_ADMIN');
140
+ }, error => {
141
+ this.isAdmin = false;
142
+ });
143
+ }
144
+ refetchDocuments() {
145
+ this.refetch$.next(null);
146
+ }
147
+ setUploadProcessLinked() {
148
+ this.uploadProviderService.checkUploadProcessLink(this.documentDefinitionName).subscribe(linked => {
149
+ this.uploadProcessLinked = linked;
150
+ this.uploadProcessLinkedSet = true;
151
+ }, () => {
152
+ this.uploadProcessLinkedSet = true;
153
+ });
154
+ }
155
+ }
156
+ DossierDetailTabDocumentenApiDocumentsComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: DossierDetailTabDocumentenApiDocumentsComponent, deps: [{ token: i1.ActivatedRoute }, { token: i2.DocumentService }, { token: i3.ToastrService }, { token: i4.UploadProviderService }, { token: i4.DownloadService }, { token: i5.PromptService }, { token: i6.TranslateService }, { token: i7.ConfigService }, { token: i8.UserProviderService }], target: i0.ɵɵFactoryTarget.Component });
157
+ DossierDetailTabDocumentenApiDocumentsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.11", type: DossierDetailTabDocumentenApiDocumentsComponent, selector: "valtimo-dossier-detail-tab-documenten-api-documents", ngImport: i0, template: "<!--\n ~ Copyright 2015-2020 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 *ngIf=\"uploadProcessLinkedSet && !uploadProcessLinked\">\n <div\n *ngIf=\"isAdmin\"\n [translate]=\"'dossier.documenten.noProcessLinked.adminRole'\"\n class=\"bg-warning text-black mb-2 p-3 text-center\"\n ></div>\n <div\n *ngIf=\"!isAdmin\"\n [translate]=\"'dossier.documenten.noProcessLinked.regularUser'\"\n class=\"bg-warning text-black mb-2 p-3 text-center\"\n ></div>\n</div>\n\n<valtimo-dropzone\n (fileSelected)=\"fileSelected($event)\"\n [acceptedFiles]=\"acceptedFiles\"\n [camera]=\"false\"\n [disabled]=\"!uploadProcessLinkedSet || !uploadProcessLinked\"\n [hideFilePreview]=\"true\"\n [hideTitle]=\"true\"\n [maxFileSize]=\"maxFileSize\"\n [maxFiles]=\"1\"\n [showMaxFileSize]=\"true\"\n [uploading]=\"uploading$ | async\"\n></valtimo-dropzone>\n\n<valtimo-widget>\n <valtimo-list\n [actions]=\"actions\"\n [fields]=\"fields\"\n [header]=\"true\"\n [isSearchable]=\"true\"\n [items]=\"relatedFiles$ | async\"\n [viewMode]=\"true\"\n >\n <div header>\n <h3 class=\"list-header-title\">{{ 'Related documents' | translate }}</h3>\n <h5 class=\"list-header-description\">\n {{ 'Overview of all documents in this dossier' | translate }}\n </h5>\n </div>\n </valtimo-list>\n</valtimo-widget>\n\n<valtimo-documenten-api-metadata-modal\n (metadata)=\"metadataSet($event)\"\n [disabled$]=\"modalDisabled$\"\n [file$]=\"fileToBeUploaded$\"\n [hide$]=\"hideModal$\"\n [show$]=\"showModal$\"\n></valtimo-documenten-api-metadata-modal>\n", styles: [""], components: [{ type: i9.DropzoneComponent, selector: "valtimo-dropzone", inputs: ["title", "hideTitle", "subtitle", "externalError$", "maxFileSize", "showMaxFileSize", "acceptedFiles", "clear$", "disabled", "hideFilePreview", "uploading", "camera", "maxFiles"], outputs: ["fileSelected"] }, { type: i9.WidgetComponent, selector: "valtimo-widget", inputs: ["type", "name", "icon", "contrast", "divider", "title", "subtitle", "collapseAble", "collapse", "additionalClasses"] }, { type: i9.ListComponent, selector: "valtimo-list", inputs: ["items", "fields", "pagination", "viewMode", "isSearchable", "header", "actions", "paginationIdentifier", "initialSortState"], outputs: ["rowClicked", "paginationClicked", "paginationSet", "search", "sortChanged"] }, { type: i9.DocumentenApiMetadataModalComponent, selector: "valtimo-documenten-api-metadata-modal", inputs: ["show$", "hide$", "disabled$", "file$"], outputs: ["metadata"] }], directives: [{ type: i10.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i6.TranslateDirective, selector: "[translate],[ngx-translate]", inputs: ["translate", "translateParams"] }], pipes: { "async": i10.AsyncPipe, "translate": i6.TranslatePipe } });
158
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: DossierDetailTabDocumentenApiDocumentsComponent, decorators: [{
159
+ type: Component,
160
+ args: [{ selector: 'valtimo-dossier-detail-tab-documenten-api-documents', template: "<!--\n ~ Copyright 2015-2020 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 *ngIf=\"uploadProcessLinkedSet && !uploadProcessLinked\">\n <div\n *ngIf=\"isAdmin\"\n [translate]=\"'dossier.documenten.noProcessLinked.adminRole'\"\n class=\"bg-warning text-black mb-2 p-3 text-center\"\n ></div>\n <div\n *ngIf=\"!isAdmin\"\n [translate]=\"'dossier.documenten.noProcessLinked.regularUser'\"\n class=\"bg-warning text-black mb-2 p-3 text-center\"\n ></div>\n</div>\n\n<valtimo-dropzone\n (fileSelected)=\"fileSelected($event)\"\n [acceptedFiles]=\"acceptedFiles\"\n [camera]=\"false\"\n [disabled]=\"!uploadProcessLinkedSet || !uploadProcessLinked\"\n [hideFilePreview]=\"true\"\n [hideTitle]=\"true\"\n [maxFileSize]=\"maxFileSize\"\n [maxFiles]=\"1\"\n [showMaxFileSize]=\"true\"\n [uploading]=\"uploading$ | async\"\n></valtimo-dropzone>\n\n<valtimo-widget>\n <valtimo-list\n [actions]=\"actions\"\n [fields]=\"fields\"\n [header]=\"true\"\n [isSearchable]=\"true\"\n [items]=\"relatedFiles$ | async\"\n [viewMode]=\"true\"\n >\n <div header>\n <h3 class=\"list-header-title\">{{ 'Related documents' | translate }}</h3>\n <h5 class=\"list-header-description\">\n {{ 'Overview of all documents in this dossier' | translate }}\n </h5>\n </div>\n </valtimo-list>\n</valtimo-widget>\n\n<valtimo-documenten-api-metadata-modal\n (metadata)=\"metadataSet($event)\"\n [disabled$]=\"modalDisabled$\"\n [file$]=\"fileToBeUploaded$\"\n [hide$]=\"hideModal$\"\n [show$]=\"showModal$\"\n></valtimo-documenten-api-metadata-modal>\n", styles: [""] }]
161
+ }], ctorParameters: function () { return [{ type: i1.ActivatedRoute }, { type: i2.DocumentService }, { type: i3.ToastrService }, { type: i4.UploadProviderService }, { type: i4.DownloadService }, { type: i5.PromptService }, { type: i6.TranslateService }, { type: i7.ConfigService }, { type: i8.UserProviderService }]; } });
162
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"documenten-api-documents.component.js","sourceRoot":"","sources":["../../../../../../../../projects/valtimo/dossier/src/lib/dossier-detail/tab/documenten-api-documents/documenten-api-documents.component.ts","../../../../../../../../projects/valtimo/dossier/src/lib/dossier-detail/tab/documenten-api-documents/documenten-api-documents.component.html"],"names":[],"mappings":"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","sourcesContent":["/*\n * Copyright 2015-2020 Ritense BV, the Netherlands.\n *\n * Licensed under EUPL, Version 1.2 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" basis,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport {Component, OnInit} from '@angular/core';\nimport {ActivatedRoute} from '@angular/router';\nimport {DocumentService, RelatedFile} from '@valtimo/document';\nimport {DownloadService, ResourceDto, UploadProviderService} from '@valtimo/resource';\nimport {ToastrService} from 'ngx-toastr';\nimport {map, switchMap, take, tap} from 'rxjs/operators';\nimport {BehaviorSubject, combineLatest, Observable, Subject} from 'rxjs';\nimport {TranslateService} from '@ngx-translate/core';\nimport {ConfigService} from '@valtimo/config';\nimport {DocumentenApiMetadata} from '@valtimo/components';\nimport {UserProviderService} from '@valtimo/security';\nimport {PromptService} from '@valtimo/user-interface';\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})\nexport class DossierDetailTabDocumentenApiDocumentsComponent implements OnInit {\n  public readonly documentId: string;\n  public readonly documentDefinitionName: string;\n  public readonly maxFileSize: number = this.configService?.config?.caseFileSizeUploadLimitMB || 5;\n  public readonly acceptedFiles: string =\n    this.configService?.config?.caseFileUploadAcceptedFiles || null;\n  public fields = [\n    {key: 'fileName', label: 'File name'},\n    {key: 'sizeInBytes', label: 'Size in bytes'},\n    {key: 'createdOn', label: 'Created on', viewType: 'date'},\n    {key: 'createdBy', label: 'Created by'},\n  ];\n  public actions = [\n    {\n      columnName: '',\n      iconClass: 'mdi mdi-open-in-new',\n      callback: this.downloadDocument.bind(this),\n    },\n    {\n      columnName: '',\n      iconClass: 'mdi mdi-delete',\n      callback: this.removeRelatedFile.bind(this),\n    },\n  ];\n  public isAdmin: boolean;\n  public uploadProcessLinkedSet = false;\n  public uploadProcessLinked!: boolean;\n  readonly uploading$ = new BehaviorSubject<boolean>(false);\n  readonly showModal$ = new Subject<null>();\n  readonly hideModal$ = new Subject<null>();\n  readonly modalDisabled$ = new BehaviorSubject<boolean>(false);\n  readonly fileToBeUploaded$ = new BehaviorSubject<File | null>(null);\n  private readonly refetch$ = new BehaviorSubject<null>(null);\n  public relatedFiles$: Observable<Array<RelatedFile>> = this.refetch$.pipe(\n    switchMap(() =>\n      combineLatest([\n        this.documentService.getDocument(this.documentId),\n        this.translateService.stream('key'),\n      ])\n    ),\n    map(([document]) => {\n      const relatedFiles = document?.relatedFiles || [];\n      const translatedFiles = relatedFiles.map(file => ({\n        ...file,\n        createdBy: file.createdBy || this.translateService.instant('list.automaticallyGenerated'),\n      }));\n\n      return translatedFiles || [];\n    })\n  );\n\n  constructor(\n    private readonly route: ActivatedRoute,\n    private readonly documentService: DocumentService,\n    private readonly toastrService: ToastrService,\n    private readonly uploadProviderService: UploadProviderService,\n    private readonly downloadService: DownloadService,\n    private readonly promptService: PromptService,\n    private readonly translateService: TranslateService,\n    private readonly configService: ConfigService,\n    private readonly userProviderService: UserProviderService\n  ) {\n    const snapshot = this.route.snapshot.paramMap;\n    this.documentId = snapshot.get('documentId') || '';\n    this.documentDefinitionName = snapshot.get('documentDefinitionName') || '';\n  }\n\n  ngOnInit(): void {\n    this.refetchDocuments();\n    this.setUploadProcessLinked();\n    this.isUserAdmin();\n  }\n\n  fileSelected(file: File): void {\n    this.fileToBeUploaded$.next(file);\n    this.showModal$.next(null);\n  }\n\n  downloadDocument(relatedFile: RelatedFile): void {\n    this.uploadProviderService\n      .getResource(relatedFile.fileId)\n      .subscribe((resource: ResourceDto) => {\n        this.downloadService.downloadFile(resource.url, resource.resource.name);\n      });\n  }\n\n  removeRelatedFile(relatedFile: RelatedFile) {\n    this.promptService.openPrompt({\n      headerText: this.translateService.instant('dossier.deleteConfirmation.title'),\n      bodyText: this.translateService.instant('dossier.deleteConfirmation.description'),\n      cancelButtonText: this.translateService.instant('dossier.deleteConfirmation.cancel'),\n      confirmButtonText: this.translateService.instant('dossier.deleteConfirmation.delete'),\n      cancelMdiIcon: 'cancel',\n      confirmMdiIcon: 'delete',\n      cancelButtonType: 'secondary',\n      confirmButtonType: 'primary',\n      closeOnConfirm: true,\n      closeOnCancel: true,\n      confirmCallBackFunction: () => {\n        this.documentService.removeResource(this.documentId, relatedFile.fileId).subscribe(\n          () => {\n            this.toastrService.success('Successfully removed document from dossier');\n            this.refetchDocuments();\n          },\n          () => {\n            this.toastrService.error('Failed to remove document from dossier');\n          }\n        );\n      }\n    });\n  }\n\n  metadataSet(metadata: DocumentenApiMetadata): void {\n    this.uploading$.next(true);\n    this.hideModal$.next(null);\n\n    this.fileToBeUploaded$\n      .pipe(take(1))\n      .pipe(\n        tap(file => {\n          this.uploadProviderService\n            .uploadFileWithMetadata(file, this.documentId, metadata)\n            .subscribe(res => {\n              this.refetchDocuments();\n              this.uploading$.next(false);\n              this.fileToBeUploaded$.next(null);\n            });\n        })\n      )\n      .subscribe();\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  private refetchDocuments(): void {\n    this.refetch$.next(null);\n  }\n\n  private setUploadProcessLinked(): void {\n    this.uploadProviderService.checkUploadProcessLink(this.documentDefinitionName).subscribe(\n      linked => {\n        this.uploadProcessLinked = linked;\n        this.uploadProcessLinkedSet = true;\n      },\n      () => {\n        this.uploadProcessLinkedSet = true;\n      }\n    );\n  }\n}\n","<!--\n  ~ Copyright 2015-2020 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 *ngIf=\"uploadProcessLinkedSet && !uploadProcessLinked\">\n  <div\n    *ngIf=\"isAdmin\"\n    [translate]=\"'dossier.documenten.noProcessLinked.adminRole'\"\n    class=\"bg-warning text-black mb-2 p-3 text-center\"\n  ></div>\n  <div\n    *ngIf=\"!isAdmin\"\n    [translate]=\"'dossier.documenten.noProcessLinked.regularUser'\"\n    class=\"bg-warning text-black mb-2 p-3 text-center\"\n  ></div>\n</div>\n\n<valtimo-dropzone\n  (fileSelected)=\"fileSelected($event)\"\n  [acceptedFiles]=\"acceptedFiles\"\n  [camera]=\"false\"\n  [disabled]=\"!uploadProcessLinkedSet || !uploadProcessLinked\"\n  [hideFilePreview]=\"true\"\n  [hideTitle]=\"true\"\n  [maxFileSize]=\"maxFileSize\"\n  [maxFiles]=\"1\"\n  [showMaxFileSize]=\"true\"\n  [uploading]=\"uploading$ | async\"\n></valtimo-dropzone>\n\n<valtimo-widget>\n  <valtimo-list\n    [actions]=\"actions\"\n    [fields]=\"fields\"\n    [header]=\"true\"\n    [isSearchable]=\"true\"\n    [items]=\"relatedFiles$ | async\"\n    [viewMode]=\"true\"\n  >\n    <div header>\n      <h3 class=\"list-header-title\">{{ 'Related documents' | translate }}</h3>\n      <h5 class=\"list-header-description\">\n        {{ 'Overview of all documents in this dossier' | translate }}\n      </h5>\n    </div>\n  </valtimo-list>\n</valtimo-widget>\n\n<valtimo-documenten-api-metadata-modal\n  (metadata)=\"metadataSet($event)\"\n  [disabled$]=\"modalDisabled$\"\n  [file$]=\"fileToBeUploaded$\"\n  [hide$]=\"hideModal$\"\n  [show$]=\"showModal$\"\n></valtimo-documenten-api-metadata-modal>\n"]}
@@ -14,102 +14,28 @@
14
14
  * limitations under the License.
15
15
  */
16
16
  import { Component } from '@angular/core';
17
- import { map, switchMap } from 'rxjs/operators';
18
- import { BehaviorSubject, combineLatest } from 'rxjs';
17
+ import { UploadProvider } from '@valtimo/config';
19
18
  import * as i0 from "@angular/core";
20
- import * as i1 from "@angular/router";
21
- import * as i2 from "@valtimo/document";
22
- import * as i3 from "ngx-toastr";
23
- import * as i4 from "@valtimo/resource";
24
- import * as i5 from "@ngx-translate/core";
25
- import * as i6 from "@valtimo/config";
26
- import * as i7 from "@valtimo/components";
27
- import * as i8 from "@angular/common";
19
+ import * as i1 from "@valtimo/config";
20
+ import * as i2 from "../s3-documents/s3-documents.component";
21
+ import * as i3 from "../documenten-api-documents/documenten-api-documents.component";
22
+ import * as i4 from "@angular/common";
28
23
  export class DossierDetailTabDocumentsComponent {
29
- constructor(route, documentService, toastrService, uploadProviderService, downloadService, translateService, configService) {
30
- this.route = route;
31
- this.documentService = documentService;
32
- this.toastrService = toastrService;
33
- this.uploadProviderService = uploadProviderService;
34
- this.downloadService = downloadService;
35
- this.translateService = translateService;
24
+ constructor(configService) {
36
25
  this.configService = configService;
37
- this.maxFileSize = this.configService?.config?.caseFileSizeUploadLimitMB || 5;
38
- this.refetch$ = new BehaviorSubject(null);
39
- this.relatedFiles$ = this.refetch$.pipe(switchMap(() => combineLatest([
40
- this.documentService.getDocument(this.documentId),
41
- this.translateService.stream('key'),
42
- ])), map(([document]) => {
43
- const relatedFiles = document?.relatedFiles || [];
44
- const translatedFiles = relatedFiles.map(file => ({
45
- ...file,
46
- createdBy: file.createdBy || this.translateService.instant('list.automaticallyGenerated'),
47
- }));
48
- return translatedFiles || [];
49
- }));
50
- this.fields = [
51
- { key: 'fileName', label: 'File name' },
52
- { key: 'sizeInBytes', label: 'Size in bytes' },
53
- { key: 'createdOn', label: 'Created on', viewType: 'date' },
54
- { key: 'createdBy', label: 'Created by' },
55
- ];
56
- this.actions = [
57
- {
58
- columnName: '',
59
- iconClass: 'mdi mdi-open-in-new',
60
- callback: this.downloadDocument.bind(this),
61
- },
62
- {
63
- columnName: '',
64
- iconClass: 'mdi mdi-delete',
65
- callback: this.removeRelatedFile.bind(this),
66
- },
67
- ];
68
- this.uploading$ = new BehaviorSubject(false);
69
- const snapshot = this.route.snapshot.paramMap;
70
- this.documentId = snapshot.get('documentId') || '';
71
- this.documentDefinitionName = snapshot.get('documentDefinitionName') || '';
26
+ this.setConfig(configService.config);
72
27
  }
73
- ngOnInit() {
74
- this.refetchDocuments();
75
- }
76
- fileSelected(file) {
77
- this.uploading$.next(true);
78
- this.uploadProviderService
79
- .uploadFile(file, this.documentDefinitionName)
80
- .pipe(switchMap(resourceFile => this.documentService.assignResource(this.documentId, resourceFile.data.resourceId)))
81
- .subscribe(() => {
82
- this.toastrService.success('Successfully uploaded document to dossier');
83
- this.refetchDocuments();
84
- this.uploading$.next(false);
85
- }, () => {
86
- this.toastrService.error('Failed to upload document to dossier');
87
- this.uploading$.next(false);
88
- });
89
- }
90
- downloadDocument(relatedFile) {
91
- this.uploadProviderService
92
- .getResource(relatedFile.fileId)
93
- .subscribe((resource) => {
94
- this.downloadService.downloadFile(resource.url, resource.resource.name);
95
- });
96
- }
97
- removeRelatedFile(relatedFile) {
98
- this.documentService.removeResource(this.documentId, relatedFile.fileId).subscribe(() => {
99
- this.toastrService.success('Successfully removed document from dossier');
100
- this.refetchDocuments();
101
- }, () => {
102
- this.toastrService.error('Failed to remove document from dossier');
103
- });
104
- }
105
- refetchDocuments() {
106
- this.refetch$.next(null);
28
+ setConfig(config) {
29
+ const uploadProvider = config.uploadProvider;
30
+ this.openZaakUploadProvider = uploadProvider === UploadProvider.OPEN_ZAAK;
31
+ this.documentenApiUploadProvider = uploadProvider === UploadProvider.DOCUMENTEN_API;
32
+ this.s3UploadProvider = config.uploadProvider === UploadProvider.S3;
107
33
  }
108
34
  }
109
- DossierDetailTabDocumentsComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: DossierDetailTabDocumentsComponent, deps: [{ token: i1.ActivatedRoute }, { token: i2.DocumentService }, { token: i3.ToastrService }, { token: i4.UploadProviderService }, { token: i4.DownloadService }, { token: i5.TranslateService }, { token: i6.ConfigService }], target: i0.ɵɵFactoryTarget.Component });
110
- DossierDetailTabDocumentsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.11", type: DossierDetailTabDocumentsComponent, selector: "valtimo-dossier-detail-tab-documents", ngImport: i0, template: "<!--\n ~ Copyright 2015-2020 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<valtimo-dropzone\n (fileSelected)=\"fileSelected($event)\"\n [acceptedFiles]=\"null\"\n [hideFilePreview]=\"true\"\n [hideTitle]=\"true\"\n [maxFileSize]=\"maxFileSize\"\n [showMaxFileSize]=\"true\"\n [camera]=\"false\"\n [uploading]=\"uploading$ | async\"\n></valtimo-dropzone>\n\n<valtimo-widget>\n <valtimo-list\n [fields]=\"fields\"\n [items]=\"relatedFiles$ | async\"\n [header]=\"true\"\n [isSearchable]=\"true\"\n [viewMode]=\"true\"\n [actions]=\"actions\"\n >\n <div header>\n <h3 class=\"list-header-title\">{{ 'Related documents' | translate }}</h3>\n <h5 class=\"list-header-description\">\n {{ 'Overview of all documents in this dossier' | translate }}\n </h5>\n </div>\n </valtimo-list>\n</valtimo-widget>\n", styles: [""], components: [{ type: i7.DropzoneComponent, selector: "valtimo-dropzone", inputs: ["title", "hideTitle", "subtitle", "externalError$", "maxFileSize", "showMaxFileSize", "acceptedFiles", "clear$", "disabled", "hideFilePreview", "uploading", "camera"], outputs: ["fileSelected"] }, { type: i7.WidgetComponent, selector: "valtimo-widget", inputs: ["type", "name", "icon", "contrast", "divider", "title", "subtitle", "collapseAble", "collapse", "additionalClasses"] }, { type: i7.ListComponent, selector: "valtimo-list", inputs: ["items", "fields", "pagination", "viewMode", "isSearchable", "header", "actions", "paginationIdentifier", "initialSortState"], outputs: ["rowClicked", "paginationClicked", "paginationSet", "search", "sortChanged"] }], pipes: { "async": i8.AsyncPipe, "translate": i5.TranslatePipe } });
35
+ DossierDetailTabDocumentsComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: DossierDetailTabDocumentsComponent, deps: [{ token: i1.ConfigService }], target: i0.ɵɵFactoryTarget.Component });
36
+ DossierDetailTabDocumentsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.11", type: DossierDetailTabDocumentsComponent, selector: "valtimo-dossier-detail-tab-documents", ngImport: i0, template: "<!--\n ~ Copyright 2015-2020 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<valtimo-dossier-detail-tab-s3-documents\n *ngIf=\"s3UploadProvider || openZaakUploadProvider\"\n></valtimo-dossier-detail-tab-s3-documents>\n<valtimo-dossier-detail-tab-documenten-api-documents *ngIf=\"documentenApiUploadProvider\">\n</valtimo-dossier-detail-tab-documenten-api-documents>\n", styles: [""], components: [{ type: i2.DossierDetailTabS3DocumentsComponent, selector: "valtimo-dossier-detail-tab-s3-documents" }, { type: i3.DossierDetailTabDocumentenApiDocumentsComponent, selector: "valtimo-dossier-detail-tab-documenten-api-documents" }], directives: [{ type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
111
37
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: DossierDetailTabDocumentsComponent, decorators: [{
112
38
  type: Component,
113
- args: [{ selector: 'valtimo-dossier-detail-tab-documents', template: "<!--\n ~ Copyright 2015-2020 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<valtimo-dropzone\n (fileSelected)=\"fileSelected($event)\"\n [acceptedFiles]=\"null\"\n [hideFilePreview]=\"true\"\n [hideTitle]=\"true\"\n [maxFileSize]=\"maxFileSize\"\n [showMaxFileSize]=\"true\"\n [camera]=\"false\"\n [uploading]=\"uploading$ | async\"\n></valtimo-dropzone>\n\n<valtimo-widget>\n <valtimo-list\n [fields]=\"fields\"\n [items]=\"relatedFiles$ | async\"\n [header]=\"true\"\n [isSearchable]=\"true\"\n [viewMode]=\"true\"\n [actions]=\"actions\"\n >\n <div header>\n <h3 class=\"list-header-title\">{{ 'Related documents' | translate }}</h3>\n <h5 class=\"list-header-description\">\n {{ 'Overview of all documents in this dossier' | translate }}\n </h5>\n </div>\n </valtimo-list>\n</valtimo-widget>\n", styles: [""] }]
114
- }], ctorParameters: function () { return [{ type: i1.ActivatedRoute }, { type: i2.DocumentService }, { type: i3.ToastrService }, { type: i4.UploadProviderService }, { type: i4.DownloadService }, { type: i5.TranslateService }, { type: i6.ConfigService }]; } });
115
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"documents.component.js","sourceRoot":"","sources":["../../../../../../../../projects/valtimo/dossier/src/lib/dossier-detail/tab/documents/documents.component.ts","../../../../../../../../projects/valtimo/dossier/src/lib/dossier-detail/tab/documents/documents.component.html"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;GAcG;AAEH,OAAO,EAAC,SAAS,EAAS,MAAM,eAAe,CAAC;AAMhD,OAAO,EAAC,GAAG,EAAE,SAAS,EAAC,MAAM,gBAAgB,CAAC;AAC9C,OAAO,EAAC,eAAe,EAAE,aAAa,EAAa,MAAM,MAAM,CAAC;;;;;;;;;;AAShE,MAAM,OAAO,kCAAkC;IA4C7C,YACmB,KAAqB,EACrB,eAAgC,EAChC,aAA4B,EAC5B,qBAA4C,EAC5C,eAAgC,EAChC,gBAAkC,EAClC,aAA4B;QAN5B,UAAK,GAAL,KAAK,CAAgB;QACrB,oBAAe,GAAf,eAAe,CAAiB;QAChC,kBAAa,GAAb,aAAa,CAAe;QAC5B,0BAAqB,GAArB,qBAAqB,CAAuB;QAC5C,oBAAe,GAAf,eAAe,CAAiB;QAChC,qBAAgB,GAAhB,gBAAgB,CAAkB;QAClC,kBAAa,GAAb,aAAa,CAAe;QAhD/B,gBAAW,GAAW,IAAI,CAAC,aAAa,EAAE,MAAM,EAAE,yBAAyB,IAAI,CAAC,CAAC;QAChF,aAAQ,GAAG,IAAI,eAAe,CAAO,IAAI,CAAC,CAAC;QACrD,kBAAa,GAAmC,IAAI,CAAC,QAAQ,CAAC,IAAI,CACvE,SAAS,CAAC,GAAG,EAAE,CACb,aAAa,CAAC;YACZ,IAAI,CAAC,eAAe,CAAC,WAAW,CAAC,IAAI,CAAC,UAAU,CAAC;YACjD,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,KAAK,CAAC;SACpC,CAAC,CACH,EACD,GAAG,CAAC,CAAC,CAAC,QAAQ,CAAC,EAAE,EAAE;YACjB,MAAM,YAAY,GAAG,QAAQ,EAAE,YAAY,IAAI,EAAE,CAAC;YAClD,MAAM,eAAe,GAAG,YAAY,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;gBAChD,GAAG,IAAI;gBACP,SAAS,EAAE,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,6BAA6B,CAAC;aAC1F,CAAC,CAAC,CAAC;YAEJ,OAAO,eAAe,IAAI,EAAE,CAAC;QAC/B,CAAC,CAAC,CACH,CAAC;QAEK,WAAM,GAAG;YACd,EAAC,GAAG,EAAE,UAAU,EAAE,KAAK,EAAE,WAAW,EAAC;YACrC,EAAC,GAAG,EAAE,aAAa,EAAE,KAAK,EAAE,eAAe,EAAC;YAC5C,EAAC,GAAG,EAAE,WAAW,EAAE,KAAK,EAAE,YAAY,EAAE,QAAQ,EAAE,MAAM,EAAC;YACzD,EAAC,GAAG,EAAE,WAAW,EAAE,KAAK,EAAE,YAAY,EAAC;SACxC,CAAC;QACK,YAAO,GAAG;YACf;gBACE,UAAU,EAAE,EAAE;gBACd,SAAS,EAAE,qBAAqB;gBAChC,QAAQ,EAAE,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,IAAI,CAAC;aAC3C;YACD;gBACE,UAAU,EAAE,EAAE;gBACd,SAAS,EAAE,gBAAgB;gBAC3B,QAAQ,EAAE,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,IAAI,CAAC;aAC5C;SACF,CAAC;QAEO,eAAU,GAAG,IAAI,eAAe,CAAU,KAAK,CAAC,CAAC;QAWxD,MAAM,QAAQ,GAAG,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,QAAQ,CAAC;QAC9C,IAAI,CAAC,UAAU,GAAG,QAAQ,CAAC,GAAG,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC;QACnD,IAAI,CAAC,sBAAsB,GAAG,QAAQ,CAAC,GAAG,CAAC,wBAAwB,CAAC,IAAI,EAAE,CAAC;IAC7E,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,gBAAgB,EAAE,CAAC;IAC1B,CAAC;IAED,YAAY,CAAC,IAAU;QACrB,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAE3B,IAAI,CAAC,qBAAqB;aACvB,UAAU,CAAC,IAAI,EAAE,IAAI,CAAC,sBAAsB,CAAC;aAC7C,IAAI,CACH,SAAS,CAAC,YAAY,CAAC,EAAE,CACvB,IAAI,CAAC,eAAe,CAAC,cAAc,CAAC,IAAI,CAAC,UAAU,EAAE,YAAY,CAAC,IAAI,CAAC,UAAU,CAAC,CACnF,CACF;aACA,SAAS,CACR,GAAG,EAAE;YACH,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,2CAA2C,CAAC,CAAC;YACxE,IAAI,CAAC,gBAAgB,EAAE,CAAC;YACxB,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC9B,CAAC,EACD,GAAG,EAAE;YACH,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,sCAAsC,CAAC,CAAC;YACjE,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC9B,CAAC,CACF,CAAC;IACN,CAAC;IAED,gBAAgB,CAAC,WAAwB;QACvC,IAAI,CAAC,qBAAqB;aACvB,WAAW,CAAC,WAAW,CAAC,MAAM,CAAC;aAC/B,SAAS,CAAC,CAAC,QAAqB,EAAE,EAAE;YACnC,IAAI,CAAC,eAAe,CAAC,YAAY,CAAC,QAAQ,CAAC,GAAG,EAAE,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;QAC1E,CAAC,CAAC,CAAC;IACP,CAAC;IAED,iBAAiB,CAAC,WAAwB;QACxC,IAAI,CAAC,eAAe,CAAC,cAAc,CAAC,IAAI,CAAC,UAAU,EAAE,WAAW,CAAC,MAAM,CAAC,CAAC,SAAS,CAChF,GAAG,EAAE;YACH,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,4CAA4C,CAAC,CAAC;YACzE,IAAI,CAAC,gBAAgB,EAAE,CAAC;QAC1B,CAAC,EACD,GAAG,EAAE;YACH,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,wCAAwC,CAAC,CAAC;QACrE,CAAC,CACF,CAAC;IACJ,CAAC;IAEO,gBAAgB;QACtB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC3B,CAAC;;gIA3GU,kCAAkC;oHAAlC,kCAAkC,4EChC/C,65CA4CA;4FDZa,kCAAkC;kBAL9C,SAAS;+BACE,sCAAsC","sourcesContent":["/*\n * Copyright 2015-2020 Ritense BV, the Netherlands.\n *\n * Licensed under EUPL, Version 1.2 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" basis,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport {Component, OnInit} from '@angular/core';\nimport {ActivatedRoute} from '@angular/router';\nimport {DocumentService, RelatedFile} from '@valtimo/document';\nimport {ResourceDto} from '@valtimo/resource';\nimport {ToastrService} from 'ngx-toastr';\nimport {DownloadService, UploadProviderService} from '@valtimo/resource';\nimport {map, switchMap} from 'rxjs/operators';\nimport {BehaviorSubject, combineLatest, Observable} from 'rxjs';\nimport {TranslateService} from '@ngx-translate/core';\nimport {ConfigService} from '@valtimo/config';\n\n@Component({\n  selector: 'valtimo-dossier-detail-tab-documents',\n  templateUrl: './documents.component.html',\n  styleUrls: ['./documents.component.css'],\n})\nexport class DossierDetailTabDocumentsComponent implements OnInit {\n  public readonly documentId: string;\n  public readonly documentDefinitionName: string;\n  public readonly maxFileSize: number = this.configService?.config?.caseFileSizeUploadLimitMB || 5;\n  private readonly refetch$ = new BehaviorSubject<null>(null);\n  public relatedFiles$: Observable<Array<RelatedFile>> = this.refetch$.pipe(\n    switchMap(() =>\n      combineLatest([\n        this.documentService.getDocument(this.documentId),\n        this.translateService.stream('key'),\n      ])\n    ),\n    map(([document]) => {\n      const relatedFiles = document?.relatedFiles || [];\n      const translatedFiles = relatedFiles.map(file => ({\n        ...file,\n        createdBy: file.createdBy || this.translateService.instant('list.automaticallyGenerated'),\n      }));\n\n      return translatedFiles || [];\n    })\n  );\n\n  public fields = [\n    {key: 'fileName', label: 'File name'},\n    {key: 'sizeInBytes', label: 'Size in bytes'},\n    {key: 'createdOn', label: 'Created on', viewType: 'date'},\n    {key: 'createdBy', label: 'Created by'},\n  ];\n  public actions = [\n    {\n      columnName: '',\n      iconClass: 'mdi mdi-open-in-new',\n      callback: this.downloadDocument.bind(this),\n    },\n    {\n      columnName: '',\n      iconClass: 'mdi mdi-delete',\n      callback: this.removeRelatedFile.bind(this),\n    },\n  ];\n\n  readonly uploading$ = new BehaviorSubject<boolean>(false);\n\n  constructor(\n    private readonly route: ActivatedRoute,\n    private readonly documentService: DocumentService,\n    private readonly toastrService: ToastrService,\n    private readonly uploadProviderService: UploadProviderService,\n    private readonly downloadService: DownloadService,\n    private readonly translateService: TranslateService,\n    private readonly configService: ConfigService\n  ) {\n    const snapshot = this.route.snapshot.paramMap;\n    this.documentId = snapshot.get('documentId') || '';\n    this.documentDefinitionName = snapshot.get('documentDefinitionName') || '';\n  }\n\n  ngOnInit(): void {\n    this.refetchDocuments();\n  }\n\n  fileSelected(file: File): void {\n    this.uploading$.next(true);\n\n    this.uploadProviderService\n      .uploadFile(file, this.documentDefinitionName)\n      .pipe(\n        switchMap(resourceFile =>\n          this.documentService.assignResource(this.documentId, resourceFile.data.resourceId)\n        )\n      )\n      .subscribe(\n        () => {\n          this.toastrService.success('Successfully uploaded document to dossier');\n          this.refetchDocuments();\n          this.uploading$.next(false);\n        },\n        () => {\n          this.toastrService.error('Failed to upload document to dossier');\n          this.uploading$.next(false);\n        }\n      );\n  }\n\n  downloadDocument(relatedFile: RelatedFile): void {\n    this.uploadProviderService\n      .getResource(relatedFile.fileId)\n      .subscribe((resource: ResourceDto) => {\n        this.downloadService.downloadFile(resource.url, resource.resource.name);\n      });\n  }\n\n  removeRelatedFile(relatedFile: RelatedFile): void {\n    this.documentService.removeResource(this.documentId, relatedFile.fileId).subscribe(\n      () => {\n        this.toastrService.success('Successfully removed document from dossier');\n        this.refetchDocuments();\n      },\n      () => {\n        this.toastrService.error('Failed to remove document from dossier');\n      }\n    );\n  }\n\n  private refetchDocuments(): void {\n    this.refetch$.next(null);\n  }\n}\n","<!--\n  ~ Copyright 2015-2020 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<valtimo-dropzone\n  (fileSelected)=\"fileSelected($event)\"\n  [acceptedFiles]=\"null\"\n  [hideFilePreview]=\"true\"\n  [hideTitle]=\"true\"\n  [maxFileSize]=\"maxFileSize\"\n  [showMaxFileSize]=\"true\"\n  [camera]=\"false\"\n  [uploading]=\"uploading$ | async\"\n></valtimo-dropzone>\n\n<valtimo-widget>\n  <valtimo-list\n    [fields]=\"fields\"\n    [items]=\"relatedFiles$ | async\"\n    [header]=\"true\"\n    [isSearchable]=\"true\"\n    [viewMode]=\"true\"\n    [actions]=\"actions\"\n  >\n    <div header>\n      <h3 class=\"list-header-title\">{{ 'Related documents' | translate }}</h3>\n      <h5 class=\"list-header-description\">\n        {{ 'Overview of all documents in this dossier' | translate }}\n      </h5>\n    </div>\n  </valtimo-list>\n</valtimo-widget>\n"]}
39
+ args: [{ selector: 'valtimo-dossier-detail-tab-documents', template: "<!--\n ~ Copyright 2015-2020 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<valtimo-dossier-detail-tab-s3-documents\n *ngIf=\"s3UploadProvider || openZaakUploadProvider\"\n></valtimo-dossier-detail-tab-s3-documents>\n<valtimo-dossier-detail-tab-documenten-api-documents *ngIf=\"documentenApiUploadProvider\">\n</valtimo-dossier-detail-tab-documenten-api-documents>\n", styles: [""] }]
40
+ }], ctorParameters: function () { return [{ type: i1.ConfigService }]; } });
41
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZG9jdW1lbnRzLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3ZhbHRpbW8vZG9zc2llci9zcmMvbGliL2Rvc3NpZXItZGV0YWlsL3RhYi9kb2N1bWVudHMvZG9jdW1lbnRzLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3ZhbHRpbW8vZG9zc2llci9zcmMvbGliL2Rvc3NpZXItZGV0YWlsL3RhYi9kb2N1bWVudHMvZG9jdW1lbnRzLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7Ozs7Ozs7OztHQWNHO0FBRUgsT0FBTyxFQUFDLFNBQVMsRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUN4QyxPQUFPLEVBQWdCLGNBQWMsRUFBZ0IsTUFBTSxpQkFBaUIsQ0FBQzs7Ozs7O0FBTzdFLE1BQU0sT0FBTyxrQ0FBa0M7SUFLN0MsWUFBNkIsYUFBNEI7UUFBNUIsa0JBQWEsR0FBYixhQUFhLENBQWU7UUFDdkQsSUFBSSxDQUFDLFNBQVMsQ0FBQyxhQUFhLENBQUMsTUFBTSxDQUFDLENBQUM7SUFDdkMsQ0FBQztJQUVPLFNBQVMsQ0FBQyxNQUFxQjtRQUNyQyxNQUFNLGNBQWMsR0FBRyxNQUFNLENBQUMsY0FBYyxDQUFDO1FBQzdDLElBQUksQ0FBQyxzQkFBc0IsR0FBRyxjQUFjLEtBQUssY0FBYyxDQUFDLFNBQVMsQ0FBQztRQUMxRSxJQUFJLENBQUMsMkJBQTJCLEdBQUcsY0FBYyxLQUFLLGNBQWMsQ0FBQyxjQUFjLENBQUM7UUFDcEYsSUFBSSxDQUFDLGdCQUFnQixHQUFHLE1BQU0sQ0FBQyxjQUFjLEtBQUssY0FBYyxDQUFDLEVBQUUsQ0FBQztJQUN0RSxDQUFDOztnSUFkVSxrQ0FBa0M7b0hBQWxDLGtDQUFrQyw0RUN4Qi9DLHM3QkFxQkE7NEZER2Esa0NBQWtDO2tCQUw5QyxTQUFTOytCQUNFLHNDQUFzQyIsInNvdXJjZXNDb250ZW50IjpbIi8qXG4gKiBDb3B5cmlnaHQgMjAxNS0yMDIwIFJpdGVuc2UgQlYsIHRoZSBOZXRoZXJsYW5kcy5cbiAqXG4gKiBMaWNlbnNlZCB1bmRlciBFVVBMLCBWZXJzaW9uIDEuMiAodGhlIFwiTGljZW5zZVwiKTtcbiAqIHlvdSBtYXkgbm90IHVzZSB0aGlzIGZpbGUgZXhjZXB0IGluIGNvbXBsaWFuY2Ugd2l0aCB0aGUgTGljZW5zZS5cbiAqIFlvdSBtYXkgb2J0YWluIGEgY29weSBvZiB0aGUgTGljZW5zZSBhdFxuICpcbiAqIGh0dHBzOi8vam9pbnVwLmVjLmV1cm9wYS5ldS9jb2xsZWN0aW9uL2V1cGwvZXVwbC10ZXh0LWV1cGwtMTJcbiAqXG4gKiBVbmxlc3MgcmVxdWlyZWQgYnkgYXBwbGljYWJsZSBsYXcgb3IgYWdyZWVkIHRvIGluIHdyaXRpbmcsIHNvZnR3YXJlXG4gKiBkaXN0cmlidXRlZCB1bmRlciB0aGUgTGljZW5zZSBpcyBkaXN0cmlidXRlZCBvbiBhbiBcIkFTIElTXCIgYmFzaXMsXG4gKiBXSVRIT1VUIFdBUlJBTlRJRVMgT1IgQ09ORElUSU9OUyBPRiBBTlkgS0lORCwgZWl0aGVyIGV4cHJlc3Mgb3IgaW1wbGllZC5cbiAqIFNlZSB0aGUgTGljZW5zZSBmb3IgdGhlIHNwZWNpZmljIGxhbmd1YWdlIGdvdmVybmluZyBwZXJtaXNzaW9ucyBhbmRcbiAqIGxpbWl0YXRpb25zIHVuZGVyIHRoZSBMaWNlbnNlLlxuICovXG5cbmltcG9ydCB7Q29tcG9uZW50fSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7Q29uZmlnU2VydmljZSwgVXBsb2FkUHJvdmlkZXIsIFZhbHRpbW9Db25maWd9IGZyb20gJ0B2YWx0aW1vL2NvbmZpZyc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ3ZhbHRpbW8tZG9zc2llci1kZXRhaWwtdGFiLWRvY3VtZW50cycsXG4gIHRlbXBsYXRlVXJsOiAnLi9kb2N1bWVudHMuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9kb2N1bWVudHMuY29tcG9uZW50LmNzcyddLFxufSlcbmV4cG9ydCBjbGFzcyBEb3NzaWVyRGV0YWlsVGFiRG9jdW1lbnRzQ29tcG9uZW50IHtcbiAgb3BlblphYWtVcGxvYWRQcm92aWRlciE6IGJvb2xlYW47XG4gIHMzVXBsb2FkUHJvdmlkZXIhOiBib29sZWFuO1xuICBkb2N1bWVudGVuQXBpVXBsb2FkUHJvdmlkZXIhOiBib29sZWFuO1xuXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgcmVhZG9ubHkgY29uZmlnU2VydmljZTogQ29uZmlnU2VydmljZSkge1xuICAgIHRoaXMuc2V0Q29uZmlnKGNvbmZpZ1NlcnZpY2UuY29uZmlnKTtcbiAgfVxuXG4gIHByaXZhdGUgc2V0Q29uZmlnKGNvbmZpZzogVmFsdGltb0NvbmZpZyk6IHZvaWQge1xuICAgIGNvbnN0IHVwbG9hZFByb3ZpZGVyID0gY29uZmlnLnVwbG9hZFByb3ZpZGVyO1xuICAgIHRoaXMub3BlblphYWtVcGxvYWRQcm92aWRlciA9IHVwbG9hZFByb3ZpZGVyID09PSBVcGxvYWRQcm92aWRlci5PUEVOX1pBQUs7XG4gICAgdGhpcy5kb2N1bWVudGVuQXBpVXBsb2FkUHJvdmlkZXIgPSB1cGxvYWRQcm92aWRlciA9PT0gVXBsb2FkUHJvdmlkZXIuRE9DVU1FTlRFTl9BUEk7XG4gICAgdGhpcy5zM1VwbG9hZFByb3ZpZGVyID0gY29uZmlnLnVwbG9hZFByb3ZpZGVyID09PSBVcGxvYWRQcm92aWRlci5TMztcbiAgfVxufVxuIiwiPCEtLVxuICB+IENvcHlyaWdodCAyMDE1LTIwMjAgUml0ZW5zZSBCViwgdGhlIE5ldGhlcmxhbmRzLlxuICB+XG4gIH4gTGljZW5zZWQgdW5kZXIgRVVQTCwgVmVyc2lvbiAxLjIgKHRoZSBcIkxpY2Vuc2VcIik7XG4gIH4geW91IG1heSBub3QgdXNlIHRoaXMgZmlsZSBleGNlcHQgaW4gY29tcGxpYW5jZSB3aXRoIHRoZSBMaWNlbnNlLlxuICB+IFlvdSBtYXkgb2J0YWluIGEgY29weSBvZiB0aGUgTGljZW5zZSBhdFxuICB+XG4gIH4gaHR0cHM6Ly9qb2ludXAuZWMuZXVyb3BhLmV1L2NvbGxlY3Rpb24vZXVwbC9ldXBsLXRleHQtZXVwbC0xMlxuICB+XG4gIH4gVW5sZXNzIHJlcXVpcmVkIGJ5IGFwcGxpY2FibGUgbGF3IG9yIGFncmVlZCB0byBpbiB3cml0aW5nLCBzb2Z0d2FyZVxuICB+IGRpc3RyaWJ1dGVkIHVuZGVyIHRoZSBMaWNlbnNlIGlzIGRpc3RyaWJ1dGVkIG9uIGFuIFwiQVMgSVNcIiBiYXNpcyxcbiAgfiBXSVRIT1VUIFdBUlJBTlRJRVMgT1IgQ09ORElUSU9OUyBPRiBBTlkgS0lORCwgZWl0aGVyIGV4cHJlc3Mgb3IgaW1wbGllZC5cbiAgfiBTZWUgdGhlIExpY2Vuc2UgZm9yIHRoZSBzcGVjaWZpYyBsYW5ndWFnZSBnb3Zlcm5pbmcgcGVybWlzc2lvbnMgYW5kXG4gIH4gbGltaXRhdGlvbnMgdW5kZXIgdGhlIExpY2Vuc2UuXG4gIC0tPlxuXG48dmFsdGltby1kb3NzaWVyLWRldGFpbC10YWItczMtZG9jdW1lbnRzXG4gICpuZ0lmPVwiczNVcGxvYWRQcm92aWRlciB8fCBvcGVuWmFha1VwbG9hZFByb3ZpZGVyXCJcbj48L3ZhbHRpbW8tZG9zc2llci1kZXRhaWwtdGFiLXMzLWRvY3VtZW50cz5cbjx2YWx0aW1vLWRvc3NpZXItZGV0YWlsLXRhYi1kb2N1bWVudGVuLWFwaS1kb2N1bWVudHMgKm5nSWY9XCJkb2N1bWVudGVuQXBpVXBsb2FkUHJvdmlkZXJcIj5cbjwvdmFsdGltby1kb3NzaWVyLWRldGFpbC10YWItZG9jdW1lbnRlbi1hcGktZG9jdW1lbnRzPlxuIl19
@@ -32,7 +32,8 @@ export class DossierDetailTabProgressComponent {
32
32
  this.documentService
33
33
  .findProcessDocumentInstances(this.documentId)
34
34
  .subscribe(processDocumentInstances => {
35
- this.processDocumentInstances = processDocumentInstances;
35
+ this.processDocumentInstances = processDocumentInstances
36
+ .sort((a, b) => (a.isActive === b.isActive) ? 0 : a.isActive ? -1 : 1);
36
37
  if (processDocumentInstances.length > 0) {
37
38
  this.selectedProcessInstanceId = processDocumentInstances[0].id.processInstanceId;
38
39
  }
@@ -48,4 +49,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImpo
48
49
  type: Component,
49
50
  args: [{ selector: 'valtimo-dossier-detail-tab-progress', template: "<!--\n ~ Copyright 2015-2020 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=\"full-height-tab-content\"\n *ngIf=\"\n processDocumentInstances && processDocumentInstances.length > 0;\n else emptyProcessDocumentInstances\n \"\n>\n <div class=\"col-3\">\n <label><strong>Process</strong></label\n ><br />\n <select class=\"form-control\" (change)=\"loadProcessInstance($event.target.value)\">\n <option\n *ngFor=\"let processDocumentInstance of processDocumentInstances\"\n [value]=\"processDocumentInstance.id.processInstanceId\"\n [selected]=\"selectedProcessInstanceId === processDocumentInstance.id.processInstanceId\"\n >\n {{ processDocumentInstance.processName }}\n </option>\n </select>\n </div>\n <valtimo-process-diagram\n [processInstanceId]=\"selectedProcessInstanceId\"\n ></valtimo-process-diagram>\n</div>\n\n<ng-template #emptyProcessDocumentInstances>\n <span> {{ 'progress.noProcessDocumentInstances' | translate }}</span>\n</ng-template>\n", styles: [".full-height-tab-content{height:calc(100vh - 380px);width:100%}\n"] }]
50
51
  }], ctorParameters: function () { return [{ type: i1.ActivatedRoute }, { type: i2.DocumentService }]; } });
51
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvZ3Jlc3MuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdmFsdGltby9kb3NzaWVyL3NyYy9saWIvZG9zc2llci1kZXRhaWwvdGFiL3Byb2dyZXNzL3Byb2dyZXNzLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3ZhbHRpbW8vZG9zc2llci9zcmMvbGliL2Rvc3NpZXItZGV0YWlsL3RhYi9wcm9ncmVzcy9wcm9ncmVzcy5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7Ozs7Ozs7Ozs7R0FjRztBQUVILE9BQU8sRUFBQyxTQUFTLEVBQVMsTUFBTSxlQUFlLENBQUM7Ozs7Ozs7O0FBVWhELE1BQU0sT0FBTyxpQ0FBaUM7SUFLNUMsWUFBb0IsS0FBcUIsRUFBVSxlQUFnQztRQUEvRCxVQUFLLEdBQUwsS0FBSyxDQUFnQjtRQUFVLG9CQUFlLEdBQWYsZUFBZSxDQUFpQjtRQUNqRixNQUFNLFFBQVEsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLFFBQVEsQ0FBQyxRQUFRLENBQUM7UUFDOUMsSUFBSSxDQUFDLFVBQVUsR0FBRyxRQUFRLENBQUMsR0FBRyxDQUFDLFlBQVksQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUNyRCxDQUFDO0lBRUQsUUFBUTtRQUNOLElBQUksQ0FBQyxlQUFlO2FBQ2pCLDRCQUE0QixDQUFDLElBQUksQ0FBQyxVQUFVLENBQUM7YUFDN0MsU0FBUyxDQUFDLHdCQUF3QixDQUFDLEVBQUU7WUFDcEMsSUFBSSxDQUFDLHdCQUF3QixHQUFHLHdCQUF3QixDQUFDO1lBQ3pELElBQUksd0JBQXdCLENBQUMsTUFBTSxHQUFHLENBQUMsRUFBRTtnQkFDdkMsSUFBSSxDQUFDLHlCQUF5QixHQUFHLHdCQUF3QixDQUFDLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxpQkFBaUIsQ0FBQzthQUNuRjtRQUNILENBQUMsQ0FBQyxDQUFDO0lBQ1AsQ0FBQztJQUVNLG1CQUFtQixDQUFDLGlCQUF5QjtRQUNsRCxJQUFJLENBQUMseUJBQXlCLEdBQUcsaUJBQWlCLENBQUM7SUFDckQsQ0FBQzs7K0hBdkJVLGlDQUFpQzttSEFBakMsaUNBQWlDLDJFQzFCOUMsc2xEQTRDQTs0RkRsQmEsaUNBQWlDO2tCQUw3QyxTQUFTOytCQUNFLHFDQUFxQyIsInNvdXJjZXNDb250ZW50IjpbIi8qXG4gKiBDb3B5cmlnaHQgMjAxNS0yMDIwIFJpdGVuc2UgQlYsIHRoZSBOZXRoZXJsYW5kcy5cbiAqXG4gKiBMaWNlbnNlZCB1bmRlciBFVVBMLCBWZXJzaW9uIDEuMiAodGhlIFwiTGljZW5zZVwiKTtcbiAqIHlvdSBtYXkgbm90IHVzZSB0aGlzIGZpbGUgZXhjZXB0IGluIGNvbXBsaWFuY2Ugd2l0aCB0aGUgTGljZW5zZS5cbiAqIFlvdSBtYXkgb2J0YWluIGEgY29weSBvZiB0aGUgTGljZW5zZSBhdFxuICpcbiAqIGh0dHBzOi8vam9pbnVwLmVjLmV1cm9wYS5ldS9jb2xsZWN0aW9uL2V1cGwvZXVwbC10ZXh0LWV1cGwtMTJcbiAqXG4gKiBVbmxlc3MgcmVxdWlyZWQgYnkgYXBwbGljYWJsZSBsYXcgb3IgYWdyZWVkIHRvIGluIHdyaXRpbmcsIHNvZnR3YXJlXG4gKiBkaXN0cmlidXRlZCB1bmRlciB0aGUgTGljZW5zZSBpcyBkaXN0cmlidXRlZCBvbiBhbiBcIkFTIElTXCIgYmFzaXMsXG4gKiBXSVRIT1VUIFdBUlJBTlRJRVMgT1IgQ09ORElUSU9OUyBPRiBBTlkgS0lORCwgZWl0aGVyIGV4cHJlc3Mgb3IgaW1wbGllZC5cbiAqIFNlZSB0aGUgTGljZW5zZSBmb3IgdGhlIHNwZWNpZmljIGxhbmd1YWdlIGdvdmVybmluZyBwZXJtaXNzaW9ucyBhbmRcbiAqIGxpbWl0YXRpb25zIHVuZGVyIHRoZSBMaWNlbnNlLlxuICovXG5cbmltcG9ydCB7Q29tcG9uZW50LCBPbkluaXR9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtBY3RpdmF0ZWRSb3V0ZX0gZnJvbSAnQGFuZ3VsYXIvcm91dGVyJztcbmltcG9ydCB7RG9jdW1lbnRTZXJ2aWNlfSBmcm9tICdAdmFsdGltby9kb2N1bWVudCc7XG5pbXBvcnQge1Byb2Nlc3NEb2N1bWVudEluc3RhbmNlfSBmcm9tICdAdmFsdGltby9kb2N1bWVudCc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ3ZhbHRpbW8tZG9zc2llci1kZXRhaWwtdGFiLXByb2dyZXNzJyxcbiAgdGVtcGxhdGVVcmw6ICcuL3Byb2dyZXNzLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vcHJvZ3Jlc3MuY29tcG9uZW50LmNzcyddLFxufSlcbmV4cG9ydCBjbGFzcyBEb3NzaWVyRGV0YWlsVGFiUHJvZ3Jlc3NDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xuICBwdWJsaWMgcHJvY2Vzc0RvY3VtZW50SW5zdGFuY2VzOiBQcm9jZXNzRG9jdW1lbnRJbnN0YW5jZVtdO1xuICBwdWJsaWMgc2VsZWN0ZWRQcm9jZXNzSW5zdGFuY2VJZDogc3RyaW5nO1xuICBwdWJsaWMgcmVhZG9ubHkgZG9jdW1lbnRJZDogc3RyaW5nO1xuXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgcm91dGU6IEFjdGl2YXRlZFJvdXRlLCBwcml2YXRlIGRvY3VtZW50U2VydmljZTogRG9jdW1lbnRTZXJ2aWNlKSB7XG4gICAgY29uc3Qgc25hcHNob3QgPSB0aGlzLnJvdXRlLnNuYXBzaG90LnBhcmFtTWFwO1xuICAgIHRoaXMuZG9jdW1lbnRJZCA9IHNuYXBzaG90LmdldCgnZG9jdW1lbnRJZCcpIHx8ICcnO1xuICB9XG5cbiAgbmdPbkluaXQoKSB7XG4gICAgdGhpcy5kb2N1bWVudFNlcnZpY2VcbiAgICAgIC5maW5kUHJvY2Vzc0RvY3VtZW50SW5zdGFuY2VzKHRoaXMuZG9jdW1lbnRJZClcbiAgICAgIC5zdWJzY3JpYmUocHJvY2Vzc0RvY3VtZW50SW5zdGFuY2VzID0+IHtcbiAgICAgICAgdGhpcy5wcm9jZXNzRG9jdW1lbnRJbnN0YW5jZXMgPSBwcm9jZXNzRG9jdW1lbnRJbnN0YW5jZXM7XG4gICAgICAgIGlmIChwcm9jZXNzRG9jdW1lbnRJbnN0YW5jZXMubGVuZ3RoID4gMCkge1xuICAgICAgICAgIHRoaXMuc2VsZWN0ZWRQcm9jZXNzSW5zdGFuY2VJZCA9IHByb2Nlc3NEb2N1bWVudEluc3RhbmNlc1swXS5pZC5wcm9jZXNzSW5zdGFuY2VJZDtcbiAgICAgICAgfVxuICAgICAgfSk7XG4gIH1cblxuICBwdWJsaWMgbG9hZFByb2Nlc3NJbnN0YW5jZShwcm9jZXNzSW5zdGFuY2VJZDogc3RyaW5nKSB7XG4gICAgdGhpcy5zZWxlY3RlZFByb2Nlc3NJbnN0YW5jZUlkID0gcHJvY2Vzc0luc3RhbmNlSWQ7XG4gIH1cbn1cbiIsIjwhLS1cbiAgfiBDb3B5cmlnaHQgMjAxNS0yMDIwIFJpdGVuc2UgQlYsIHRoZSBOZXRoZXJsYW5kcy5cbiAgflxuICB+IExpY2Vuc2VkIHVuZGVyIEVVUEwsIFZlcnNpb24gMS4yICh0aGUgXCJMaWNlbnNlXCIpO1xuICB+IHlvdSBtYXkgbm90IHVzZSB0aGlzIGZpbGUgZXhjZXB0IGluIGNvbXBsaWFuY2Ugd2l0aCB0aGUgTGljZW5zZS5cbiAgfiBZb3UgbWF5IG9idGFpbiBhIGNvcHkgb2YgdGhlIExpY2Vuc2UgYXRcbiAgflxuICB+IGh0dHBzOi8vam9pbnVwLmVjLmV1cm9wYS5ldS9jb2xsZWN0aW9uL2V1cGwvZXVwbC10ZXh0LWV1cGwtMTJcbiAgflxuICB+IFVubGVzcyByZXF1aXJlZCBieSBhcHBsaWNhYmxlIGxhdyBvciBhZ3JlZWQgdG8gaW4gd3JpdGluZywgc29mdHdhcmVcbiAgfiBkaXN0cmlidXRlZCB1bmRlciB0aGUgTGljZW5zZSBpcyBkaXN0cmlidXRlZCBvbiBhbiBcIkFTIElTXCIgYmFzaXMsXG4gIH4gV0lUSE9VVCBXQVJSQU5USUVTIE9SIENPTkRJVElPTlMgT0YgQU5ZIEtJTkQsIGVpdGhlciBleHByZXNzIG9yIGltcGxpZWQuXG4gIH4gU2VlIHRoZSBMaWNlbnNlIGZvciB0aGUgc3BlY2lmaWMgbGFuZ3VhZ2UgZ292ZXJuaW5nIHBlcm1pc3Npb25zIGFuZFxuICB+IGxpbWl0YXRpb25zIHVuZGVyIHRoZSBMaWNlbnNlLlxuICAtLT5cblxuPGRpdlxuICBjbGFzcz1cImZ1bGwtaGVpZ2h0LXRhYi1jb250ZW50XCJcbiAgKm5nSWY9XCJcbiAgICBwcm9jZXNzRG9jdW1lbnRJbnN0YW5jZXMgJiYgcHJvY2Vzc0RvY3VtZW50SW5zdGFuY2VzLmxlbmd0aCA+IDA7XG4gICAgZWxzZSBlbXB0eVByb2Nlc3NEb2N1bWVudEluc3RhbmNlc1xuICBcIlxuPlxuICA8ZGl2IGNsYXNzPVwiY29sLTNcIj5cbiAgICA8bGFiZWw+PHN0cm9uZz5Qcm9jZXNzPC9zdHJvbmc+PC9sYWJlbFxuICAgID48YnIgLz5cbiAgICA8c2VsZWN0IGNsYXNzPVwiZm9ybS1jb250cm9sXCIgKGNoYW5nZSk9XCJsb2FkUHJvY2Vzc0luc3RhbmNlKCRldmVudC50YXJnZXQudmFsdWUpXCI+XG4gICAgICA8b3B0aW9uXG4gICAgICAgICpuZ0Zvcj1cImxldCBwcm9jZXNzRG9jdW1lbnRJbnN0YW5jZSBvZiBwcm9jZXNzRG9jdW1lbnRJbnN0YW5jZXNcIlxuICAgICAgICBbdmFsdWVdPVwicHJvY2Vzc0RvY3VtZW50SW5zdGFuY2UuaWQucHJvY2Vzc0luc3RhbmNlSWRcIlxuICAgICAgICBbc2VsZWN0ZWRdPVwic2VsZWN0ZWRQcm9jZXNzSW5zdGFuY2VJZCA9PT0gcHJvY2Vzc0RvY3VtZW50SW5zdGFuY2UuaWQucHJvY2Vzc0luc3RhbmNlSWRcIlxuICAgICAgPlxuICAgICAgICB7eyBwcm9jZXNzRG9jdW1lbnRJbnN0YW5jZS5wcm9jZXNzTmFtZSB9fVxuICAgICAgPC9vcHRpb24+XG4gICAgPC9zZWxlY3Q+XG4gIDwvZGl2PlxuICA8dmFsdGltby1wcm9jZXNzLWRpYWdyYW1cbiAgICBbcHJvY2Vzc0luc3RhbmNlSWRdPVwic2VsZWN0ZWRQcm9jZXNzSW5zdGFuY2VJZFwiXG4gID48L3ZhbHRpbW8tcHJvY2Vzcy1kaWFncmFtPlxuPC9kaXY+XG5cbjxuZy10ZW1wbGF0ZSAjZW1wdHlQcm9jZXNzRG9jdW1lbnRJbnN0YW5jZXM+XG4gIDxzcGFuPiB7eyAncHJvZ3Jlc3Mubm9Qcm9jZXNzRG9jdW1lbnRJbnN0YW5jZXMnIHwgdHJhbnNsYXRlIH19PC9zcGFuPlxuPC9uZy10ZW1wbGF0ZT5cbiJdfQ==
52
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvZ3Jlc3MuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdmFsdGltby9kb3NzaWVyL3NyYy9saWIvZG9zc2llci1kZXRhaWwvdGFiL3Byb2dyZXNzL3Byb2dyZXNzLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3ZhbHRpbW8vZG9zc2llci9zcmMvbGliL2Rvc3NpZXItZGV0YWlsL3RhYi9wcm9ncmVzcy9wcm9ncmVzcy5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7Ozs7Ozs7Ozs7R0FjRztBQUVILE9BQU8sRUFBQyxTQUFTLEVBQVMsTUFBTSxlQUFlLENBQUM7Ozs7Ozs7O0FBVWhELE1BQU0sT0FBTyxpQ0FBaUM7SUFLNUMsWUFBb0IsS0FBcUIsRUFBVSxlQUFnQztRQUEvRCxVQUFLLEdBQUwsS0FBSyxDQUFnQjtRQUFVLG9CQUFlLEdBQWYsZUFBZSxDQUFpQjtRQUNqRixNQUFNLFFBQVEsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLFFBQVEsQ0FBQyxRQUFRLENBQUM7UUFDOUMsSUFBSSxDQUFDLFVBQVUsR0FBRyxRQUFRLENBQUMsR0FBRyxDQUFDLFlBQVksQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUNyRCxDQUFDO0lBRUQsUUFBUTtRQUNOLElBQUksQ0FBQyxlQUFlO2FBQ2pCLDRCQUE0QixDQUFDLElBQUksQ0FBQyxVQUFVLENBQUM7YUFDN0MsU0FBUyxDQUFDLHdCQUF3QixDQUFDLEVBQUU7WUFDcEMsSUFBSSxDQUFDLHdCQUF3QixHQUFHLHdCQUF3QjtpQkFDckQsSUFBSSxDQUFDLENBQUMsQ0FBQyxFQUFDLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQyxDQUFDLENBQUMsUUFBUSxLQUFLLENBQUMsQ0FBQyxRQUFRLENBQUMsQ0FBQSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7WUFDdEUsSUFBSSx3QkFBd0IsQ0FBQyxNQUFNLEdBQUcsQ0FBQyxFQUFFO2dCQUN2QyxJQUFJLENBQUMseUJBQXlCLEdBQUcsd0JBQXdCLENBQUMsQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLGlCQUFpQixDQUFDO2FBQ25GO1FBQ0gsQ0FBQyxDQUFDLENBQUM7SUFDUCxDQUFDO0lBRU0sbUJBQW1CLENBQUMsaUJBQXlCO1FBQ2xELElBQUksQ0FBQyx5QkFBeUIsR0FBRyxpQkFBaUIsQ0FBQztJQUNyRCxDQUFDOzsrSEF4QlUsaUNBQWlDO21IQUFqQyxpQ0FBaUMsMkVDMUI5QyxzbERBNENBOzRGRGxCYSxpQ0FBaUM7a0JBTDdDLFNBQVM7K0JBQ0UscUNBQXFDIiwic291cmNlc0NvbnRlbnQiOlsiLypcbiAqIENvcHlyaWdodCAyMDE1LTIwMjAgUml0ZW5zZSBCViwgdGhlIE5ldGhlcmxhbmRzLlxuICpcbiAqIExpY2Vuc2VkIHVuZGVyIEVVUEwsIFZlcnNpb24gMS4yICh0aGUgXCJMaWNlbnNlXCIpO1xuICogeW91IG1heSBub3QgdXNlIHRoaXMgZmlsZSBleGNlcHQgaW4gY29tcGxpYW5jZSB3aXRoIHRoZSBMaWNlbnNlLlxuICogWW91IG1heSBvYnRhaW4gYSBjb3B5IG9mIHRoZSBMaWNlbnNlIGF0XG4gKlxuICogaHR0cHM6Ly9qb2ludXAuZWMuZXVyb3BhLmV1L2NvbGxlY3Rpb24vZXVwbC9ldXBsLXRleHQtZXVwbC0xMlxuICpcbiAqIFVubGVzcyByZXF1aXJlZCBieSBhcHBsaWNhYmxlIGxhdyBvciBhZ3JlZWQgdG8gaW4gd3JpdGluZywgc29mdHdhcmVcbiAqIGRpc3RyaWJ1dGVkIHVuZGVyIHRoZSBMaWNlbnNlIGlzIGRpc3RyaWJ1dGVkIG9uIGFuIFwiQVMgSVNcIiBiYXNpcyxcbiAqIFdJVEhPVVQgV0FSUkFOVElFUyBPUiBDT05ESVRJT05TIE9GIEFOWSBLSU5ELCBlaXRoZXIgZXhwcmVzcyBvciBpbXBsaWVkLlxuICogU2VlIHRoZSBMaWNlbnNlIGZvciB0aGUgc3BlY2lmaWMgbGFuZ3VhZ2UgZ292ZXJuaW5nIHBlcm1pc3Npb25zIGFuZFxuICogbGltaXRhdGlvbnMgdW5kZXIgdGhlIExpY2Vuc2UuXG4gKi9cblxuaW1wb3J0IHtDb21wb25lbnQsIE9uSW5pdH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge0FjdGl2YXRlZFJvdXRlfSBmcm9tICdAYW5ndWxhci9yb3V0ZXInO1xuaW1wb3J0IHtEb2N1bWVudFNlcnZpY2V9IGZyb20gJ0B2YWx0aW1vL2RvY3VtZW50JztcbmltcG9ydCB7UHJvY2Vzc0RvY3VtZW50SW5zdGFuY2V9IGZyb20gJ0B2YWx0aW1vL2RvY3VtZW50JztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAndmFsdGltby1kb3NzaWVyLWRldGFpbC10YWItcHJvZ3Jlc3MnLFxuICB0ZW1wbGF0ZVVybDogJy4vcHJvZ3Jlc3MuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9wcm9ncmVzcy5jb21wb25lbnQuY3NzJ10sXG59KVxuZXhwb3J0IGNsYXNzIERvc3NpZXJEZXRhaWxUYWJQcm9ncmVzc0NvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XG4gIHB1YmxpYyBwcm9jZXNzRG9jdW1lbnRJbnN0YW5jZXM6IFByb2Nlc3NEb2N1bWVudEluc3RhbmNlW107XG4gIHB1YmxpYyBzZWxlY3RlZFByb2Nlc3NJbnN0YW5jZUlkOiBzdHJpbmc7XG4gIHB1YmxpYyByZWFkb25seSBkb2N1bWVudElkOiBzdHJpbmc7XG5cbiAgY29uc3RydWN0b3IocHJpdmF0ZSByb3V0ZTogQWN0aXZhdGVkUm91dGUsIHByaXZhdGUgZG9jdW1lbnRTZXJ2aWNlOiBEb2N1bWVudFNlcnZpY2UpIHtcbiAgICBjb25zdCBzbmFwc2hvdCA9IHRoaXMucm91dGUuc25hcHNob3QucGFyYW1NYXA7XG4gICAgdGhpcy5kb2N1bWVudElkID0gc25hcHNob3QuZ2V0KCdkb2N1bWVudElkJykgfHwgJyc7XG4gIH1cblxuICBuZ09uSW5pdCgpIHtcbiAgICB0aGlzLmRvY3VtZW50U2VydmljZVxuICAgICAgLmZpbmRQcm9jZXNzRG9jdW1lbnRJbnN0YW5jZXModGhpcy5kb2N1bWVudElkKVxuICAgICAgLnN1YnNjcmliZShwcm9jZXNzRG9jdW1lbnRJbnN0YW5jZXMgPT4ge1xuICAgICAgICB0aGlzLnByb2Nlc3NEb2N1bWVudEluc3RhbmNlcyA9IHByb2Nlc3NEb2N1bWVudEluc3RhbmNlc1xuICAgICAgICAgIC5zb3J0KChhLGIpID0+IChhLmlzQWN0aXZlID09PSBiLmlzQWN0aXZlKT8gMCA6IGEuaXNBY3RpdmUgPyAtMTogMSk7XG4gICAgICAgIGlmIChwcm9jZXNzRG9jdW1lbnRJbnN0YW5jZXMubGVuZ3RoID4gMCkge1xuICAgICAgICAgIHRoaXMuc2VsZWN0ZWRQcm9jZXNzSW5zdGFuY2VJZCA9IHByb2Nlc3NEb2N1bWVudEluc3RhbmNlc1swXS5pZC5wcm9jZXNzSW5zdGFuY2VJZDtcbiAgICAgICAgfVxuICAgICAgfSk7XG4gIH1cblxuICBwdWJsaWMgbG9hZFByb2Nlc3NJbnN0YW5jZShwcm9jZXNzSW5zdGFuY2VJZDogc3RyaW5nKSB7XG4gICAgdGhpcy5zZWxlY3RlZFByb2Nlc3NJbnN0YW5jZUlkID0gcHJvY2Vzc0luc3RhbmNlSWQ7XG4gIH1cbn1cbiIsIjwhLS1cbiAgfiBDb3B5cmlnaHQgMjAxNS0yMDIwIFJpdGVuc2UgQlYsIHRoZSBOZXRoZXJsYW5kcy5cbiAgflxuICB+IExpY2Vuc2VkIHVuZGVyIEVVUEwsIFZlcnNpb24gMS4yICh0aGUgXCJMaWNlbnNlXCIpO1xuICB+IHlvdSBtYXkgbm90IHVzZSB0aGlzIGZpbGUgZXhjZXB0IGluIGNvbXBsaWFuY2Ugd2l0aCB0aGUgTGljZW5zZS5cbiAgfiBZb3UgbWF5IG9idGFpbiBhIGNvcHkgb2YgdGhlIExpY2Vuc2UgYXRcbiAgflxuICB+IGh0dHBzOi8vam9pbnVwLmVjLmV1cm9wYS5ldS9jb2xsZWN0aW9uL2V1cGwvZXVwbC10ZXh0LWV1cGwtMTJcbiAgflxuICB+IFVubGVzcyByZXF1aXJlZCBieSBhcHBsaWNhYmxlIGxhdyBvciBhZ3JlZWQgdG8gaW4gd3JpdGluZywgc29mdHdhcmVcbiAgfiBkaXN0cmlidXRlZCB1bmRlciB0aGUgTGljZW5zZSBpcyBkaXN0cmlidXRlZCBvbiBhbiBcIkFTIElTXCIgYmFzaXMsXG4gIH4gV0lUSE9VVCBXQVJSQU5USUVTIE9SIENPTkRJVElPTlMgT0YgQU5ZIEtJTkQsIGVpdGhlciBleHByZXNzIG9yIGltcGxpZWQuXG4gIH4gU2VlIHRoZSBMaWNlbnNlIGZvciB0aGUgc3BlY2lmaWMgbGFuZ3VhZ2UgZ292ZXJuaW5nIHBlcm1pc3Npb25zIGFuZFxuICB+IGxpbWl0YXRpb25zIHVuZGVyIHRoZSBMaWNlbnNlLlxuICAtLT5cblxuPGRpdlxuICBjbGFzcz1cImZ1bGwtaGVpZ2h0LXRhYi1jb250ZW50XCJcbiAgKm5nSWY9XCJcbiAgICBwcm9jZXNzRG9jdW1lbnRJbnN0YW5jZXMgJiYgcHJvY2Vzc0RvY3VtZW50SW5zdGFuY2VzLmxlbmd0aCA+IDA7XG4gICAgZWxzZSBlbXB0eVByb2Nlc3NEb2N1bWVudEluc3RhbmNlc1xuICBcIlxuPlxuICA8ZGl2IGNsYXNzPVwiY29sLTNcIj5cbiAgICA8bGFiZWw+PHN0cm9uZz5Qcm9jZXNzPC9zdHJvbmc+PC9sYWJlbFxuICAgID48YnIgLz5cbiAgICA8c2VsZWN0IGNsYXNzPVwiZm9ybS1jb250cm9sXCIgKGNoYW5nZSk9XCJsb2FkUHJvY2Vzc0luc3RhbmNlKCRldmVudC50YXJnZXQudmFsdWUpXCI+XG4gICAgICA8b3B0aW9uXG4gICAgICAgICpuZ0Zvcj1cImxldCBwcm9jZXNzRG9jdW1lbnRJbnN0YW5jZSBvZiBwcm9jZXNzRG9jdW1lbnRJbnN0YW5jZXNcIlxuICAgICAgICBbdmFsdWVdPVwicHJvY2Vzc0RvY3VtZW50SW5zdGFuY2UuaWQucHJvY2Vzc0luc3RhbmNlSWRcIlxuICAgICAgICBbc2VsZWN0ZWRdPVwic2VsZWN0ZWRQcm9jZXNzSW5zdGFuY2VJZCA9PT0gcHJvY2Vzc0RvY3VtZW50SW5zdGFuY2UuaWQucHJvY2Vzc0luc3RhbmNlSWRcIlxuICAgICAgPlxuICAgICAgICB7eyBwcm9jZXNzRG9jdW1lbnRJbnN0YW5jZS5wcm9jZXNzTmFtZSB9fVxuICAgICAgPC9vcHRpb24+XG4gICAgPC9zZWxlY3Q+XG4gIDwvZGl2PlxuICA8dmFsdGltby1wcm9jZXNzLWRpYWdyYW1cbiAgICBbcHJvY2Vzc0luc3RhbmNlSWRdPVwic2VsZWN0ZWRQcm9jZXNzSW5zdGFuY2VJZFwiXG4gID48L3ZhbHRpbW8tcHJvY2Vzcy1kaWFncmFtPlxuPC9kaXY+XG5cbjxuZy10ZW1wbGF0ZSAjZW1wdHlQcm9jZXNzRG9jdW1lbnRJbnN0YW5jZXM+XG4gIDxzcGFuPiB7eyAncHJvZ3Jlc3Mubm9Qcm9jZXNzRG9jdW1lbnRJbnN0YW5jZXMnIHwgdHJhbnNsYXRlIH19PC9zcGFuPlxuPC9uZy10ZW1wbGF0ZT5cbiJdfQ==
@@ -0,0 +1,132 @@
1
+ /*
2
+ * Copyright 2015-2020 Ritense BV, the Netherlands.
3
+ *
4
+ * Licensed under EUPL, Version 1.2 (the "License");
5
+ * you may not use this file except in compliance with the License.
6
+ * You may obtain a copy of the License at
7
+ *
8
+ * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12
9
+ *
10
+ * Unless required by applicable law or agreed to in writing, software
11
+ * distributed under the License is distributed on an "AS IS" basis,
12
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13
+ * See the License for the specific language governing permissions and
14
+ * limitations under the License.
15
+ */
16
+ import { Component } from '@angular/core';
17
+ import { map, switchMap } from 'rxjs/operators';
18
+ import { BehaviorSubject, combineLatest } from 'rxjs';
19
+ import * as i0 from "@angular/core";
20
+ import * as i1 from "@angular/router";
21
+ import * as i2 from "@valtimo/document";
22
+ import * as i3 from "ngx-toastr";
23
+ import * as i4 from "@valtimo/resource";
24
+ import * as i5 from "@valtimo/user-interface";
25
+ import * as i6 from "@ngx-translate/core";
26
+ import * as i7 from "@valtimo/config";
27
+ import * as i8 from "@valtimo/components";
28
+ import * as i9 from "@angular/common";
29
+ export class DossierDetailTabS3DocumentsComponent {
30
+ constructor(route, documentService, toastrService, uploadProviderService, downloadService, promptService, translateService, configService) {
31
+ this.route = route;
32
+ this.documentService = documentService;
33
+ this.toastrService = toastrService;
34
+ this.uploadProviderService = uploadProviderService;
35
+ this.downloadService = downloadService;
36
+ this.promptService = promptService;
37
+ this.translateService = translateService;
38
+ this.configService = configService;
39
+ this.maxFileSize = this.configService?.config?.caseFileSizeUploadLimitMB || 5;
40
+ this.acceptedFiles = this.configService?.config?.caseFileUploadAcceptedFiles || null;
41
+ this.fields = [
42
+ { key: 'fileName', label: 'File name' },
43
+ { key: 'sizeInBytes', label: 'Size in bytes' },
44
+ { key: 'createdOn', label: 'Created on', viewType: 'date' },
45
+ { key: 'createdBy', label: 'Created by' },
46
+ ];
47
+ this.actions = [
48
+ {
49
+ columnName: '',
50
+ iconClass: 'mdi mdi-open-in-new',
51
+ callback: this.downloadDocument.bind(this),
52
+ },
53
+ {
54
+ columnName: '',
55
+ iconClass: 'mdi mdi-delete',
56
+ callback: this.removeRelatedFile.bind(this),
57
+ },
58
+ ];
59
+ this.uploading$ = new BehaviorSubject(false);
60
+ this.refetch$ = new BehaviorSubject(null);
61
+ this.relatedFiles$ = this.refetch$.pipe(switchMap(() => combineLatest([
62
+ this.documentService.getDocument(this.documentId),
63
+ this.translateService.stream('key'),
64
+ ])), map(([document]) => {
65
+ const relatedFiles = document?.relatedFiles || [];
66
+ const translatedFiles = relatedFiles.map(file => ({
67
+ ...file,
68
+ createdBy: file.createdBy || this.translateService.instant('list.automaticallyGenerated'),
69
+ }));
70
+ return translatedFiles || [];
71
+ }));
72
+ const snapshot = this.route.snapshot.paramMap;
73
+ this.documentId = snapshot.get('documentId') || '';
74
+ this.documentDefinitionName = snapshot.get('documentDefinitionName') || '';
75
+ }
76
+ ngOnInit() {
77
+ this.refetchDocuments();
78
+ }
79
+ fileSelected(file) {
80
+ this.uploading$.next(true);
81
+ this.uploadProviderService
82
+ .uploadFile(file, this.documentDefinitionName)
83
+ .pipe(switchMap(resourceFile => this.documentService.assignResource(this.documentId, resourceFile.data.resourceId)))
84
+ .subscribe(() => {
85
+ this.toastrService.success('Successfully uploaded document to dossier');
86
+ this.refetchDocuments();
87
+ this.uploading$.next(false);
88
+ }, () => {
89
+ this.toastrService.error('Failed to upload document to dossier');
90
+ this.uploading$.next(false);
91
+ });
92
+ }
93
+ downloadDocument(relatedFile) {
94
+ this.uploadProviderService
95
+ .getResource(relatedFile.fileId)
96
+ .subscribe((resource) => {
97
+ this.downloadService.downloadFile(resource.url, resource.resource.name);
98
+ });
99
+ }
100
+ removeRelatedFile(relatedFile) {
101
+ this.promptService.openPrompt({
102
+ headerText: this.translateService.instant('dossier.deleteConfirmation.title'),
103
+ bodyText: this.translateService.instant('dossier.deleteConfirmation.description'),
104
+ cancelButtonText: this.translateService.instant('dossier.deleteConfirmation.cancel'),
105
+ confirmButtonText: this.translateService.instant('dossier.deleteConfirmation.delete'),
106
+ cancelMdiIcon: 'cancel',
107
+ confirmMdiIcon: 'delete',
108
+ cancelButtonType: 'secondary',
109
+ confirmButtonType: 'primary',
110
+ closeOnConfirm: true,
111
+ closeOnCancel: true,
112
+ confirmCallBackFunction: () => {
113
+ this.documentService.removeResource(this.documentId, relatedFile.fileId).subscribe(() => {
114
+ this.toastrService.success('Successfully removed document from dossier');
115
+ this.refetchDocuments();
116
+ }, () => {
117
+ this.toastrService.error('Failed to remove document from dossier');
118
+ });
119
+ }
120
+ });
121
+ }
122
+ refetchDocuments() {
123
+ this.refetch$.next(null);
124
+ }
125
+ }
126
+ DossierDetailTabS3DocumentsComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: DossierDetailTabS3DocumentsComponent, deps: [{ token: i1.ActivatedRoute }, { token: i2.DocumentService }, { token: i3.ToastrService }, { token: i4.UploadProviderService }, { token: i4.DownloadService }, { token: i5.PromptService }, { token: i6.TranslateService }, { token: i7.ConfigService }], target: i0.ɵɵFactoryTarget.Component });
127
+ DossierDetailTabS3DocumentsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.11", type: DossierDetailTabS3DocumentsComponent, selector: "valtimo-dossier-detail-tab-s3-documents", ngImport: i0, template: "<!--\n ~ Copyright 2015-2020 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<valtimo-dropzone\n (fileSelected)=\"fileSelected($event)\"\n [acceptedFiles]=\"acceptedFiles\"\n [hideFilePreview]=\"true\"\n [hideTitle]=\"true\"\n [maxFileSize]=\"maxFileSize\"\n [showMaxFileSize]=\"true\"\n [camera]=\"false\"\n [uploading]=\"uploading$ | async\"\n></valtimo-dropzone>\n\n<valtimo-widget>\n <valtimo-list\n [fields]=\"fields\"\n [items]=\"relatedFiles$ | async\"\n [header]=\"true\"\n [isSearchable]=\"true\"\n [viewMode]=\"true\"\n [actions]=\"actions\"\n >\n <div header>\n <h3 class=\"list-header-title\">{{ 'Related documents' | translate }}</h3>\n <h5 class=\"list-header-description\">\n {{ 'Overview of all documents in this dossier' | translate }}\n </h5>\n </div>\n </valtimo-list>\n</valtimo-widget>\n", styles: [""], components: [{ type: i8.DropzoneComponent, selector: "valtimo-dropzone", inputs: ["title", "hideTitle", "subtitle", "externalError$", "maxFileSize", "showMaxFileSize", "acceptedFiles", "clear$", "disabled", "hideFilePreview", "uploading", "camera", "maxFiles"], outputs: ["fileSelected"] }, { type: i8.WidgetComponent, selector: "valtimo-widget", inputs: ["type", "name", "icon", "contrast", "divider", "title", "subtitle", "collapseAble", "collapse", "additionalClasses"] }, { type: i8.ListComponent, selector: "valtimo-list", inputs: ["items", "fields", "pagination", "viewMode", "isSearchable", "header", "actions", "paginationIdentifier", "initialSortState"], outputs: ["rowClicked", "paginationClicked", "paginationSet", "search", "sortChanged"] }], pipes: { "async": i9.AsyncPipe, "translate": i6.TranslatePipe } });
128
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: DossierDetailTabS3DocumentsComponent, decorators: [{
129
+ type: Component,
130
+ args: [{ selector: 'valtimo-dossier-detail-tab-s3-documents', template: "<!--\n ~ Copyright 2015-2020 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<valtimo-dropzone\n (fileSelected)=\"fileSelected($event)\"\n [acceptedFiles]=\"acceptedFiles\"\n [hideFilePreview]=\"true\"\n [hideTitle]=\"true\"\n [maxFileSize]=\"maxFileSize\"\n [showMaxFileSize]=\"true\"\n [camera]=\"false\"\n [uploading]=\"uploading$ | async\"\n></valtimo-dropzone>\n\n<valtimo-widget>\n <valtimo-list\n [fields]=\"fields\"\n [items]=\"relatedFiles$ | async\"\n [header]=\"true\"\n [isSearchable]=\"true\"\n [viewMode]=\"true\"\n [actions]=\"actions\"\n >\n <div header>\n <h3 class=\"list-header-title\">{{ 'Related documents' | translate }}</h3>\n <h5 class=\"list-header-description\">\n {{ 'Overview of all documents in this dossier' | translate }}\n </h5>\n </div>\n </valtimo-list>\n</valtimo-widget>\n", styles: [""] }]
131
+ }], ctorParameters: function () { return [{ type: i1.ActivatedRoute }, { type: i2.DocumentService }, { type: i3.ToastrService }, { type: i4.UploadProviderService }, { type: i4.DownloadService }, { type: i5.PromptService }, { type: i6.TranslateService }, { type: i7.ConfigService }]; } });
132
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"s3-documents.component.js","sourceRoot":"","sources":["../../../../../../../../projects/valtimo/dossier/src/lib/dossier-detail/tab/s3-documents/s3-documents.component.ts","../../../../../../../../projects/valtimo/dossier/src/lib/dossier-detail/tab/s3-documents/s3-documents.component.html"],"names":[],"mappings":"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","sourcesContent":["/*\n * Copyright 2015-2020 Ritense BV, the Netherlands.\n *\n * Licensed under EUPL, Version 1.2 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" basis,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport {Component, OnInit} from '@angular/core';\nimport {ActivatedRoute} from '@angular/router';\nimport {DocumentService, RelatedFile} from '@valtimo/document';\nimport {DownloadService, ResourceDto, UploadProviderService} from '@valtimo/resource';\nimport {ToastrService} from 'ngx-toastr';\nimport {map, switchMap} from 'rxjs/operators';\nimport {BehaviorSubject, combineLatest, Observable} from 'rxjs';\nimport {TranslateService} from '@ngx-translate/core';\nimport {ConfigService} from '@valtimo/config';\nimport {PromptService} from '@valtimo/user-interface';\n\n@Component({\n  selector: 'valtimo-dossier-detail-tab-s3-documents',\n  templateUrl: './s3-documents.component.html',\n  styleUrls: ['./s3-documents.component.scss'],\n})\nexport class DossierDetailTabS3DocumentsComponent implements OnInit {\n  public readonly documentId: string;\n  public readonly documentDefinitionName: string;\n  public readonly maxFileSize: number = this.configService?.config?.caseFileSizeUploadLimitMB || 5;\n  public readonly acceptedFiles: string = this.configService?.config?.caseFileUploadAcceptedFiles || null;\n  public fields = [\n    {key: 'fileName', label: 'File name'},\n    {key: 'sizeInBytes', label: 'Size in bytes'},\n    {key: 'createdOn', label: 'Created on', viewType: 'date'},\n    {key: 'createdBy', label: 'Created by'},\n  ];\n  public actions = [\n    {\n      columnName: '',\n      iconClass: 'mdi mdi-open-in-new',\n      callback: this.downloadDocument.bind(this),\n    },\n    {\n      columnName: '',\n      iconClass: 'mdi mdi-delete',\n      callback: this.removeRelatedFile.bind(this),\n    },\n  ];\n  readonly uploading$ = new BehaviorSubject<boolean>(false);\n  private readonly refetch$ = new BehaviorSubject<null>(null);\n  public relatedFiles$: Observable<Array<RelatedFile>> = this.refetch$.pipe(\n    switchMap(() =>\n      combineLatest([\n        this.documentService.getDocument(this.documentId),\n        this.translateService.stream('key'),\n      ])\n    ),\n    map(([document]) => {\n      const relatedFiles = document?.relatedFiles || [];\n      const translatedFiles = relatedFiles.map(file => ({\n        ...file,\n        createdBy: file.createdBy || this.translateService.instant('list.automaticallyGenerated'),\n      }));\n\n      return translatedFiles || [];\n    })\n  );\n\n  constructor(\n    private readonly route: ActivatedRoute,\n    private readonly documentService: DocumentService,\n    private readonly toastrService: ToastrService,\n    private readonly uploadProviderService: UploadProviderService,\n    private readonly downloadService: DownloadService,\n    private readonly promptService: PromptService,\n    private readonly translateService: TranslateService,\n    private readonly configService: ConfigService\n  ) {\n    const snapshot = this.route.snapshot.paramMap;\n    this.documentId = snapshot.get('documentId') || '';\n    this.documentDefinitionName = snapshot.get('documentDefinitionName') || '';\n  }\n\n  ngOnInit(): void {\n    this.refetchDocuments();\n  }\n\n  fileSelected(file: File): void {\n    this.uploading$.next(true);\n\n    this.uploadProviderService\n      .uploadFile(file, this.documentDefinitionName)\n      .pipe(\n        switchMap(resourceFile =>\n          this.documentService.assignResource(this.documentId, resourceFile.data.resourceId)\n        )\n      )\n      .subscribe(\n        () => {\n          this.toastrService.success('Successfully uploaded document to dossier');\n          this.refetchDocuments();\n          this.uploading$.next(false);\n        },\n        () => {\n          this.toastrService.error('Failed to upload document to dossier');\n          this.uploading$.next(false);\n        }\n      );\n  }\n\n  downloadDocument(relatedFile: RelatedFile): void {\n    this.uploadProviderService\n      .getResource(relatedFile.fileId)\n      .subscribe((resource: ResourceDto) => {\n        this.downloadService.downloadFile(resource.url, resource.resource.name);\n      });\n  }\n\n  removeRelatedFile(relatedFile: RelatedFile) {\n    this.promptService.openPrompt({\n      headerText: this.translateService.instant('dossier.deleteConfirmation.title'),\n      bodyText: this.translateService.instant('dossier.deleteConfirmation.description'),\n      cancelButtonText: this.translateService.instant('dossier.deleteConfirmation.cancel'),\n      confirmButtonText: this.translateService.instant('dossier.deleteConfirmation.delete'),\n      cancelMdiIcon: 'cancel',\n      confirmMdiIcon: 'delete',\n      cancelButtonType: 'secondary',\n      confirmButtonType: 'primary',\n      closeOnConfirm: true,\n      closeOnCancel: true,\n      confirmCallBackFunction: () => {\n        this.documentService.removeResource(this.documentId, relatedFile.fileId).subscribe(\n          () => {\n            this.toastrService.success('Successfully removed document from dossier');\n            this.refetchDocuments();\n          },\n          () => {\n            this.toastrService.error('Failed to remove document from dossier');\n          }\n        );\n      }\n    });\n  }\n\n  private refetchDocuments(): void {\n    this.refetch$.next(null);\n  }\n}\n","<!--\n  ~ Copyright 2015-2020 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<valtimo-dropzone\n  (fileSelected)=\"fileSelected($event)\"\n  [acceptedFiles]=\"acceptedFiles\"\n  [hideFilePreview]=\"true\"\n  [hideTitle]=\"true\"\n  [maxFileSize]=\"maxFileSize\"\n  [showMaxFileSize]=\"true\"\n  [camera]=\"false\"\n  [uploading]=\"uploading$ | async\"\n></valtimo-dropzone>\n\n<valtimo-widget>\n  <valtimo-list\n    [fields]=\"fields\"\n    [items]=\"relatedFiles$ | async\"\n    [header]=\"true\"\n    [isSearchable]=\"true\"\n    [viewMode]=\"true\"\n    [actions]=\"actions\"\n  >\n    <div header>\n      <h3 class=\"list-header-title\">{{ 'Related documents' | translate }}</h3>\n      <h5 class=\"list-header-description\">\n        {{ 'Overview of all documents in this dossier' | translate }}\n      </h5>\n    </div>\n  </valtimo-list>\n</valtimo-widget>\n"]}