@valtimo/dossier 10.8.1 → 10.8.2

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.
@@ -15,8 +15,8 @@
15
15
  */
16
16
  import { Component, EventEmitter, Output, ViewChild, ViewEncapsulation } from '@angular/core';
17
17
  import { FormioOptionsImpl, } from '@valtimo/components';
18
- import { noop } from 'rxjs';
19
- import { map, take } from 'rxjs/operators';
18
+ import { BehaviorSubject, combineLatest, of, switchMap, tap } from 'rxjs';
19
+ import { catchError, map, take } from 'rxjs/operators';
20
20
  import * as i0 from "@angular/core";
21
21
  import * as i1 from "@angular/router";
22
22
  import * as i2 from "@valtimo/process";
@@ -38,77 +38,72 @@ export class DossierSupportingProcessStartModalComponent {
38
38
  this.formFlowService = formFlowService;
39
39
  this.logger = logger;
40
40
  this.userProviderService = userProviderService;
41
+ this.formSubmit = new EventEmitter();
42
+ this.processDefinitionKey$ = new BehaviorSubject('');
43
+ this.documentDefinitionName$ = new BehaviorSubject('');
44
+ this.processName$ = new BehaviorSubject('');
45
+ this.formDefinition$ = new BehaviorSubject(undefined);
46
+ this.formioSubmission$ = new BehaviorSubject(undefined);
47
+ this.formAssociation$ = new BehaviorSubject(undefined);
48
+ this.processLinkId$ = new BehaviorSubject('');
49
+ this.options$ = new BehaviorSubject(undefined);
50
+ this.submission$ = new BehaviorSubject(undefined);
51
+ this.processDefinitionId$ = new BehaviorSubject(undefined);
52
+ this.formFlowInstanceId$ = new BehaviorSubject(undefined);
53
+ this.documentId$ = new BehaviorSubject(undefined);
41
54
  this.isAdmin$ = this.userProviderService
42
55
  .getUserSubject()
43
56
  .pipe(map(userIdentity => userIdentity?.roles?.includes('ROLE_ADMIN')));
44
- this.formSubmit = new EventEmitter();
45
57
  }
46
58
  loadProcessLink() {
47
- this.formAssociation = null;
48
- this.processLinkId = null;
49
- this.formDefinition = null;
50
- this.formFlowInstanceId = null;
51
- this.processService
52
- .getProcessDefinitionStartProcessLink(this.processDefinitionId, this.documentId, null)
53
- .pipe(take(1))
59
+ combineLatest([this.processDefinitionId$, this.documentId$])
60
+ .pipe(take(1), switchMap(([processDefinitionId, documentId]) => this.processService.getProcessDefinitionStartProcessLink(processDefinitionId, documentId, null)))
54
61
  .subscribe(startProcessResult => {
55
62
  if (startProcessResult) {
56
63
  switch (startProcessResult.type) {
57
64
  case 'form':
58
- this.formDefinition = startProcessResult.properties.prefilledForm;
59
- this.processLinkId = startProcessResult.processLinkId;
65
+ this.formDefinition$.next(startProcessResult.properties.prefilledForm);
66
+ this.processLinkId$.next(startProcessResult.processLinkId);
60
67
  break;
61
68
  case 'form-flow':
62
- this.formFlowInstanceId = startProcessResult.properties.formFlowInstanceId;
69
+ this.formFlowInstanceId$.next(startProcessResult.properties.formFlowInstanceId);
63
70
  break;
64
71
  }
65
72
  this.modal.show();
66
73
  }
67
74
  else {
68
75
  // backwards compatibility for form associations
69
- this.formLinkService
70
- .getStartEventFormDefinitionByProcessDefinitionKey(this.processDefinitionKey, this.documentId)
71
- .pipe(take(1))
72
- .subscribe({
73
- next: formDefinitionWithFormAssociation => this.openFormAssociation(formDefinitionWithFormAssociation),
74
- error: error => {
75
- this.modal.show();
76
- },
77
- });
76
+ combineLatest([this.processDefinitionKey$, this.documentId$])
77
+ .pipe(take(1), switchMap(([processDefinitionKey, documentId]) => this.formLinkService.getStartEventFormDefinitionByProcessDefinitionKey(processDefinitionKey, documentId)), tap(formDefinitionWithFormAssociation => {
78
+ this.openFormAssociation(formDefinitionWithFormAssociation);
79
+ }), catchError(() => {
80
+ this.modal.show();
81
+ return of(null);
82
+ }))
83
+ .subscribe();
78
84
  }
79
85
  });
80
86
  }
81
87
  openFormAssociation(formDefinitionWithFormAssociation) {
82
- this.formAssociation = formDefinitionWithFormAssociation.formAssociation;
83
- const className = this.formAssociation.formLink.className.split('.');
88
+ const formAssociation = formDefinitionWithFormAssociation.formAssociation;
89
+ const className = formAssociation.formLink.className.split('.');
90
+ this.formAssociation$.next(formAssociation);
84
91
  const linkType = className[className.length - 1];
85
92
  switch (linkType) {
86
93
  case 'BpmnElementFormIdLink':
87
- this.formDefinition = formDefinitionWithFormAssociation;
88
- this.documentService.getDocument(this.documentId).subscribe(document => {
89
- this.submission = {
90
- data: document.content,
91
- };
92
- }, () => noop());
93
- this.modal.show();
94
+ this.setFormDefinition(formDefinitionWithFormAssociation);
94
95
  break;
95
96
  case 'BpmnElementFormFlowIdLink':
96
- this.formFlowService
97
- .createInstanceForNewProcess(this.processDefinitionKey, {
98
- documentId: this.documentId,
99
- documentDefinitionName: null,
100
- })
101
- .subscribe(result => (this.formFlowInstanceId = result.formFlowInstanceId));
102
- this.modal.show();
97
+ this.setFormFlow();
103
98
  break;
104
99
  case 'BpmnElementUrlLink':
105
- const url = this.router.serializeUrl(this.router.createUrlTree([this.formAssociation.formLink.url]));
100
+ const url = this.router.serializeUrl(this.router.createUrlTree([this.formAssociation$.getValue().formLink.url]));
106
101
  window.open(url, '_blank');
107
102
  break;
108
103
  case 'BpmnElementAngularStateUrlLink':
109
104
  this.route.params.pipe(take(1)).subscribe(params => {
110
105
  const documentId = params?.documentId;
111
- this.router.navigate([this.formAssociation.formLink.url], {
106
+ this.router.navigate([this.formAssociation$.getValue().formLink.url], {
112
107
  state: { ...(documentId && { documentId }) },
113
108
  });
114
109
  });
@@ -118,24 +113,25 @@ export class DossierSupportingProcessStartModalComponent {
118
113
  }
119
114
  }
120
115
  openModal(processDocumentDefinition, documentId) {
121
- this.documentId = documentId;
122
- this.documentDefinitionName = processDocumentDefinition.id.documentDefinitionId.name;
123
- this.processDefinitionKey = processDocumentDefinition.id.processDefinitionKey;
124
- this.processDefinitionId = processDocumentDefinition.latestVersionId;
125
- this.processName = processDocumentDefinition.processName;
126
- this.options = new FormioOptionsImpl();
127
- this.options.disableAlerts = true;
116
+ this.documentId$.next(documentId);
117
+ this.documentDefinitionName$.next(processDocumentDefinition.id.documentDefinitionId.name);
118
+ this.processDefinitionKey$.next(processDocumentDefinition.id.processDefinitionKey);
119
+ this.processDefinitionId$.next(processDocumentDefinition.latestVersionId);
120
+ this.processName$.next(processDocumentDefinition.processName);
128
121
  const formioBeforeSubmit = function (submission, callback) {
129
122
  callback(null, submission);
130
123
  };
131
- this.options.setHooks(formioBeforeSubmit);
124
+ const options = new FormioOptionsImpl();
125
+ options.disableAlerts = true;
126
+ options.setHooks(formioBeforeSubmit);
127
+ this.options$.next(options);
132
128
  this.loadProcessLink();
133
129
  }
134
130
  onSubmit(submission) {
135
- this.formioSubmission = submission;
136
- if (this.processLinkId) {
137
- this.processLinkService
138
- .submitForm(this.processLinkId, submission.data, this.documentId)
131
+ this.formioSubmission$.next(submission);
132
+ if (this.processLinkId$.getValue()) {
133
+ combineLatest([this.processLinkId$, this.documentId$])
134
+ .pipe(take(1), switchMap(([processLinkId, documentId]) => this.processLinkService.submitForm(processLinkId, submission.data, documentId)))
139
135
  .subscribe({
140
136
  next: (formSubmissionResult) => {
141
137
  this.formSubmitted();
@@ -146,8 +142,8 @@ export class DossierSupportingProcessStartModalComponent {
146
142
  });
147
143
  }
148
144
  else {
149
- this.formLinkService
150
- .onSubmit(this.processDefinitionKey, this.formAssociation.formLink.id, submission.data, this.documentId)
145
+ combineLatest([this.processDefinitionKey$, this.formAssociation$, this.documentId$])
146
+ .pipe(take(1), switchMap(([processDefinitionKey, formAssociation, documentId]) => this.formLinkService.onSubmit(processDefinitionKey, formAssociation.formLink.id, submission.data, documentId)))
151
147
  .subscribe((formSubmissionResult) => {
152
148
  this.formSubmitted();
153
149
  }, errors => {
@@ -161,14 +157,40 @@ export class DossierSupportingProcessStartModalComponent {
161
157
  }
162
158
  gotoFormLinkScreen() {
163
159
  this.modal.hide();
164
- this.router.navigate(['form-links'], { queryParams: { process: this.processDefinitionKey } });
160
+ this.router.navigate(['form-links'], {
161
+ queryParams: { process: this.processDefinitionKey$.getValue() },
162
+ });
163
+ }
164
+ setFormDefinition(formDefinitionWithFormAssociation) {
165
+ this.formDefinition$.next(formDefinitionWithFormAssociation);
166
+ this.documentId$
167
+ .pipe(take(1), switchMap(documentId => this.documentService.getDocument(documentId)), tap(document => {
168
+ this.submission$.next({
169
+ data: document.content,
170
+ });
171
+ }), tap(() => {
172
+ this.modal.show();
173
+ }))
174
+ .subscribe();
175
+ }
176
+ setFormFlow() {
177
+ combineLatest([this.processDefinitionKey$, this.documentId$])
178
+ .pipe(take(1), switchMap(([processDefinitionKey, documentId]) => this.formFlowService.createInstanceForNewProcess(processDefinitionKey, {
179
+ documentId,
180
+ documentDefinitionName: null,
181
+ })), tap(result => {
182
+ this.formFlowInstanceId$.next(result.formFlowInstanceId);
183
+ }), tap(() => {
184
+ this.modal.show();
185
+ }))
186
+ .subscribe();
165
187
  }
166
188
  }
167
189
  DossierSupportingProcessStartModalComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: DossierSupportingProcessStartModalComponent, deps: [{ token: i1.ActivatedRoute }, { token: i1.Router }, { token: i2.ProcessService }, { token: i3.ProcessLinkService }, { token: i4.DocumentService }, { token: i3.FormLinkService }, { token: i3.FormFlowService }, { token: i5.NGXLogger }, { token: i6.UserProviderService }], target: i0.ɵɵFactoryTarget.Component });
168
- DossierSupportingProcessStartModalComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: DossierSupportingProcessStartModalComponent, selector: "valtimo-dossier-supporting-process-start-modal", outputs: { formSubmit: "formSubmit" }, viewQueries: [{ propertyName: "form", first: true, predicate: ["form"], descendants: true }, { propertyName: "modal", first: true, predicate: ["supportingProcessStartModal"], descendants: true }], ngImport: i0, template: "<!--\n ~ Copyright 2015-2023 Ritense BV, the Netherlands.\n ~\n ~ Licensed under EUPL, Version 1.2 (the \"License\");\n ~ you may not use this file except in compliance with the License.\n ~ You may obtain a copy of the License at\n ~\n ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n ~\n ~ Unless required by applicable law or agreed to in writing, software\n ~ distributed under the License is distributed on an \"AS IS\" basis,\n ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n ~ See the License for the specific language governing permissions and\n ~ limitations under the License.\n -->\n\n<valtimo-modal\n #supportingProcessStartModal\n elementId=\"supportingProcessStartModal\"\n [title]=\"\n (processDefinitionKey | translate) !== processDefinitionKey\n ? (processDefinitionKey | translate)\n : processName\n \"\n>\n <div body *ngIf=\"formDefinition\">\n <valtimo-form-io\n #form\n [submission]=\"submission\"\n [form]=\"formDefinition\"\n [options]=\"options\"\n (submit)=\"onSubmit($event)\"\n >\n </valtimo-form-io>\n </div>\n <div body *ngIf=\"formFlowInstanceId\">\n <valtimo-form-flow\n #formFlow\n [formFlowInstanceId]=\"formFlowInstanceId\"\n (formFlowComplete)=\"formSubmitted()\"\n ></valtimo-form-flow>\n </div>\n <div body *ngIf=\"!formDefinition && !formFlowInstanceId\">\n <div class=\"bg-warning text-black mb-0 p-3 text-center\">\n {{\n (isAdmin$ | async)\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.gotoFormLinksButton' | translate }}\n </button>\n </div>\n </div>\n</valtimo-modal>\n", styles: ["/*!\n * Copyright 2015-2023 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 */#supportingProcessStartModal .formio-component-submit{text-align:right}\n"], dependencies: [{ kind: "directive", type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i8.FormioComponent, selector: "valtimo-form-io", inputs: ["form", "options", "submission", "readOnly", "formRefresh$"], outputs: ["submit", "change"] }, { kind: "component", type: i8.ModalComponent, selector: "valtimo-modal", inputs: ["elementId", "title", "subtitle", "templateBelowSubtitle", "showFooter"] }, { kind: "component", type: i3.FormFlowComponent, selector: "valtimo-form-flow", inputs: ["formIoFormData", "formFlowInstanceId"], outputs: ["formFlowComplete"] }, { kind: "pipe", type: i7.AsyncPipe, name: "async" }, { kind: "pipe", type: i9.TranslatePipe, name: "translate" }], encapsulation: i0.ViewEncapsulation.None });
190
+ DossierSupportingProcessStartModalComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: DossierSupportingProcessStartModalComponent, selector: "valtimo-dossier-supporting-process-start-modal", outputs: { formSubmit: "formSubmit" }, viewQueries: [{ propertyName: "form", first: true, predicate: ["form"], descendants: true }, { propertyName: "modal", first: true, predicate: ["supportingProcessStartModal"], descendants: true }], ngImport: i0, template: "<!--\n ~ Copyright 2015-2023 Ritense BV, the Netherlands.\n ~\n ~ Licensed under EUPL, Version 1.2 (the \"License\");\n ~ you may not use this file except in compliance with the License.\n ~ You may obtain a copy of the License at\n ~\n ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n ~\n ~ Unless required by applicable law or agreed to in writing, software\n ~ distributed under the License is distributed on an \"AS IS\" basis,\n ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n ~ See the License for the specific language governing permissions and\n ~ limitations under the License.\n -->\n\n<valtimo-modal\n *ngIf=\"{\n processDefinitionKey: processDefinitionKey$ | async,\n processName: processName$ | async\n } as vars\"\n #supportingProcessStartModal\n elementId=\"supportingProcessStartModal\"\n [title]=\"\n (vars.processDefinitionKey | translate) !== vars.processDefinitionKey\n ? (vars.processDefinitionKey | translate)\n : vars.processName\n \"\n>\n <div body *ngIf=\"formDefinition$ | async as formDefinition\">\n <valtimo-form-io\n #form\n [submission]=\"submission$ | async\"\n [form]=\"formDefinition\"\n [options]=\"options$ | async\"\n (submit)=\"onSubmit($event)\"\n >\n </valtimo-form-io>\n </div>\n <div body *ngIf=\"formFlowInstanceId$ | async as formFlowInstanceId\">\n <valtimo-form-flow\n #formFlow\n [formFlowInstanceId]=\"formFlowInstanceId\"\n (formFlowComplete)=\"formSubmitted()\"\n ></valtimo-form-flow>\n </div>\n\n <ng-container\n *ngIf=\"{\n formDefinition: formDefinition$ | async,\n formFlowInstanceId: formFlowInstanceId$ | async\n } as obs\"\n >\n <div body *ngIf=\"!obs.formDefinition && !obs.formFlowInstanceId\">\n <div class=\"bg-warning text-black mb-0 p-3 text-center\">\n {{\n (isAdmin$ | async)\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.gotoFormLinksButton' | translate }}\n </button>\n </div>\n </div>\n </ng-container>\n</valtimo-modal>\n", styles: ["/*!\n * Copyright 2015-2023 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 */#supportingProcessStartModal .formio-component-submit{text-align:right}\n"], dependencies: [{ kind: "directive", type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i8.FormioComponent, selector: "valtimo-form-io", inputs: ["options", "submission", "form", "readOnly", "formRefresh$"], outputs: ["submit", "change"] }, { kind: "component", type: i8.ModalComponent, selector: "valtimo-modal", inputs: ["elementId", "title", "subtitle", "templateBelowSubtitle", "showFooter"] }, { kind: "component", type: i3.FormFlowComponent, selector: "valtimo-form-flow", inputs: ["formIoFormData", "formFlowInstanceId"], outputs: ["formFlowComplete"] }, { kind: "pipe", type: i7.AsyncPipe, name: "async" }, { kind: "pipe", type: i9.TranslatePipe, name: "translate" }], encapsulation: i0.ViewEncapsulation.None });
169
191
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: DossierSupportingProcessStartModalComponent, decorators: [{
170
192
  type: Component,
171
- args: [{ selector: 'valtimo-dossier-supporting-process-start-modal', encapsulation: ViewEncapsulation.None, template: "<!--\n ~ Copyright 2015-2023 Ritense BV, the Netherlands.\n ~\n ~ Licensed under EUPL, Version 1.2 (the \"License\");\n ~ you may not use this file except in compliance with the License.\n ~ You may obtain a copy of the License at\n ~\n ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n ~\n ~ Unless required by applicable law or agreed to in writing, software\n ~ distributed under the License is distributed on an \"AS IS\" basis,\n ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n ~ See the License for the specific language governing permissions and\n ~ limitations under the License.\n -->\n\n<valtimo-modal\n #supportingProcessStartModal\n elementId=\"supportingProcessStartModal\"\n [title]=\"\n (processDefinitionKey | translate) !== processDefinitionKey\n ? (processDefinitionKey | translate)\n : processName\n \"\n>\n <div body *ngIf=\"formDefinition\">\n <valtimo-form-io\n #form\n [submission]=\"submission\"\n [form]=\"formDefinition\"\n [options]=\"options\"\n (submit)=\"onSubmit($event)\"\n >\n </valtimo-form-io>\n </div>\n <div body *ngIf=\"formFlowInstanceId\">\n <valtimo-form-flow\n #formFlow\n [formFlowInstanceId]=\"formFlowInstanceId\"\n (formFlowComplete)=\"formSubmitted()\"\n ></valtimo-form-flow>\n </div>\n <div body *ngIf=\"!formDefinition && !formFlowInstanceId\">\n <div class=\"bg-warning text-black mb-0 p-3 text-center\">\n {{\n (isAdmin$ | async)\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.gotoFormLinksButton' | translate }}\n </button>\n </div>\n </div>\n</valtimo-modal>\n", styles: ["/*!\n * Copyright 2015-2023 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 */#supportingProcessStartModal .formio-component-submit{text-align:right}\n"] }]
193
+ args: [{ selector: 'valtimo-dossier-supporting-process-start-modal', encapsulation: ViewEncapsulation.None, template: "<!--\n ~ Copyright 2015-2023 Ritense BV, the Netherlands.\n ~\n ~ Licensed under EUPL, Version 1.2 (the \"License\");\n ~ you may not use this file except in compliance with the License.\n ~ You may obtain a copy of the License at\n ~\n ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n ~\n ~ Unless required by applicable law or agreed to in writing, software\n ~ distributed under the License is distributed on an \"AS IS\" basis,\n ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n ~ See the License for the specific language governing permissions and\n ~ limitations under the License.\n -->\n\n<valtimo-modal\n *ngIf=\"{\n processDefinitionKey: processDefinitionKey$ | async,\n processName: processName$ | async\n } as vars\"\n #supportingProcessStartModal\n elementId=\"supportingProcessStartModal\"\n [title]=\"\n (vars.processDefinitionKey | translate) !== vars.processDefinitionKey\n ? (vars.processDefinitionKey | translate)\n : vars.processName\n \"\n>\n <div body *ngIf=\"formDefinition$ | async as formDefinition\">\n <valtimo-form-io\n #form\n [submission]=\"submission$ | async\"\n [form]=\"formDefinition\"\n [options]=\"options$ | async\"\n (submit)=\"onSubmit($event)\"\n >\n </valtimo-form-io>\n </div>\n <div body *ngIf=\"formFlowInstanceId$ | async as formFlowInstanceId\">\n <valtimo-form-flow\n #formFlow\n [formFlowInstanceId]=\"formFlowInstanceId\"\n (formFlowComplete)=\"formSubmitted()\"\n ></valtimo-form-flow>\n </div>\n\n <ng-container\n *ngIf=\"{\n formDefinition: formDefinition$ | async,\n formFlowInstanceId: formFlowInstanceId$ | async\n } as obs\"\n >\n <div body *ngIf=\"!obs.formDefinition && !obs.formFlowInstanceId\">\n <div class=\"bg-warning text-black mb-0 p-3 text-center\">\n {{\n (isAdmin$ | async)\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.gotoFormLinksButton' | translate }}\n </button>\n </div>\n </div>\n </ng-container>\n</valtimo-modal>\n", styles: ["/*!\n * Copyright 2015-2023 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 */#supportingProcessStartModal .formio-component-submit{text-align:right}\n"] }]
172
194
  }], ctorParameters: function () { return [{ type: i1.ActivatedRoute }, { type: i1.Router }, { type: i2.ProcessService }, { type: i3.ProcessLinkService }, { type: i4.DocumentService }, { type: i3.FormLinkService }, { type: i3.FormFlowService }, { type: i5.NGXLogger }, { type: i6.UserProviderService }]; }, propDecorators: { form: [{
173
195
  type: ViewChild,
174
196
  args: ['form', { static: false }]
@@ -178,4 +200,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
178
200
  }], formSubmit: [{
179
201
  type: Output
180
202
  }] } });
181
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dossier-supporting-process-start-modal.component.js","sourceRoot":"","sources":["../../../../../../projects/valtimo/dossier/src/lib/dossier-supporting-process-start-modal/dossier-supporting-process-start-modal.component.ts","../../../../../../projects/valtimo/dossier/src/lib/dossier-supporting-process-start-modal/dossier-supporting-process-start-modal.component.html"],"names":[],"mappings":"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","sourcesContent":["/*\n * Copyright 2015-2023 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, EventEmitter, Output, ViewChild, ViewEncapsulation} from '@angular/core';\nimport {FormioBeforeSubmit, FormioForm} from '@formio/angular';\nimport {\n  FormioComponent,\n  FormioOptionsImpl,\n  FormioSubmission,\n  ModalComponent,\n  ValtimoFormioOptions,\n} from '@valtimo/components';\nimport {ActivatedRoute, Router} from '@angular/router';\nimport {ProcessService} from '@valtimo/process';\nimport {DocumentService, ProcessDocumentDefinition} from '@valtimo/document';\nimport {\n  FormAssociation,\n  FormFlowService,\n  FormLinkService,\n  FormSubmissionResult,\n  ProcessLinkService,\n} from '@valtimo/form-link';\nimport {NGXLogger} from 'ngx-logger';\nimport {noop, Observable} from 'rxjs';\nimport {map, take} from 'rxjs/operators';\nimport {UserProviderService} from '@valtimo/security';\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  public processDefinitionKey: string;\n  public documentDefinitionName: string;\n  public processName: string;\n  public formDefinition: FormioForm;\n  public formioSubmission: FormioSubmission;\n  private formAssociation: FormAssociation;\n  private processLinkId: string;\n  public options: ValtimoFormioOptions;\n  public submission: object;\n  public processDefinitionId: string;\n  public formFlowInstanceId: string;\n\n  readonly isAdmin$: Observable<boolean> = this.userProviderService\n    .getUserSubject()\n    .pipe(map(userIdentity => userIdentity?.roles?.includes('ROLE_ADMIN')));\n\n  @ViewChild('form', {static: false}) form: FormioComponent;\n  @ViewChild('supportingProcessStartModal', {static: false}) modal: ModalComponent;\n  @Output() formSubmit = new EventEmitter();\n\n  private documentId: string;\n\n  constructor(\n    private route: ActivatedRoute,\n    private router: Router,\n    private processService: ProcessService,\n    private processLinkService: ProcessLinkService,\n    private documentService: DocumentService,\n    private formLinkService: FormLinkService,\n    private formFlowService: FormFlowService,\n    private logger: NGXLogger,\n    private readonly userProviderService: UserProviderService\n  ) {}\n\n  private loadProcessLink() {\n    this.formAssociation = null;\n    this.processLinkId = null;\n    this.formDefinition = null;\n    this.formFlowInstanceId = null;\n    this.processService\n      .getProcessDefinitionStartProcessLink(this.processDefinitionId, this.documentId, null)\n      .pipe(take(1))\n      .subscribe(startProcessResult => {\n        if (startProcessResult) {\n          switch (startProcessResult.type) {\n            case 'form':\n              this.formDefinition = startProcessResult.properties.prefilledForm;\n              this.processLinkId = startProcessResult.processLinkId;\n              break;\n            case 'form-flow':\n              this.formFlowInstanceId = startProcessResult.properties.formFlowInstanceId;\n              break;\n          }\n          this.modal.show();\n        } else {\n          // backwards compatibility for form associations\n          this.formLinkService\n            .getStartEventFormDefinitionByProcessDefinitionKey(\n              this.processDefinitionKey,\n              this.documentId\n            )\n            .pipe(take(1))\n            .subscribe({\n              next: formDefinitionWithFormAssociation =>\n                this.openFormAssociation(formDefinitionWithFormAssociation),\n              error: error => {\n                this.modal.show();\n              },\n            });\n        }\n      });\n  }\n\n  private openFormAssociation(formDefinitionWithFormAssociation: any) {\n    this.formAssociation = formDefinitionWithFormAssociation.formAssociation;\n    const className = this.formAssociation.formLink.className.split('.');\n    const linkType = className[className.length - 1];\n    switch (linkType) {\n      case 'BpmnElementFormIdLink':\n        this.formDefinition = formDefinitionWithFormAssociation;\n        this.documentService.getDocument(this.documentId).subscribe(\n          document => {\n            this.submission = {\n              data: document.content,\n            };\n          },\n          () => noop()\n        );\n        this.modal.show();\n        break;\n      case 'BpmnElementFormFlowIdLink':\n        this.formFlowService\n          .createInstanceForNewProcess(this.processDefinitionKey, {\n            documentId: this.documentId,\n            documentDefinitionName: null,\n          })\n          .subscribe(result => (this.formFlowInstanceId = result.formFlowInstanceId));\n        this.modal.show();\n        break;\n      case 'BpmnElementUrlLink':\n        const url = this.router.serializeUrl(\n          this.router.createUrlTree([this.formAssociation.formLink.url])\n        );\n        window.open(url, '_blank');\n        break;\n      case 'BpmnElementAngularStateUrlLink':\n        this.route.params.pipe(take(1)).subscribe(params => {\n          const documentId = params?.documentId;\n\n          this.router.navigate([this.formAssociation.formLink.url], {\n            state: {...(documentId && {documentId})},\n          });\n        });\n        break;\n      default:\n        this.logger.fatal('Unsupported class name');\n    }\n  }\n\n  openModal(processDocumentDefinition: ProcessDocumentDefinition, documentId: string) {\n    this.documentId = documentId;\n    this.documentDefinitionName = processDocumentDefinition.id.documentDefinitionId.name;\n    this.processDefinitionKey = processDocumentDefinition.id.processDefinitionKey;\n    this.processDefinitionId = processDocumentDefinition.latestVersionId;\n    this.processName = processDocumentDefinition.processName;\n    this.options = new FormioOptionsImpl();\n    this.options.disableAlerts = true;\n    const formioBeforeSubmit: FormioBeforeSubmit = function (submission, callback) {\n      callback(null, submission);\n    };\n    this.options.setHooks(formioBeforeSubmit);\n    this.loadProcessLink();\n  }\n\n  public onSubmit(submission: FormioSubmission) {\n    this.formioSubmission = submission;\n    if (this.processLinkId) {\n      this.processLinkService\n        .submitForm(this.processLinkId, submission.data, this.documentId)\n        .subscribe({\n          next: (formSubmissionResult: FormSubmissionResult) => {\n            this.formSubmitted();\n          },\n          error: errors => {\n            this.form.showErrors(errors);\n          },\n        });\n    } else {\n      this.formLinkService\n        .onSubmit(\n          this.processDefinitionKey,\n          this.formAssociation.formLink.id,\n          submission.data,\n          this.documentId\n        )\n        .subscribe(\n          (formSubmissionResult: FormSubmissionResult) => {\n            this.formSubmitted();\n          },\n          errors => {\n            this.form.showErrors(errors);\n          }\n        );\n    }\n  }\n\n  public formSubmitted() {\n    this.modal.hide();\n    this.formSubmit.emit();\n  }\n\n  public gotoFormLinkScreen() {\n    this.modal.hide();\n    this.router.navigate(['form-links'], {queryParams: {process: this.processDefinitionKey}});\n  }\n}\n","<!--\n  ~ Copyright 2015-2023 Ritense BV, the Netherlands.\n  ~\n  ~ Licensed under EUPL, Version 1.2 (the \"License\");\n  ~ you may not use this file except in compliance with the License.\n  ~ You may obtain a copy of the License at\n  ~\n  ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n  ~\n  ~ Unless required by applicable law or agreed to in writing, software\n  ~ distributed under the License is distributed on an \"AS IS\" basis,\n  ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n  ~ See the License for the specific language governing permissions and\n  ~ limitations under the License.\n  -->\n\n<valtimo-modal\n  #supportingProcessStartModal\n  elementId=\"supportingProcessStartModal\"\n  [title]=\"\n    (processDefinitionKey | translate) !== processDefinitionKey\n      ? (processDefinitionKey | translate)\n      : processName\n  \"\n>\n  <div body *ngIf=\"formDefinition\">\n    <valtimo-form-io\n      #form\n      [submission]=\"submission\"\n      [form]=\"formDefinition\"\n      [options]=\"options\"\n      (submit)=\"onSubmit($event)\"\n    >\n    </valtimo-form-io>\n  </div>\n  <div body *ngIf=\"formFlowInstanceId\">\n    <valtimo-form-flow\n      #formFlow\n      [formFlowInstanceId]=\"formFlowInstanceId\"\n      (formFlowComplete)=\"formSubmitted()\"\n    ></valtimo-form-flow>\n  </div>\n  <div body *ngIf=\"!formDefinition && !formFlowInstanceId\">\n    <div class=\"bg-warning text-black mb-0 p-3 text-center\">\n      {{\n        (isAdmin$ | async)\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.gotoFormLinksButton' | translate }}\n      </button>\n    </div>\n  </div>\n</valtimo-modal>\n"]}
203
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dossier-supporting-process-start-modal.component.js","sourceRoot":"","sources":["../../../../../../projects/valtimo/dossier/src/lib/dossier-supporting-process-start-modal/dossier-supporting-process-start-modal.component.ts","../../../../../../projects/valtimo/dossier/src/lib/dossier-supporting-process-start-modal/dossier-supporting-process-start-modal.component.html"],"names":[],"mappings":"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","sourcesContent":["/*\n * Copyright 2015-2023 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, EventEmitter, Output, ViewChild, ViewEncapsulation} from '@angular/core';\nimport {FormioBeforeSubmit, FormioForm} from '@formio/angular';\nimport {\n  FormioComponent,\n  FormioOptionsImpl,\n  FormioSubmission,\n  ModalComponent,\n  ValtimoFormioOptions,\n} from '@valtimo/components';\nimport {ActivatedRoute, Router} from '@angular/router';\nimport {ProcessService} from '@valtimo/process';\nimport {DocumentService, ProcessDocumentDefinition} from '@valtimo/document';\nimport {\n  FormAssociation,\n  FormFlowService,\n  FormLinkService,\n  FormSubmissionResult,\n  ProcessLinkService,\n} from '@valtimo/form-link';\nimport {NGXLogger} from 'ngx-logger';\nimport {BehaviorSubject, combineLatest, Observable, of, switchMap, tap} from 'rxjs';\nimport {catchError, map, take} from 'rxjs/operators';\nimport {UserProviderService} from '@valtimo/security';\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('supportingProcessStartModal', {static: false}) modal: ModalComponent;\n\n  @Output() formSubmit = new EventEmitter();\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 formAssociation$ = new BehaviorSubject<FormAssociation>(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\n  public readonly isAdmin$: Observable<boolean> = this.userProviderService\n    .getUserSubject()\n    .pipe(map(userIdentity => userIdentity?.roles?.includes('ROLE_ADMIN')));\n\n  constructor(\n    private readonly route: ActivatedRoute,\n    private readonly router: Router,\n    private readonly processService: ProcessService,\n    private readonly processLinkService: ProcessLinkService,\n    private readonly documentService: DocumentService,\n    private readonly formLinkService: FormLinkService,\n    private readonly formFlowService: FormFlowService,\n    private readonly logger: NGXLogger,\n    private readonly userProviderService: UserProviderService\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          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          }\n          this.modal.show();\n        } else {\n          // backwards compatibility for form associations\n          combineLatest([this.processDefinitionKey$, this.documentId$])\n            .pipe(\n              take(1),\n              switchMap(([processDefinitionKey, documentId]) =>\n                this.formLinkService.getStartEventFormDefinitionByProcessDefinitionKey(\n                  processDefinitionKey,\n                  documentId\n                )\n              ),\n              tap(formDefinitionWithFormAssociation => {\n                this.openFormAssociation(formDefinitionWithFormAssociation);\n              }),\n              catchError(() => {\n                this.modal.show();\n                return of(null);\n              })\n            )\n            .subscribe();\n        }\n      });\n  }\n\n  private openFormAssociation(formDefinitionWithFormAssociation: any): void {\n    const formAssociation = formDefinitionWithFormAssociation.formAssociation;\n    const className = formAssociation.formLink.className.split('.');\n\n    this.formAssociation$.next(formAssociation);\n\n    const linkType = className[className.length - 1];\n    switch (linkType) {\n      case 'BpmnElementFormIdLink':\n        this.setFormDefinition(formDefinitionWithFormAssociation);\n        break;\n      case 'BpmnElementFormFlowIdLink':\n        this.setFormFlow();\n        break;\n      case 'BpmnElementUrlLink':\n        const url = this.router.serializeUrl(\n          this.router.createUrlTree([this.formAssociation$.getValue().formLink.url])\n        );\n        window.open(url, '_blank');\n        break;\n      case 'BpmnElementAngularStateUrlLink':\n        this.route.params.pipe(take(1)).subscribe(params => {\n          const documentId = params?.documentId;\n\n          this.router.navigate([this.formAssociation$.getValue().formLink.url], {\n            state: {...(documentId && {documentId})},\n          });\n        });\n        break;\n      default:\n        this.logger.fatal('Unsupported class name');\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  }\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    } else {\n      combineLatest([this.processDefinitionKey$, this.formAssociation$, this.documentId$])\n        .pipe(\n          take(1),\n          switchMap(([processDefinitionKey, formAssociation, documentId]) =>\n            this.formLinkService.onSubmit(\n              processDefinitionKey,\n              formAssociation.formLink.id,\n              submission.data,\n              documentId\n            )\n          )\n        )\n        .subscribe(\n          (formSubmissionResult: FormSubmissionResult) => {\n            this.formSubmitted();\n          },\n          errors => {\n            this.form.showErrors(errors);\n          }\n        );\n    }\n  }\n\n  public formSubmitted(): void {\n    this.modal.hide();\n    this.formSubmit.emit();\n  }\n\n  public gotoFormLinkScreen(): void {\n    this.modal.hide();\n    this.router.navigate(['form-links'], {\n      queryParams: {process: this.processDefinitionKey$.getValue()},\n    });\n  }\n\n  private setFormDefinition(formDefinitionWithFormAssociation: any): void {\n    this.formDefinition$.next(formDefinitionWithFormAssociation);\n    this.documentId$\n      .pipe(\n        take(1),\n        switchMap(documentId => this.documentService.getDocument(documentId)),\n        tap(document => {\n          this.submission$.next({\n            data: document.content,\n          });\n        }),\n        tap(() => {\n          this.modal.show();\n        })\n      )\n      .subscribe();\n  }\n\n  private setFormFlow(): void {\n    combineLatest([this.processDefinitionKey$, this.documentId$])\n      .pipe(\n        take(1),\n        switchMap(([processDefinitionKey, documentId]) =>\n          this.formFlowService.createInstanceForNewProcess(processDefinitionKey, {\n            documentId,\n            documentDefinitionName: null,\n          })\n        ),\n        tap(result => {\n          this.formFlowInstanceId$.next(result.formFlowInstanceId);\n        }),\n        tap(() => {\n          this.modal.show();\n        })\n      )\n      .subscribe();\n  }\n}\n","<!--\n  ~ Copyright 2015-2023 Ritense BV, the Netherlands.\n  ~\n  ~ Licensed under EUPL, Version 1.2 (the \"License\");\n  ~ you may not use this file except in compliance with the License.\n  ~ You may obtain a copy of the License at\n  ~\n  ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n  ~\n  ~ Unless required by applicable law or agreed to in writing, software\n  ~ distributed under the License is distributed on an \"AS IS\" basis,\n  ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n  ~ See the License for the specific language governing permissions and\n  ~ limitations under the License.\n  -->\n\n<valtimo-modal\n  *ngIf=\"{\n    processDefinitionKey: processDefinitionKey$ | async,\n    processName: processName$ | async\n  } as vars\"\n  #supportingProcessStartModal\n  elementId=\"supportingProcessStartModal\"\n  [title]=\"\n    (vars.processDefinitionKey | translate) !== vars.processDefinitionKey\n      ? (vars.processDefinitionKey | translate)\n      : vars.processName\n  \"\n>\n  <div body *ngIf=\"formDefinition$ | async as formDefinition\">\n    <valtimo-form-io\n      #form\n      [submission]=\"submission$ | async\"\n      [form]=\"formDefinition\"\n      [options]=\"options$ | async\"\n      (submit)=\"onSubmit($event)\"\n    >\n    </valtimo-form-io>\n  </div>\n  <div body *ngIf=\"formFlowInstanceId$ | async as formFlowInstanceId\">\n    <valtimo-form-flow\n      #formFlow\n      [formFlowInstanceId]=\"formFlowInstanceId\"\n      (formFlowComplete)=\"formSubmitted()\"\n    ></valtimo-form-flow>\n  </div>\n\n  <ng-container\n    *ngIf=\"{\n      formDefinition: formDefinition$ | async,\n      formFlowInstanceId: formFlowInstanceId$ | async\n    } as obs\"\n  >\n    <div body *ngIf=\"!obs.formDefinition && !obs.formFlowInstanceId\">\n      <div class=\"bg-warning text-black mb-0 p-3 text-center\">\n        {{\n          (isAdmin$ | async)\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.gotoFormLinksButton' | translate }}\n        </button>\n      </div>\n    </div>\n  </ng-container>\n</valtimo-modal>\n"]}