@valtimo/dossier 12.16.0 → 12.16.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/components/dossier-supporting-process-start-modal/dossier-supporting-process-start-modal.component.mjs +26 -20
- package/fesm2022/valtimo-dossier.mjs +23 -17
- package/fesm2022/valtimo-dossier.mjs.map +1 -1
- package/lib/components/dossier-supporting-process-start-modal/dossier-supporting-process-start-modal.component.d.ts +2 -1
- package/lib/components/dossier-supporting-process-start-modal/dossier-supporting-process-start-modal.component.d.ts.map +1 -1
- package/package.json +1 -1
|
@@ -13,12 +13,12 @@
|
|
|
13
13
|
* See the License for the specific language governing permissions and
|
|
14
14
|
* limitations under the License.
|
|
15
15
|
*/
|
|
16
|
-
import { Component, EventEmitter, Inject, Input, Optional, Output, ViewChild, ViewContainerRef, ViewEncapsulation,
|
|
17
|
-
import { FormioOptionsImpl, } from '@valtimo/components';
|
|
16
|
+
import { Component, EventEmitter, Inject, Input, Optional, Output, signal, ViewChild, ViewContainerRef, ViewEncapsulation, } from '@angular/core';
|
|
17
|
+
import { CARBON_CONSTANTS, FormioOptionsImpl, } from '@valtimo/components';
|
|
18
|
+
import { FORM_VIEW_MODEL_TOKEN } from '@valtimo/config';
|
|
18
19
|
import { FORM_CUSTOM_COMPONENT_TOKEN, } from '@valtimo/process-link';
|
|
19
20
|
import { BehaviorSubject, combineLatest, Subscription, switchMap } from 'rxjs';
|
|
20
21
|
import { take } from 'rxjs/operators';
|
|
21
|
-
import { FORM_VIEW_MODEL_TOKEN } from '@valtimo/config';
|
|
22
22
|
import * as i0 from "@angular/core";
|
|
23
23
|
import * as i1 from "@angular/router";
|
|
24
24
|
import * as i2 from "@valtimo/process";
|
|
@@ -40,14 +40,14 @@ export class DossierSupportingProcessStartModalComponent {
|
|
|
40
40
|
this.processDefinitionKey$ = new BehaviorSubject('');
|
|
41
41
|
this.documentDefinitionName$ = new BehaviorSubject('');
|
|
42
42
|
this.processName$ = new BehaviorSubject('');
|
|
43
|
-
this.formDefinition$ = new BehaviorSubject(
|
|
44
|
-
this.formioSubmission$ = new BehaviorSubject(
|
|
43
|
+
this.formDefinition$ = new BehaviorSubject(null);
|
|
44
|
+
this.formioSubmission$ = new BehaviorSubject(null);
|
|
45
45
|
this.processLinkId$ = new BehaviorSubject('');
|
|
46
|
-
this.options$ = new BehaviorSubject(
|
|
47
|
-
this.submission$ = new BehaviorSubject(
|
|
48
|
-
this.processDefinitionId$ = new BehaviorSubject(
|
|
49
|
-
this.formFlowInstanceId$ = new BehaviorSubject(
|
|
50
|
-
this.documentId$ = new BehaviorSubject(
|
|
46
|
+
this.options$ = new BehaviorSubject(null);
|
|
47
|
+
this.submission$ = new BehaviorSubject(null);
|
|
48
|
+
this.processDefinitionId$ = new BehaviorSubject(null);
|
|
49
|
+
this.formFlowInstanceId$ = new BehaviorSubject(null);
|
|
50
|
+
this.documentId$ = new BehaviorSubject(null);
|
|
51
51
|
this.modalOpen$ = new BehaviorSubject(false);
|
|
52
52
|
this._formCustomComponentConfig$ = new BehaviorSubject({});
|
|
53
53
|
this.closeModalEvent = new EventEmitter();
|
|
@@ -56,8 +56,9 @@ export class DossierSupportingProcessStartModalComponent {
|
|
|
56
56
|
this._formCustomComponentConfig$.next(formCustomComponentConfig);
|
|
57
57
|
}
|
|
58
58
|
loadProcessLink() {
|
|
59
|
+
this.$loading.set(true);
|
|
59
60
|
combineLatest([this.processDefinitionId$, this.documentId$])
|
|
60
|
-
.pipe(take(1), switchMap(([processDefinitionId, documentId]) => this.processService.getProcessDefinitionStartProcessLink(processDefinitionId, documentId,
|
|
61
|
+
.pipe(take(1), switchMap(([processDefinitionId, documentId]) => this.processService.getProcessDefinitionStartProcessLink(processDefinitionId ?? '', documentId ?? '', '')))
|
|
61
62
|
.subscribe(startProcessResult => {
|
|
62
63
|
if (startProcessResult) {
|
|
63
64
|
this.isUIComponent = false;
|
|
@@ -68,10 +69,10 @@ export class DossierSupportingProcessStartModalComponent {
|
|
|
68
69
|
this.processLinkId$.next(startProcessResult.processLinkId);
|
|
69
70
|
break;
|
|
70
71
|
case 'form-flow':
|
|
71
|
-
this.formFlowInstanceId$.next(startProcessResult.properties.formFlowInstanceId);
|
|
72
|
+
this.formFlowInstanceId$.next(startProcessResult.properties.formFlowInstanceId ?? null);
|
|
72
73
|
break;
|
|
73
74
|
case 'form-view-model':
|
|
74
|
-
this.formDefinition$.next(startProcessResult.properties.formDefinition);
|
|
75
|
+
this.formDefinition$.next(startProcessResult.properties.formDefinition ?? null);
|
|
75
76
|
this.setFormViewModelComponent(startProcessResult.properties.formName);
|
|
76
77
|
break;
|
|
77
78
|
case 'ui-component':
|
|
@@ -79,8 +80,8 @@ export class DossierSupportingProcessStartModalComponent {
|
|
|
79
80
|
this.isUIComponent = true;
|
|
80
81
|
break;
|
|
81
82
|
}
|
|
82
|
-
this.$loading.set(false);
|
|
83
83
|
}
|
|
84
|
+
this.$loading.set(false);
|
|
84
85
|
});
|
|
85
86
|
}
|
|
86
87
|
openModal(processDocumentDefinition, documentId) {
|
|
@@ -103,7 +104,7 @@ export class DossierSupportingProcessStartModalComponent {
|
|
|
103
104
|
this.formioSubmission$.next(submission);
|
|
104
105
|
if (this.processLinkId$.getValue()) {
|
|
105
106
|
combineLatest([this.processLinkId$, this.documentId$])
|
|
106
|
-
.pipe(take(1), switchMap(([processLinkId, documentId]) => this.processLinkService.submitForm(processLinkId, submission.data, documentId)))
|
|
107
|
+
.pipe(take(1), switchMap(([processLinkId, documentId]) => this.processLinkService.submitForm(processLinkId, submission.data, documentId ?? '')))
|
|
107
108
|
.subscribe({
|
|
108
109
|
next: (formSubmissionResult) => {
|
|
109
110
|
this.formSubmitted();
|
|
@@ -117,7 +118,6 @@ export class DossierSupportingProcessStartModalComponent {
|
|
|
117
118
|
formSubmitted() {
|
|
118
119
|
this.closeCdsModal();
|
|
119
120
|
this.formSubmit.emit();
|
|
120
|
-
this.formDefinition$.next(null);
|
|
121
121
|
}
|
|
122
122
|
gotoFormLinkScreen() {
|
|
123
123
|
this.closeCdsModal();
|
|
@@ -129,7 +129,7 @@ export class DossierSupportingProcessStartModalComponent {
|
|
|
129
129
|
this.closeCdsModal();
|
|
130
130
|
}
|
|
131
131
|
setFormViewModelComponent(formName) {
|
|
132
|
-
if (!this.formViewModel.component)
|
|
132
|
+
if (!this.formViewModel.component || !formName)
|
|
133
133
|
return;
|
|
134
134
|
this.formViewModelDynamicContainer.clear();
|
|
135
135
|
const formViewModelComponent = this.formViewModelDynamicContainer.createComponent(this.formViewModel.component);
|
|
@@ -160,7 +160,7 @@ export class DossierSupportingProcessStartModalComponent {
|
|
|
160
160
|
}
|
|
161
161
|
setFormCustomComponent(formCustomComponentKey) {
|
|
162
162
|
this.formCustomComponentDynamicContainer.clear();
|
|
163
|
-
if (!this.formCustomComponentConfig)
|
|
163
|
+
if (!this.formCustomComponentConfig || !formCustomComponentKey)
|
|
164
164
|
return;
|
|
165
165
|
this._formCustomComponentConfig$.pipe(take(1)).subscribe(formCustomComponentConfig => {
|
|
166
166
|
const customComponent = formCustomComponentConfig[formCustomComponentKey];
|
|
@@ -182,11 +182,17 @@ export class DossierSupportingProcessStartModalComponent {
|
|
|
182
182
|
closeCdsModal() {
|
|
183
183
|
this.modalOpen$.next(false);
|
|
184
184
|
this.closeModalEvent.emit();
|
|
185
|
+
this.reset();
|
|
185
186
|
}
|
|
186
187
|
openCdsModal() {
|
|
187
|
-
this.loadProcessLink();
|
|
188
188
|
this.modalOpen$.next(true);
|
|
189
189
|
}
|
|
190
|
+
reset() {
|
|
191
|
+
setTimeout(() => {
|
|
192
|
+
this.formDefinition$.next(null);
|
|
193
|
+
this.formFlowInstanceId$.next(null);
|
|
194
|
+
}, CARBON_CONSTANTS.modalAnimationMs);
|
|
195
|
+
}
|
|
190
196
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DossierSupportingProcessStartModalComponent, deps: [{ token: i1.Router }, { token: i2.ProcessService }, { token: i3.ProcessLinkService }, { token: FORM_VIEW_MODEL_TOKEN, optional: true }, { token: FORM_CUSTOM_COMPONENT_TOKEN, optional: true }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
191
197
|
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: DossierSupportingProcessStartModalComponent, selector: "valtimo-dossier-supporting-process-start-modal", inputs: { isAdmin: "isAdmin" }, outputs: { formSubmit: "formSubmit" }, viewQueries: [{ propertyName: "form", first: true, predicate: ["form"], descendants: true }, { propertyName: "formViewModelDynamicContainer", first: true, predicate: ["formViewModelComponent"], descendants: true, read: ViewContainerRef, static: true }, { propertyName: "formCustomComponentDynamicContainer", first: true, predicate: ["formCustomComponent"], descendants: true, read: ViewContainerRef }], 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<cds-modal [open]=\"modalOpen$ | async\" valtimoCdsModal size=\"sm\">\n <cds-modal-header [showCloseButton]=\"true\" (closeSelect)=\"onCloseSelect()\" [cdsLayer]=\"1\"\n ><h3 cdsModalHeaderHeading>\n {{\n (processDefinitionKey$ | async | translate) !== (processDefinitionKey$ | async)\n ? (processDefinitionKey$ | async | translate)\n : (processName$ | async)\n }}\n </h3>\n </cds-modal-header>\n\n <section cdsModalContent [cdsLayer]=\"1\">\n <ng-template #formViewModelComponent></ng-template>\n <ng-template #formCustomComponent></ng-template>\n\n @if ($loading()) {\n <cds-loading></cds-loading>\n } @else {\n @if (!isFormViewModel && !isUIComponent && (formDefinition$ | async)) {\n <valtimo-form-io\n #form\n [submission]=\"submission$ | async\"\n [form]=\"formDefinition$ | async\"\n [options]=\"options$ | async\"\n (submit)=\"onSubmit($event)\"\n ></valtimo-form-io>\n }\n\n @if (formFlowInstanceId$ | async) {\n <valtimo-form-flow\n #formFlow\n [formFlowInstanceId]=\"formFlowInstanceId$ | async\"\n (formFlowComplete)=\"formSubmitted()\"\n ></valtimo-form-flow>\n }\n\n @if (!(formDefinition$ | async) && !(formFlowInstanceId$ | async) && !isUIComponent) {\n <div class=\"bg-warning text-black mb-0 p-3 text-center\">\n {{\n isAdmin\n ? ('formManagement.noFormDefinitionFoundAdmin' | translate)\n : ('formManagement.noFormDefinitionFoundUser' | translate)\n }}\n </div>\n <div class=\"mb-0 mt-4 p-3 text-center\">\n <button\n class=\"btn btn-secondary btn-space\"\n type=\"button\"\n (click)=\"gotoFormLinkScreen()\"\n id=\"form-link-button\"\n >\n {{ 'formManagement.gotoProcessLinksButton' | translate }}\n </button>\n </div>\n }\n }\n </section>\n</cds-modal>\n", styles: ["#supportingProcessStartModal .formio-component-submit{text-align:right}cds-loading{display:flex;justify-content: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: "component", type: i4.FormioComponent, selector: "valtimo-form-io", inputs: ["options", "submission", "form", "readOnly", "formRefresh$"], outputs: ["submit", "change", "event"] }, { kind: "component", type: i5.Loading, selector: "cds-loading, ibm-loading", inputs: ["title", "isActive", "size", "overlay"] }, { kind: "component", type: i3.FormFlowComponent, selector: "valtimo-form-flow", inputs: ["formIoFormData", "formFlowInstanceId"], outputs: ["formFlowComplete", "formFlowChange"] }, { kind: "component", type: i5.Modal, selector: "cds-modal, ibm-modal", inputs: ["size", "theme", "ariaLabel", "open", "trigger", "hasScrollingContent"], outputs: ["overlaySelected", "close"] }, { kind: "component", type: i5.ModalHeader, selector: "cds-modal-header, ibm-modal-header", inputs: ["theme", "closeLabel", "showCloseButton"], outputs: ["closeSelect"] }, { kind: "directive", type: i5.ModalContent, selector: "[cdsModalContent], [ibmModalContent]", inputs: ["hasForm"] }, { kind: "directive", type: i5.ModalHeaderHeading, selector: "[cdsModalHeaderHeading], [ibmModalHeaderHeading]" }, { kind: "directive", type: i4.ValtimoCdsModalDirective, selector: "[valtimoCdsModal]", inputs: ["enableOverflow"] }, { kind: "directive", type: i5.LayerDirective, selector: "[cdsLayer], [ibmLayer]", inputs: ["ibmLayer", "cdsLayer"], exportAs: ["layer"] }, { kind: "pipe", type: i6.AsyncPipe, name: "async" }, { kind: "pipe", type: i7.TranslatePipe, name: "translate" }], encapsulation: i0.ViewEncapsulation.None }); }
|
|
192
198
|
}
|
|
@@ -217,4 +223,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
217
223
|
}], formSubmit: [{
|
|
218
224
|
type: Output
|
|
219
225
|
}] } });
|
|
220
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dossier-supporting-process-start-modal.component.js","sourceRoot":"","sources":["../../../../../../../projects/valtimo/dossier/src/lib/components/dossier-supporting-process-start-modal/dossier-supporting-process-start-modal.component.ts","../../../../../../../projects/valtimo/dossier/src/lib/components/dossier-supporting-process-start-modal/dossier-supporting-process-start-modal.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 {\n  Component,\n  ComponentRef,\n  EventEmitter,\n  Inject,\n  Input,\n  Optional,\n  Output,\n  ViewChild,\n  ViewContainerRef,\n  ViewEncapsulation,\n  signal,\n} from '@angular/core';\nimport {Router} from '@angular/router';\nimport {FormioBeforeSubmit, FormioForm} from '@formio/angular';\nimport {\n  FormioComponent,\n  FormioOptionsImpl,\n  FormioSubmission,\n  ValtimoFormioOptions,\n} from '@valtimo/components';\nimport {ProcessDocumentDefinition} from '@valtimo/document';\nimport {ProcessService} from '@valtimo/process';\nimport {\n  FORM_CUSTOM_COMPONENT_TOKEN,\n  FormCustomComponent,\n  FormCustomComponentConfig,\n  FormSubmissionResult,\n  ProcessLinkService,\n} from '@valtimo/process-link';\nimport {BehaviorSubject, combineLatest, Subscription, switchMap} from 'rxjs';\nimport {take} from 'rxjs/operators';\nimport {FORM_VIEW_MODEL_TOKEN, FormViewModel} from '@valtimo/config';\n\n@Component({\n  selector: 'valtimo-dossier-supporting-process-start-modal',\n  templateUrl: './dossier-supporting-process-start-modal.component.html',\n  styleUrls: ['./dossier-supporting-process-start-modal.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n})\nexport class DossierSupportingProcessStartModalComponent {\n  @ViewChild('form', {static: false}) form: FormioComponent;\n  @ViewChild('formViewModelComponent', {static: true, read: ViewContainerRef})\n  public formViewModelDynamicContainer: ViewContainerRef;\n  @ViewChild('formCustomComponent', {static: false, read: ViewContainerRef})\n  public formCustomComponentDynamicContainer: ViewContainerRef;\n\n  @Input() isAdmin: boolean;\n  @Output() formSubmit = new EventEmitter();\n\n  protected isFormViewModel = false;\n  public isUIComponent = false;\n\n  public readonly processDefinitionKey$ = new BehaviorSubject<string>('');\n  public readonly documentDefinitionName$ = new BehaviorSubject<string>('');\n  public readonly processName$ = new BehaviorSubject<string>('');\n  public readonly formDefinition$ = new BehaviorSubject<FormioForm>(undefined);\n  public readonly formioSubmission$ = new BehaviorSubject<FormioSubmission>(undefined);\n  public readonly processLinkId$ = new BehaviorSubject<string>('');\n  public readonly options$ = new BehaviorSubject<ValtimoFormioOptions>(undefined);\n  public readonly submission$ = new BehaviorSubject<object>(undefined);\n  public readonly processDefinitionId$ = new BehaviorSubject<string>(undefined);\n  public readonly formFlowInstanceId$ = new BehaviorSubject<string>(undefined);\n  public readonly documentId$ = new BehaviorSubject<string>(undefined);\n  public readonly modalOpen$ = new BehaviorSubject<boolean>(false);\n  private readonly _formCustomComponentConfig$ = new BehaviorSubject<\n    FormCustomComponentConfig | {}\n  >({});\n  public readonly closeModalEvent = new EventEmitter();\n  public readonly $loading = signal<boolean>(true);\n\n  private readonly _subscriptions = new Subscription();\n\n  constructor(\n    private readonly router: Router,\n    private readonly processService: ProcessService,\n    private readonly processLinkService: ProcessLinkService,\n    @Optional() @Inject(FORM_VIEW_MODEL_TOKEN) private readonly formViewModel: FormViewModel,\n    @Optional()\n    @Inject(FORM_CUSTOM_COMPONENT_TOKEN)\n    private readonly formCustomComponentConfig: FormCustomComponentConfig\n  ) {\n    this._formCustomComponentConfig$.next(formCustomComponentConfig);\n  }\n\n  private loadProcessLink(): void {\n    combineLatest([this.processDefinitionId$, this.documentId$])\n      .pipe(\n        take(1),\n        switchMap(([processDefinitionId, documentId]) =>\n          this.processService.getProcessDefinitionStartProcessLink(\n            processDefinitionId,\n            documentId,\n            null\n          )\n        )\n      )\n      .subscribe(startProcessResult => {\n        if (startProcessResult) {\n          this.isUIComponent = false;\n          this.isFormViewModel = false;\n          switch (startProcessResult.type) {\n            case 'form':\n              this.formDefinition$.next(startProcessResult.properties.prefilledForm);\n              this.processLinkId$.next(startProcessResult.processLinkId);\n              break;\n            case 'form-flow':\n              this.formFlowInstanceId$.next(startProcessResult.properties.formFlowInstanceId);\n              break;\n            case 'form-view-model':\n              this.formDefinition$.next(startProcessResult.properties.formDefinition);\n              this.setFormViewModelComponent(startProcessResult.properties.formName);\n              break;\n            case 'ui-component':\n              this.setFormCustomComponent(startProcessResult.properties.componentKey);\n              this.isUIComponent = true;\n              break;\n          }\n          this.$loading.set(false);\n        }\n      });\n  }\n\n  public openModal(processDocumentDefinition: ProcessDocumentDefinition, documentId: string): void {\n    this.documentId$.next(documentId);\n    this.documentDefinitionName$.next(processDocumentDefinition.id.documentDefinitionId.name);\n    this.processDefinitionKey$.next(processDocumentDefinition.id.processDefinitionKey);\n    this.processDefinitionId$.next(processDocumentDefinition.latestVersionId);\n    this.processName$.next(processDocumentDefinition.processName);\n\n    const formioBeforeSubmit: FormioBeforeSubmit = function (submission, callback) {\n      callback(null, submission);\n    };\n\n    const options = new FormioOptionsImpl();\n    options.disableAlerts = true;\n    options.setHooks(formioBeforeSubmit);\n\n    this.options$.next(options);\n\n    this.loadProcessLink();\n    this.openCdsModal();\n  }\n\n  public onSubmit(submission: FormioSubmission): void {\n    this.formioSubmission$.next(submission);\n\n    if (this.processLinkId$.getValue()) {\n      combineLatest([this.processLinkId$, this.documentId$])\n        .pipe(\n          take(1),\n          switchMap(([processLinkId, documentId]) =>\n            this.processLinkService.submitForm(processLinkId, submission.data, documentId)\n          )\n        )\n        .subscribe({\n          next: (formSubmissionResult: FormSubmissionResult) => {\n            this.formSubmitted();\n          },\n          error: errors => {\n            this.form.showErrors(errors);\n          },\n        });\n    }\n  }\n\n  public formSubmitted(): void {\n    this.closeCdsModal();\n    this.formSubmit.emit();\n    this.formDefinition$.next(null);\n  }\n\n  public gotoFormLinkScreen(): void {\n    this.closeCdsModal();\n    this.router.navigate(['process-links'], {\n      queryParams: {process: this.processDefinitionKey$.getValue()},\n    });\n  }\n\n  public onCloseSelect(): void {\n    this.closeCdsModal();\n  }\n\n  private setFormViewModelComponent(formName: string): void {\n    if (!this.formViewModel.component) return;\n    this.formViewModelDynamicContainer.clear();\n    const formViewModelComponent = this.formViewModelDynamicContainer.createComponent(\n      this.formViewModel.component\n    );\n\n    combineLatest([\n      this.formDefinition$,\n      this.processDefinitionKey$,\n      this.documentDefinitionName$,\n      this.options$,\n      this.documentId$,\n    ])\n      .pipe(take(1))\n      .subscribe(([form, processDefinitionKey, documentDefinitionName, options, documentId]) => {\n        formViewModelComponent.instance.formName = formName;\n        formViewModelComponent.instance.form = form;\n        formViewModelComponent.instance.processDefinitionKey = processDefinitionKey;\n        formViewModelComponent.instance.documentDefinitionName = documentDefinitionName;\n        formViewModelComponent.instance.options = options;\n        formViewModelComponent.instance.isStartForm = true;\n        formViewModelComponent.instance.documentId = documentId;\n      });\n\n    formViewModelComponent.instance.formSubmit.pipe(take(1)).subscribe(() => {\n      this.formSubmitted();\n    });\n\n    this._subscriptions.add(\n      this.closeModalEvent.subscribe(() => {\n        formViewModelComponent.destroy();\n      })\n    );\n\n    this.isFormViewModel = true;\n  }\n\n  private setFormCustomComponent(formCustomComponentKey: string): void {\n    this.formCustomComponentDynamicContainer.clear();\n    if (!this.formCustomComponentConfig) return;\n    this._formCustomComponentConfig$.pipe(take(1)).subscribe(formCustomComponentConfig => {\n      const customComponent = formCustomComponentConfig[formCustomComponentKey];\n      const renderedComponent = this.formCustomComponentDynamicContainer.createComponent(\n        customComponent\n      ) as ComponentRef<FormCustomComponent>;\n\n      combineLatest([this.processDefinitionKey$, this.documentDefinitionName$])\n        .pipe(take(1))\n        .subscribe(([processDefinitionKey, documentDefinitionName]) => {\n          renderedComponent.instance.processDefinitionKey = processDefinitionKey;\n          renderedComponent.instance.documentDefinitionName = documentDefinitionName;\n        });\n\n      renderedComponent.instance.submittedEvent.subscribe(() => {\n        this.formSubmitted();\n      });\n\n      this._subscriptions.add(\n        this.closeModalEvent.subscribe(() => {\n          renderedComponent.destroy();\n        })\n      );\n    });\n  }\n\n  private closeCdsModal(): void {\n    this.modalOpen$.next(false);\n    this.closeModalEvent.emit();\n  }\n\n  private openCdsModal(): void {\n    this.loadProcessLink();\n    this.modalOpen$.next(true);\n  }\n}\n","<!--\n  ~ Copyright 2015-2024 Ritense BV, the Netherlands.\n  ~\n  ~ Licensed under EUPL, Version 1.2 (the \"License\");\n  ~ you may not use this file except in compliance with the License.\n  ~ You may obtain a copy of the License at\n  ~\n  ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n  ~\n  ~ Unless required by applicable law or agreed to in writing, software\n  ~ distributed under the License is distributed on an \"AS IS\" basis,\n  ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n  ~ See the License for the specific language governing permissions and\n  ~ limitations under the License.\n  -->\n\n<cds-modal [open]=\"modalOpen$ | async\" valtimoCdsModal size=\"sm\">\n  <cds-modal-header [showCloseButton]=\"true\" (closeSelect)=\"onCloseSelect()\" [cdsLayer]=\"1\"\n    ><h3 cdsModalHeaderHeading>\n      {{\n        (processDefinitionKey$ | async | translate) !== (processDefinitionKey$ | async)\n          ? (processDefinitionKey$ | async | translate)\n          : (processName$ | async)\n      }}\n    </h3>\n  </cds-modal-header>\n\n  <section cdsModalContent [cdsLayer]=\"1\">\n    <ng-template #formViewModelComponent></ng-template>\n    <ng-template #formCustomComponent></ng-template>\n\n    @if ($loading()) {\n      <cds-loading></cds-loading>\n    } @else {\n      @if (!isFormViewModel && !isUIComponent && (formDefinition$ | async)) {\n        <valtimo-form-io\n          #form\n          [submission]=\"submission$ | async\"\n          [form]=\"formDefinition$ | async\"\n          [options]=\"options$ | async\"\n          (submit)=\"onSubmit($event)\"\n        ></valtimo-form-io>\n      }\n\n      @if (formFlowInstanceId$ | async) {\n        <valtimo-form-flow\n          #formFlow\n          [formFlowInstanceId]=\"formFlowInstanceId$ | async\"\n          (formFlowComplete)=\"formSubmitted()\"\n        ></valtimo-form-flow>\n      }\n\n      @if (!(formDefinition$ | async) && !(formFlowInstanceId$ | async) && !isUIComponent) {\n        <div class=\"bg-warning text-black mb-0 p-3 text-center\">\n          {{\n            isAdmin\n              ? ('formManagement.noFormDefinitionFoundAdmin' | translate)\n              : ('formManagement.noFormDefinitionFoundUser' | translate)\n          }}\n        </div>\n        <div class=\"mb-0 mt-4 p-3 text-center\">\n          <button\n            class=\"btn btn-secondary btn-space\"\n            type=\"button\"\n            (click)=\"gotoFormLinkScreen()\"\n            id=\"form-link-button\"\n          >\n            {{ 'formManagement.gotoProcessLinksButton' | translate }}\n          </button>\n        </div>\n      }\n    }\n  </section>\n</cds-modal>\n"]}
|
|
226
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dossier-supporting-process-start-modal.component.js","sourceRoot":"","sources":["../../../../../../../projects/valtimo/dossier/src/lib/components/dossier-supporting-process-start-modal/dossier-supporting-process-start-modal.component.ts","../../../../../../../projects/valtimo/dossier/src/lib/components/dossier-supporting-process-start-modal/dossier-supporting-process-start-modal.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 {\n  Component,\n  ComponentRef,\n  EventEmitter,\n  Inject,\n  Input,\n  Optional,\n  Output,\n  signal,\n  ViewChild,\n  ViewContainerRef,\n  ViewEncapsulation,\n} from '@angular/core';\nimport {Router} from '@angular/router';\nimport {FormioBeforeSubmit, FormioForm} from '@formio/angular';\nimport {\n  CARBON_CONSTANTS,\n  FormioComponent,\n  FormioOptionsImpl,\n  FormioSubmission,\n  ValtimoFormioOptions,\n} from '@valtimo/components';\nimport {FORM_VIEW_MODEL_TOKEN, FormViewModel} from '@valtimo/config';\nimport {ProcessDocumentDefinition} from '@valtimo/document';\nimport {ProcessService} from '@valtimo/process';\nimport {\n  FORM_CUSTOM_COMPONENT_TOKEN,\n  FormCustomComponent,\n  FormCustomComponentConfig,\n  FormSubmissionResult,\n  ProcessLinkService,\n} from '@valtimo/process-link';\nimport {BehaviorSubject, combineLatest, Subscription, switchMap} from 'rxjs';\nimport {take} from 'rxjs/operators';\n\n@Component({\n  selector: 'valtimo-dossier-supporting-process-start-modal',\n  templateUrl: './dossier-supporting-process-start-modal.component.html',\n  styleUrls: ['./dossier-supporting-process-start-modal.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n})\nexport class DossierSupportingProcessStartModalComponent {\n  @ViewChild('form', {static: false}) form: FormioComponent;\n  @ViewChild('formViewModelComponent', {static: true, read: ViewContainerRef})\n  public formViewModelDynamicContainer: ViewContainerRef;\n  @ViewChild('formCustomComponent', {static: false, read: ViewContainerRef})\n  public formCustomComponentDynamicContainer: ViewContainerRef;\n\n  @Input() isAdmin: boolean;\n  @Output() formSubmit = new EventEmitter();\n\n  protected isFormViewModel = false;\n  public isUIComponent = false;\n\n  public readonly processDefinitionKey$ = new BehaviorSubject<string>('');\n  public readonly documentDefinitionName$ = new BehaviorSubject<string>('');\n  public readonly processName$ = new BehaviorSubject<string>('');\n  public readonly formDefinition$ = new BehaviorSubject<FormioForm | null>(null);\n  public readonly formioSubmission$ = new BehaviorSubject<FormioSubmission | null>(null);\n  public readonly processLinkId$ = new BehaviorSubject<string>('');\n  public readonly options$ = new BehaviorSubject<ValtimoFormioOptions | null>(null);\n  public readonly submission$ = new BehaviorSubject<object | null>(null);\n  public readonly processDefinitionId$ = new BehaviorSubject<string | null>(null);\n  public readonly formFlowInstanceId$ = new BehaviorSubject<string | null>(null);\n  public readonly documentId$ = new BehaviorSubject<string | null>(null);\n  public readonly modalOpen$ = new BehaviorSubject<boolean>(false);\n  private readonly _formCustomComponentConfig$ = new BehaviorSubject<\n    FormCustomComponentConfig | {}\n  >({});\n  public readonly closeModalEvent = new EventEmitter();\n  public readonly $loading = signal<boolean>(true);\n\n  private readonly _subscriptions = new Subscription();\n\n  constructor(\n    private readonly router: Router,\n    private readonly processService: ProcessService,\n    private readonly processLinkService: ProcessLinkService,\n    @Optional() @Inject(FORM_VIEW_MODEL_TOKEN) private readonly formViewModel: FormViewModel,\n    @Optional()\n    @Inject(FORM_CUSTOM_COMPONENT_TOKEN)\n    private readonly formCustomComponentConfig: FormCustomComponentConfig\n  ) {\n    this._formCustomComponentConfig$.next(formCustomComponentConfig);\n  }\n\n  private loadProcessLink(): void {\n    this.$loading.set(true);\n    combineLatest([this.processDefinitionId$, this.documentId$])\n      .pipe(\n        take(1),\n        switchMap(([processDefinitionId, documentId]) =>\n          this.processService.getProcessDefinitionStartProcessLink(\n            processDefinitionId ?? '',\n            documentId ?? '',\n            ''\n          )\n        )\n      )\n      .subscribe(startProcessResult => {\n        if (startProcessResult) {\n          this.isUIComponent = false;\n          this.isFormViewModel = false;\n          switch (startProcessResult.type) {\n            case 'form':\n              this.formDefinition$.next(startProcessResult.properties.prefilledForm);\n              this.processLinkId$.next(startProcessResult.processLinkId);\n              break;\n            case 'form-flow':\n              this.formFlowInstanceId$.next(\n                startProcessResult.properties.formFlowInstanceId ?? null\n              );\n              break;\n            case 'form-view-model':\n              this.formDefinition$.next(startProcessResult.properties.formDefinition ?? null);\n              this.setFormViewModelComponent(startProcessResult.properties.formName);\n              break;\n            case 'ui-component':\n              this.setFormCustomComponent(startProcessResult.properties.componentKey);\n              this.isUIComponent = true;\n              break;\n          }\n        }\n        this.$loading.set(false);\n      });\n  }\n\n  public openModal(processDocumentDefinition: ProcessDocumentDefinition, documentId: string): void {\n    this.documentId$.next(documentId);\n    this.documentDefinitionName$.next(processDocumentDefinition.id.documentDefinitionId.name);\n    this.processDefinitionKey$.next(processDocumentDefinition.id.processDefinitionKey);\n    this.processDefinitionId$.next(processDocumentDefinition.latestVersionId);\n    this.processName$.next(processDocumentDefinition.processName);\n\n    const formioBeforeSubmit: FormioBeforeSubmit = function (submission, callback) {\n      callback(null, submission);\n    };\n\n    const options = new FormioOptionsImpl();\n    options.disableAlerts = true;\n    options.setHooks(formioBeforeSubmit);\n\n    this.options$.next(options);\n\n    this.loadProcessLink();\n    this.openCdsModal();\n  }\n\n  public onSubmit(submission: FormioSubmission): void {\n    this.formioSubmission$.next(submission);\n\n    if (this.processLinkId$.getValue()) {\n      combineLatest([this.processLinkId$, this.documentId$])\n        .pipe(\n          take(1),\n          switchMap(([processLinkId, documentId]) =>\n            this.processLinkService.submitForm(processLinkId, submission.data, documentId ?? '')\n          )\n        )\n        .subscribe({\n          next: (formSubmissionResult: FormSubmissionResult) => {\n            this.formSubmitted();\n          },\n          error: errors => {\n            this.form.showErrors(errors);\n          },\n        });\n    }\n  }\n\n  public formSubmitted(): void {\n    this.closeCdsModal();\n    this.formSubmit.emit();\n  }\n\n  public gotoFormLinkScreen(): void {\n    this.closeCdsModal();\n    this.router.navigate(['process-links'], {\n      queryParams: {process: this.processDefinitionKey$.getValue()},\n    });\n  }\n\n  public onCloseSelect(): void {\n    this.closeCdsModal();\n  }\n\n  private setFormViewModelComponent(formName: string | undefined): void {\n    if (!this.formViewModel.component || !formName) return;\n    this.formViewModelDynamicContainer.clear();\n    const formViewModelComponent = this.formViewModelDynamicContainer.createComponent(\n      this.formViewModel.component\n    );\n\n    combineLatest([\n      this.formDefinition$,\n      this.processDefinitionKey$,\n      this.documentDefinitionName$,\n      this.options$,\n      this.documentId$,\n    ])\n      .pipe(take(1))\n      .subscribe(([form, processDefinitionKey, documentDefinitionName, options, documentId]) => {\n        formViewModelComponent.instance.formName = formName;\n        formViewModelComponent.instance.form = form;\n        formViewModelComponent.instance.processDefinitionKey = processDefinitionKey;\n        formViewModelComponent.instance.documentDefinitionName = documentDefinitionName;\n        formViewModelComponent.instance.options = options;\n        formViewModelComponent.instance.isStartForm = true;\n        formViewModelComponent.instance.documentId = documentId;\n      });\n\n    formViewModelComponent.instance.formSubmit.pipe(take(1)).subscribe(() => {\n      this.formSubmitted();\n    });\n\n    this._subscriptions.add(\n      this.closeModalEvent.subscribe(() => {\n        formViewModelComponent.destroy();\n      })\n    );\n\n    this.isFormViewModel = true;\n  }\n\n  private setFormCustomComponent(formCustomComponentKey: string | undefined): void {\n    this.formCustomComponentDynamicContainer.clear();\n    if (!this.formCustomComponentConfig || !formCustomComponentKey) return;\n    this._formCustomComponentConfig$.pipe(take(1)).subscribe(formCustomComponentConfig => {\n      const customComponent = formCustomComponentConfig[formCustomComponentKey];\n      const renderedComponent = this.formCustomComponentDynamicContainer.createComponent(\n        customComponent\n      ) as ComponentRef<FormCustomComponent>;\n\n      combineLatest([this.processDefinitionKey$, this.documentDefinitionName$])\n        .pipe(take(1))\n        .subscribe(([processDefinitionKey, documentDefinitionName]) => {\n          renderedComponent.instance.processDefinitionKey = processDefinitionKey;\n          renderedComponent.instance.documentDefinitionName = documentDefinitionName;\n        });\n\n      renderedComponent.instance.submittedEvent.subscribe(() => {\n        this.formSubmitted();\n      });\n\n      this._subscriptions.add(\n        this.closeModalEvent.subscribe(() => {\n          renderedComponent.destroy();\n        })\n      );\n    });\n  }\n\n  private closeCdsModal(): void {\n    this.modalOpen$.next(false);\n    this.closeModalEvent.emit();\n    this.reset();\n  }\n\n  private openCdsModal(): void {\n    this.modalOpen$.next(true);\n  }\n\n  private reset(): void {\n    setTimeout(() => {\n      this.formDefinition$.next(null);\n      this.formFlowInstanceId$.next(null);\n    }, CARBON_CONSTANTS.modalAnimationMs);\n  }\n}\n","<!--\n  ~ Copyright 2015-2024 Ritense BV, the Netherlands.\n  ~\n  ~ Licensed under EUPL, Version 1.2 (the \"License\");\n  ~ you may not use this file except in compliance with the License.\n  ~ You may obtain a copy of the License at\n  ~\n  ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n  ~\n  ~ Unless required by applicable law or agreed to in writing, software\n  ~ distributed under the License is distributed on an \"AS IS\" basis,\n  ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n  ~ See the License for the specific language governing permissions and\n  ~ limitations under the License.\n  -->\n\n<cds-modal [open]=\"modalOpen$ | async\" valtimoCdsModal size=\"sm\">\n  <cds-modal-header [showCloseButton]=\"true\" (closeSelect)=\"onCloseSelect()\" [cdsLayer]=\"1\"\n    ><h3 cdsModalHeaderHeading>\n      {{\n        (processDefinitionKey$ | async | translate) !== (processDefinitionKey$ | async)\n          ? (processDefinitionKey$ | async | translate)\n          : (processName$ | async)\n      }}\n    </h3>\n  </cds-modal-header>\n\n  <section cdsModalContent [cdsLayer]=\"1\">\n    <ng-template #formViewModelComponent></ng-template>\n    <ng-template #formCustomComponent></ng-template>\n\n    @if ($loading()) {\n      <cds-loading></cds-loading>\n    } @else {\n      @if (!isFormViewModel && !isUIComponent && (formDefinition$ | async)) {\n        <valtimo-form-io\n          #form\n          [submission]=\"submission$ | async\"\n          [form]=\"formDefinition$ | async\"\n          [options]=\"options$ | async\"\n          (submit)=\"onSubmit($event)\"\n        ></valtimo-form-io>\n      }\n\n      @if (formFlowInstanceId$ | async) {\n        <valtimo-form-flow\n          #formFlow\n          [formFlowInstanceId]=\"formFlowInstanceId$ | async\"\n          (formFlowComplete)=\"formSubmitted()\"\n        ></valtimo-form-flow>\n      }\n\n      @if (!(formDefinition$ | async) && !(formFlowInstanceId$ | async) && !isUIComponent) {\n        <div class=\"bg-warning text-black mb-0 p-3 text-center\">\n          {{\n            isAdmin\n              ? ('formManagement.noFormDefinitionFoundAdmin' | translate)\n              : ('formManagement.noFormDefinitionFoundUser' | translate)\n          }}\n        </div>\n        <div class=\"mb-0 mt-4 p-3 text-center\">\n          <button\n            class=\"btn btn-secondary btn-space\"\n            type=\"button\"\n            (click)=\"gotoFormLinkScreen()\"\n            id=\"form-link-button\"\n          >\n            {{ 'formManagement.gotoProcessLinksButton' | translate }}\n          </button>\n        </div>\n      }\n    }\n  </section>\n</cds-modal>\n"]}
|
|
@@ -15,7 +15,7 @@ import * as i1$1 from '@angular/router';
|
|
|
15
15
|
import { NavigationStart, RouterModule } from '@angular/router';
|
|
16
16
|
import * as i1$2 from 'ngx-logger';
|
|
17
17
|
import * as i2$2 from '@valtimo/components';
|
|
18
|
-
import { FormioOptionsImpl, TimelineItemImpl, CASES_WITHOUT_STATUS_KEY, CarbonListModule, ViewType, EllipsisPipe, FormIoModule, CARBON_THEME, CurrentCarbonTheme, WidgetModule,
|
|
18
|
+
import { FormioOptionsImpl, TimelineItemImpl, CASES_WITHOUT_STATUS_KEY, CarbonListModule, ViewType, EllipsisPipe, FormIoModule, CARBON_THEME, CurrentCarbonTheme, WidgetModule, CARBON_CONSTANTS, PendingChangesComponent, CarbonListComponent, pendingChangesGuard, ListModule, BpmnJsDiagramModule, TimelineModule, CamundaFormModule, FilterSidebarModule, DataListModule, ModalModule, SpinnerModule, UploaderModule, DropzoneModule, SelectModule, InputLabelModule, ParagraphModule, TableModule, VModalModule, TitleModule, ButtonModule as ButtonModule$1, SearchableDropdownSelectModule, SearchFieldsModule, PageModule, InputModule as InputModule$1, FormModule as FormModule$1, ConfirmationModalModule, IsArrayPipe, StatusSelectorComponent, RenderInPageHeaderDirectiveModule, ValtimoCdsOverflowButtonDirectiveModule, CaseTagsSelectorComponent, ValtimoCdsModalDirectiveModule } from '@valtimo/components';
|
|
19
19
|
export { CASES_WITHOUT_STATUS_KEY } from '@valtimo/components';
|
|
20
20
|
import moment from 'moment';
|
|
21
21
|
import * as i3 from '@valtimo/form';
|
|
@@ -3917,14 +3917,14 @@ class DossierSupportingProcessStartModalComponent {
|
|
|
3917
3917
|
this.processDefinitionKey$ = new BehaviorSubject('');
|
|
3918
3918
|
this.documentDefinitionName$ = new BehaviorSubject('');
|
|
3919
3919
|
this.processName$ = new BehaviorSubject('');
|
|
3920
|
-
this.formDefinition$ = new BehaviorSubject(
|
|
3921
|
-
this.formioSubmission$ = new BehaviorSubject(
|
|
3920
|
+
this.formDefinition$ = new BehaviorSubject(null);
|
|
3921
|
+
this.formioSubmission$ = new BehaviorSubject(null);
|
|
3922
3922
|
this.processLinkId$ = new BehaviorSubject('');
|
|
3923
|
-
this.options$ = new BehaviorSubject(
|
|
3924
|
-
this.submission$ = new BehaviorSubject(
|
|
3925
|
-
this.processDefinitionId$ = new BehaviorSubject(
|
|
3926
|
-
this.formFlowInstanceId$ = new BehaviorSubject(
|
|
3927
|
-
this.documentId$ = new BehaviorSubject(
|
|
3923
|
+
this.options$ = new BehaviorSubject(null);
|
|
3924
|
+
this.submission$ = new BehaviorSubject(null);
|
|
3925
|
+
this.processDefinitionId$ = new BehaviorSubject(null);
|
|
3926
|
+
this.formFlowInstanceId$ = new BehaviorSubject(null);
|
|
3927
|
+
this.documentId$ = new BehaviorSubject(null);
|
|
3928
3928
|
this.modalOpen$ = new BehaviorSubject(false);
|
|
3929
3929
|
this._formCustomComponentConfig$ = new BehaviorSubject({});
|
|
3930
3930
|
this.closeModalEvent = new EventEmitter();
|
|
@@ -3933,8 +3933,9 @@ class DossierSupportingProcessStartModalComponent {
|
|
|
3933
3933
|
this._formCustomComponentConfig$.next(formCustomComponentConfig);
|
|
3934
3934
|
}
|
|
3935
3935
|
loadProcessLink() {
|
|
3936
|
+
this.$loading.set(true);
|
|
3936
3937
|
combineLatest([this.processDefinitionId$, this.documentId$])
|
|
3937
|
-
.pipe(take$1(1), switchMap(([processDefinitionId, documentId]) => this.processService.getProcessDefinitionStartProcessLink(processDefinitionId, documentId,
|
|
3938
|
+
.pipe(take$1(1), switchMap(([processDefinitionId, documentId]) => this.processService.getProcessDefinitionStartProcessLink(processDefinitionId ?? '', documentId ?? '', '')))
|
|
3938
3939
|
.subscribe(startProcessResult => {
|
|
3939
3940
|
if (startProcessResult) {
|
|
3940
3941
|
this.isUIComponent = false;
|
|
@@ -3945,10 +3946,10 @@ class DossierSupportingProcessStartModalComponent {
|
|
|
3945
3946
|
this.processLinkId$.next(startProcessResult.processLinkId);
|
|
3946
3947
|
break;
|
|
3947
3948
|
case 'form-flow':
|
|
3948
|
-
this.formFlowInstanceId$.next(startProcessResult.properties.formFlowInstanceId);
|
|
3949
|
+
this.formFlowInstanceId$.next(startProcessResult.properties.formFlowInstanceId ?? null);
|
|
3949
3950
|
break;
|
|
3950
3951
|
case 'form-view-model':
|
|
3951
|
-
this.formDefinition$.next(startProcessResult.properties.formDefinition);
|
|
3952
|
+
this.formDefinition$.next(startProcessResult.properties.formDefinition ?? null);
|
|
3952
3953
|
this.setFormViewModelComponent(startProcessResult.properties.formName);
|
|
3953
3954
|
break;
|
|
3954
3955
|
case 'ui-component':
|
|
@@ -3956,8 +3957,8 @@ class DossierSupportingProcessStartModalComponent {
|
|
|
3956
3957
|
this.isUIComponent = true;
|
|
3957
3958
|
break;
|
|
3958
3959
|
}
|
|
3959
|
-
this.$loading.set(false);
|
|
3960
3960
|
}
|
|
3961
|
+
this.$loading.set(false);
|
|
3961
3962
|
});
|
|
3962
3963
|
}
|
|
3963
3964
|
openModal(processDocumentDefinition, documentId) {
|
|
@@ -3980,7 +3981,7 @@ class DossierSupportingProcessStartModalComponent {
|
|
|
3980
3981
|
this.formioSubmission$.next(submission);
|
|
3981
3982
|
if (this.processLinkId$.getValue()) {
|
|
3982
3983
|
combineLatest([this.processLinkId$, this.documentId$])
|
|
3983
|
-
.pipe(take$1(1), switchMap(([processLinkId, documentId]) => this.processLinkService.submitForm(processLinkId, submission.data, documentId)))
|
|
3984
|
+
.pipe(take$1(1), switchMap(([processLinkId, documentId]) => this.processLinkService.submitForm(processLinkId, submission.data, documentId ?? '')))
|
|
3984
3985
|
.subscribe({
|
|
3985
3986
|
next: (formSubmissionResult) => {
|
|
3986
3987
|
this.formSubmitted();
|
|
@@ -3994,7 +3995,6 @@ class DossierSupportingProcessStartModalComponent {
|
|
|
3994
3995
|
formSubmitted() {
|
|
3995
3996
|
this.closeCdsModal();
|
|
3996
3997
|
this.formSubmit.emit();
|
|
3997
|
-
this.formDefinition$.next(null);
|
|
3998
3998
|
}
|
|
3999
3999
|
gotoFormLinkScreen() {
|
|
4000
4000
|
this.closeCdsModal();
|
|
@@ -4006,7 +4006,7 @@ class DossierSupportingProcessStartModalComponent {
|
|
|
4006
4006
|
this.closeCdsModal();
|
|
4007
4007
|
}
|
|
4008
4008
|
setFormViewModelComponent(formName) {
|
|
4009
|
-
if (!this.formViewModel.component)
|
|
4009
|
+
if (!this.formViewModel.component || !formName)
|
|
4010
4010
|
return;
|
|
4011
4011
|
this.formViewModelDynamicContainer.clear();
|
|
4012
4012
|
const formViewModelComponent = this.formViewModelDynamicContainer.createComponent(this.formViewModel.component);
|
|
@@ -4037,7 +4037,7 @@ class DossierSupportingProcessStartModalComponent {
|
|
|
4037
4037
|
}
|
|
4038
4038
|
setFormCustomComponent(formCustomComponentKey) {
|
|
4039
4039
|
this.formCustomComponentDynamicContainer.clear();
|
|
4040
|
-
if (!this.formCustomComponentConfig)
|
|
4040
|
+
if (!this.formCustomComponentConfig || !formCustomComponentKey)
|
|
4041
4041
|
return;
|
|
4042
4042
|
this._formCustomComponentConfig$.pipe(take$1(1)).subscribe(formCustomComponentConfig => {
|
|
4043
4043
|
const customComponent = formCustomComponentConfig[formCustomComponentKey];
|
|
@@ -4059,11 +4059,17 @@ class DossierSupportingProcessStartModalComponent {
|
|
|
4059
4059
|
closeCdsModal() {
|
|
4060
4060
|
this.modalOpen$.next(false);
|
|
4061
4061
|
this.closeModalEvent.emit();
|
|
4062
|
+
this.reset();
|
|
4062
4063
|
}
|
|
4063
4064
|
openCdsModal() {
|
|
4064
|
-
this.loadProcessLink();
|
|
4065
4065
|
this.modalOpen$.next(true);
|
|
4066
4066
|
}
|
|
4067
|
+
reset() {
|
|
4068
|
+
setTimeout(() => {
|
|
4069
|
+
this.formDefinition$.next(null);
|
|
4070
|
+
this.formFlowInstanceId$.next(null);
|
|
4071
|
+
}, CARBON_CONSTANTS.modalAnimationMs);
|
|
4072
|
+
}
|
|
4067
4073
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DossierSupportingProcessStartModalComponent, deps: [{ token: i1$1.Router }, { token: i2$3.ProcessService }, { token: i3$3.ProcessLinkService }, { token: FORM_VIEW_MODEL_TOKEN, optional: true }, { token: FORM_CUSTOM_COMPONENT_TOKEN, optional: true }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
4068
4074
|
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: DossierSupportingProcessStartModalComponent, selector: "valtimo-dossier-supporting-process-start-modal", inputs: { isAdmin: "isAdmin" }, outputs: { formSubmit: "formSubmit" }, viewQueries: [{ propertyName: "form", first: true, predicate: ["form"], descendants: true }, { propertyName: "formViewModelDynamicContainer", first: true, predicate: ["formViewModelComponent"], descendants: true, read: ViewContainerRef, static: true }, { propertyName: "formCustomComponentDynamicContainer", first: true, predicate: ["formCustomComponent"], descendants: true, read: ViewContainerRef }], 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<cds-modal [open]=\"modalOpen$ | async\" valtimoCdsModal size=\"sm\">\n <cds-modal-header [showCloseButton]=\"true\" (closeSelect)=\"onCloseSelect()\" [cdsLayer]=\"1\"\n ><h3 cdsModalHeaderHeading>\n {{\n (processDefinitionKey$ | async | translate) !== (processDefinitionKey$ | async)\n ? (processDefinitionKey$ | async | translate)\n : (processName$ | async)\n }}\n </h3>\n </cds-modal-header>\n\n <section cdsModalContent [cdsLayer]=\"1\">\n <ng-template #formViewModelComponent></ng-template>\n <ng-template #formCustomComponent></ng-template>\n\n @if ($loading()) {\n <cds-loading></cds-loading>\n } @else {\n @if (!isFormViewModel && !isUIComponent && (formDefinition$ | async)) {\n <valtimo-form-io\n #form\n [submission]=\"submission$ | async\"\n [form]=\"formDefinition$ | async\"\n [options]=\"options$ | async\"\n (submit)=\"onSubmit($event)\"\n ></valtimo-form-io>\n }\n\n @if (formFlowInstanceId$ | async) {\n <valtimo-form-flow\n #formFlow\n [formFlowInstanceId]=\"formFlowInstanceId$ | async\"\n (formFlowComplete)=\"formSubmitted()\"\n ></valtimo-form-flow>\n }\n\n @if (!(formDefinition$ | async) && !(formFlowInstanceId$ | async) && !isUIComponent) {\n <div class=\"bg-warning text-black mb-0 p-3 text-center\">\n {{\n isAdmin\n ? ('formManagement.noFormDefinitionFoundAdmin' | translate)\n : ('formManagement.noFormDefinitionFoundUser' | translate)\n }}\n </div>\n <div class=\"mb-0 mt-4 p-3 text-center\">\n <button\n class=\"btn btn-secondary btn-space\"\n type=\"button\"\n (click)=\"gotoFormLinkScreen()\"\n id=\"form-link-button\"\n >\n {{ 'formManagement.gotoProcessLinksButton' | translate }}\n </button>\n </div>\n }\n }\n </section>\n</cds-modal>\n", styles: ["#supportingProcessStartModal .formio-component-submit{text-align:right}cds-loading{display:flex;justify-content: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: "component", type: i2$2.FormioComponent, selector: "valtimo-form-io", inputs: ["options", "submission", "form", "readOnly", "formRefresh$"], outputs: ["submit", "change", "event"] }, { kind: "component", type: i5.Loading, selector: "cds-loading, ibm-loading", inputs: ["title", "isActive", "size", "overlay"] }, { kind: "component", type: i3$3.FormFlowComponent, selector: "valtimo-form-flow", inputs: ["formIoFormData", "formFlowInstanceId"], outputs: ["formFlowComplete", "formFlowChange"] }, { kind: "component", type: i5.Modal, selector: "cds-modal, ibm-modal", inputs: ["size", "theme", "ariaLabel", "open", "trigger", "hasScrollingContent"], outputs: ["overlaySelected", "close"] }, { kind: "component", type: i5.ModalHeader, selector: "cds-modal-header, ibm-modal-header", inputs: ["theme", "closeLabel", "showCloseButton"], outputs: ["closeSelect"] }, { kind: "directive", type: i5.ModalContent, selector: "[cdsModalContent], [ibmModalContent]", inputs: ["hasForm"] }, { kind: "directive", type: i5.ModalHeaderHeading, selector: "[cdsModalHeaderHeading], [ibmModalHeaderHeading]" }, { kind: "directive", type: i2$2.ValtimoCdsModalDirective, selector: "[valtimoCdsModal]", inputs: ["enableOverflow"] }, { kind: "directive", type: i5.LayerDirective, selector: "[cdsLayer], [ibmLayer]", inputs: ["ibmLayer", "cdsLayer"], exportAs: ["layer"] }, { kind: "pipe", type: i6$1.AsyncPipe, name: "async" }, { kind: "pipe", type: i6.TranslatePipe, name: "translate" }], encapsulation: i0.ViewEncapsulation.None }); }
|
|
4069
4075
|
}
|