@valtimo/process-link 12.0.0 → 12.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/components/process-link-modal/process-link-modal.component.mjs +24 -16
- package/esm2022/lib/components/select-form/select-form.component.mjs +12 -4
- package/esm2022/lib/models/process-link.model.mjs +1 -1
- package/esm2022/lib/process-link.module.mjs +7 -4
- package/esm2022/lib/services/process-link-state.service.mjs +9 -1
- package/fesm2022/valtimo-process-link.mjs +56 -30
- package/fesm2022/valtimo-process-link.mjs.map +1 -1
- package/lib/components/process-link-modal/process-link-modal.component.d.ts +7 -1
- package/lib/components/process-link-modal/process-link-modal.component.d.ts.map +1 -1
- package/lib/components/select-form/select-form.component.d.ts.map +1 -1
- package/lib/models/process-link.model.d.ts +3 -0
- package/lib/models/process-link.model.d.ts.map +1 -1
- package/lib/process-link.module.d.ts +1 -1
- package/lib/process-link.module.d.ts.map +1 -1
- package/lib/services/process-link-state.service.d.ts +3 -0
- package/lib/services/process-link-state.service.d.ts.map +1 -1
- package/package.json +1 -1
|
@@ -17,22 +17,25 @@ import { Component } from '@angular/core';
|
|
|
17
17
|
import { take } from 'rxjs/operators';
|
|
18
18
|
import * as i0 from "@angular/core";
|
|
19
19
|
import * as i1 from "../../services";
|
|
20
|
-
import * as i2 from "@
|
|
21
|
-
import * as i3 from "
|
|
22
|
-
import * as i4 from "
|
|
23
|
-
import * as i5 from "
|
|
24
|
-
import * as i6 from "../select-plugin-
|
|
25
|
-
import * as i7 from "../plugin-action-
|
|
26
|
-
import * as i8 from "../
|
|
27
|
-
import * as i9 from "../
|
|
28
|
-
import * as i10 from "../select-form
|
|
29
|
-
import * as i11 from "
|
|
20
|
+
import * as i2 from "@valtimo/config";
|
|
21
|
+
import * as i3 from "@angular/common";
|
|
22
|
+
import * as i4 from "carbon-components-angular";
|
|
23
|
+
import * as i5 from "@valtimo/components";
|
|
24
|
+
import * as i6 from "../select-plugin-configuration/select-plugin-configuration.component";
|
|
25
|
+
import * as i7 from "../select-plugin-action/select-plugin-action.component";
|
|
26
|
+
import * as i8 from "../plugin-action-configuration/plugin-action-configuration.component";
|
|
27
|
+
import * as i9 from "../choose-process-link-type/choose-process-link-type.component";
|
|
28
|
+
import * as i10 from "../select-form/select-form.component";
|
|
29
|
+
import * as i11 from "../select-form-flow/select-form-flow.component";
|
|
30
|
+
import * as i12 from "@ngx-translate/core";
|
|
30
31
|
export class ProcessLinkModalComponent {
|
|
31
|
-
constructor(stateService, stepService, buttonService, processLinkService) {
|
|
32
|
+
constructor(stateService, stepService, buttonService, processLinkService, processLinkStateService, configService) {
|
|
32
33
|
this.stateService = stateService;
|
|
33
34
|
this.stepService = stepService;
|
|
34
35
|
this.buttonService = buttonService;
|
|
35
36
|
this.processLinkService = processLinkService;
|
|
37
|
+
this.processLinkStateService = processLinkStateService;
|
|
38
|
+
this.configService = configService;
|
|
36
39
|
this.showModal$ = this.stateService.showModal$;
|
|
37
40
|
this.processStepName$ = this.stateService.elementName$;
|
|
38
41
|
this.steps$ = this.stepService.steps$;
|
|
@@ -46,6 +49,8 @@ export class ProcessLinkModalComponent {
|
|
|
46
49
|
this.hideProgressIndicator$ = this.stateService.hideProgressIndicator$;
|
|
47
50
|
this.saving$ = this.stateService.saving$;
|
|
48
51
|
this.typeOfSelectedProcessLink$ = this.stateService.typeOfSelectedProcessLink$;
|
|
52
|
+
this.viewModelEnabled$ = this.stateService.viewModelEnabled$;
|
|
53
|
+
this.showViewModelToggle = this.configService.config.featureToggles.enableFormViewModel;
|
|
49
54
|
}
|
|
50
55
|
closeModal() {
|
|
51
56
|
this.stateService.closeModal();
|
|
@@ -69,11 +74,14 @@ export class ProcessLinkModalComponent {
|
|
|
69
74
|
});
|
|
70
75
|
});
|
|
71
76
|
}
|
|
72
|
-
|
|
73
|
-
|
|
77
|
+
toggleCheckedChange(value) {
|
|
78
|
+
this.processLinkStateService.setViewModelEnabled(value);
|
|
79
|
+
}
|
|
80
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.3", ngImport: i0, type: ProcessLinkModalComponent, deps: [{ token: i1.ProcessLinkStateService }, { token: i1.ProcessLinkStepService }, { token: i1.ProcessLinkButtonService }, { token: i1.ProcessLinkService }, { token: i1.ProcessLinkStateService }, { token: i2.ConfigService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
81
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.3", type: ProcessLinkModalComponent, selector: "valtimo-process-link-modal", ngImport: i0, template: "<!--\n ~ Copyright 2015-2024 Ritense BV, the Netherlands.\n ~\n ~ Licensed under EUPL, Version 1.2 (the \"License\");\n ~ you may not use this file except in compliance with the License.\n ~ You may obtain a copy of the License at\n ~\n ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n ~\n ~ Unless required by applicable law or agreed to in writing, software\n ~ distributed under the License is distributed on an \"AS IS\" basis,\n ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n ~ See the License for the specific language governing permissions and\n ~ limitations under the License.\n -->\n\n<div\n class=\"process-link-modal-container\"\n *ngIf=\"{\n showModal: showModal$ | async,\n processStepName: processStepName$ | async,\n steps: steps$ | async,\n currentStepIndex: currentStepIndex$ | async,\n currentStepId: currentStepId$ | async,\n showSaveButton: showSaveButton$ | async,\n enableSaveButton: enableSaveButton$ | async,\n showBackButton: showBackButton$ | async,\n showNextButton: showNextButton$ | async,\n enableNextButton: enableNextButton$ | async,\n saving: saving$ | async,\n hideProgressIndicator: hideProgressIndicator$ | async,\n typeOfSelectedProgressLink: typeOfSelectedProcessLink$ | async\n } as obs\"\n>\n <cds-modal valtimoCdsModal [open]=\"obs.showModal\" size=\"lg\">\n <cds-modal-header (closeSelect)=\"closeModal()\">\n <h2 cdsModalHeaderLabel>{{ 'processLinkConfiguration.configureStep' | translate }}</h2>\n <h3 cdsModalHeaderHeading>\n {{\n 'processLinkConfiguration.modalTitle'\n | translate: {processStepName: obs.processStepName || '-'}\n }}\n </h3>\n <div class=\"process-link-progress\" *ngIf=\"!obs.typeOfSelectedProgressLink\">\n <ng-container *ngTemplateOutlet=\"progressIndicator; context: {obs: obs}\"></ng-container>\n </div>\n </cds-modal-header>\n <section cdsModalContent>\n <ng-container *ngTemplateOutlet=\"stepContent; context: {obs: obs}\"></ng-container>\n </section>\n <ng-template *ngTemplateOutlet=\"footer; context: {obs: obs}\"></ng-template>\n </cds-modal>\n</div>\n\n<ng-template #progressIndicator let-obs=\"obs\">\n <cds-progress-indicator\n *ngIf=\"obs.steps && !obs.hideProgressIndicator\"\n [steps]=\"obs.steps\"\n [current]=\"obs.currentStepIndex\"\n spacing=\"equal\"\n ></cds-progress-indicator>\n</ng-template>\n\n<ng-template #stepContent let-obs=\"obs\">\n <div class=\"cds-loading-container\" *ngIf=\"obs.saving\">\n <cds-loading></cds-loading>\n </div>\n <div [ngClass]=\"{hidden: obs.saving}\">\n <ng-container>\n <ng-container *ngIf=\"obs.currentStepId === 'chooseProcessLinkType'\">\n <valtimo-choose-process-link-type></valtimo-choose-process-link-type>\n </ng-container>\n <ng-container\n *ngIf=\"obs.currentStepId === 'selectForm' || obs.typeOfSelectedProgressLink === 'form'\"\n >\n <valtimo-select-form></valtimo-select-form>\n <br />\n <cds-toggle\n *ngIf=\"showViewModelToggle\"\n [label]=\"'processLinkConfiguration.toggleViewModel.title' | translate\"\n [onText]=\"'processLinkConfiguration.toggleViewModel.checkboxDescription' | translate\"\n [offText]=\"'processLinkConfiguration.toggleViewModel.checkboxDescription' | translate\"\n [checked]=\"viewModelEnabled$ | async\"\n (checkedChange)=\"toggleCheckedChange($event)\"\n ></cds-toggle>\n </ng-container>\n <ng-container\n *ngIf=\"\n obs.currentStepId === 'selectFormFlow' || obs.typeOfSelectedProgressLink === 'form-flow'\n \"\n >\n <valtimo-select-form-flow></valtimo-select-form-flow>\n </ng-container>\n <ng-container *ngIf=\"obs.currentStepId === 'choosePluginConfiguration'\">\n <valtimo-select-plugin-configuration></valtimo-select-plugin-configuration>\n </ng-container>\n <ng-container *ngIf=\"obs.currentStepId === 'choosePluginAction'\">\n <valtimo-select-plugin-action></valtimo-select-plugin-action>\n </ng-container>\n <ng-container\n *ngIf=\"\n obs.currentStepId === 'configurePluginAction' ||\n obs.typeOfSelectedProgressLink === 'plugin'\n \"\n >\n <valtimo-plugin-action-configuration></valtimo-plugin-action-configuration>\n </ng-container>\n </ng-container>\n </div>\n</ng-template>\n\n<ng-template #footer let-obs=\"obs\">\n <cds-modal-footer *ngIf=\"!obs.saving\">\n <div class=\"cancel-button\">\n <button cdsButton=\"ghost\" (click)=\"closeModal()\" [disabled]=\"obs.disabled\">\n {{ 'processLinkConfiguration.cancel' | translate }}\n </button>\n </div>\n <div class=\"navigation-buttons\">\n <button\n *ngIf=\"obs.showBackButton && !obs.saving\"\n cdsButton=\"secondary\"\n (click)=\"backButtonClick()\"\n >\n {{ 'processLinkConfiguration.back' | translate }}\n </button>\n <button\n cdsButton=\"primary\"\n *ngIf=\"obs.showNextButton && !obs.saving\"\n [disabled]=\"obs.enableNextButton === false\"\n (click)=\"nextButtonClick()\"\n >\n {{ 'processLinkConfiguration.next' | translate }}\n </button>\n <button\n cdsButton=\"danger--primary\"\n *ngIf=\"obs.typeOfSelectedProgressLink\"\n (click)=\"unlinkButtonClick()\"\n >\n {{ 'processLinkConfiguration.unlink' | translate }}\n </button>\n <button\n cdsButton=\"primary\"\n *ngIf=\"(obs.showSaveButton && !obs.saving) || obs.typeOfSelectedProgressLink\"\n [disabled]=\"obs.enableSaveButton === false\"\n (click)=\"saveButtonClick()\"\n >\n {{ 'processLinkConfiguration.complete' | translate }}\n </button>\n </div>\n </cds-modal-footer>\n</ng-template>\n", styles: ["::ng-deep .process-link-modal-container .cds--modal-container{max-width:960px;min-height:70%}::ng-deep .process-link-modal-container .cds--modal-footer{justify-content:space-between}.cds-loading-container{position:absolute;top:50px;padding-bottom:50px;left:0;width:100%;height:calc(100% - 50px);display:flex;justify-content:center;align-items:center;background:var(--cds-layer);z-index:99;box-sizing:border-box}.navigation-buttons{justify-content:flex-end}.navigation-buttons,.cancel-button{max-width:50%;display:flex;flex-direction:row;flex-grow:1}.navigation-buttons button,.cancel-button button{min-width:50%}.cancel-button{max-width:25%}.cancel-button button{min-width:100%}.process-link-progress{width:100%;margin-top:32px;margin-bottom:40px}.hidden{visibility:hidden}\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: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i4.Modal, selector: "cds-modal, ibm-modal", inputs: ["size", "theme", "ariaLabel", "open", "trigger", "hasScrollingContent"], outputs: ["overlaySelected", "close"] }, { kind: "component", type: i4.ModalHeader, selector: "cds-modal-header, ibm-modal-header", inputs: ["theme", "closeLabel", "showCloseButton"], outputs: ["closeSelect"] }, { kind: "component", type: i4.ModalFooter, selector: "cds-modal-footer, ibm-modal-footer" }, { kind: "directive", type: i4.ModalContent, selector: "[cdsModalContent], [ibmModalContent]", inputs: ["hasForm"] }, { kind: "directive", type: i4.ModalHeaderHeading, selector: "[cdsModalHeaderHeading], [ibmModalHeaderHeading]" }, { kind: "directive", type: i4.ModalHeaderLabel, selector: "[cdsModalHeaderLabel], [ibmModalHeaderLabel]" }, { kind: "component", type: i4.ProgressIndicator, selector: "cds-progress-indicator, ibm-progress-indicator", inputs: ["current", "steps", "translations", "orientation", "skeleton", "spacing"], outputs: ["stepSelected"] }, { kind: "directive", type: i4.Button, selector: "[cdsButton], [ibmButton]", inputs: ["ibmButton", "cdsButton", "size", "skeleton", "iconOnly", "isExpressive"] }, { kind: "component", type: i4.Loading, selector: "cds-loading, ibm-loading", inputs: ["title", "isActive", "size", "overlay"] }, { kind: "directive", type: i5.ValtimoCdsModalDirective, selector: "[valtimoCdsModal]" }, { kind: "component", type: i4.Toggle, selector: "cds-toggle, ibm-toggle", inputs: ["offText", "onText", "label", "size", "hideLabel", "skeleton"] }, { kind: "component", type: i6.SelectPluginConfigurationComponent, selector: "valtimo-select-plugin-configuration" }, { kind: "component", type: i7.SelectPluginActionComponent, selector: "valtimo-select-plugin-action" }, { kind: "component", type: i8.PluginActionConfigurationComponent, selector: "valtimo-plugin-action-configuration", outputs: ["valid", "configuration"] }, { kind: "component", type: i9.ChooseProcessLinkTypeComponent, selector: "valtimo-choose-process-link-type" }, { kind: "component", type: i10.SelectFormComponent, selector: "valtimo-select-form" }, { kind: "component", type: i11.SelectFormFlowComponent, selector: "valtimo-select-form-flow" }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }, { kind: "pipe", type: i12.TranslatePipe, name: "translate" }] }); }
|
|
74
82
|
}
|
|
75
83
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.3", ngImport: i0, type: ProcessLinkModalComponent, decorators: [{
|
|
76
84
|
type: Component,
|
|
77
|
-
args: [{ selector: 'valtimo-process-link-modal', template: "<!--\n ~ Copyright 2015-2024 Ritense BV, the Netherlands.\n ~\n ~ Licensed under EUPL, Version 1.2 (the \"License\");\n ~ you may not use this file except in compliance with the License.\n ~ You may obtain a copy of the License at\n ~\n ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n ~\n ~ Unless required by applicable law or agreed to in writing, software\n ~ distributed under the License is distributed on an \"AS IS\" basis,\n ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n ~ See the License for the specific language governing permissions and\n ~ limitations under the License.\n -->\n\n<div\n class=\"process-link-modal-container\"\n *ngIf=\"{\n showModal: showModal$ | async,\n processStepName: processStepName$ | async,\n steps: steps$ | async,\n currentStepIndex: currentStepIndex$ | async,\n currentStepId: currentStepId$ | async,\n showSaveButton: showSaveButton$ | async,\n enableSaveButton: enableSaveButton$ | async,\n showBackButton: showBackButton$ | async,\n showNextButton: showNextButton$ | async,\n enableNextButton: enableNextButton$ | async,\n saving: saving$ | async,\n hideProgressIndicator: hideProgressIndicator$ | async,\n typeOfSelectedProgressLink: typeOfSelectedProcessLink$ | async\n } as obs\"\n>\n <cds-modal valtimoCdsModal [open]=\"obs.showModal\" size=\"lg\">\n <cds-modal-header (closeSelect)=\"closeModal()\">\n <h2 cdsModalHeaderLabel>{{ 'processLinkConfiguration.configureStep' | translate }}</h2>\n <h3 cdsModalHeaderHeading>\n {{\n 'processLinkConfiguration.modalTitle'\n | translate: {processStepName: obs.processStepName || '-'}\n }}\n </h3>\n <div class=\"process-link-progress\" *ngIf=\"!obs.typeOfSelectedProgressLink\">\n <ng-container *ngTemplateOutlet=\"progressIndicator; context: {obs: obs}\"></ng-container>\n </div>\n </cds-modal-header>\n <section cdsModalContent>\n <ng-container *ngTemplateOutlet=\"stepContent; context: {obs: obs}\"></ng-container>\n </section>\n <ng-template *ngTemplateOutlet=\"footer; context: {obs: obs}\"></ng-template>\n </cds-modal>\n</div>\n\n<ng-template #progressIndicator let-obs=\"obs\">\n <cds-progress-indicator\n *ngIf=\"obs.steps && !obs.hideProgressIndicator\"\n [steps]=\"obs.steps\"\n [current]=\"obs.currentStepIndex\"\n spacing=\"equal\"\n ></cds-progress-indicator>\n</ng-template>\n\n<ng-template #stepContent let-obs=\"obs\">\n <div class=\"cds-loading-container\" *ngIf=\"obs.saving\">\n <cds-loading></cds-loading>\n </div>\n <div [ngClass]=\"{hidden: obs.saving}\">\n <ng-container>\n <ng-container *ngIf=\"obs.currentStepId === 'chooseProcessLinkType'\">\n <valtimo-choose-process-link-type></valtimo-choose-process-link-type>\n </ng-container>\n <ng-container\n *ngIf=\"obs.currentStepId === 'selectForm' || obs.typeOfSelectedProgressLink === 'form'\"\n >\n <valtimo-select-form></valtimo-select-form>\n </ng-container>\n <ng-container\n *ngIf=\"\n obs.currentStepId === 'selectFormFlow' || obs.typeOfSelectedProgressLink === 'form-flow'\n \"\n >\n <valtimo-select-form-flow></valtimo-select-form-flow>\n </ng-container>\n <ng-container *ngIf=\"obs.currentStepId === 'choosePluginConfiguration'\">\n <valtimo-select-plugin-configuration></valtimo-select-plugin-configuration>\n </ng-container>\n <ng-container *ngIf=\"obs.currentStepId === 'choosePluginAction'\">\n <valtimo-select-plugin-action></valtimo-select-plugin-action>\n </ng-container>\n <ng-container\n *ngIf=\"\n obs.currentStepId === 'configurePluginAction' ||\n obs.typeOfSelectedProgressLink === 'plugin'\n \"\n >\n <valtimo-plugin-action-configuration></valtimo-plugin-action-configuration>\n </ng-container>\n </ng-container>\n </div>\n</ng-template>\n\n<ng-template #footer let-obs=\"obs\">\n <cds-modal-footer *ngIf=\"!obs.saving\">\n <div class=\"cancel-button\">\n <button cdsButton=\"ghost\" (click)=\"closeModal()\" [disabled]=\"obs.disabled\">\n {{ 'processLinkConfiguration.cancel' | translate }}\n </button>\n </div>\n <div class=\"navigation-buttons\">\n <button\n *ngIf=\"obs.showBackButton && !obs.saving\"\n cdsButton=\"secondary\"\n (click)=\"backButtonClick()\"\n >\n {{ 'processLinkConfiguration.back' | translate }}\n </button>\n <button\n cdsButton=\"primary\"\n *ngIf=\"obs.showNextButton && !obs.saving\"\n [disabled]=\"obs.enableNextButton === false\"\n (click)=\"nextButtonClick()\"\n >\n {{ 'processLinkConfiguration.next' | translate }}\n </button>\n <button\n cdsButton=\"danger--primary\"\n *ngIf=\"obs.typeOfSelectedProgressLink\"\n (click)=\"unlinkButtonClick()\"\n >\n {{ 'processLinkConfiguration.unlink' | translate }}\n </button>\n <button\n cdsButton=\"primary\"\n *ngIf=\"(obs.showSaveButton && !obs.saving) || obs.typeOfSelectedProgressLink\"\n [disabled]=\"obs.enableSaveButton === false\"\n (click)=\"saveButtonClick()\"\n >\n {{ 'processLinkConfiguration.complete' | translate }}\n </button>\n </div>\n </cds-modal-footer>\n</ng-template>\n", styles: ["::ng-deep .process-link-modal-container .cds--modal-container{max-width:960px;min-height:70%}::ng-deep .process-link-modal-container .cds--modal-footer{justify-content:space-between}.cds-loading-container{position:absolute;top:50px;padding-bottom:50px;left:0;width:100%;height:calc(100% - 50px);display:flex;justify-content:center;align-items:center;background:var(--cds-layer);z-index:99;box-sizing:border-box}.navigation-buttons{justify-content:flex-end}.navigation-buttons,.cancel-button{max-width:50%;display:flex;flex-direction:row;flex-grow:1}.navigation-buttons button,.cancel-button button{min-width:50%}.cancel-button{max-width:25%}.cancel-button button{min-width:100%}.process-link-progress{width:100%;margin-top:32px;margin-bottom:40px}.hidden{visibility:hidden}\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"] }]
|
|
78
|
-
}], ctorParameters: () => [{ type: i1.ProcessLinkStateService }, { type: i1.ProcessLinkStepService }, { type: i1.ProcessLinkButtonService }, { type: i1.ProcessLinkService }] });
|
|
79
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"process-link-modal.component.js","sourceRoot":"","sources":["../../../../../../../projects/valtimo/process-link/src/lib/components/process-link-modal/process-link-modal.component.ts","../../../../../../../projects/valtimo/process-link/src/lib/components/process-link-modal/process-link-modal.component.html"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;GAcG;AAEH,OAAO,EAAC,SAAS,EAAC,MAAM,eAAe,CAAC;AAOxC,OAAO,EAAC,IAAI,EAAC,MAAM,gBAAgB,CAAC;;;;;;;;;;;;;AAOpC,MAAM,OAAO,yBAAyB;IAepC,YACmB,YAAqC,EACrC,WAAmC,EACnC,aAAuC,EACvC,kBAAsC;QAHtC,iBAAY,GAAZ,YAAY,CAAyB;QACrC,gBAAW,GAAX,WAAW,CAAwB;QACnC,kBAAa,GAAb,aAAa,CAA0B;QACvC,uBAAkB,GAAlB,kBAAkB,CAAoB;QAlBzC,eAAU,GAAG,IAAI,CAAC,YAAY,CAAC,UAAU,CAAC;QAC1C,qBAAgB,GAAG,IAAI,CAAC,YAAY,CAAC,YAAY,CAAC;QAClD,WAAM,GAAG,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC;QACjC,sBAAiB,GAAG,IAAI,CAAC,WAAW,CAAC,iBAAiB,CAAC;QACvD,mBAAc,GAAG,IAAI,CAAC,WAAW,CAAC,cAAc,CAAC;QACjD,oBAAe,GAAG,IAAI,CAAC,aAAa,CAAC,eAAe,CAAC;QACrD,sBAAiB,GAAG,IAAI,CAAC,aAAa,CAAC,iBAAiB,CAAC;QACzD,oBAAe,GAAG,IAAI,CAAC,aAAa,CAAC,eAAe,CAAC;QACrD,oBAAe,GAAG,IAAI,CAAC,aAAa,CAAC,eAAe,CAAC;QACrD,sBAAiB,GAAG,IAAI,CAAC,aAAa,CAAC,iBAAiB,CAAC;QACzD,2BAAsB,GAAG,IAAI,CAAC,YAAY,CAAC,sBAAsB,CAAC;QAClE,YAAO,GAAG,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC;QACpC,+BAA0B,GAAG,IAAI,CAAC,YAAY,CAAC,0BAA0B,CAAC;IAOvF,CAAC;IAEJ,UAAU;QACR,IAAI,CAAC,YAAY,CAAC,UAAU,EAAE,CAAC;IACjC,CAAC;IAED,eAAe;QACb,IAAI,CAAC,aAAa,CAAC,eAAe,EAAE,CAAC;IACvC,CAAC;IAED,eAAe;QACb,IAAI,CAAC,aAAa,CAAC,eAAe,EAAE,CAAC;IACvC,CAAC;IAED,eAAe;QACb,IAAI,CAAC,aAAa,CAAC,eAAe,EAAE,CAAC;IACvC,CAAC;IAED,iBAAiB;QACf,IAAI,CAAC,YAAY,CAAC,WAAW,EAAE,CAAC;QAEhC,IAAI,CAAC,YAAY,CAAC,oBAAoB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,mBAAmB,CAAC,EAAE;YACnF,IAAI,CAAC,kBAAkB,CAAC,iBAAiB,CAAC,mBAAmB,CAAC,EAAE,CAAC,CAAC,SAAS,CACzE,GAAG,EAAE;gBACH,IAAI,CAAC,YAAY,CAAC,UAAU,EAAE,CAAC;YACjC,CAAC,EACD,GAAG,EAAE;gBACH,IAAI,CAAC,YAAY,CAAC,UAAU,EAAE,CAAC;YACjC,CAAC,CACF,CAAC;QACJ,CAAC,CAAC,CAAC;IACL,CAAC;8GAnDU,yBAAyB;kGAAzB,yBAAyB,kEC9BtC,41KA+IA;;2FDjHa,yBAAyB;kBALrC,SAAS;+BACE,4BAA4B","sourcesContent":["/*\n * Copyright 2015-2024 Ritense BV, the Netherlands.\n *\n * Licensed under EUPL, Version 1.2 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" basis,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport {Component} from '@angular/core';\nimport {\n  ProcessLinkButtonService,\n  ProcessLinkService,\n  ProcessLinkStateService,\n  ProcessLinkStepService,\n} from '../../services';\nimport {take} from 'rxjs/operators';\n\n@Component({\n  selector: 'valtimo-process-link-modal',\n  templateUrl: './process-link-modal.component.html',\n  styleUrls: ['./process-link-modal.component.scss'],\n})\nexport class ProcessLinkModalComponent {\n  public readonly showModal$ = this.stateService.showModal$;\n  public readonly processStepName$ = this.stateService.elementName$;\n  public readonly steps$ = this.stepService.steps$;\n  public readonly currentStepIndex$ = this.stepService.currentStepIndex$;\n  public readonly currentStepId$ = this.stepService.currentStepId$;\n  public readonly showSaveButton$ = this.buttonService.showSaveButton$;\n  public readonly enableSaveButton$ = this.buttonService.enableSaveButton$;\n  public readonly showBackButton$ = this.buttonService.showBackButton$;\n  public readonly showNextButton$ = this.buttonService.showNextButton$;\n  public readonly enableNextButton$ = this.buttonService.enableNextButton$;\n  public readonly hideProgressIndicator$ = this.stateService.hideProgressIndicator$;\n  public readonly saving$ = this.stateService.saving$;\n  public readonly typeOfSelectedProcessLink$ = this.stateService.typeOfSelectedProcessLink$;\n\n  constructor(\n    private readonly stateService: ProcessLinkStateService,\n    private readonly stepService: ProcessLinkStepService,\n    private readonly buttonService: ProcessLinkButtonService,\n    private readonly processLinkService: ProcessLinkService\n  ) {}\n\n  closeModal(): void {\n    this.stateService.closeModal();\n  }\n\n  backButtonClick(): void {\n    this.buttonService.clickBackButton();\n  }\n\n  saveButtonClick(): void {\n    this.buttonService.clickSaveButton();\n  }\n\n  nextButtonClick(): void {\n    this.buttonService.clickNextButton();\n  }\n\n  unlinkButtonClick(): void {\n    this.stateService.startSaving();\n\n    this.stateService.selectedProcessLink$.pipe(take(1)).subscribe(selectedProcessLink => {\n      this.processLinkService.deleteProcessLink(selectedProcessLink.id).subscribe(\n        () => {\n          this.stateService.closeModal();\n        },\n        () => {\n          this.stateService.stopSaving();\n        }\n      );\n    });\n  }\n}\n","<!--\n  ~ Copyright 2015-2024 Ritense BV, the Netherlands.\n  ~\n  ~ Licensed under EUPL, Version 1.2 (the \"License\");\n  ~ you may not use this file except in compliance with the License.\n  ~ You may obtain a copy of the License at\n  ~\n  ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n  ~\n  ~ Unless required by applicable law or agreed to in writing, software\n  ~ distributed under the License is distributed on an \"AS IS\" basis,\n  ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n  ~ See the License for the specific language governing permissions and\n  ~ limitations under the License.\n  -->\n\n<div\n  class=\"process-link-modal-container\"\n  *ngIf=\"{\n    showModal: showModal$ | async,\n    processStepName: processStepName$ | async,\n    steps: steps$ | async,\n    currentStepIndex: currentStepIndex$ | async,\n    currentStepId: currentStepId$ | async,\n    showSaveButton: showSaveButton$ | async,\n    enableSaveButton: enableSaveButton$ | async,\n    showBackButton: showBackButton$ | async,\n    showNextButton: showNextButton$ | async,\n    enableNextButton: enableNextButton$ | async,\n    saving: saving$ | async,\n    hideProgressIndicator: hideProgressIndicator$ | async,\n    typeOfSelectedProgressLink: typeOfSelectedProcessLink$ | async\n  } as obs\"\n>\n  <cds-modal valtimoCdsModal [open]=\"obs.showModal\" size=\"lg\">\n    <cds-modal-header (closeSelect)=\"closeModal()\">\n      <h2 cdsModalHeaderLabel>{{ 'processLinkConfiguration.configureStep' | translate }}</h2>\n      <h3 cdsModalHeaderHeading>\n        {{\n          'processLinkConfiguration.modalTitle'\n            | translate: {processStepName: obs.processStepName || '-'}\n        }}\n      </h3>\n      <div class=\"process-link-progress\" *ngIf=\"!obs.typeOfSelectedProgressLink\">\n        <ng-container *ngTemplateOutlet=\"progressIndicator; context: {obs: obs}\"></ng-container>\n      </div>\n    </cds-modal-header>\n    <section cdsModalContent>\n      <ng-container *ngTemplateOutlet=\"stepContent; context: {obs: obs}\"></ng-container>\n    </section>\n    <ng-template *ngTemplateOutlet=\"footer; context: {obs: obs}\"></ng-template>\n  </cds-modal>\n</div>\n\n<ng-template #progressIndicator let-obs=\"obs\">\n  <cds-progress-indicator\n    *ngIf=\"obs.steps && !obs.hideProgressIndicator\"\n    [steps]=\"obs.steps\"\n    [current]=\"obs.currentStepIndex\"\n    spacing=\"equal\"\n  ></cds-progress-indicator>\n</ng-template>\n\n<ng-template #stepContent let-obs=\"obs\">\n  <div class=\"cds-loading-container\" *ngIf=\"obs.saving\">\n    <cds-loading></cds-loading>\n  </div>\n  <div [ngClass]=\"{hidden: obs.saving}\">\n    <ng-container>\n      <ng-container *ngIf=\"obs.currentStepId === 'chooseProcessLinkType'\">\n        <valtimo-choose-process-link-type></valtimo-choose-process-link-type>\n      </ng-container>\n      <ng-container\n        *ngIf=\"obs.currentStepId === 'selectForm' || obs.typeOfSelectedProgressLink === 'form'\"\n      >\n        <valtimo-select-form></valtimo-select-form>\n      </ng-container>\n      <ng-container\n        *ngIf=\"\n          obs.currentStepId === 'selectFormFlow' || obs.typeOfSelectedProgressLink === 'form-flow'\n        \"\n      >\n        <valtimo-select-form-flow></valtimo-select-form-flow>\n      </ng-container>\n      <ng-container *ngIf=\"obs.currentStepId === 'choosePluginConfiguration'\">\n        <valtimo-select-plugin-configuration></valtimo-select-plugin-configuration>\n      </ng-container>\n      <ng-container *ngIf=\"obs.currentStepId === 'choosePluginAction'\">\n        <valtimo-select-plugin-action></valtimo-select-plugin-action>\n      </ng-container>\n      <ng-container\n        *ngIf=\"\n          obs.currentStepId === 'configurePluginAction' ||\n          obs.typeOfSelectedProgressLink === 'plugin'\n        \"\n      >\n        <valtimo-plugin-action-configuration></valtimo-plugin-action-configuration>\n      </ng-container>\n    </ng-container>\n  </div>\n</ng-template>\n\n<ng-template #footer let-obs=\"obs\">\n  <cds-modal-footer *ngIf=\"!obs.saving\">\n    <div class=\"cancel-button\">\n      <button cdsButton=\"ghost\" (click)=\"closeModal()\" [disabled]=\"obs.disabled\">\n        {{ 'processLinkConfiguration.cancel' | translate }}\n      </button>\n    </div>\n    <div class=\"navigation-buttons\">\n      <button\n        *ngIf=\"obs.showBackButton && !obs.saving\"\n        cdsButton=\"secondary\"\n        (click)=\"backButtonClick()\"\n      >\n        {{ 'processLinkConfiguration.back' | translate }}\n      </button>\n      <button\n        cdsButton=\"primary\"\n        *ngIf=\"obs.showNextButton && !obs.saving\"\n        [disabled]=\"obs.enableNextButton === false\"\n        (click)=\"nextButtonClick()\"\n      >\n        {{ 'processLinkConfiguration.next' | translate }}\n      </button>\n      <button\n        cdsButton=\"danger--primary\"\n        *ngIf=\"obs.typeOfSelectedProgressLink\"\n        (click)=\"unlinkButtonClick()\"\n      >\n        {{ 'processLinkConfiguration.unlink' | translate }}\n      </button>\n      <button\n        cdsButton=\"primary\"\n        *ngIf=\"(obs.showSaveButton && !obs.saving) || obs.typeOfSelectedProgressLink\"\n        [disabled]=\"obs.enableSaveButton === false\"\n        (click)=\"saveButtonClick()\"\n      >\n        {{ 'processLinkConfiguration.complete' | translate }}\n      </button>\n    </div>\n  </cds-modal-footer>\n</ng-template>\n"]}
|
|
85
|
+
args: [{ selector: 'valtimo-process-link-modal', template: "<!--\n ~ Copyright 2015-2024 Ritense BV, the Netherlands.\n ~\n ~ Licensed under EUPL, Version 1.2 (the \"License\");\n ~ you may not use this file except in compliance with the License.\n ~ You may obtain a copy of the License at\n ~\n ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n ~\n ~ Unless required by applicable law or agreed to in writing, software\n ~ distributed under the License is distributed on an \"AS IS\" basis,\n ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n ~ See the License for the specific language governing permissions and\n ~ limitations under the License.\n -->\n\n<div\n class=\"process-link-modal-container\"\n *ngIf=\"{\n showModal: showModal$ | async,\n processStepName: processStepName$ | async,\n steps: steps$ | async,\n currentStepIndex: currentStepIndex$ | async,\n currentStepId: currentStepId$ | async,\n showSaveButton: showSaveButton$ | async,\n enableSaveButton: enableSaveButton$ | async,\n showBackButton: showBackButton$ | async,\n showNextButton: showNextButton$ | async,\n enableNextButton: enableNextButton$ | async,\n saving: saving$ | async,\n hideProgressIndicator: hideProgressIndicator$ | async,\n typeOfSelectedProgressLink: typeOfSelectedProcessLink$ | async\n } as obs\"\n>\n <cds-modal valtimoCdsModal [open]=\"obs.showModal\" size=\"lg\">\n <cds-modal-header (closeSelect)=\"closeModal()\">\n <h2 cdsModalHeaderLabel>{{ 'processLinkConfiguration.configureStep' | translate }}</h2>\n <h3 cdsModalHeaderHeading>\n {{\n 'processLinkConfiguration.modalTitle'\n | translate: {processStepName: obs.processStepName || '-'}\n }}\n </h3>\n <div class=\"process-link-progress\" *ngIf=\"!obs.typeOfSelectedProgressLink\">\n <ng-container *ngTemplateOutlet=\"progressIndicator; context: {obs: obs}\"></ng-container>\n </div>\n </cds-modal-header>\n <section cdsModalContent>\n <ng-container *ngTemplateOutlet=\"stepContent; context: {obs: obs}\"></ng-container>\n </section>\n <ng-template *ngTemplateOutlet=\"footer; context: {obs: obs}\"></ng-template>\n </cds-modal>\n</div>\n\n<ng-template #progressIndicator let-obs=\"obs\">\n <cds-progress-indicator\n *ngIf=\"obs.steps && !obs.hideProgressIndicator\"\n [steps]=\"obs.steps\"\n [current]=\"obs.currentStepIndex\"\n spacing=\"equal\"\n ></cds-progress-indicator>\n</ng-template>\n\n<ng-template #stepContent let-obs=\"obs\">\n <div class=\"cds-loading-container\" *ngIf=\"obs.saving\">\n <cds-loading></cds-loading>\n </div>\n <div [ngClass]=\"{hidden: obs.saving}\">\n <ng-container>\n <ng-container *ngIf=\"obs.currentStepId === 'chooseProcessLinkType'\">\n <valtimo-choose-process-link-type></valtimo-choose-process-link-type>\n </ng-container>\n <ng-container\n *ngIf=\"obs.currentStepId === 'selectForm' || obs.typeOfSelectedProgressLink === 'form'\"\n >\n <valtimo-select-form></valtimo-select-form>\n <br />\n <cds-toggle\n *ngIf=\"showViewModelToggle\"\n [label]=\"'processLinkConfiguration.toggleViewModel.title' | translate\"\n [onText]=\"'processLinkConfiguration.toggleViewModel.checkboxDescription' | translate\"\n [offText]=\"'processLinkConfiguration.toggleViewModel.checkboxDescription' | translate\"\n [checked]=\"viewModelEnabled$ | async\"\n (checkedChange)=\"toggleCheckedChange($event)\"\n ></cds-toggle>\n </ng-container>\n <ng-container\n *ngIf=\"\n obs.currentStepId === 'selectFormFlow' || obs.typeOfSelectedProgressLink === 'form-flow'\n \"\n >\n <valtimo-select-form-flow></valtimo-select-form-flow>\n </ng-container>\n <ng-container *ngIf=\"obs.currentStepId === 'choosePluginConfiguration'\">\n <valtimo-select-plugin-configuration></valtimo-select-plugin-configuration>\n </ng-container>\n <ng-container *ngIf=\"obs.currentStepId === 'choosePluginAction'\">\n <valtimo-select-plugin-action></valtimo-select-plugin-action>\n </ng-container>\n <ng-container\n *ngIf=\"\n obs.currentStepId === 'configurePluginAction' ||\n obs.typeOfSelectedProgressLink === 'plugin'\n \"\n >\n <valtimo-plugin-action-configuration></valtimo-plugin-action-configuration>\n </ng-container>\n </ng-container>\n </div>\n</ng-template>\n\n<ng-template #footer let-obs=\"obs\">\n <cds-modal-footer *ngIf=\"!obs.saving\">\n <div class=\"cancel-button\">\n <button cdsButton=\"ghost\" (click)=\"closeModal()\" [disabled]=\"obs.disabled\">\n {{ 'processLinkConfiguration.cancel' | translate }}\n </button>\n </div>\n <div class=\"navigation-buttons\">\n <button\n *ngIf=\"obs.showBackButton && !obs.saving\"\n cdsButton=\"secondary\"\n (click)=\"backButtonClick()\"\n >\n {{ 'processLinkConfiguration.back' | translate }}\n </button>\n <button\n cdsButton=\"primary\"\n *ngIf=\"obs.showNextButton && !obs.saving\"\n [disabled]=\"obs.enableNextButton === false\"\n (click)=\"nextButtonClick()\"\n >\n {{ 'processLinkConfiguration.next' | translate }}\n </button>\n <button\n cdsButton=\"danger--primary\"\n *ngIf=\"obs.typeOfSelectedProgressLink\"\n (click)=\"unlinkButtonClick()\"\n >\n {{ 'processLinkConfiguration.unlink' | translate }}\n </button>\n <button\n cdsButton=\"primary\"\n *ngIf=\"(obs.showSaveButton && !obs.saving) || obs.typeOfSelectedProgressLink\"\n [disabled]=\"obs.enableSaveButton === false\"\n (click)=\"saveButtonClick()\"\n >\n {{ 'processLinkConfiguration.complete' | translate }}\n </button>\n </div>\n </cds-modal-footer>\n</ng-template>\n", styles: ["::ng-deep .process-link-modal-container .cds--modal-container{max-width:960px;min-height:70%}::ng-deep .process-link-modal-container .cds--modal-footer{justify-content:space-between}.cds-loading-container{position:absolute;top:50px;padding-bottom:50px;left:0;width:100%;height:calc(100% - 50px);display:flex;justify-content:center;align-items:center;background:var(--cds-layer);z-index:99;box-sizing:border-box}.navigation-buttons{justify-content:flex-end}.navigation-buttons,.cancel-button{max-width:50%;display:flex;flex-direction:row;flex-grow:1}.navigation-buttons button,.cancel-button button{min-width:50%}.cancel-button{max-width:25%}.cancel-button button{min-width:100%}.process-link-progress{width:100%;margin-top:32px;margin-bottom:40px}.hidden{visibility:hidden}\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"] }]
|
|
86
|
+
}], ctorParameters: () => [{ type: i1.ProcessLinkStateService }, { type: i1.ProcessLinkStepService }, { type: i1.ProcessLinkButtonService }, { type: i1.ProcessLinkService }, { type: i1.ProcessLinkStateService }, { type: i2.ConfigService }] });
|
|
87
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"process-link-modal.component.js","sourceRoot":"","sources":["../../../../../../../projects/valtimo/process-link/src/lib/components/process-link-modal/process-link-modal.component.ts","../../../../../../../projects/valtimo/process-link/src/lib/components/process-link-modal/process-link-modal.component.html"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;GAcG;AAEH,OAAO,EAAC,SAAS,EAAC,MAAM,eAAe,CAAC;AAOxC,OAAO,EAAC,IAAI,EAAC,MAAM,gBAAgB,CAAC;;;;;;;;;;;;;;AAQpC,MAAM,OAAO,yBAAyB;IAmBpC,YACmB,YAAqC,EACrC,WAAmC,EACnC,aAAuC,EACvC,kBAAsC,EACtC,uBAAgD,EAChD,aAA4B;QAL5B,iBAAY,GAAZ,YAAY,CAAyB;QACrC,gBAAW,GAAX,WAAW,CAAwB;QACnC,kBAAa,GAAb,aAAa,CAA0B;QACvC,uBAAkB,GAAlB,kBAAkB,CAAoB;QACtC,4BAAuB,GAAvB,uBAAuB,CAAyB;QAChD,kBAAa,GAAb,aAAa,CAAe;QAxB/B,eAAU,GAAG,IAAI,CAAC,YAAY,CAAC,UAAU,CAAC;QAC1C,qBAAgB,GAAG,IAAI,CAAC,YAAY,CAAC,YAAY,CAAC;QAClD,WAAM,GAAG,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC;QACjC,sBAAiB,GAAG,IAAI,CAAC,WAAW,CAAC,iBAAiB,CAAC;QACvD,mBAAc,GAAG,IAAI,CAAC,WAAW,CAAC,cAAc,CAAC;QACjD,oBAAe,GAAG,IAAI,CAAC,aAAa,CAAC,eAAe,CAAC;QACrD,sBAAiB,GAAG,IAAI,CAAC,aAAa,CAAC,iBAAiB,CAAC;QACzD,oBAAe,GAAG,IAAI,CAAC,aAAa,CAAC,eAAe,CAAC;QACrD,oBAAe,GAAG,IAAI,CAAC,aAAa,CAAC,eAAe,CAAC;QACrD,sBAAiB,GAAG,IAAI,CAAC,aAAa,CAAC,iBAAiB,CAAC;QACzD,2BAAsB,GAAG,IAAI,CAAC,YAAY,CAAC,sBAAsB,CAAC;QAClE,YAAO,GAAG,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC;QACpC,+BAA0B,GAAG,IAAI,CAAC,YAAY,CAAC,0BAA0B,CAAC;QAC1E,sBAAiB,GAAG,IAAI,CAAC,YAAY,CAAC,iBAAiB,CAAC;QAExD,wBAAmB,GACjC,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,cAAc,CAAC,mBAAmB,CAAC;IAS5D,CAAC;IAEJ,UAAU;QACR,IAAI,CAAC,YAAY,CAAC,UAAU,EAAE,CAAC;IACjC,CAAC;IAED,eAAe;QACb,IAAI,CAAC,aAAa,CAAC,eAAe,EAAE,CAAC;IACvC,CAAC;IAED,eAAe;QACb,IAAI,CAAC,aAAa,CAAC,eAAe,EAAE,CAAC;IACvC,CAAC;IAED,eAAe;QACb,IAAI,CAAC,aAAa,CAAC,eAAe,EAAE,CAAC;IACvC,CAAC;IAED,iBAAiB;QACf,IAAI,CAAC,YAAY,CAAC,WAAW,EAAE,CAAC;QAEhC,IAAI,CAAC,YAAY,CAAC,oBAAoB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,mBAAmB,CAAC,EAAE;YACnF,IAAI,CAAC,kBAAkB,CAAC,iBAAiB,CAAC,mBAAmB,CAAC,EAAE,CAAC,CAAC,SAAS,CACzE,GAAG,EAAE;gBACH,IAAI,CAAC,YAAY,CAAC,UAAU,EAAE,CAAC;YACjC,CAAC,EACD,GAAG,EAAE;gBACH,IAAI,CAAC,YAAY,CAAC,UAAU,EAAE,CAAC;YACjC,CAAC,CACF,CAAC;QACJ,CAAC,CAAC,CAAC;IACL,CAAC;IAEM,mBAAmB,CAAC,KAAc;QACvC,IAAI,CAAC,uBAAuB,CAAC,mBAAmB,CAAC,KAAK,CAAC,CAAC;IAC1D,CAAC;8GA7DU,yBAAyB;kGAAzB,yBAAyB,kEC/BtC,20LAwJA;;2FDzHa,yBAAyB;kBALrC,SAAS;+BACE,4BAA4B","sourcesContent":["/*\n * Copyright 2015-2024 Ritense BV, the Netherlands.\n *\n * Licensed under EUPL, Version 1.2 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" basis,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport {Component} from '@angular/core';\nimport {\n  ProcessLinkButtonService,\n  ProcessLinkService,\n  ProcessLinkStateService,\n  ProcessLinkStepService,\n} from '../../services';\nimport {take} from 'rxjs/operators';\nimport {ConfigService} from '@valtimo/config';\n\n@Component({\n  selector: 'valtimo-process-link-modal',\n  templateUrl: './process-link-modal.component.html',\n  styleUrls: ['./process-link-modal.component.scss'],\n})\nexport class ProcessLinkModalComponent {\n  public readonly showModal$ = this.stateService.showModal$;\n  public readonly processStepName$ = this.stateService.elementName$;\n  public readonly steps$ = this.stepService.steps$;\n  public readonly currentStepIndex$ = this.stepService.currentStepIndex$;\n  public readonly currentStepId$ = this.stepService.currentStepId$;\n  public readonly showSaveButton$ = this.buttonService.showSaveButton$;\n  public readonly enableSaveButton$ = this.buttonService.enableSaveButton$;\n  public readonly showBackButton$ = this.buttonService.showBackButton$;\n  public readonly showNextButton$ = this.buttonService.showNextButton$;\n  public readonly enableNextButton$ = this.buttonService.enableNextButton$;\n  public readonly hideProgressIndicator$ = this.stateService.hideProgressIndicator$;\n  public readonly saving$ = this.stateService.saving$;\n  public readonly typeOfSelectedProcessLink$ = this.stateService.typeOfSelectedProcessLink$;\n  public readonly viewModelEnabled$ = this.stateService.viewModelEnabled$;\n\n  public readonly showViewModelToggle =\n    this.configService.config.featureToggles.enableFormViewModel;\n\n  constructor(\n    private readonly stateService: ProcessLinkStateService,\n    private readonly stepService: ProcessLinkStepService,\n    private readonly buttonService: ProcessLinkButtonService,\n    private readonly processLinkService: ProcessLinkService,\n    private readonly processLinkStateService: ProcessLinkStateService,\n    private readonly configService: ConfigService\n  ) {}\n\n  closeModal(): void {\n    this.stateService.closeModal();\n  }\n\n  backButtonClick(): void {\n    this.buttonService.clickBackButton();\n  }\n\n  saveButtonClick(): void {\n    this.buttonService.clickSaveButton();\n  }\n\n  nextButtonClick(): void {\n    this.buttonService.clickNextButton();\n  }\n\n  unlinkButtonClick(): void {\n    this.stateService.startSaving();\n\n    this.stateService.selectedProcessLink$.pipe(take(1)).subscribe(selectedProcessLink => {\n      this.processLinkService.deleteProcessLink(selectedProcessLink.id).subscribe(\n        () => {\n          this.stateService.closeModal();\n        },\n        () => {\n          this.stateService.stopSaving();\n        }\n      );\n    });\n  }\n\n  public toggleCheckedChange(value: boolean): void {\n    this.processLinkStateService.setViewModelEnabled(value);\n  }\n}\n","<!--\n  ~ Copyright 2015-2024 Ritense BV, the Netherlands.\n  ~\n  ~ Licensed under EUPL, Version 1.2 (the \"License\");\n  ~ you may not use this file except in compliance with the License.\n  ~ You may obtain a copy of the License at\n  ~\n  ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n  ~\n  ~ Unless required by applicable law or agreed to in writing, software\n  ~ distributed under the License is distributed on an \"AS IS\" basis,\n  ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n  ~ See the License for the specific language governing permissions and\n  ~ limitations under the License.\n  -->\n\n<div\n  class=\"process-link-modal-container\"\n  *ngIf=\"{\n    showModal: showModal$ | async,\n    processStepName: processStepName$ | async,\n    steps: steps$ | async,\n    currentStepIndex: currentStepIndex$ | async,\n    currentStepId: currentStepId$ | async,\n    showSaveButton: showSaveButton$ | async,\n    enableSaveButton: enableSaveButton$ | async,\n    showBackButton: showBackButton$ | async,\n    showNextButton: showNextButton$ | async,\n    enableNextButton: enableNextButton$ | async,\n    saving: saving$ | async,\n    hideProgressIndicator: hideProgressIndicator$ | async,\n    typeOfSelectedProgressLink: typeOfSelectedProcessLink$ | async\n  } as obs\"\n>\n  <cds-modal valtimoCdsModal [open]=\"obs.showModal\" size=\"lg\">\n    <cds-modal-header (closeSelect)=\"closeModal()\">\n      <h2 cdsModalHeaderLabel>{{ 'processLinkConfiguration.configureStep' | translate }}</h2>\n      <h3 cdsModalHeaderHeading>\n        {{\n          'processLinkConfiguration.modalTitle'\n            | translate: {processStepName: obs.processStepName || '-'}\n        }}\n      </h3>\n      <div class=\"process-link-progress\" *ngIf=\"!obs.typeOfSelectedProgressLink\">\n        <ng-container *ngTemplateOutlet=\"progressIndicator; context: {obs: obs}\"></ng-container>\n      </div>\n    </cds-modal-header>\n    <section cdsModalContent>\n      <ng-container *ngTemplateOutlet=\"stepContent; context: {obs: obs}\"></ng-container>\n    </section>\n    <ng-template *ngTemplateOutlet=\"footer; context: {obs: obs}\"></ng-template>\n  </cds-modal>\n</div>\n\n<ng-template #progressIndicator let-obs=\"obs\">\n  <cds-progress-indicator\n    *ngIf=\"obs.steps && !obs.hideProgressIndicator\"\n    [steps]=\"obs.steps\"\n    [current]=\"obs.currentStepIndex\"\n    spacing=\"equal\"\n  ></cds-progress-indicator>\n</ng-template>\n\n<ng-template #stepContent let-obs=\"obs\">\n  <div class=\"cds-loading-container\" *ngIf=\"obs.saving\">\n    <cds-loading></cds-loading>\n  </div>\n  <div [ngClass]=\"{hidden: obs.saving}\">\n    <ng-container>\n      <ng-container *ngIf=\"obs.currentStepId === 'chooseProcessLinkType'\">\n        <valtimo-choose-process-link-type></valtimo-choose-process-link-type>\n      </ng-container>\n      <ng-container\n        *ngIf=\"obs.currentStepId === 'selectForm' || obs.typeOfSelectedProgressLink === 'form'\"\n      >\n        <valtimo-select-form></valtimo-select-form>\n        <br />\n        <cds-toggle\n          *ngIf=\"showViewModelToggle\"\n          [label]=\"'processLinkConfiguration.toggleViewModel.title' | translate\"\n          [onText]=\"'processLinkConfiguration.toggleViewModel.checkboxDescription' | translate\"\n          [offText]=\"'processLinkConfiguration.toggleViewModel.checkboxDescription' | translate\"\n          [checked]=\"viewModelEnabled$ | async\"\n          (checkedChange)=\"toggleCheckedChange($event)\"\n        ></cds-toggle>\n      </ng-container>\n      <ng-container\n        *ngIf=\"\n          obs.currentStepId === 'selectFormFlow' || obs.typeOfSelectedProgressLink === 'form-flow'\n        \"\n      >\n        <valtimo-select-form-flow></valtimo-select-form-flow>\n      </ng-container>\n      <ng-container *ngIf=\"obs.currentStepId === 'choosePluginConfiguration'\">\n        <valtimo-select-plugin-configuration></valtimo-select-plugin-configuration>\n      </ng-container>\n      <ng-container *ngIf=\"obs.currentStepId === 'choosePluginAction'\">\n        <valtimo-select-plugin-action></valtimo-select-plugin-action>\n      </ng-container>\n      <ng-container\n        *ngIf=\"\n          obs.currentStepId === 'configurePluginAction' ||\n          obs.typeOfSelectedProgressLink === 'plugin'\n        \"\n      >\n        <valtimo-plugin-action-configuration></valtimo-plugin-action-configuration>\n      </ng-container>\n    </ng-container>\n  </div>\n</ng-template>\n\n<ng-template #footer let-obs=\"obs\">\n  <cds-modal-footer *ngIf=\"!obs.saving\">\n    <div class=\"cancel-button\">\n      <button cdsButton=\"ghost\" (click)=\"closeModal()\" [disabled]=\"obs.disabled\">\n        {{ 'processLinkConfiguration.cancel' | translate }}\n      </button>\n    </div>\n    <div class=\"navigation-buttons\">\n      <button\n        *ngIf=\"obs.showBackButton && !obs.saving\"\n        cdsButton=\"secondary\"\n        (click)=\"backButtonClick()\"\n      >\n        {{ 'processLinkConfiguration.back' | translate }}\n      </button>\n      <button\n        cdsButton=\"primary\"\n        *ngIf=\"obs.showNextButton && !obs.saving\"\n        [disabled]=\"obs.enableNextButton === false\"\n        (click)=\"nextButtonClick()\"\n      >\n        {{ 'processLinkConfiguration.next' | translate }}\n      </button>\n      <button\n        cdsButton=\"danger--primary\"\n        *ngIf=\"obs.typeOfSelectedProgressLink\"\n        (click)=\"unlinkButtonClick()\"\n      >\n        {{ 'processLinkConfiguration.unlink' | translate }}\n      </button>\n      <button\n        cdsButton=\"primary\"\n        *ngIf=\"(obs.showSaveButton && !obs.saving) || obs.typeOfSelectedProgressLink\"\n        [disabled]=\"obs.enableSaveButton === false\"\n        (click)=\"saveButtonClick()\"\n      >\n        {{ 'processLinkConfiguration.complete' | translate }}\n      </button>\n    </div>\n  </cds-modal-footer>\n</ng-template>\n"]}
|
|
@@ -84,10 +84,13 @@ export class SelectFormComponent {
|
|
|
84
84
|
});
|
|
85
85
|
}
|
|
86
86
|
updateProcessLink() {
|
|
87
|
-
this.stateService.selectedProcessLink
|
|
87
|
+
combineLatest([this.stateService.selectedProcessLink$, this.stateService.viewModelEnabled$])
|
|
88
|
+
.pipe(take(1))
|
|
89
|
+
.subscribe(([selectedProcessLink, viewModelEnabled]) => {
|
|
88
90
|
const updateProcessLinkRequest = {
|
|
89
91
|
id: selectedProcessLink.id,
|
|
90
92
|
formDefinitionId: this._selectedFormDefinition.id,
|
|
93
|
+
viewModelEnabled,
|
|
91
94
|
};
|
|
92
95
|
this.processLinkService.updateProcessLink(updateProcessLinkRequest).subscribe(() => {
|
|
93
96
|
this.stateService.closeModal();
|
|
@@ -97,13 +100,18 @@ export class SelectFormComponent {
|
|
|
97
100
|
});
|
|
98
101
|
}
|
|
99
102
|
saveNewProcessLink() {
|
|
100
|
-
combineLatest([
|
|
101
|
-
|
|
103
|
+
combineLatest([
|
|
104
|
+
this.stateService.modalParams$,
|
|
105
|
+
this.stateService.selectedProcessLinkTypeId$,
|
|
106
|
+
this.stateService.viewModelEnabled$,
|
|
107
|
+
])
|
|
108
|
+
.pipe(take(1), switchMap(([modalParams, processLinkTypeId, viewModelEnabled]) => this.processLinkService.saveProcessLink({
|
|
102
109
|
formDefinitionId: this._selectedFormDefinition.id,
|
|
103
110
|
activityType: modalParams.element.activityListenerType,
|
|
104
111
|
processDefinitionId: modalParams.processDefinitionId,
|
|
105
112
|
processLinkType: processLinkTypeId,
|
|
106
113
|
activityId: modalParams.element.id,
|
|
114
|
+
viewModelEnabled,
|
|
107
115
|
})))
|
|
108
116
|
.subscribe(() => {
|
|
109
117
|
this.stateService.closeModal();
|
|
@@ -118,4 +126,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.3", ngImpor
|
|
|
118
126
|
type: Component,
|
|
119
127
|
args: [{ selector: 'valtimo-select-form', 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<ng-container\n *ngIf=\"{\n formDefinitions: formDefinitionListItems$ | async,\n saving: saving$ | async\n } as obs\"\n>\n <p class=\"step-description\">\n {{ 'processLinkConfiguration.chooseFormDescription' | translate }}\n </p>\n <div class=\"select-form\">\n <cds-combo-box\n [appendInline]=\"true\"\n [disabled]=\"!obs.formDefinitions || obs.saving\"\n [items]=\"obs.formDefinitions || []\"\n [placeholder]=\"'interface.typeToSearch' | translate\"\n (selected)=\"selectFormDefinition($event)\"\n [label]=\"'processLinkSteps.selectForm' | translate\"\n ><cds-dropdown-list></cds-dropdown-list\n ></cds-combo-box>\n </div>\n</ng-container>\n", styles: [".label-with-tooltip{display:flex;align-items:center}.select-form{display:flex;flex-direction:column;width:100%;margin-top:24px}\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"] }]
|
|
120
128
|
}], ctorParameters: () => [{ type: i1.FormService }, { type: i2.ProcessLinkStateService }, { type: i2.ProcessLinkService }, { type: i2.ProcessLinkButtonService }] });
|
|
121
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select-form.component.js","sourceRoot":"","sources":["../../../../../../../projects/valtimo/process-link/src/lib/components/select-form/select-form.component.ts","../../../../../../../projects/valtimo/process-link/src/lib/components/select-form/select-form.component.html"],"names":[],"mappings":"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","sourcesContent":["/*\n * Copyright 2015-2024 Ritense BV, the Netherlands.\n *\n * Licensed under EUPL, Version 1.2 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" basis,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport {Component, OnDestroy, OnInit} from '@angular/core';\nimport {FormService} from '@valtimo/form';\nimport {combineLatest, map, Observable, Subscription, switchMap, tap} from 'rxjs';\nimport {\n  ProcessLinkButtonService,\n  ProcessLinkService,\n  ProcessLinkStateService,\n} from '../../services';\nimport {FormDefinitionListItem, FormProcessLinkUpdateRequestDto} from '../../models';\nimport {take} from 'rxjs/operators';\n\n@Component({\n  selector: 'valtimo-select-form',\n  templateUrl: './select-form.component.html',\n  styleUrls: ['./select-form.component.scss'],\n})\nexport class SelectFormComponent implements OnInit, OnDestroy {\n  public readonly saving$ = this.stateService.saving$;\n  private readonly formDefinitions$ = this.formService.getAllFormDefinitions();\n  public readonly formDefinitionListItems$: Observable<Array<FormDefinitionListItem>> =\n    combineLatest([this.stateService.selectedProcessLink$, this.formDefinitions$]).pipe(\n      map(([selectedProcessLink, formDefinitions]) =>\n        formDefinitions.map(definition => ({\n          content: definition.name,\n          id: definition.id,\n          selected: selectedProcessLink\n            ? selectedProcessLink.formDefinitionId === definition.id\n            : false,\n        }))\n      ),\n      tap(formDefinitionListItems => {\n        const selectedItem = formDefinitionListItems.find(item => item.selected);\n\n        if (selectedItem) {\n          this.selectFormDefinition(selectedItem);\n        }\n      })\n    );\n\n  private _selectedFormDefinition!: FormDefinitionListItem;\n  private _subscriptions = new Subscription();\n\n  constructor(\n    private readonly formService: FormService,\n    private readonly stateService: ProcessLinkStateService,\n    private readonly processLinkService: ProcessLinkService,\n    private readonly buttonService: ProcessLinkButtonService\n  ) {}\n\n  ngOnInit(): void {\n    this.openBackButtonSubscription();\n    this.openSaveButtonSubscription();\n  }\n\n  ngOnDestroy(): void {\n    this._subscriptions.unsubscribe();\n  }\n\n  selectFormDefinition(formDefinition: FormDefinitionListItem): void {\n    if (typeof formDefinition === 'object' && formDefinition.id) {\n      this._selectedFormDefinition = formDefinition;\n      this.buttonService.enableSaveButton();\n    } else {\n      this._selectedFormDefinition = null;\n      this.buttonService.disableSaveButton();\n    }\n  }\n\n  private openBackButtonSubscription(): void {\n    this._subscriptions.add(\n      this.buttonService.backButtonClick$.subscribe(() => {\n        this.stateService.setInitial();\n      })\n    );\n  }\n\n  private openSaveButtonSubscription(): void {\n    this._subscriptions.add(\n      this.buttonService.saveButtonClick$.subscribe(() => {\n        this.stateService.startSaving();\n        this.saveProcessLink();\n      })\n    );\n  }\n\n  private saveProcessLink(): void {\n    this.stateService.selectedProcessLink$.pipe(take(1)).subscribe(selectedProcessLink => {\n      if (selectedProcessLink) {\n        this.updateProcessLink();\n      } else {\n        this.saveNewProcessLink();\n      }\n    });\n  }\n\n  private updateProcessLink(): void {\n    this.stateService.selectedProcessLink$.pipe(take(1)).subscribe(selectedProcessLink => {\n      const updateProcessLinkRequest: FormProcessLinkUpdateRequestDto = {\n        id: selectedProcessLink.id,\n        formDefinitionId: this._selectedFormDefinition.id,\n      };\n\n      this.processLinkService.updateProcessLink(updateProcessLinkRequest).subscribe(\n        () => {\n          this.stateService.closeModal();\n        },\n        () => {\n          this.stateService.stopSaving();\n        }\n      );\n    });\n  }\n\n  private saveNewProcessLink(): void {\n    combineLatest([this.stateService.modalParams$, this.stateService.selectedProcessLinkTypeId$])\n      .pipe(\n        take(1),\n        switchMap(([modalParams, processLinkTypeId]) =>\n          this.processLinkService.saveProcessLink({\n            formDefinitionId: this._selectedFormDefinition.id,\n            activityType: modalParams.element.activityListenerType,\n            processDefinitionId: modalParams.processDefinitionId,\n            processLinkType: processLinkTypeId,\n            activityId: modalParams.element.id,\n          })\n        )\n      )\n      .subscribe(\n        () => {\n          this.stateService.closeModal();\n        },\n        () => {\n          this.stateService.stopSaving();\n        }\n      );\n  }\n}\n","<!--\n  ~ Copyright 2015-2024 Ritense BV, the Netherlands.\n  ~\n  ~ Licensed under EUPL, Version 1.2 (the \"License\");\n  ~ you may not use this file except in compliance with the License.\n  ~ You may obtain a copy of the License at\n  ~\n  ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n  ~\n  ~ Unless required by applicable law or agreed to in writing, software\n  ~ distributed under the License is distributed on an \"AS IS\" basis,\n  ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n  ~ See the License for the specific language governing permissions and\n  ~ limitations under the License.\n  -->\n\n<ng-container\n  *ngIf=\"{\n    formDefinitions: formDefinitionListItems$ | async,\n    saving: saving$ | async\n  } as obs\"\n>\n  <p class=\"step-description\">\n    {{ 'processLinkConfiguration.chooseFormDescription' | translate }}\n  </p>\n  <div class=\"select-form\">\n    <cds-combo-box\n      [appendInline]=\"true\"\n      [disabled]=\"!obs.formDefinitions || obs.saving\"\n      [items]=\"obs.formDefinitions || []\"\n      [placeholder]=\"'interface.typeToSearch' | translate\"\n      (selected)=\"selectFormDefinition($event)\"\n      [label]=\"'processLinkSteps.selectForm' | translate\"\n      ><cds-dropdown-list></cds-dropdown-list\n    ></cds-combo-box>\n  </div>\n</ng-container>\n"]}
|
|
129
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select-form.component.js","sourceRoot":"","sources":["../../../../../../../projects/valtimo/process-link/src/lib/components/select-form/select-form.component.ts","../../../../../../../projects/valtimo/process-link/src/lib/components/select-form/select-form.component.html"],"names":[],"mappings":"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","sourcesContent":["/*\n * Copyright 2015-2024 Ritense BV, the Netherlands.\n *\n * Licensed under EUPL, Version 1.2 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" basis,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport {Component, OnDestroy, OnInit} from '@angular/core';\nimport {FormService} from '@valtimo/form';\nimport {combineLatest, map, Observable, Subscription, switchMap, tap} from 'rxjs';\nimport {\n  ProcessLinkButtonService,\n  ProcessLinkService,\n  ProcessLinkStateService,\n} from '../../services';\nimport {FormDefinitionListItem, FormProcessLinkUpdateRequestDto} from '../../models';\nimport {take} from 'rxjs/operators';\n\n@Component({\n  selector: 'valtimo-select-form',\n  templateUrl: './select-form.component.html',\n  styleUrls: ['./select-form.component.scss'],\n})\nexport class SelectFormComponent implements OnInit, OnDestroy {\n  public readonly saving$ = this.stateService.saving$;\n  private readonly formDefinitions$ = this.formService.getAllFormDefinitions();\n  public readonly formDefinitionListItems$: Observable<Array<FormDefinitionListItem>> =\n    combineLatest([this.stateService.selectedProcessLink$, this.formDefinitions$]).pipe(\n      map(([selectedProcessLink, formDefinitions]) =>\n        formDefinitions.map(definition => ({\n          content: definition.name,\n          id: definition.id,\n          selected: selectedProcessLink\n            ? selectedProcessLink.formDefinitionId === definition.id\n            : false,\n        }))\n      ),\n      tap(formDefinitionListItems => {\n        const selectedItem = formDefinitionListItems.find(item => item.selected);\n\n        if (selectedItem) {\n          this.selectFormDefinition(selectedItem);\n        }\n      })\n    );\n\n  private _selectedFormDefinition!: FormDefinitionListItem;\n  private _subscriptions = new Subscription();\n\n  constructor(\n    private readonly formService: FormService,\n    private readonly stateService: ProcessLinkStateService,\n    private readonly processLinkService: ProcessLinkService,\n    private readonly buttonService: ProcessLinkButtonService\n  ) {}\n\n  ngOnInit(): void {\n    this.openBackButtonSubscription();\n    this.openSaveButtonSubscription();\n  }\n\n  ngOnDestroy(): void {\n    this._subscriptions.unsubscribe();\n  }\n\n  selectFormDefinition(formDefinition: FormDefinitionListItem): void {\n    if (typeof formDefinition === 'object' && formDefinition.id) {\n      this._selectedFormDefinition = formDefinition;\n      this.buttonService.enableSaveButton();\n    } else {\n      this._selectedFormDefinition = null;\n      this.buttonService.disableSaveButton();\n    }\n  }\n\n  private openBackButtonSubscription(): void {\n    this._subscriptions.add(\n      this.buttonService.backButtonClick$.subscribe(() => {\n        this.stateService.setInitial();\n      })\n    );\n  }\n\n  private openSaveButtonSubscription(): void {\n    this._subscriptions.add(\n      this.buttonService.saveButtonClick$.subscribe(() => {\n        this.stateService.startSaving();\n        this.saveProcessLink();\n      })\n    );\n  }\n\n  private saveProcessLink(): void {\n    this.stateService.selectedProcessLink$.pipe(take(1)).subscribe(selectedProcessLink => {\n      if (selectedProcessLink) {\n        this.updateProcessLink();\n      } else {\n        this.saveNewProcessLink();\n      }\n    });\n  }\n\n  private updateProcessLink(): void {\n    combineLatest([this.stateService.selectedProcessLink$, this.stateService.viewModelEnabled$])\n      .pipe(take(1))\n      .subscribe(([selectedProcessLink, viewModelEnabled]) => {\n        const updateProcessLinkRequest: FormProcessLinkUpdateRequestDto = {\n          id: selectedProcessLink.id,\n          formDefinitionId: this._selectedFormDefinition.id,\n          viewModelEnabled,\n        };\n\n        this.processLinkService.updateProcessLink(updateProcessLinkRequest).subscribe(\n          () => {\n            this.stateService.closeModal();\n          },\n          () => {\n            this.stateService.stopSaving();\n          }\n        );\n      });\n  }\n\n  private saveNewProcessLink(): void {\n    combineLatest([\n      this.stateService.modalParams$,\n      this.stateService.selectedProcessLinkTypeId$,\n      this.stateService.viewModelEnabled$,\n    ])\n      .pipe(\n        take(1),\n        switchMap(([modalParams, processLinkTypeId, viewModelEnabled]) =>\n          this.processLinkService.saveProcessLink({\n            formDefinitionId: this._selectedFormDefinition.id,\n            activityType: modalParams.element.activityListenerType,\n            processDefinitionId: modalParams.processDefinitionId,\n            processLinkType: processLinkTypeId,\n            activityId: modalParams.element.id,\n            viewModelEnabled,\n          })\n        )\n      )\n      .subscribe(\n        () => {\n          this.stateService.closeModal();\n        },\n        () => {\n          this.stateService.stopSaving();\n        }\n      );\n  }\n}\n","<!--\n  ~ Copyright 2015-2024 Ritense BV, the Netherlands.\n  ~\n  ~ Licensed under EUPL, Version 1.2 (the \"License\");\n  ~ you may not use this file except in compliance with the License.\n  ~ You may obtain a copy of the License at\n  ~\n  ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n  ~\n  ~ Unless required by applicable law or agreed to in writing, software\n  ~ distributed under the License is distributed on an \"AS IS\" basis,\n  ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n  ~ See the License for the specific language governing permissions and\n  ~ limitations under the License.\n  -->\n\n<ng-container\n  *ngIf=\"{\n    formDefinitions: formDefinitionListItems$ | async,\n    saving: saving$ | async\n  } as obs\"\n>\n  <p class=\"step-description\">\n    {{ 'processLinkConfiguration.chooseFormDescription' | translate }}\n  </p>\n  <div class=\"select-form\">\n    <cds-combo-box\n      [appendInline]=\"true\"\n      [disabled]=\"!obs.formDefinitions || obs.saving\"\n      [items]=\"obs.formDefinitions || []\"\n      [placeholder]=\"'interface.typeToSearch' | translate\"\n      (selected)=\"selectFormDefinition($event)\"\n      [label]=\"'processLinkSteps.selectForm' | translate\"\n      ><cds-dropdown-list></cds-dropdown-list\n    ></cds-combo-box>\n  </div>\n</ng-container>\n"]}
|
|
@@ -14,4 +14,4 @@
|
|
|
14
14
|
* limitations under the License.
|
|
15
15
|
*/
|
|
16
16
|
export {};
|
|
17
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvY2Vzcy1saW5rLm1vZGVsLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdmFsdGltby9wcm9jZXNzLWxpbmsvc3JjL2xpYi9tb2RlbHMvcHJvY2Vzcy1saW5rLm1vZGVsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7Ozs7Ozs7OztHQWNHIiwic291cmNlc0NvbnRlbnQiOlsiLypcbiAqIENvcHlyaWdodCAyMDE1LTIwMjQgUml0ZW5zZSBCViwgdGhlIE5ldGhlcmxhbmRzLlxuICpcbiAqIExpY2Vuc2VkIHVuZGVyIEVVUEwsIFZlcnNpb24gMS4yICh0aGUgXCJMaWNlbnNlXCIpO1xuICogeW91IG1heSBub3QgdXNlIHRoaXMgZmlsZSBleGNlcHQgaW4gY29tcGxpYW5jZSB3aXRoIHRoZSBMaWNlbnNlLlxuICogWW91IG1heSBvYnRhaW4gYSBjb3B5IG9mIHRoZSBMaWNlbnNlIGF0XG4gKlxuICogaHR0cHM6Ly9qb2ludXAuZWMuZXVyb3BhLmV1L2NvbGxlY3Rpb24vZXVwbC9ldXBsLXRleHQtZXVwbC0xMlxuICpcbiAqIFVubGVzcyByZXF1aXJlZCBieSBhcHBsaWNhYmxlIGxhdyBvciBhZ3JlZWQgdG8gaW4gd3JpdGluZywgc29mdHdhcmVcbiAqIGRpc3RyaWJ1dGVkIHVuZGVyIHRoZSBMaWNlbnNlIGlzIGRpc3RyaWJ1dGVkIG9uIGFuIFwiQVMgSVNcIiBiYXNpcyxcbiAqIFdJVEhPVVQgV0FSUkFOVElFUyBPUiBDT05ESVRJT05TIE9GIEFOWSBLSU5ELCBlaXRoZXIgZXhwcmVzcyBvciBpbXBsaWVkLlxuICogU2VlIHRoZSBMaWNlbnNlIGZvciB0aGUgc3BlY2lmaWMgbGFuZ3VhZ2UgZ292ZXJuaW5nIHBlcm1pc3Npb25zIGFuZFxuICogbGltaXRhdGlvbnMgdW5kZXIgdGhlIExpY2Vuc2UuXG4gKi9cblxuaW50ZXJmYWNlIFByb2Nlc3NMaW5rIHtcbiAgaWQ6IHN0cmluZztcbiAgcHJvY2Vzc0RlZmluaXRpb25JZDogc3RyaW5nO1xuICBhY3Rpdml0eUlkOiBzdHJpbmc7XG4gIGFjdGl2aXR5VHlwZTogc3RyaW5nO1xuICBwcm9jZXNzTGlua1R5cGU6IHN0cmluZztcbiAgcGx1Z2luQ29uZmlndXJhdGlvbklkPzogc3RyaW5nO1xuICBwbHVnaW5BY3Rpb25EZWZpbml0aW9uS2V5Pzogc3RyaW5nO1xuICBhY3Rpb25Qcm9wZXJ0aWVzPzoge1xuICAgIFtrZXk6IHN0cmluZ106IGFueTtcbiAgfTtcbiAgZm9ybURlZmluaXRpb25JZD86IHN0cmluZztcbiAgZm9ybUZsb3dEZWZpbml0aW9uSWQ/
|
|
17
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvY2Vzcy1saW5rLm1vZGVsLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdmFsdGltby9wcm9jZXNzLWxpbmsvc3JjL2xpYi9tb2RlbHMvcHJvY2Vzcy1saW5rLm1vZGVsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7Ozs7Ozs7OztHQWNHIiwic291cmNlc0NvbnRlbnQiOlsiLypcbiAqIENvcHlyaWdodCAyMDE1LTIwMjQgUml0ZW5zZSBCViwgdGhlIE5ldGhlcmxhbmRzLlxuICpcbiAqIExpY2Vuc2VkIHVuZGVyIEVVUEwsIFZlcnNpb24gMS4yICh0aGUgXCJMaWNlbnNlXCIpO1xuICogeW91IG1heSBub3QgdXNlIHRoaXMgZmlsZSBleGNlcHQgaW4gY29tcGxpYW5jZSB3aXRoIHRoZSBMaWNlbnNlLlxuICogWW91IG1heSBvYnRhaW4gYSBjb3B5IG9mIHRoZSBMaWNlbnNlIGF0XG4gKlxuICogaHR0cHM6Ly9qb2ludXAuZWMuZXVyb3BhLmV1L2NvbGxlY3Rpb24vZXVwbC9ldXBsLXRleHQtZXVwbC0xMlxuICpcbiAqIFVubGVzcyByZXF1aXJlZCBieSBhcHBsaWNhYmxlIGxhdyBvciBhZ3JlZWQgdG8gaW4gd3JpdGluZywgc29mdHdhcmVcbiAqIGRpc3RyaWJ1dGVkIHVuZGVyIHRoZSBMaWNlbnNlIGlzIGRpc3RyaWJ1dGVkIG9uIGFuIFwiQVMgSVNcIiBiYXNpcyxcbiAqIFdJVEhPVVQgV0FSUkFOVElFUyBPUiBDT05ESVRJT05TIE9GIEFOWSBLSU5ELCBlaXRoZXIgZXhwcmVzcyBvciBpbXBsaWVkLlxuICogU2VlIHRoZSBMaWNlbnNlIGZvciB0aGUgc3BlY2lmaWMgbGFuZ3VhZ2UgZ292ZXJuaW5nIHBlcm1pc3Npb25zIGFuZFxuICogbGltaXRhdGlvbnMgdW5kZXIgdGhlIExpY2Vuc2UuXG4gKi9cblxuaW50ZXJmYWNlIFByb2Nlc3NMaW5rIHtcbiAgaWQ6IHN0cmluZztcbiAgcHJvY2Vzc0RlZmluaXRpb25JZDogc3RyaW5nO1xuICBhY3Rpdml0eUlkOiBzdHJpbmc7XG4gIGFjdGl2aXR5VHlwZTogc3RyaW5nO1xuICBwcm9jZXNzTGlua1R5cGU6IHN0cmluZztcbiAgcGx1Z2luQ29uZmlndXJhdGlvbklkPzogc3RyaW5nO1xuICBwbHVnaW5BY3Rpb25EZWZpbml0aW9uS2V5Pzogc3RyaW5nO1xuICBhY3Rpb25Qcm9wZXJ0aWVzPzoge1xuICAgIFtrZXk6IHN0cmluZ106IGFueTtcbiAgfTtcbiAgZm9ybURlZmluaXRpb25JZD86IHN0cmluZztcbiAgZm9ybUZsb3dEZWZpbml0aW9uSWQ/OiBzdHJpbmc7XG4gIHZpZXdNb2RlbEVuYWJsZWQ/OiBib29sZWFuO1xufVxuXG50eXBlIEdldFByb2Nlc3NMaW5rUmVzcG9uc2UgPSBBcnJheTxQcm9jZXNzTGluaz47XG5cbmludGVyZmFjZSBHZXRQcm9jZXNzTGlua1JlcXVlc3Qge1xuICBhY3Rpdml0eUlkOiBzdHJpbmc7XG4gIHByb2Nlc3NEZWZpbml0aW9uSWQ6IHN0cmluZztcbn1cblxuaW50ZXJmYWNlIFByb2Nlc3NMaW5rVHlwZSB7XG4gIGVuYWJsZWQ6IGJvb2xlYW47XG4gIHByb2Nlc3NMaW5rVHlwZTogc3RyaW5nO1xufVxuXG50eXBlIFByb2Nlc3NMaW5rQ29uZmlndXJhdGlvblN0ZXAgPVxuICB8ICdjaG9vc2VQcm9jZXNzTGlua1R5cGUnXG4gIHwgJ2Nob29zZVBsdWdpbkNvbmZpZ3VyYXRpb24nXG4gIHwgJ2Nob29zZVBsdWdpbkFjdGlvbidcbiAgfCAnY29uZmlndXJlUGx1Z2luQWN0aW9uJ1xuICB8ICdzZWxlY3RGb3JtJ1xuICB8ICdzZWxlY3RGb3JtRmxvdydcbiAgfCAnZW1wdHknO1xuXG5pbnRlcmZhY2UgRm9ybVByb2Nlc3NMaW5rQ3JlYXRlUmVxdWVzdER0byB7XG4gIHByb2Nlc3NEZWZpbml0aW9uSWQ6IHN0cmluZztcbiAgYWN0aXZpdHlJZDogc3RyaW5nO1xuICBhY3Rpdml0eVR5cGU6IHN0cmluZztcbiAgcHJvY2Vzc0xpbmtUeXBlOiBzdHJpbmc7XG4gIGZvcm1EZWZpbml0aW9uSWQ6IHN0cmluZztcbiAgdmlld01vZGVsRW5hYmxlZDogYm9vbGVhbjtcbn1cblxuaW50ZXJmYWNlIEZvcm1GbG93UHJvY2Vzc0xpbmtDcmVhdGVSZXF1ZXN0RHRvIHtcbiAgcHJvY2Vzc0RlZmluaXRpb25JZDogc3RyaW5nO1xuICBhY3Rpdml0eUlkOiBzdHJpbmc7XG4gIGFjdGl2aXR5VHlwZTogc3RyaW5nO1xuICBwcm9jZXNzTGlua1R5cGU6IHN0cmluZztcbiAgZm9ybUZsb3dEZWZpbml0aW9uSWQ6IHN0cmluZztcbn1cblxuaW50ZXJmYWNlIFBsdWdpblByb2Nlc3NMaW5rQ3JlYXRlRHRvIHtcbiAgcHJvY2Vzc0RlZmluaXRpb25JZDogc3RyaW5nO1xuICBhY3Rpdml0eUlkOiBzdHJpbmc7XG4gIGFjdGl2aXR5VHlwZTogc3RyaW5nO1xuICBwcm9jZXNzTGlua1R5cGU6IHN0cmluZztcbiAgcGx1Z2luQ29uZmlndXJhdGlvbklkOiBzdHJpbmc7XG4gIHBsdWdpbkFjdGlvbkRlZmluaXRpb25LZXk6IHN0cmluZztcbiAgYWN0aW9uUHJvcGVydGllczogb2JqZWN0O1xufVxuXG5pbnRlcmZhY2UgUGx1Z2luUHJvY2Vzc0xpbmtVcGRhdGVEdG8ge1xuICBpZDogc3RyaW5nO1xuICBwbHVnaW5Db25maWd1cmF0aW9uSWQ6IHN0cmluZztcbiAgcGx1Z2luQWN0aW9uRGVmaW5pdGlvbktleTogc3RyaW5nO1xuICBhY3Rpb25Qcm9wZXJ0aWVzOiB7XG4gICAgW2tleTogc3RyaW5nXTogYW55O1xuICB9O1xufVxuXG5pbnRlcmZhY2UgRm9ybUZsb3dQcm9jZXNzTGlua1VwZGF0ZVJlcXVlc3REdG8ge1xuICBpZDogc3RyaW5nO1xuICBmb3JtRmxvd0RlZmluaXRpb25JZDogc3RyaW5nO1xufVxuXG5pbnRlcmZhY2UgRm9ybVByb2Nlc3NMaW5rVXBkYXRlUmVxdWVzdER0byB7XG4gIGlkOiBzdHJpbmc7XG4gIGZvcm1EZWZpbml0aW9uSWQ6IHN0cmluZztcbiAgdmlld01vZGVsRW5hYmxlZDogYm9vbGVhbjtcbn1cblxuZXhwb3J0IHtcbiAgR2V0UHJvY2Vzc0xpbmtSZXF1ZXN0LFxuICBQcm9jZXNzTGluayxcbiAgR2V0UHJvY2Vzc0xpbmtSZXNwb25zZSxcbiAgUGx1Z2luUHJvY2Vzc0xpbmtVcGRhdGVEdG8sXG4gIFByb2Nlc3NMaW5rVHlwZSxcbiAgUHJvY2Vzc0xpbmtDb25maWd1cmF0aW9uU3RlcCxcbiAgRm9ybVByb2Nlc3NMaW5rQ3JlYXRlUmVxdWVzdER0byxcbiAgRm9ybUZsb3dQcm9jZXNzTGlua0NyZWF0ZVJlcXVlc3REdG8sXG4gIFBsdWdpblByb2Nlc3NMaW5rQ3JlYXRlRHRvLFxuICBGb3JtRmxvd1Byb2Nlc3NMaW5rVXBkYXRlUmVxdWVzdER0byxcbiAgRm9ybVByb2Nlc3NMaW5rVXBkYXRlUmVxdWVzdER0byxcbn07XG4iXX0=
|
|
@@ -26,7 +26,7 @@ import { PluginConfigurationContainerModule, PluginTranslatePipeModule } from '@
|
|
|
26
26
|
import { PluginActionConfigurationComponent } from './components/plugin-action-configuration/plugin-action-configuration.component';
|
|
27
27
|
import { ProcessLinkComponent } from './components/process-link/process-link.component';
|
|
28
28
|
import { ProcessLinkModalComponent } from './components/process-link-modal/process-link-modal.component';
|
|
29
|
-
import { ButtonModule as CarbonButtonModule, ComboBoxModule, IconModule, InputModule, LoadingModule, ModalModule as CarbonModalModule, ProgressIndicatorModule, SelectModule, StructuredListModule, TilesModule, } from 'carbon-components-angular';
|
|
29
|
+
import { ButtonModule as CarbonButtonModule, ComboBoxModule, IconModule, InputModule, LoadingModule, ModalModule as CarbonModalModule, ProgressIndicatorModule, SelectModule, StructuredListModule, TilesModule, ToggleModule, } from 'carbon-components-angular';
|
|
30
30
|
import { ChooseProcessLinkTypeComponent } from './components/choose-process-link-type';
|
|
31
31
|
import { SelectFormComponent } from './components/select-form';
|
|
32
32
|
import { FormFlowComponent } from './components/form-flow/form-flow.component';
|
|
@@ -73,7 +73,8 @@ export class ProcessLinkModule {
|
|
|
73
73
|
StructuredListModule,
|
|
74
74
|
TilesModule,
|
|
75
75
|
RenderInPageHeaderDirectiveModule,
|
|
76
|
-
SelectModule
|
|
76
|
+
SelectModule,
|
|
77
|
+
ToggleModule], exports: [ProcessLinkComponent,
|
|
77
78
|
SelectPluginConfigurationComponent,
|
|
78
79
|
SelectPluginActionComponent,
|
|
79
80
|
PluginActionConfigurationComponent,
|
|
@@ -107,7 +108,8 @@ export class ProcessLinkModule {
|
|
|
107
108
|
StructuredListModule,
|
|
108
109
|
TilesModule,
|
|
109
110
|
RenderInPageHeaderDirectiveModule,
|
|
110
|
-
SelectModule
|
|
111
|
+
SelectModule,
|
|
112
|
+
ToggleModule] }); }
|
|
111
113
|
}
|
|
112
114
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.3", ngImport: i0, type: ProcessLinkModule, decorators: [{
|
|
113
115
|
type: NgModule,
|
|
@@ -155,6 +157,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.3", ngImpor
|
|
|
155
157
|
TilesModule,
|
|
156
158
|
RenderInPageHeaderDirectiveModule,
|
|
157
159
|
SelectModule,
|
|
160
|
+
ToggleModule,
|
|
158
161
|
],
|
|
159
162
|
exports: [
|
|
160
163
|
ProcessLinkComponent,
|
|
@@ -166,4 +169,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.3", ngImpor
|
|
|
166
169
|
],
|
|
167
170
|
}]
|
|
168
171
|
}] });
|
|
169
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
172
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"process-link.module.js","sourceRoot":"","sources":["../../../../../projects/valtimo/process-link/src/lib/process-link.module.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;GAcG;AAEH,OAAO,EAAC,QAAQ,EAAC,MAAM,eAAe,CAAC;AACvC,OAAO,EAAC,+BAA+B,EAAC,MAAM,4EAA4E,CAAC;AAC3H,OAAO,EAAC,YAAY,EAAC,MAAM,iBAAiB,CAAC;AAC7C,OAAO,EAAC,wBAAwB,EAAC,MAAM,+BAA+B,CAAC;AACvE,OAAO,EAAC,WAAW,EAAC,MAAM,gBAAgB,CAAC;AAC3C,OAAO,EACL,YAAY,EACZ,YAAY,EACZ,WAAW,EACX,eAAe,EACf,iCAAiC,EACjC,8BAA8B,EAC9B,aAAa,EACb,WAAW,EACX,iBAAiB,EACjB,aAAa,EACb,8BAA8B,EAC9B,WAAW,EACX,YAAY,GACb,MAAM,qBAAqB,CAAC;AAC7B,OAAO,EAAC,eAAe,EAAC,MAAM,qBAAqB,CAAC;AACpD,OAAO,EAAC,kCAAkC,EAAC,MAAM,gFAAgF,CAAC;AAClI,OAAO,EAAC,2BAA2B,EAAC,MAAM,kEAAkE,CAAC;AAC7G,OAAO,EAAC,kCAAkC,EAAE,yBAAyB,EAAC,MAAM,iBAAiB,CAAC;AAC9F,OAAO,EAAC,kCAAkC,EAAC,MAAM,gFAAgF,CAAC;AAClI,OAAO,EAAC,oBAAoB,EAAC,MAAM,kDAAkD,CAAC;AACtF,OAAO,EAAC,yBAAyB,EAAC,MAAM,8DAA8D,CAAC;AACvG,OAAO,EACL,YAAY,IAAI,kBAAkB,EAClC,cAAc,EACd,UAAU,EACV,WAAW,EACX,aAAa,EACb,WAAW,IAAI,iBAAiB,EAChC,uBAAuB,EACvB,YAAY,EACZ,oBAAoB,EACpB,WAAW,EACX,YAAY,GACb,MAAM,2BAA2B,CAAC;AACnC,OAAO,EAAC,8BAA8B,EAAC,MAAM,uCAAuC,CAAC;AACrF,OAAO,EAAC,mBAAmB,EAAC,MAAM,0BAA0B,CAAC;AAC7D,OAAO,EAAC,iBAAiB,EAAC,MAAM,4CAA4C,CAAC;AAC7E,OAAO,EAAC,uBAAuB,EAAC,MAAM,+BAA+B,CAAC;AACtE,OAAO,EAAC,uCAAuC,EAAC,MAAM,gDAAgD,CAAC;;AAyDvG,MAAM,OAAO,iBAAiB;8GAAjB,iBAAiB;+GAAjB,iBAAiB,iBArD1B,oBAAoB;YACpB,+BAA+B;YAC/B,kCAAkC;YAClC,2BAA2B;YAC3B,kCAAkC;YAClC,yBAAyB;YACzB,8BAA8B;YAC9B,mBAAmB;YACnB,iBAAiB;YACjB,uBAAuB;YACvB,uCAAuC,aAGvC,YAAY;YACZ,wBAAwB;YACxB,WAAW;YACX,WAAW;YACX,8BAA8B;YAC9B,eAAe;YACf,aAAa;YACb,YAAY;YACZ,WAAW;YACX,yBAAyB;YACzB,eAAe;YACf,kCAAkC;YAClC,YAAY;YACZ,WAAW;YACX,iBAAiB;YACjB,uBAAuB;YACvB,kBAAkB;YAClB,UAAU;YACV,aAAa;YACb,cAAc;YACd,WAAW;YACX,iBAAiB;YACjB,aAAa;YACb,YAAY;YACZ,8BAA8B;YAC9B,oBAAoB;YACpB,WAAW;YACX,iCAAiC;YACjC,YAAY;YACZ,YAAY,aAGZ,oBAAoB;YACpB,kCAAkC;YAClC,2BAA2B;YAC3B,kCAAkC;YAClC,yBAAyB;YACzB,iBAAiB;+GAGR,iBAAiB,YAxC1B,YAAY;YACZ,wBAAwB;YACxB,WAAW;YACX,WAAW;YACX,8BAA8B;YAC9B,eAAe;YACf,aAAa;YACb,YAAY;YACZ,WAAW;YACX,yBAAyB;YACzB,eAAe;YACf,kCAAkC;YAClC,YAAY;YACZ,WAAW;YACX,iBAAiB;YACjB,uBAAuB;YACvB,kBAAkB;YAClB,UAAU;YACV,aAAa;YACb,cAAc;YACd,WAAW;YACX,iBAAiB;YACjB,aAAa;YACb,YAAY;YACZ,8BAA8B;YAC9B,oBAAoB;YACpB,WAAW;YACX,iCAAiC;YACjC,YAAY;YACZ,YAAY;;2FAWH,iBAAiB;kBAvD7B,QAAQ;mBAAC;oBACR,YAAY,EAAE;wBACZ,oBAAoB;wBACpB,+BAA+B;wBAC/B,kCAAkC;wBAClC,2BAA2B;wBAC3B,kCAAkC;wBAClC,yBAAyB;wBACzB,8BAA8B;wBAC9B,mBAAmB;wBACnB,iBAAiB;wBACjB,uBAAuB;wBACvB,uCAAuC;qBACxC;oBACD,OAAO,EAAE;wBACP,YAAY;wBACZ,wBAAwB;wBACxB,WAAW;wBACX,WAAW;wBACX,8BAA8B;wBAC9B,eAAe;wBACf,aAAa;wBACb,YAAY;wBACZ,WAAW;wBACX,yBAAyB;wBACzB,eAAe;wBACf,kCAAkC;wBAClC,YAAY;wBACZ,WAAW;wBACX,iBAAiB;wBACjB,uBAAuB;wBACvB,kBAAkB;wBAClB,UAAU;wBACV,aAAa;wBACb,cAAc;wBACd,WAAW;wBACX,iBAAiB;wBACjB,aAAa;wBACb,YAAY;wBACZ,8BAA8B;wBAC9B,oBAAoB;wBACpB,WAAW;wBACX,iCAAiC;wBACjC,YAAY;wBACZ,YAAY;qBACb;oBACD,OAAO,EAAE;wBACP,oBAAoB;wBACpB,kCAAkC;wBAClC,2BAA2B;wBAC3B,kCAAkC;wBAClC,yBAAyB;wBACzB,iBAAiB;qBAClB;iBACF","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 {NgModule} from '@angular/core';\nimport {FormLinkProcessDiagramComponent} from './components/form-link-process-diagram/form-link-process-diagram.component';\nimport {CommonModule} from '@angular/common';\nimport {ProcessLinkRoutingModule} from './process-link-routing.module';\nimport {FormsModule} from '@angular/forms';\nimport {\n  ButtonModule,\n  FormIoModule,\n  ModalModule,\n  ParagraphModule,\n  RenderInPageHeaderDirectiveModule,\n  SearchableDropdownSelectModule,\n  StepperModule,\n  TitleModule,\n  TooltipIconModule,\n  TooltipModule,\n  ValtimoCdsModalDirectiveModule,\n  VCardModule,\n  VModalModule,\n} from '@valtimo/components';\nimport {TranslateModule} from '@ngx-translate/core';\nimport {SelectPluginConfigurationComponent} from './components/select-plugin-configuration/select-plugin-configuration.component';\nimport {SelectPluginActionComponent} from './components/select-plugin-action/select-plugin-action.component';\nimport {PluginConfigurationContainerModule, PluginTranslatePipeModule} from '@valtimo/plugin';\nimport {PluginActionConfigurationComponent} from './components/plugin-action-configuration/plugin-action-configuration.component';\nimport {ProcessLinkComponent} from './components/process-link/process-link.component';\nimport {ProcessLinkModalComponent} from './components/process-link-modal/process-link-modal.component';\nimport {\n  ButtonModule as CarbonButtonModule,\n  ComboBoxModule,\n  IconModule,\n  InputModule,\n  LoadingModule,\n  ModalModule as CarbonModalModule,\n  ProgressIndicatorModule,\n  SelectModule,\n  StructuredListModule,\n  TilesModule,\n  ToggleModule,\n} from 'carbon-components-angular';\nimport {ChooseProcessLinkTypeComponent} from './components/choose-process-link-type';\nimport {SelectFormComponent} from './components/select-form';\nimport {FormFlowComponent} from './components/form-flow/form-flow.component';\nimport {SelectFormFlowComponent} from './components/select-form-flow';\nimport {FormFlowConfigurationContainerComponent} from './components/form-flow-configuration-container';\n\n@NgModule({\n  declarations: [\n    ProcessLinkComponent,\n    FormLinkProcessDiagramComponent,\n    SelectPluginConfigurationComponent,\n    SelectPluginActionComponent,\n    PluginActionConfigurationComponent,\n    ProcessLinkModalComponent,\n    ChooseProcessLinkTypeComponent,\n    SelectFormComponent,\n    FormFlowComponent,\n    SelectFormFlowComponent,\n    FormFlowConfigurationContainerComponent,\n  ],\n  imports: [\n    CommonModule,\n    ProcessLinkRoutingModule,\n    FormsModule,\n    ModalModule,\n    SearchableDropdownSelectModule,\n    TranslateModule,\n    StepperModule,\n    VModalModule,\n    VCardModule,\n    PluginTranslatePipeModule,\n    ParagraphModule,\n    PluginConfigurationContainerModule,\n    ButtonModule,\n    TitleModule,\n    CarbonModalModule,\n    ProgressIndicatorModule,\n    CarbonButtonModule,\n    IconModule,\n    TooltipModule,\n    ComboBoxModule,\n    InputModule,\n    TooltipIconModule,\n    LoadingModule,\n    FormIoModule,\n    ValtimoCdsModalDirectiveModule,\n    StructuredListModule,\n    TilesModule,\n    RenderInPageHeaderDirectiveModule,\n    SelectModule,\n    ToggleModule,\n  ],\n  exports: [\n    ProcessLinkComponent,\n    SelectPluginConfigurationComponent,\n    SelectPluginActionComponent,\n    PluginActionConfigurationComponent,\n    ProcessLinkModalComponent,\n    FormFlowComponent,\n  ],\n})\nexport class ProcessLinkModule {}\n"]}
|
|
@@ -60,6 +60,7 @@ export class ProcessLinkStateService {
|
|
|
60
60
|
this._availableProcessLinkTypes$ = new BehaviorSubject([]);
|
|
61
61
|
this._elementName$ = new BehaviorSubject('');
|
|
62
62
|
this._selectedProcessLinkTypeId$ = new BehaviorSubject('');
|
|
63
|
+
this._viewModelEnabled$ = new BehaviorSubject(false);
|
|
63
64
|
this._saving$ = new BehaviorSubject(false);
|
|
64
65
|
this._modalParams$ = new BehaviorSubject(undefined);
|
|
65
66
|
this._selectedProcessLink$ = new BehaviorSubject(undefined);
|
|
@@ -92,6 +93,12 @@ export class ProcessLinkStateService {
|
|
|
92
93
|
this._selectedProcessLinkTypeId$.next(processLinkTypeId);
|
|
93
94
|
this.processLinkStepService.setProcessLinkTypeSteps(processLinkTypeId, hasOneOption);
|
|
94
95
|
}
|
|
96
|
+
setViewModelEnabled(viewModelEnabled) {
|
|
97
|
+
this._viewModelEnabled$.next(viewModelEnabled);
|
|
98
|
+
}
|
|
99
|
+
get viewModelEnabled$() {
|
|
100
|
+
return this._viewModelEnabled$.asObservable();
|
|
101
|
+
}
|
|
95
102
|
clearSelectedProcessLinkType() {
|
|
96
103
|
this._selectedProcessLinkTypeId$.next('');
|
|
97
104
|
}
|
|
@@ -114,6 +121,7 @@ export class ProcessLinkStateService {
|
|
|
114
121
|
selectProcessLink(processLink) {
|
|
115
122
|
this._selectedProcessLink$.next(processLink);
|
|
116
123
|
this.pluginStateService.selectProcessLink(processLink);
|
|
124
|
+
this.setViewModelEnabled(processLink.viewModelEnabled);
|
|
117
125
|
}
|
|
118
126
|
deselectProcessLink() {
|
|
119
127
|
this._selectedProcessLink$.next(undefined);
|
|
@@ -140,4 +148,4 @@ export class ProcessLinkStateService {
|
|
|
140
148
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.3", ngImport: i0, type: ProcessLinkStateService, decorators: [{
|
|
141
149
|
type: Injectable
|
|
142
150
|
}], ctorParameters: () => [{ type: i1.ProcessLinkStepService }, { type: i2.ProcessLinkButtonService }, { type: i3.PluginStateService }] });
|
|
143
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"process-link-state.service.js","sourceRoot":"","sources":["../../../../../../projects/valtimo/process-link/src/lib/services/process-link-state.service.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;GAcG;AAEH,OAAO,EAAC,UAAU,EAAY,MAAM,eAAe,CAAC;AACpD,OAAO,EAAC,eAAe,EAAE,GAAG,EAA2B,MAAM,MAAM,CAAC;;;;;AAOpE,MAAM,OAAO,uBAAuB;IAWlC,IAAI,UAAU;QACZ,OAAO,IAAI,CAAC,WAAW,CAAC,YAAY,EAAE,CAAC;IACzC,CAAC;IACD,IAAI,YAAY;QACd,OAAO,IAAI,CAAC,aAAa,CAAC,YAAY,EAAE,CAAC;IAC3C,CAAC;IACD,IAAI,0BAA0B;QAC5B,OAAO,IAAI,CAAC,2BAA2B,CAAC,YAAY,EAAE,CAAC;IACzD,CAAC;IACD,IAAI,sBAAsB;QACxB,OAAO,IAAI,CAAC,2BAA2B;aACpC,YAAY,EAAE;aACd,IAAI,CACH,GAAG,CACD,cAAc,CAAC,EAAE,CACf,KAAK,CAAC,OAAO,CAAC,cAAc,CAAC;YAC7B,cAAc,CAAC,MAAM,KAAK,CAAC;YAC3B,CAAC,cAAc,CAAC,CAAC,CAAC,EAAE,eAAe,KAAK,MAAM;gBAC5C,cAAc,CAAC,CAAC,CAAC,EAAE,eAAe,KAAK,WAAW,CAAC,CACxD,CACF,CAAC;IACN,CAAC;IACD,IAAI,0BAA0B;QAC5B,OAAO,IAAI,CAAC,2BAA2B,CAAC,YAAY,EAAE,CAAC;IACzD,CAAC;IACD,IAAI,OAAO;QACT,OAAO,IAAI,CAAC,QAAQ,CAAC,YAAY,EAAE,CAAC;IACtC,CAAC;IACD,IAAI,YAAY;QACd,OAAO,IAAI,CAAC,aAAa,CAAC,YAAY,EAAE,CAAC;IAC3C,CAAC;IAED,IAAI,oBAAoB;QACtB,OAAO,IAAI,CAAC,qBAAqB,CAAC,YAAY,EAAE,CAAC;IACnD,CAAC;IAED,IAAI,0BAA0B;QAC5B,OAAO,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,GAAG,CAAC,WAAW,CAAC,EAAE,CAAC,WAAW,EAAE,eAAe,IAAI,EAAE,CAAC,CAAC,CAAC;IAChG,CAAC;IAED,YACmB,sBAA8C,EAC9C,aAAuC,EACvC,kBAAsC;QAFtC,2BAAsB,GAAtB,sBAAsB,CAAwB;QAC9C,kBAAa,GAAb,aAAa,CAA0B;QACvC,uBAAkB,GAAlB,kBAAkB,CAAoB;QArDxC,gBAAW,GAAG,IAAI,eAAe,CAAU,KAAK,CAAC,CAAC;QAClD,gCAA2B,GAAG,IAAI,eAAe,CAAyB,EAAE,CAAC,CAAC;QAC9E,kBAAa,GAAG,IAAI,eAAe,CAAS,EAAE,CAAC,CAAC;QAChD,gCAA2B,GAAG,IAAI,eAAe,CAAS,EAAE,CAAC,CAAC;QAC9D,aAAQ,GAAG,IAAI,eAAe,CAAU,KAAK,CAAC,CAAC;QAC/C,kBAAa,GAAG,IAAI,eAAe,CAAc,SAAS,CAAC,CAAC;QAC5D,0BAAqB,GAAG,IAAI,eAAe,CAAc,SAAS,CAAC,CAAC;QAiDnF,IAAI,CAAC,yCAAyC,EAAE,CAAC;IACnD,CAAC;IAED,WAAW;QACT,IAAI,CAAC,sCAAsC,EAAE,WAAW,EAAE,CAAC;IAC7D,CAAC;IAED,4BAA4B,CAAC,gBAAwC;QACnE,MAAM,YAAY,GAAG,gBAAgB,CAAC,MAAM,KAAK,CAAC,CAAC;QACnD,IAAI,CAAC,2BAA2B,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;QACxD,IAAI,CAAC,sBAAsB,CAAC,wBAAwB,CAAC,YAAY,CAAC,CAAC;QAEnE,IAAI,YAAY,EAAE,CAAC;YACjB,IAAI,CAAC,qBAAqB,CAAC,gBAAgB,CAAC,CAAC,CAAC,CAAC,eAAe,EAAE,YAAY,CAAC,CAAC;QAChF,CAAC;IACH,CAAC;IAED,cAAc,CAAC,IAAY;QACzB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAChC,CAAC;IAED,SAAS;QACP,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC9B,CAAC;IAED,UAAU;QACR,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAE7B,UAAU,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,KAAK,EAAE,CAAC;QACf,CAAC,EAAE,GAAG,CAAC,CAAC;IACV,CAAC;IAED,qBAAqB,CAAC,iBAAyB,EAAE,YAAsB;QACrE,IAAI,CAAC,2BAA2B,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC;QACzD,IAAI,CAAC,sBAAsB,CAAC,uBAAuB,CAAC,iBAAiB,EAAE,YAAY,CAAC,CAAC;IACvF,CAAC;IAED,4BAA4B;QAC1B,IAAI,CAAC,2BAA2B,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IAC5C,CAAC;IAED,WAAW;QACT,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACzB,IAAI,CAAC,sBAAsB,CAAC,YAAY,EAAE,CAAC;IAC7C,CAAC;IAED,UAAU;QACR,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC1B,IAAI,CAAC,sBAAsB,CAAC,WAAW,EAAE,CAAC;IAC5C,CAAC;IAED,UAAU;QACR,MAAM,cAAc,GAAG,IAAI,CAAC,2BAA2B,CAAC,QAAQ,EAAE,CAAC;QACnE,IAAI,CAAC,aAAa,CAAC,YAAY,EAAE,CAAC;QAClC,IAAI,CAAC,sBAAsB,CAAC,eAAe,CAAC,cAAc,CAAC,CAAC;IAC9D,CAAC;IAED,cAAc,CAAC,MAAmB;QAChC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IAClC,CAAC;IAED,iBAAiB,CAAC,WAAwB;QACxC,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;QAC7C,IAAI,CAAC,kBAAkB,CAAC,iBAAiB,CAAC,WAAW,CAAC,CAAC;IACzD,CAAC;IAED,mBAAmB;QACjB,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QAC3C,IAAI,CAAC,kBAAkB,CAAC,mBAAmB,EAAE,CAAC;IAChD,CAAC;IAEO,yCAAyC;QAC/C,IAAI,CAAC,sCAAsC,GAAG,IAAI,CAAC,2BAA2B,CAAC,SAAS,CACtF,yBAAyB,CAAC,EAAE;YAC1B,IAAI,yBAAyB,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;gBACzC,IAAI,CAAC,UAAU,EAAE,CAAC;YACpB,CAAC;QACH,CAAC,CACF,CAAC;IACJ,CAAC;IAEO,KAAK;QACX,IAAI,CAAC,4BAA4B,CAAC,EAAE,CAAC,CAAC;QACtC,IAAI,CAAC,sBAAsB,CAAC,KAAK,EAAE,CAAC;QACpC,IAAI,CAAC,UAAU,EAAE,CAAC;QAClB,IAAI,CAAC,aAAa,CAAC,YAAY,EAAE,CAAC;QAClC,IAAI,CAAC,4BAA4B,EAAE,CAAC;QACpC,IAAI,CAAC,mBAAmB,EAAE,CAAC;IAC7B,CAAC;8GAjJU,uBAAuB;kHAAvB,uBAAuB;;2FAAvB,uBAAuB;kBADnC,UAAU","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 {Injectable, OnDestroy} from '@angular/core';\nimport {BehaviorSubject, map, Observable, Subscription} from 'rxjs';\nimport {ModalParams, ProcessLink, ProcessLinkType} from '../models';\nimport {ProcessLinkStepService} from './process-link-step.service';\nimport {ProcessLinkButtonService} from './process-link-button.service';\nimport {PluginStateService} from './plugin-state.service';\n\n@Injectable()\nexport class ProcessLinkStateService implements OnDestroy {\n  private readonly _showModal$ = new BehaviorSubject<boolean>(false);\n  private readonly _availableProcessLinkTypes$ = new BehaviorSubject<Array<ProcessLinkType>>([]);\n  private readonly _elementName$ = new BehaviorSubject<string>('');\n  private readonly _selectedProcessLinkTypeId$ = new BehaviorSubject<string>('');\n  private readonly _saving$ = new BehaviorSubject<boolean>(false);\n  private readonly _modalParams$ = new BehaviorSubject<ModalParams>(undefined);\n  private readonly _selectedProcessLink$ = new BehaviorSubject<ProcessLink>(undefined);\n\n  private _availableProcessLinkTypesSubscription!: Subscription;\n\n  get showModal$(): Observable<boolean> {\n    return this._showModal$.asObservable();\n  }\n  get elementName$(): Observable<string> {\n    return this._elementName$.asObservable();\n  }\n  get availableProcessLinkTypes$(): Observable<Array<ProcessLinkType>> {\n    return this._availableProcessLinkTypes$.asObservable();\n  }\n  get hideProgressIndicator$(): Observable<boolean> {\n    return this._availableProcessLinkTypes$\n      .asObservable()\n      .pipe(\n        map(\n          availableTypes =>\n            Array.isArray(availableTypes) &&\n            availableTypes.length === 1 &&\n            (availableTypes[0]?.processLinkType === 'form' ||\n              availableTypes[0]?.processLinkType === 'form-flow')\n        )\n      );\n  }\n  get selectedProcessLinkTypeId$(): Observable<string> {\n    return this._selectedProcessLinkTypeId$.asObservable();\n  }\n  get saving$(): Observable<boolean> {\n    return this._saving$.asObservable();\n  }\n  get modalParams$(): Observable<ModalParams> {\n    return this._modalParams$.asObservable();\n  }\n\n  get selectedProcessLink$(): Observable<ProcessLink> {\n    return this._selectedProcessLink$.asObservable();\n  }\n\n  get typeOfSelectedProcessLink$(): Observable<string> {\n    return this.selectedProcessLink$.pipe(map(processLink => processLink?.processLinkType || ''));\n  }\n\n  constructor(\n    private readonly processLinkStepService: ProcessLinkStepService,\n    private readonly buttonService: ProcessLinkButtonService,\n    private readonly pluginStateService: PluginStateService\n  ) {\n    this.openAvailableProcessLinkTypesSubscription();\n  }\n\n  ngOnDestroy(): void {\n    this._availableProcessLinkTypesSubscription?.unsubscribe();\n  }\n\n  setAvailableProcessLinkTypes(processLinkTypes: Array<ProcessLinkType>): void {\n    const hasOneOption = processLinkTypes.length === 1;\n    this._availableProcessLinkTypes$.next(processLinkTypes);\n    this.processLinkStepService.setHasOneProcessLinkType(hasOneOption);\n\n    if (hasOneOption) {\n      this.selectProcessLinkType(processLinkTypes[0].processLinkType, hasOneOption);\n    }\n  }\n\n  setElementName(name: string): void {\n    this._elementName$.next(name);\n  }\n\n  showModal(): void {\n    this._showModal$.next(true);\n  }\n\n  closeModal(): void {\n    this._showModal$.next(false);\n\n    setTimeout(() => {\n      this.reset();\n    }, 240);\n  }\n\n  selectProcessLinkType(processLinkTypeId: string, hasOneOption?: boolean): void {\n    this._selectedProcessLinkTypeId$.next(processLinkTypeId);\n    this.processLinkStepService.setProcessLinkTypeSteps(processLinkTypeId, hasOneOption);\n  }\n\n  clearSelectedProcessLinkType(): void {\n    this._selectedProcessLinkTypeId$.next('');\n  }\n\n  startSaving(): void {\n    this._saving$.next(true);\n    this.processLinkStepService.disableSteps();\n  }\n\n  stopSaving(): void {\n    this._saving$.next(false);\n    this.processLinkStepService.enableSteps();\n  }\n\n  setInitial(): void {\n    const availableTypes = this._availableProcessLinkTypes$.getValue();\n    this.buttonService.resetButtons();\n    this.processLinkStepService.setInitialSteps(availableTypes);\n  }\n\n  setModalParams(params: ModalParams): void {\n    this._modalParams$.next(params);\n  }\n\n  selectProcessLink(processLink: ProcessLink): void {\n    this._selectedProcessLink$.next(processLink);\n    this.pluginStateService.selectProcessLink(processLink);\n  }\n\n  deselectProcessLink(): void {\n    this._selectedProcessLink$.next(undefined);\n    this.pluginStateService.deselectProcessLink();\n  }\n\n  private openAvailableProcessLinkTypesSubscription(): void {\n    this._availableProcessLinkTypesSubscription = this._availableProcessLinkTypes$.subscribe(\n      availableProcessLinkTypes => {\n        if (availableProcessLinkTypes.length > 1) {\n          this.setInitial();\n        }\n      }\n    );\n  }\n\n  private reset(): void {\n    this.setAvailableProcessLinkTypes([]);\n    this.processLinkStepService.reset();\n    this.stopSaving();\n    this.buttonService.resetButtons();\n    this.clearSelectedProcessLinkType();\n    this.deselectProcessLink();\n  }\n}\n"]}
|
|
151
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"process-link-state.service.js","sourceRoot":"","sources":["../../../../../../projects/valtimo/process-link/src/lib/services/process-link-state.service.ts"],"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 {Injectable, OnDestroy} from '@angular/core';\nimport {BehaviorSubject, map, Observable, Subscription} from 'rxjs';\nimport {ModalParams, ProcessLink, ProcessLinkType} from '../models';\nimport {ProcessLinkStepService} from './process-link-step.service';\nimport {ProcessLinkButtonService} from './process-link-button.service';\nimport {PluginStateService} from './plugin-state.service';\n\n@Injectable()\nexport class ProcessLinkStateService implements OnDestroy {\n  private readonly _showModal$ = new BehaviorSubject<boolean>(false);\n  private readonly _availableProcessLinkTypes$ = new BehaviorSubject<Array<ProcessLinkType>>([]);\n  private readonly _elementName$ = new BehaviorSubject<string>('');\n  private readonly _selectedProcessLinkTypeId$ = new BehaviorSubject<string>('');\n  private readonly _viewModelEnabled$ = new BehaviorSubject<boolean>(false);\n  private readonly _saving$ = new BehaviorSubject<boolean>(false);\n  private readonly _modalParams$ = new BehaviorSubject<ModalParams>(undefined);\n  private readonly _selectedProcessLink$ = new BehaviorSubject<ProcessLink>(undefined);\n\n  private _availableProcessLinkTypesSubscription!: Subscription;\n\n  get showModal$(): Observable<boolean> {\n    return this._showModal$.asObservable();\n  }\n  get elementName$(): Observable<string> {\n    return this._elementName$.asObservable();\n  }\n  get availableProcessLinkTypes$(): Observable<Array<ProcessLinkType>> {\n    return this._availableProcessLinkTypes$.asObservable();\n  }\n  get hideProgressIndicator$(): Observable<boolean> {\n    return this._availableProcessLinkTypes$\n      .asObservable()\n      .pipe(\n        map(\n          availableTypes =>\n            Array.isArray(availableTypes) &&\n            availableTypes.length === 1 &&\n            (availableTypes[0]?.processLinkType === 'form' ||\n              availableTypes[0]?.processLinkType === 'form-flow')\n        )\n      );\n  }\n  get selectedProcessLinkTypeId$(): Observable<string> {\n    return this._selectedProcessLinkTypeId$.asObservable();\n  }\n  get saving$(): Observable<boolean> {\n    return this._saving$.asObservable();\n  }\n  get modalParams$(): Observable<ModalParams> {\n    return this._modalParams$.asObservable();\n  }\n\n  get selectedProcessLink$(): Observable<ProcessLink> {\n    return this._selectedProcessLink$.asObservable();\n  }\n\n  get typeOfSelectedProcessLink$(): Observable<string> {\n    return this.selectedProcessLink$.pipe(map(processLink => processLink?.processLinkType || ''));\n  }\n\n  constructor(\n    private readonly processLinkStepService: ProcessLinkStepService,\n    private readonly buttonService: ProcessLinkButtonService,\n    private readonly pluginStateService: PluginStateService\n  ) {\n    this.openAvailableProcessLinkTypesSubscription();\n  }\n\n  ngOnDestroy(): void {\n    this._availableProcessLinkTypesSubscription?.unsubscribe();\n  }\n\n  setAvailableProcessLinkTypes(processLinkTypes: Array<ProcessLinkType>): void {\n    const hasOneOption = processLinkTypes.length === 1;\n    this._availableProcessLinkTypes$.next(processLinkTypes);\n    this.processLinkStepService.setHasOneProcessLinkType(hasOneOption);\n\n    if (hasOneOption) {\n      this.selectProcessLinkType(processLinkTypes[0].processLinkType, hasOneOption);\n    }\n  }\n\n  setElementName(name: string): void {\n    this._elementName$.next(name);\n  }\n\n  showModal(): void {\n    this._showModal$.next(true);\n  }\n\n  closeModal(): void {\n    this._showModal$.next(false);\n\n    setTimeout(() => {\n      this.reset();\n    }, 240);\n  }\n\n  selectProcessLinkType(processLinkTypeId: string, hasOneOption?: boolean): void {\n    this._selectedProcessLinkTypeId$.next(processLinkTypeId);\n    this.processLinkStepService.setProcessLinkTypeSteps(processLinkTypeId, hasOneOption);\n  }\n\n  public setViewModelEnabled(viewModelEnabled: boolean): void {\n    this._viewModelEnabled$.next(viewModelEnabled);\n  }\n\n  public get viewModelEnabled$(): Observable<boolean> {\n    return this._viewModelEnabled$.asObservable();\n  }\n\n  clearSelectedProcessLinkType(): void {\n    this._selectedProcessLinkTypeId$.next('');\n  }\n\n  startSaving(): void {\n    this._saving$.next(true);\n    this.processLinkStepService.disableSteps();\n  }\n\n  stopSaving(): void {\n    this._saving$.next(false);\n    this.processLinkStepService.enableSteps();\n  }\n\n  setInitial(): void {\n    const availableTypes = this._availableProcessLinkTypes$.getValue();\n    this.buttonService.resetButtons();\n    this.processLinkStepService.setInitialSteps(availableTypes);\n  }\n\n  setModalParams(params: ModalParams): void {\n    this._modalParams$.next(params);\n  }\n\n  selectProcessLink(processLink: ProcessLink): void {\n    this._selectedProcessLink$.next(processLink);\n    this.pluginStateService.selectProcessLink(processLink);\n    this.setViewModelEnabled(processLink.viewModelEnabled);\n  }\n\n  deselectProcessLink(): void {\n    this._selectedProcessLink$.next(undefined);\n    this.pluginStateService.deselectProcessLink();\n  }\n\n  private openAvailableProcessLinkTypesSubscription(): void {\n    this._availableProcessLinkTypesSubscription = this._availableProcessLinkTypes$.subscribe(\n      availableProcessLinkTypes => {\n        if (availableProcessLinkTypes.length > 1) {\n          this.setInitial();\n        }\n      }\n    );\n  }\n\n  private reset(): void {\n    this.setAvailableProcessLinkTypes([]);\n    this.processLinkStepService.reset();\n    this.stopSaving();\n    this.buttonService.resetButtons();\n    this.clearSelectedProcessLinkType();\n    this.deselectProcessLink();\n  }\n}\n"]}
|