@valtimo/process-link 12.3.1 → 12.4.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (59) hide show
  1. package/esm2022/lib/components/choose-process-link-type/choose-process-link-type.component.mjs +3 -3
  2. package/esm2022/lib/components/form-display-configuration/form-display-configuration.component.mjs +109 -0
  3. package/esm2022/lib/components/form-flow/form-flow.component.mjs +97 -22
  4. package/esm2022/lib/components/process-link-modal/process-link-modal.component.mjs +5 -4
  5. package/esm2022/lib/components/select-form/select-form.component.mjs +63 -26
  6. package/esm2022/lib/components/select-form-flow/select-form-flow.component.mjs +60 -25
  7. package/esm2022/lib/components/select-url/select-url.component.mjs +134 -0
  8. package/esm2022/lib/constants/index.mjs +2 -1
  9. package/esm2022/lib/constants/process.link.mjs +23 -0
  10. package/esm2022/lib/models/form-link.model.mjs +1 -1
  11. package/esm2022/lib/models/process-link-url.model.mjs +17 -0
  12. package/esm2022/lib/models/process-link.model.mjs +1 -1
  13. package/esm2022/lib/process-link.module.mjs +25 -5
  14. package/esm2022/lib/services/form-flow.service.mjs +7 -1
  15. package/esm2022/lib/services/process-link-state.service.mjs +6 -1
  16. package/esm2022/lib/services/process-link-step.service.mjs +25 -3
  17. package/esm2022/lib/services/process-link.service.mjs +21 -1
  18. package/esm2022/lib/services/url-resolver.service.mjs +18 -0
  19. package/esm2022/lib/services/url-validator.service.mjs +26 -0
  20. package/esm2022/public-api.mjs +4 -1
  21. package/fesm2022/valtimo-process-link.mjs +590 -100
  22. package/fesm2022/valtimo-process-link.mjs.map +1 -1
  23. package/lib/components/form-display-configuration/form-display-configuration.component.d.ts +40 -0
  24. package/lib/components/form-display-configuration/form-display-configuration.component.d.ts.map +1 -0
  25. package/lib/components/form-flow/form-flow.component.d.ts +25 -6
  26. package/lib/components/form-flow/form-flow.component.d.ts.map +1 -1
  27. package/lib/components/select-form/select-form.component.d.ts +10 -2
  28. package/lib/components/select-form/select-form.component.d.ts.map +1 -1
  29. package/lib/components/select-form-flow/select-form-flow.component.d.ts +10 -2
  30. package/lib/components/select-form-flow/select-form-flow.component.d.ts.map +1 -1
  31. package/lib/components/select-url/select-url.component.d.ts +31 -0
  32. package/lib/components/select-url/select-url.component.d.ts.map +1 -0
  33. package/lib/constants/index.d.ts +1 -0
  34. package/lib/constants/index.d.ts.map +1 -1
  35. package/lib/constants/process.link.d.ts +5 -0
  36. package/lib/constants/process.link.d.ts.map +1 -0
  37. package/lib/models/form-link.model.d.ts +11 -1
  38. package/lib/models/form-link.model.d.ts.map +1 -1
  39. package/lib/models/process-link-url.model.d.ts +5 -0
  40. package/lib/models/process-link-url.model.d.ts.map +1 -0
  41. package/lib/models/process-link.model.d.ts +22 -1
  42. package/lib/models/process-link.model.d.ts.map +1 -1
  43. package/lib/process-link.module.d.ts +10 -8
  44. package/lib/process-link.module.d.ts.map +1 -1
  45. package/lib/services/form-flow.service.d.ts +3 -1
  46. package/lib/services/form-flow.service.d.ts.map +1 -1
  47. package/lib/services/process-link-state.service.d.ts +2 -0
  48. package/lib/services/process-link-state.service.d.ts.map +1 -1
  49. package/lib/services/process-link-step.service.d.ts +2 -0
  50. package/lib/services/process-link-step.service.d.ts.map +1 -1
  51. package/lib/services/process-link.service.d.ts +6 -3
  52. package/lib/services/process-link.service.d.ts.map +1 -1
  53. package/lib/services/url-resolver.service.d.ts +7 -0
  54. package/lib/services/url-resolver.service.d.ts.map +1 -0
  55. package/lib/services/url-validator.service.d.ts +11 -0
  56. package/lib/services/url-validator.service.d.ts.map +1 -0
  57. package/package.json +1 -1
  58. package/public-api.d.ts +3 -0
  59. package/public-api.d.ts.map +1 -1
@@ -29,10 +29,10 @@ export class ChooseProcessLinkTypeComponent {
29
29
  this.processLinkStateService.selectProcessLinkType(processLinkTypeId);
30
30
  }
31
31
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ChooseProcessLinkTypeComponent, deps: [{ token: i1.ProcessLinkStateService }], target: i0.ɵɵFactoryTarget.Component }); }
32
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: ChooseProcessLinkTypeComponent, selector: "valtimo-choose-process-link-type", 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<ng-container\n *ngIf=\"{\n availableProcessLinkTypes: availableProcessLinkTypes$ | async\n } as obs\"\n>\n <p class=\"step-description\">\n {{ 'processLinkConfiguration.chooseProcessLinkTypeDescription' | translate }}\n </p>\n <div class=\"process-link-grid\">\n <div\n class=\"process-link-item\"\n *ngFor=\"let availableProcessLinkType of obs.availableProcessLinkTypes\"\n >\n <ng-container *ngIf=\"availableProcessLinkType.processLinkType as processLinkTypeId\">\n <button\n (click)=\"selectProcessLinkType(processLinkTypeId)\"\n cdsButton=\"secondary\"\n size=\"xl\"\n class=\"process-link-type-button\"\n [disabled]=\"!availableProcessLinkType.enabled\"\n [vTooltip]=\"'processLinkTypeDisabledTooltip.' + processLinkTypeId | translate\"\n [onBottom]=\"true\"\n [tooltipDisabled]=\"availableProcessLinkType.enabled\"\n >\n {{ 'processLinkType.' + processLinkTypeId | translate }}\n <svg\n *ngIf=\"processLinkTypeId === 'plugin'\"\n class=\"cds--btn__icon\"\n cdsIcon=\"link\"\n size=\"16\"\n ></svg>\n <svg\n *ngIf=\"processLinkTypeId === 'form'\"\n class=\"cds--btn__icon\"\n cdsIcon=\"receipt\"\n size=\"16\"\n ></svg>\n <svg\n *ngIf=\"processLinkTypeId === 'form-flow'\"\n class=\"cds--btn__icon\"\n cdsIcon=\"flow--data\"\n size=\"16\"\n ></svg>\n </button>\n </ng-container>\n </div>\n </div>\n</ng-container>\n", styles: [".process-link-type-button{width:100%}.process-link-grid{margin-top:24px;display:flex;justify-content:flex-start;width:100%;flex-wrap:wrap;gap:8px}.process-link-item{flex-basis:calc(33.3% - 5.3333333333px)}\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: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.Button, selector: "[cdsButton], [ibmButton]", inputs: ["ibmButton", "cdsButton", "size", "skeleton", "iconOnly", "isExpressive"] }, { kind: "directive", type: i3.IconDirective, selector: "[cdsIcon], [ibmIcon]", inputs: ["ibmIcon", "cdsIcon", "size", "title", "ariaLabel", "ariaLabelledBy", "ariaHidden", "isFocusable"] }, { kind: "directive", type: i4.TooltipDirective, selector: "[vTooltip]", inputs: ["vTooltip", "onBottom", "tooltipDisabled"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }, { kind: "pipe", type: i5.TranslatePipe, name: "translate" }] }); }
32
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: ChooseProcessLinkTypeComponent, selector: "valtimo-choose-process-link-type", 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<ng-container\n *ngIf=\"{\n availableProcessLinkTypes: availableProcessLinkTypes$ | async,\n } as obs\"\n>\n <p class=\"step-description\">\n {{ 'processLinkConfiguration.chooseProcessLinkTypeDescription' | translate }}\n </p>\n <div class=\"process-link-grid\">\n <div\n class=\"process-link-item\"\n *ngFor=\"let availableProcessLinkType of obs.availableProcessLinkTypes\"\n >\n <ng-container *ngIf=\"availableProcessLinkType.processLinkType as processLinkTypeId\">\n <button\n (click)=\"selectProcessLinkType(processLinkTypeId)\"\n cdsButton=\"secondary\"\n size=\"xl\"\n class=\"process-link-type-button\"\n [disabled]=\"!availableProcessLinkType.enabled\"\n [vTooltip]=\"'processLinkTypeDisabledTooltip.' + processLinkTypeId | translate\"\n [onBottom]=\"true\"\n [tooltipDisabled]=\"availableProcessLinkType.enabled\"\n >\n {{ 'processLinkType.' + processLinkTypeId | translate }}\n <svg\n *ngIf=\"processLinkTypeId === 'plugin'\"\n class=\"cds--btn__icon\"\n cdsIcon=\"link\"\n size=\"16\"\n ></svg>\n <svg\n *ngIf=\"processLinkTypeId === 'form'\"\n class=\"cds--btn__icon\"\n cdsIcon=\"receipt\"\n size=\"16\"\n ></svg>\n <svg\n *ngIf=\"processLinkTypeId === 'form-flow'\"\n class=\"cds--btn__icon\"\n cdsIcon=\"flow--data\"\n size=\"16\"\n ></svg>\n </button>\n </ng-container>\n </div>\n </div>\n</ng-container>\n", styles: [".process-link-type-button{width:100%}.process-link-grid{margin-top:24px;display:flex;justify-content:flex-start;width:100%;flex-wrap:wrap;gap:8px}.process-link-item{flex-basis:calc(33.3% - 5.3333333333px)}\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: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.Button, selector: "[cdsButton], [ibmButton]", inputs: ["ibmButton", "cdsButton", "size", "skeleton", "iconOnly", "isExpressive"] }, { kind: "directive", type: i3.IconDirective, selector: "[cdsIcon], [ibmIcon]", inputs: ["ibmIcon", "cdsIcon", "size", "title", "ariaLabel", "ariaLabelledBy", "ariaHidden", "isFocusable"] }, { kind: "directive", type: i4.TooltipDirective, selector: "[vTooltip]", inputs: ["vTooltip", "onBottom", "tooltipDisabled"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }, { kind: "pipe", type: i5.TranslatePipe, name: "translate" }] }); }
33
33
  }
34
34
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ChooseProcessLinkTypeComponent, decorators: [{
35
35
  type: Component,
36
- args: [{ selector: 'valtimo-choose-process-link-type', 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 availableProcessLinkTypes: availableProcessLinkTypes$ | async\n } as obs\"\n>\n <p class=\"step-description\">\n {{ 'processLinkConfiguration.chooseProcessLinkTypeDescription' | translate }}\n </p>\n <div class=\"process-link-grid\">\n <div\n class=\"process-link-item\"\n *ngFor=\"let availableProcessLinkType of obs.availableProcessLinkTypes\"\n >\n <ng-container *ngIf=\"availableProcessLinkType.processLinkType as processLinkTypeId\">\n <button\n (click)=\"selectProcessLinkType(processLinkTypeId)\"\n cdsButton=\"secondary\"\n size=\"xl\"\n class=\"process-link-type-button\"\n [disabled]=\"!availableProcessLinkType.enabled\"\n [vTooltip]=\"'processLinkTypeDisabledTooltip.' + processLinkTypeId | translate\"\n [onBottom]=\"true\"\n [tooltipDisabled]=\"availableProcessLinkType.enabled\"\n >\n {{ 'processLinkType.' + processLinkTypeId | translate }}\n <svg\n *ngIf=\"processLinkTypeId === 'plugin'\"\n class=\"cds--btn__icon\"\n cdsIcon=\"link\"\n size=\"16\"\n ></svg>\n <svg\n *ngIf=\"processLinkTypeId === 'form'\"\n class=\"cds--btn__icon\"\n cdsIcon=\"receipt\"\n size=\"16\"\n ></svg>\n <svg\n *ngIf=\"processLinkTypeId === 'form-flow'\"\n class=\"cds--btn__icon\"\n cdsIcon=\"flow--data\"\n size=\"16\"\n ></svg>\n </button>\n </ng-container>\n </div>\n </div>\n</ng-container>\n", styles: [".process-link-type-button{width:100%}.process-link-grid{margin-top:24px;display:flex;justify-content:flex-start;width:100%;flex-wrap:wrap;gap:8px}.process-link-item{flex-basis:calc(33.3% - 5.3333333333px)}\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"] }]
36
+ args: [{ selector: 'valtimo-choose-process-link-type', 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 availableProcessLinkTypes: availableProcessLinkTypes$ | async,\n } as obs\"\n>\n <p class=\"step-description\">\n {{ 'processLinkConfiguration.chooseProcessLinkTypeDescription' | translate }}\n </p>\n <div class=\"process-link-grid\">\n <div\n class=\"process-link-item\"\n *ngFor=\"let availableProcessLinkType of obs.availableProcessLinkTypes\"\n >\n <ng-container *ngIf=\"availableProcessLinkType.processLinkType as processLinkTypeId\">\n <button\n (click)=\"selectProcessLinkType(processLinkTypeId)\"\n cdsButton=\"secondary\"\n size=\"xl\"\n class=\"process-link-type-button\"\n [disabled]=\"!availableProcessLinkType.enabled\"\n [vTooltip]=\"'processLinkTypeDisabledTooltip.' + processLinkTypeId | translate\"\n [onBottom]=\"true\"\n [tooltipDisabled]=\"availableProcessLinkType.enabled\"\n >\n {{ 'processLinkType.' + processLinkTypeId | translate }}\n <svg\n *ngIf=\"processLinkTypeId === 'plugin'\"\n class=\"cds--btn__icon\"\n cdsIcon=\"link\"\n size=\"16\"\n ></svg>\n <svg\n *ngIf=\"processLinkTypeId === 'form'\"\n class=\"cds--btn__icon\"\n cdsIcon=\"receipt\"\n size=\"16\"\n ></svg>\n <svg\n *ngIf=\"processLinkTypeId === 'form-flow'\"\n class=\"cds--btn__icon\"\n cdsIcon=\"flow--data\"\n size=\"16\"\n ></svg>\n </button>\n </ng-container>\n </div>\n </div>\n</ng-container>\n", styles: [".process-link-type-button{width:100%}.process-link-grid{margin-top:24px;display:flex;justify-content:flex-start;width:100%;flex-wrap:wrap;gap:8px}.process-link-item{flex-basis:calc(33.3% - 5.3333333333px)}\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"] }]
37
37
  }], ctorParameters: () => [{ type: i1.ProcessLinkStateService }] });
38
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hvb3NlLXByb2Nlc3MtbGluay10eXBlLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3ZhbHRpbW8vcHJvY2Vzcy1saW5rL3NyYy9saWIvY29tcG9uZW50cy9jaG9vc2UtcHJvY2Vzcy1saW5rLXR5cGUvY2hvb3NlLXByb2Nlc3MtbGluay10eXBlLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3ZhbHRpbW8vcHJvY2Vzcy1saW5rL3NyYy9saWIvY29tcG9uZW50cy9jaG9vc2UtcHJvY2Vzcy1saW5rLXR5cGUvY2hvb3NlLXByb2Nlc3MtbGluay10eXBlLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7Ozs7Ozs7OztHQWNHO0FBRUgsT0FBTyxFQUFDLFNBQVMsRUFBQyxNQUFNLGVBQWUsQ0FBQzs7Ozs7OztBQVF4QyxNQUFNLE9BQU8sOEJBQThCO0lBSXpDLFlBQTZCLHVCQUFnRDtRQUFoRCw0QkFBdUIsR0FBdkIsdUJBQXVCLENBQXlCO1FBSDdELCtCQUEwQixHQUN4QyxJQUFJLENBQUMsdUJBQXVCLENBQUMsMEJBQTBCLENBQUM7SUFFc0IsQ0FBQztJQUVqRixxQkFBcUIsQ0FBQyxpQkFBeUI7UUFDN0MsSUFBSSxDQUFDLHVCQUF1QixDQUFDLHFCQUFxQixDQUFDLGlCQUFpQixDQUFDLENBQUM7SUFDeEUsQ0FBQzsrR0FSVSw4QkFBOEI7bUdBQTlCLDhCQUE4Qix3RUN4QjNDLG93RUFnRUE7OzRGRHhDYSw4QkFBOEI7a0JBTDFDLFNBQVM7K0JBQ0Usa0NBQWtDIiwic291cmNlc0NvbnRlbnQiOlsiLypcbiAqIENvcHlyaWdodCAyMDE1LTIwMjQgUml0ZW5zZSBCViwgdGhlIE5ldGhlcmxhbmRzLlxuICpcbiAqIExpY2Vuc2VkIHVuZGVyIEVVUEwsIFZlcnNpb24gMS4yICh0aGUgXCJMaWNlbnNlXCIpO1xuICogeW91IG1heSBub3QgdXNlIHRoaXMgZmlsZSBleGNlcHQgaW4gY29tcGxpYW5jZSB3aXRoIHRoZSBMaWNlbnNlLlxuICogWW91IG1heSBvYnRhaW4gYSBjb3B5IG9mIHRoZSBMaWNlbnNlIGF0XG4gKlxuICogaHR0cHM6Ly9qb2ludXAuZWMuZXVyb3BhLmV1L2NvbGxlY3Rpb24vZXVwbC9ldXBsLXRleHQtZXVwbC0xMlxuICpcbiAqIFVubGVzcyByZXF1aXJlZCBieSBhcHBsaWNhYmxlIGxhdyBvciBhZ3JlZWQgdG8gaW4gd3JpdGluZywgc29mdHdhcmVcbiAqIGRpc3RyaWJ1dGVkIHVuZGVyIHRoZSBMaWNlbnNlIGlzIGRpc3RyaWJ1dGVkIG9uIGFuIFwiQVMgSVNcIiBiYXNpcyxcbiAqIFdJVEhPVVQgV0FSUkFOVElFUyBPUiBDT05ESVRJT05TIE9GIEFOWSBLSU5ELCBlaXRoZXIgZXhwcmVzcyBvciBpbXBsaWVkLlxuICogU2VlIHRoZSBMaWNlbnNlIGZvciB0aGUgc3BlY2lmaWMgbGFuZ3VhZ2UgZ292ZXJuaW5nIHBlcm1pc3Npb25zIGFuZFxuICogbGltaXRhdGlvbnMgdW5kZXIgdGhlIExpY2Vuc2UuXG4gKi9cblxuaW1wb3J0IHtDb21wb25lbnR9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtQcm9jZXNzTGlua1N0YXRlU2VydmljZX0gZnJvbSAnLi4vLi4vc2VydmljZXMnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICd2YWx0aW1vLWNob29zZS1wcm9jZXNzLWxpbmstdHlwZScsXG4gIHRlbXBsYXRlVXJsOiAnLi9jaG9vc2UtcHJvY2Vzcy1saW5rLXR5cGUuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9jaG9vc2UtcHJvY2Vzcy1saW5rLXR5cGUuY29tcG9uZW50LnNjc3MnXSxcbn0pXG5leHBvcnQgY2xhc3MgQ2hvb3NlUHJvY2Vzc0xpbmtUeXBlQ29tcG9uZW50IHtcbiAgcHVibGljIHJlYWRvbmx5IGF2YWlsYWJsZVByb2Nlc3NMaW5rVHlwZXMkID1cbiAgICB0aGlzLnByb2Nlc3NMaW5rU3RhdGVTZXJ2aWNlLmF2YWlsYWJsZVByb2Nlc3NMaW5rVHlwZXMkO1xuXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgcmVhZG9ubHkgcHJvY2Vzc0xpbmtTdGF0ZVNlcnZpY2U6IFByb2Nlc3NMaW5rU3RhdGVTZXJ2aWNlKSB7fVxuXG4gIHNlbGVjdFByb2Nlc3NMaW5rVHlwZShwcm9jZXNzTGlua1R5cGVJZDogc3RyaW5nKTogdm9pZCB7XG4gICAgdGhpcy5wcm9jZXNzTGlua1N0YXRlU2VydmljZS5zZWxlY3RQcm9jZXNzTGlua1R5cGUocHJvY2Vzc0xpbmtUeXBlSWQpO1xuICB9XG59XG4iLCI8IS0tXG4gIH4gQ29weXJpZ2h0IDIwMTUtMjAyNCBSaXRlbnNlIEJWLCB0aGUgTmV0aGVybGFuZHMuXG4gIH5cbiAgfiBMaWNlbnNlZCB1bmRlciBFVVBMLCBWZXJzaW9uIDEuMiAodGhlIFwiTGljZW5zZVwiKTtcbiAgfiB5b3UgbWF5IG5vdCB1c2UgdGhpcyBmaWxlIGV4Y2VwdCBpbiBjb21wbGlhbmNlIHdpdGggdGhlIExpY2Vuc2UuXG4gIH4gWW91IG1heSBvYnRhaW4gYSBjb3B5IG9mIHRoZSBMaWNlbnNlIGF0XG4gIH5cbiAgfiBodHRwczovL2pvaW51cC5lYy5ldXJvcGEuZXUvY29sbGVjdGlvbi9ldXBsL2V1cGwtdGV4dC1ldXBsLTEyXG4gIH5cbiAgfiBVbmxlc3MgcmVxdWlyZWQgYnkgYXBwbGljYWJsZSBsYXcgb3IgYWdyZWVkIHRvIGluIHdyaXRpbmcsIHNvZnR3YXJlXG4gIH4gZGlzdHJpYnV0ZWQgdW5kZXIgdGhlIExpY2Vuc2UgaXMgZGlzdHJpYnV0ZWQgb24gYW4gXCJBUyBJU1wiIGJhc2lzLFxuICB+IFdJVEhPVVQgV0FSUkFOVElFUyBPUiBDT05ESVRJT05TIE9GIEFOWSBLSU5ELCBlaXRoZXIgZXhwcmVzcyBvciBpbXBsaWVkLlxuICB+IFNlZSB0aGUgTGljZW5zZSBmb3IgdGhlIHNwZWNpZmljIGxhbmd1YWdlIGdvdmVybmluZyBwZXJtaXNzaW9ucyBhbmRcbiAgfiBsaW1pdGF0aW9ucyB1bmRlciB0aGUgTGljZW5zZS5cbiAgLS0+XG5cbjxuZy1jb250YWluZXJcbiAgKm5nSWY9XCJ7XG4gICAgYXZhaWxhYmxlUHJvY2Vzc0xpbmtUeXBlczogYXZhaWxhYmxlUHJvY2Vzc0xpbmtUeXBlcyQgfCBhc3luY1xuICB9IGFzIG9ic1wiXG4+XG4gIDxwIGNsYXNzPVwic3RlcC1kZXNjcmlwdGlvblwiPlxuICAgIHt7ICdwcm9jZXNzTGlua0NvbmZpZ3VyYXRpb24uY2hvb3NlUHJvY2Vzc0xpbmtUeXBlRGVzY3JpcHRpb24nIHwgdHJhbnNsYXRlIH19XG4gIDwvcD5cbiAgPGRpdiBjbGFzcz1cInByb2Nlc3MtbGluay1ncmlkXCI+XG4gICAgPGRpdlxuICAgICAgY2xhc3M9XCJwcm9jZXNzLWxpbmstaXRlbVwiXG4gICAgICAqbmdGb3I9XCJsZXQgYXZhaWxhYmxlUHJvY2Vzc0xpbmtUeXBlIG9mIG9icy5hdmFpbGFibGVQcm9jZXNzTGlua1R5cGVzXCJcbiAgICA+XG4gICAgICA8bmctY29udGFpbmVyICpuZ0lmPVwiYXZhaWxhYmxlUHJvY2Vzc0xpbmtUeXBlLnByb2Nlc3NMaW5rVHlwZSBhcyBwcm9jZXNzTGlua1R5cGVJZFwiPlxuICAgICAgICA8YnV0dG9uXG4gICAgICAgICAgKGNsaWNrKT1cInNlbGVjdFByb2Nlc3NMaW5rVHlwZShwcm9jZXNzTGlua1R5cGVJZClcIlxuICAgICAgICAgIGNkc0J1dHRvbj1cInNlY29uZGFyeVwiXG4gICAgICAgICAgc2l6ZT1cInhsXCJcbiAgICAgICAgICBjbGFzcz1cInByb2Nlc3MtbGluay10eXBlLWJ1dHRvblwiXG4gICAgICAgICAgW2Rpc2FibGVkXT1cIiFhdmFpbGFibGVQcm9jZXNzTGlua1R5cGUuZW5hYmxlZFwiXG4gICAgICAgICAgW3ZUb29sdGlwXT1cIidwcm9jZXNzTGlua1R5cGVEaXNhYmxlZFRvb2x0aXAuJyArIHByb2Nlc3NMaW5rVHlwZUlkIHwgdHJhbnNsYXRlXCJcbiAgICAgICAgICBbb25Cb3R0b21dPVwidHJ1ZVwiXG4gICAgICAgICAgW3Rvb2x0aXBEaXNhYmxlZF09XCJhdmFpbGFibGVQcm9jZXNzTGlua1R5cGUuZW5hYmxlZFwiXG4gICAgICAgID5cbiAgICAgICAgICB7eyAncHJvY2Vzc0xpbmtUeXBlLicgKyBwcm9jZXNzTGlua1R5cGVJZCB8IHRyYW5zbGF0ZSB9fVxuICAgICAgICAgIDxzdmdcbiAgICAgICAgICAgICpuZ0lmPVwicHJvY2Vzc0xpbmtUeXBlSWQgPT09ICdwbHVnaW4nXCJcbiAgICAgICAgICAgIGNsYXNzPVwiY2RzLS1idG5fX2ljb25cIlxuICAgICAgICAgICAgY2RzSWNvbj1cImxpbmtcIlxuICAgICAgICAgICAgc2l6ZT1cIjE2XCJcbiAgICAgICAgICA+PC9zdmc+XG4gICAgICAgICAgPHN2Z1xuICAgICAgICAgICAgKm5nSWY9XCJwcm9jZXNzTGlua1R5cGVJZCA9PT0gJ2Zvcm0nXCJcbiAgICAgICAgICAgIGNsYXNzPVwiY2RzLS1idG5fX2ljb25cIlxuICAgICAgICAgICAgY2RzSWNvbj1cInJlY2VpcHRcIlxuICAgICAgICAgICAgc2l6ZT1cIjE2XCJcbiAgICAgICAgICA+PC9zdmc+XG4gICAgICAgICAgPHN2Z1xuICAgICAgICAgICAgKm5nSWY9XCJwcm9jZXNzTGlua1R5cGVJZCA9PT0gJ2Zvcm0tZmxvdydcIlxuICAgICAgICAgICAgY2xhc3M9XCJjZHMtLWJ0bl9faWNvblwiXG4gICAgICAgICAgICBjZHNJY29uPVwiZmxvdy0tZGF0YVwiXG4gICAgICAgICAgICBzaXplPVwiMTZcIlxuICAgICAgICAgID48L3N2Zz5cbiAgICAgICAgPC9idXR0b24+XG4gICAgICA8L25nLWNvbnRhaW5lcj5cbiAgICA8L2Rpdj5cbiAgPC9kaXY+XG48L25nLWNvbnRhaW5lcj5cbiJdfQ==
38
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hvb3NlLXByb2Nlc3MtbGluay10eXBlLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3ZhbHRpbW8vcHJvY2Vzcy1saW5rL3NyYy9saWIvY29tcG9uZW50cy9jaG9vc2UtcHJvY2Vzcy1saW5rLXR5cGUvY2hvb3NlLXByb2Nlc3MtbGluay10eXBlLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3ZhbHRpbW8vcHJvY2Vzcy1saW5rL3NyYy9saWIvY29tcG9uZW50cy9jaG9vc2UtcHJvY2Vzcy1saW5rLXR5cGUvY2hvb3NlLXByb2Nlc3MtbGluay10eXBlLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7Ozs7Ozs7OztHQWNHO0FBRUgsT0FBTyxFQUFDLFNBQVMsRUFBQyxNQUFNLGVBQWUsQ0FBQzs7Ozs7OztBQVF4QyxNQUFNLE9BQU8sOEJBQThCO0lBSXpDLFlBQTZCLHVCQUFnRDtRQUFoRCw0QkFBdUIsR0FBdkIsdUJBQXVCLENBQXlCO1FBSDdELCtCQUEwQixHQUN4QyxJQUFJLENBQUMsdUJBQXVCLENBQUMsMEJBQTBCLENBQUM7SUFFc0IsQ0FBQztJQUVqRixxQkFBcUIsQ0FBQyxpQkFBeUI7UUFDN0MsSUFBSSxDQUFDLHVCQUF1QixDQUFDLHFCQUFxQixDQUFDLGlCQUFpQixDQUFDLENBQUM7SUFDeEUsQ0FBQzsrR0FSVSw4QkFBOEI7bUdBQTlCLDhCQUE4Qix3RUN4QjNDLHF3RUFnRUE7OzRGRHhDYSw4QkFBOEI7a0JBTDFDLFNBQVM7K0JBQ0Usa0NBQWtDIiwic291cmNlc0NvbnRlbnQiOlsiLypcbiAqIENvcHlyaWdodCAyMDE1LTIwMjQgUml0ZW5zZSBCViwgdGhlIE5ldGhlcmxhbmRzLlxuICpcbiAqIExpY2Vuc2VkIHVuZGVyIEVVUEwsIFZlcnNpb24gMS4yICh0aGUgXCJMaWNlbnNlXCIpO1xuICogeW91IG1heSBub3QgdXNlIHRoaXMgZmlsZSBleGNlcHQgaW4gY29tcGxpYW5jZSB3aXRoIHRoZSBMaWNlbnNlLlxuICogWW91IG1heSBvYnRhaW4gYSBjb3B5IG9mIHRoZSBMaWNlbnNlIGF0XG4gKlxuICogaHR0cHM6Ly9qb2ludXAuZWMuZXVyb3BhLmV1L2NvbGxlY3Rpb24vZXVwbC9ldXBsLXRleHQtZXVwbC0xMlxuICpcbiAqIFVubGVzcyByZXF1aXJlZCBieSBhcHBsaWNhYmxlIGxhdyBvciBhZ3JlZWQgdG8gaW4gd3JpdGluZywgc29mdHdhcmVcbiAqIGRpc3RyaWJ1dGVkIHVuZGVyIHRoZSBMaWNlbnNlIGlzIGRpc3RyaWJ1dGVkIG9uIGFuIFwiQVMgSVNcIiBiYXNpcyxcbiAqIFdJVEhPVVQgV0FSUkFOVElFUyBPUiBDT05ESVRJT05TIE9GIEFOWSBLSU5ELCBlaXRoZXIgZXhwcmVzcyBvciBpbXBsaWVkLlxuICogU2VlIHRoZSBMaWNlbnNlIGZvciB0aGUgc3BlY2lmaWMgbGFuZ3VhZ2UgZ292ZXJuaW5nIHBlcm1pc3Npb25zIGFuZFxuICogbGltaXRhdGlvbnMgdW5kZXIgdGhlIExpY2Vuc2UuXG4gKi9cblxuaW1wb3J0IHtDb21wb25lbnR9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtQcm9jZXNzTGlua1N0YXRlU2VydmljZX0gZnJvbSAnLi4vLi4vc2VydmljZXMnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICd2YWx0aW1vLWNob29zZS1wcm9jZXNzLWxpbmstdHlwZScsXG4gIHRlbXBsYXRlVXJsOiAnLi9jaG9vc2UtcHJvY2Vzcy1saW5rLXR5cGUuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9jaG9vc2UtcHJvY2Vzcy1saW5rLXR5cGUuY29tcG9uZW50LnNjc3MnXSxcbn0pXG5leHBvcnQgY2xhc3MgQ2hvb3NlUHJvY2Vzc0xpbmtUeXBlQ29tcG9uZW50IHtcbiAgcHVibGljIHJlYWRvbmx5IGF2YWlsYWJsZVByb2Nlc3NMaW5rVHlwZXMkID1cbiAgICB0aGlzLnByb2Nlc3NMaW5rU3RhdGVTZXJ2aWNlLmF2YWlsYWJsZVByb2Nlc3NMaW5rVHlwZXMkO1xuXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgcmVhZG9ubHkgcHJvY2Vzc0xpbmtTdGF0ZVNlcnZpY2U6IFByb2Nlc3NMaW5rU3RhdGVTZXJ2aWNlKSB7fVxuXG4gIHNlbGVjdFByb2Nlc3NMaW5rVHlwZShwcm9jZXNzTGlua1R5cGVJZDogc3RyaW5nKTogdm9pZCB7XG4gICAgdGhpcy5wcm9jZXNzTGlua1N0YXRlU2VydmljZS5zZWxlY3RQcm9jZXNzTGlua1R5cGUocHJvY2Vzc0xpbmtUeXBlSWQpO1xuICB9XG59XG4iLCI8IS0tXG4gIH4gQ29weXJpZ2h0IDIwMTUtMjAyNCBSaXRlbnNlIEJWLCB0aGUgTmV0aGVybGFuZHMuXG4gIH5cbiAgfiBMaWNlbnNlZCB1bmRlciBFVVBMLCBWZXJzaW9uIDEuMiAodGhlIFwiTGljZW5zZVwiKTtcbiAgfiB5b3UgbWF5IG5vdCB1c2UgdGhpcyBmaWxlIGV4Y2VwdCBpbiBjb21wbGlhbmNlIHdpdGggdGhlIExpY2Vuc2UuXG4gIH4gWW91IG1heSBvYnRhaW4gYSBjb3B5IG9mIHRoZSBMaWNlbnNlIGF0XG4gIH5cbiAgfiBodHRwczovL2pvaW51cC5lYy5ldXJvcGEuZXUvY29sbGVjdGlvbi9ldXBsL2V1cGwtdGV4dC1ldXBsLTEyXG4gIH5cbiAgfiBVbmxlc3MgcmVxdWlyZWQgYnkgYXBwbGljYWJsZSBsYXcgb3IgYWdyZWVkIHRvIGluIHdyaXRpbmcsIHNvZnR3YXJlXG4gIH4gZGlzdHJpYnV0ZWQgdW5kZXIgdGhlIExpY2Vuc2UgaXMgZGlzdHJpYnV0ZWQgb24gYW4gXCJBUyBJU1wiIGJhc2lzLFxuICB+IFdJVEhPVVQgV0FSUkFOVElFUyBPUiBDT05ESVRJT05TIE9GIEFOWSBLSU5ELCBlaXRoZXIgZXhwcmVzcyBvciBpbXBsaWVkLlxuICB+IFNlZSB0aGUgTGljZW5zZSBmb3IgdGhlIHNwZWNpZmljIGxhbmd1YWdlIGdvdmVybmluZyBwZXJtaXNzaW9ucyBhbmRcbiAgfiBsaW1pdGF0aW9ucyB1bmRlciB0aGUgTGljZW5zZS5cbiAgLS0+XG5cbjxuZy1jb250YWluZXJcbiAgKm5nSWY9XCJ7XG4gICAgYXZhaWxhYmxlUHJvY2Vzc0xpbmtUeXBlczogYXZhaWxhYmxlUHJvY2Vzc0xpbmtUeXBlcyQgfCBhc3luYyxcbiAgfSBhcyBvYnNcIlxuPlxuICA8cCBjbGFzcz1cInN0ZXAtZGVzY3JpcHRpb25cIj5cbiAgICB7eyAncHJvY2Vzc0xpbmtDb25maWd1cmF0aW9uLmNob29zZVByb2Nlc3NMaW5rVHlwZURlc2NyaXB0aW9uJyB8IHRyYW5zbGF0ZSB9fVxuICA8L3A+XG4gIDxkaXYgY2xhc3M9XCJwcm9jZXNzLWxpbmstZ3JpZFwiPlxuICAgIDxkaXZcbiAgICAgIGNsYXNzPVwicHJvY2Vzcy1saW5rLWl0ZW1cIlxuICAgICAgKm5nRm9yPVwibGV0IGF2YWlsYWJsZVByb2Nlc3NMaW5rVHlwZSBvZiBvYnMuYXZhaWxhYmxlUHJvY2Vzc0xpbmtUeXBlc1wiXG4gICAgPlxuICAgICAgPG5nLWNvbnRhaW5lciAqbmdJZj1cImF2YWlsYWJsZVByb2Nlc3NMaW5rVHlwZS5wcm9jZXNzTGlua1R5cGUgYXMgcHJvY2Vzc0xpbmtUeXBlSWRcIj5cbiAgICAgICAgPGJ1dHRvblxuICAgICAgICAgIChjbGljayk9XCJzZWxlY3RQcm9jZXNzTGlua1R5cGUocHJvY2Vzc0xpbmtUeXBlSWQpXCJcbiAgICAgICAgICBjZHNCdXR0b249XCJzZWNvbmRhcnlcIlxuICAgICAgICAgIHNpemU9XCJ4bFwiXG4gICAgICAgICAgY2xhc3M9XCJwcm9jZXNzLWxpbmstdHlwZS1idXR0b25cIlxuICAgICAgICAgIFtkaXNhYmxlZF09XCIhYXZhaWxhYmxlUHJvY2Vzc0xpbmtUeXBlLmVuYWJsZWRcIlxuICAgICAgICAgIFt2VG9vbHRpcF09XCIncHJvY2Vzc0xpbmtUeXBlRGlzYWJsZWRUb29sdGlwLicgKyBwcm9jZXNzTGlua1R5cGVJZCB8IHRyYW5zbGF0ZVwiXG4gICAgICAgICAgW29uQm90dG9tXT1cInRydWVcIlxuICAgICAgICAgIFt0b29sdGlwRGlzYWJsZWRdPVwiYXZhaWxhYmxlUHJvY2Vzc0xpbmtUeXBlLmVuYWJsZWRcIlxuICAgICAgICA+XG4gICAgICAgICAge3sgJ3Byb2Nlc3NMaW5rVHlwZS4nICsgcHJvY2Vzc0xpbmtUeXBlSWQgfCB0cmFuc2xhdGUgfX1cbiAgICAgICAgICA8c3ZnXG4gICAgICAgICAgICAqbmdJZj1cInByb2Nlc3NMaW5rVHlwZUlkID09PSAncGx1Z2luJ1wiXG4gICAgICAgICAgICBjbGFzcz1cImNkcy0tYnRuX19pY29uXCJcbiAgICAgICAgICAgIGNkc0ljb249XCJsaW5rXCJcbiAgICAgICAgICAgIHNpemU9XCIxNlwiXG4gICAgICAgICAgPjwvc3ZnPlxuICAgICAgICAgIDxzdmdcbiAgICAgICAgICAgICpuZ0lmPVwicHJvY2Vzc0xpbmtUeXBlSWQgPT09ICdmb3JtJ1wiXG4gICAgICAgICAgICBjbGFzcz1cImNkcy0tYnRuX19pY29uXCJcbiAgICAgICAgICAgIGNkc0ljb249XCJyZWNlaXB0XCJcbiAgICAgICAgICAgIHNpemU9XCIxNlwiXG4gICAgICAgICAgPjwvc3ZnPlxuICAgICAgICAgIDxzdmdcbiAgICAgICAgICAgICpuZ0lmPVwicHJvY2Vzc0xpbmtUeXBlSWQgPT09ICdmb3JtLWZsb3cnXCJcbiAgICAgICAgICAgIGNsYXNzPVwiY2RzLS1idG5fX2ljb25cIlxuICAgICAgICAgICAgY2RzSWNvbj1cImZsb3ctLWRhdGFcIlxuICAgICAgICAgICAgc2l6ZT1cIjE2XCJcbiAgICAgICAgICA+PC9zdmc+XG4gICAgICAgIDwvYnV0dG9uPlxuICAgICAgPC9uZy1jb250YWluZXI+XG4gICAgPC9kaXY+XG4gIDwvZGl2PlxuPC9uZy1jb250YWluZXI+XG4iXX0=
@@ -0,0 +1,109 @@
1
+ import { Component, EventEmitter, Input, Output } from '@angular/core';
2
+ import { BehaviorSubject, combineLatest, Subscription } from 'rxjs';
3
+ import { map } from 'rxjs/operators';
4
+ import * as i0 from "@angular/core";
5
+ import * as i1 from "../../services";
6
+ import * as i2 from "@valtimo/config";
7
+ import * as i3 from "@ngx-translate/core";
8
+ import * as i4 from "@angular/common";
9
+ import * as i5 from "carbon-components-angular";
10
+ import * as i6 from "carbon-components-angular/dropdown";
11
+ export class FormDisplayConfigurationComponent {
12
+ constructor(buttonService, configService, stateService, translateService) {
13
+ this.buttonService = buttonService;
14
+ this.configService = configService;
15
+ this.stateService = stateService;
16
+ this.translateService = translateService;
17
+ this.formDisplayValue = new EventEmitter();
18
+ this.formSizeValue = new EventEmitter();
19
+ this.formDisplayValue$ = new BehaviorSubject(null);
20
+ this.formSizeValue$ = new BehaviorSubject(null);
21
+ this.disableFormSizeInput$ = new BehaviorSubject(true);
22
+ this.saving$ = this.stateService.saving$;
23
+ this.taskPanelEnabled$ = new BehaviorSubject(false);
24
+ this.isUserTask$ = new BehaviorSubject(false);
25
+ this._DISPLAY_TYPE_OPTIONS = ['modal', 'panel'];
26
+ this._FORM_SIZE_OPTIONS = ['extraSmall', 'small', 'medium', 'large'];
27
+ this._subscriptions = new Subscription();
28
+ this.formDisplayTypeListItems$ = combineLatest([
29
+ this.formDisplayValue$,
30
+ this.translateService.stream('key'),
31
+ ]).pipe(map(([formDisplayValue]) => this._DISPLAY_TYPE_OPTIONS.map((key) => ({
32
+ content: this.translateService.instant(`processLinkSteps.displayType.options.${key}`),
33
+ key: key,
34
+ selected: this.formDisplayValue$.getValue() === key,
35
+ }))));
36
+ this.formSizeListItems$ = combineLatest([
37
+ this.formSizeValue$,
38
+ this.translateService.stream('key'),
39
+ ]).pipe(map(([formSizeValue]) => this._FORM_SIZE_OPTIONS.map((key) => ({
40
+ content: this.translateService.instant(`processLinkSteps.formSize.options.${key}`),
41
+ key: key,
42
+ selected: this.formSizeValue$.getValue() === key,
43
+ }))));
44
+ this.taskPanelEnabled$.next(!!this.configService.featureToggles?.enableTaskPanel);
45
+ }
46
+ ngOnInit() {
47
+ this._subscriptions.add(combineLatest([
48
+ this.stateService.modalParams$,
49
+ this.stateService.selectedProcessLink$,
50
+ ]).subscribe(([modalParams, selectedProcessLink]) => {
51
+ this.isUserTask$.next(modalParams?.element?.type === 'bpmn:UserTask');
52
+ if (selectedProcessLink) {
53
+ if (selectedProcessLink.formDisplayType)
54
+ this.disableFormSizeInput$.next(false);
55
+ if (selectedProcessLink.activityType.includes('bpmn:UserTask'))
56
+ this.isUserTask$.next(true);
57
+ this.formDisplayValue$.next(selectedProcessLink.formDisplayType);
58
+ this.formSizeValue$.next(selectedProcessLink.formSize);
59
+ }
60
+ }));
61
+ }
62
+ ngOnDestroy() {
63
+ this._subscriptions.unsubscribe();
64
+ }
65
+ selectFormDisplayType(event) {
66
+ this.updateFormDisplayType(event?.key);
67
+ this.enableSaveButtonWhenValid();
68
+ }
69
+ selectFormSize(event) {
70
+ this.updateFormSize(event?.key);
71
+ this.enableSaveButtonWhenValid();
72
+ }
73
+ updateFormDisplayType(formDisplayType) {
74
+ formDisplayType ? this.disableFormSizeInput$.next(false) : this.resetFormSize();
75
+ this.formDisplayValue$.next(formDisplayType);
76
+ this.formDisplayValue.emit(formDisplayType);
77
+ }
78
+ updateFormSize(formSize) {
79
+ this.formSizeValue$.next(formSize);
80
+ this.formSizeValue.emit(formSize);
81
+ }
82
+ resetFormSize() {
83
+ this.disableFormSizeInput$.next(true);
84
+ this.updateFormSize(null);
85
+ }
86
+ enableSaveButtonWhenValid() {
87
+ if (this.selectedFormDefinition &&
88
+ this.formDisplayValue$.getValue() &&
89
+ this.formSizeValue$.getValue()) {
90
+ this.buttonService.enableSaveButton();
91
+ }
92
+ else {
93
+ this.buttonService.disableSaveButton();
94
+ }
95
+ }
96
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FormDisplayConfigurationComponent, deps: [{ token: i1.ProcessLinkButtonService }, { token: i2.ConfigService }, { token: i1.ProcessLinkStateService }, { token: i3.TranslateService }], target: i0.ɵɵFactoryTarget.Component }); }
97
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: FormDisplayConfigurationComponent, selector: "valtimo-form-display-configuration", inputs: { selectedFormDefinition: "selectedFormDefinition" }, outputs: { formDisplayValue: "formDisplayValue", formSizeValue: "formSizeValue" }, ngImport: i0, template: "<ng-container\n *ngIf=\"{\n formDisplayValue: formDisplayValue$ | async,\n formDisplayTypeListItems: formDisplayTypeListItems$ | async,\n formSizeListItems: formSizeListItems$ | async,\n disableFormSizeInput: disableFormSizeInput$ | async,\n isUserTask: isUserTask$ | async,\n taskPanelEnabled: taskPanelEnabled$ | async,\n saving: saving$ | async,\n } as obs\"\n>\n @if (obs.taskPanelEnabled && obs.isUserTask) {\n <cds-combo-box\n [placeholder]=\"'processLinkSteps.displayType.placeholder' | translate\"\n [label]=\"'processLinkSteps.displayType.label' | translate\"\n [disabled]=\"obs.saving\"\n (selected)=\"selectFormDisplayType($event)\"\n >\n <cds-dropdown-list [items]=\"obs.formDisplayTypeListItems || []\"></cds-dropdown-list>\n </cds-combo-box>\n <br />\n\n <cds-combo-box\n [placeholder]=\"'processLinkSteps.formSize.placeholder' | translate\"\n [label]=\"'processLinkSteps.formSize.label' | translate\"\n [disabled]=\"obs.disableFormSizeInput || obs.saving\"\n (selected)=\"selectFormSize($event)\"\n >\n <cds-dropdown-list [items]=\"obs.formSizeListItems || []\"></cds-dropdown-list>\n </cds-combo-box>\n }\n</ng-container>\n", dependencies: [{ kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i5.ComboBox, selector: "cds-combo-box, ibm-combo-box", inputs: ["placeholder", "openMenuAria", "closeMenuAria", "clearSelectionsTitle", "clearSelectionsAria", "clearSelectionTitle", "clearSelectionAria", "id", "labelId", "items", "type", "size", "itemValueKey", "label", "hideLabel", "helperText", "appendInline", "invalid", "invalidText", "warn", "warnText", "maxLength", "theme", "selectionFeedback", "autocomplete", "dropUp", "disabled"], outputs: ["selected", "submit", "close", "search", "clear"] }, { kind: "component", type: i6.DropdownList, selector: "cds-dropdown-list, ibm-dropdown-list", inputs: ["ariaLabel", "items", "listTpl", "type", "showTitles"], outputs: ["select", "scroll", "blurIntent"] }, { kind: "pipe", type: i4.AsyncPipe, name: "async" }, { kind: "pipe", type: i3.TranslatePipe, name: "translate" }] }); }
98
+ }
99
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FormDisplayConfigurationComponent, decorators: [{
100
+ type: Component,
101
+ args: [{ selector: 'valtimo-form-display-configuration', template: "<ng-container\n *ngIf=\"{\n formDisplayValue: formDisplayValue$ | async,\n formDisplayTypeListItems: formDisplayTypeListItems$ | async,\n formSizeListItems: formSizeListItems$ | async,\n disableFormSizeInput: disableFormSizeInput$ | async,\n isUserTask: isUserTask$ | async,\n taskPanelEnabled: taskPanelEnabled$ | async,\n saving: saving$ | async,\n } as obs\"\n>\n @if (obs.taskPanelEnabled && obs.isUserTask) {\n <cds-combo-box\n [placeholder]=\"'processLinkSteps.displayType.placeholder' | translate\"\n [label]=\"'processLinkSteps.displayType.label' | translate\"\n [disabled]=\"obs.saving\"\n (selected)=\"selectFormDisplayType($event)\"\n >\n <cds-dropdown-list [items]=\"obs.formDisplayTypeListItems || []\"></cds-dropdown-list>\n </cds-combo-box>\n <br />\n\n <cds-combo-box\n [placeholder]=\"'processLinkSteps.formSize.placeholder' | translate\"\n [label]=\"'processLinkSteps.formSize.label' | translate\"\n [disabled]=\"obs.disableFormSizeInput || obs.saving\"\n (selected)=\"selectFormSize($event)\"\n >\n <cds-dropdown-list [items]=\"obs.formSizeListItems || []\"></cds-dropdown-list>\n </cds-combo-box>\n }\n</ng-container>\n" }]
102
+ }], ctorParameters: () => [{ type: i1.ProcessLinkButtonService }, { type: i2.ConfigService }, { type: i1.ProcessLinkStateService }, { type: i3.TranslateService }], propDecorators: { selectedFormDefinition: [{
103
+ type: Input
104
+ }], formDisplayValue: [{
105
+ type: Output
106
+ }], formSizeValue: [{
107
+ type: Output
108
+ }] } });
109
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-display-configuration.component.js","sourceRoot":"","sources":["../../../../../../../projects/valtimo/process-link/src/lib/components/form-display-configuration/form-display-configuration.component.ts","../../../../../../../projects/valtimo/process-link/src/lib/components/form-display-configuration/form-display-configuration.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, EventEmitter, Input, OnDestroy, OnInit, Output} from '@angular/core';\nimport {BehaviorSubject, combineLatest, Observable, Subscription} from 'rxjs';\nimport {FormDefinitionListItem, FormDisplayType, FormSize} from '../../models';\nimport {TranslateService} from '@ngx-translate/core';\nimport {ProcessLinkButtonService, ProcessLinkStateService} from '../../services';\nimport {ListItem} from 'carbon-components-angular';\nimport {map} from 'rxjs/operators';\nimport {ConfigService} from '@valtimo/config';\n\n@Component({\n  selector: 'valtimo-form-display-configuration',\n  templateUrl: './form-display-configuration.component.html',\n})\nexport class FormDisplayConfigurationComponent implements OnInit, OnDestroy {\n  @Input() public selectedFormDefinition: FormDefinitionListItem;\n\n  @Output() public formDisplayValue = new EventEmitter<string>();\n  @Output() public formSizeValue = new EventEmitter<string>();\n\n  public readonly formDisplayValue$ = new BehaviorSubject<FormDisplayType | null>(null);\n  public readonly formSizeValue$ = new BehaviorSubject<FormSize | null>(null);\n  public readonly disableFormSizeInput$ = new BehaviorSubject<boolean>(true);\n  public readonly saving$ = this.stateService.saving$;\n  public readonly taskPanelEnabled$ = new BehaviorSubject<boolean>(false);\n  public readonly isUserTask$ = new BehaviorSubject<boolean>(false);\n\n  private readonly _DISPLAY_TYPE_OPTIONS: FormDisplayType[] = ['modal', 'panel'];\n  private readonly _FORM_SIZE_OPTIONS: FormSize[] = ['extraSmall', 'small', 'medium', 'large'];\n  private readonly _subscriptions = new Subscription();\n\n  public readonly formDisplayTypeListItems$: Observable<ListItem[]> = combineLatest([\n    this.formDisplayValue$,\n    this.translateService.stream('key'),\n  ]).pipe(\n    map(([formDisplayValue]) =>\n      this._DISPLAY_TYPE_OPTIONS.map((key: string) => ({\n        content: this.translateService.instant(`processLinkSteps.displayType.options.${key}`),\n        key: key,\n        selected: this.formDisplayValue$.getValue() === key,\n      }))\n    )\n  );\n\n  public readonly formSizeListItems$: Observable<ListItem[]> = combineLatest([\n    this.formSizeValue$,\n    this.translateService.stream('key'),\n  ]).pipe(\n    map(([formSizeValue]) =>\n      this._FORM_SIZE_OPTIONS.map((key: string) => ({\n        content: this.translateService.instant(`processLinkSteps.formSize.options.${key}`),\n        key: key,\n        selected: this.formSizeValue$.getValue() === key,\n      }))\n    )\n  );\n\n  constructor(\n    private readonly buttonService: ProcessLinkButtonService,\n    private readonly configService: ConfigService,\n    private readonly stateService: ProcessLinkStateService,\n    private readonly translateService: TranslateService\n  ) {\n    this.taskPanelEnabled$.next(!!this.configService.featureToggles?.enableTaskPanel);\n  }\n\n  public ngOnInit(): void {\n    this._subscriptions.add(\n      combineLatest([\n        this.stateService.modalParams$,\n        this.stateService.selectedProcessLink$,\n      ]).subscribe(([modalParams, selectedProcessLink]) => {\n        this.isUserTask$.next(modalParams?.element?.type === 'bpmn:UserTask');\n\n        if (selectedProcessLink) {\n          if (selectedProcessLink.formDisplayType) this.disableFormSizeInput$.next(false);\n          if (selectedProcessLink.activityType.includes('bpmn:UserTask'))\n            this.isUserTask$.next(true);\n          this.formDisplayValue$.next(selectedProcessLink.formDisplayType);\n          this.formSizeValue$.next(selectedProcessLink.formSize);\n        }\n      })\n    );\n  }\n\n  public ngOnDestroy(): void {\n    this._subscriptions.unsubscribe();\n  }\n\n  public selectFormDisplayType(event: ListItem): void {\n    this.updateFormDisplayType(event?.key);\n    this.enableSaveButtonWhenValid();\n  }\n\n  public selectFormSize(event: ListItem): void {\n    this.updateFormSize(event?.key);\n    this.enableSaveButtonWhenValid();\n  }\n\n  private updateFormDisplayType(formDisplayType): void {\n    formDisplayType ? this.disableFormSizeInput$.next(false) : this.resetFormSize();\n    this.formDisplayValue$.next(formDisplayType);\n    this.formDisplayValue.emit(formDisplayType);\n  }\n\n  private updateFormSize(formSize): void {\n    this.formSizeValue$.next(formSize);\n    this.formSizeValue.emit(formSize);\n  }\n\n  private resetFormSize(): void {\n    this.disableFormSizeInput$.next(true);\n    this.updateFormSize(null);\n  }\n\n  private enableSaveButtonWhenValid(): void {\n    if (\n      this.selectedFormDefinition &&\n      this.formDisplayValue$.getValue() &&\n      this.formSizeValue$.getValue()\n    ) {\n      this.buttonService.enableSaveButton();\n    } else {\n      this.buttonService.disableSaveButton();\n    }\n  }\n}\n","<ng-container\n  *ngIf=\"{\n    formDisplayValue: formDisplayValue$ | async,\n    formDisplayTypeListItems: formDisplayTypeListItems$ | async,\n    formSizeListItems: formSizeListItems$ | async,\n    disableFormSizeInput: disableFormSizeInput$ | async,\n    isUserTask: isUserTask$ | async,\n    taskPanelEnabled: taskPanelEnabled$ | async,\n    saving: saving$ | async,\n  } as obs\"\n>\n  @if (obs.taskPanelEnabled && obs.isUserTask) {\n    <cds-combo-box\n      [placeholder]=\"'processLinkSteps.displayType.placeholder' | translate\"\n      [label]=\"'processLinkSteps.displayType.label' | translate\"\n      [disabled]=\"obs.saving\"\n      (selected)=\"selectFormDisplayType($event)\"\n    >\n      <cds-dropdown-list [items]=\"obs.formDisplayTypeListItems || []\"></cds-dropdown-list>\n    </cds-combo-box>\n    <br />\n\n    <cds-combo-box\n      [placeholder]=\"'processLinkSteps.formSize.placeholder' | translate\"\n      [label]=\"'processLinkSteps.formSize.label' | translate\"\n      [disabled]=\"obs.disableFormSizeInput || obs.saving\"\n      (selected)=\"selectFormSize($event)\"\n    >\n      <cds-dropdown-list [items]=\"obs.formSizeListItems || []\"></cds-dropdown-list>\n    </cds-combo-box>\n  }\n</ng-container>\n"]}
@@ -14,51 +14,71 @@
14
14
  * limitations under the License.
15
15
  */
16
16
  import { Component, EventEmitter, Input, Output, ViewChild } from '@angular/core';
17
- import { BehaviorSubject } from 'rxjs';
17
+ import { BehaviorSubject, combineLatest, filter, Subscription } from 'rxjs';
18
18
  import { FormioOptionsImpl, } from '@valtimo/components';
19
+ import { map } from 'rxjs/operators';
19
20
  import * as i0 from "@angular/core";
20
21
  import * as i1 from "../../services";
21
22
  import * as i2 from "@valtimo/components";
22
- import * as i3 from "@angular/common";
23
- import * as i4 from "../form-flow-configuration-container/form-flow-configuration-container.component";
23
+ import * as i3 from "@ngx-translate/core";
24
+ import * as i4 from "@valtimo/config";
25
+ import * as i5 from "@angular/common";
26
+ import * as i6 from "carbon-components-angular";
27
+ import * as i7 from "../form-flow-configuration-container/form-flow-configuration-container.component";
24
28
  export class FormFlowComponent {
25
- constructor(formFlowService, modalService) {
29
+ constructor(formFlowService, modalService, translateService, configService) {
26
30
  this.formFlowService = formFlowService;
27
31
  this.modalService = modalService;
32
+ this.translateService = translateService;
33
+ this.configService = configService;
28
34
  this.formIoFormData = new BehaviorSubject(null);
29
35
  this.formFlowComplete = new EventEmitter();
36
+ this.breadcrumbs$ = new BehaviorSubject([]);
30
37
  this.disabled$ = new BehaviorSubject(false);
31
38
  this.formFlowStepType$ = new BehaviorSubject(null);
32
39
  this.FormFlowCustomComponentId$ = new BehaviorSubject('');
40
+ this.currentStepIndex$ = new BehaviorSubject(0);
41
+ this.enableFormFlowBreadcrumbs$ = this.configService.getFeatureToggleObservable('enableFormFlowBreadcrumbs');
42
+ this._subscriptions = new Subscription();
33
43
  this.formioOptions = new FormioOptionsImpl();
34
44
  this.formioOptions.disableAlerts = true;
35
45
  }
36
46
  ngOnInit() {
37
47
  this.getFormFlowStep();
48
+ this.getBreadcrumbs();
49
+ }
50
+ ngOnDestroy() {
51
+ this._subscriptions.unsubscribe();
38
52
  }
39
53
  onChange(event) {
40
- if (event?.data) {
54
+ if (event?.data)
41
55
  this.formIoFormData.next(event.data);
42
- }
43
56
  }
44
57
  onSubmit(submission) {
45
58
  this.disable();
46
59
  if (submission.data) {
47
60
  this.formIoFormData.next(submission.data);
48
61
  }
49
- if (submission.data.submit) {
62
+ if (submission.data.submit && this.formFlowInstanceId && this.formFlowStepInstanceId) {
50
63
  this.formFlowService
51
64
  .submitStep(this.formFlowInstanceId, this.formFlowStepInstanceId, this.formIoFormData.getValue())
52
- .subscribe((result) => this.handleFormFlowStep(result), errors => {
53
- this.form?.showErrors(errors);
54
- this.enable();
65
+ .subscribe({
66
+ next: (result) => {
67
+ this.handleFormFlowStep(result);
68
+ },
69
+ error: errors => {
70
+ this.form?.showErrors(errors);
71
+ this.enable();
72
+ },
55
73
  });
56
74
  }
57
75
  else if (submission.data['back']) {
58
- this.formFlowService.back(this.formFlowInstanceId, submission.data).subscribe((result) => this.handleFormFlowStep(result), errors => {
59
- this.form?.showErrors(errors);
60
- this.enable();
61
- });
76
+ this.back(submission.data);
77
+ }
78
+ }
79
+ onEvent(submission) {
80
+ if (submission.data['back'] || submission.type == 'back') {
81
+ this.back(submission.data);
62
82
  }
63
83
  }
64
84
  saveData() {
@@ -67,13 +87,67 @@ export class FormFlowComponent {
67
87
  this.formFlowService.save(this.formFlowInstanceId, formIoFormDataValue).subscribe(() => null, errors => this.form.showErrors(errors));
68
88
  }
69
89
  }
90
+ onStepSelected(event) {
91
+ this.disable();
92
+ this.currentStepIndex$.next(event.index);
93
+ const submissionData = this.formIoFormData.getValue().data;
94
+ if (!this.formFlowInstanceId || !this.formFlowStepInstanceId)
95
+ return;
96
+ this.formFlowService
97
+ .navigateToStep(this.formFlowInstanceId, this.formFlowStepInstanceId, event.step.stepInstanceId, submissionData)
98
+ .subscribe({
99
+ next: (result) => this.handleFormFlowStep(result),
100
+ error: errors => {
101
+ this.form?.showErrors(errors);
102
+ this.enable();
103
+ },
104
+ });
105
+ }
106
+ getBreadcrumbs() {
107
+ if (!this.formFlowInstanceId)
108
+ return;
109
+ this._subscriptions.add(combineLatest([
110
+ this.enableFormFlowBreadcrumbs$,
111
+ this.formFlowService.getBreadcrumbs(this.formFlowInstanceId),
112
+ this.translateService.stream('key'),
113
+ ])
114
+ .pipe(filter(([enableFormFlowBreadcrumbs]) => enableFormFlowBreadcrumbs), map(([_, breadcrumbs]) => breadcrumbs))
115
+ .subscribe(breadcrumbs => {
116
+ this.currentStepIndex$.next(breadcrumbs.currentStepIndex);
117
+ this.breadcrumbs$.next(breadcrumbs.breadcrumbs.map(breadcrumb => ({
118
+ label: breadcrumb.title ??
119
+ this.translateService.instant(`formFlow.step.${breadcrumb.key}.title`) ??
120
+ breadcrumb.key,
121
+ disabled: breadcrumb.stepInstanceId === null,
122
+ complete: breadcrumb.completed,
123
+ stepInstanceId: breadcrumb.stepInstanceId,
124
+ })));
125
+ const classElement = document.getElementsByClassName('cds--progress-step--current');
126
+ if (classElement.length > 0) {
127
+ classElement[0].scrollIntoView({ behavior: 'smooth', inline: 'center' });
128
+ }
129
+ }));
130
+ }
70
131
  getFormFlowStep() {
132
+ if (!this.formFlowInstanceId)
133
+ return;
71
134
  this.formFlowService
72
135
  .getFormFlowStep(this.formFlowInstanceId)
73
136
  .subscribe((result) => {
74
137
  this.handleFormFlowStep(result);
75
138
  });
76
139
  }
140
+ back(submissionData) {
141
+ if (!this.formFlowInstanceId)
142
+ return;
143
+ this.formFlowService.back(this.formFlowInstanceId, submissionData).subscribe({
144
+ next: (result) => this.handleFormFlowStep(result),
145
+ error: errors => {
146
+ this.form?.showErrors(errors);
147
+ this.enable();
148
+ },
149
+ });
150
+ }
77
151
  handleFormFlowStep(formFlowInstance) {
78
152
  if (formFlowInstance.step === null) {
79
153
  this.formFlowStepType$.next(null);
@@ -83,12 +157,13 @@ export class FormFlowComponent {
83
157
  this.formFlowComplete.emit(null);
84
158
  }
85
159
  else {
160
+ this.getBreadcrumbs();
86
161
  this.modalService.scrollToTop();
87
- this.formFlowStepType$.next(formFlowInstance.step.type);
162
+ this.formFlowStepType$.next(formFlowInstance.step?.type ?? null);
88
163
  this.FormFlowCustomComponentId$.next(formFlowInstance?.step?.typeProperties?.id || '');
89
164
  this.formFlowInstanceId = formFlowInstance.id;
90
- this.formFlowStepInstanceId = formFlowInstance.step.id;
91
- this.formDefinition = formFlowInstance.step.typeProperties.definition;
165
+ this.formFlowStepInstanceId = formFlowInstance.step?.id ?? null;
166
+ this.formDefinition = formFlowInstance.step?.typeProperties.definition;
92
167
  }
93
168
  this.enable();
94
169
  }
@@ -98,13 +173,13 @@ export class FormFlowComponent {
98
173
  enable() {
99
174
  this.disabled$.next(false);
100
175
  }
101
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FormFlowComponent, deps: [{ token: i1.FormFlowService }, { token: i2.ValtimoModalService }], target: i0.ɵɵFactoryTarget.Component }); }
102
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: FormFlowComponent, selector: "valtimo-form-flow", inputs: { formIoFormData: "formIoFormData", formFlowInstanceId: "formFlowInstanceId" }, outputs: { formFlowComplete: "formFlowComplete" }, viewQueries: [{ propertyName: "form", first: true, predicate: ["form"], descendants: true }], 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 <div body *ngIf=\"formDefinition && (formFlowStepType$ | async) === 'form'\">\n <valtimo-form-io\n #form\n [form]=\"formDefinition\"\n (submit)=\"onSubmit($event)\"\n (change)=\"onChange($event)\"\n [options]=\"formioOptions\"\n ></valtimo-form-io>\n </div>\n <div body *ngIf=\"(formFlowStepType$ | async) === 'custom-component'\">\n <valtimo-form-flow-configuration-container\n [componentId]=\"FormFlowCustomComponentId$ | async\"\n [formFlowInstanceId]=\"formFlowInstanceId\"\n [disabled]=\"disabled$ | async\"\n (submitEvent)=\"onSubmit($event)\"\n (changeEvent)=\"onChange($event)\"\n >\n </valtimo-form-flow-configuration-container>\n </div>\n</div>\n", styles: [""], dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.FormioComponent, selector: "valtimo-form-io", inputs: ["options", "submission", "form", "readOnly", "formRefresh$"], outputs: ["submit", "change"] }, { kind: "component", type: i4.FormFlowConfigurationContainerComponent, selector: "valtimo-form-flow-configuration-container", inputs: ["disabled", "componentId", "formFlowInstanceId"], outputs: ["changeEvent", "submitEvent"] }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }] }); }
176
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FormFlowComponent, deps: [{ token: i1.FormFlowService }, { token: i2.ValtimoModalService }, { token: i3.TranslateService }, { token: i4.ConfigService }], target: i0.ɵɵFactoryTarget.Component }); }
177
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: FormFlowComponent, selector: "valtimo-form-flow", inputs: { formIoFormData: "formIoFormData", formFlowInstanceId: "formFlowInstanceId" }, outputs: { formFlowComplete: "formFlowComplete" }, viewQueries: [{ propertyName: "form", first: true, predicate: ["form"], descendants: true }], 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 *ngIf=\"{\n breadcrumbs: breadcrumbs$ | async,\n currentStepIndex: currentStepIndex$ | async,\n enableFormFlowBreadcrumbs: enableFormFlowBreadcrumbs$ | async,\n } as obs\"\n>\n <div *ngIf=\"formDefinition && (formFlowStepType$ | async) === 'form'\">\n <div *ngIf=\"obs.enableFormFlowBreadcrumbs\" class=\"form-flow__progress-bar-indicator\">\n <cds-progress-indicator\n [spacing]=\"'equal'\"\n [skeleton]=\"obs.breadcrumbs.length === 0\"\n [current]=\"obs.currentStepIndex\"\n [steps]=\"obs.breadcrumbs\"\n (stepSelected)=\"onStepSelected($event)\"\n >\n </cds-progress-indicator>\n </div>\n\n <valtimo-form-io\n #form\n [form]=\"formDefinition\"\n (submit)=\"onSubmit($event)\"\n (change)=\"onChange($event)\"\n (event)=\"onEvent($event)\"\n [options]=\"formioOptions\"\n ></valtimo-form-io>\n </div>\n <div *ngIf=\"(formFlowStepType$ | async) === 'custom-component'\">\n <valtimo-form-flow-configuration-container\n [componentId]=\"FormFlowCustomComponentId$ | async\"\n [formFlowInstanceId]=\"formFlowInstanceId\"\n [disabled]=\"disabled$ | async\"\n (submitEvent)=\"onSubmit($event)\"\n (changeEvent)=\"onChange($event)\"\n >\n </valtimo-form-flow-configuration-container>\n </div>\n</div>\n", styles: [".form-flow__progress-bar-indicator{height:64px;overflow-x:auto;-ms-overflow-style:none;scrollbar-width:none}.form-flow__progress-bar-indicator ::-webkit-scrollbar{display:none}\n"], dependencies: [{ kind: "directive", type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i6.ProgressIndicator, selector: "cds-progress-indicator, ibm-progress-indicator", inputs: ["current", "steps", "translations", "orientation", "skeleton", "spacing"], outputs: ["stepSelected"] }, { kind: "component", type: i2.FormioComponent, selector: "valtimo-form-io", inputs: ["options", "submission", "form", "readOnly", "formRefresh$"], outputs: ["submit", "change", "event"] }, { kind: "component", type: i7.FormFlowConfigurationContainerComponent, selector: "valtimo-form-flow-configuration-container", inputs: ["disabled", "componentId", "formFlowInstanceId"], outputs: ["changeEvent", "submitEvent"] }, { kind: "pipe", type: i5.AsyncPipe, name: "async" }] }); }
103
178
  }
104
179
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FormFlowComponent, decorators: [{
105
180
  type: Component,
106
- args: [{ selector: 'valtimo-form-flow', 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 <div body *ngIf=\"formDefinition && (formFlowStepType$ | async) === 'form'\">\n <valtimo-form-io\n #form\n [form]=\"formDefinition\"\n (submit)=\"onSubmit($event)\"\n (change)=\"onChange($event)\"\n [options]=\"formioOptions\"\n ></valtimo-form-io>\n </div>\n <div body *ngIf=\"(formFlowStepType$ | async) === 'custom-component'\">\n <valtimo-form-flow-configuration-container\n [componentId]=\"FormFlowCustomComponentId$ | async\"\n [formFlowInstanceId]=\"formFlowInstanceId\"\n [disabled]=\"disabled$ | async\"\n (submitEvent)=\"onSubmit($event)\"\n (changeEvent)=\"onChange($event)\"\n >\n </valtimo-form-flow-configuration-container>\n </div>\n</div>\n" }]
107
- }], ctorParameters: () => [{ type: i1.FormFlowService }, { type: i2.ValtimoModalService }], propDecorators: { form: [{
181
+ args: [{ selector: 'valtimo-form-flow', 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 *ngIf=\"{\n breadcrumbs: breadcrumbs$ | async,\n currentStepIndex: currentStepIndex$ | async,\n enableFormFlowBreadcrumbs: enableFormFlowBreadcrumbs$ | async,\n } as obs\"\n>\n <div *ngIf=\"formDefinition && (formFlowStepType$ | async) === 'form'\">\n <div *ngIf=\"obs.enableFormFlowBreadcrumbs\" class=\"form-flow__progress-bar-indicator\">\n <cds-progress-indicator\n [spacing]=\"'equal'\"\n [skeleton]=\"obs.breadcrumbs.length === 0\"\n [current]=\"obs.currentStepIndex\"\n [steps]=\"obs.breadcrumbs\"\n (stepSelected)=\"onStepSelected($event)\"\n >\n </cds-progress-indicator>\n </div>\n\n <valtimo-form-io\n #form\n [form]=\"formDefinition\"\n (submit)=\"onSubmit($event)\"\n (change)=\"onChange($event)\"\n (event)=\"onEvent($event)\"\n [options]=\"formioOptions\"\n ></valtimo-form-io>\n </div>\n <div *ngIf=\"(formFlowStepType$ | async) === 'custom-component'\">\n <valtimo-form-flow-configuration-container\n [componentId]=\"FormFlowCustomComponentId$ | async\"\n [formFlowInstanceId]=\"formFlowInstanceId\"\n [disabled]=\"disabled$ | async\"\n (submitEvent)=\"onSubmit($event)\"\n (changeEvent)=\"onChange($event)\"\n >\n </valtimo-form-flow-configuration-container>\n </div>\n</div>\n", styles: [".form-flow__progress-bar-indicator{height:64px;overflow-x:auto;-ms-overflow-style:none;scrollbar-width:none}.form-flow__progress-bar-indicator ::-webkit-scrollbar{display:none}\n"] }]
182
+ }], ctorParameters: () => [{ type: i1.FormFlowService }, { type: i2.ValtimoModalService }, { type: i3.TranslateService }, { type: i4.ConfigService }], propDecorators: { form: [{
108
183
  type: ViewChild,
109
184
  args: ['form']
110
185
  }], formIoFormData: [{
@@ -114,4 +189,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
114
189
  }], formFlowComplete: [{
115
190
  type: Output
116
191
  }] } });
117
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-flow.component.js","sourceRoot":"","sources":["../../../../../../../projects/valtimo/process-link/src/lib/components/form-flow/form-flow.component.ts","../../../../../../../projects/valtimo/process-link/src/lib/components/form-flow/form-flow.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, EventEmitter, Input, OnInit, Output, ViewChild} from '@angular/core';\nimport {BehaviorSubject} from 'rxjs';\nimport {FormioForm} from '@formio/angular';\nimport {\n  FormioComponent,\n  FormioOptionsImpl,\n  FormioSubmission,\n  ValtimoFormioOptions,\n  ValtimoModalService,\n} from '@valtimo/components';\nimport {FormFlowService} from '../../services';\nimport {FormFlowInstance, FormFlowStepType} from '../../models';\n\n@Component({\n  selector: 'valtimo-form-flow',\n  templateUrl: './form-flow.component.html',\n  styleUrls: ['./form-flow.component.css'],\n})\nexport class FormFlowComponent implements OnInit {\n  @ViewChild('form') form: FormioComponent;\n  @Input() formIoFormData: BehaviorSubject<any> | null = new BehaviorSubject<any>(null);\n  @Input() formFlowInstanceId: string;\n  @Output() formFlowComplete = new EventEmitter();\n\n  public readonly disabled$ = new BehaviorSubject<boolean>(false);\n  public readonly formFlowStepType$ = new BehaviorSubject<FormFlowStepType | null>(null);\n  public readonly FormFlowCustomComponentId$ = new BehaviorSubject<string>('');\n\n  formDefinition: FormioForm;\n  formioOptions: ValtimoFormioOptions;\n\n  private formFlowStepInstanceId: string;\n\n  constructor(\n    private readonly formFlowService: FormFlowService,\n    private readonly modalService: ValtimoModalService\n  ) {\n    this.formioOptions = new FormioOptionsImpl();\n    this.formioOptions.disableAlerts = true;\n  }\n\n  public ngOnInit() {\n    this.getFormFlowStep();\n  }\n\n  public onChange(event: any): void {\n    if (event?.data) {\n      this.formIoFormData.next(event.data);\n    }\n  }\n\n  public onSubmit(submission: FormioSubmission): void {\n    this.disable();\n\n    if (submission.data) {\n      this.formIoFormData.next(submission.data);\n    }\n    if (submission.data.submit) {\n      this.formFlowService\n        .submitStep(\n          this.formFlowInstanceId,\n          this.formFlowStepInstanceId,\n          this.formIoFormData.getValue()\n        )\n        .subscribe(\n          (result: FormFlowInstance) => this.handleFormFlowStep(result),\n          errors => {\n            this.form?.showErrors(errors);\n            this.enable();\n          }\n        );\n    } else if (submission.data['back']) {\n      this.formFlowService.back(this.formFlowInstanceId, submission.data).subscribe(\n        (result: FormFlowInstance) => this.handleFormFlowStep(result),\n        errors => {\n          this.form?.showErrors(errors);\n          this.enable();\n        }\n      );\n    }\n  }\n\n  public saveData(): void {\n    const formIoFormDataValue = this.formIoFormData.getValue();\n    if (formIoFormDataValue && this.formFlowInstanceId) {\n      this.formFlowService.save(this.formFlowInstanceId, formIoFormDataValue).subscribe(\n        () => null,\n        errors => this.form.showErrors(errors)\n      );\n    }\n  }\n\n  private getFormFlowStep(): void {\n    this.formFlowService\n      .getFormFlowStep(this.formFlowInstanceId)\n      .subscribe((result: FormFlowInstance) => {\n        this.handleFormFlowStep(result);\n      });\n  }\n\n  private handleFormFlowStep(formFlowInstance: FormFlowInstance) {\n    if (formFlowInstance.step === null) {\n      this.formFlowStepType$.next(null);\n      this.FormFlowCustomComponentId$.next('');\n      this.formFlowInstanceId = null;\n      this.formFlowStepInstanceId = null;\n      this.formFlowComplete.emit(null);\n    } else {\n      this.modalService.scrollToTop();\n      this.formFlowStepType$.next(formFlowInstance.step.type);\n      this.FormFlowCustomComponentId$.next(formFlowInstance?.step?.typeProperties?.id || '');\n      this.formFlowInstanceId = formFlowInstance.id;\n      this.formFlowStepInstanceId = formFlowInstance.step.id;\n      this.formDefinition = formFlowInstance.step.typeProperties.definition;\n    }\n\n    this.enable();\n  }\n\n  private disable(): void {\n    this.disabled$.next(true);\n  }\n\n  private enable(): void {\n    this.disabled$.next(false);\n  }\n}\n","<!--\n  ~ Copyright 2015-2024 Ritense BV, the Netherlands.\n  ~\n  ~ Licensed under EUPL, Version 1.2 (the \"License\");\n  ~ you may not use this file except in compliance with the License.\n  ~ You may obtain a copy of the License at\n  ~\n  ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n  ~\n  ~ Unless required by applicable law or agreed to in writing, software\n  ~ distributed under the License is distributed on an \"AS IS\" basis,\n  ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n  ~ See the License for the specific language governing permissions and\n  ~ limitations under the License.\n  -->\n\n<div>\n  <div body *ngIf=\"formDefinition && (formFlowStepType$ | async) === 'form'\">\n    <valtimo-form-io\n      #form\n      [form]=\"formDefinition\"\n      (submit)=\"onSubmit($event)\"\n      (change)=\"onChange($event)\"\n      [options]=\"formioOptions\"\n    ></valtimo-form-io>\n  </div>\n  <div body *ngIf=\"(formFlowStepType$ | async) === 'custom-component'\">\n    <valtimo-form-flow-configuration-container\n      [componentId]=\"FormFlowCustomComponentId$ | async\"\n      [formFlowInstanceId]=\"formFlowInstanceId\"\n      [disabled]=\"disabled$ | async\"\n      (submitEvent)=\"onSubmit($event)\"\n      (changeEvent)=\"onChange($event)\"\n    >\n    </valtimo-form-flow-configuration-container>\n  </div>\n</div>\n"]}
192
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-flow.component.js","sourceRoot":"","sources":["../../../../../../../projects/valtimo/process-link/src/lib/components/form-flow/form-flow.component.ts","../../../../../../../projects/valtimo/process-link/src/lib/components/form-flow/form-flow.component.html"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;GAcG;AAEH,OAAO,EAAC,SAAS,EAAE,YAAY,EAAE,KAAK,EAAqB,MAAM,EAAE,SAAS,EAAC,MAAM,eAAe,CAAC;AACnG,OAAO,EAAC,eAAe,EAAE,aAAa,EAAE,MAAM,EAAc,YAAY,EAAC,MAAM,MAAM,CAAC;AAEtF,OAAO,EAEL,iBAAiB,GAIlB,MAAM,qBAAqB,CAAC;AAM7B,OAAO,EAAC,GAAG,EAAC,MAAM,gBAAgB,CAAC;;;;;;;;;AAOnC,MAAM,OAAO,iBAAiB;IAsB5B,YACmB,eAAgC,EAChC,YAAiC,EACjC,gBAAkC,EAClC,aAA4B;QAH5B,oBAAe,GAAf,eAAe,CAAiB;QAChC,iBAAY,GAAZ,YAAY,CAAqB;QACjC,qBAAgB,GAAhB,gBAAgB,CAAkB;QAClC,kBAAa,GAAb,aAAa,CAAe;QAxBtC,mBAAc,GAAgC,IAAI,eAAe,CAAM,IAAI,CAAC,CAAC;QAE5E,qBAAgB,GAAG,IAAI,YAAY,EAAE,CAAC;QAEhC,iBAAY,GAAG,IAAI,eAAe,CAAS,EAAE,CAAC,CAAC;QAC/C,cAAS,GAAG,IAAI,eAAe,CAAU,KAAK,CAAC,CAAC;QAChD,sBAAiB,GAAG,IAAI,eAAe,CAA0B,IAAI,CAAC,CAAC;QACvE,+BAA0B,GAAG,IAAI,eAAe,CAAS,EAAE,CAAC,CAAC;QAC7D,sBAAiB,GAAG,IAAI,eAAe,CAAS,CAAC,CAAC,CAAC;QACnD,+BAA0B,GAAG,IAAI,CAAC,aAAa,CAAC,0BAA0B,CACxF,2BAA2B,CAC5B,CAAC;QAEe,mBAAc,GAAG,IAAI,YAAY,EAAE,CAAC;QAanD,IAAI,CAAC,aAAa,GAAG,IAAI,iBAAiB,EAAE,CAAC;QAC7C,IAAI,CAAC,aAAa,CAAC,aAAa,GAAG,IAAI,CAAC;IAC1C,CAAC;IAEM,QAAQ;QACb,IAAI,CAAC,eAAe,EAAE,CAAC;QACvB,IAAI,CAAC,cAAc,EAAE,CAAC;IACxB,CAAC;IAEM,WAAW;QAChB,IAAI,CAAC,cAAc,CAAC,WAAW,EAAE,CAAC;IACpC,CAAC;IAEM,QAAQ,CAAC,KAAU;QACxB,IAAI,KAAK,EAAE,IAAI;YAAE,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;IACxD,CAAC;IAEM,QAAQ,CAAC,UAA4B;QAC1C,IAAI,CAAC,OAAO,EAAE,CAAC;QAEf,IAAI,UAAU,CAAC,IAAI,EAAE,CAAC;YACpB,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;QAC5C,CAAC;QACD,IAAI,UAAU,CAAC,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC,kBAAkB,IAAI,IAAI,CAAC,sBAAsB,EAAE,CAAC;YACrF,IAAI,CAAC,eAAe;iBACjB,UAAU,CACT,IAAI,CAAC,kBAAkB,EACvB,IAAI,CAAC,sBAAsB,EAC3B,IAAI,CAAC,cAAc,CAAC,QAAQ,EAAE,CAC/B;iBACA,SAAS,CAAC;gBACT,IAAI,EAAE,CAAC,MAAwB,EAAE,EAAE;oBACjC,IAAI,CAAC,kBAAkB,CAAC,MAAM,CAAC,CAAC;gBAClC,CAAC;gBACD,KAAK,EAAE,MAAM,CAAC,EAAE;oBACd,IAAI,CAAC,IAAI,EAAE,UAAU,CAAC,MAAM,CAAC,CAAC;oBAC9B,IAAI,CAAC,MAAM,EAAE,CAAC;gBAChB,CAAC;aACF,CAAC,CAAC;QACP,CAAC;aAAM,IAAI,UAAU,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC;YACnC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;QAC7B,CAAC;IACH,CAAC;IAEM,OAAO,CAAC,UAAe;QAC5B,IAAI,UAAU,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,UAAU,CAAC,IAAI,IAAI,MAAM,EAAE,CAAC;YACzD,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;QAC7B,CAAC;IACH,CAAC;IAEM,QAAQ;QACb,MAAM,mBAAmB,GAAG,IAAI,CAAC,cAAc,CAAC,QAAQ,EAAE,CAAC;QAC3D,IAAI,mBAAmB,IAAI,IAAI,CAAC,kBAAkB,EAAE,CAAC;YACnD,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC,kBAAkB,EAAE,mBAAmB,CAAC,CAAC,SAAS,CAC/E,GAAG,EAAE,CAAC,IAAI,EACV,MAAM,CAAC,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,CACvC,CAAC;QACJ,CAAC;IACH,CAAC;IAEM,cAAc,CAAC,KAAsD;QAC1E,IAAI,CAAC,OAAO,EAAE,CAAC;QACf,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;QACzC,MAAM,cAAc,GAAG,IAAI,CAAC,cAAc,CAAC,QAAQ,EAAE,CAAC,IAAI,CAAC;QAC3D,IAAI,CAAC,IAAI,CAAC,kBAAkB,IAAI,CAAC,IAAI,CAAC,sBAAsB;YAAE,OAAO;QACrE,IAAI,CAAC,eAAe;aACjB,cAAc,CACb,IAAI,CAAC,kBAAkB,EACvB,IAAI,CAAC,sBAAsB,EAC3B,KAAK,CAAC,IAAI,CAAC,cAAc,EACzB,cAAc,CACf;aACA,SAAS,CAAC;YACT,IAAI,EAAE,CAAC,MAAwB,EAAE,EAAE,CAAC,IAAI,CAAC,kBAAkB,CAAC,MAAM,CAAC;YACnE,KAAK,EAAE,MAAM,CAAC,EAAE;gBACd,IAAI,CAAC,IAAI,EAAE,UAAU,CAAC,MAAM,CAAC,CAAC;gBAC9B,IAAI,CAAC,MAAM,EAAE,CAAC;YAChB,CAAC;SACF,CAAC,CAAC;IACP,CAAC;IAEO,cAAc;QACpB,IAAI,CAAC,IAAI,CAAC,kBAAkB;YAAE,OAAO;QACrC,IAAI,CAAC,cAAc,CAAC,GAAG,CACrB,aAAa,CAAC;YACZ,IAAI,CAAC,0BAA0B;YAC/B,IAAI,CAAC,eAAe,CAAC,cAAc,CAAC,IAAI,CAAC,kBAAkB,CAAC;YAC5D,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,KAAK,CAAC;SACpC,CAAC;aACC,IAAI,CACH,MAAM,CAAC,CAAC,CAAC,yBAAyB,CAAC,EAAE,EAAE,CAAC,yBAAyB,CAAC,EAClE,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,WAAW,CAAC,EAAE,EAAE,CAAC,WAAW,CAAC,CACvC;aACA,SAAS,CAAC,WAAW,CAAC,EAAE;YACvB,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,WAAW,CAAC,gBAAgB,CAAC,CAAC;YAC1D,IAAI,CAAC,YAAY,CAAC,IAAI,CACpB,WAAW,CAAC,WAAW,CAAC,GAAG,CAAC,UAAU,CAAC,EAAE,CAAC,CAAC;gBACzC,KAAK,EACH,UAAU,CAAC,KAAK;oBAChB,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,iBAAiB,UAAU,CAAC,GAAG,QAAQ,CAAC;oBACtE,UAAU,CAAC,GAAG;gBAChB,QAAQ,EAAE,UAAU,CAAC,cAAc,KAAK,IAAI;gBAC5C,QAAQ,EAAE,UAAU,CAAC,SAAS;gBAC9B,cAAc,EAAE,UAAU,CAAC,cAAc;aAC1C,CAAC,CAAC,CACJ,CAAC;YACF,MAAM,YAAY,GAAG,QAAQ,CAAC,sBAAsB,CAAC,6BAA6B,CAAC,CAAC;YACpF,IAAI,YAAY,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;gBAC5B,YAAY,CAAC,CAAC,CAAC,CAAC,cAAc,CAAC,EAAC,QAAQ,EAAE,QAAQ,EAAE,MAAM,EAAE,QAAQ,EAAC,CAAC,CAAC;YACzE,CAAC;QACH,CAAC,CAAC,CACL,CAAC;IACJ,CAAC;IAEO,eAAe;QACrB,IAAI,CAAC,IAAI,CAAC,kBAAkB;YAAE,OAAO;QACrC,IAAI,CAAC,eAAe;aACjB,eAAe,CAAC,IAAI,CAAC,kBAAkB,CAAC;aACxC,SAAS,CAAC,CAAC,MAAwB,EAAE,EAAE;YACtC,IAAI,CAAC,kBAAkB,CAAC,MAAM,CAAC,CAAC;QAClC,CAAC,CAAC,CAAC;IACP,CAAC;IAEO,IAAI,CAAC,cAAmB;QAC9B,IAAI,CAAC,IAAI,CAAC,kBAAkB;YAAE,OAAO;QAErC,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC,kBAAkB,EAAE,cAAc,CAAC,CAAC,SAAS,CAAC;YAC3E,IAAI,EAAE,CAAC,MAAwB,EAAE,EAAE,CAAC,IAAI,CAAC,kBAAkB,CAAC,MAAM,CAAC;YACnE,KAAK,EAAE,MAAM,CAAC,EAAE;gBACd,IAAI,CAAC,IAAI,EAAE,UAAU,CAAC,MAAM,CAAC,CAAC;gBAC9B,IAAI,CAAC,MAAM,EAAE,CAAC;YAChB,CAAC;SACF,CAAC,CAAC;IACL,CAAC;IAEO,kBAAkB,CAAC,gBAAkC;QAC3D,IAAI,gBAAgB,CAAC,IAAI,KAAK,IAAI,EAAE,CAAC;YACnC,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YAClC,IAAI,CAAC,0BAA0B,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;YACzC,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC;YAC/B,IAAI,CAAC,sBAAsB,GAAG,IAAI,CAAC;YACnC,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACnC,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,cAAc,EAAE,CAAC;YACtB,IAAI,CAAC,YAAY,CAAC,WAAW,EAAE,CAAC;YAChC,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,gBAAgB,CAAC,IAAI,EAAE,IAAI,IAAI,IAAI,CAAC,CAAC;YACjE,IAAI,CAAC,0BAA0B,CAAC,IAAI,CAAC,gBAAgB,EAAE,IAAI,EAAE,cAAc,EAAE,EAAE,IAAI,EAAE,CAAC,CAAC;YACvF,IAAI,CAAC,kBAAkB,GAAG,gBAAgB,CAAC,EAAE,CAAC;YAC9C,IAAI,CAAC,sBAAsB,GAAG,gBAAgB,CAAC,IAAI,EAAE,EAAE,IAAI,IAAI,CAAC;YAChE,IAAI,CAAC,cAAc,GAAG,gBAAgB,CAAC,IAAI,EAAE,cAAc,CAAC,UAAU,CAAC;QACzE,CAAC;QAED,IAAI,CAAC,MAAM,EAAE,CAAC;IAChB,CAAC;IAEO,OAAO;QACb,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC5B,CAAC;IAEO,MAAM;QACZ,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC7B,CAAC;+GA7LU,iBAAiB;mGAAjB,iBAAiB,kSCtC9B,i9DAuDA;;4FDjBa,iBAAiB;kBAL7B,SAAS;+BACE,mBAAmB;iLAKV,IAAI;sBAAtB,SAAS;uBAAC,MAAM;gBACR,cAAc;sBAAtB,KAAK;gBACG,kBAAkB;sBAA1B,KAAK;gBACI,gBAAgB;sBAAzB,MAAM","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, EventEmitter, Input, OnDestroy, OnInit, Output, ViewChild} from '@angular/core';\nimport {BehaviorSubject, combineLatest, filter, Observable, Subscription} from 'rxjs';\nimport {FormioForm} from '@formio/angular';\nimport {\n  FormioComponent,\n  FormioOptionsImpl,\n  FormioSubmission,\n  ValtimoFormioOptions,\n  ValtimoModalService,\n} from '@valtimo/components';\nimport {FormFlowService} from '../../services';\nimport {FormFlowInstance, FormFlowStepType} from '../../models';\nimport {TranslateService} from '@ngx-translate/core';\nimport {Step} from 'carbon-components-angular';\nimport {ConfigService} from '@valtimo/config';\nimport {map} from 'rxjs/operators';\n\n@Component({\n  selector: 'valtimo-form-flow',\n  templateUrl: './form-flow.component.html',\n  styleUrls: ['./form-flow.component.scss'],\n})\nexport class FormFlowComponent implements OnInit, OnDestroy {\n  @ViewChild('form') form: FormioComponent;\n  @Input() formIoFormData: BehaviorSubject<any | null> = new BehaviorSubject<any>(null);\n  @Input() formFlowInstanceId: string | null;\n  @Output() formFlowComplete = new EventEmitter();\n\n  public readonly breadcrumbs$ = new BehaviorSubject<Step[]>([]);\n  public readonly disabled$ = new BehaviorSubject<boolean>(false);\n  public readonly formFlowStepType$ = new BehaviorSubject<FormFlowStepType | null>(null);\n  public readonly FormFlowCustomComponentId$ = new BehaviorSubject<string>('');\n  public readonly currentStepIndex$ = new BehaviorSubject<number>(0);\n  public readonly enableFormFlowBreadcrumbs$ = this.configService.getFeatureToggleObservable(\n    'enableFormFlowBreadcrumbs'\n  );\n\n  private readonly _subscriptions = new Subscription();\n\n  formDefinition: FormioForm;\n  formioOptions: ValtimoFormioOptions;\n\n  private formFlowStepInstanceId: string | null;\n\n  constructor(\n    private readonly formFlowService: FormFlowService,\n    private readonly modalService: ValtimoModalService,\n    private readonly translateService: TranslateService,\n    private readonly configService: ConfigService\n  ) {\n    this.formioOptions = new FormioOptionsImpl();\n    this.formioOptions.disableAlerts = true;\n  }\n\n  public ngOnInit() {\n    this.getFormFlowStep();\n    this.getBreadcrumbs();\n  }\n\n  public ngOnDestroy(): void {\n    this._subscriptions.unsubscribe();\n  }\n\n  public onChange(event: any): void {\n    if (event?.data) this.formIoFormData.next(event.data);\n  }\n\n  public onSubmit(submission: FormioSubmission): void {\n    this.disable();\n\n    if (submission.data) {\n      this.formIoFormData.next(submission.data);\n    }\n    if (submission.data.submit && this.formFlowInstanceId && this.formFlowStepInstanceId) {\n      this.formFlowService\n        .submitStep(\n          this.formFlowInstanceId,\n          this.formFlowStepInstanceId,\n          this.formIoFormData.getValue()\n        )\n        .subscribe({\n          next: (result: FormFlowInstance) => {\n            this.handleFormFlowStep(result);\n          },\n          error: errors => {\n            this.form?.showErrors(errors);\n            this.enable();\n          },\n        });\n    } else if (submission.data['back']) {\n      this.back(submission.data);\n    }\n  }\n\n  public onEvent(submission: any): void {\n    if (submission.data['back'] || submission.type == 'back') {\n      this.back(submission.data);\n    }\n  }\n\n  public saveData(): void {\n    const formIoFormDataValue = this.formIoFormData.getValue();\n    if (formIoFormDataValue && this.formFlowInstanceId) {\n      this.formFlowService.save(this.formFlowInstanceId, formIoFormDataValue).subscribe(\n        () => null,\n        errors => this.form.showErrors(errors)\n      );\n    }\n  }\n\n  public onStepSelected(event: {step: {stepInstanceId: string}; index: number}): void {\n    this.disable();\n    this.currentStepIndex$.next(event.index);\n    const submissionData = this.formIoFormData.getValue().data;\n    if (!this.formFlowInstanceId || !this.formFlowStepInstanceId) return;\n    this.formFlowService\n      .navigateToStep(\n        this.formFlowInstanceId,\n        this.formFlowStepInstanceId,\n        event.step.stepInstanceId,\n        submissionData\n      )\n      .subscribe({\n        next: (result: FormFlowInstance) => this.handleFormFlowStep(result),\n        error: errors => {\n          this.form?.showErrors(errors);\n          this.enable();\n        },\n      });\n  }\n\n  private getBreadcrumbs(): void {\n    if (!this.formFlowInstanceId) return;\n    this._subscriptions.add(\n      combineLatest([\n        this.enableFormFlowBreadcrumbs$,\n        this.formFlowService.getBreadcrumbs(this.formFlowInstanceId),\n        this.translateService.stream('key'),\n      ])\n        .pipe(\n          filter(([enableFormFlowBreadcrumbs]) => enableFormFlowBreadcrumbs),\n          map(([_, breadcrumbs]) => breadcrumbs)\n        )\n        .subscribe(breadcrumbs => {\n          this.currentStepIndex$.next(breadcrumbs.currentStepIndex);\n          this.breadcrumbs$.next(\n            breadcrumbs.breadcrumbs.map(breadcrumb => ({\n              label:\n                breadcrumb.title ??\n                this.translateService.instant(`formFlow.step.${breadcrumb.key}.title`) ??\n                breadcrumb.key,\n              disabled: breadcrumb.stepInstanceId === null,\n              complete: breadcrumb.completed,\n              stepInstanceId: breadcrumb.stepInstanceId,\n            }))\n          );\n          const classElement = document.getElementsByClassName('cds--progress-step--current');\n          if (classElement.length > 0) {\n            classElement[0].scrollIntoView({behavior: 'smooth', inline: 'center'});\n          }\n        })\n    );\n  }\n\n  private getFormFlowStep(): void {\n    if (!this.formFlowInstanceId) return;\n    this.formFlowService\n      .getFormFlowStep(this.formFlowInstanceId)\n      .subscribe((result: FormFlowInstance) => {\n        this.handleFormFlowStep(result);\n      });\n  }\n\n  private back(submissionData: any): void {\n    if (!this.formFlowInstanceId) return;\n\n    this.formFlowService.back(this.formFlowInstanceId, submissionData).subscribe({\n      next: (result: FormFlowInstance) => this.handleFormFlowStep(result),\n      error: errors => {\n        this.form?.showErrors(errors);\n        this.enable();\n      },\n    });\n  }\n\n  private handleFormFlowStep(formFlowInstance: FormFlowInstance) {\n    if (formFlowInstance.step === null) {\n      this.formFlowStepType$.next(null);\n      this.FormFlowCustomComponentId$.next('');\n      this.formFlowInstanceId = null;\n      this.formFlowStepInstanceId = null;\n      this.formFlowComplete.emit(null);\n    } else {\n      this.getBreadcrumbs();\n      this.modalService.scrollToTop();\n      this.formFlowStepType$.next(formFlowInstance.step?.type ?? null);\n      this.FormFlowCustomComponentId$.next(formFlowInstance?.step?.typeProperties?.id || '');\n      this.formFlowInstanceId = formFlowInstance.id;\n      this.formFlowStepInstanceId = formFlowInstance.step?.id ?? null;\n      this.formDefinition = formFlowInstance.step?.typeProperties.definition;\n    }\n\n    this.enable();\n  }\n\n  private disable(): void {\n    this.disabled$.next(true);\n  }\n\n  private enable(): void {\n    this.disabled$.next(false);\n  }\n}\n","<!--\n  ~ Copyright 2015-2024 Ritense BV, the Netherlands.\n  ~\n  ~ Licensed under EUPL, Version 1.2 (the \"License\");\n  ~ you may not use this file except in compliance with the License.\n  ~ You may obtain a copy of the License at\n  ~\n  ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n  ~\n  ~ Unless required by applicable law or agreed to in writing, software\n  ~ distributed under the License is distributed on an \"AS IS\" basis,\n  ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n  ~ See the License for the specific language governing permissions and\n  ~ limitations under the License.\n  -->\n\n<div\n  *ngIf=\"{\n    breadcrumbs: breadcrumbs$ | async,\n    currentStepIndex: currentStepIndex$ | async,\n    enableFormFlowBreadcrumbs: enableFormFlowBreadcrumbs$ | async,\n  } as obs\"\n>\n  <div *ngIf=\"formDefinition && (formFlowStepType$ | async) === 'form'\">\n    <div *ngIf=\"obs.enableFormFlowBreadcrumbs\" class=\"form-flow__progress-bar-indicator\">\n      <cds-progress-indicator\n        [spacing]=\"'equal'\"\n        [skeleton]=\"obs.breadcrumbs.length === 0\"\n        [current]=\"obs.currentStepIndex\"\n        [steps]=\"obs.breadcrumbs\"\n        (stepSelected)=\"onStepSelected($event)\"\n      >\n      </cds-progress-indicator>\n    </div>\n\n    <valtimo-form-io\n      #form\n      [form]=\"formDefinition\"\n      (submit)=\"onSubmit($event)\"\n      (change)=\"onChange($event)\"\n      (event)=\"onEvent($event)\"\n      [options]=\"formioOptions\"\n    ></valtimo-form-io>\n  </div>\n  <div *ngIf=\"(formFlowStepType$ | async) === 'custom-component'\">\n    <valtimo-form-flow-configuration-container\n      [componentId]=\"FormFlowCustomComponentId$ | async\"\n      [formFlowInstanceId]=\"formFlowInstanceId\"\n      [disabled]=\"disabled$ | async\"\n      (submitEvent)=\"onSubmit($event)\"\n      (changeEvent)=\"onChange($event)\"\n    >\n    </valtimo-form-flow-configuration-container>\n  </div>\n</div>\n"]}