@valtimo/dossier 12.15.1 → 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.
@@ -13,34 +13,42 @@
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, Optional, Output, ViewChild, ViewContainerRef, ViewEncapsulation, signal, } from '@angular/core';
17
- import { FORM_CUSTOM_COMPONENT_TOKEN, } from '@valtimo/process-link';
16
+ import { Component, EventEmitter, Inject, Optional, Output, signal, ViewChild, ViewContainerRef, ViewEncapsulation, } from '@angular/core';
18
17
  import { FormioOptionsImpl, } from '@valtimo/components';
19
- import { take } from 'rxjs/operators';
20
- import { CAN_VIEW_CASE_PERMISSION, DOSSIER_DETAIL_PERMISSION_RESOURCE } from '../../permissions';
21
18
  import { FORM_VIEW_MODEL_TOKEN } from '@valtimo/config';
19
+ import { FORM_CUSTOM_COMPONENT_TOKEN, } from '@valtimo/process-link';
22
20
  import { BehaviorSubject, Subscription } from 'rxjs';
21
+ import { filter, take } from 'rxjs/operators';
22
+ import { CAN_VIEW_CASE_PERMISSION, DOSSIER_DETAIL_PERMISSION_RESOURCE } from '../../permissions';
23
23
  import * as i0 from "@angular/core";
24
24
  import * as i1 from "@angular/router";
25
25
  import * as i2 from "@valtimo/process";
26
- import * as i3 from "@valtimo/document";
27
- import * as i4 from "@valtimo/process-link";
28
- import * as i5 from "@valtimo/security";
29
- import * as i6 from "@valtimo/access-control";
30
- import * as i7 from "../../services";
31
- import * as i8 from "@valtimo/config";
32
- import * as i9 from "@valtimo/components";
33
- import * as i10 from "@ngx-translate/core";
34
- import * as i11 from "carbon-components-angular";
35
- import * as i12 from "@angular/common";
26
+ import * as i3 from "@valtimo/process-link";
27
+ import * as i4 from "@valtimo/security";
28
+ import * as i5 from "@valtimo/access-control";
29
+ import * as i6 from "../../services";
30
+ import * as i7 from "@valtimo/config";
31
+ import * as i8 from "@valtimo/components";
32
+ import * as i9 from "@ngx-translate/core";
33
+ import * as i10 from "carbon-components-angular";
34
+ import * as i11 from "@angular/common";
36
35
  export class DossierProcessStartModalComponent {
37
- constructor(route, router, processService, documentService, processLinkService, formFlowService, userProviderService, permissionService, listService, startModalService, configService, formViewModel, formCustomComponentConfig, urlResolverService) {
38
- this.route = route;
36
+ set formViewModelDynamicContainer(vcr) {
37
+ this._formViewModelDynamicContainer$.next(vcr);
38
+ }
39
+ get formViewModelDynamicContainer$() {
40
+ return this._formViewModelDynamicContainer$.pipe(filter(temp => !!temp));
41
+ }
42
+ set formCustomComponentDynamicContainer(vcr) {
43
+ this._formCustomComponentDynamicContainer$.next(vcr);
44
+ }
45
+ get formCustomComponentDynamicContainer$() {
46
+ return this._formCustomComponentDynamicContainer$.pipe(filter(temp => !!temp));
47
+ }
48
+ constructor(router, processService, processLinkService, userProviderService, permissionService, listService, startModalService, configService, formViewModel, formCustomComponentConfig, urlResolverService) {
39
49
  this.router = router;
40
50
  this.processService = processService;
41
- this.documentService = documentService;
42
51
  this.processLinkService = processLinkService;
43
- this.formFlowService = formFlowService;
44
52
  this.userProviderService = userProviderService;
45
53
  this.permissionService = permissionService;
46
54
  this.listService = listService;
@@ -51,6 +59,8 @@ export class DossierProcessStartModalComponent {
51
59
  this.urlResolverService = urlResolverService;
52
60
  this.isFormViewModel = false;
53
61
  this.isUIComponent = false;
62
+ this._formViewModelDynamicContainer$ = new BehaviorSubject(undefined);
63
+ this._formCustomComponentDynamicContainer$ = new BehaviorSubject(undefined);
54
64
  this.formFlowComplete = new EventEmitter();
55
65
  this.noProcessLinked = new EventEmitter();
56
66
  this.modalOpen$ = new BehaviorSubject(false);
@@ -83,6 +93,7 @@ export class DossierProcessStartModalComponent {
83
93
  .pipe(take(1))
84
94
  .subscribe(startProcessResult => {
85
95
  this.$loading.set(false);
96
+ this.openCdsModal();
86
97
  if (startProcessResult) {
87
98
  this.isUIComponent = false;
88
99
  this.isFormViewModel = false;
@@ -90,11 +101,9 @@ export class DossierProcessStartModalComponent {
90
101
  case 'form':
91
102
  this.formDefinition = startProcessResult.properties.prefilledForm;
92
103
  this.processLinkId = startProcessResult.processLinkId;
93
- this.openCdsModal();
94
104
  break;
95
105
  case 'form-flow':
96
106
  this.formFlowInstanceId = startProcessResult.properties.formFlowInstanceId;
97
- this.openCdsModal();
98
107
  break;
99
108
  case 'form-view-model':
100
109
  this.formDefinition = startProcessResult.properties.formDefinition;
@@ -102,7 +111,6 @@ export class DossierProcessStartModalComponent {
102
111
  this.processLinkId = startProcessResult.processLinkId;
103
112
  this.isFormViewModel = true;
104
113
  this.setFormViewModelComponent();
105
- this.openCdsModal();
106
114
  break;
107
115
  case 'url':
108
116
  this.processLinkId = startProcessResult.processLinkId;
@@ -122,7 +130,6 @@ export class DossierProcessStartModalComponent {
122
130
  case 'ui-component':
123
131
  this.setFormCustomComponent(startProcessResult.properties.componentKey);
124
132
  this.isUIComponent = true;
125
- this.openCdsModal();
126
133
  break;
127
134
  }
128
135
  }
@@ -201,40 +208,44 @@ export class DossierProcessStartModalComponent {
201
208
  });
202
209
  }
203
210
  setFormViewModelComponent() {
204
- if (!this.formViewModel.component)
205
- return;
206
- this.formViewModelDynamicContainer.clear();
207
- const formViewModelComponent = this.formViewModelDynamicContainer.createComponent(this.formViewModel.component);
208
- formViewModelComponent.instance.form = this.formDefinition;
209
- formViewModelComponent.instance.formName = this.formName;
210
- formViewModelComponent.instance.isStartForm = true;
211
- formViewModelComponent.instance.processDefinitionKey = this.processDefinitionKey;
212
- formViewModelComponent.instance.documentDefinitionName = this.documentDefinitionName;
213
- this._subscriptions.add(formViewModelComponent.instance.formSubmit.subscribe(() => {
214
- this.listService.forceRefresh();
215
- this.closeCdsModal();
216
- }));
217
- this._subscriptions.add(this.closeModalEvent.subscribe(() => {
218
- formViewModelComponent.destroy();
219
- }));
220
- }
221
- setFormCustomComponent(formCustomComponentKey) {
222
- this.formCustomComponentDynamicContainer.clear();
223
- if (!this.formCustomComponentConfig)
224
- return;
225
- this._formCustomComponentConfig$.pipe(take(1)).subscribe(formCustomComponentConfig => {
226
- const customComponent = formCustomComponentConfig[formCustomComponentKey];
227
- const renderedComponent = this.formCustomComponentDynamicContainer.createComponent(customComponent);
228
- renderedComponent.instance.processDefinitionKey = this.processDefinitionKey;
229
- renderedComponent.instance.documentDefinitionName = this.documentDefinitionName;
230
- renderedComponent.instance.submittedEvent.subscribe(() => {
211
+ this.formViewModelDynamicContainer$.pipe(take(1)).subscribe(template => {
212
+ if (!this.formViewModel.component)
213
+ return;
214
+ template.clear();
215
+ const formViewModelComponent = template.createComponent(this.formViewModel.component);
216
+ formViewModelComponent.instance.form = this.formDefinition;
217
+ formViewModelComponent.instance.formName = this.formName;
218
+ formViewModelComponent.instance.isStartForm = true;
219
+ formViewModelComponent.instance.processDefinitionKey = this.processDefinitionKey;
220
+ formViewModelComponent.instance.documentDefinitionName = this.documentDefinitionName;
221
+ this._subscriptions.add(formViewModelComponent.instance.formSubmit.subscribe(() => {
222
+ this.listService.forceRefresh();
231
223
  this.closeCdsModal();
232
- });
224
+ }));
233
225
  this._subscriptions.add(this.closeModalEvent.subscribe(() => {
234
- renderedComponent.destroy();
226
+ formViewModelComponent.destroy();
235
227
  }));
236
228
  });
237
229
  }
230
+ setFormCustomComponent(formCustomComponentKey) {
231
+ this.formCustomComponentDynamicContainer$.pipe(take(1)).subscribe(template => {
232
+ template.clear();
233
+ if (!this.formCustomComponentConfig)
234
+ return;
235
+ this._formCustomComponentConfig$.pipe(take(1)).subscribe(formCustomComponentConfig => {
236
+ const customComponent = formCustomComponentConfig[formCustomComponentKey];
237
+ const renderedComponent = template.createComponent(customComponent);
238
+ renderedComponent.instance.processDefinitionKey = this.processDefinitionKey;
239
+ renderedComponent.instance.documentDefinitionName = this.documentDefinitionName;
240
+ renderedComponent.instance.submittedEvent.subscribe(() => {
241
+ this.closeCdsModal();
242
+ });
243
+ this._subscriptions.add(this.closeModalEvent.subscribe(() => {
244
+ renderedComponent.destroy();
245
+ }));
246
+ });
247
+ });
248
+ }
238
249
  openCdsModal() {
239
250
  this.modalOpen$.next(true);
240
251
  }
@@ -242,13 +253,13 @@ export class DossierProcessStartModalComponent {
242
253
  this.modalOpen$.next(false);
243
254
  this.closeModalEvent.emit();
244
255
  }
245
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DossierProcessStartModalComponent, deps: [{ token: i1.ActivatedRoute }, { token: i1.Router }, { token: i2.ProcessService }, { token: i3.DocumentService }, { token: i4.ProcessLinkService }, { token: i4.FormFlowService }, { token: i5.UserProviderService }, { token: i6.PermissionService }, { token: i7.DossierListService }, { token: i7.StartModalService }, { token: i8.ConfigService }, { token: FORM_VIEW_MODEL_TOKEN, optional: true }, { token: FORM_CUSTOM_COMPONENT_TOKEN, optional: true }, { token: i4.UrlResolverService }], target: i0.ɵɵFactoryTarget.Component }); }
246
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: DossierProcessStartModalComponent, selector: "valtimo-dossier-process-start-modal", outputs: { formFlowComplete: "formFlowComplete", noProcessLinked: "noProcessLinked" }, 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\" size=\"sm\" valtimoCdsModal [enableOverflow]=\"true\">\n <cds-modal-header [showCloseButton]=\"true\" (closeSelect)=\"onCloseSelect()\"\n ><h3 cdsModalHeaderHeading>\n {{ modalTitle }}\n </h3>\n </cds-modal-header>\n\n <section cdsModalContent [cdsLayer]=\"1\" class=\"process-start-modal-content\">\n @if ($loading()) {\n <cds-loading></cds-loading>\n } @else {\n <ng-template #formViewModelComponent></ng-template>\n\n <ng-template #formCustomComponent></ng-template>\n\n @if (formDefinition && !isFormViewModel && !isUIComponent) {\n <valtimo-form-io\n #form\n [form]=\"formDefinition\"\n [options]=\"options\"\n (submit)=\"onSubmit($event)\"\n >\n </valtimo-form-io>\n }\n\n @if (formFlowInstanceId) {\n <valtimo-form-flow\n [formFlowInstanceId]=\"formFlowInstanceId\"\n (formFlowComplete)=\"formFlowSubmitted()\"\n ></valtimo-form-flow>\n }\n\n @if (!formFlowInstanceId && !formDefinition && isAdmin && !isUIComponent) {\n <div\n class=\"bg-warning text-black mb-0 p-3 text-center\"\n [translate]=\"'formManagement.noFormDefinitionFoundAdmin'\"\n ></div>\n <div class=\"mb-0 mt-4 p-3 text-center\">\n <button\n (click)=\"gotoProcessLinkScreen()\"\n class=\"btn btn-secondary btn-space\"\n id=\"process-link-button\"\n type=\"button\"\n >\n {{ 'formManagement.gotoProcessLinksButton' | translate }}\n </button>\n </div>\n }\n\n @if (!formFlowInstanceId && !formDefinition && !isAdmin && !isUIComponent) {\n <div\n class=\"bg-warning text-black mb-0 p-3 text-center\"\n [translate]=\"'formManagement.noFormDefinitionFoundUser'\"\n ></div>\n }\n }\n </section>\n</cds-modal>\n", styles: [".process-start-modal-content{padding:16px}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: i9.FormioComponent, selector: "valtimo-form-io", inputs: ["options", "submission", "form", "readOnly", "formRefresh$"], outputs: ["submit", "change", "event"] }, { kind: "directive", type: i10.TranslateDirective, selector: "[translate],[ngx-translate]", inputs: ["translate", "translateParams"] }, { kind: "component", type: i11.Loading, selector: "cds-loading, ibm-loading", inputs: ["title", "isActive", "size", "overlay"] }, { kind: "component", type: i4.FormFlowComponent, selector: "valtimo-form-flow", inputs: ["formIoFormData", "formFlowInstanceId"], outputs: ["formFlowComplete", "formFlowChange"] }, { kind: "component", type: i11.Modal, selector: "cds-modal, ibm-modal", inputs: ["size", "theme", "ariaLabel", "open", "trigger", "hasScrollingContent"], outputs: ["overlaySelected", "close"] }, { kind: "component", type: i11.ModalHeader, selector: "cds-modal-header, ibm-modal-header", inputs: ["theme", "closeLabel", "showCloseButton"], outputs: ["closeSelect"] }, { kind: "directive", type: i11.ModalContent, selector: "[cdsModalContent], [ibmModalContent]", inputs: ["hasForm"] }, { kind: "directive", type: i11.ModalHeaderHeading, selector: "[cdsModalHeaderHeading], [ibmModalHeaderHeading]" }, { kind: "directive", type: i9.ValtimoCdsModalDirective, selector: "[valtimoCdsModal]", inputs: ["enableOverflow"] }, { kind: "directive", type: i11.LayerDirective, selector: "[cdsLayer], [ibmLayer]", inputs: ["ibmLayer", "cdsLayer"], exportAs: ["layer"] }, { kind: "pipe", type: i12.AsyncPipe, name: "async" }, { kind: "pipe", type: i10.TranslatePipe, name: "translate" }], encapsulation: i0.ViewEncapsulation.None }); }
256
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DossierProcessStartModalComponent, deps: [{ token: i1.Router }, { token: i2.ProcessService }, { token: i3.ProcessLinkService }, { token: i4.UserProviderService }, { token: i5.PermissionService }, { token: i6.DossierListService }, { token: i6.StartModalService }, { token: i7.ConfigService }, { token: FORM_VIEW_MODEL_TOKEN, optional: true }, { token: FORM_CUSTOM_COMPONENT_TOKEN, optional: true }, { token: i3.UrlResolverService }], target: i0.ɵɵFactoryTarget.Component }); }
257
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: DossierProcessStartModalComponent, selector: "valtimo-dossier-process-start-modal", outputs: { formFlowComplete: "formFlowComplete", noProcessLinked: "noProcessLinked" }, viewQueries: [{ propertyName: "form", first: true, predicate: ["form"], descendants: true }, { propertyName: "formViewModelDynamicContainer", first: true, predicate: ["formViewModelComponent"], descendants: true, read: ViewContainerRef }, { 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\" size=\"sm\" valtimoCdsModal [enableOverflow]=\"true\">\n <cds-modal-header [showCloseButton]=\"true\" (closeSelect)=\"onCloseSelect()\"\n ><h3 cdsModalHeaderHeading>\n {{ modalTitle }}\n </h3>\n </cds-modal-header>\n\n <section cdsModalContent [cdsLayer]=\"1\" class=\"process-start-modal-content\">\n @if ($loading()) {\n <cds-loading></cds-loading>\n } @else {\n @if (modalOpen$ | async) {\n <ng-template #formViewModelComponent></ng-template>\n\n <ng-template #formCustomComponent></ng-template>\n }\n\n @if (formDefinition && !isFormViewModel && !isUIComponent) {\n <valtimo-form-io\n #form\n [form]=\"formDefinition\"\n [options]=\"options\"\n (submit)=\"onSubmit($event)\"\n >\n </valtimo-form-io>\n }\n\n @if (formFlowInstanceId) {\n <valtimo-form-flow\n [formFlowInstanceId]=\"formFlowInstanceId\"\n (formFlowComplete)=\"formFlowSubmitted()\"\n ></valtimo-form-flow>\n }\n\n @if (!formFlowInstanceId && !formDefinition && isAdmin && !isUIComponent) {\n <div\n class=\"bg-warning text-black mb-0 p-3 text-center\"\n [translate]=\"'formManagement.noFormDefinitionFoundAdmin'\"\n ></div>\n <div class=\"mb-0 mt-4 p-3 text-center\">\n <button\n (click)=\"gotoProcessLinkScreen()\"\n class=\"btn btn-secondary btn-space\"\n id=\"process-link-button\"\n type=\"button\"\n >\n {{ 'formManagement.gotoProcessLinksButton' | translate }}\n </button>\n </div>\n }\n\n @if (!formFlowInstanceId && !formDefinition && !isAdmin && !isUIComponent) {\n <div\n class=\"bg-warning text-black mb-0 p-3 text-center\"\n [translate]=\"'formManagement.noFormDefinitionFoundUser'\"\n ></div>\n }\n }\n </section>\n</cds-modal>\n", styles: [".process-start-modal-content{padding:16px}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: i8.FormioComponent, selector: "valtimo-form-io", inputs: ["options", "submission", "form", "readOnly", "formRefresh$"], outputs: ["submit", "change", "event"] }, { kind: "directive", type: i9.TranslateDirective, selector: "[translate],[ngx-translate]", inputs: ["translate", "translateParams"] }, { kind: "component", type: i10.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: i10.Modal, selector: "cds-modal, ibm-modal", inputs: ["size", "theme", "ariaLabel", "open", "trigger", "hasScrollingContent"], outputs: ["overlaySelected", "close"] }, { kind: "component", type: i10.ModalHeader, selector: "cds-modal-header, ibm-modal-header", inputs: ["theme", "closeLabel", "showCloseButton"], outputs: ["closeSelect"] }, { kind: "directive", type: i10.ModalContent, selector: "[cdsModalContent], [ibmModalContent]", inputs: ["hasForm"] }, { kind: "directive", type: i10.ModalHeaderHeading, selector: "[cdsModalHeaderHeading], [ibmModalHeaderHeading]" }, { kind: "directive", type: i8.ValtimoCdsModalDirective, selector: "[valtimoCdsModal]", inputs: ["enableOverflow"] }, { kind: "directive", type: i10.LayerDirective, selector: "[cdsLayer], [ibmLayer]", inputs: ["ibmLayer", "cdsLayer"], exportAs: ["layer"] }, { kind: "pipe", type: i11.AsyncPipe, name: "async" }, { kind: "pipe", type: i9.TranslatePipe, name: "translate" }], encapsulation: i0.ViewEncapsulation.None }); }
247
258
  }
248
259
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DossierProcessStartModalComponent, decorators: [{
249
260
  type: Component,
250
- args: [{ selector: 'valtimo-dossier-process-start-modal', encapsulation: ViewEncapsulation.None, 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\" size=\"sm\" valtimoCdsModal [enableOverflow]=\"true\">\n <cds-modal-header [showCloseButton]=\"true\" (closeSelect)=\"onCloseSelect()\"\n ><h3 cdsModalHeaderHeading>\n {{ modalTitle }}\n </h3>\n </cds-modal-header>\n\n <section cdsModalContent [cdsLayer]=\"1\" class=\"process-start-modal-content\">\n @if ($loading()) {\n <cds-loading></cds-loading>\n } @else {\n <ng-template #formViewModelComponent></ng-template>\n\n <ng-template #formCustomComponent></ng-template>\n\n @if (formDefinition && !isFormViewModel && !isUIComponent) {\n <valtimo-form-io\n #form\n [form]=\"formDefinition\"\n [options]=\"options\"\n (submit)=\"onSubmit($event)\"\n >\n </valtimo-form-io>\n }\n\n @if (formFlowInstanceId) {\n <valtimo-form-flow\n [formFlowInstanceId]=\"formFlowInstanceId\"\n (formFlowComplete)=\"formFlowSubmitted()\"\n ></valtimo-form-flow>\n }\n\n @if (!formFlowInstanceId && !formDefinition && isAdmin && !isUIComponent) {\n <div\n class=\"bg-warning text-black mb-0 p-3 text-center\"\n [translate]=\"'formManagement.noFormDefinitionFoundAdmin'\"\n ></div>\n <div class=\"mb-0 mt-4 p-3 text-center\">\n <button\n (click)=\"gotoProcessLinkScreen()\"\n class=\"btn btn-secondary btn-space\"\n id=\"process-link-button\"\n type=\"button\"\n >\n {{ 'formManagement.gotoProcessLinksButton' | translate }}\n </button>\n </div>\n }\n\n @if (!formFlowInstanceId && !formDefinition && !isAdmin && !isUIComponent) {\n <div\n class=\"bg-warning text-black mb-0 p-3 text-center\"\n [translate]=\"'formManagement.noFormDefinitionFoundUser'\"\n ></div>\n }\n }\n </section>\n</cds-modal>\n", styles: [".process-start-modal-content{padding:16px}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"] }]
251
- }], ctorParameters: () => [{ type: i1.ActivatedRoute }, { type: i1.Router }, { type: i2.ProcessService }, { type: i3.DocumentService }, { type: i4.ProcessLinkService }, { type: i4.FormFlowService }, { type: i5.UserProviderService }, { type: i6.PermissionService }, { type: i7.DossierListService }, { type: i7.StartModalService }, { type: i8.ConfigService }, { type: undefined, decorators: [{
261
+ args: [{ selector: 'valtimo-dossier-process-start-modal', encapsulation: ViewEncapsulation.None, 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\" size=\"sm\" valtimoCdsModal [enableOverflow]=\"true\">\n <cds-modal-header [showCloseButton]=\"true\" (closeSelect)=\"onCloseSelect()\"\n ><h3 cdsModalHeaderHeading>\n {{ modalTitle }}\n </h3>\n </cds-modal-header>\n\n <section cdsModalContent [cdsLayer]=\"1\" class=\"process-start-modal-content\">\n @if ($loading()) {\n <cds-loading></cds-loading>\n } @else {\n @if (modalOpen$ | async) {\n <ng-template #formViewModelComponent></ng-template>\n\n <ng-template #formCustomComponent></ng-template>\n }\n\n @if (formDefinition && !isFormViewModel && !isUIComponent) {\n <valtimo-form-io\n #form\n [form]=\"formDefinition\"\n [options]=\"options\"\n (submit)=\"onSubmit($event)\"\n >\n </valtimo-form-io>\n }\n\n @if (formFlowInstanceId) {\n <valtimo-form-flow\n [formFlowInstanceId]=\"formFlowInstanceId\"\n (formFlowComplete)=\"formFlowSubmitted()\"\n ></valtimo-form-flow>\n }\n\n @if (!formFlowInstanceId && !formDefinition && isAdmin && !isUIComponent) {\n <div\n class=\"bg-warning text-black mb-0 p-3 text-center\"\n [translate]=\"'formManagement.noFormDefinitionFoundAdmin'\"\n ></div>\n <div class=\"mb-0 mt-4 p-3 text-center\">\n <button\n (click)=\"gotoProcessLinkScreen()\"\n class=\"btn btn-secondary btn-space\"\n id=\"process-link-button\"\n type=\"button\"\n >\n {{ 'formManagement.gotoProcessLinksButton' | translate }}\n </button>\n </div>\n }\n\n @if (!formFlowInstanceId && !formDefinition && !isAdmin && !isUIComponent) {\n <div\n class=\"bg-warning text-black mb-0 p-3 text-center\"\n [translate]=\"'formManagement.noFormDefinitionFoundUser'\"\n ></div>\n }\n }\n </section>\n</cds-modal>\n", styles: [".process-start-modal-content{padding:16px}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"] }]
262
+ }], ctorParameters: () => [{ type: i1.Router }, { type: i2.ProcessService }, { type: i3.ProcessLinkService }, { type: i4.UserProviderService }, { type: i5.PermissionService }, { type: i6.DossierListService }, { type: i6.StartModalService }, { type: i7.ConfigService }, { type: undefined, decorators: [{
252
263
  type: Optional
253
264
  }, {
254
265
  type: Inject,
@@ -258,18 +269,18 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
258
269
  }, {
259
270
  type: Inject,
260
271
  args: [FORM_CUSTOM_COMPONENT_TOKEN]
261
- }] }, { type: i4.UrlResolverService }], propDecorators: { form: [{
272
+ }] }, { type: i3.UrlResolverService }], propDecorators: { form: [{
262
273
  type: ViewChild,
263
274
  args: ['form', { static: false }]
264
275
  }], formViewModelDynamicContainer: [{
265
276
  type: ViewChild,
266
- args: ['formViewModelComponent', { static: true, read: ViewContainerRef }]
277
+ args: ['formViewModelComponent', { read: ViewContainerRef }]
267
278
  }], formCustomComponentDynamicContainer: [{
268
279
  type: ViewChild,
269
- args: ['formCustomComponent', { static: false, read: ViewContainerRef }]
280
+ args: ['formCustomComponent', { read: ViewContainerRef }]
270
281
  }], formFlowComplete: [{
271
282
  type: Output
272
283
  }], noProcessLinked: [{
273
284
  type: Output
274
285
  }] } });
275
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dossier-process-start-modal.component.js","sourceRoot":"","sources":["../../../../../../../projects/valtimo/dossier/src/lib/components/dossier-process-start-modal/dossier-process-start-modal.component.ts","../../../../../../../projects/valtimo/dossier/src/lib/components/dossier-process-start-modal/dossier-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 */\n\nimport {\n  Component,\n  ComponentRef,\n  EventEmitter,\n  Inject,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n  ViewChild,\n  ViewContainerRef,\n  ViewEncapsulation,\n  signal,\n} from '@angular/core';\nimport {PermissionService} from '@valtimo/access-control';\nimport {DocumentService, ProcessDocumentDefinition} from '@valtimo/document';\nimport {\n  FORM_CUSTOM_COMPONENT_TOKEN,\n  FormCustomComponent,\n  FormCustomComponentConfig,\n  FormFlowService,\n  FormSubmissionResult,\n  ProcessLinkService,\n  UrlResolverService,\n} from '@valtimo/process-link';\nimport {ActivatedRoute, Router} from '@angular/router';\nimport {ProcessService} from '@valtimo/process';\nimport {FormioComponent, FormioOptionsImpl, FormioSubmission, ValtimoFormioOptions,} from '@valtimo/components';\nimport {FormioBeforeSubmit} from '@formio/angular/formio.common';\nimport {FormioForm} from '@formio/angular';\nimport {UserProviderService} from '@valtimo/security';\nimport {take} from 'rxjs/operators';\nimport {CAN_VIEW_CASE_PERMISSION, DOSSIER_DETAIL_PERMISSION_RESOURCE} from '../../permissions';\nimport {DossierListService, StartModalService} from '../../services';\nimport {ConfigService, FORM_VIEW_MODEL_TOKEN, FormViewModel} from '@valtimo/config';\nimport {BehaviorSubject, Subscription} from 'rxjs';\n\n@Component({\n  selector: 'valtimo-dossier-process-start-modal',\n  templateUrl: './dossier-process-start-modal.component.html',\n  styleUrls: ['./dossier-process-start-modal.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n})\nexport class DossierProcessStartModalComponent implements OnInit, OnDestroy {\n  public processDefinitionKey: string;\n  public processDefinitionId: string;\n  public documentDefinitionName: string;\n  public processName: string;\n  private _startEventName: string;\n  private readonly _useStartEventNameAsStartFormTitle!: boolean;\n  public formDefinition: FormioForm;\n  public formName: string;\n  public formFlowInstanceId: string;\n  public formioSubmission: FormioSubmission;\n  private processLinkId: string;\n  public options: ValtimoFormioOptions;\n  public isAdmin: boolean;\n  public isFormViewModel = false;\n  public isUIComponent = false;\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  @Output() formFlowComplete = new EventEmitter();\n  @Output() noProcessLinked = new EventEmitter();\n\n  public readonly modalOpen$ = new BehaviorSubject<boolean>(false);\n  public readonly $loading = signal<boolean>(true);\n\n  private _subscriptions = new Subscription();\n  private readonly _formCustomComponentConfig$ = new BehaviorSubject<\n    FormCustomComponentConfig | {}\n  >({});\n  public readonly closeModalEvent = new EventEmitter();\n\n\n  constructor(\n    private route: ActivatedRoute,\n    private router: Router,\n    private processService: ProcessService,\n    private documentService: DocumentService,\n    private processLinkService: ProcessLinkService,\n    private formFlowService: FormFlowService,\n    private userProviderService: UserProviderService,\n    private permissionService: PermissionService,\n    private listService: DossierListService,\n    private startModalService: StartModalService,\n    private configService: ConfigService,\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    private urlResolverService: UrlResolverService\n  ) {\n    this._useStartEventNameAsStartFormTitle =\n      this.configService.config.featureToggles?.useStartEventNameAsStartFormTitle;\n\n    this._formCustomComponentConfig$.next(formCustomComponentConfig);\n  }\n\n  ngOnInit() {\n    this.isUserAdmin();\n  }\n\n  ngOnDestroy() {\n    this._subscriptions.unsubscribe();\n  }\n\n  private loadProcessLink() {\n    this.$loading.set(true);\n    this.processLinkId = null;\n    this.formDefinition = null;\n    this.formFlowInstanceId = null;\n    if (this._useStartEventNameAsStartFormTitle) {\n      this.processService.getProcessDefinitionXml(this.processDefinitionId).subscribe(result => {\n        this._startEventName = this.startModalService.getStandardStartEventTitle(result.bpmn20Xml);\n      });\n    }\n    this.processService\n      .getProcessDefinitionStartProcessLink(\n        this.processDefinitionId,\n        null,\n        this.documentDefinitionName\n      )\n      .pipe(take(1))\n      .subscribe(startProcessResult => {\n        this.$loading.set(false);\n        if (startProcessResult) {\n          this.isUIComponent = false;\n          this.isFormViewModel = false;\n          switch (startProcessResult.type) {\n            case 'form':\n              this.formDefinition = startProcessResult.properties.prefilledForm;\n              this.processLinkId = startProcessResult.processLinkId;\n              this.openCdsModal();\n              break;\n            case 'form-flow':\n              this.formFlowInstanceId = startProcessResult.properties.formFlowInstanceId;\n              this.openCdsModal();\n              break;\n            case 'form-view-model':\n              this.formDefinition = startProcessResult.properties.formDefinition;\n              this.formName = startProcessResult.properties.formName;\n              this.processLinkId = startProcessResult.processLinkId;\n              this.isFormViewModel = true;\n              this.setFormViewModelComponent();\n              this.openCdsModal();\n              break;\n            case 'url':\n              this.processLinkId = startProcessResult.processLinkId;\n              this.processLinkService\n                .getVariables()\n                .pipe(take(1))\n                .subscribe(variables => {\n                  let url = this.urlResolverService.resolveUrlVariables(\n                    startProcessResult.properties.url,\n                    variables.variables\n                  );\n                  window.open(url, '_blank').focus();\n                  this.processLinkService\n                    .submitURLProcessLink(this.processLinkId)\n                    .subscribe(result => {\n                      this.submitCompleted(result);\n                    });\n                });\n              break;\n            case 'ui-component':\n              this.setFormCustomComponent(startProcessResult.properties.componentKey);\n              this.isUIComponent = true;\n              this.openCdsModal();\n              break;\n          }\n        } else {\n          this.noProcessLinked.emit();\n        }\n      });\n  }\n\n  public gotoProcessLinkScreen(): void {\n    this.closeCdsModal();\n    this.router.navigate(['process-links'], {queryParams: {process: this.processDefinitionKey}});\n  }\n\n  public get modalTitle() {\n    const fallbackTitle = `Start - ${this.processName}`;\n    return this._useStartEventNameAsStartFormTitle\n      ? this._startEventName || fallbackTitle\n      : fallbackTitle;\n  }\n\n  openModal(processDocumentDefinition: ProcessDocumentDefinition) {\n    this.processDefinitionKey = processDocumentDefinition.id.processDefinitionKey;\n    this.processDefinitionId = processDocumentDefinition.latestVersionId;\n    this.documentDefinitionName = processDocumentDefinition.id.documentDefinitionId.name;\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\n    this.processLinkService.submitForm(this.processLinkId, submission.data).subscribe({\n      next: (formSubmissionResult: FormSubmissionResult) => {\n        this.submitCompleted(formSubmissionResult);\n      },\n      error: errors => {\n        this.form.showErrors(errors);\n      },\n    });\n  }\n\n  public formFlowSubmitted(): void {\n    this.formFlowComplete.emit(null);\n    this.closeCdsModal();\n  }\n\n  public isUserAdmin(): void {\n    this.userProviderService.getUserSubject().subscribe(\n      userIdentity => {\n        this.isAdmin = userIdentity.roles.includes('ROLE_ADMIN');\n      },\n      error => {\n        this.isAdmin = false;\n      }\n    );\n  }\n\n  public onCloseSelect(): void {\n    this.closeCdsModal();\n  }\n\n  private submitCompleted(formSubmissionResult: FormSubmissionResult): void {\n    this.closeCdsModal();\n    this.permissionService\n      .requestPermission(CAN_VIEW_CASE_PERMISSION, {\n        resource: DOSSIER_DETAIL_PERMISSION_RESOURCE.jsonSchemaDocument,\n        identifier: formSubmissionResult.documentId,\n      })\n      .subscribe(canViewCase => {\n        if (canViewCase) {\n          this.router.navigate([\n            'dossiers',\n            this.documentDefinitionName,\n            'document',\n            formSubmissionResult.documentId,\n          ]);\n        } else {\n          this.listService.forceRefresh();\n        }\n      });\n  }\n\n  private setFormViewModelComponent() {\n    if (!this.formViewModel.component) return;\n    this.formViewModelDynamicContainer.clear();\n    const formViewModelComponent = this.formViewModelDynamicContainer.createComponent(\n      this.formViewModel.component\n    );\n    formViewModelComponent.instance.form = this.formDefinition;\n    formViewModelComponent.instance.formName = this.formName;\n    formViewModelComponent.instance.isStartForm = true;\n    formViewModelComponent.instance.processDefinitionKey = this.processDefinitionKey;\n    formViewModelComponent.instance.documentDefinitionName = this.documentDefinitionName;\n    this._subscriptions.add(\n      formViewModelComponent.instance.formSubmit.subscribe(() => {\n        this.listService.forceRefresh();\n        this.closeCdsModal();\n      })\n    );\n\n    this._subscriptions.add(\n      this.closeModalEvent.subscribe(() => {\n        formViewModelComponent.destroy();\n      })\n    );\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      renderedComponent.instance.processDefinitionKey = this.processDefinitionKey;\n      renderedComponent.instance.documentDefinitionName = this.documentDefinitionName;\n\n      renderedComponent.instance.submittedEvent.subscribe(() => {\n        this.closeCdsModal();\n      });\n\n      this._subscriptions.add(\n        this.closeModalEvent.subscribe(() => {\n          renderedComponent.destroy();\n        })\n      );\n    });\n  }\n\n  private openCdsModal(): void {\n    this.modalOpen$.next(true);\n  }\n\n  private closeCdsModal(): void {\n    this.modalOpen$.next(false);\n    this.closeModalEvent.emit();\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\" size=\"sm\" valtimoCdsModal [enableOverflow]=\"true\">\n  <cds-modal-header [showCloseButton]=\"true\" (closeSelect)=\"onCloseSelect()\"\n    ><h3 cdsModalHeaderHeading>\n      {{ modalTitle }}\n    </h3>\n  </cds-modal-header>\n\n  <section cdsModalContent [cdsLayer]=\"1\" class=\"process-start-modal-content\">\n    @if ($loading()) {\n      <cds-loading></cds-loading>\n    } @else {\n      <ng-template #formViewModelComponent></ng-template>\n\n      <ng-template #formCustomComponent></ng-template>\n\n      @if (formDefinition && !isFormViewModel && !isUIComponent) {\n        <valtimo-form-io\n          #form\n          [form]=\"formDefinition\"\n          [options]=\"options\"\n          (submit)=\"onSubmit($event)\"\n        >\n        </valtimo-form-io>\n      }\n\n      @if (formFlowInstanceId) {\n        <valtimo-form-flow\n          [formFlowInstanceId]=\"formFlowInstanceId\"\n          (formFlowComplete)=\"formFlowSubmitted()\"\n        ></valtimo-form-flow>\n      }\n\n      @if (!formFlowInstanceId && !formDefinition && isAdmin && !isUIComponent) {\n        <div\n          class=\"bg-warning text-black mb-0 p-3 text-center\"\n          [translate]=\"'formManagement.noFormDefinitionFoundAdmin'\"\n        ></div>\n        <div class=\"mb-0 mt-4 p-3 text-center\">\n          <button\n            (click)=\"gotoProcessLinkScreen()\"\n            class=\"btn btn-secondary btn-space\"\n            id=\"process-link-button\"\n            type=\"button\"\n          >\n            {{ 'formManagement.gotoProcessLinksButton' | translate }}\n          </button>\n        </div>\n      }\n\n      @if (!formFlowInstanceId && !formDefinition && !isAdmin && !isUIComponent) {\n        <div\n          class=\"bg-warning text-black mb-0 p-3 text-center\"\n          [translate]=\"'formManagement.noFormDefinitionFoundUser'\"\n        ></div>\n      }\n    }\n  </section>\n</cds-modal>\n"]}
286
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dossier-process-start-modal.component.js","sourceRoot":"","sources":["../../../../../../../projects/valtimo/dossier/src/lib/components/dossier-process-start-modal/dossier-process-start-modal.component.ts","../../../../../../../projects/valtimo/dossier/src/lib/components/dossier-process-start-modal/dossier-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  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n  signal,\n  ViewChild,\n  ViewContainerRef,\n  ViewEncapsulation,\n} from '@angular/core';\nimport {Router} from '@angular/router';\nimport {FormioForm} from '@formio/angular';\nimport {FormioBeforeSubmit} from '@formio/angular/formio.common';\nimport {PermissionService} from '@valtimo/access-control';\nimport {\n  FormioComponent,\n  FormioOptionsImpl,\n  FormioSubmission,\n  ValtimoFormioOptions,\n} from '@valtimo/components';\nimport {ConfigService, 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  UrlResolverService,\n} from '@valtimo/process-link';\nimport {UserProviderService} from '@valtimo/security';\nimport {BehaviorSubject, Observable, Subscription} from 'rxjs';\nimport {filter, take} from 'rxjs/operators';\nimport {CAN_VIEW_CASE_PERMISSION, DOSSIER_DETAIL_PERMISSION_RESOURCE} from '../../permissions';\nimport {DossierListService, StartModalService} from '../../services';\n\n@Component({\n  selector: 'valtimo-dossier-process-start-modal',\n  templateUrl: './dossier-process-start-modal.component.html',\n  styleUrls: ['./dossier-process-start-modal.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n})\nexport class DossierProcessStartModalComponent implements OnInit, OnDestroy {\n  public processDefinitionKey: string;\n  public processDefinitionId: string;\n  public documentDefinitionName: string;\n  public processName: string;\n  private _startEventName: string;\n  private readonly _useStartEventNameAsStartFormTitle!: boolean;\n  public formDefinition: FormioForm;\n  public formName: string;\n  public formFlowInstanceId: string;\n  public formioSubmission: FormioSubmission;\n  private processLinkId: string;\n  public options: ValtimoFormioOptions;\n  public isAdmin: boolean;\n  public isFormViewModel = false;\n  public isUIComponent = false;\n  @ViewChild('form', {static: false}) form: FormioComponent;\n  private _formViewModelDynamicContainer$ = new BehaviorSubject<ViewContainerRef | undefined>(\n    undefined\n  );\n  @ViewChild('formViewModelComponent', {read: ViewContainerRef}) set formViewModelDynamicContainer(\n    vcr: ViewContainerRef | undefined\n  ) {\n    this._formViewModelDynamicContainer$.next(vcr);\n  }\n  get formViewModelDynamicContainer$(): Observable<ViewContainerRef> {\n    return this._formViewModelDynamicContainer$.pipe(filter(temp => !!temp));\n  }\n  private _formCustomComponentDynamicContainer$ = new BehaviorSubject<ViewContainerRef | undefined>(\n    undefined\n  );\n  @ViewChild('formCustomComponent', {read: ViewContainerRef})\n  set formCustomComponentDynamicContainer(vcr: ViewContainerRef | undefined) {\n    this._formCustomComponentDynamicContainer$.next(vcr);\n  }\n  get formCustomComponentDynamicContainer$(): Observable<ViewContainerRef> {\n    return this._formCustomComponentDynamicContainer$.pipe(filter(temp => !!temp));\n  }\n  @Output() formFlowComplete = new EventEmitter();\n  @Output() noProcessLinked = new EventEmitter();\n\n  public readonly modalOpen$ = new BehaviorSubject<boolean>(false);\n  public readonly $loading = signal<boolean>(true);\n\n  private _subscriptions = new Subscription();\n  private readonly _formCustomComponentConfig$ = new BehaviorSubject<\n    FormCustomComponentConfig | {}\n  >({});\n  public readonly closeModalEvent = new EventEmitter();\n\n  constructor(\n    private router: Router,\n    private processService: ProcessService,\n    private processLinkService: ProcessLinkService,\n    private userProviderService: UserProviderService,\n    private permissionService: PermissionService,\n    private listService: DossierListService,\n    private startModalService: StartModalService,\n    private configService: ConfigService,\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    private urlResolverService: UrlResolverService\n  ) {\n    this._useStartEventNameAsStartFormTitle =\n      this.configService.config.featureToggles?.useStartEventNameAsStartFormTitle;\n\n    this._formCustomComponentConfig$.next(formCustomComponentConfig);\n  }\n\n  ngOnInit() {\n    this.isUserAdmin();\n  }\n\n  ngOnDestroy() {\n    this._subscriptions.unsubscribe();\n  }\n\n  private loadProcessLink() {\n    this.$loading.set(true);\n    this.processLinkId = null;\n    this.formDefinition = null;\n    this.formFlowInstanceId = null;\n    if (this._useStartEventNameAsStartFormTitle) {\n      this.processService.getProcessDefinitionXml(this.processDefinitionId).subscribe(result => {\n        this._startEventName = this.startModalService.getStandardStartEventTitle(result.bpmn20Xml);\n      });\n    }\n    this.processService\n      .getProcessDefinitionStartProcessLink(\n        this.processDefinitionId,\n        null,\n        this.documentDefinitionName\n      )\n      .pipe(take(1))\n      .subscribe(startProcessResult => {\n        this.$loading.set(false);\n\n        this.openCdsModal();\n        if (startProcessResult) {\n          this.isUIComponent = false;\n          this.isFormViewModel = false;\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            case 'form-view-model':\n              this.formDefinition = startProcessResult.properties.formDefinition;\n              this.formName = startProcessResult.properties.formName;\n              this.processLinkId = startProcessResult.processLinkId;\n              this.isFormViewModel = true;\n              this.setFormViewModelComponent();\n              break;\n            case 'url':\n              this.processLinkId = startProcessResult.processLinkId;\n              this.processLinkService\n                .getVariables()\n                .pipe(take(1))\n                .subscribe(variables => {\n                  let url = this.urlResolverService.resolveUrlVariables(\n                    startProcessResult.properties.url,\n                    variables.variables\n                  );\n                  window.open(url, '_blank').focus();\n                  this.processLinkService\n                    .submitURLProcessLink(this.processLinkId)\n                    .subscribe(result => {\n                      this.submitCompleted(result);\n                    });\n                });\n              break;\n            case 'ui-component':\n              this.setFormCustomComponent(startProcessResult.properties.componentKey);\n              this.isUIComponent = true;\n              break;\n          }\n        } else {\n          this.noProcessLinked.emit();\n        }\n      });\n  }\n\n  public gotoProcessLinkScreen(): void {\n    this.closeCdsModal();\n    this.router.navigate(['process-links'], {queryParams: {process: this.processDefinitionKey}});\n  }\n\n  public get modalTitle() {\n    const fallbackTitle = `Start - ${this.processName}`;\n    return this._useStartEventNameAsStartFormTitle\n      ? this._startEventName || fallbackTitle\n      : fallbackTitle;\n  }\n\n  openModal(processDocumentDefinition: ProcessDocumentDefinition) {\n    this.processDefinitionKey = processDocumentDefinition.id.processDefinitionKey;\n    this.processDefinitionId = processDocumentDefinition.latestVersionId;\n    this.documentDefinitionName = processDocumentDefinition.id.documentDefinitionId.name;\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\n    this.processLinkService.submitForm(this.processLinkId, submission.data).subscribe({\n      next: (formSubmissionResult: FormSubmissionResult) => {\n        this.submitCompleted(formSubmissionResult);\n      },\n      error: errors => {\n        this.form.showErrors(errors);\n      },\n    });\n  }\n\n  public formFlowSubmitted(): void {\n    this.formFlowComplete.emit(null);\n    this.closeCdsModal();\n  }\n\n  public isUserAdmin(): void {\n    this.userProviderService.getUserSubject().subscribe(\n      userIdentity => {\n        this.isAdmin = userIdentity.roles.includes('ROLE_ADMIN');\n      },\n      error => {\n        this.isAdmin = false;\n      }\n    );\n  }\n\n  public onCloseSelect(): void {\n    this.closeCdsModal();\n  }\n\n  private submitCompleted(formSubmissionResult: FormSubmissionResult): void {\n    this.closeCdsModal();\n    this.permissionService\n      .requestPermission(CAN_VIEW_CASE_PERMISSION, {\n        resource: DOSSIER_DETAIL_PERMISSION_RESOURCE.jsonSchemaDocument,\n        identifier: formSubmissionResult.documentId,\n      })\n      .subscribe(canViewCase => {\n        if (canViewCase) {\n          this.router.navigate([\n            'dossiers',\n            this.documentDefinitionName,\n            'document',\n            formSubmissionResult.documentId,\n          ]);\n        } else {\n          this.listService.forceRefresh();\n        }\n      });\n  }\n\n  private setFormViewModelComponent() {\n    this.formViewModelDynamicContainer$.pipe(take(1)).subscribe(template => {\n      if (!this.formViewModel.component) return;\n      template.clear();\n      const formViewModelComponent = template.createComponent(this.formViewModel.component);\n      formViewModelComponent.instance.form = this.formDefinition;\n      formViewModelComponent.instance.formName = this.formName;\n      formViewModelComponent.instance.isStartForm = true;\n      formViewModelComponent.instance.processDefinitionKey = this.processDefinitionKey;\n      formViewModelComponent.instance.documentDefinitionName = this.documentDefinitionName;\n      this._subscriptions.add(\n        formViewModelComponent.instance.formSubmit.subscribe(() => {\n          this.listService.forceRefresh();\n          this.closeCdsModal();\n        })\n      );\n\n      this._subscriptions.add(\n        this.closeModalEvent.subscribe(() => {\n          formViewModelComponent.destroy();\n        })\n      );\n    });\n  }\n\n  private setFormCustomComponent(formCustomComponentKey: string): void {\n    this.formCustomComponentDynamicContainer$.pipe(take(1)).subscribe(template => {\n      template.clear();\n      if (!this.formCustomComponentConfig) return;\n      this._formCustomComponentConfig$.pipe(take(1)).subscribe(formCustomComponentConfig => {\n        const customComponent = formCustomComponentConfig[formCustomComponentKey];\n        const renderedComponent = template.createComponent(\n          customComponent\n        ) as ComponentRef<FormCustomComponent>;\n\n        renderedComponent.instance.processDefinitionKey = this.processDefinitionKey;\n        renderedComponent.instance.documentDefinitionName = this.documentDefinitionName;\n\n        renderedComponent.instance.submittedEvent.subscribe(() => {\n          this.closeCdsModal();\n        });\n\n        this._subscriptions.add(\n          this.closeModalEvent.subscribe(() => {\n            renderedComponent.destroy();\n          })\n        );\n      });\n    });\n  }\n\n  private openCdsModal(): void {\n    this.modalOpen$.next(true);\n  }\n\n  private closeCdsModal(): void {\n    this.modalOpen$.next(false);\n    this.closeModalEvent.emit();\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\" size=\"sm\" valtimoCdsModal [enableOverflow]=\"true\">\n  <cds-modal-header [showCloseButton]=\"true\" (closeSelect)=\"onCloseSelect()\"\n    ><h3 cdsModalHeaderHeading>\n      {{ modalTitle }}\n    </h3>\n  </cds-modal-header>\n\n  <section cdsModalContent [cdsLayer]=\"1\" class=\"process-start-modal-content\">\n    @if ($loading()) {\n      <cds-loading></cds-loading>\n    } @else {\n      @if (modalOpen$ | async) {\n        <ng-template #formViewModelComponent></ng-template>\n\n        <ng-template #formCustomComponent></ng-template>\n      }\n\n      @if (formDefinition && !isFormViewModel && !isUIComponent) {\n        <valtimo-form-io\n          #form\n          [form]=\"formDefinition\"\n          [options]=\"options\"\n          (submit)=\"onSubmit($event)\"\n        >\n        </valtimo-form-io>\n      }\n\n      @if (formFlowInstanceId) {\n        <valtimo-form-flow\n          [formFlowInstanceId]=\"formFlowInstanceId\"\n          (formFlowComplete)=\"formFlowSubmitted()\"\n        ></valtimo-form-flow>\n      }\n\n      @if (!formFlowInstanceId && !formDefinition && isAdmin && !isUIComponent) {\n        <div\n          class=\"bg-warning text-black mb-0 p-3 text-center\"\n          [translate]=\"'formManagement.noFormDefinitionFoundAdmin'\"\n        ></div>\n        <div class=\"mb-0 mt-4 p-3 text-center\">\n          <button\n            (click)=\"gotoProcessLinkScreen()\"\n            class=\"btn btn-secondary btn-space\"\n            id=\"process-link-button\"\n            type=\"button\"\n          >\n            {{ 'formManagement.gotoProcessLinksButton' | translate }}\n          </button>\n        </div>\n      }\n\n      @if (!formFlowInstanceId && !formDefinition && !isAdmin && !isUIComponent) {\n        <div\n          class=\"bg-warning text-black mb-0 p-3 text-center\"\n          [translate]=\"'formManagement.noFormDefinitionFoundUser'\"\n        ></div>\n      }\n    }\n  </section>\n</cds-modal>\n"]}