@valtimo/zgw 12.11.0 → 12.14.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/modules/documenten-api/components/documenten-api-documents/documenten-api-documents.component.mjs +6 -8
- package/esm2022/lib/modules/zaakdetails/components/document-objecten-api-sync/document-objecten-api-sync.component.mjs +2 -2
- package/fesm2022/valtimo-zgw.mjs +6 -8
- package/fesm2022/valtimo-zgw.mjs.map +1 -1
- package/lib/modules/documenten-api/components/documenten-api-documents/documenten-api-documents.component.d.ts +1 -1
- package/lib/modules/documenten-api/components/documenten-api-documents/documenten-api-documents.component.d.ts.map +1 -1
- package/package.json +1 -1
|
@@ -38,9 +38,6 @@ import * as i9 from "@valtimo/access-control";
|
|
|
38
38
|
import * as i10 from "@angular/common";
|
|
39
39
|
import * as i11 from "@valtimo/components";
|
|
40
40
|
export class DossierDetailTabDocumentenApiDocumentsComponent {
|
|
41
|
-
get sortState$() {
|
|
42
|
-
return this._sort$.pipe(map(sortValue => this.getSortStateFromSortString(sortValue?.sort)));
|
|
43
|
-
}
|
|
44
41
|
constructor(route, router, uploadProviderService, downloadService, translateService, configService, userProviderService, iconService, documentenApiDocumentService, documentenApiColumnService, documentenApiVersionService, permissionService) {
|
|
45
42
|
this.route = route;
|
|
46
43
|
this.router = router;
|
|
@@ -63,7 +60,9 @@ export class DossierDetailTabDocumentenApiDocumentsComponent {
|
|
|
63
60
|
this._sort$,
|
|
64
61
|
])), map(([columns, supportedDocumentenApiFeatures, sort]) => {
|
|
65
62
|
const defaultSortColumn = columns.find((column) => !!column.defaultSort);
|
|
66
|
-
if (!!defaultSortColumn &&
|
|
63
|
+
if (!!defaultSortColumn &&
|
|
64
|
+
!sort?.sort &&
|
|
65
|
+
supportedDocumentenApiFeatures.supportsSortableColumns) {
|
|
67
66
|
this._sort$.next({ sort: `${defaultSortColumn.key},${defaultSortColumn.defaultSort}` });
|
|
68
67
|
}
|
|
69
68
|
return columns.map((column) => ({
|
|
@@ -77,9 +76,7 @@ export class DossierDetailTabDocumentenApiDocumentsComponent {
|
|
|
77
76
|
...(column.key === DOCUMENTEN_COLUMN_KEYS.CREATIEDATUM && { format: 'DD-MM-YYYY' }),
|
|
78
77
|
sortable: column.sortable && supportedDocumentenApiFeatures.supportsSortableColumns,
|
|
79
78
|
}));
|
|
80
|
-
}), tap(() =>
|
|
81
|
-
this.fieldsLoading$.next(false);
|
|
82
|
-
}));
|
|
79
|
+
}), tap(() => this.fieldsLoading$.next(false)));
|
|
83
80
|
this.actionItems = [
|
|
84
81
|
{
|
|
85
82
|
label: 'document.download',
|
|
@@ -123,6 +120,7 @@ export class DossierDetailTabDocumentenApiDocumentsComponent {
|
|
|
123
120
|
...DEFAULT_PAGINATOR_CONFIG,
|
|
124
121
|
itemsPerPageOptions: [5, 10, 20, 50, 100],
|
|
125
122
|
};
|
|
123
|
+
this.sortState$ = this._sort$.pipe(filter(sortValue => !!sortValue?.sort), map(sortValue => this.getSortStateFromSortString(sortValue?.sort)));
|
|
126
124
|
this.uploadFields$ = this.documentId$.pipe(switchMap(documentId => this.documentenApiDocumentService.getPrefilledUploadFields(documentId)), map(uploadFields => uploadFields.reduce((acc, curr) => ({
|
|
127
125
|
...acc,
|
|
128
126
|
[curr.key]: {
|
|
@@ -442,4 +440,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
442
440
|
type: ViewChild,
|
|
443
441
|
args: ['translationTemplate']
|
|
444
442
|
}] } });
|
|
445
|
-
//# 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 {\n  CAN_CREATE_RESOURCE_PERMISSION,\n  CAN_DELETE_RESOURCE_PERMISSION,\n  CAN_MODIFY_RESOURCE_PERMISSION,\n  CAN_VIEW_RESOURCE_PERMISSION,\n  DownloadService,\n  RESOURCE_PERMISSION_RESOURCE,\n  UploadProviderService,\n} 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';\nimport {PermissionRequest, PermissionService} from '@valtimo/access-control';\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      disabledCallback: this.downloadDisabled.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      disabledCallback: this.deleteDisabled.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> =\n    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  public readonly enablePbacDocumentenApiDocuments$: Observable<boolean> =\n    this.configService.getFeatureToggleObservable('enablePbacDocumentenApiDocuments');\n\n  public filePermissions: {\n    [fileId: string]: {canView: boolean; canModify: boolean; canDelete: boolean};\n  } = {};\n\n  public readonly canCreateResource$: Observable<boolean> = this.documentId$.pipe(\n    switchMap(documentId =>\n      this.getPermission(CAN_CREATE_RESOURCE_PERMISSION, {\n        resource: RESOURCE_PERMISSION_RESOURCE.jsonSchemaDocument,\n        identifier: documentId,\n      })\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    private readonly permissionService: PermissionService\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    this.registerPermissionSubscriptions();\n  }\n\n  public registerPermissionSubscriptions(): void {\n    this._subscriptions.add(\n      this.relatedFiles$\n        .pipe(\n          switchMap(files =>\n            combineLatest({\n              files: of(files),\n              canView: this.getPermissions(files, CAN_VIEW_RESOURCE_PERMISSION),\n              canModify: this.getPermissions(files, CAN_MODIFY_RESOURCE_PERMISSION),\n              canDelete: this.getPermissions(files, CAN_DELETE_RESOURCE_PERMISSION),\n            })\n          )\n        )\n        .subscribe(permissions =>\n          permissions.files.map(\n            file =>\n              (this.filePermissions[file.fileId] = {\n                canView: permissions.canView[file.fileId],\n                canModify: permissions.canModify[file.fileId],\n                canDelete: permissions.canDelete[file.fileId],\n              })\n          )\n        )\n    );\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    if (this.filePermissions[event.fileId]?.canView) {\n      this.downloadDocument(event, false);\n    }\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 downloadDisabled(file: DocumentenApiRelatedFile): boolean {\n    return !this.filePermissions[file.fileId]?.canView;\n  }\n\n  private editDisabled(file: DocumentenApiRelatedFile): boolean {\n    return (\n      (!this.supportedDocumentenApiFeatures$.value.supportsUpdatingDefinitiveDocument &&\n        file.status === 'definitief') ||\n      !this.filePermissions[file.fileId]?.canModify\n    );\n  }\n\n  private deleteDisabled(file: DocumentenApiRelatedFile): boolean {\n    return !this.filePermissions[file.fileId]?.canDelete;\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  private getPermissions(\n    files: DocumentenApiRelatedFile[],\n    permissionRequest: PermissionRequest\n  ): Observable<{\n    [key: string]: boolean;\n  }> {\n    return combineLatest(\n      files.map(file =>\n        this.getPermission(permissionRequest, {\n          resource: RESOURCE_PERMISSION_RESOURCE.resourcePermission,\n          identifier: file.fileId,\n        }).pipe(map(available => ({[file.fileId]: available})))\n      )\n    ).pipe(\n      map(permissions => permissions.reduce((acc, permission) => ({...acc, ...permission}), {}))\n    );\n  }\n\n  private getPermission(permissionRequest: PermissionRequest, context?: any): Observable<boolean> {\n    return this.enablePbacDocumentenApiDocuments$.pipe(\n      switchMap(enabled => {\n        if (!enabled) {\n          return of(true);\n        }\n        return this.permissionService.requestPermission(permissionRequest, context);\n      })\n    );\n  }\n}\n","<!--\n  ~ Copyright 2015-2024 Ritense BV, the Netherlands.\n  ~\n  ~ Licensed under EUPL, Version 1.2 (the \"License\");\n  ~ you may not use this file except in compliance with the License.\n  ~ You may obtain a copy of the License at\n  ~\n  ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n  ~\n  ~ Unless required by applicable law or agreed to in writing, software\n  ~ distributed under the License is distributed on an \"AS IS\" basis,\n  ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n  ~ See the License for the specific language governing permissions and\n  ~ limitations under the License.\n  -->\n<div\n  class=\"carbon-document-table-wrapper\"\n  *ngIf=\"{\n    loading: loading$ | async,\n    fieldsLoading: fieldsLoading$ | async,\n    uploading: uploading$ | async,\n    relatedFiles: relatedFiles$ | async,\n    fields: fields$ | async,\n    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 #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]=\"\n      (uploadProcessLinkedSet && !uploadProcessLinked) ||\n      showZaakLinkWarning ||\n      disabled ||\n      (canCreateResource$ | async) === false\n    \"\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"]}
|
|
443
|
+
//# 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 {\n  CAN_CREATE_RESOURCE_PERMISSION,\n  CAN_DELETE_RESOURCE_PERMISSION,\n  CAN_MODIFY_RESOURCE_PERMISSION,\n  CAN_VIEW_RESOURCE_PERMISSION,\n  DownloadService,\n  RESOURCE_PERMISSION_RESOURCE,\n  UploadProviderService,\n} 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';\nimport {PermissionRequest, PermissionService} from '@valtimo/access-control';\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 (\n        !!defaultSortColumn &&\n        !sort?.sort &&\n        supportedDocumentenApiFeatures.supportsSortableColumns\n      ) {\n        this._sort$.next({sort: `${defaultSortColumn.key},${defaultSortColumn.defaultSort}`});\n      }\n\n      return columns.map((column: ConfiguredColumn) => ({\n        key: column.key === DOCUMENTEN_COLUMN_KEYS.BESTANDSOMVANG ? 'size' : column.key,\n        label: `zgw.documentColumns.${column.key}`,\n        viewType: !COLUMN_VIEW_TYPES[column.key] ? ViewType.TEXT : COLUMN_VIEW_TYPES[column.key],\n        ...(COLUMN_VIEW_TYPES[column.key] === ViewType.TEMPLATE && {\n          template: this.translationTemplate,\n          templateData: {key: column.key},\n        }),\n        ...(column.key === DOCUMENTEN_COLUMN_KEYS.CREATIEDATUM && {format: 'DD-MM-YYYY'}),\n        sortable: column.sortable && supportedDocumentenApiFeatures.supportsSortableColumns,\n      }));\n    }),\n    tap(() => this.fieldsLoading$.next(false))\n  );\n  public document: DocumentenApiRelatedFile;\n  public actionItems: ActionItem[] = [\n    {\n      label: 'document.download',\n      callback: this.onDownloadActionClick.bind(this),\n      disabledCallback: this.downloadDisabled.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      disabledCallback: this.deleteDisabled.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 sortState$: Observable<SortState | null> = this._sort$.pipe(\n    filter(sortValue => !!sortValue?.sort),\n    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> =\n    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  public readonly enablePbacDocumentenApiDocuments$: Observable<boolean> =\n    this.configService.getFeatureToggleObservable('enablePbacDocumentenApiDocuments');\n\n  public filePermissions: {\n    [fileId: string]: {canView: boolean; canModify: boolean; canDelete: boolean};\n  } = {};\n\n  public readonly canCreateResource$: Observable<boolean> = this.documentId$.pipe(\n    switchMap(documentId =>\n      this.getPermission(CAN_CREATE_RESOURCE_PERMISSION, {\n        resource: RESOURCE_PERMISSION_RESOURCE.jsonSchemaDocument,\n        identifier: documentId,\n      })\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    private readonly permissionService: PermissionService\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    this.registerPermissionSubscriptions();\n  }\n\n  public registerPermissionSubscriptions(): void {\n    this._subscriptions.add(\n      this.relatedFiles$\n        .pipe(\n          switchMap(files =>\n            combineLatest({\n              files: of(files),\n              canView: this.getPermissions(files, CAN_VIEW_RESOURCE_PERMISSION),\n              canModify: this.getPermissions(files, CAN_MODIFY_RESOURCE_PERMISSION),\n              canDelete: this.getPermissions(files, CAN_DELETE_RESOURCE_PERMISSION),\n            })\n          )\n        )\n        .subscribe(permissions =>\n          permissions.files.map(\n            file =>\n              (this.filePermissions[file.fileId] = {\n                canView: permissions.canView[file.fileId],\n                canModify: permissions.canModify[file.fileId],\n                canDelete: permissions.canDelete[file.fileId],\n              })\n          )\n        )\n    );\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    if (this.filePermissions[event.fileId]?.canView) {\n      this.downloadDocument(event, false);\n    }\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 downloadDisabled(file: DocumentenApiRelatedFile): boolean {\n    return !this.filePermissions[file.fileId]?.canView;\n  }\n\n  private editDisabled(file: DocumentenApiRelatedFile): boolean {\n    return (\n      (!this.supportedDocumentenApiFeatures$.value.supportsUpdatingDefinitiveDocument &&\n        file.status === 'definitief') ||\n      !this.filePermissions[file.fileId]?.canModify\n    );\n  }\n\n  private deleteDisabled(file: DocumentenApiRelatedFile): boolean {\n    return !this.filePermissions[file.fileId]?.canDelete;\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  private getPermissions(\n    files: DocumentenApiRelatedFile[],\n    permissionRequest: PermissionRequest\n  ): Observable<{\n    [key: string]: boolean;\n  }> {\n    return combineLatest(\n      files.map(file =>\n        this.getPermission(permissionRequest, {\n          resource: RESOURCE_PERMISSION_RESOURCE.resourcePermission,\n          identifier: file.fileId,\n        }).pipe(map(available => ({[file.fileId]: available})))\n      )\n    ).pipe(\n      map(permissions => permissions.reduce((acc, permission) => ({...acc, ...permission}), {}))\n    );\n  }\n\n  private getPermission(permissionRequest: PermissionRequest, context?: any): Observable<boolean> {\n    return this.enablePbacDocumentenApiDocuments$.pipe(\n      switchMap(enabled => {\n        if (!enabled) {\n          return of(true);\n        }\n        return this.permissionService.requestPermission(permissionRequest, context);\n      })\n    );\n  }\n}\n","<!--\n  ~ Copyright 2015-2024 Ritense BV, the Netherlands.\n  ~\n  ~ Licensed under EUPL, Version 1.2 (the \"License\");\n  ~ you may not use this file except in compliance with the License.\n  ~ You may obtain a copy of the License at\n  ~\n  ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n  ~\n  ~ Unless required by applicable law or agreed to in writing, software\n  ~ distributed under the License is distributed on an \"AS IS\" basis,\n  ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n  ~ See the License for the specific language governing permissions and\n  ~ limitations under the License.\n  -->\n<div\n  class=\"carbon-document-table-wrapper\"\n  *ngIf=\"{\n    loading: loading$ | async,\n    fieldsLoading: fieldsLoading$ | async,\n    uploading: uploading$ | async,\n    relatedFiles: relatedFiles$ | async,\n    fields: fields$ | async,\n    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 #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]=\"\n      (uploadProcessLinkedSet && !uploadProcessLinked) ||\n      showZaakLinkWarning ||\n      disabled ||\n      (canCreateResource$ | async) === false\n    \"\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"]}
|
|
@@ -105,7 +105,7 @@ export class DocumentObjectenApiSyncComponent {
|
|
|
105
105
|
this.modalShowing$.next(false);
|
|
106
106
|
}
|
|
107
107
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DocumentObjectenApiSyncComponent, deps: [{ token: i1.ActivatedRoute }, { token: i2.DocumentObjectenApiSyncService }, { token: i3.CdsThemeService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
108
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: DocumentObjectenApiSyncComponent, isStandalone: true, selector: "valtimo-document-objecten-api-sync", 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\n<div class=\"input-group mt-4 mb-2 align-items-center\">\n <div>\n <h2>{{ 'zaakdetails.title' | translate }}</h2>\n </div>\n</div>\n\n<ng-container\n *ngIf=\"{\n loading: loading$ | async,\n documentObjectenApiSync: documentObjectenApiSync$ | async,\n } as obs\"\n>\n <ng-container *ngIf=\"obs.loading === false; else loading\">\n <ng-container *ngIf=\"obs.documentObjectenApiSync; else addSync\">\n <div class=\"card card-border card-contrast\">\n <div class=\"card-header card-header-contrast card-header-featured\">\n <div>\n {{ obs.documentObjectenApiSync.objectManagementConfigurationTitle || '-' }}\n </div>\n <div class=\"controls\">\n <button class=\"btn btn-danger ml-3\" (click)=\"showModal()\">\n <i class=\"icon mdi mdi-pencil\"></i>\n </button>\n <button class=\"btn btn-danger ml-3\" (click)=\"remove()\">\n <i class=\"icon mdi mdi-delete\"></i>\n </button>\n </div>\n </div>\n <div class=\"card-body\">\n <div class=\"row pt-3 mt-1\">\n <div class=\"col-3\">\n <strong>{{ 'zaakdetails.enabled' | translate }}</strong>\n </div>\n <div class=\"col-3\">\n {{\n obs.documentObjectenApiSync?.enabled\n ? ('zaakdetails.yes' | translate)\n : ('zaakdetails.no' | translate)\n }}\n </div>\n </div>\n <div class=\"row pt-3 mt-1\">\n <div class=\"col-3\">\n <strong>{{ 'zaakdetails.objectManagementConfigurationTitle' | translate }}</strong>\n </div>\n <div class=\"col-3\">\n {{ obs.documentObjectenApiSync.objectManagementConfigurationTitle || '-' }}\n </div>\n </div>\n </div>\n </div>\n </ng-container>\n </ng-container>\n <ng-container *ngTemplateOutlet=\"modal; context: {obs: obs}\"></ng-container>\n</ng-container>\n\n<ng-template #addSync>\n <div class=\"text-right mt-5\">\n <button class=\"btn btn-primary\" (click)=\"showModal()\">\n <i class=\"icon mdi mdi-plus mr-1\"></i>{{ 'zaakdetails.submitButton' | translate }}\n </button>\n </div>\n</ng-template>\n\n<ng-template #modal let-obs=\"obs\">\n <cds-modal\n valtimoCdsModal\n [title]=\"'zaakdetails.editModal.title' | translate\"\n [open]=\"modalShowing$ | async\"\n [showFooter]=\"true\"\n >\n <cds-modal-header [showCloseButton]=\"true\" (closeSelect)=\"onModalClose()\">\n <h3 cdsModalHeaderHeading>\n {{ 'zaakdetails.editModal.title' | translate }}\n </h3>\n </cds-modal-header>\n\n <section cdsModalContent>\n <form [formGroup]=\"formGroup\">\n <v-select\n *ngIf=\"objectManagementConfigurationItems$ | async as objectManagementConfigurations\"\n [appendInline]=\"false\"\n [dropUp]=\"false\"\n [items]=\"objectManagementConfigurations\"\n [defaultSelectionId]=\"objectManagementConfigurationId.getRawValue()\"\n [placeholder]=\"\n 'zaakdetails.editModal.objectManagementConfigurationPlaceholder' | translate\n \"\n [title]=\"'zaakdetails.editModal.objectManagementConfiguration' | translate\"\n [disabled]=\"false\"\n [margin]=\"true\"\n [required]=\"true\"\n name=\"objectManagementConfigurationId\"\n [carbonTheme]=\"currentTheme$ | async\"\n (selectedChange)=\"configSelected($event)\"\n ></v-select>\n\n <cds-checkbox formControlName=\"enabled\"\n >{{ 'zaakdetails.editModal.enabled' | translate }}\n </cds-checkbox>\n </form>\n </section>\n\n <cds-modal-footer>\n <ng-container *ngTemplateOutlet=\"buttonsFooterModal; context: {obs: obs}\"></ng-container>\n </cds-modal-footer>\n </cds-modal>\n</ng-template>\n\n<ng-template #buttonsFooterModal let-obs=\"obs\">\n <button cdsButton=\"secondary\" (click)=\"onModalClose()\" [disabled]=\"false\">\n {{ 'interface.cancel' | translate }}\n </button>\n\n <button cdsButton=\"primary\" [disabled]=\"!formGroup.valid\" (click)=\"submit()\">\n {{ 'searchFieldsOverview.submit' | translate }}\n </button>\n</ng-template>\n\n<ng-template #loading>\n <div class=\"mb-8\">\n <valtimo-spinner></valtimo-spinner>\n </div>\n</ng-template>\n\n<ng-template #noConfigAvailable>\n <div class=\"mb-8\">\n <h4>{{ 'zaakdetails.error.configNotFound' | translate }}</h4>\n </div>\n</ng-template>\n", styles: [".card-header,.setting-row{display:flex;flex-direction:row;justify-content:space-between;align-items:center}.controls{display:flex;align-items:center}\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: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "pipe", type: i4.AsyncPipe, name: "async" }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i5.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i5.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i6.TranslatePipe, name: "translate" }, { kind: "ngmodule", type: SpinnerModule }, { kind: "component", type: i3.SpinnerComponent, selector: "valtimo-spinner", inputs: ["useBootstrapSpinner", "name", "type", "size", "color", "bdColor", "fullScreen", "noMarginTop"] }, { kind: "ngmodule", type: FormModule }, { kind: "ngmodule", type: InputModule }, { kind: "ngmodule", type: SelectModule }, { kind: "component", type: i3.SelectComponent, selector: "v-select", inputs: ["items", "defaultSelection", "defaultSelectionId", "defaultSelectionIds", "disabled", "dropUp", "multiple", "margin", "widthInPx", "notFoundText", "clearAllText", "clearText", "name", "title", "titleTranslationKey", "clearSelectionSubject$", "tooltip", "required", "loading", "loadingText", "placeholder", "smallMargin", "carbonTheme", "appendInline", "dataTestId"], outputs: ["selectedChange"] }, { kind: "ngmodule", type: ValtimoCdsModalDirectiveModule }, { kind: "directive", type: i3.ValtimoCdsModalDirective, selector: "[valtimoCdsModal]" }, { kind: "ngmodule", type: CheckboxModule }, { kind: "component", type: i7.Checkbox, selector: "cds-checkbox, ibm-checkbox", inputs: ["disabled", "skeleton", "hideLabel", "name", "id", "required", "value", "ariaLabel", "ariaLabelledby", "indeterminate", "checked"], outputs: ["click", "checkedChange", "indeterminateChange"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i5.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i5.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "ngmodule", type: ButtonModule }, { kind: "directive", type: i7.Button, selector: "[cdsButton], [ibmButton]", inputs: ["ibmButton", "cdsButton", "size", "skeleton", "iconOnly", "isExpressive"] }, { kind: "ngmodule", type: ModalModule }, { kind: "component", type: i7.Modal, selector: "cds-modal, ibm-modal", inputs: ["size", "theme", "ariaLabel", "open", "trigger", "hasScrollingContent"], outputs: ["overlaySelected", "close"] }, { kind: "component", type: i7.ModalHeader, selector: "cds-modal-header, ibm-modal-header", inputs: ["theme", "closeLabel", "showCloseButton"], outputs: ["closeSelect"] }, { kind: "component", type: i7.ModalFooter, selector: "cds-modal-footer, ibm-modal-footer" }, { kind: "directive", type: i7.ModalContent, selector: "[cdsModalContent], [ibmModalContent]", inputs: ["hasForm"] }, { kind: "directive", type: i7.ModalHeaderHeading, selector: "[cdsModalHeaderHeading], [ibmModalHeaderHeading]" }] }); }
|
|
108
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: DocumentObjectenApiSyncComponent, isStandalone: true, selector: "valtimo-document-objecten-api-sync", 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\n<div class=\"input-group mt-4 mb-2 align-items-center\">\n <div>\n <h2>{{ 'zaakdetails.title' | translate }}</h2>\n </div>\n</div>\n\n<ng-container\n *ngIf=\"{\n loading: loading$ | async,\n documentObjectenApiSync: documentObjectenApiSync$ | async,\n } as obs\"\n>\n <ng-container *ngIf=\"obs.loading === false; else loading\">\n <ng-container *ngIf=\"obs.documentObjectenApiSync; else addSync\">\n <div class=\"card card-border card-contrast\">\n <div class=\"card-header card-header-contrast card-header-featured\">\n <div>\n {{ obs.documentObjectenApiSync.objectManagementConfigurationTitle || '-' }}\n </div>\n <div class=\"controls\">\n <button class=\"btn btn-danger ml-3\" (click)=\"showModal()\">\n <i class=\"icon mdi mdi-pencil\"></i>\n </button>\n <button class=\"btn btn-danger ml-3\" (click)=\"remove()\">\n <i class=\"icon mdi mdi-delete\"></i>\n </button>\n </div>\n </div>\n <div class=\"card-body\">\n <div class=\"row pt-3 mt-1\">\n <div class=\"col-3\">\n <strong>{{ 'zaakdetails.enabled' | translate }}</strong>\n </div>\n <div class=\"col-3\">\n {{\n obs.documentObjectenApiSync?.enabled\n ? ('zaakdetails.yes' | translate)\n : ('zaakdetails.no' | translate)\n }}\n </div>\n </div>\n <div class=\"row pt-3 mt-1\">\n <div class=\"col-3\">\n <strong>{{ 'zaakdetails.objectManagementConfigurationTitle' | translate }}</strong>\n </div>\n <div class=\"col-3\">\n {{ obs.documentObjectenApiSync.objectManagementConfigurationTitle || '-' }}\n </div>\n </div>\n </div>\n </div>\n </ng-container>\n </ng-container>\n <ng-container *ngTemplateOutlet=\"modal; context: {obs: obs}\"></ng-container>\n</ng-container>\n\n<ng-template #addSync>\n <div class=\"text-right mt-5\">\n <button class=\"btn btn-primary\" (click)=\"showModal()\">\n <i class=\"icon mdi mdi-plus mr-1\"></i>{{ 'zaakdetails.submitButton' | translate }}\n </button>\n </div>\n</ng-template>\n\n<ng-template #modal let-obs=\"obs\">\n <cds-modal\n valtimoCdsModal\n [title]=\"'zaakdetails.editModal.title' | translate\"\n [open]=\"modalShowing$ | async\"\n [showFooter]=\"true\"\n >\n <cds-modal-header [showCloseButton]=\"true\" (closeSelect)=\"onModalClose()\">\n <h3 cdsModalHeaderHeading>\n {{ 'zaakdetails.editModal.title' | translate }}\n </h3>\n </cds-modal-header>\n\n <section cdsModalContent>\n <form [formGroup]=\"formGroup\">\n <v-select\n *ngIf=\"objectManagementConfigurationItems$ | async as objectManagementConfigurations\"\n [appendInline]=\"false\"\n [dropUp]=\"false\"\n [items]=\"objectManagementConfigurations\"\n [defaultSelectionId]=\"objectManagementConfigurationId.getRawValue()\"\n [placeholder]=\"\n 'zaakdetails.editModal.objectManagementConfigurationPlaceholder' | translate\n \"\n [title]=\"'zaakdetails.editModal.objectManagementConfiguration' | translate\"\n [disabled]=\"false\"\n [margin]=\"true\"\n [required]=\"true\"\n name=\"objectManagementConfigurationId\"\n [carbonTheme]=\"currentTheme$ | async\"\n (selectedChange)=\"configSelected($event)\"\n ></v-select>\n\n <cds-checkbox formControlName=\"enabled\"\n >{{ 'zaakdetails.editModal.enabled' | translate }}\n </cds-checkbox>\n </form>\n </section>\n\n <cds-modal-footer>\n <ng-container *ngTemplateOutlet=\"buttonsFooterModal; context: {obs: obs}\"></ng-container>\n </cds-modal-footer>\n </cds-modal>\n</ng-template>\n\n<ng-template #buttonsFooterModal let-obs=\"obs\">\n <button cdsButton=\"secondary\" (click)=\"onModalClose()\" [disabled]=\"false\">\n {{ 'interface.cancel' | translate }}\n </button>\n\n <button cdsButton=\"primary\" [disabled]=\"!formGroup.valid\" (click)=\"submit()\">\n {{ 'searchFieldsOverview.submit' | translate }}\n </button>\n</ng-template>\n\n<ng-template #loading>\n <div class=\"mb-8\">\n <valtimo-spinner></valtimo-spinner>\n </div>\n</ng-template>\n\n<ng-template #noConfigAvailable>\n <div class=\"mb-8\">\n <h4>{{ 'zaakdetails.error.configNotFound' | translate }}</h4>\n </div>\n</ng-template>\n", styles: [".card-header,.setting-row{display:flex;flex-direction:row;justify-content:space-between;align-items:center}.controls{display:flex;align-items:center}\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: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "pipe", type: i4.AsyncPipe, name: "async" }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i5.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i5.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i6.TranslatePipe, name: "translate" }, { kind: "ngmodule", type: SpinnerModule }, { kind: "component", type: i3.SpinnerComponent, selector: "valtimo-spinner", inputs: ["useBootstrapSpinner", "name", "type", "size", "color", "bdColor", "fullScreen", "noMarginTop"] }, { kind: "ngmodule", type: FormModule }, { kind: "ngmodule", type: InputModule }, { kind: "ngmodule", type: SelectModule }, { kind: "component", type: i3.SelectComponent, selector: "v-select", inputs: ["items", "defaultSelection", "defaultSelectionId", "defaultSelectionIds", "disabled", "dropUp", "multiple", "margin", "widthInPx", "notFoundText", "clearAllText", "clearText", "name", "title", "titleTranslationKey", "clearSelectionSubject$", "tooltip", "required", "loading", "loadingText", "placeholder", "smallMargin", "carbonTheme", "appendInline", "dataTestId"], outputs: ["selectedChange"] }, { kind: "ngmodule", type: ValtimoCdsModalDirectiveModule }, { kind: "directive", type: i3.ValtimoCdsModalDirective, selector: "[valtimoCdsModal]", inputs: ["enableOverflow"] }, { kind: "ngmodule", type: CheckboxModule }, { kind: "component", type: i7.Checkbox, selector: "cds-checkbox, ibm-checkbox", inputs: ["disabled", "skeleton", "hideLabel", "name", "id", "required", "value", "ariaLabel", "ariaLabelledby", "indeterminate", "checked"], outputs: ["click", "checkedChange", "indeterminateChange"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i5.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i5.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "ngmodule", type: ButtonModule }, { kind: "directive", type: i7.Button, selector: "[cdsButton], [ibmButton]", inputs: ["ibmButton", "cdsButton", "size", "skeleton", "iconOnly", "isExpressive"] }, { kind: "ngmodule", type: ModalModule }, { kind: "component", type: i7.Modal, selector: "cds-modal, ibm-modal", inputs: ["size", "theme", "ariaLabel", "open", "trigger", "hasScrollingContent"], outputs: ["overlaySelected", "close"] }, { kind: "component", type: i7.ModalHeader, selector: "cds-modal-header, ibm-modal-header", inputs: ["theme", "closeLabel", "showCloseButton"], outputs: ["closeSelect"] }, { kind: "component", type: i7.ModalFooter, selector: "cds-modal-footer, ibm-modal-footer" }, { kind: "directive", type: i7.ModalContent, selector: "[cdsModalContent], [ibmModalContent]", inputs: ["hasForm"] }, { kind: "directive", type: i7.ModalHeaderHeading, selector: "[cdsModalHeaderHeading], [ibmModalHeaderHeading]" }] }); }
|
|
109
109
|
}
|
|
110
110
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DocumentObjectenApiSyncComponent, decorators: [{
|
|
111
111
|
type: Component,
|
|
@@ -124,4 +124,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
124
124
|
ModalModule,
|
|
125
125
|
], 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<div class=\"input-group mt-4 mb-2 align-items-center\">\n <div>\n <h2>{{ 'zaakdetails.title' | translate }}</h2>\n </div>\n</div>\n\n<ng-container\n *ngIf=\"{\n loading: loading$ | async,\n documentObjectenApiSync: documentObjectenApiSync$ | async,\n } as obs\"\n>\n <ng-container *ngIf=\"obs.loading === false; else loading\">\n <ng-container *ngIf=\"obs.documentObjectenApiSync; else addSync\">\n <div class=\"card card-border card-contrast\">\n <div class=\"card-header card-header-contrast card-header-featured\">\n <div>\n {{ obs.documentObjectenApiSync.objectManagementConfigurationTitle || '-' }}\n </div>\n <div class=\"controls\">\n <button class=\"btn btn-danger ml-3\" (click)=\"showModal()\">\n <i class=\"icon mdi mdi-pencil\"></i>\n </button>\n <button class=\"btn btn-danger ml-3\" (click)=\"remove()\">\n <i class=\"icon mdi mdi-delete\"></i>\n </button>\n </div>\n </div>\n <div class=\"card-body\">\n <div class=\"row pt-3 mt-1\">\n <div class=\"col-3\">\n <strong>{{ 'zaakdetails.enabled' | translate }}</strong>\n </div>\n <div class=\"col-3\">\n {{\n obs.documentObjectenApiSync?.enabled\n ? ('zaakdetails.yes' | translate)\n : ('zaakdetails.no' | translate)\n }}\n </div>\n </div>\n <div class=\"row pt-3 mt-1\">\n <div class=\"col-3\">\n <strong>{{ 'zaakdetails.objectManagementConfigurationTitle' | translate }}</strong>\n </div>\n <div class=\"col-3\">\n {{ obs.documentObjectenApiSync.objectManagementConfigurationTitle || '-' }}\n </div>\n </div>\n </div>\n </div>\n </ng-container>\n </ng-container>\n <ng-container *ngTemplateOutlet=\"modal; context: {obs: obs}\"></ng-container>\n</ng-container>\n\n<ng-template #addSync>\n <div class=\"text-right mt-5\">\n <button class=\"btn btn-primary\" (click)=\"showModal()\">\n <i class=\"icon mdi mdi-plus mr-1\"></i>{{ 'zaakdetails.submitButton' | translate }}\n </button>\n </div>\n</ng-template>\n\n<ng-template #modal let-obs=\"obs\">\n <cds-modal\n valtimoCdsModal\n [title]=\"'zaakdetails.editModal.title' | translate\"\n [open]=\"modalShowing$ | async\"\n [showFooter]=\"true\"\n >\n <cds-modal-header [showCloseButton]=\"true\" (closeSelect)=\"onModalClose()\">\n <h3 cdsModalHeaderHeading>\n {{ 'zaakdetails.editModal.title' | translate }}\n </h3>\n </cds-modal-header>\n\n <section cdsModalContent>\n <form [formGroup]=\"formGroup\">\n <v-select\n *ngIf=\"objectManagementConfigurationItems$ | async as objectManagementConfigurations\"\n [appendInline]=\"false\"\n [dropUp]=\"false\"\n [items]=\"objectManagementConfigurations\"\n [defaultSelectionId]=\"objectManagementConfigurationId.getRawValue()\"\n [placeholder]=\"\n 'zaakdetails.editModal.objectManagementConfigurationPlaceholder' | translate\n \"\n [title]=\"'zaakdetails.editModal.objectManagementConfiguration' | translate\"\n [disabled]=\"false\"\n [margin]=\"true\"\n [required]=\"true\"\n name=\"objectManagementConfigurationId\"\n [carbonTheme]=\"currentTheme$ | async\"\n (selectedChange)=\"configSelected($event)\"\n ></v-select>\n\n <cds-checkbox formControlName=\"enabled\"\n >{{ 'zaakdetails.editModal.enabled' | translate }}\n </cds-checkbox>\n </form>\n </section>\n\n <cds-modal-footer>\n <ng-container *ngTemplateOutlet=\"buttonsFooterModal; context: {obs: obs}\"></ng-container>\n </cds-modal-footer>\n </cds-modal>\n</ng-template>\n\n<ng-template #buttonsFooterModal let-obs=\"obs\">\n <button cdsButton=\"secondary\" (click)=\"onModalClose()\" [disabled]=\"false\">\n {{ 'interface.cancel' | translate }}\n </button>\n\n <button cdsButton=\"primary\" [disabled]=\"!formGroup.valid\" (click)=\"submit()\">\n {{ 'searchFieldsOverview.submit' | translate }}\n </button>\n</ng-template>\n\n<ng-template #loading>\n <div class=\"mb-8\">\n <valtimo-spinner></valtimo-spinner>\n </div>\n</ng-template>\n\n<ng-template #noConfigAvailable>\n <div class=\"mb-8\">\n <h4>{{ 'zaakdetails.error.configNotFound' | translate }}</h4>\n </div>\n</ng-template>\n", styles: [".card-header,.setting-row{display:flex;flex-direction:row;justify-content:space-between;align-items:center}.controls{display:flex;align-items:center}\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"] }]
|
|
126
126
|
}], ctorParameters: () => [{ type: i1.ActivatedRoute }, { type: i2.DocumentObjectenApiSyncService }, { type: i3.CdsThemeService }] });
|
|
127
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"document-objecten-api-sync.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/valtimo/zgw/src/lib/modules/zaakdetails/components/document-objecten-api-sync/document-objecten-api-sync.component.ts","../../../../../../../../../projects/valtimo/zgw/src/lib/modules/zaakdetails/components/document-objecten-api-sync/document-objecten-api-sync.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 {Component, OnInit} from '@angular/core';\nimport {\n  AbstractControl,\n  FormControl,\n  FormGroup,\n  FormsModule,\n  ReactiveFormsModule,\n  Validators,\n} from '@angular/forms';\nimport {ActivatedRoute} from '@angular/router';\nimport {\n  CdsThemeService,\n  FormModule,\n  InputModule,\n  SelectItem,\n  SelectModule,\n  SpinnerModule,\n  ValtimoCdsModalDirectiveModule,\n} from '@valtimo/components';\nimport {TranslateModule} from '@ngx-translate/core';\nimport {BehaviorSubject, map, Observable, switchMap, tap} from 'rxjs';\nimport {CommonModule} from '@angular/common';\nimport {ButtonModule, CheckboxModule, ModalModule} from 'carbon-components-angular';\nimport {DocumentObjectenApiSyncService} from '../../services';\nimport {DocumentObjectenApiSync} from '../../models';\nimport {DocumentDefinition} from '@valtimo/document';\n\n@Component({\n  selector: 'valtimo-document-objecten-api-sync',\n  templateUrl: './document-objecten-api-sync.component.html',\n  styleUrls: ['./document-objecten-api-sync.component.scss'],\n  standalone: true,\n  imports: [\n    CommonModule,\n    FormsModule,\n    TranslateModule,\n    SpinnerModule,\n    FormModule,\n    InputModule,\n    SelectModule,\n    ValtimoCdsModalDirectiveModule,\n    CheckboxModule,\n    ReactiveFormsModule,\n    ButtonModule,\n    ModalModule,\n  ],\n})\nexport class DocumentObjectenApiSyncComponent implements OnInit {\n  public readonly loading$ = new BehaviorSubject<boolean>(true);\n  private readonly documentDefinitionName$: Observable<string> = this.route.params.pipe(\n    map(params => params.name || '')\n  );\n  private readonly documentDefinition$: Observable<DocumentDefinition> =\n    this.documentDefinitionName$.pipe(\n      switchMap(documentDefinitionName =>\n        this.documentObjectenApiSyncService.getDocumentDefinition(documentDefinitionName)\n      )\n    );\n  public readonly documentObjectenApiSync$ = new BehaviorSubject<DocumentObjectenApiSync>(null);\n  public readonly objectManagementConfigurationItems$: Observable<Array<SelectItem>> =\n    this.documentObjectenApiSyncService.getObjectManagementConfigurations().pipe(\n      map(results =>\n        results?.map(configuration => ({\n          id: configuration.id,\n          text: configuration.title,\n        }))\n      )\n    );\n  private readonly modalShowing$ = new BehaviorSubject<boolean>(false);\n  public readonly currentTheme$ = this.cdsThemeService.currentTheme$;\n  public readonly formGroup = new FormGroup({\n    objectManagementConfigurationId: new FormControl('', Validators.required),\n    enabled: new FormControl(true),\n  });\n\n  public get objectManagementConfigurationId(): AbstractControl<string> {\n    return this.formGroup.get('objectManagementConfigurationId');\n  }\n\n  public get enabled(): AbstractControl<boolean> {\n    return this.formGroup.get('enabled');\n  }\n\n  public readonly valid$ = new BehaviorSubject<boolean>(false);\n\n  constructor(\n    private readonly route: ActivatedRoute,\n    private readonly documentObjectenApiSyncService: DocumentObjectenApiSyncService,\n    private readonly cdsThemeService: CdsThemeService\n  ) {}\n\n  public ngOnInit(): void {\n    this.loadDocumentenObjectenApiSync();\n  }\n\n  public loadDocumentenObjectenApiSync(): void {\n    this.documentDefinition$\n      .pipe(\n        switchMap(documentDefinition =>\n          this.documentObjectenApiSyncService.getDocumentObjectenApiSync(\n            documentDefinition.id.name,\n            documentDefinition.id.version\n          )\n        )\n      )\n      .subscribe(documentObjectenApiSync => {\n        this.loading$.next(false);\n        this.configSelected(documentObjectenApiSync?.objectManagementConfigurationId);\n        this.enabled.patchValue(documentObjectenApiSync?.enabled);\n        this.documentObjectenApiSync$.next(documentObjectenApiSync);\n      });\n  }\n\n  public remove(): void {\n    this.documentDefinition$\n      .pipe(\n        switchMap(documentDefinition =>\n          this.documentObjectenApiSyncService.deleteDocumentObjectenApiSync(\n            documentDefinition.id.name,\n            documentDefinition.id.version\n          )\n        ),\n        tap(() => {\n          this.documentObjectenApiSync$.next(null);\n        })\n      )\n      .subscribe();\n  }\n\n  public submit(): void {\n    const formValues = this.formGroup.getRawValue();\n    this.documentDefinition$\n      .pipe(\n        switchMap(documentDefinition =>\n          this.documentObjectenApiSyncService.updateDocumentObjectenApiSync(\n            documentDefinition.id.name,\n            documentDefinition.id.version,\n            {\n              objectManagementConfigurationId: formValues.objectManagementConfigurationId,\n              enabled: formValues.enabled,\n            }\n          )\n        )\n      )\n      .subscribe(() => {\n        this.loadDocumentenObjectenApiSync();\n        this.hideModal();\n      });\n  }\n\n  public onModalClose(): void {\n    this.hideModal();\n  }\n\n  public showModal(): void {\n    this.modalShowing$.next(true);\n  }\n\n  public configSelected(selectedId: string): void {\n    if (!selectedId) {\n      this.objectManagementConfigurationId.patchValue('');\n    } else {\n      this.objectManagementConfigurationId.patchValue(selectedId);\n    }\n  }\n\n  private hideModal(): void {\n    this.modalShowing$.next(false);\n  }\n}\n","<!--\n  ~ Copyright 2015-2024 Ritense BV, the Netherlands.\n  ~\n  ~ Licensed under EUPL, Version 1.2 (the \"License\");\n  ~ you may not use this file except in compliance with the License.\n  ~ You may obtain a copy of the License at\n  ~\n  ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n  ~\n  ~ Unless required by applicable law or agreed to in writing, software\n  ~ distributed under the License is distributed on an \"AS IS\" basis,\n  ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n  ~ See the License for the specific language governing permissions and\n  ~ limitations under the License.\n  -->\n\n<div class=\"input-group mt-4 mb-2 align-items-center\">\n  <div>\n    <h2>{{ 'zaakdetails.title' | translate }}</h2>\n  </div>\n</div>\n\n<ng-container\n  *ngIf=\"{\n    loading: loading$ | async,\n    documentObjectenApiSync: documentObjectenApiSync$ | async,\n  } as obs\"\n>\n  <ng-container *ngIf=\"obs.loading === false; else loading\">\n    <ng-container *ngIf=\"obs.documentObjectenApiSync; else addSync\">\n      <div class=\"card card-border card-contrast\">\n        <div class=\"card-header card-header-contrast card-header-featured\">\n          <div>\n            {{ obs.documentObjectenApiSync.objectManagementConfigurationTitle || '-' }}\n          </div>\n          <div class=\"controls\">\n            <button class=\"btn btn-danger ml-3\" (click)=\"showModal()\">\n              <i class=\"icon mdi mdi-pencil\"></i>\n            </button>\n            <button class=\"btn btn-danger ml-3\" (click)=\"remove()\">\n              <i class=\"icon mdi mdi-delete\"></i>\n            </button>\n          </div>\n        </div>\n        <div class=\"card-body\">\n          <div class=\"row pt-3 mt-1\">\n            <div class=\"col-3\">\n              <strong>{{ 'zaakdetails.enabled' | translate }}</strong>\n            </div>\n            <div class=\"col-3\">\n              {{\n                obs.documentObjectenApiSync?.enabled\n                  ? ('zaakdetails.yes' | translate)\n                  : ('zaakdetails.no' | translate)\n              }}\n            </div>\n          </div>\n          <div class=\"row pt-3 mt-1\">\n            <div class=\"col-3\">\n              <strong>{{ 'zaakdetails.objectManagementConfigurationTitle' | translate }}</strong>\n            </div>\n            <div class=\"col-3\">\n              {{ obs.documentObjectenApiSync.objectManagementConfigurationTitle || '-' }}\n            </div>\n          </div>\n        </div>\n      </div>\n    </ng-container>\n  </ng-container>\n  <ng-container *ngTemplateOutlet=\"modal; context: {obs: obs}\"></ng-container>\n</ng-container>\n\n<ng-template #addSync>\n  <div class=\"text-right mt-5\">\n    <button class=\"btn btn-primary\" (click)=\"showModal()\">\n      <i class=\"icon mdi mdi-plus mr-1\"></i>{{ 'zaakdetails.submitButton' | translate }}\n    </button>\n  </div>\n</ng-template>\n\n<ng-template #modal let-obs=\"obs\">\n  <cds-modal\n    valtimoCdsModal\n    [title]=\"'zaakdetails.editModal.title' | translate\"\n    [open]=\"modalShowing$ | async\"\n    [showFooter]=\"true\"\n  >\n    <cds-modal-header [showCloseButton]=\"true\" (closeSelect)=\"onModalClose()\">\n      <h3 cdsModalHeaderHeading>\n        {{ 'zaakdetails.editModal.title' | translate }}\n      </h3>\n    </cds-modal-header>\n\n    <section cdsModalContent>\n      <form [formGroup]=\"formGroup\">\n        <v-select\n          *ngIf=\"objectManagementConfigurationItems$ | async as objectManagementConfigurations\"\n          [appendInline]=\"false\"\n          [dropUp]=\"false\"\n          [items]=\"objectManagementConfigurations\"\n          [defaultSelectionId]=\"objectManagementConfigurationId.getRawValue()\"\n          [placeholder]=\"\n            'zaakdetails.editModal.objectManagementConfigurationPlaceholder' | translate\n          \"\n          [title]=\"'zaakdetails.editModal.objectManagementConfiguration' | translate\"\n          [disabled]=\"false\"\n          [margin]=\"true\"\n          [required]=\"true\"\n          name=\"objectManagementConfigurationId\"\n          [carbonTheme]=\"currentTheme$ | async\"\n          (selectedChange)=\"configSelected($event)\"\n        ></v-select>\n\n        <cds-checkbox formControlName=\"enabled\"\n          >{{ 'zaakdetails.editModal.enabled' | translate }}\n        </cds-checkbox>\n      </form>\n    </section>\n\n    <cds-modal-footer>\n      <ng-container *ngTemplateOutlet=\"buttonsFooterModal; context: {obs: obs}\"></ng-container>\n    </cds-modal-footer>\n  </cds-modal>\n</ng-template>\n\n<ng-template #buttonsFooterModal let-obs=\"obs\">\n  <button cdsButton=\"secondary\" (click)=\"onModalClose()\" [disabled]=\"false\">\n    {{ 'interface.cancel' | translate }}\n  </button>\n\n  <button cdsButton=\"primary\" [disabled]=\"!formGroup.valid\" (click)=\"submit()\">\n    {{ 'searchFieldsOverview.submit' | translate }}\n  </button>\n</ng-template>\n\n<ng-template #loading>\n  <div class=\"mb-8\">\n    <valtimo-spinner></valtimo-spinner>\n  </div>\n</ng-template>\n\n<ng-template #noConfigAvailable>\n  <div class=\"mb-8\">\n    <h4>{{ 'zaakdetails.error.configNotFound' | translate }}</h4>\n  </div>\n</ng-template>\n"]}
|
|
127
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"document-objecten-api-sync.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/valtimo/zgw/src/lib/modules/zaakdetails/components/document-objecten-api-sync/document-objecten-api-sync.component.ts","../../../../../../../../../projects/valtimo/zgw/src/lib/modules/zaakdetails/components/document-objecten-api-sync/document-objecten-api-sync.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 {Component, OnInit} from '@angular/core';\nimport {\n  AbstractControl,\n  FormControl,\n  FormGroup,\n  FormsModule,\n  ReactiveFormsModule,\n  Validators,\n} from '@angular/forms';\nimport {ActivatedRoute} from '@angular/router';\nimport {\n  CdsThemeService,\n  FormModule,\n  InputModule,\n  SelectItem,\n  SelectModule,\n  SpinnerModule,\n  ValtimoCdsModalDirectiveModule,\n} from '@valtimo/components';\nimport {TranslateModule} from '@ngx-translate/core';\nimport {BehaviorSubject, map, Observable, switchMap, tap} from 'rxjs';\nimport {CommonModule} from '@angular/common';\nimport {ButtonModule, CheckboxModule, ModalModule} from 'carbon-components-angular';\nimport {DocumentObjectenApiSyncService} from '../../services';\nimport {DocumentObjectenApiSync} from '../../models';\nimport {DocumentDefinition} from '@valtimo/document';\n\n@Component({\n  selector: 'valtimo-document-objecten-api-sync',\n  templateUrl: './document-objecten-api-sync.component.html',\n  styleUrls: ['./document-objecten-api-sync.component.scss'],\n  standalone: true,\n  imports: [\n    CommonModule,\n    FormsModule,\n    TranslateModule,\n    SpinnerModule,\n    FormModule,\n    InputModule,\n    SelectModule,\n    ValtimoCdsModalDirectiveModule,\n    CheckboxModule,\n    ReactiveFormsModule,\n    ButtonModule,\n    ModalModule,\n  ],\n})\nexport class DocumentObjectenApiSyncComponent implements OnInit {\n  public readonly loading$ = new BehaviorSubject<boolean>(true);\n  private readonly documentDefinitionName$: Observable<string> = this.route.params.pipe(\n    map(params => params.name || '')\n  );\n  private readonly documentDefinition$: Observable<DocumentDefinition> =\n    this.documentDefinitionName$.pipe(\n      switchMap(documentDefinitionName =>\n        this.documentObjectenApiSyncService.getDocumentDefinition(documentDefinitionName)\n      )\n    );\n  public readonly documentObjectenApiSync$ = new BehaviorSubject<DocumentObjectenApiSync>(null);\n  public readonly objectManagementConfigurationItems$: Observable<Array<SelectItem>> =\n    this.documentObjectenApiSyncService.getObjectManagementConfigurations().pipe(\n      map(results =>\n        results?.map(configuration => ({\n          id: configuration.id,\n          text: configuration.title,\n        }))\n      )\n    );\n  private readonly modalShowing$ = new BehaviorSubject<boolean>(false);\n  public readonly currentTheme$ = this.cdsThemeService.currentTheme$;\n  public readonly formGroup = new FormGroup({\n    objectManagementConfigurationId: new FormControl('', Validators.required),\n    enabled: new FormControl(true),\n  });\n\n  public get objectManagementConfigurationId(): AbstractControl<string> {\n    return this.formGroup.get('objectManagementConfigurationId');\n  }\n\n  public get enabled(): AbstractControl<boolean> {\n    return this.formGroup.get('enabled');\n  }\n\n  public readonly valid$ = new BehaviorSubject<boolean>(false);\n\n  constructor(\n    private readonly route: ActivatedRoute,\n    private readonly documentObjectenApiSyncService: DocumentObjectenApiSyncService,\n    private readonly cdsThemeService: CdsThemeService\n  ) {}\n\n  public ngOnInit(): void {\n    this.loadDocumentenObjectenApiSync();\n  }\n\n  public loadDocumentenObjectenApiSync(): void {\n    this.documentDefinition$\n      .pipe(\n        switchMap(documentDefinition =>\n          this.documentObjectenApiSyncService.getDocumentObjectenApiSync(\n            documentDefinition.id.name,\n            documentDefinition.id.version\n          )\n        )\n      )\n      .subscribe(documentObjectenApiSync => {\n        this.loading$.next(false);\n        this.configSelected(documentObjectenApiSync?.objectManagementConfigurationId);\n        this.enabled.patchValue(documentObjectenApiSync?.enabled);\n        this.documentObjectenApiSync$.next(documentObjectenApiSync);\n      });\n  }\n\n  public remove(): void {\n    this.documentDefinition$\n      .pipe(\n        switchMap(documentDefinition =>\n          this.documentObjectenApiSyncService.deleteDocumentObjectenApiSync(\n            documentDefinition.id.name,\n            documentDefinition.id.version\n          )\n        ),\n        tap(() => {\n          this.documentObjectenApiSync$.next(null);\n        })\n      )\n      .subscribe();\n  }\n\n  public submit(): void {\n    const formValues = this.formGroup.getRawValue();\n    this.documentDefinition$\n      .pipe(\n        switchMap(documentDefinition =>\n          this.documentObjectenApiSyncService.updateDocumentObjectenApiSync(\n            documentDefinition.id.name,\n            documentDefinition.id.version,\n            {\n              objectManagementConfigurationId: formValues.objectManagementConfigurationId,\n              enabled: formValues.enabled,\n            }\n          )\n        )\n      )\n      .subscribe(() => {\n        this.loadDocumentenObjectenApiSync();\n        this.hideModal();\n      });\n  }\n\n  public onModalClose(): void {\n    this.hideModal();\n  }\n\n  public showModal(): void {\n    this.modalShowing$.next(true);\n  }\n\n  public configSelected(selectedId: string): void {\n    if (!selectedId) {\n      this.objectManagementConfigurationId.patchValue('');\n    } else {\n      this.objectManagementConfigurationId.patchValue(selectedId);\n    }\n  }\n\n  private hideModal(): void {\n    this.modalShowing$.next(false);\n  }\n}\n","<!--\n  ~ Copyright 2015-2024 Ritense BV, the Netherlands.\n  ~\n  ~ Licensed under EUPL, Version 1.2 (the \"License\");\n  ~ you may not use this file except in compliance with the License.\n  ~ You may obtain a copy of the License at\n  ~\n  ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n  ~\n  ~ Unless required by applicable law or agreed to in writing, software\n  ~ distributed under the License is distributed on an \"AS IS\" basis,\n  ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n  ~ See the License for the specific language governing permissions and\n  ~ limitations under the License.\n  -->\n\n<div class=\"input-group mt-4 mb-2 align-items-center\">\n  <div>\n    <h2>{{ 'zaakdetails.title' | translate }}</h2>\n  </div>\n</div>\n\n<ng-container\n  *ngIf=\"{\n    loading: loading$ | async,\n    documentObjectenApiSync: documentObjectenApiSync$ | async,\n  } as obs\"\n>\n  <ng-container *ngIf=\"obs.loading === false; else loading\">\n    <ng-container *ngIf=\"obs.documentObjectenApiSync; else addSync\">\n      <div class=\"card card-border card-contrast\">\n        <div class=\"card-header card-header-contrast card-header-featured\">\n          <div>\n            {{ obs.documentObjectenApiSync.objectManagementConfigurationTitle || '-' }}\n          </div>\n          <div class=\"controls\">\n            <button class=\"btn btn-danger ml-3\" (click)=\"showModal()\">\n              <i class=\"icon mdi mdi-pencil\"></i>\n            </button>\n            <button class=\"btn btn-danger ml-3\" (click)=\"remove()\">\n              <i class=\"icon mdi mdi-delete\"></i>\n            </button>\n          </div>\n        </div>\n        <div class=\"card-body\">\n          <div class=\"row pt-3 mt-1\">\n            <div class=\"col-3\">\n              <strong>{{ 'zaakdetails.enabled' | translate }}</strong>\n            </div>\n            <div class=\"col-3\">\n              {{\n                obs.documentObjectenApiSync?.enabled\n                  ? ('zaakdetails.yes' | translate)\n                  : ('zaakdetails.no' | translate)\n              }}\n            </div>\n          </div>\n          <div class=\"row pt-3 mt-1\">\n            <div class=\"col-3\">\n              <strong>{{ 'zaakdetails.objectManagementConfigurationTitle' | translate }}</strong>\n            </div>\n            <div class=\"col-3\">\n              {{ obs.documentObjectenApiSync.objectManagementConfigurationTitle || '-' }}\n            </div>\n          </div>\n        </div>\n      </div>\n    </ng-container>\n  </ng-container>\n  <ng-container *ngTemplateOutlet=\"modal; context: {obs: obs}\"></ng-container>\n</ng-container>\n\n<ng-template #addSync>\n  <div class=\"text-right mt-5\">\n    <button class=\"btn btn-primary\" (click)=\"showModal()\">\n      <i class=\"icon mdi mdi-plus mr-1\"></i>{{ 'zaakdetails.submitButton' | translate }}\n    </button>\n  </div>\n</ng-template>\n\n<ng-template #modal let-obs=\"obs\">\n  <cds-modal\n    valtimoCdsModal\n    [title]=\"'zaakdetails.editModal.title' | translate\"\n    [open]=\"modalShowing$ | async\"\n    [showFooter]=\"true\"\n  >\n    <cds-modal-header [showCloseButton]=\"true\" (closeSelect)=\"onModalClose()\">\n      <h3 cdsModalHeaderHeading>\n        {{ 'zaakdetails.editModal.title' | translate }}\n      </h3>\n    </cds-modal-header>\n\n    <section cdsModalContent>\n      <form [formGroup]=\"formGroup\">\n        <v-select\n          *ngIf=\"objectManagementConfigurationItems$ | async as objectManagementConfigurations\"\n          [appendInline]=\"false\"\n          [dropUp]=\"false\"\n          [items]=\"objectManagementConfigurations\"\n          [defaultSelectionId]=\"objectManagementConfigurationId.getRawValue()\"\n          [placeholder]=\"\n            'zaakdetails.editModal.objectManagementConfigurationPlaceholder' | translate\n          \"\n          [title]=\"'zaakdetails.editModal.objectManagementConfiguration' | translate\"\n          [disabled]=\"false\"\n          [margin]=\"true\"\n          [required]=\"true\"\n          name=\"objectManagementConfigurationId\"\n          [carbonTheme]=\"currentTheme$ | async\"\n          (selectedChange)=\"configSelected($event)\"\n        ></v-select>\n\n        <cds-checkbox formControlName=\"enabled\"\n          >{{ 'zaakdetails.editModal.enabled' | translate }}\n        </cds-checkbox>\n      </form>\n    </section>\n\n    <cds-modal-footer>\n      <ng-container *ngTemplateOutlet=\"buttonsFooterModal; context: {obs: obs}\"></ng-container>\n    </cds-modal-footer>\n  </cds-modal>\n</ng-template>\n\n<ng-template #buttonsFooterModal let-obs=\"obs\">\n  <button cdsButton=\"secondary\" (click)=\"onModalClose()\" [disabled]=\"false\">\n    {{ 'interface.cancel' | translate }}\n  </button>\n\n  <button cdsButton=\"primary\" [disabled]=\"!formGroup.valid\" (click)=\"submit()\">\n    {{ 'searchFieldsOverview.submit' | translate }}\n  </button>\n</ng-template>\n\n<ng-template #loading>\n  <div class=\"mb-8\">\n    <valtimo-spinner></valtimo-spinner>\n  </div>\n</ng-template>\n\n<ng-template #noConfigAvailable>\n  <div class=\"mb-8\">\n    <h4>{{ 'zaakdetails.error.configNotFound' | translate }}</h4>\n  </div>\n</ng-template>\n"]}
|