@valtimo/process-link 12.6.1 → 12.8.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.
Files changed (44) 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 +1 -1
  3. package/esm2022/lib/components/form-flow/form-flow.component.mjs +36 -27
  4. package/esm2022/lib/components/import-plugin-configuration/import-plugin-configuration.component.mjs +137 -0
  5. package/esm2022/lib/components/plugin-action-configuration/plugin-action-configuration.component.mjs +15 -6
  6. package/esm2022/lib/components/process-link-modal/process-link-modal.component.mjs +5 -4
  7. package/esm2022/lib/components/select-ui-component/select-ui-component.component.mjs +128 -0
  8. package/esm2022/lib/constants/injection-tokens.mjs +3 -2
  9. package/esm2022/lib/models/form-custom-component.model.mjs +17 -0
  10. package/esm2022/lib/models/index.mjs +2 -1
  11. package/esm2022/lib/models/process-link.model.mjs +1 -1
  12. package/esm2022/lib/process-link.module.mjs +17 -5
  13. package/esm2022/lib/services/process-link-state.service.mjs +23 -6
  14. package/esm2022/lib/services/process-link-step.service.mjs +13 -1
  15. package/esm2022/lib/services/process-link.service.mjs +19 -12
  16. package/fesm2022/valtimo-process-link.mjs +437 -113
  17. package/fesm2022/valtimo-process-link.mjs.map +1 -1
  18. package/lib/components/choose-process-link-type/choose-process-link-type.component.d.ts +2 -1
  19. package/lib/components/choose-process-link-type/choose-process-link-type.component.d.ts.map +1 -1
  20. package/lib/components/form-flow/form-flow.component.d.ts +11 -10
  21. package/lib/components/form-flow/form-flow.component.d.ts.map +1 -1
  22. package/lib/components/import-plugin-configuration/import-plugin-configuration.component.d.ts +47 -0
  23. package/lib/components/import-plugin-configuration/import-plugin-configuration.component.d.ts.map +1 -0
  24. package/lib/components/plugin-action-configuration/plugin-action-configuration.component.d.ts +4 -0
  25. package/lib/components/plugin-action-configuration/plugin-action-configuration.component.d.ts.map +1 -1
  26. package/lib/components/select-ui-component/select-ui-component.component.d.ts +28 -0
  27. package/lib/components/select-ui-component/select-ui-component.component.d.ts.map +1 -0
  28. package/lib/constants/injection-tokens.d.ts +3 -2
  29. package/lib/constants/injection-tokens.d.ts.map +1 -1
  30. package/lib/models/form-custom-component.model.d.ts +16 -0
  31. package/lib/models/form-custom-component.model.d.ts.map +1 -0
  32. package/lib/models/index.d.ts +1 -0
  33. package/lib/models/index.d.ts.map +1 -1
  34. package/lib/models/process-link.model.d.ts +23 -2
  35. package/lib/models/process-link.model.d.ts.map +1 -1
  36. package/lib/process-link.module.d.ts +10 -8
  37. package/lib/process-link.module.d.ts.map +1 -1
  38. package/lib/services/process-link-state.service.d.ts +4 -3
  39. package/lib/services/process-link-state.service.d.ts.map +1 -1
  40. package/lib/services/process-link-step.service.d.ts +1 -0
  41. package/lib/services/process-link-step.service.d.ts.map +1 -1
  42. package/lib/services/process-link.service.d.ts +5 -4
  43. package/lib/services/process-link.service.d.ts.map +1 -1
  44. package/package.json +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 <svg\n *ngIf=\"processLinkTypeId === 'ui-component'\"\n class=\"cds--btn__icon\"\n cdsIcon=\"receipt\"\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 <svg\n *ngIf=\"processLinkTypeId === 'ui-component'\"\n class=\"cds--btn__icon\"\n cdsIcon=\"receipt\"\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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hvb3NlLXByb2Nlc3MtbGluay10eXBlLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3ZhbHRpbW8vcHJvY2Vzcy1saW5rL3NyYy9saWIvY29tcG9uZW50cy9jaG9vc2UtcHJvY2Vzcy1saW5rLXR5cGUvY2hvb3NlLXByb2Nlc3MtbGluay10eXBlLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3ZhbHRpbW8vcHJvY2Vzcy1saW5rL3NyYy9saWIvY29tcG9uZW50cy9jaG9vc2UtcHJvY2Vzcy1saW5rLXR5cGUvY2hvb3NlLXByb2Nlc3MtbGluay10eXBlLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7Ozs7Ozs7OztHQWNHO0FBRUgsT0FBTyxFQUFDLFNBQVMsRUFBQyxNQUFNLGVBQWUsQ0FBQzs7Ozs7OztBQVF4QyxNQUFNLE9BQU8sOEJBQThCO0lBSXpDLFlBQTZCLHVCQUFnRDtRQUFoRCw0QkFBdUIsR0FBdkIsdUJBQXVCLENBQXlCO1FBSDdELCtCQUEwQixHQUN4QyxJQUFJLENBQUMsdUJBQXVCLENBQUMsMEJBQTBCLENBQUM7SUFFc0IsQ0FBQztJQUVqRixxQkFBcUIsQ0FBQyxpQkFBeUI7UUFDN0MsSUFBSSxDQUFDLHVCQUF1QixDQUFDLHFCQUFxQixDQUFDLGlCQUFpQixDQUFDLENBQUM7SUFDeEUsQ0FBQzsrR0FSVSw4QkFBOEI7bUdBQTlCLDhCQUE4Qix3RUN4QjNDLHF3RUFnRUE7OzRGRHhDYSw4QkFBOEI7a0JBTDFDLFNBQVM7K0JBQ0Usa0NBQWtDIiwic291cmNlc0NvbnRlbnQiOlsiLypcbiAqIENvcHlyaWdodCAyMDE1LTIwMjQgUml0ZW5zZSBCViwgdGhlIE5ldGhlcmxhbmRzLlxuICpcbiAqIExpY2Vuc2VkIHVuZGVyIEVVUEwsIFZlcnNpb24gMS4yICh0aGUgXCJMaWNlbnNlXCIpO1xuICogeW91IG1heSBub3QgdXNlIHRoaXMgZmlsZSBleGNlcHQgaW4gY29tcGxpYW5jZSB3aXRoIHRoZSBMaWNlbnNlLlxuICogWW91IG1heSBvYnRhaW4gYSBjb3B5IG9mIHRoZSBMaWNlbnNlIGF0XG4gKlxuICogaHR0cHM6Ly9qb2ludXAuZWMuZXVyb3BhLmV1L2NvbGxlY3Rpb24vZXVwbC9ldXBsLXRleHQtZXVwbC0xMlxuICpcbiAqIFVubGVzcyByZXF1aXJlZCBieSBhcHBsaWNhYmxlIGxhdyBvciBhZ3JlZWQgdG8gaW4gd3JpdGluZywgc29mdHdhcmVcbiAqIGRpc3RyaWJ1dGVkIHVuZGVyIHRoZSBMaWNlbnNlIGlzIGRpc3RyaWJ1dGVkIG9uIGFuIFwiQVMgSVNcIiBiYXNpcyxcbiAqIFdJVEhPVVQgV0FSUkFOVElFUyBPUiBDT05ESVRJT05TIE9GIEFOWSBLSU5ELCBlaXRoZXIgZXhwcmVzcyBvciBpbXBsaWVkLlxuICogU2VlIHRoZSBMaWNlbnNlIGZvciB0aGUgc3BlY2lmaWMgbGFuZ3VhZ2UgZ292ZXJuaW5nIHBlcm1pc3Npb25zIGFuZFxuICogbGltaXRhdGlvbnMgdW5kZXIgdGhlIExpY2Vuc2UuXG4gKi9cblxuaW1wb3J0IHtDb21wb25lbnR9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtQcm9jZXNzTGlua1N0YXRlU2VydmljZX0gZnJvbSAnLi4vLi4vc2VydmljZXMnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICd2YWx0aW1vLWNob29zZS1wcm9jZXNzLWxpbmstdHlwZScsXG4gIHRlbXBsYXRlVXJsOiAnLi9jaG9vc2UtcHJvY2Vzcy1saW5rLXR5cGUuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9jaG9vc2UtcHJvY2Vzcy1saW5rLXR5cGUuY29tcG9uZW50LnNjc3MnXSxcbn0pXG5leHBvcnQgY2xhc3MgQ2hvb3NlUHJvY2Vzc0xpbmtUeXBlQ29tcG9uZW50IHtcbiAgcHVibGljIHJlYWRvbmx5IGF2YWlsYWJsZVByb2Nlc3NMaW5rVHlwZXMkID1cbiAgICB0aGlzLnByb2Nlc3NMaW5rU3RhdGVTZXJ2aWNlLmF2YWlsYWJsZVByb2Nlc3NMaW5rVHlwZXMkO1xuXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgcmVhZG9ubHkgcHJvY2Vzc0xpbmtTdGF0ZVNlcnZpY2U6IFByb2Nlc3NMaW5rU3RhdGVTZXJ2aWNlKSB7fVxuXG4gIHNlbGVjdFByb2Nlc3NMaW5rVHlwZShwcm9jZXNzTGlua1R5cGVJZDogc3RyaW5nKTogdm9pZCB7XG4gICAgdGhpcy5wcm9jZXNzTGlua1N0YXRlU2VydmljZS5zZWxlY3RQcm9jZXNzTGlua1R5cGUocHJvY2Vzc0xpbmtUeXBlSWQpO1xuICB9XG59XG4iLCI8IS0tXG4gIH4gQ29weXJpZ2h0IDIwMTUtMjAyNCBSaXRlbnNlIEJWLCB0aGUgTmV0aGVybGFuZHMuXG4gIH5cbiAgfiBMaWNlbnNlZCB1bmRlciBFVVBMLCBWZXJzaW9uIDEuMiAodGhlIFwiTGljZW5zZVwiKTtcbiAgfiB5b3UgbWF5IG5vdCB1c2UgdGhpcyBmaWxlIGV4Y2VwdCBpbiBjb21wbGlhbmNlIHdpdGggdGhlIExpY2Vuc2UuXG4gIH4gWW91IG1heSBvYnRhaW4gYSBjb3B5IG9mIHRoZSBMaWNlbnNlIGF0XG4gIH5cbiAgfiBodHRwczovL2pvaW51cC5lYy5ldXJvcGEuZXUvY29sbGVjdGlvbi9ldXBsL2V1cGwtdGV4dC1ldXBsLTEyXG4gIH5cbiAgfiBVbmxlc3MgcmVxdWlyZWQgYnkgYXBwbGljYWJsZSBsYXcgb3IgYWdyZWVkIHRvIGluIHdyaXRpbmcsIHNvZnR3YXJlXG4gIH4gZGlzdHJpYnV0ZWQgdW5kZXIgdGhlIExpY2Vuc2UgaXMgZGlzdHJpYnV0ZWQgb24gYW4gXCJBUyBJU1wiIGJhc2lzLFxuICB+IFdJVEhPVVQgV0FSUkFOVElFUyBPUiBDT05ESVRJT05TIE9GIEFOWSBLSU5ELCBlaXRoZXIgZXhwcmVzcyBvciBpbXBsaWVkLlxuICB+IFNlZSB0aGUgTGljZW5zZSBmb3IgdGhlIHNwZWNpZmljIGxhbmd1YWdlIGdvdmVybmluZyBwZXJtaXNzaW9ucyBhbmRcbiAgfiBsaW1pdGF0aW9ucyB1bmRlciB0aGUgTGljZW5zZS5cbiAgLS0+XG5cbjxuZy1jb250YWluZXJcbiAgKm5nSWY9XCJ7XG4gICAgYXZhaWxhYmxlUHJvY2Vzc0xpbmtUeXBlczogYXZhaWxhYmxlUHJvY2Vzc0xpbmtUeXBlcyQgfCBhc3luYyxcbiAgfSBhcyBvYnNcIlxuPlxuICA8cCBjbGFzcz1cInN0ZXAtZGVzY3JpcHRpb25cIj5cbiAgICB7eyAncHJvY2Vzc0xpbmtDb25maWd1cmF0aW9uLmNob29zZVByb2Nlc3NMaW5rVHlwZURlc2NyaXB0aW9uJyB8IHRyYW5zbGF0ZSB9fVxuICA8L3A+XG4gIDxkaXYgY2xhc3M9XCJwcm9jZXNzLWxpbmstZ3JpZFwiPlxuICAgIDxkaXZcbiAgICAgIGNsYXNzPVwicHJvY2Vzcy1saW5rLWl0ZW1cIlxuICAgICAgKm5nRm9yPVwibGV0IGF2YWlsYWJsZVByb2Nlc3NMaW5rVHlwZSBvZiBvYnMuYXZhaWxhYmxlUHJvY2Vzc0xpbmtUeXBlc1wiXG4gICAgPlxuICAgICAgPG5nLWNvbnRhaW5lciAqbmdJZj1cImF2YWlsYWJsZVByb2Nlc3NMaW5rVHlwZS5wcm9jZXNzTGlua1R5cGUgYXMgcHJvY2Vzc0xpbmtUeXBlSWRcIj5cbiAgICAgICAgPGJ1dHRvblxuICAgICAgICAgIChjbGljayk9XCJzZWxlY3RQcm9jZXNzTGlua1R5cGUocHJvY2Vzc0xpbmtUeXBlSWQpXCJcbiAgICAgICAgICBjZHNCdXR0b249XCJzZWNvbmRhcnlcIlxuICAgICAgICAgIHNpemU9XCJ4bFwiXG4gICAgICAgICAgY2xhc3M9XCJwcm9jZXNzLWxpbmstdHlwZS1idXR0b25cIlxuICAgICAgICAgIFtkaXNhYmxlZF09XCIhYXZhaWxhYmxlUHJvY2Vzc0xpbmtUeXBlLmVuYWJsZWRcIlxuICAgICAgICAgIFt2VG9vbHRpcF09XCIncHJvY2Vzc0xpbmtUeXBlRGlzYWJsZWRUb29sdGlwLicgKyBwcm9jZXNzTGlua1R5cGVJZCB8IHRyYW5zbGF0ZVwiXG4gICAgICAgICAgW29uQm90dG9tXT1cInRydWVcIlxuICAgICAgICAgIFt0b29sdGlwRGlzYWJsZWRdPVwiYXZhaWxhYmxlUHJvY2Vzc0xpbmtUeXBlLmVuYWJsZWRcIlxuICAgICAgICA+XG4gICAgICAgICAge3sgJ3Byb2Nlc3NMaW5rVHlwZS4nICsgcHJvY2Vzc0xpbmtUeXBlSWQgfCB0cmFuc2xhdGUgfX1cbiAgICAgICAgICA8c3ZnXG4gICAgICAgICAgICAqbmdJZj1cInByb2Nlc3NMaW5rVHlwZUlkID09PSAncGx1Z2luJ1wiXG4gICAgICAgICAgICBjbGFzcz1cImNkcy0tYnRuX19pY29uXCJcbiAgICAgICAgICAgIGNkc0ljb249XCJsaW5rXCJcbiAgICAgICAgICAgIHNpemU9XCIxNlwiXG4gICAgICAgICAgPjwvc3ZnPlxuICAgICAgICAgIDxzdmdcbiAgICAgICAgICAgICpuZ0lmPVwicHJvY2Vzc0xpbmtUeXBlSWQgPT09ICdmb3JtJ1wiXG4gICAgICAgICAgICBjbGFzcz1cImNkcy0tYnRuX19pY29uXCJcbiAgICAgICAgICAgIGNkc0ljb249XCJyZWNlaXB0XCJcbiAgICAgICAgICAgIHNpemU9XCIxNlwiXG4gICAgICAgICAgPjwvc3ZnPlxuICAgICAgICAgIDxzdmdcbiAgICAgICAgICAgICpuZ0lmPVwicHJvY2Vzc0xpbmtUeXBlSWQgPT09ICdmb3JtLWZsb3cnXCJcbiAgICAgICAgICAgIGNsYXNzPVwiY2RzLS1idG5fX2ljb25cIlxuICAgICAgICAgICAgY2RzSWNvbj1cImZsb3ctLWRhdGFcIlxuICAgICAgICAgICAgc2l6ZT1cIjE2XCJcbiAgICAgICAgICA+PC9zdmc+XG4gICAgICAgIDwvYnV0dG9uPlxuICAgICAgPC9uZy1jb250YWluZXI+XG4gICAgPC9kaXY+XG4gIDwvZGl2PlxuPC9uZy1jb250YWluZXI+XG4iXX0=
38
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hvb3NlLXByb2Nlc3MtbGluay10eXBlLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3ZhbHRpbW8vcHJvY2Vzcy1saW5rL3NyYy9saWIvY29tcG9uZW50cy9jaG9vc2UtcHJvY2Vzcy1saW5rLXR5cGUvY2hvb3NlLXByb2Nlc3MtbGluay10eXBlLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3ZhbHRpbW8vcHJvY2Vzcy1saW5rL3NyYy9saWIvY29tcG9uZW50cy9jaG9vc2UtcHJvY2Vzcy1saW5rLXR5cGUvY2hvb3NlLXByb2Nlc3MtbGluay10eXBlLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7Ozs7Ozs7OztHQWNHO0FBRUgsT0FBTyxFQUFDLFNBQVMsRUFBOEIsTUFBTSxlQUFlLENBQUM7Ozs7Ozs7QUFXckUsTUFBTSxPQUFPLDhCQUE4QjtJQUl6QyxZQUE2Qix1QkFBZ0Q7UUFBaEQsNEJBQXVCLEdBQXZCLHVCQUF1QixDQUF5QjtRQUg3RCwrQkFBMEIsR0FDeEMsSUFBSSxDQUFDLHVCQUF1QixDQUFDLDBCQUEwQixDQUFDO0lBRXNCLENBQUM7SUFFakYscUJBQXFCLENBQUMsaUJBQXlCO1FBQzdDLElBQUksQ0FBQyx1QkFBdUIsQ0FBQyxxQkFBcUIsQ0FBQyxpQkFBaUIsQ0FBQyxDQUFDO0lBQ3hFLENBQUM7K0dBUlUsOEJBQThCO21HQUE5Qiw4QkFBOEIsd0VDM0IzQyxvOEVBc0VBOzs0RkQzQ2EsOEJBQThCO2tCQUwxQyxTQUFTOytCQUNFLGtDQUFrQyIsInNvdXJjZXNDb250ZW50IjpbIi8qXG4gKiBDb3B5cmlnaHQgMjAxNS0yMDI0IFJpdGVuc2UgQlYsIHRoZSBOZXRoZXJsYW5kcy5cbiAqXG4gKiBMaWNlbnNlZCB1bmRlciBFVVBMLCBWZXJzaW9uIDEuMiAodGhlIFwiTGljZW5zZVwiKTtcbiAqIHlvdSBtYXkgbm90IHVzZSB0aGlzIGZpbGUgZXhjZXB0IGluIGNvbXBsaWFuY2Ugd2l0aCB0aGUgTGljZW5zZS5cbiAqIFlvdSBtYXkgb2J0YWluIGEgY29weSBvZiB0aGUgTGljZW5zZSBhdFxuICpcbiAqIGh0dHBzOi8vam9pbnVwLmVjLmV1cm9wYS5ldS9jb2xsZWN0aW9uL2V1cGwvZXVwbC10ZXh0LWV1cGwtMTJcbiAqXG4gKiBVbmxlc3MgcmVxdWlyZWQgYnkgYXBwbGljYWJsZSBsYXcgb3IgYWdyZWVkIHRvIGluIHdyaXRpbmcsIHNvZnR3YXJlXG4gKiBkaXN0cmlidXRlZCB1bmRlciB0aGUgTGljZW5zZSBpcyBkaXN0cmlidXRlZCBvbiBhbiBcIkFTIElTXCIgYmFzaXMsXG4gKiBXSVRIT1VUIFdBUlJBTlRJRVMgT1IgQ09ORElUSU9OUyBPRiBBTlkgS0lORCwgZWl0aGVyIGV4cHJlc3Mgb3IgaW1wbGllZC5cbiAqIFNlZSB0aGUgTGljZW5zZSBmb3IgdGhlIHNwZWNpZmljIGxhbmd1YWdlIGdvdmVybmluZyBwZXJtaXNzaW9ucyBhbmRcbiAqIGxpbWl0YXRpb25zIHVuZGVyIHRoZSBMaWNlbnNlLlxuICovXG5cbmltcG9ydCB7Q29tcG9uZW50LCBJbmplY3QsIE9uRGVzdHJveSwgT3B0aW9uYWx9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtQcm9jZXNzTGlua1N0YXRlU2VydmljZX0gZnJvbSAnLi4vLi4vc2VydmljZXMnO1xuaW1wb3J0IHtGb3JtQ3VzdG9tQ29tcG9uZW50Q29uZmlnLCBQcm9jZXNzTGlua1R5cGV9IGZyb20gJy4uLy4uL21vZGVscyc7XG5pbXBvcnQge0ZPUk1fQ1VTVE9NX0NPTVBPTkVOVF9UT0tFTn0gZnJvbSAnLi4vLi4vY29uc3RhbnRzJztcbmltcG9ydCB7bWFwLCBTdWJzY3JpcHRpb259IGZyb20gJ3J4anMnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICd2YWx0aW1vLWNob29zZS1wcm9jZXNzLWxpbmstdHlwZScsXG4gIHRlbXBsYXRlVXJsOiAnLi9jaG9vc2UtcHJvY2Vzcy1saW5rLXR5cGUuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9jaG9vc2UtcHJvY2Vzcy1saW5rLXR5cGUuY29tcG9uZW50LnNjc3MnXSxcbn0pXG5leHBvcnQgY2xhc3MgQ2hvb3NlUHJvY2Vzc0xpbmtUeXBlQ29tcG9uZW50IHtcbiAgcHVibGljIHJlYWRvbmx5IGF2YWlsYWJsZVByb2Nlc3NMaW5rVHlwZXMkID1cbiAgICB0aGlzLnByb2Nlc3NMaW5rU3RhdGVTZXJ2aWNlLmF2YWlsYWJsZVByb2Nlc3NMaW5rVHlwZXMkO1xuXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgcmVhZG9ubHkgcHJvY2Vzc0xpbmtTdGF0ZVNlcnZpY2U6IFByb2Nlc3NMaW5rU3RhdGVTZXJ2aWNlKSB7fVxuXG4gIHNlbGVjdFByb2Nlc3NMaW5rVHlwZShwcm9jZXNzTGlua1R5cGVJZDogc3RyaW5nKTogdm9pZCB7XG4gICAgdGhpcy5wcm9jZXNzTGlua1N0YXRlU2VydmljZS5zZWxlY3RQcm9jZXNzTGlua1R5cGUocHJvY2Vzc0xpbmtUeXBlSWQpO1xuICB9XG59XG4iLCI8IS0tXG4gIH4gQ29weXJpZ2h0IDIwMTUtMjAyNCBSaXRlbnNlIEJWLCB0aGUgTmV0aGVybGFuZHMuXG4gIH5cbiAgfiBMaWNlbnNlZCB1bmRlciBFVVBMLCBWZXJzaW9uIDEuMiAodGhlIFwiTGljZW5zZVwiKTtcbiAgfiB5b3UgbWF5IG5vdCB1c2UgdGhpcyBmaWxlIGV4Y2VwdCBpbiBjb21wbGlhbmNlIHdpdGggdGhlIExpY2Vuc2UuXG4gIH4gWW91IG1heSBvYnRhaW4gYSBjb3B5IG9mIHRoZSBMaWNlbnNlIGF0XG4gIH5cbiAgfiBodHRwczovL2pvaW51cC5lYy5ldXJvcGEuZXUvY29sbGVjdGlvbi9ldXBsL2V1cGwtdGV4dC1ldXBsLTEyXG4gIH5cbiAgfiBVbmxlc3MgcmVxdWlyZWQgYnkgYXBwbGljYWJsZSBsYXcgb3IgYWdyZWVkIHRvIGluIHdyaXRpbmcsIHNvZnR3YXJlXG4gIH4gZGlzdHJpYnV0ZWQgdW5kZXIgdGhlIExpY2Vuc2UgaXMgZGlzdHJpYnV0ZWQgb24gYW4gXCJBUyBJU1wiIGJhc2lzLFxuICB+IFdJVEhPVVQgV0FSUkFOVElFUyBPUiBDT05ESVRJT05TIE9GIEFOWSBLSU5ELCBlaXRoZXIgZXhwcmVzcyBvciBpbXBsaWVkLlxuICB+IFNlZSB0aGUgTGljZW5zZSBmb3IgdGhlIHNwZWNpZmljIGxhbmd1YWdlIGdvdmVybmluZyBwZXJtaXNzaW9ucyBhbmRcbiAgfiBsaW1pdGF0aW9ucyB1bmRlciB0aGUgTGljZW5zZS5cbiAgLS0+XG5cbjxuZy1jb250YWluZXJcbiAgKm5nSWY9XCJ7XG4gICAgYXZhaWxhYmxlUHJvY2Vzc0xpbmtUeXBlczogYXZhaWxhYmxlUHJvY2Vzc0xpbmtUeXBlcyQgfCBhc3luYyxcbiAgfSBhcyBvYnNcIlxuPlxuICA8cCBjbGFzcz1cInN0ZXAtZGVzY3JpcHRpb25cIj5cbiAgICB7eyAncHJvY2Vzc0xpbmtDb25maWd1cmF0aW9uLmNob29zZVByb2Nlc3NMaW5rVHlwZURlc2NyaXB0aW9uJyB8IHRyYW5zbGF0ZSB9fVxuICA8L3A+XG4gIDxkaXYgY2xhc3M9XCJwcm9jZXNzLWxpbmstZ3JpZFwiPlxuICAgIDxkaXZcbiAgICAgIGNsYXNzPVwicHJvY2Vzcy1saW5rLWl0ZW1cIlxuICAgICAgKm5nRm9yPVwibGV0IGF2YWlsYWJsZVByb2Nlc3NMaW5rVHlwZSBvZiBvYnMuYXZhaWxhYmxlUHJvY2Vzc0xpbmtUeXBlc1wiXG4gICAgPlxuICAgICAgPG5nLWNvbnRhaW5lciAqbmdJZj1cImF2YWlsYWJsZVByb2Nlc3NMaW5rVHlwZS5wcm9jZXNzTGlua1R5cGUgYXMgcHJvY2Vzc0xpbmtUeXBlSWRcIj5cbiAgICAgICAgPGJ1dHRvblxuICAgICAgICAgIChjbGljayk9XCJzZWxlY3RQcm9jZXNzTGlua1R5cGUocHJvY2Vzc0xpbmtUeXBlSWQpXCJcbiAgICAgICAgICBjZHNCdXR0b249XCJzZWNvbmRhcnlcIlxuICAgICAgICAgIHNpemU9XCJ4bFwiXG4gICAgICAgICAgY2xhc3M9XCJwcm9jZXNzLWxpbmstdHlwZS1idXR0b25cIlxuICAgICAgICAgIFtkaXNhYmxlZF09XCIhYXZhaWxhYmxlUHJvY2Vzc0xpbmtUeXBlLmVuYWJsZWRcIlxuICAgICAgICAgIFt2VG9vbHRpcF09XCIncHJvY2Vzc0xpbmtUeXBlRGlzYWJsZWRUb29sdGlwLicgKyBwcm9jZXNzTGlua1R5cGVJZCB8IHRyYW5zbGF0ZVwiXG4gICAgICAgICAgW29uQm90dG9tXT1cInRydWVcIlxuICAgICAgICAgIFt0b29sdGlwRGlzYWJsZWRdPVwiYXZhaWxhYmxlUHJvY2Vzc0xpbmtUeXBlLmVuYWJsZWRcIlxuICAgICAgICA+XG4gICAgICAgICAge3sgJ3Byb2Nlc3NMaW5rVHlwZS4nICsgcHJvY2Vzc0xpbmtUeXBlSWQgfCB0cmFuc2xhdGUgfX1cbiAgICAgICAgICA8c3ZnXG4gICAgICAgICAgICAqbmdJZj1cInByb2Nlc3NMaW5rVHlwZUlkID09PSAncGx1Z2luJ1wiXG4gICAgICAgICAgICBjbGFzcz1cImNkcy0tYnRuX19pY29uXCJcbiAgICAgICAgICAgIGNkc0ljb249XCJsaW5rXCJcbiAgICAgICAgICAgIHNpemU9XCIxNlwiXG4gICAgICAgICAgPjwvc3ZnPlxuICAgICAgICAgIDxzdmdcbiAgICAgICAgICAgICpuZ0lmPVwicHJvY2Vzc0xpbmtUeXBlSWQgPT09ICdmb3JtJ1wiXG4gICAgICAgICAgICBjbGFzcz1cImNkcy0tYnRuX19pY29uXCJcbiAgICAgICAgICAgIGNkc0ljb249XCJyZWNlaXB0XCJcbiAgICAgICAgICAgIHNpemU9XCIxNlwiXG4gICAgICAgICAgPjwvc3ZnPlxuICAgICAgICAgIDxzdmdcbiAgICAgICAgICAgICpuZ0lmPVwicHJvY2Vzc0xpbmtUeXBlSWQgPT09ICdmb3JtLWZsb3cnXCJcbiAgICAgICAgICAgIGNsYXNzPVwiY2RzLS1idG5fX2ljb25cIlxuICAgICAgICAgICAgY2RzSWNvbj1cImZsb3ctLWRhdGFcIlxuICAgICAgICAgICAgc2l6ZT1cIjE2XCJcbiAgICAgICAgICA+PC9zdmc+XG4gICAgICAgICAgPHN2Z1xuICAgICAgICAgICAgKm5nSWY9XCJwcm9jZXNzTGlua1R5cGVJZCA9PT0gJ3VpLWNvbXBvbmVudCdcIlxuICAgICAgICAgICAgY2xhc3M9XCJjZHMtLWJ0bl9faWNvblwiXG4gICAgICAgICAgICBjZHNJY29uPVwicmVjZWlwdFwiXG4gICAgICAgICAgICBzaXplPVwiMTZcIlxuICAgICAgICAgID48L3N2Zz5cbiAgICAgICAgPC9idXR0b24+XG4gICAgICA8L25nLWNvbnRhaW5lcj5cbiAgICA8L2Rpdj5cbiAgPC9kaXY+XG48L25nLWNvbnRhaW5lcj5cbiJdfQ==
@@ -102,7 +102,7 @@ export class FormDisplayConfigurationComponent {
102
102
  }
103
103
  }
104
104
  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 }); }
105
- 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", subtitlesValue: "subtitlesValue" }, ngImport: i0, template: "<ng-container\n *ngIf=\"{\n formDisplayValue: formDisplayValue$ | async,\n formDisplayTypeListItems: formDisplayTypeListItems$ | async,\n formSizeListItems: formSizeListItems$ | async,\n disableFormSizeInput: disableFormSizeInput$ | async,\n subtitles: subtitles$ | 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\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 <br />\n\n <valtimo-carbon-multi-input\n type=\"value\"\n titleTranslationKey=\"processLinkSteps.subtitles\"\n addRowTranslationKey=\"processLinkSteps.addSubtitle\"\n [disabled]=\"obs.saving\"\n [fullWidth]=\"true\"\n [minimumAmountOfRows]=\"0\"\n [initialAmountOfRows]=\"0\"\n [defaultValues]=\"obs.subtitles\"\n (valueChange)=\"onSubtitlesChange($event)\"\n ></valtimo-carbon-multi-input>\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: "component", type: i7.CarbonMultiInputComponent, selector: "valtimo-carbon-multi-input", inputs: ["name", "title", "titleTranslationKey", "type", "arbitraryValueAmount", "arbitraryAmountTitles", "initialAmountOfRows", "minimumAmountOfRows", "maxRows", "addRowText", "addRowTranslationKey", "deleteRowText", "deleteRowTranslationKey", "disabled", "defaultValues", "margin", "tooltip", "required", "keyColumnTitle", "valueColumnTitle", "dropdownColumnTitle", "hideDeleteButton", "hideAddButton", "dropdownItems", "dropdownWidth", "fullWidth", "carbonTheme"], outputs: ["valueChange", "allValuesValidEvent"] }, { kind: "pipe", type: i4.AsyncPipe, name: "async" }, { kind: "pipe", type: i3.TranslatePipe, name: "translate" }] }); }
105
+ 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", subtitlesValue: "subtitlesValue" }, ngImport: i0, template: "<ng-container\n *ngIf=\"{\n formDisplayValue: formDisplayValue$ | async,\n formDisplayTypeListItems: formDisplayTypeListItems$ | async,\n formSizeListItems: formSizeListItems$ | async,\n disableFormSizeInput: disableFormSizeInput$ | async,\n subtitles: subtitles$ | 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\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 <br />\n\n <valtimo-carbon-multi-input\n type=\"value\"\n titleTranslationKey=\"processLinkSteps.subtitles\"\n addRowTranslationKey=\"processLinkSteps.addSubtitle\"\n [disabled]=\"obs.saving\"\n [fullWidth]=\"true\"\n [minimumAmountOfRows]=\"0\"\n [initialAmountOfRows]=\"0\"\n [defaultValues]=\"obs.subtitles\"\n (valueChange)=\"onSubtitlesChange($event)\"\n ></valtimo-carbon-multi-input>\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: "component", type: i7.CarbonMultiInputComponent, selector: "valtimo-carbon-multi-input", inputs: ["addRowText", "addRowTranslationKey", "arbitraryAmountTitles", "arbitraryValueAmount", "defaultValues", "deleteRowText", "deleteRowTranslationKey", "disabled", "dropdownColumnTitle", "dropdownItems", "dropdownWidth", "fullWidth", "hideAddButton", "hideDeleteButton", "initialAmountOfRows", "keyColumnTitle", "margin", "maxRows", "minimumAmountOfRows", "name", "required", "title", "titleTranslationKey", "tooltip", "type", "valueColumnTitle", "valuePathSelectorDocumentDefinitionName", "valuePathSelectorPrefixes", "valuePathSelectorShowDocumentDefinitionSelector", "valuePathSelectorNotation", "keyColumnFlex", "dropdownColumnFlex", "valueColumnFlex"], outputs: ["valueChange", "allValuesValidEvent"] }, { kind: "pipe", type: i4.AsyncPipe, name: "async" }, { kind: "pipe", type: i3.TranslatePipe, name: "translate" }] }); }
106
106
  }
107
107
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FormDisplayConfigurationComponent, decorators: [{
108
108
  type: Component,
@@ -14,7 +14,7 @@
14
14
  * limitations under the License.
15
15
  */
16
16
  import { Component, EventEmitter, Input, Output, ViewChild } from '@angular/core';
17
- import { BehaviorSubject, combineLatest, filter, Subscription } from 'rxjs';
17
+ import { BehaviorSubject, combineLatest } from 'rxjs';
18
18
  import { FormioOptionsImpl, } from '@valtimo/components';
19
19
  import { map } from 'rxjs/operators';
20
20
  import * as i0 from "@angular/core";
@@ -26,6 +26,11 @@ import * as i5 from "@angular/common";
26
26
  import * as i6 from "carbon-components-angular";
27
27
  import * as i7 from "../form-flow-configuration-container/form-flow-configuration-container.component";
28
28
  export class FormFlowComponent {
29
+ set formFlowInstanceId(value) {
30
+ this.formFlowInstanceId$.next(value);
31
+ if (value)
32
+ this.getBreadcrumbs();
33
+ }
29
34
  constructor(formFlowService, modalService, translateService, configService) {
30
35
  this.formFlowService = formFlowService;
31
36
  this.modalService = modalService;
@@ -40,16 +45,16 @@ export class FormFlowComponent {
40
45
  this.FormFlowCustomComponentId$ = new BehaviorSubject('');
41
46
  this.currentStepIndex$ = new BehaviorSubject(0);
42
47
  this.enableFormFlowBreadcrumbs$ = this.configService.getFeatureToggleObservable('enableFormFlowBreadcrumbs');
43
- this._subscriptions = new Subscription();
48
+ this.formFlowInstanceId$ = new BehaviorSubject('');
49
+ this.formFlowStepInstanceId = null;
44
50
  this.formioOptions = new FormioOptionsImpl();
45
51
  this.formioOptions.disableAlerts = true;
46
52
  }
47
53
  ngOnInit() {
48
54
  this.getFormFlowStep();
49
- this.getBreadcrumbs();
50
55
  }
51
56
  ngOnDestroy() {
52
- this._subscriptions.unsubscribe();
57
+ this._breadcrumbsSubscription?.unsubscribe();
53
58
  }
54
59
  onChange(event) {
55
60
  if (!event?.data)
@@ -62,9 +67,11 @@ export class FormFlowComponent {
62
67
  if (submission.data) {
63
68
  this.formIoFormData.next(submission.data);
64
69
  }
65
- if (submission.data.submit && this.formFlowInstanceId && this.formFlowStepInstanceId) {
70
+ if (submission.data.submit &&
71
+ this.formFlowInstanceId$.getValue() &&
72
+ this.formFlowStepInstanceId) {
66
73
  this.formFlowService
67
- .submitStep(this.formFlowInstanceId, this.formFlowStepInstanceId, this.formIoFormData.getValue())
74
+ .submitStep(this.formFlowInstanceId$.getValue(), this.formFlowStepInstanceId, this.formIoFormData.getValue())
68
75
  .subscribe({
69
76
  next: (result) => {
70
77
  this.handleFormFlowStep(result);
@@ -86,18 +93,18 @@ export class FormFlowComponent {
86
93
  }
87
94
  saveData() {
88
95
  const formIoFormDataValue = this.formIoFormData.getValue();
89
- if (formIoFormDataValue && this.formFlowInstanceId) {
90
- this.formFlowService.save(this.formFlowInstanceId, formIoFormDataValue).subscribe(() => null, errors => this.form.showErrors(errors));
96
+ if (formIoFormDataValue && this.formFlowInstanceId$.getValue()) {
97
+ this.formFlowService.save(this.formFlowInstanceId$.getValue(), formIoFormDataValue).subscribe(() => null, errors => this.form.showErrors(errors));
91
98
  }
92
99
  }
93
100
  onStepSelected(event) {
101
+ const submissionData = this.formIoFormData.getValue().data;
94
102
  this.disable();
95
103
  this.currentStepIndex$.next(event.index);
96
- const submissionData = this.formIoFormData.getValue().data;
97
- if (!this.formFlowInstanceId || !this.formFlowStepInstanceId)
104
+ if (!this.formFlowInstanceId$.getValue() || !this.formFlowStepInstanceId)
98
105
  return;
99
106
  this.formFlowService
100
- .navigateToStep(this.formFlowInstanceId, this.formFlowStepInstanceId, event.step.stepInstanceId, submissionData)
107
+ .navigateToStep(this.formFlowInstanceId$.getValue(), this.formFlowStepInstanceId, event.step.stepInstanceId, submissionData)
101
108
  .subscribe({
102
109
  next: (result) => this.handleFormFlowStep(result),
103
110
  error: errors => {
@@ -107,15 +114,18 @@ export class FormFlowComponent {
107
114
  });
108
115
  }
109
116
  getBreadcrumbs() {
110
- if (!this.formFlowInstanceId)
117
+ if (!this.formFlowInstanceId$.getValue() ||
118
+ !this.configService.getFeatureToggle('enableFormFlowBreadcrumbs')) {
111
119
  return;
112
- this._subscriptions.add(combineLatest([
113
- this.enableFormFlowBreadcrumbs$,
114
- this.formFlowService.getBreadcrumbs(this.formFlowInstanceId),
120
+ }
121
+ this._breadcrumbsSubscription?.unsubscribe();
122
+ this._breadcrumbsSubscription = combineLatest([
123
+ this.formFlowService.getBreadcrumbs(this.formFlowInstanceId$.getValue()),
115
124
  this.translateService.stream('key'),
116
125
  ])
117
- .pipe(filter(([enableFormFlowBreadcrumbs]) => enableFormFlowBreadcrumbs), map(([_, breadcrumbs]) => breadcrumbs))
126
+ .pipe(map(([breadcrumbs]) => breadcrumbs))
118
127
  .subscribe(breadcrumbs => {
128
+ const classElement = document.getElementsByClassName('cds--progress-step--current');
119
129
  this.currentStepIndex$.next(breadcrumbs.currentStepIndex);
120
130
  this.breadcrumbs$.next(breadcrumbs.breadcrumbs.map(breadcrumb => ({
121
131
  label: breadcrumb.title ??
@@ -125,25 +135,24 @@ export class FormFlowComponent {
125
135
  complete: breadcrumb.completed,
126
136
  stepInstanceId: breadcrumb.stepInstanceId,
127
137
  })));
128
- const classElement = document.getElementsByClassName('cds--progress-step--current');
129
138
  if (classElement.length > 0) {
130
139
  classElement[0].scrollIntoView({ behavior: 'smooth', inline: 'center' });
131
140
  }
132
- }));
141
+ });
133
142
  }
134
143
  getFormFlowStep() {
135
- if (!this.formFlowInstanceId)
144
+ if (!this.formFlowInstanceId$.getValue())
136
145
  return;
137
146
  this.formFlowService
138
- .getFormFlowStep(this.formFlowInstanceId)
147
+ .getFormFlowStep(this.formFlowInstanceId$.getValue())
139
148
  .subscribe((result) => {
140
149
  this.handleFormFlowStep(result);
141
150
  });
142
151
  }
143
152
  back(submissionData) {
144
- if (!this.formFlowInstanceId)
153
+ if (!this.formFlowInstanceId$.getValue())
145
154
  return;
146
- this.formFlowService.back(this.formFlowInstanceId, submissionData).subscribe({
155
+ this.formFlowService.back(this.formFlowInstanceId$.getValue(), submissionData).subscribe({
147
156
  next: (result) => this.handleFormFlowStep(result),
148
157
  error: errors => {
149
158
  this.form?.showErrors(errors);
@@ -155,7 +164,7 @@ export class FormFlowComponent {
155
164
  if (formFlowInstance.step === null) {
156
165
  this.formFlowStepType$.next(null);
157
166
  this.FormFlowCustomComponentId$.next('');
158
- this.formFlowInstanceId = null;
167
+ this.formFlowInstanceId$.next(null);
159
168
  this.formFlowStepInstanceId = null;
160
169
  this.formFlowComplete.emit(null);
161
170
  }
@@ -164,7 +173,7 @@ export class FormFlowComponent {
164
173
  this.modalService.scrollToTop();
165
174
  this.formFlowStepType$.next(formFlowInstance.step?.type ?? null);
166
175
  this.FormFlowCustomComponentId$.next(formFlowInstance?.step?.typeProperties?.id || '');
167
- this.formFlowInstanceId = formFlowInstance.id;
176
+ this.formFlowInstanceId$.next(formFlowInstance.id);
168
177
  this.formFlowStepInstanceId = formFlowInstance.step?.id ?? null;
169
178
  this.formDefinition = formFlowInstance.step?.typeProperties.definition;
170
179
  }
@@ -177,11 +186,11 @@ export class FormFlowComponent {
177
186
  this.disabled$.next(false);
178
187
  }
179
188
  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 }); }
180
- 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", formFlowChange: "formFlowChange" }, 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" }] }); }
189
+ 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", formFlowChange: "formFlowChange" }, 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 formFlowInstanceId: formFlowInstanceId$ | 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\n <div *ngIf=\"(formFlowStepType$ | async) === 'custom-component'\">\n <valtimo-form-flow-configuration-container\n [componentId]=\"FormFlowCustomComponentId$ | async\"\n [formFlowInstanceId]=\"obs.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" }] }); }
181
190
  }
182
191
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FormFlowComponent, decorators: [{
183
192
  type: Component,
184
- 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"] }]
193
+ 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 formFlowInstanceId: formFlowInstanceId$ | 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\n <div *ngIf=\"(formFlowStepType$ | async) === 'custom-component'\">\n <valtimo-form-flow-configuration-container\n [componentId]=\"FormFlowCustomComponentId$ | async\"\n [formFlowInstanceId]=\"obs.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"] }]
185
194
  }], ctorParameters: () => [{ type: i1.FormFlowService }, { type: i2.ValtimoModalService }, { type: i3.TranslateService }, { type: i4.ConfigService }], propDecorators: { form: [{
186
195
  type: ViewChild,
187
196
  args: ['form']
@@ -194,4 +203,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
194
203
  }], formFlowChange: [{
195
204
  type: Output
196
205
  }] } });
197
- //# 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, 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  @Output() formFlowChange = 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) return;\n\n    this.formIoFormData.next(event.data);\n    this.formFlowChange.emit();\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"]}
206
+ //# 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, OnDestroy, OnInit, Output, ViewChild} from '@angular/core';\nimport {BehaviorSubject, combineLatest, 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') public readonly form: FormioComponent;\n\n  @Input() public readonly formIoFormData: BehaviorSubject<any | null> = new BehaviorSubject<any>(\n    null\n  );\n  @Input() public set formFlowInstanceId(value: string | null) {\n    this.formFlowInstanceId$.next(value);\n\n    if (value) this.getBreadcrumbs();\n  }\n\n  @Output() public readonly formFlowComplete = new EventEmitter();\n  @Output() public readonly formFlowChange = new EventEmitter();\n\n  public formDefinition: FormioForm;\n  public formioOptions: ValtimoFormioOptions;\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  public readonly formFlowInstanceId$ = new BehaviorSubject<string | null>('');\n\n  private formFlowStepInstanceId: string | null = null;\n\n  private _breadcrumbsSubscription!: Subscription;\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  }\n\n  public ngOnDestroy(): void {\n    this._breadcrumbsSubscription?.unsubscribe();\n  }\n\n  public onChange(event: any): void {\n    if (!event?.data) return;\n\n    this.formIoFormData.next(event.data);\n    this.formFlowChange.emit();\n  }\n\n  public onSubmit(submission: FormioSubmission): void {\n    this.disable();\n\n    if (submission.data) {\n      this.formIoFormData.next(submission.data);\n    }\n\n    if (\n      submission.data.submit &&\n      this.formFlowInstanceId$.getValue() &&\n      this.formFlowStepInstanceId\n    ) {\n      this.formFlowService\n        .submitStep(\n          this.formFlowInstanceId$.getValue(),\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\n    if (formIoFormDataValue && this.formFlowInstanceId$.getValue()) {\n      this.formFlowService.save(this.formFlowInstanceId$.getValue(), 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    const submissionData = this.formIoFormData.getValue().data;\n\n    this.disable();\n\n    this.currentStepIndex$.next(event.index);\n\n    if (!this.formFlowInstanceId$.getValue() || !this.formFlowStepInstanceId) return;\n\n    this.formFlowService\n      .navigateToStep(\n        this.formFlowInstanceId$.getValue(),\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 (\n      !this.formFlowInstanceId$.getValue() ||\n      !this.configService.getFeatureToggle('enableFormFlowBreadcrumbs')\n    ) {\n      return;\n    }\n\n    this._breadcrumbsSubscription?.unsubscribe();\n\n    this._breadcrumbsSubscription = combineLatest([\n      this.formFlowService.getBreadcrumbs(this.formFlowInstanceId$.getValue()),\n      this.translateService.stream('key'),\n    ])\n      .pipe(map(([breadcrumbs]) => breadcrumbs))\n      .subscribe(breadcrumbs => {\n        const classElement = document.getElementsByClassName('cds--progress-step--current');\n\n        this.currentStepIndex$.next(breadcrumbs.currentStepIndex);\n\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\n        if (classElement.length > 0) {\n          classElement[0].scrollIntoView({behavior: 'smooth', inline: 'center'});\n        }\n      });\n  }\n\n  private getFormFlowStep(): void {\n    if (!this.formFlowInstanceId$.getValue()) return;\n\n    this.formFlowService\n      .getFormFlowStep(this.formFlowInstanceId$.getValue())\n      .subscribe((result: FormFlowInstance) => {\n        this.handleFormFlowStep(result);\n      });\n  }\n\n  private back(submissionData: any): void {\n    if (!this.formFlowInstanceId$.getValue()) return;\n\n    this.formFlowService.back(this.formFlowInstanceId$.getValue(), 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): void {\n    if (formFlowInstance.step === null) {\n      this.formFlowStepType$.next(null);\n      this.FormFlowCustomComponentId$.next('');\n      this.formFlowInstanceId$.next(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$.next(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    formFlowInstanceId: formFlowInstanceId$ | 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\n  <div *ngIf=\"(formFlowStepType$ | async) === 'custom-component'\">\n    <valtimo-form-flow-configuration-container\n      [componentId]=\"FormFlowCustomComponentId$ | async\"\n      [formFlowInstanceId]=\"obs.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"]}