@valtimo/zgw 12.5.0 → 12.6.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 (40) hide show
  1. package/esm2022/lib/components/dossier-management-zgw/dossier-management-zgw.component.mjs +9 -9
  2. package/esm2022/lib/models/dossier-management-zgw.model.mjs +2 -1
  3. package/esm2022/lib/modules/documenten-api/components/documenten-api-documents/documenten-api-documents.component.mjs +32 -3
  4. package/esm2022/lib/modules/documenten-api/components/documenten-api-metadata-modal/documenten-api-metadata-modal.component.mjs +95 -53
  5. package/esm2022/lib/modules/documenten-api/components/documenten-api-tags/documenten-api-tags.component.mjs +1 -3
  6. package/esm2022/lib/modules/documenten-api/components/documenten-api-upload-field-model/documenten-api-upload-field-modal.component.mjs +182 -0
  7. package/esm2022/lib/modules/documenten-api/components/documenten-api-upload-fields/documenten-api-upload-fields.component.mjs +118 -0
  8. package/esm2022/lib/modules/documenten-api/components/index.mjs +4 -2
  9. package/esm2022/lib/modules/documenten-api/formio/documenten-api-uploader/documenten-api-uploader-edit-form.mjs +287 -49
  10. package/esm2022/lib/modules/documenten-api/formio/documenten-api-uploader/documenten-api-uploader.component.mjs +108 -5
  11. package/esm2022/lib/modules/documenten-api/models/documenten-api-metadata.model.mjs +19 -2
  12. package/esm2022/lib/modules/documenten-api/models/documenten-api-upload-field.model.mjs +33 -0
  13. package/esm2022/lib/modules/documenten-api/services/documenten-api-document.service.mjs +10 -1
  14. package/fesm2022/valtimo-zgw.mjs +868 -159
  15. package/fesm2022/valtimo-zgw.mjs.map +1 -1
  16. package/lib/components/dossier-management-zgw/dossier-management-zgw.component.d.ts.map +1 -1
  17. package/lib/models/dossier-management-zgw.model.d.ts +2 -1
  18. package/lib/models/dossier-management-zgw.model.d.ts.map +1 -1
  19. package/lib/modules/documenten-api/components/documenten-api-documents/documenten-api-documents.component.d.ts +4 -0
  20. package/lib/modules/documenten-api/components/documenten-api-documents/documenten-api-documents.component.d.ts.map +1 -1
  21. package/lib/modules/documenten-api/components/documenten-api-metadata-modal/documenten-api-metadata-modal.component.d.ts +17 -21
  22. package/lib/modules/documenten-api/components/documenten-api-metadata-modal/documenten-api-metadata-modal.component.d.ts.map +1 -1
  23. package/lib/modules/documenten-api/components/documenten-api-tags/documenten-api-tags.component.d.ts.map +1 -1
  24. package/lib/modules/documenten-api/components/documenten-api-upload-field-model/documenten-api-upload-field-modal.component.d.ts +51 -0
  25. package/lib/modules/documenten-api/components/documenten-api-upload-field-model/documenten-api-upload-field-modal.component.d.ts.map +1 -0
  26. package/lib/modules/documenten-api/components/documenten-api-upload-fields/documenten-api-upload-fields.component.d.ts +31 -0
  27. package/lib/modules/documenten-api/components/documenten-api-upload-fields/documenten-api-upload-fields.component.d.ts.map +1 -0
  28. package/lib/modules/documenten-api/components/index.d.ts +3 -1
  29. package/lib/modules/documenten-api/components/index.d.ts.map +1 -1
  30. package/lib/modules/documenten-api/formio/documenten-api-uploader/documenten-api-uploader-edit-form.d.ts +44 -0
  31. package/lib/modules/documenten-api/formio/documenten-api-uploader/documenten-api-uploader-edit-form.d.ts.map +1 -1
  32. package/lib/modules/documenten-api/formio/documenten-api-uploader/documenten-api-uploader.component.d.ts +25 -10
  33. package/lib/modules/documenten-api/formio/documenten-api-uploader/documenten-api-uploader.component.d.ts.map +1 -1
  34. package/lib/modules/documenten-api/models/documenten-api-metadata.model.d.ts +11 -8
  35. package/lib/modules/documenten-api/models/documenten-api-metadata.model.d.ts.map +1 -1
  36. package/lib/modules/documenten-api/models/documenten-api-upload-field.model.d.ts +45 -0
  37. package/lib/modules/documenten-api/models/documenten-api-upload-field.model.d.ts.map +1 -0
  38. package/lib/modules/documenten-api/services/documenten-api-document.service.d.ts +4 -0
  39. package/lib/modules/documenten-api/services/documenten-api-document.service.d.ts.map +1 -1
  40. package/package.json +1 -1
@@ -18,7 +18,7 @@ import { TabsModule } from 'carbon-components-angular';
18
18
  import { ZgwTabEnum } from '../../models';
19
19
  import { TranslateModule } from '@ngx-translate/core';
20
20
  import { CommonModule } from '@angular/common';
21
- import { DocumentenApiColumnsComponent, DocumentenApiTagsComponent, } from '../../modules';
21
+ import { DocumentenApiColumnsComponent, DocumentenApiTagsComponent, DocumentenApiUploadFieldsComponent, } from '../../modules';
22
22
  import { BehaviorSubject, combineLatest, filter, map, switchMap, tap } from 'rxjs';
23
23
  import * as i0 from "@angular/core";
24
24
  import * as i1 from "../../services";
@@ -46,6 +46,12 @@ export class DossierManagementZgwComponent {
46
46
  tab: ZgwTabEnum.DOCUMENTEN_API_COLUMNS,
47
47
  component: DocumentenApiColumnsComponent,
48
48
  },
49
+ {
50
+ class: 'no-padding-left-right no-padding-top-bottom',
51
+ headingTranslationKey: 'zgw.tabs.documentUploadFields',
52
+ tab: ZgwTabEnum.DOCUMENTEN_API_UPLOAD_FIELDS,
53
+ component: DocumentenApiUploadFieldsComponent,
54
+ },
49
55
  ...(supportedDocumentenApiFeatures.supportsTrefwoorden
50
56
  ? [
51
57
  {
@@ -77,15 +83,9 @@ export class DossierManagementZgwComponent {
77
83
  }
78
84
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DossierManagementZgwComponent, decorators: [{
79
85
  type: Component,
80
- args: [{ changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [
81
- CommonModule,
82
- TabsModule,
83
- TranslateModule,
84
- DocumentenApiTagsComponent,
85
- DocumentenApiColumnsComponent,
86
- ], template: "<!--\n ~ Copyright 2015-2024 Ritense BV, the Netherlands.\n ~\n ~ Licensed under EUPL, Version 1.2 (the \"License\");\n ~ you may not use this file except in compliance with the License.\n ~ You may obtain a copy of the License at\n ~\n ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n ~\n ~ Unless required by applicable law or agreed to in writing, software\n ~ distributed under the License is distributed on an \"AS IS\" basis,\n ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n ~ See the License for the specific language governing permissions and\n ~ limitations under the License.\n -->\n\n<cds-tabs class=\"dossier-management-tabs\">\n @for (zgwTab of (zgwTabs$ | async) || []; track zgwTab.tab) {\n <cds-tab\n [class]=\"zgwTab.class\"\n [active]=\"zgwTab.active\"\n [heading]=\"zgwTab.headingTranslationKey | translate\"\n (selected)=\"displayTab(zgwTab.tab)\"\n ></cds-tab>\n }\n</cds-tabs>\n\n<div class=\"dossier-management-zgw__content\">\n <ng-template #zgwTabContent></ng-template>\n</div>\n", styles: ["/*!\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"] }]
86
+ args: [{ changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [CommonModule, TabsModule, TranslateModule], template: "<!--\n ~ Copyright 2015-2024 Ritense BV, the Netherlands.\n ~\n ~ Licensed under EUPL, Version 1.2 (the \"License\");\n ~ you may not use this file except in compliance with the License.\n ~ You may obtain a copy of the License at\n ~\n ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n ~\n ~ Unless required by applicable law or agreed to in writing, software\n ~ distributed under the License is distributed on an \"AS IS\" basis,\n ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n ~ See the License for the specific language governing permissions and\n ~ limitations under the License.\n -->\n\n<cds-tabs class=\"dossier-management-tabs\">\n @for (zgwTab of (zgwTabs$ | async) || []; track zgwTab.tab) {\n <cds-tab\n [class]=\"zgwTab.class\"\n [active]=\"zgwTab.active\"\n [heading]=\"zgwTab.headingTranslationKey | translate\"\n (selected)=\"displayTab(zgwTab.tab)\"\n ></cds-tab>\n }\n</cds-tabs>\n\n<div class=\"dossier-management-zgw__content\">\n <ng-template #zgwTabContent></ng-template>\n</div>\n", styles: ["/*!\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"] }]
87
87
  }], ctorParameters: () => [{ type: i1.DossierManagementZgwService }, { type: i0.ChangeDetectorRef }, { type: i2.DocumentenApiVersionService }, { type: i3.ActivatedRoute }], propDecorators: { _zgwTabContent: [{
88
88
  type: ViewChild,
89
89
  args: ['zgwTabContent', { read: ViewContainerRef }]
90
90
  }] } });
91
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dossier-management-zgw.component.js","sourceRoot":"","sources":["../../../../../../../projects/valtimo/zgw/src/lib/components/dossier-management-zgw/dossier-management-zgw.component.ts","../../../../../../../projects/valtimo/zgw/src/lib/components/dossier-management-zgw/dossier-management-zgw.component.html"],"names":[],"mappings":"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","sourcesContent":["/*\n * Copyright 2015-2024 Ritense BV, the Netherlands.\n *\n * Licensed under EUPL, Version 1.2 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" basis,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  OnDestroy,\n  ViewChild,\n  ViewContainerRef,\n} from '@angular/core';\nimport {TabsModule} from 'carbon-components-angular';\nimport {DossierManagementZgwService} from '../../services';\nimport {ZgwTab, ZgwTabEnum} from '../../models';\nimport {TranslateModule} from '@ngx-translate/core';\nimport {CommonModule} from '@angular/common';\nimport {\n  DocumentenApiColumnsComponent,\n  DocumentenApiTagsComponent,\n  DocumentenApiVersionService,\n  SupportedDocumentenApiFeatures,\n} from '../../modules';\nimport {BehaviorSubject, combineLatest, filter, map, Observable, switchMap, tap} from 'rxjs';\nimport {ActivatedRoute} from '@angular/router';\n\n@Component({\n  templateUrl: './dossier-management-zgw.component.html',\n  styleUrls: ['./dossier-management-zgw.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [\n    CommonModule,\n    TabsModule,\n    TranslateModule,\n    DocumentenApiTagsComponent,\n    DocumentenApiColumnsComponent,\n  ],\n})\nexport class DossierManagementZgwComponent implements AfterViewInit, OnDestroy {\n  @ViewChild('zgwTabContent', {read: ViewContainerRef})\n  private _zgwTabContent: ViewContainerRef;\n\n  private readonly _viewInitialized$ = new BehaviorSubject<boolean>(false);\n\n  private readonly _supportedDocumentenApiFeatures$: Observable<SupportedDocumentenApiFeatures> =\n    this.route.params.pipe(\n      map(params => params?.name),\n      filter(caseDefinitionName => !!caseDefinitionName),\n      switchMap(caseDefinitionName =>\n        this.documentenApiVersionService.getSupportedApiFeatures(caseDefinitionName)\n      )\n    );\n\n  public readonly zgwTabs$: Observable<ZgwTab[]> = combineLatest([\n    this._viewInitialized$,\n    this.dossierManagementZgwService.currentTab$,\n    this._supportedDocumentenApiFeatures$,\n  ]).pipe(\n    filter(([viewInitialized]) => viewInitialized),\n    map(([_, currentTab, supportedDocumentenApiFeatures]) =>\n      [\n        {\n          class: 'no-padding-left-right no-padding-top-bottom',\n          headingTranslationKey: 'zgw.tabs.documentColumns',\n          tab: ZgwTabEnum.DOCUMENTEN_API_COLUMNS,\n          component: DocumentenApiColumnsComponent,\n        },\n        ...(supportedDocumentenApiFeatures.supportsTrefwoorden\n          ? [\n              {\n                class: 'no-padding-left-right no-padding-top-bottom',\n                headingTranslationKey: 'zgw.tabs.documentTags',\n                tab: ZgwTabEnum.DOCUMENTEN_API_TAGS,\n                component: DocumentenApiTagsComponent,\n              },\n            ]\n          : []),\n      ].map(zgwTab => ({...zgwTab, active: currentTab === zgwTab.tab}))\n    ),\n    tap(zgwTabs => {\n      const activeTab = zgwTabs.length > 1 ? zgwTabs.find(tab => tab.active) : zgwTabs[0];\n      this._zgwTabContent.clear();\n      this._zgwTabContent.createComponent(activeTab.component);\n      this.cdr.detectChanges();\n    })\n  );\n\n  constructor(\n    private readonly dossierManagementZgwService: DossierManagementZgwService,\n    private readonly cdr: ChangeDetectorRef,\n    private readonly documentenApiVersionService: DocumentenApiVersionService,\n    private readonly route: ActivatedRoute\n  ) {}\n\n  public ngAfterViewInit(): void {\n    this._viewInitialized$.next(true);\n  }\n\n  public ngOnDestroy(): void {\n    this.dossierManagementZgwService.resetToDefaultTab();\n  }\n\n  public displayTab(tab: ZgwTabEnum): void {\n    this.dossierManagementZgwService.currentTab = tab;\n  }\n}\n","<!--\n  ~ Copyright 2015-2024 Ritense BV, the Netherlands.\n  ~\n  ~ Licensed under EUPL, Version 1.2 (the \"License\");\n  ~ you may not use this file except in compliance with the License.\n  ~ You may obtain a copy of the License at\n  ~\n  ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n  ~\n  ~ Unless required by applicable law or agreed to in writing, software\n  ~ distributed under the License is distributed on an \"AS IS\" basis,\n  ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n  ~ See the License for the specific language governing permissions and\n  ~ limitations under the License.\n  -->\n\n<cds-tabs class=\"dossier-management-tabs\">\n  @for (zgwTab of (zgwTabs$ | async) || []; track zgwTab.tab) {\n    <cds-tab\n      [class]=\"zgwTab.class\"\n      [active]=\"zgwTab.active\"\n      [heading]=\"zgwTab.headingTranslationKey | translate\"\n      (selected)=\"displayTab(zgwTab.tab)\"\n    ></cds-tab>\n  }\n</cds-tabs>\n\n<div class=\"dossier-management-zgw__content\">\n  <ng-template #zgwTabContent></ng-template>\n</div>\n"]}
91
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dossier-management-zgw.component.js","sourceRoot":"","sources":["../../../../../../../projects/valtimo/zgw/src/lib/components/dossier-management-zgw/dossier-management-zgw.component.ts","../../../../../../../projects/valtimo/zgw/src/lib/components/dossier-management-zgw/dossier-management-zgw.component.html"],"names":[],"mappings":"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","sourcesContent":["/*\n * Copyright 2015-2024 Ritense BV, the Netherlands.\n *\n * Licensed under EUPL, Version 1.2 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" basis,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  OnDestroy,\n  ViewChild,\n  ViewContainerRef,\n} from '@angular/core';\nimport {TabsModule} from 'carbon-components-angular';\nimport {DossierManagementZgwService} from '../../services';\nimport {ZgwTab, ZgwTabEnum} from '../../models';\nimport {TranslateModule} from '@ngx-translate/core';\nimport {CommonModule} from '@angular/common';\nimport {\n  DocumentenApiColumnsComponent,\n  DocumentenApiTagsComponent,\n  DocumentenApiUploadFieldsComponent,\n  DocumentenApiVersionService,\n  SupportedDocumentenApiFeatures,\n} from '../../modules';\nimport {BehaviorSubject, combineLatest, filter, map, Observable, switchMap, tap} from 'rxjs';\nimport {ActivatedRoute} from '@angular/router';\n\n@Component({\n  templateUrl: './dossier-management-zgw.component.html',\n  styleUrls: ['./dossier-management-zgw.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [CommonModule, TabsModule, TranslateModule],\n})\nexport class DossierManagementZgwComponent implements AfterViewInit, OnDestroy {\n  @ViewChild('zgwTabContent', {read: ViewContainerRef})\n  private _zgwTabContent: ViewContainerRef;\n\n  private readonly _viewInitialized$ = new BehaviorSubject<boolean>(false);\n\n  private readonly _supportedDocumentenApiFeatures$: Observable<SupportedDocumentenApiFeatures> =\n    this.route.params.pipe(\n      map(params => params?.name),\n      filter(caseDefinitionName => !!caseDefinitionName),\n      switchMap(caseDefinitionName =>\n        this.documentenApiVersionService.getSupportedApiFeatures(caseDefinitionName)\n      )\n    );\n\n  public readonly zgwTabs$: Observable<ZgwTab[]> = combineLatest([\n    this._viewInitialized$,\n    this.dossierManagementZgwService.currentTab$,\n    this._supportedDocumentenApiFeatures$,\n  ]).pipe(\n    filter(([viewInitialized]) => viewInitialized),\n    map(([_, currentTab, supportedDocumentenApiFeatures]) =>\n      [\n        {\n          class: 'no-padding-left-right no-padding-top-bottom',\n          headingTranslationKey: 'zgw.tabs.documentColumns',\n          tab: ZgwTabEnum.DOCUMENTEN_API_COLUMNS,\n          component: DocumentenApiColumnsComponent,\n        },\n        {\n          class: 'no-padding-left-right no-padding-top-bottom',\n          headingTranslationKey: 'zgw.tabs.documentUploadFields',\n          tab: ZgwTabEnum.DOCUMENTEN_API_UPLOAD_FIELDS,\n          component: DocumentenApiUploadFieldsComponent,\n        },\n        ...(supportedDocumentenApiFeatures.supportsTrefwoorden\n          ? [\n              {\n                class: 'no-padding-left-right no-padding-top-bottom',\n                headingTranslationKey: 'zgw.tabs.documentTags',\n                tab: ZgwTabEnum.DOCUMENTEN_API_TAGS,\n                component: DocumentenApiTagsComponent,\n              },\n            ]\n          : []),\n      ].map(zgwTab => ({...zgwTab, active: currentTab === zgwTab.tab}))\n    ),\n    tap(zgwTabs => {\n      const activeTab = zgwTabs.length > 1 ? zgwTabs.find(tab => tab.active) : zgwTabs[0];\n      this._zgwTabContent.clear();\n      this._zgwTabContent.createComponent(activeTab.component);\n      this.cdr.detectChanges();\n    })\n  );\n\n  constructor(\n    private readonly dossierManagementZgwService: DossierManagementZgwService,\n    private readonly cdr: ChangeDetectorRef,\n    private readonly documentenApiVersionService: DocumentenApiVersionService,\n    private readonly route: ActivatedRoute\n  ) {}\n\n  public ngAfterViewInit(): void {\n    this._viewInitialized$.next(true);\n  }\n\n  public ngOnDestroy(): void {\n    this.dossierManagementZgwService.resetToDefaultTab();\n  }\n\n  public displayTab(tab: ZgwTabEnum): void {\n    this.dossierManagementZgwService.currentTab = tab;\n  }\n}\n","<!--\n  ~ Copyright 2015-2024 Ritense BV, the Netherlands.\n  ~\n  ~ Licensed under EUPL, Version 1.2 (the \"License\");\n  ~ you may not use this file except in compliance with the License.\n  ~ You may obtain a copy of the License at\n  ~\n  ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n  ~\n  ~ Unless required by applicable law or agreed to in writing, software\n  ~ distributed under the License is distributed on an \"AS IS\" basis,\n  ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n  ~ See the License for the specific language governing permissions and\n  ~ limitations under the License.\n  -->\n\n<cds-tabs class=\"dossier-management-tabs\">\n  @for (zgwTab of (zgwTabs$ | async) || []; track zgwTab.tab) {\n    <cds-tab\n      [class]=\"zgwTab.class\"\n      [active]=\"zgwTab.active\"\n      [heading]=\"zgwTab.headingTranslationKey | translate\"\n      (selected)=\"displayTab(zgwTab.tab)\"\n    ></cds-tab>\n  }\n</cds-tabs>\n\n<div class=\"dossier-management-zgw__content\">\n  <ng-template #zgwTabContent></ng-template>\n</div>\n"]}
@@ -17,6 +17,7 @@ var ZgwTabEnum;
17
17
  (function (ZgwTabEnum) {
18
18
  ZgwTabEnum["DOCUMENTEN_API_COLUMNS"] = "documentenApiColumns";
19
19
  ZgwTabEnum["DOCUMENTEN_API_TAGS"] = "documentenApiTags";
20
+ ZgwTabEnum["DOCUMENTEN_API_UPLOAD_FIELDS"] = "documentenApiUploadFields";
20
21
  })(ZgwTabEnum || (ZgwTabEnum = {}));
21
22
  export { ZgwTabEnum };
22
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZG9zc2llci1tYW5hZ2VtZW50LXpndy5tb2RlbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3ZhbHRpbW8vemd3L3NyYy9saWIvbW9kZWxzL2Rvc3NpZXItbWFuYWdlbWVudC16Z3cubW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7Ozs7Ozs7Ozs7O0dBY0c7QUFJSCxJQUFLLFVBR0o7QUFIRCxXQUFLLFVBQVU7SUFDYiw2REFBK0MsQ0FBQTtJQUMvQyx1REFBeUMsQ0FBQTtBQUMzQyxDQUFDLEVBSEksVUFBVSxLQUFWLFVBQVUsUUFHZDtBQVVELE9BQU8sRUFBQyxVQUFVLEVBQVMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qXG4gKiBDb3B5cmlnaHQgMjAxNS0yMDI0IFJpdGVuc2UgQlYsIHRoZSBOZXRoZXJsYW5kcy5cbiAqXG4gKiBMaWNlbnNlZCB1bmRlciBFVVBMLCBWZXJzaW9uIDEuMiAodGhlIFwiTGljZW5zZVwiKTtcbiAqIHlvdSBtYXkgbm90IHVzZSB0aGlzIGZpbGUgZXhjZXB0IGluIGNvbXBsaWFuY2Ugd2l0aCB0aGUgTGljZW5zZS5cbiAqIFlvdSBtYXkgb2J0YWluIGEgY29weSBvZiB0aGUgTGljZW5zZSBhdFxuICpcbiAqIGh0dHBzOi8vam9pbnVwLmVjLmV1cm9wYS5ldS9jb2xsZWN0aW9uL2V1cGwvZXVwbC10ZXh0LWV1cGwtMTJcbiAqXG4gKiBVbmxlc3MgcmVxdWlyZWQgYnkgYXBwbGljYWJsZSBsYXcgb3IgYWdyZWVkIHRvIGluIHdyaXRpbmcsIHNvZnR3YXJlXG4gKiBkaXN0cmlidXRlZCB1bmRlciB0aGUgTGljZW5zZSBpcyBkaXN0cmlidXRlZCBvbiBhbiBcIkFTIElTXCIgYmFzaXMsXG4gKiBXSVRIT1VUIFdBUlJBTlRJRVMgT1IgQ09ORElUSU9OUyBPRiBBTlkgS0lORCwgZWl0aGVyIGV4cHJlc3Mgb3IgaW1wbGllZC5cbiAqIFNlZSB0aGUgTGljZW5zZSBmb3IgdGhlIHNwZWNpZmljIGxhbmd1YWdlIGdvdmVybmluZyBwZXJtaXNzaW9ucyBhbmRcbiAqIGxpbWl0YXRpb25zIHVuZGVyIHRoZSBMaWNlbnNlLlxuICovXG5cbmltcG9ydCB7VHlwZX0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmVudW0gWmd3VGFiRW51bSB7XG4gIERPQ1VNRU5URU5fQVBJX0NPTFVNTlMgPSAnZG9jdW1lbnRlbkFwaUNvbHVtbnMnLFxuICBET0NVTUVOVEVOX0FQSV9UQUdTID0gJ2RvY3VtZW50ZW5BcGlUYWdzJyxcbn1cblxuaW50ZXJmYWNlIFpnd1RhYiB7XG4gIGNsYXNzOiBzdHJpbmc7XG4gIGhlYWRpbmdUcmFuc2xhdGlvbktleTogc3RyaW5nO1xuICB0YWI6IFpnd1RhYkVudW07XG4gIGFjdGl2ZT86IGJvb2xlYW47XG4gIGNvbXBvbmVudDogVHlwZTxhbnk+O1xufVxuXG5leHBvcnQge1pnd1RhYkVudW0sIFpnd1RhYn07XG4iXX0=
23
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZG9zc2llci1tYW5hZ2VtZW50LXpndy5tb2RlbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3ZhbHRpbW8vemd3L3NyYy9saWIvbW9kZWxzL2Rvc3NpZXItbWFuYWdlbWVudC16Z3cubW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7Ozs7Ozs7Ozs7O0dBY0c7QUFJSCxJQUFLLFVBSUo7QUFKRCxXQUFLLFVBQVU7SUFDYiw2REFBK0MsQ0FBQTtJQUMvQyx1REFBeUMsQ0FBQTtJQUN6Qyx3RUFBMEQsQ0FBQTtBQUM1RCxDQUFDLEVBSkksVUFBVSxLQUFWLFVBQVUsUUFJZDtBQVVELE9BQU8sRUFBQyxVQUFVLEVBQVMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qXG4gKiBDb3B5cmlnaHQgMjAxNS0yMDI0IFJpdGVuc2UgQlYsIHRoZSBOZXRoZXJsYW5kcy5cbiAqXG4gKiBMaWNlbnNlZCB1bmRlciBFVVBMLCBWZXJzaW9uIDEuMiAodGhlIFwiTGljZW5zZVwiKTtcbiAqIHlvdSBtYXkgbm90IHVzZSB0aGlzIGZpbGUgZXhjZXB0IGluIGNvbXBsaWFuY2Ugd2l0aCB0aGUgTGljZW5zZS5cbiAqIFlvdSBtYXkgb2J0YWluIGEgY29weSBvZiB0aGUgTGljZW5zZSBhdFxuICpcbiAqIGh0dHBzOi8vam9pbnVwLmVjLmV1cm9wYS5ldS9jb2xsZWN0aW9uL2V1cGwvZXVwbC10ZXh0LWV1cGwtMTJcbiAqXG4gKiBVbmxlc3MgcmVxdWlyZWQgYnkgYXBwbGljYWJsZSBsYXcgb3IgYWdyZWVkIHRvIGluIHdyaXRpbmcsIHNvZnR3YXJlXG4gKiBkaXN0cmlidXRlZCB1bmRlciB0aGUgTGljZW5zZSBpcyBkaXN0cmlidXRlZCBvbiBhbiBcIkFTIElTXCIgYmFzaXMsXG4gKiBXSVRIT1VUIFdBUlJBTlRJRVMgT1IgQ09ORElUSU9OUyBPRiBBTlkgS0lORCwgZWl0aGVyIGV4cHJlc3Mgb3IgaW1wbGllZC5cbiAqIFNlZSB0aGUgTGljZW5zZSBmb3IgdGhlIHNwZWNpZmljIGxhbmd1YWdlIGdvdmVybmluZyBwZXJtaXNzaW9ucyBhbmRcbiAqIGxpbWl0YXRpb25zIHVuZGVyIHRoZSBMaWNlbnNlLlxuICovXG5cbmltcG9ydCB7VHlwZX0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmVudW0gWmd3VGFiRW51bSB7XG4gIERPQ1VNRU5URU5fQVBJX0NPTFVNTlMgPSAnZG9jdW1lbnRlbkFwaUNvbHVtbnMnLFxuICBET0NVTUVOVEVOX0FQSV9UQUdTID0gJ2RvY3VtZW50ZW5BcGlUYWdzJyxcbiAgRE9DVU1FTlRFTl9BUElfVVBMT0FEX0ZJRUxEUyA9ICdkb2N1bWVudGVuQXBpVXBsb2FkRmllbGRzJyxcbn1cblxuaW50ZXJmYWNlIFpnd1RhYiB7XG4gIGNsYXNzOiBzdHJpbmc7XG4gIGhlYWRpbmdUcmFuc2xhdGlvbktleTogc3RyaW5nO1xuICB0YWI6IFpnd1RhYkVudW07XG4gIGFjdGl2ZT86IGJvb2xlYW47XG4gIGNvbXBvbmVudDogVHlwZTxhbnk+O1xufVxuXG5leHBvcnQge1pnd1RhYkVudW0sIFpnd1RhYn07XG4iXX0=
@@ -118,6 +118,35 @@ export class DossierDetailTabDocumentenApiDocumentsComponent {
118
118
  ...DEFAULT_PAGINATOR_CONFIG,
119
119
  itemsPerPageOptions: [5, 10, 20, 50, 100],
120
120
  };
121
+ this.uploadFields$ = this.documentId$.pipe(switchMap(documentId => this.documentenApiDocumentService.getPrefilledUploadFields(documentId)), map(uploadFields => uploadFields.reduce((acc, curr) => ({
122
+ ...acc,
123
+ [curr.key]: {
124
+ key: curr.key,
125
+ defaultValue: curr.defaultValue,
126
+ visible: curr.visible,
127
+ readonly: curr.readonly,
128
+ },
129
+ }), {})));
130
+ this.defaultValues$ = this.uploadFields$.pipe(map(formFields => ({
131
+ auteur: formFields?.auteur?.defaultValue,
132
+ vertrouwelijkheidaanduiding: formFields?.vertrouwelijkheidaanduiding?.defaultValue,
133
+ beschrijving: formFields?.beschrijving?.defaultValue,
134
+ titel: formFields?.titel?.defaultValue,
135
+ informatieobjecttype: formFields?.informatieobjecttype?.defaultValue,
136
+ bestandsnaam: formFields?.bestandsnaam?.defaultValue,
137
+ taal: formFields?.taal?.defaultValue,
138
+ status: formFields?.status?.defaultValue,
139
+ trefwoorden: formFields?.trefwoorden?.defaultValue
140
+ ?.split(',')
141
+ ?.map(tag => tag.trim())
142
+ ?.filter(tag => !!tag),
143
+ })));
144
+ this.hideFields$ = this.uploadFields$.pipe(map(formFields => {
145
+ if (formFields) {
146
+ return Object.keys(formFields).filter(field => !formFields[field]?.visible);
147
+ }
148
+ return [];
149
+ }));
121
150
  this.relatedFiles$ = combineLatest([
122
151
  this.documentId$,
123
152
  this.route.queryParamMap,
@@ -341,7 +370,7 @@ export class DossierDetailTabDocumentenApiDocumentsComponent {
341
370
  return null;
342
371
  }
343
372
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", 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 }); }
344
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", 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 supportedDocumentenApiFeatures: supportedDocumentenApiFeatures$ | async,\n pagination: pagination$ | async,\n sortState: sortState$ | 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 [initialSortState]=\"obs.sortState\"\n [loading]=\"obs.loading\"\n [pagination]=\"obs.pagination\"\n [paginatorConfig]=\"paginatorConfig\"\n paginationIdentifier=\"documentenApi\"\n (rowClicked)=\"onRowClick($event)\"\n (sortChanged)=\"\n obs?.supportedDocumentenApiFeatures?.supportsSortableColumns && onSortChanged($event)\n \"\n (paginationClicked)=\"onPaginationClicked($event)\"\n (paginationSet)=\"onPaginationSet($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 <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", "disableTrefwoorden", "documentTitle", "documentType", "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"] }] }); }
373
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", 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 supportedDocumentenApiFeatures: supportedDocumentenApiFeatures$ | async,\n pagination: pagination$ | async,\n sortState: sortState$ | async,\n uploadFields: uploadFields$ | async,\n defaultValues: defaultValues$ | async,\n hideFields: hideFields$ | 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 [initialSortState]=\"obs.sortState\"\n [loading]=\"obs.loading\"\n [pagination]=\"obs.pagination\"\n [paginatorConfig]=\"paginatorConfig\"\n paginationIdentifier=\"documentenApi\"\n (rowClicked)=\"onRowClick($event)\"\n (sortChanged)=\"\n obs?.supportedDocumentenApiFeatures?.supportsSortableColumns && onSortChanged($event)\n \"\n (paginationClicked)=\"onPaginationClicked($event)\"\n (paginationSet)=\"onPaginationSet($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 <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 [defaultValues]=\"obs.defaultValues\"\n [disableAuthor]=\"obs.uploadFields?.auteur?.readonly\"\n [disableConfidentialityLevel]=\"obs.uploadFields?.vertrouwelijkheidaanduiding?.readonly\"\n [disableCreationDate]=\"obs.uploadFields?.creatiedatum?.readonly\"\n [disableDescription]=\"obs.uploadFields?.beschrijving?.readonly\"\n [disableDocumentTitle]=\"obs.uploadFields?.titel?.readonly\"\n [disableDocumentType]=\"obs.uploadFields?.informatieobjecttype?.readonly\"\n [disableFilename]=\"obs.uploadFields?.bestandsnaam?.readonly\"\n [disableLanguage]=\"obs.uploadFields?.taal?.readonly\"\n [disableStatus]=\"obs.uploadFields?.status?.readonly\"\n [hideFields]=\"obs.hideFields\"\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 @if (data.item[data.key]) {\n {{ 'document.' + data.item[data.key] | translate }}\n } @else {\n -\n }\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$", "hideFields", "defaultValues", "disableAuthor", "disableConfidentialityLevel", "disableDescription", "disableDocumentTitle", "disableDocumentType", "disableFilename", "disableLanguage", "disableStatus", "supportsTrefwoorden", "disableCreationDate", "isEditMode", "open"], 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"] }] }); }
345
374
  }
346
375
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DossierDetailTabDocumentenApiDocumentsComponent, decorators: [{
347
376
  type: Component,
@@ -355,7 +384,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
355
384
  DocumentenApiFilterComponent,
356
385
  DialogModule,
357
386
  ConfirmationModalModule,
358
- ], 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 supportedDocumentenApiFeatures: supportedDocumentenApiFeatures$ | async,\n pagination: pagination$ | async,\n sortState: sortState$ | 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 [initialSortState]=\"obs.sortState\"\n [loading]=\"obs.loading\"\n [pagination]=\"obs.pagination\"\n [paginatorConfig]=\"paginatorConfig\"\n paginationIdentifier=\"documentenApi\"\n (rowClicked)=\"onRowClick($event)\"\n (sortChanged)=\"\n obs?.supportedDocumentenApiFeatures?.supportsSortableColumns && onSortChanged($event)\n \"\n (paginationClicked)=\"onPaginationClicked($event)\"\n (paginationSet)=\"onPaginationSet($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 <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"] }]
387
+ ], 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 supportedDocumentenApiFeatures: supportedDocumentenApiFeatures$ | async,\n pagination: pagination$ | async,\n sortState: sortState$ | async,\n uploadFields: uploadFields$ | async,\n defaultValues: defaultValues$ | async,\n hideFields: hideFields$ | 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 [initialSortState]=\"obs.sortState\"\n [loading]=\"obs.loading\"\n [pagination]=\"obs.pagination\"\n [paginatorConfig]=\"paginatorConfig\"\n paginationIdentifier=\"documentenApi\"\n (rowClicked)=\"onRowClick($event)\"\n (sortChanged)=\"\n obs?.supportedDocumentenApiFeatures?.supportsSortableColumns && onSortChanged($event)\n \"\n (paginationClicked)=\"onPaginationClicked($event)\"\n (paginationSet)=\"onPaginationSet($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 <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 [defaultValues]=\"obs.defaultValues\"\n [disableAuthor]=\"obs.uploadFields?.auteur?.readonly\"\n [disableConfidentialityLevel]=\"obs.uploadFields?.vertrouwelijkheidaanduiding?.readonly\"\n [disableCreationDate]=\"obs.uploadFields?.creatiedatum?.readonly\"\n [disableDescription]=\"obs.uploadFields?.beschrijving?.readonly\"\n [disableDocumentTitle]=\"obs.uploadFields?.titel?.readonly\"\n [disableDocumentType]=\"obs.uploadFields?.informatieobjecttype?.readonly\"\n [disableFilename]=\"obs.uploadFields?.bestandsnaam?.readonly\"\n [disableLanguage]=\"obs.uploadFields?.taal?.readonly\"\n [disableStatus]=\"obs.uploadFields?.status?.readonly\"\n [hideFields]=\"obs.hideFields\"\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 @if (data.item[data.key]) {\n {{ 'document.' + data.item[data.key] | translate }}\n } @else {\n -\n }\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"] }]
359
388
  }], 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: [{
360
389
  type: ViewChild,
361
390
  args: ['fileInput']
@@ -363,4 +392,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
363
392
  type: ViewChild,
364
393
  args: ['translationTemplate']
365
394
  }] } });
366
- //# 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":"AAAA;;;;;;;;;;;;;;GAcG;AACH,OAAO,EAAC,YAAY,EAAC,MAAM,iBAAiB,CAAC;AAC7C,OAAO,EAAC,SAAS,EAA8C,SAAS,EAAC,MAAM,eAAe,CAAC;AAE/F,OAAO,EAAC,QAAQ,EAAE,UAAU,EAAE,QAAQ,EAAC,MAAM,eAAe,CAAC;AAC7D,OAAO,EAAC,eAAe,EAAmB,MAAM,qBAAqB,CAAC;AACtE,OAAO,EAEL,gBAAgB,EAEhB,uBAAuB,EACvB,kBAAkB,EAClB,wBAAwB,EAIxB,QAAQ,GACT,MAAM,qBAAqB,CAAC;AAI7B,OAAO,EAAC,YAAY,EAAE,YAAY,EAAE,UAAU,EAAc,MAAM,2BAA2B,CAAC;AAC9F,OAAO,EACL,eAAe,EACf,aAAa,EAEb,EAAE,EACF,aAAa,EACb,OAAO,EACP,YAAY,GACb,MAAM,MAAM,CAAC;AACd,OAAO,EAAC,UAAU,EAAE,MAAM,EAAE,GAAG,EAAE,SAAS,EAAE,IAAI,EAAE,GAAG,EAAC,MAAM,gBAAgB,CAAC;AAC7E,OAAO,EACL,iBAAiB,EAEjB,sBAAsB,GAIvB,MAAM,cAAc,CAAC;AAGtB,OAAO,EAAC,4BAA4B,EAAC,MAAM,0DAA0D,CAAC;AACtG,OAAO,EAAC,mCAAmC,EAAC,MAAM,0EAA0E,CAAC;;;;;;;;;;;;AAmB7H,MAAM,OAAO,+CAA+C;IAwH1D,IAAW,UAAU;QACnB,OAAO,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,EAAE,CAAC,IAAI,CAAC,0BAA0B,CAAC,SAAS,EAAE,IAAI,CAAC,CAAC,CAAC,CAAC;IAC9F,CAAC;IA4CD,YACmB,KAAqB,EACrB,MAAc,EACd,qBAA4C,EAC5C,eAAgC,EAChC,gBAAkC,EAClC,aAA4B,EAC5B,mBAAwC,EACxC,WAAwB,EACxB,4BAA0D,EAC1D,0BAAsD,EACtD,2BAAwD;QAVxD,UAAK,GAAL,KAAK,CAAgB;QACrB,WAAM,GAAN,MAAM,CAAQ;QACd,0BAAqB,GAArB,qBAAqB,CAAuB;QAC5C,oBAAe,GAAf,eAAe,CAAiB;QAChC,qBAAgB,GAAhB,gBAAgB,CAAkB;QAClC,kBAAa,GAAb,aAAa,CAAe;QAC5B,wBAAmB,GAAnB,mBAAmB,CAAqB;QACxC,gBAAW,GAAX,WAAW,CAAa;QACxB,iCAA4B,GAA5B,4BAA4B,CAA8B;QAC1D,+BAA0B,GAA1B,0BAA0B,CAA4B;QACtD,gCAA2B,GAA3B,2BAA2B,CAA6B;QA7K1D,6BAAwB,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAChE,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,sBAAsB,CAAC,EAC7C,MAAM,CAAC,kBAAkB,CAAC,EAAE,CAAC,CAAC,CAAC,kBAAkB,CAAC,CACnD,CAAC;QAEc,oCAA+B,GAC7C,IAAI,eAAe,CAAwC,IAAI,CAAC,CAAC;QAElD,qCAAgC,GAC/C,IAAI,CAAC,wBAAwB,CAAC,IAAI,CAChC,SAAS,CAAC,kBAAkB,CAAC,EAAE,CAC7B,IAAI,CAAC,2BAA2B,CAAC,uBAAuB,CAAC,kBAAkB,CAAC,CAC7E,EACD,GAAG,CAAC,8BAA8B,CAAC,EAAE,CACnC,IAAI,CAAC,+BAA+B,CAAC,IAAI,CAAC,8BAA8B,CAAC,CAC1E,CACF,CAAC;QAEY,YAAO,GAA+B,IAAI,CAAC,wBAAwB,CAAC,IAAI,CACtF,GAAG,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,EACzC,SAAS,CAAC,sBAAsB,CAAC,EAAE,CACjC,aAAa,CAAC;YACZ,IAAI,CAAC,0BAA0B,CAAC,oBAAoB,CAAC,sBAAsB,CAAC;YAC5E,IAAI,CAAC,gCAAgC;YACrC,IAAI,CAAC,MAAM;SACZ,CAAC,CACH,EACD,GAAG,CAAC,CAAC,CAAC,OAAO,EAAE,8BAA8B,EAAE,IAAI,CAAC,EAAE,EAAE;YACtD,MAAM,iBAAiB,GAAiC,OAAO,CAAC,IAAI,CAClE,CAAC,MAAwB,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,WAAW,CACnD,CAAC;YACF,IAAI,CAAC,CAAC,iBAAiB,IAAI,CAAC,IAAI,IAAI,8BAA8B,CAAC,uBAAuB,EAAE,CAAC;gBAC3F,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,EAAC,IAAI,EAAE,GAAG,iBAAiB,CAAC,GAAG,IAAI,iBAAiB,CAAC,WAAW,EAAE,EAAC,CAAC,CAAC;YACxF,CAAC;YAED,OAAO,OAAO,CAAC,GAAG,CAAC,CAAC,MAAwB,EAAE,EAAE,CAAC,CAAC;gBAChD,GAAG,EAAE,MAAM,CAAC,GAAG,KAAK,sBAAsB,CAAC,cAAc,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,GAAG;gBAC/E,KAAK,EAAE,uBAAuB,MAAM,CAAC,GAAG,EAAE;gBAC1C,QAAQ,EAAE,CAAC,iBAAiB,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,iBAAiB,CAAC,MAAM,CAAC,GAAG,CAAC;gBACxF,GAAG,CAAC,iBAAiB,CAAC,MAAM,CAAC,GAAG,CAAC,KAAK,QAAQ,CAAC,QAAQ,IAAI;oBACzD,QAAQ,EAAE,IAAI,CAAC,mBAAmB;oBAClC,YAAY,EAAE,EAAC,GAAG,EAAE,MAAM,CAAC,GAAG,EAAC;iBAChC,CAAC;gBACF,GAAG,CAAC,MAAM,CAAC,GAAG,KAAK,sBAAsB,CAAC,YAAY,IAAI,EAAC,MAAM,EAAE,YAAY,EAAC,CAAC;gBACjF,QAAQ,EAAE,MAAM,CAAC,QAAQ,IAAI,8BAA8B,CAAC,uBAAuB;aACpF,CAAC,CAAC,CAAC;QACN,CAAC,CAAC,EACF,GAAG,CAAC,GAAG,EAAE;YACP,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAClC,CAAC,CAAC,CACH,CAAC;QAEK,gBAAW,GAAiB;YACjC;gBACE,KAAK,EAAE,mBAAmB;gBAC1B,QAAQ,EAAE,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,IAAI,CAAC;gBAC/C,IAAI,EAAE,QAAQ;aACf;YACD;gBACE,KAAK,EAAE,eAAe;gBACtB,QAAQ,EAAE,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC;gBACxC,gBAAgB,EAAE,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC;gBAC9C,IAAI,EAAE,QAAQ;aACf;YACD;gBACE,KAAK,EAAE,iBAAiB;gBACxB,QAAQ,EAAE,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,IAAI,CAAC;gBAC7C,IAAI,EAAE,QAAQ;aACf;SACF,CAAC;QAEc,4BAAuB,GAAuB,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAClF,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,sBAAsB,CAAC,EAC7C,MAAM,CAAC,sBAAsB,CAAC,EAAE,CAAC,CAAC,CAAC,sBAAsB,CAAC,CAC3D,CAAC;QAEc,gBAAW,GAAuB,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CACtE,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,UAAU,CAAC,EACjC,MAAM,CAAC,UAAU,CAAC,EAAE,CAAC,CAAC,CAAC,UAAU,CAAC,CACnC,CAAC;QAIK,2BAAsB,GAAG,KAAK,CAAC;QAG/B,gBAAW,GAAG,IAAI,eAAe,CAAU,KAAK,CAAC,CAAC;QAEzC,kBAAa,GAC3B,IAAI,CAAC,aAAa,EAAE,MAAM,EAAE,2BAA2B,IAAI,IAAI,CAAC;QAClD,gBAAW,GAAW,IAAI,CAAC,aAAa,EAAE,MAAM,EAAE,yBAAyB,IAAI,CAAC,CAAC;QAEjF,sBAAiB,GAAG,IAAI,eAAe,CAAc,IAAI,CAAC,CAAC;QAC3D,mBAAc,GAAG,IAAI,eAAe,CAAU,KAAK,CAAC,CAAC;QACrD,eAAU,GAAG,IAAI,OAAO,EAAQ,CAAC;QACjC,qBAAgB,GAAG,IAAI,eAAe,CAAU,KAAK,CAAC,CAAC;QACvD,iCAA4B,GAAG,IAAI,eAAe,CAAU,KAAK,CAAC,CAAC;QAEnE,eAAU,GAAG,IAAI,eAAe,CAAU,KAAK,CAAC,CAAC;QAChD,mBAAc,GAAG,IAAI,eAAe,CAAU,IAAI,CAAC,CAAC;QACrD,mBAAc,GAAG,IAAI,eAAe,CAAU,IAAI,CAAC,CAAC;QACpD,aAAQ,GAAG,aAAa,CAAC,CAAC,IAAI,CAAC,cAAc,EAAE,IAAI,CAAC,cAAc,CAAC,CAAC,CAAC,IAAI,CACvF,GAAG,CAAC,CAAC,CAAC,YAAY,EAAE,aAAa,CAAC,EAAE,EAAE,CAAC,YAAY,IAAI,aAAa,CAAC,CACtE,CAAC;QAEc,YAAO,GAAG,IAAI,aAAa,EAAmC,CAAC;QAC/D,gBAAW,GAAG,IAAI,eAAe,CAAa,kBAAkB,CAAC,CAAC;QACjE,cAAS,GAAG,IAAI,eAAe,CAAO,IAAI,CAAC,CAAC;QAC5C,WAAM,GAAG,IAAI,aAAa,EAAyB,CAAC;QAGrD,oBAAe,GAAG;YAChC,GAAG,wBAAwB;YAC3B,mBAAmB,EAAE,CAAC,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,GAAG,CAAC;SAC1C,CAAC;QAMK,kBAAa,GAAgD,aAAa,CAAC;YAChF,IAAI,CAAC,WAAW;YAChB,IAAI,CAAC,KAAK,CAAC,aAAa;YACxB,IAAI,CAAC,SAAS;SACf,CAAC,CAAC,IAAI,CACL,GAAG,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,EACzC,SAAS,CAAC,CAAC,CAAC,UAAU,EAAE,WAAW,CAAC,EAAE,EAAE,CACtC,aAAa,CAAC;YACZ,IAAI,CAAC,4BAA4B,CAAC,4BAA4B,CAC5D,UAAU,EACV,WAAW,CAAC,QAAQ,CAAC,CACtB;YACD,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,KAAK,CAAC;SACpC,CAAC,CACH,EACD,GAAG,CAAC,CAAC,CAAC,YAAY,CAAC,EAAE,EAAE;YACrB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC;gBACpB,GAAG,IAAI,CAAC,WAAW,CAAC,QAAQ,EAAE;gBAC9B,cAAc,EAAE,YAAY,CAAC,aAAa;aAC3C,CAAC,CAAC;YACH,MAAM,eAAe,GAAG,YAAY,EAAE,OAAO,EAAE,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;gBAC1D,GAAG,IAAI;gBACP,SAAS,EAAE,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,6BAA6B,CAAC;gBACzF,IAAI,EAAE,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,cAAc,CAAC;gBAChD,IAAI,EAAE,IAAI,CAAC,WAAW,EAAE,GAAG,CAAC,CAAC,SAAiB,EAAE,EAAE,CAAC,CAAC;oBAClD,OAAO,EAAE,SAAS;iBACnB,CAAC,CAAC;aACJ,CAAC,CAAC,CAAC;YACJ,OAAO,eAAe,IAAI,EAAE,CAAC;QAC/B,CAAC,CAAC,EACF,GAAG,CAAC,GAAG,EAAE;YACP,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAClC,CAAC,CAAC,EACF,UAAU,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC;YAChC,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YAChC,OAAO,EAAE,CAAC,EAAE,CAAC,CAAC;QAChB,CAAC,CAAC,CACH,CAAC;QAEe,mBAAc,GAAG,IAAI,YAAY,EAAE,CAAC;QAenD,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC;QACpC,IAAI,CAAC,kBAAkB,GAAG,aAAa,CAAC,MAAM,CAAC,UAAU,CAAC,WAAW,CAAC;IACxE,CAAC;IAEM,QAAQ;QACb,IAAI,CAAC,gBAAgB,EAAE,CAAC;QACxB,IAAI,CAAC,sBAAsB,EAAE,CAAC;QAC9B,IAAI,CAAC,WAAW,EAAE,CAAC;QACnB,IAAI,CAAC,WAAW,CAAC,WAAW,CAAC,CAAC,QAAQ,EAAE,UAAU,EAAE,QAAQ,CAAC,CAAC,CAAC;IACjE,CAAC;IAEM,WAAW;QAChB,IAAI,CAAC,cAAc,CAAC,WAAW,EAAE,CAAC;IACpC,CAAC;IAEM,mBAAmB,CAAC,IAA8B;QACvD,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;QACrB,IAAI,CAAC,4BAA4B,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC/C,CAAC;IAEM,cAAc;QACnB,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC/B,IAAI,CAAC,4BAA4B,CAAC,cAAc,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,SAAS,CAAC,GAAG,EAAE;YAC7E,IAAI,CAAC,gBAAgB,EAAE,CAAC;QAC1B,CAAC,CAAC,CAAC;IACL,CAAC;IAEM,gBAAgB,CAAC,KAAyB;QAC/C,IAAI,CAAC,KAAK;YAAE,OAAO,EAAE,CAAC;QAEtB,MAAM,SAAS,GAAG,KAAK,GAAG,CAAC,IAAI,GAAG,IAAI,CAAC,CAAC;QACxC,IAAI,SAAS,GAAG,CAAC,EAAE,CAAC;YAClB,OAAO,GAAG,IAAI,CAAC,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,KAAK,CAAC;QAC7C,CAAC;aAAM,IAAI,SAAS,GAAG,IAAI,EAAE,CAAC;YAC5B,OAAO,SAAS,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC;QACtC,CAAC;QAED,OAAO,CAAC,SAAS,GAAG,IAAI,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC;IAC/C,CAAC;IAEM,sBAAsB;QAC3B,IAAI,IAAI,CAAC,sBAAsB,IAAI,IAAI,CAAC,mBAAmB,EAAE,CAAC;YAC5D,OAAO,QAAQ,CAAC;QAClB,CAAC;aAAM,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;YACxB,OAAO,8CAA8C,CAAC;QACxD,CAAC;QAED,OAAO,gDAAgD,CAAC;IAC1D,CAAC;IAEM,WAAW;QAChB,IAAI,CAAC,mBAAmB;aACrB,cAAc,EAAE;aAChB,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;aACb,SAAS,CACR,YAAY,CAAC,EAAE;YACb,IAAI,CAAC,OAAO,GAAG,YAAY,CAAC,KAAK,CAAC,QAAQ,CAAC,YAAY,CAAC,CAAC;QAC3D,CAAC,EACD,GAAG,EAAE;YACH,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;QACvB,CAAC,CACF,CAAC;IACN,CAAC;IAEM,WAAW,CAAC,QAA+B;QAChD,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAE3B,aAAa,CAAC,CAAC,IAAI,CAAC,iBAAiB,EAAE,IAAI,CAAC,WAAW,CAAC,CAAC;aACtD,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;aACb,IAAI,CACH,GAAG,CAAC,CAAC,CAAC,IAAI,EAAE,UAAU,CAAC,EAAE,EAAE;YACzB,IAAI,CAAC,IAAI;gBAAE,OAAO;YAClB,IAAI,IAAI,CAAC,WAAW,CAAC,QAAQ,EAAE,EAAE,CAAC;gBAChC,IAAI,CAAC,4BAA4B,CAAC,cAAc,CAAC,IAAI,EAAE,QAAQ,CAAC,CAAC,SAAS,CAAC,GAAG,EAAE;oBAC9E,IAAI,CAAC,gBAAgB,EAAE,CAAC;oBACxB,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;oBAC5B,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;gBACpC,CAAC,CAAC,CAAC;YACL,CAAC;iBAAM,CAAC;gBACN,IAAI,CAAC,qBAAqB;qBACvB,sBAAsB,CAAC,IAAI,EAAE,UAAU,EAAE,QAAQ,CAAC;qBAClD,SAAS,CAAC,GAAG,EAAE;oBACd,IAAI,CAAC,gBAAgB,EAAE,CAAC;oBACxB,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;oBACxB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC;oBAC1C,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;oBAC5B,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;gBACpC,CAAC,CAAC,CAAC;YACP,CAAC;QACH,CAAC,CAAC,CACH;aACA,SAAS,EAAE,CAAC;IACjB,CAAC;IAEM,qBAAqB,CAAC,IAA8B;QACzD,IAAI,CAAC,gBAAgB,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;IACpC,CAAC;IAEM,cAAc,CAAC,IAAU;QAC9B,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC5B,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAClC,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACnC,CAAC;IAEM,kBAAkB;QACvB,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACpC,CAAC;IAEM,cAAc,CAAC,KAAU;QAC9B,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC7B,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;QACnD,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACjC,IAAI,CAAC,cAAc,EAAE,CAAC;IACxB,CAAC;IAEM,0BAA0B;QAC/B,IAAI,CAAC,uBAAuB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,sBAAsB,CAAC,EAAE;YAC5E,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,+BAA+B,sBAAsB,EAAE,CAAC,CAAC,CAAC;QAClF,CAAC,CAAC,CAAC;IACL,CAAC;IAEM,UAAU,CAAC,KAAU;QAC1B,IAAI,CAAC,gBAAgB,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;IACtC,CAAC;IAEM,mBAAmB,CAAC,IAAY;QACrC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,EAAC,GAAG,IAAI,CAAC,WAAW,CAAC,QAAQ,EAAE,EAAE,IAAI,EAAC,CAAC,CAAC;IAChE,CAAC;IAEM,eAAe,CAAC,IAAY;QACjC,MAAM,EAAC,cAAc,EAAE,IAAI,EAAC,GAAG,IAAI,CAAC,WAAW,CAAC,QAAQ,EAAE,CAAC;QAC3D,MAAM,SAAS,GAAY,IAAI,CAAC,IAAI,CAAC,CAAC,cAAc,GAAG,IAAI,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,cAAc,GAAG,CAAC,CAAC;QAC7F,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,EAAC,GAAG,IAAI,CAAC,WAAW,CAAC,QAAQ,EAAE,EAAE,IAAI,EAAE,GAAG,CAAC,SAAS,IAAI,EAAC,IAAI,EAAE,CAAC,EAAC,CAAC,EAAC,CAAC,CAAC;IAC7F,CAAC;IAEM,mBAAmB;QACxB,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;IACvC,CAAC;IAEM,aAAa,CAAC,MAAuC;QAC1D,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QAC1B,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,EAAC,GAAG,IAAI,CAAC,WAAW,CAAC,QAAQ,EAAE,EAAE,GAAG,kBAAkB,EAAC,CAAC,CAAC;IACjF,CAAC;IAEM,aAAa,CAAC,SAAoB;QACvC,IAAI,CAAC,MAAM,CAAC,IAAI,CACd,SAAS,CAAC,SAAS;YACjB,CAAC,CAAC;gBACE,IAAI,EAAE,GAAG,SAAS,CAAC,KAAK,CAAC,IAAI,KAAK,MAAM,CAAC,CAAC,CAAC,sBAAsB,CAAC,cAAc,CAAC,CAAC,CAAC,SAAS,CAAC,KAAK,CAAC,IAAI,IAAI,SAAS,CAAC,KAAK,CAAC,SAAS,EAAE;aACvI;YACH,CAAC,CAAC,IAAI,CACT,CAAC;IACJ,CAAC;IAEM,gBAAgB;QACrB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC5B,CAAC;IAEO,YAAY,CAAC,IAA8B;QACjD,OAAO,IAAI,CAAC,MAAM,KAAK,YAAY,CAAC;IACtC,CAAC;IAEO,gBAAgB,CAAC,WAAqC,EAAE,aAAsB;QACpF,IAAI,CAAC,eAAe,CAAC,YAAY,CAC/B,GAAG,IAAI,CAAC,kBAAkB,qBAAqB,WAAW,CAAC,qBAAqB,UAAU,WAAW,CAAC,MAAM,WAAW,EACvH,WAAW,CAAC,YAAY,IAAI,EAAE,EAC9B,aAAa,CACd,CAAC;IACJ,CAAC;IAEO,2BAA2B;QACjC,IAAI,CAAC,cAAc,CAAC,GAAG,CACrB,aAAa,CAAC;YACZ,IAAI,CAAC,uBAAuB;YAC5B,IAAI,CAAC,WAAW;YAChB,IAAI,CAAC,OAAO;YACZ,IAAI,CAAC,MAAM;YACX,IAAI,CAAC,WAAW;SACjB,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,cAAc,EAAE,UAAU,EAAE,MAAM,EAAE,IAAI,EAAE,UAAU,CAAC,EAAE,EAAE;YACtE,MAAM,EAAC,IAAI,EAAE,IAAI,EAAC,GAAG,UAAU,CAAC;YAChC,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,aAAa,cAAc,aAAa,UAAU,YAAY,CAAC,EAAE;gBACrF,WAAW,EAAE,EAAC,GAAG,MAAM,EAAE,GAAG,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,GAAG,CAAC,EAAC;aACxD,CAAC,CAAC;QACL,CAAC,CAAC,CACH,CAAC;IACJ,CAAC;IAEO,cAAc;QACpB,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,KAAK,GAAG,EAAE,CAAC;IAC1C,CAAC;IAEO,sBAAsB;QAC5B,IAAI,CAAC,uBAAuB;aACzB,IAAI,CACH,SAAS,CAAC,sBAAsB,CAAC,EAAE,CACjC,IAAI,CAAC,qBAAqB,CAAC,sBAAsB,CAAC,sBAAsB,CAAC,CAC1E,EACD,IAAI,CAAC,CAAC,CAAC,EACP,GAAG,CAAC,GAAG,EAAE;YACP,IAAI,CAAC,sBAAsB,GAAG,IAAI,CAAC;QACrC,CAAC,CAAC,CACH;aACA,SAAS,CAAC,CAAC,MAAe,EAAE,EAAE;YAC7B,IAAI,CAAC,mBAAmB,GAAG,MAAM,CAAC;QACpC,CAAC,CAAC,CAAC;IACP,CAAC;IAEO,gBAAgB;QACtB,IAAI,CAAC,KAAK,CAAC,aAAa;aACrB,IAAI,CACH,IAAI,CAAC,CAAC,CAAC,EACP,GAAG,CAAC,WAAW,CAAC,EAAE;YAChB,MAAM,EAAC,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,GAAG,MAAM,EAAC,GAAG,WAAW,CAAC,QAAQ,CAAC,CAAC;YAC5D,OAAO,EAAC,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,IAAI,EAAC,CAAC;QACpC,CAAC,CAAC,CACH;aACA,SAAS,CAAC,CAAC,EAAC,MAAM,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAC,EAAE,EAAE;YACxC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,EAAC,IAAI,EAAC,CAAC,CAAC;YACzB,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;YAC1B,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC;gBACpB,GAAG,IAAI,CAAC,WAAW,CAAC,QAAQ,EAAE;gBAC9B,IAAI,EAAE,CAAC,IAAI;gBACX,IAAI,EAAE,CAAC,CAAC,IAAI,IAAI,CAAC,CAAC,GAAG,CAAC;aACvB,CAAC,CAAC;YACH,IAAI,CAAC,2BAA2B,EAAE,CAAC;QACrC,CAAC,CAAC,CAAC;IACP,CAAC;IAEO,0BAA0B,CAAC,UAAmB;QACpD,MAAM,WAAW,GAAG,UAAU,IAAI,UAAU,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;QACxD,IAAI,WAAW,IAAI,WAAW,EAAE,MAAM,GAAG,CAAC,EAAE,CAAC;YAC3C,OAAO;gBACL,SAAS,EAAE,IAAI;gBACf,KAAK,EAAE;oBACL,IAAI,EAAE,WAAW,CAAC,CAAC,CAAC;oBACpB,SAAS,EAAE,WAAW,CAAC,CAAC,CAAc;iBACvC;aACF,CAAC;QACJ,CAAC;QAED,OAAO,IAAI,CAAC;IACd,CAAC;+GApaU,+CAA+C;mGAA/C,+CAA+C,oUC5E5D,y6MAsLA,+hCDrHI,YAAY,yZACZ,gBAAgB,21BAChB,mCAAmC,yfACnC,YAAY,gMACZ,UAAU,4NACV,eAAe,4FACf,4BAA4B,sHAC5B,YAAY,mQACZ,uBAAuB;;4FAGd,+CAA+C;kBAjB3D,SAAS;+BACE,qDAAqD,cAGnD,IAAI,WACP;wBACP,YAAY;wBACZ,gBAAgB;wBAChB,mCAAmC;wBACnC,YAAY;wBACZ,UAAU;wBACV,eAAe;wBACf,4BAA4B;wBAC5B,YAAY;wBACZ,uBAAuB;qBACxB;+ZAGuB,SAAS;sBAAhC,SAAS;uBAAC,WAAW;gBACY,mBAAmB;sBAApD,SAAS;uBAAC,qBAAqB","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, OnDestroy, 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  DEFAULT_PAGINATION,\n  DEFAULT_PAGINATOR_CONFIG,\n  DocumentenApiMetadata,\n  Pagination,\n  SortState,\n  ViewType,\n} from '@valtimo/components';\nimport {ConfigService, Direction} from '@valtimo/config';\nimport {DownloadService, UploadProviderService} from '@valtimo/resource';\nimport {UserProviderService} from '@valtimo/security';\nimport {ButtonModule, DialogModule, IconModule, IconService} from 'carbon-components-angular';\nimport {\n  BehaviorSubject,\n  combineLatest,\n  Observable,\n  of,\n  ReplaySubject,\n  Subject,\n  Subscription,\n} 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, OnDestroy {\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        this._sort$,\n      ])\n    ),\n    map(([columns, supportedDocumentenApiFeatures, sort]) => {\n      const defaultSortColumn: ConfiguredColumn | undefined = columns.find(\n        (column: ConfiguredColumn) => !!column.defaultSort\n      );\n      if (!!defaultSortColumn && !sort && 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(() => {\n      this.fieldsLoading$.next(false);\n    })\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 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  public readonly pagination$ = new BehaviorSubject<Pagination>(DEFAULT_PAGINATION);\n  private readonly _refetch$ = new BehaviorSubject<null>(null);\n  private readonly _sort$ = new ReplaySubject<{sort: string} | null>();\n  private readonly valtimoEndpointUri!: string;\n\n  public readonly paginatorConfig = {\n    ...DEFAULT_PAGINATOR_CONFIG,\n    itemsPerPageOptions: [5, 10, 20, 50, 100],\n  };\n\n  public get sortState$(): Observable<SortState | null> {\n    return this._sort$.pipe(map(sortValue => this.getSortStateFromSortString(sortValue?.sort)));\n  }\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      this.pagination$.next({\n        ...this.pagination$.getValue(),\n        collectionSize: relatedFiles.totalElements,\n      });\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  private readonly _subscriptions = new Subscription();\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    this.valtimoEndpointUri = configService.config.valtimoApi.endpointUri;\n  }\n\n  public ngOnInit(): void {\n    this.setInitialParams();\n    this.setUploadProcessLinked();\n    this.isUserAdmin();\n    this.iconService.registerAll([Filter16, TagGroup16, Upload16]);\n  }\n\n  public ngOnDestroy(): void {\n    this._subscriptions.unsubscribe();\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\n      .getUserSubject()\n      .pipe(take(1))\n      .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.pagination$.next(DEFAULT_PAGINATION);\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 onPaginationClicked(page: number): void {\n    this.pagination$.next({...this.pagination$.getValue(), page});\n  }\n\n  public onPaginationSet(size: number): void {\n    const {collectionSize, page} = this.pagination$.getValue();\n    const resetPage: boolean = Math.ceil(+collectionSize / size) <= +page && +collectionSize > 0;\n    this.pagination$.next({...this.pagination$.getValue(), size, ...(resetPage && {page: 1})});\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    this.pagination$.next({...this.pagination$.getValue(), ...DEFAULT_PAGINATION});\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      `${this.valtimoEndpointUri}v1/documenten-api/${relatedFile.pluginConfigurationId}/files/${relatedFile.fileId}/download`,\n      relatedFile.bestandsnaam ?? '',\n      forceDownload\n    );\n  }\n\n  private openQueryParamsSubscription(): void {\n    this._subscriptions.add(\n      combineLatest([\n        this.documentDefinitionName$,\n        this.documentId$,\n        this.filter$,\n        this._sort$,\n        this.pagination$,\n      ]).subscribe(([definitionName, documentId, filter, sort, pagination]) => {\n        const {size, page} = pagination;\n        this.router.navigate([`/dossiers/${definitionName}/document/${documentId}/documents`], {\n          queryParams: {...filter, ...sort, size, page: page - 1},\n        });\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 setInitialParams(): void {\n    this.route.queryParamMap\n      .pipe(\n        take(1),\n        map(queryParams => {\n          const {sort, size, page, ...filter} = queryParams['params'];\n          return {sort, filter, size, page};\n        })\n      )\n      .subscribe(({filter, sort, size, page}) => {\n        this._sort$.next({sort});\n        this.filter$.next(filter);\n        this.pagination$.next({\n          ...this.pagination$.getValue(),\n          size: +size,\n          page: +(page ?? 0) + 1,\n        });\n        this.openQueryParamsSubscription();\n      });\n  }\n\n  private getSortStateFromSortString(sortString?: string): SortState | null {\n    const splitString = sortString && sortString.split(',');\n    if (splitString && splitString?.length > 1) {\n      return {\n        isSorting: true,\n        state: {\n          name: splitString[0],\n          direction: splitString[1] as Direction,\n        },\n      };\n    }\n\n    return null;\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    supportedDocumentenApiFeatures: supportedDocumentenApiFeatures$ | async,\n    pagination: pagination$ | async,\n    sortState: sortState$ | 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      [initialSortState]=\"obs.sortState\"\n      [loading]=\"obs.loading\"\n      [pagination]=\"obs.pagination\"\n      [paginatorConfig]=\"paginatorConfig\"\n      paginationIdentifier=\"documentenApi\"\n      (rowClicked)=\"onRowClick($event)\"\n      (sortChanged)=\"\n        obs?.supportedDocumentenApiFeatures?.supportsSortableColumns && onSortChanged($event)\n      \"\n      (paginationClicked)=\"onPaginationClicked($event)\"\n      (paginationSet)=\"onPaginationSet($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        <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"]}
395
+ //# 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, OnDestroy, 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  DEFAULT_PAGINATION,\n  DEFAULT_PAGINATOR_CONFIG,\n  DocumentenApiMetadata,\n  Pagination,\n  SortState,\n  ViewType,\n} from '@valtimo/components';\nimport {ConfigService, Direction} from '@valtimo/config';\nimport {DownloadService, UploadProviderService} from '@valtimo/resource';\nimport {UserProviderService} from '@valtimo/security';\nimport {ButtonModule, DialogModule, IconModule, IconService} from 'carbon-components-angular';\nimport {\n  BehaviorSubject,\n  combineLatest,\n  Observable,\n  of,\n  ReplaySubject,\n  Subject,\n  Subscription,\n} 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';\nimport {\n  DocumentenApiUploadFieldDefaultValues,\n  DocumentenApiUploadFields\n} from '../../models/documenten-api-upload-field.model';\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, OnDestroy {\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        this._sort$,\n      ])\n    ),\n    map(([columns, supportedDocumentenApiFeatures, sort]) => {\n      const defaultSortColumn: ConfiguredColumn | undefined = columns.find(\n        (column: ConfiguredColumn) => !!column.defaultSort\n      );\n      if (!!defaultSortColumn && !sort && 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(() => {\n      this.fieldsLoading$.next(false);\n    })\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 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  public readonly pagination$ = new BehaviorSubject<Pagination>(DEFAULT_PAGINATION);\n  private readonly _refetch$ = new BehaviorSubject<null>(null);\n  private readonly _sort$ = new ReplaySubject<{sort: string} | null>();\n  private readonly valtimoEndpointUri!: string;\n\n  public readonly paginatorConfig = {\n    ...DEFAULT_PAGINATOR_CONFIG,\n    itemsPerPageOptions: [5, 10, 20, 50, 100],\n  };\n\n  public get sortState$(): Observable<SortState | null> {\n    return this._sort$.pipe(map(sortValue => this.getSortStateFromSortString(sortValue?.sort)));\n  }\n\n  public uploadFields$: Observable<DocumentenApiUploadFields> = this.documentId$.pipe(\n    switchMap(documentId => this.documentenApiDocumentService.getPrefilledUploadFields(documentId)),\n    map(uploadFields =>\n      uploadFields.reduce(\n        (acc, curr) => ({\n          ...acc,\n          [curr.key]: {\n            key: curr.key,\n            defaultValue: curr.defaultValue,\n            visible: curr.visible,\n            readonly: curr.readonly,\n          },\n        }),\n        {}\n      )\n    )\n  );\n\n  public defaultValues$: Observable<DocumentenApiUploadFieldDefaultValues> = this.uploadFields$.pipe(\n    map(formFields => ({\n      auteur: formFields?.auteur?.defaultValue,\n      vertrouwelijkheidaanduiding: formFields?.vertrouwelijkheidaanduiding?.defaultValue,\n      beschrijving: formFields?.beschrijving?.defaultValue,\n      titel: formFields?.titel?.defaultValue,\n      informatieobjecttype: formFields?.informatieobjecttype?.defaultValue,\n      bestandsnaam: formFields?.bestandsnaam?.defaultValue,\n      taal: formFields?.taal?.defaultValue,\n      status: formFields?.status?.defaultValue,\n      trefwoorden: formFields?.trefwoorden?.defaultValue\n        ?.split(',')\n        ?.map(tag => tag.trim())\n        ?.filter(tag => !!tag),\n    }))\n  );\n\n  public hideFields$: Observable<Array<string>> = this.uploadFields$.pipe(\n    map(formFields => {\n      if (formFields) {\n        return Object.keys(formFields).filter(field => !formFields[field]?.visible);\n      }\n      return [];\n    })\n  );\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      this.pagination$.next({\n        ...this.pagination$.getValue(),\n        collectionSize: relatedFiles.totalElements,\n      });\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  private readonly _subscriptions = new Subscription();\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    this.valtimoEndpointUri = configService.config.valtimoApi.endpointUri;\n  }\n\n  public ngOnInit(): void {\n    this.setInitialParams();\n    this.setUploadProcessLinked();\n    this.isUserAdmin();\n    this.iconService.registerAll([Filter16, TagGroup16, Upload16]);\n  }\n\n  public ngOnDestroy(): void {\n    this._subscriptions.unsubscribe();\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\n      .getUserSubject()\n      .pipe(take(1))\n      .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.pagination$.next(DEFAULT_PAGINATION);\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 onPaginationClicked(page: number): void {\n    this.pagination$.next({...this.pagination$.getValue(), page});\n  }\n\n  public onPaginationSet(size: number): void {\n    const {collectionSize, page} = this.pagination$.getValue();\n    const resetPage: boolean = Math.ceil(+collectionSize / size) <= +page && +collectionSize > 0;\n    this.pagination$.next({...this.pagination$.getValue(), size, ...(resetPage && {page: 1})});\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    this.pagination$.next({...this.pagination$.getValue(), ...DEFAULT_PAGINATION});\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      `${this.valtimoEndpointUri}v1/documenten-api/${relatedFile.pluginConfigurationId}/files/${relatedFile.fileId}/download`,\n      relatedFile.bestandsnaam ?? '',\n      forceDownload\n    );\n  }\n\n  private openQueryParamsSubscription(): void {\n    this._subscriptions.add(\n      combineLatest([\n        this.documentDefinitionName$,\n        this.documentId$,\n        this.filter$,\n        this._sort$,\n        this.pagination$,\n      ]).subscribe(([definitionName, documentId, filter, sort, pagination]) => {\n        const {size, page} = pagination;\n        this.router.navigate([`/dossiers/${definitionName}/document/${documentId}/documents`], {\n          queryParams: {...filter, ...sort, size, page: page - 1},\n        });\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 setInitialParams(): void {\n    this.route.queryParamMap\n      .pipe(\n        take(1),\n        map(queryParams => {\n          const {sort, size, page, ...filter} = queryParams['params'];\n          return {sort, filter, size, page};\n        })\n      )\n      .subscribe(({filter, sort, size, page}) => {\n        this._sort$.next({sort});\n        this.filter$.next(filter);\n        this.pagination$.next({\n          ...this.pagination$.getValue(),\n          size: +size,\n          page: +(page ?? 0) + 1,\n        });\n        this.openQueryParamsSubscription();\n      });\n  }\n\n  private getSortStateFromSortString(sortString?: string): SortState | null {\n    const splitString = sortString && sortString.split(',');\n    if (splitString && splitString?.length > 1) {\n      return {\n        isSorting: true,\n        state: {\n          name: splitString[0],\n          direction: splitString[1] as Direction,\n        },\n      };\n    }\n\n    return null;\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    supportedDocumentenApiFeatures: supportedDocumentenApiFeatures$ | async,\n    pagination: pagination$ | async,\n    sortState: sortState$ | async,\n    uploadFields: uploadFields$ | async,\n    defaultValues: defaultValues$ | async,\n    hideFields: hideFields$ | 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      [initialSortState]=\"obs.sortState\"\n      [loading]=\"obs.loading\"\n      [pagination]=\"obs.pagination\"\n      [paginatorConfig]=\"paginatorConfig\"\n      paginationIdentifier=\"documentenApi\"\n      (rowClicked)=\"onRowClick($event)\"\n      (sortChanged)=\"\n        obs?.supportedDocumentenApiFeatures?.supportsSortableColumns && onSortChanged($event)\n      \"\n      (paginationClicked)=\"onPaginationClicked($event)\"\n      (paginationSet)=\"onPaginationSet($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        <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    [defaultValues]=\"obs.defaultValues\"\n    [disableAuthor]=\"obs.uploadFields?.auteur?.readonly\"\n    [disableConfidentialityLevel]=\"obs.uploadFields?.vertrouwelijkheidaanduiding?.readonly\"\n    [disableCreationDate]=\"obs.uploadFields?.creatiedatum?.readonly\"\n    [disableDescription]=\"obs.uploadFields?.beschrijving?.readonly\"\n    [disableDocumentTitle]=\"obs.uploadFields?.titel?.readonly\"\n    [disableDocumentType]=\"obs.uploadFields?.informatieobjecttype?.readonly\"\n    [disableFilename]=\"obs.uploadFields?.bestandsnaam?.readonly\"\n    [disableLanguage]=\"obs.uploadFields?.taal?.readonly\"\n    [disableStatus]=\"obs.uploadFields?.status?.readonly\"\n    [hideFields]=\"obs.hideFields\"\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  @if (data.item[data.key]) {\n    {{ 'document.' + data.item[data.key] | translate }}\n  } @else {\n    -\n  }\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"]}