@valtimo/process-link 12.7.0 → 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.
- package/esm2022/lib/components/choose-process-link-type/choose-process-link-type.component.mjs +1 -1
- package/esm2022/lib/components/form-flow/form-flow.component.mjs +36 -27
- package/esm2022/lib/components/import-plugin-configuration/import-plugin-configuration.component.mjs +137 -0
- package/esm2022/lib/components/plugin-action-configuration/plugin-action-configuration.component.mjs +15 -6
- package/esm2022/lib/components/process-link-modal/process-link-modal.component.mjs +3 -3
- package/esm2022/lib/components/select-ui-component/select-ui-component.component.mjs +20 -20
- package/esm2022/lib/constants/injection-tokens.mjs +1 -1
- package/esm2022/lib/models/form-custom-component.model.mjs +1 -1
- package/esm2022/lib/models/process-link.model.mjs +1 -1
- package/esm2022/lib/process-link.module.mjs +11 -5
- package/esm2022/lib/services/process-link-state.service.mjs +23 -6
- package/esm2022/lib/services/process-link-step.service.mjs +2 -2
- package/esm2022/lib/services/process-link.service.mjs +19 -16
- package/fesm2022/valtimo-process-link.mjs +302 -134
- package/fesm2022/valtimo-process-link.mjs.map +1 -1
- package/lib/components/choose-process-link-type/choose-process-link-type.component.d.ts +2 -1
- package/lib/components/choose-process-link-type/choose-process-link-type.component.d.ts.map +1 -1
- package/lib/components/form-flow/form-flow.component.d.ts +11 -10
- package/lib/components/form-flow/form-flow.component.d.ts.map +1 -1
- package/lib/components/import-plugin-configuration/import-plugin-configuration.component.d.ts +47 -0
- package/lib/components/import-plugin-configuration/import-plugin-configuration.component.d.ts.map +1 -0
- package/lib/components/plugin-action-configuration/plugin-action-configuration.component.d.ts +4 -0
- package/lib/components/plugin-action-configuration/plugin-action-configuration.component.d.ts.map +1 -1
- package/lib/components/select-ui-component/select-ui-component.component.d.ts.map +1 -1
- package/lib/models/form-custom-component.model.d.ts +1 -1
- package/lib/models/form-custom-component.model.d.ts.map +1 -1
- package/lib/models/process-link.model.d.ts +9 -1
- package/lib/models/process-link.model.d.ts.map +1 -1
- package/lib/process-link.module.d.ts +9 -8
- package/lib/process-link.module.d.ts.map +1 -1
- package/lib/services/process-link-state.service.d.ts +4 -3
- package/lib/services/process-link-state.service.d.ts.map +1 -1
- package/lib/services/process-link.service.d.ts +3 -2
- package/lib/services/process-link.service.d.ts.map +1 -1
- package/package.json +1 -1
package/esm2022/lib/components/choose-process-link-type/choose-process-link-type.component.mjs
CHANGED
|
@@ -35,4 +35,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
35
35
|
type: Component,
|
|
36
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,
|
|
38
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hvb3NlLXByb2Nlc3MtbGluay10eXBlLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3ZhbHRpbW8vcHJvY2Vzcy1saW5rL3NyYy9saWIvY29tcG9uZW50cy9jaG9vc2UtcHJvY2Vzcy1saW5rLXR5cGUvY2hvb3NlLXByb2Nlc3MtbGluay10eXBlLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3ZhbHRpbW8vcHJvY2Vzcy1saW5rL3NyYy9saWIvY29tcG9uZW50cy9jaG9vc2UtcHJvY2Vzcy1saW5rLXR5cGUvY2hvb3NlLXByb2Nlc3MtbGluay10eXBlLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7Ozs7Ozs7OztHQWNHO0FBRUgsT0FBTyxFQUFDLFNBQVMsRUFBOEIsTUFBTSxlQUFlLENBQUM7Ozs7Ozs7QUFXckUsTUFBTSxPQUFPLDhCQUE4QjtJQUl6QyxZQUE2Qix1QkFBZ0Q7UUFBaEQsNEJBQXVCLEdBQXZCLHVCQUF1QixDQUF5QjtRQUg3RCwrQkFBMEIsR0FDeEMsSUFBSSxDQUFDLHVCQUF1QixDQUFDLDBCQUEwQixDQUFDO0lBRXNCLENBQUM7SUFFakYscUJBQXFCLENBQUMsaUJBQXlCO1FBQzdDLElBQUksQ0FBQyx1QkFBdUIsQ0FBQyxxQkFBcUIsQ0FBQyxpQkFBaUIsQ0FBQyxDQUFDO0lBQ3hFLENBQUM7K0dBUlUsOEJBQThCO21HQUE5Qiw4QkFBOEIsd0VDM0IzQyxvOEVBc0VBOzs0RkQzQ2EsOEJBQThCO2tCQUwxQyxTQUFTOytCQUNFLGtDQUFrQyIsInNvdXJjZXNDb250ZW50IjpbIi8qXG4gKiBDb3B5cmlnaHQgMjAxNS0yMDI0IFJpdGVuc2UgQlYsIHRoZSBOZXRoZXJsYW5kcy5cbiAqXG4gKiBMaWNlbnNlZCB1bmRlciBFVVBMLCBWZXJzaW9uIDEuMiAodGhlIFwiTGljZW5zZVwiKTtcbiAqIHlvdSBtYXkgbm90IHVzZSB0aGlzIGZpbGUgZXhjZXB0IGluIGNvbXBsaWFuY2Ugd2l0aCB0aGUgTGljZW5zZS5cbiAqIFlvdSBtYXkgb2J0YWluIGEgY29weSBvZiB0aGUgTGljZW5zZSBhdFxuICpcbiAqIGh0dHBzOi8vam9pbnVwLmVjLmV1cm9wYS5ldS9jb2xsZWN0aW9uL2V1cGwvZXVwbC10ZXh0LWV1cGwtMTJcbiAqXG4gKiBVbmxlc3MgcmVxdWlyZWQgYnkgYXBwbGljYWJsZSBsYXcgb3IgYWdyZWVkIHRvIGluIHdyaXRpbmcsIHNvZnR3YXJlXG4gKiBkaXN0cmlidXRlZCB1bmRlciB0aGUgTGljZW5zZSBpcyBkaXN0cmlidXRlZCBvbiBhbiBcIkFTIElTXCIgYmFzaXMsXG4gKiBXSVRIT1VUIFdBUlJBTlRJRVMgT1IgQ09ORElUSU9OUyBPRiBBTlkgS0lORCwgZWl0aGVyIGV4cHJlc3Mgb3IgaW1wbGllZC5cbiAqIFNlZSB0aGUgTGljZW5zZSBmb3IgdGhlIHNwZWNpZmljIGxhbmd1YWdlIGdvdmVybmluZyBwZXJtaXNzaW9ucyBhbmRcbiAqIGxpbWl0YXRpb25zIHVuZGVyIHRoZSBMaWNlbnNlLlxuICovXG5cbmltcG9ydCB7Q29tcG9uZW50LCBJbmplY3QsIE9uRGVzdHJveSwgT3B0aW9uYWx9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtQcm9jZXNzTGlua1N0YXRlU2VydmljZX0gZnJvbSAnLi4vLi4vc2VydmljZXMnO1xuaW1wb3J0IHtGb3JtQ3VzdG9tQ29tcG9uZW50Q29uZmlnLCBQcm9jZXNzTGlua1R5cGV9IGZyb20gJy4uLy4uL21vZGVscyc7XG5pbXBvcnQge0ZPUk1fQ1VTVE9NX0NPTVBPTkVOVF9UT0tFTn0gZnJvbSAnLi4vLi4vY29uc3RhbnRzJztcbmltcG9ydCB7bWFwLCBTdWJzY3JpcHRpb259IGZyb20gJ3J4anMnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICd2YWx0aW1vLWNob29zZS1wcm9jZXNzLWxpbmstdHlwZScsXG4gIHRlbXBsYXRlVXJsOiAnLi9jaG9vc2UtcHJvY2Vzcy1saW5rLXR5cGUuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9jaG9vc2UtcHJvY2Vzcy1saW5rLXR5cGUuY29tcG9uZW50LnNjc3MnXSxcbn0pXG5leHBvcnQgY2xhc3MgQ2hvb3NlUHJvY2Vzc0xpbmtUeXBlQ29tcG9uZW50IHtcbiAgcHVibGljIHJlYWRvbmx5IGF2YWlsYWJsZVByb2Nlc3NMaW5rVHlwZXMkID1cbiAgICB0aGlzLnByb2Nlc3NMaW5rU3RhdGVTZXJ2aWNlLmF2YWlsYWJsZVByb2Nlc3NMaW5rVHlwZXMkO1xuXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgcmVhZG9ubHkgcHJvY2Vzc0xpbmtTdGF0ZVNlcnZpY2U6IFByb2Nlc3NMaW5rU3RhdGVTZXJ2aWNlKSB7fVxuXG4gIHNlbGVjdFByb2Nlc3NMaW5rVHlwZShwcm9jZXNzTGlua1R5cGVJZDogc3RyaW5nKTogdm9pZCB7XG4gICAgdGhpcy5wcm9jZXNzTGlua1N0YXRlU2VydmljZS5zZWxlY3RQcm9jZXNzTGlua1R5cGUocHJvY2Vzc0xpbmtUeXBlSWQpO1xuICB9XG59XG4iLCI8IS0tXG4gIH4gQ29weXJpZ2h0IDIwMTUtMjAyNCBSaXRlbnNlIEJWLCB0aGUgTmV0aGVybGFuZHMuXG4gIH5cbiAgfiBMaWNlbnNlZCB1bmRlciBFVVBMLCBWZXJzaW9uIDEuMiAodGhlIFwiTGljZW5zZVwiKTtcbiAgfiB5b3UgbWF5IG5vdCB1c2UgdGhpcyBmaWxlIGV4Y2VwdCBpbiBjb21wbGlhbmNlIHdpdGggdGhlIExpY2Vuc2UuXG4gIH4gWW91IG1heSBvYnRhaW4gYSBjb3B5IG9mIHRoZSBMaWNlbnNlIGF0XG4gIH5cbiAgfiBodHRwczovL2pvaW51cC5lYy5ldXJvcGEuZXUvY29sbGVjdGlvbi9ldXBsL2V1cGwtdGV4dC1ldXBsLTEyXG4gIH5cbiAgfiBVbmxlc3MgcmVxdWlyZWQgYnkgYXBwbGljYWJsZSBsYXcgb3IgYWdyZWVkIHRvIGluIHdyaXRpbmcsIHNvZnR3YXJlXG4gIH4gZGlzdHJpYnV0ZWQgdW5kZXIgdGhlIExpY2Vuc2UgaXMgZGlzdHJpYnV0ZWQgb24gYW4gXCJBUyBJU1wiIGJhc2lzLFxuICB+IFdJVEhPVVQgV0FSUkFOVElFUyBPUiBDT05ESVRJT05TIE9GIEFOWSBLSU5ELCBlaXRoZXIgZXhwcmVzcyBvciBpbXBsaWVkLlxuICB+IFNlZSB0aGUgTGljZW5zZSBmb3IgdGhlIHNwZWNpZmljIGxhbmd1YWdlIGdvdmVybmluZyBwZXJtaXNzaW9ucyBhbmRcbiAgfiBsaW1pdGF0aW9ucyB1bmRlciB0aGUgTGljZW5zZS5cbiAgLS0+XG5cbjxuZy1jb250YWluZXJcbiAgKm5nSWY9XCJ7XG4gICAgYXZhaWxhYmxlUHJvY2Vzc0xpbmtUeXBlczogYXZhaWxhYmxlUHJvY2Vzc0xpbmtUeXBlcyQgfCBhc3luYyxcbiAgfSBhcyBvYnNcIlxuPlxuICA8cCBjbGFzcz1cInN0ZXAtZGVzY3JpcHRpb25cIj5cbiAgICB7eyAncHJvY2Vzc0xpbmtDb25maWd1cmF0aW9uLmNob29zZVByb2Nlc3NMaW5rVHlwZURlc2NyaXB0aW9uJyB8IHRyYW5zbGF0ZSB9fVxuICA8L3A+XG4gIDxkaXYgY2xhc3M9XCJwcm9jZXNzLWxpbmstZ3JpZFwiPlxuICAgIDxkaXZcbiAgICAgIGNsYXNzPVwicHJvY2Vzcy1saW5rLWl0ZW1cIlxuICAgICAgKm5nRm9yPVwibGV0IGF2YWlsYWJsZVByb2Nlc3NMaW5rVHlwZSBvZiBvYnMuYXZhaWxhYmxlUHJvY2Vzc0xpbmtUeXBlc1wiXG4gICAgPlxuICAgICAgPG5nLWNvbnRhaW5lciAqbmdJZj1cImF2YWlsYWJsZVByb2Nlc3NMaW5rVHlwZS5wcm9jZXNzTGlua1R5cGUgYXMgcHJvY2Vzc0xpbmtUeXBlSWRcIj5cbiAgICAgICAgPGJ1dHRvblxuICAgICAgICAgIChjbGljayk9XCJzZWxlY3RQcm9jZXNzTGlua1R5cGUocHJvY2Vzc0xpbmtUeXBlSWQpXCJcbiAgICAgICAgICBjZHNCdXR0b249XCJzZWNvbmRhcnlcIlxuICAgICAgICAgIHNpemU9XCJ4bFwiXG4gICAgICAgICAgY2xhc3M9XCJwcm9jZXNzLWxpbmstdHlwZS1idXR0b25cIlxuICAgICAgICAgIFtkaXNhYmxlZF09XCIhYXZhaWxhYmxlUHJvY2Vzc0xpbmtUeXBlLmVuYWJsZWRcIlxuICAgICAgICAgIFt2VG9vbHRpcF09XCIncHJvY2Vzc0xpbmtUeXBlRGlzYWJsZWRUb29sdGlwLicgKyBwcm9jZXNzTGlua1R5cGVJZCB8IHRyYW5zbGF0ZVwiXG4gICAgICAgICAgW29uQm90dG9tXT1cInRydWVcIlxuICAgICAgICAgIFt0b29sdGlwRGlzYWJsZWRdPVwiYXZhaWxhYmxlUHJvY2Vzc0xpbmtUeXBlLmVuYWJsZWRcIlxuICAgICAgICA+XG4gICAgICAgICAge3sgJ3Byb2Nlc3NMaW5rVHlwZS4nICsgcHJvY2Vzc0xpbmtUeXBlSWQgfCB0cmFuc2xhdGUgfX1cbiAgICAgICAgICA8c3ZnXG4gICAgICAgICAgICAqbmdJZj1cInByb2Nlc3NMaW5rVHlwZUlkID09PSAncGx1Z2luJ1wiXG4gICAgICAgICAgICBjbGFzcz1cImNkcy0tYnRuX19pY29uXCJcbiAgICAgICAgICAgIGNkc0ljb249XCJsaW5rXCJcbiAgICAgICAgICAgIHNpemU9XCIxNlwiXG4gICAgICAgICAgPjwvc3ZnPlxuICAgICAgICAgIDxzdmdcbiAgICAgICAgICAgICpuZ0lmPVwicHJvY2Vzc0xpbmtUeXBlSWQgPT09ICdmb3JtJ1wiXG4gICAgICAgICAgICBjbGFzcz1cImNkcy0tYnRuX19pY29uXCJcbiAgICAgICAgICAgIGNkc0ljb249XCJyZWNlaXB0XCJcbiAgICAgICAgICAgIHNpemU9XCIxNlwiXG4gICAgICAgICAgPjwvc3ZnPlxuICAgICAgICAgIDxzdmdcbiAgICAgICAgICAgICpuZ0lmPVwicHJvY2Vzc0xpbmtUeXBlSWQgPT09ICdmb3JtLWZsb3cnXCJcbiAgICAgICAgICAgIGNsYXNzPVwiY2RzLS1idG5fX2ljb25cIlxuICAgICAgICAgICAgY2RzSWNvbj1cImZsb3ctLWRhdGFcIlxuICAgICAgICAgICAgc2l6ZT1cIjE2XCJcbiAgICAgICAgICA+PC9zdmc+XG4gICAgICAgICAgPHN2Z1xuICAgICAgICAgICAgKm5nSWY9XCJwcm9jZXNzTGlua1R5cGVJZCA9PT0gJ3VpLWNvbXBvbmVudCdcIlxuICAgICAgICAgICAgY2xhc3M9XCJjZHMtLWJ0bl9faWNvblwiXG4gICAgICAgICAgICBjZHNJY29uPVwicmVjZWlwdFwiXG4gICAgICAgICAgICBzaXplPVwiMTZcIlxuICAgICAgICAgID48L3N2Zz5cbiAgICAgICAgPC9idXR0b24+XG4gICAgICA8L25nLWNvbnRhaW5lcj5cbiAgICA8L2Rpdj5cbiAgPC9kaXY+XG48L25nLWNvbnRhaW5lcj5cbiJdfQ==
|
|
@@ -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
|
|
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.
|
|
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.
|
|
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 &&
|
|
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
|
-
|
|
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
|
-
|
|
113
|
-
|
|
114
|
-
|
|
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(
|
|
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
|
|
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
|
|
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"]}
|
package/esm2022/lib/components/import-plugin-configuration/import-plugin-configuration.component.mjs
ADDED
|
@@ -0,0 +1,137 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* Copyright 2015-2024 Ritense BV, the Netherlands.
|
|
3
|
+
*
|
|
4
|
+
* Licensed under EUPL, Version 1.2 (the "License");
|
|
5
|
+
* you may not use this file except in compliance with the License.
|
|
6
|
+
* You may obtain a copy of the License at
|
|
7
|
+
*
|
|
8
|
+
* https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12
|
|
9
|
+
*
|
|
10
|
+
* Unless required by applicable law or agreed to in writing, software
|
|
11
|
+
* distributed under the License is distributed on an "AS IS" basis,
|
|
12
|
+
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
13
|
+
* See the License for the specific language governing permissions and
|
|
14
|
+
* limitations under the License.
|
|
15
|
+
*/
|
|
16
|
+
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
17
|
+
import { FormControl, Validators } from '@angular/forms';
|
|
18
|
+
import { BehaviorSubject, combineLatest, map, startWith, Subject } from 'rxjs';
|
|
19
|
+
import { Upload16 } from '@carbon/icons';
|
|
20
|
+
import * as i0 from "@angular/core";
|
|
21
|
+
import * as i1 from "@angular/forms";
|
|
22
|
+
import * as i2 from "../../services";
|
|
23
|
+
import * as i3 from "carbon-components-angular";
|
|
24
|
+
import * as i4 from "carbon-components-angular/dropdown";
|
|
25
|
+
import * as i5 from "@angular/common";
|
|
26
|
+
import * as i6 from "@ngx-translate/core";
|
|
27
|
+
export class ImportPluginConfigurationComponent {
|
|
28
|
+
set pluginActionKey(value) {
|
|
29
|
+
this.importPluginForm.reset();
|
|
30
|
+
this.fetchCompatiblePluginProcessLinks(value);
|
|
31
|
+
}
|
|
32
|
+
get process() {
|
|
33
|
+
return this.importPluginForm.get('process');
|
|
34
|
+
}
|
|
35
|
+
get version() {
|
|
36
|
+
return this.importPluginForm.get('version');
|
|
37
|
+
}
|
|
38
|
+
get activity() {
|
|
39
|
+
return this.importPluginForm.get('activity');
|
|
40
|
+
}
|
|
41
|
+
constructor(formBuilder, processLinkService, iconService, elementRef) {
|
|
42
|
+
this.formBuilder = formBuilder;
|
|
43
|
+
this.processLinkService = processLinkService;
|
|
44
|
+
this.iconService = iconService;
|
|
45
|
+
this.elementRef = elementRef;
|
|
46
|
+
this.configurationEvent = new EventEmitter();
|
|
47
|
+
this.open$ = new Subject();
|
|
48
|
+
this._compatiblePluginProcessLinksSubject$ = new BehaviorSubject([]);
|
|
49
|
+
this.compatiblePluginProcessLinks$ = this._compatiblePluginProcessLinksSubject$.asObservable();
|
|
50
|
+
this.importPluginForm = this.formBuilder.group({
|
|
51
|
+
process: new FormControl('', Validators.required),
|
|
52
|
+
version: new FormControl('', Validators.required),
|
|
53
|
+
activity: new FormControl('', Validators.required),
|
|
54
|
+
});
|
|
55
|
+
this.processListItems$ = combineLatest([
|
|
56
|
+
this._compatiblePluginProcessLinksSubject$,
|
|
57
|
+
this.process.valueChanges.pipe(startWith('')),
|
|
58
|
+
]).pipe(map(([compatibleProcessLinks, processValue]) => compatibleProcessLinks?.map(compatibleProcessLink => ({
|
|
59
|
+
content: compatibleProcessLink.processDefinitionKey,
|
|
60
|
+
selected: processValue === compatibleProcessLink.processDefinitionKey,
|
|
61
|
+
})) || []));
|
|
62
|
+
this.versionListItems$ = combineLatest([
|
|
63
|
+
this._compatiblePluginProcessLinksSubject$,
|
|
64
|
+
this.process.valueChanges.pipe(startWith('')),
|
|
65
|
+
this.version.valueChanges.pipe(startWith('')),
|
|
66
|
+
]).pipe(map(([compatibleProcessLinks, processValue, versionValue]) => !processValue
|
|
67
|
+
? []
|
|
68
|
+
: compatibleProcessLinks
|
|
69
|
+
.find(compatibleLinks => compatibleLinks.processDefinitionKey === processValue)
|
|
70
|
+
?.versions.sort((a, b) => Number(b.version) - Number(a.version))
|
|
71
|
+
.map(versionItem => ({
|
|
72
|
+
content: versionItem.version,
|
|
73
|
+
selected: versionItem.version === versionValue,
|
|
74
|
+
})) || []));
|
|
75
|
+
this.activityListItems$ = combineLatest([
|
|
76
|
+
this._compatiblePluginProcessLinksSubject$,
|
|
77
|
+
this.process.valueChanges.pipe(startWith('')),
|
|
78
|
+
this.version.valueChanges.pipe(startWith('')),
|
|
79
|
+
this.activity.valueChanges.pipe(startWith('')),
|
|
80
|
+
]).pipe(map(([compatibleProcessLinks, processValue, versionValue, activityValue]) => !processValue || !versionValue
|
|
81
|
+
? []
|
|
82
|
+
: compatibleProcessLinks
|
|
83
|
+
.find(compatibleLinks => compatibleLinks.processDefinitionKey === processValue)
|
|
84
|
+
.versions.find(versionItem => versionItem.version === versionValue)
|
|
85
|
+
.processLinks.map(processLinkItem => ({
|
|
86
|
+
content: processLinkItem.activityId,
|
|
87
|
+
selected: processLinkItem.activityId === activityValue,
|
|
88
|
+
}))));
|
|
89
|
+
this.iconService.register(Upload16);
|
|
90
|
+
}
|
|
91
|
+
ngAfterViewInit() {
|
|
92
|
+
const button = this.elementRef.nativeElement.querySelector('button.cds--toggletip-button');
|
|
93
|
+
if (!button)
|
|
94
|
+
return;
|
|
95
|
+
button.classList.remove('cds--toggletip-button');
|
|
96
|
+
}
|
|
97
|
+
onSubmit() {
|
|
98
|
+
this.configurationEvent.emit(this._compatiblePluginProcessLinksSubject$
|
|
99
|
+
.getValue()
|
|
100
|
+
.find(compatiblePluginProcessLinks => compatiblePluginProcessLinks.processDefinitionKey === this.process.value)
|
|
101
|
+
.versions.find(versionItem => versionItem.version === this.version.value)
|
|
102
|
+
.processLinks.find(processLinkItem => processLinkItem.activityId === this.activity.value)
|
|
103
|
+
.actionProperties);
|
|
104
|
+
// needed to reliably trigger toggle tip closure
|
|
105
|
+
this.open$.next(true);
|
|
106
|
+
setTimeout(() => this.open$.next(false));
|
|
107
|
+
this.importPluginForm.reset();
|
|
108
|
+
}
|
|
109
|
+
fetchCompatiblePluginProcessLinks(pluginActionKey) {
|
|
110
|
+
this.processLinkService
|
|
111
|
+
.getCompatiblePluginProcessLinks(pluginActionKey)
|
|
112
|
+
.subscribe(res => this._compatiblePluginProcessLinksSubject$.next(res));
|
|
113
|
+
}
|
|
114
|
+
processSelected(event) {
|
|
115
|
+
this.process.setValue(event?.item?.content);
|
|
116
|
+
this.version.setValue('');
|
|
117
|
+
this.activity.setValue('');
|
|
118
|
+
}
|
|
119
|
+
versionSelected(event) {
|
|
120
|
+
this.version.setValue(event?.item?.content);
|
|
121
|
+
this.activity.setValue('');
|
|
122
|
+
}
|
|
123
|
+
activitySelected(event) {
|
|
124
|
+
this.activity.setValue(event?.item?.content);
|
|
125
|
+
}
|
|
126
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ImportPluginConfigurationComponent, deps: [{ token: i1.FormBuilder }, { token: i2.ProcessLinkService }, { token: i3.IconService }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
127
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: ImportPluginConfigurationComponent, selector: "valtimo-import-plugin-configuration", inputs: { pluginActionKey: "pluginActionKey" }, outputs: { configurationEvent: "configurationEvent" }, ngImport: i0, template: "<!--\n ~ Copyright 2015-2024 Ritense BV, the Netherlands.\n ~\n ~ Licensed under EUPL, Version 1.2 (the \"License\");\n ~ you may not use this file except in compliance with the License.\n ~ You may obtain a copy of the License at\n ~\n ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n ~\n ~ Unless required by applicable law or agreed to in writing, software\n ~ distributed under the License is distributed on an \"AS IS\" basis,\n ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n ~ See the License for the specific language governing permissions and\n ~ limitations under the License.\n -->\n\n<cds-toggletip align=\"right-bottom\" [autoAlign]=\"true\" [isOpen]=\"open$ | async\">\n <button\n class=\"process-link-configuration-import-button\"\n [disabled]=\"((compatiblePluginProcessLinks$ | async) || []).length === 0\"\n cdsToggletipButton\n cdsButton=\"ghost\"\n >\n {{ 'processLinkConfiguration.importConfiguration' | translate }}\n\n <svg class=\"cds--btn__icon\" cdsIcon=\"upload\" size=\"16\"></svg>\n </button>\n\n <div cdsToggletipContent data-carbon-theme=\"g90\" class=\"process-link-configuration-select\">\n <cds-dropdown\n [label]=\"'processLinkConfiguration.process' | translate\"\n [placeholder]=\"'processLinkConfiguration.selectProcess' | translate\"\n (selected)=\"processSelected($event)\"\n [appendInline]=\"true\"\n [cdsLayer]=\"1\"\n >\n <cds-dropdown-list\n [items]=\"processListItems$ | async\"\n onclick=\"event.stopPropagation()\"\n ></cds-dropdown-list>\n </cds-dropdown>\n\n <cds-dropdown\n [label]=\"'processLinkConfiguration.version' | translate\"\n [placeholder]=\"'processLinkConfiguration.selectVersion' | translate\"\n [disabled]=\"!process.value\"\n (selected)=\"versionSelected($event)\"\n [appendInline]=\"true\"\n [cdsLayer]=\"1\"\n >\n <cds-dropdown-list\n [items]=\"versionListItems$ | async\"\n onclick=\"event.stopPropagation()\"\n ></cds-dropdown-list>\n </cds-dropdown>\n\n <cds-dropdown\n [label]=\"'processLinkConfiguration.activity' | translate\"\n [placeholder]=\"'processLinkConfiguration.selectActivity' | translate\"\n [disabled]=\"!process.value || !version.value\"\n (selected)=\"activitySelected($event)\"\n [appendInline]=\"true\"\n [cdsLayer]=\"1\"\n >\n <cds-dropdown-list\n [items]=\"activityListItems$ | async\"\n onclick=\"event.stopPropagation()\"\n ></cds-dropdown-list>\n </cds-dropdown>\n\n <button cdsButton [disabled]=\"!importPluginForm.valid\" (click)=\"onSubmit()\" [cdsLayer]=\"1\">\n {{ 'processLinkConfiguration.importConfiguration' | translate }}\n </button>\n </div>\n</cds-toggletip>\n", styles: [":host ::ng-deep .cds--popover-content{max-inline-size:unset}.process-link-configuration-import-button{margin-bottom:16px}.process-link-configuration-select{width:400px;max-inline-size:400px;display:flex;flex-direction:column;gap:16px}.process-link-configuration-select .cds--btn{width:100%;max-width:unset}\n/*!\n * Copyright 2015-2024 Ritense BV, the Netherlands.\n *\n * Licensed under EUPL, Version 1.2 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" basis,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n"], dependencies: [{ kind: "directive", type: i3.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: "component", type: i4.Dropdown, selector: "cds-dropdown, ibm-dropdown", inputs: ["id", "label", "hideLabel", "helperText", "placeholder", "displayValue", "clearText", "size", "type", "theme", "disabled", "skeleton", "inline", "disableArrowKeys", "invalid", "invalidText", "warn", "warnText", "appendInline", "scrollableContainer", "itemValueKey", "selectionFeedback", "menuButtonLabel", "selectedLabel", "dropUp"], outputs: ["selected", "onClose", "close"] }, { kind: "component", type: i4.DropdownList, selector: "cds-dropdown-list, ibm-dropdown-list", inputs: ["ariaLabel", "items", "listTpl", "type", "showTitles"], outputs: ["select", "scroll", "blurIntent"] }, { kind: "directive", type: i3.LayerDirective, selector: "[cdsLayer], [ibmLayer]", inputs: ["ibmLayer", "cdsLayer"], exportAs: ["layer"] }, { kind: "component", type: i3.Toggletip, selector: "cds-toggletip, ibm-toggletip", inputs: ["id", "isOpen"] }, { kind: "directive", type: i3.ToggletipButton, selector: "[cdsToggletipButton], [ibmToggletipButton]", inputs: ["ariaLabel"] }, { kind: "directive", type: i3.ToggletipContent, selector: "[cdsToggletipContent], [ibmToggletipContent]" }, { kind: "pipe", type: i5.AsyncPipe, name: "async" }, { kind: "pipe", type: i6.TranslatePipe, name: "translate" }] }); }
|
|
128
|
+
}
|
|
129
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ImportPluginConfigurationComponent, decorators: [{
|
|
130
|
+
type: Component,
|
|
131
|
+
args: [{ selector: 'valtimo-import-plugin-configuration', template: "<!--\n ~ Copyright 2015-2024 Ritense BV, the Netherlands.\n ~\n ~ Licensed under EUPL, Version 1.2 (the \"License\");\n ~ you may not use this file except in compliance with the License.\n ~ You may obtain a copy of the License at\n ~\n ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n ~\n ~ Unless required by applicable law or agreed to in writing, software\n ~ distributed under the License is distributed on an \"AS IS\" basis,\n ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n ~ See the License for the specific language governing permissions and\n ~ limitations under the License.\n -->\n\n<cds-toggletip align=\"right-bottom\" [autoAlign]=\"true\" [isOpen]=\"open$ | async\">\n <button\n class=\"process-link-configuration-import-button\"\n [disabled]=\"((compatiblePluginProcessLinks$ | async) || []).length === 0\"\n cdsToggletipButton\n cdsButton=\"ghost\"\n >\n {{ 'processLinkConfiguration.importConfiguration' | translate }}\n\n <svg class=\"cds--btn__icon\" cdsIcon=\"upload\" size=\"16\"></svg>\n </button>\n\n <div cdsToggletipContent data-carbon-theme=\"g90\" class=\"process-link-configuration-select\">\n <cds-dropdown\n [label]=\"'processLinkConfiguration.process' | translate\"\n [placeholder]=\"'processLinkConfiguration.selectProcess' | translate\"\n (selected)=\"processSelected($event)\"\n [appendInline]=\"true\"\n [cdsLayer]=\"1\"\n >\n <cds-dropdown-list\n [items]=\"processListItems$ | async\"\n onclick=\"event.stopPropagation()\"\n ></cds-dropdown-list>\n </cds-dropdown>\n\n <cds-dropdown\n [label]=\"'processLinkConfiguration.version' | translate\"\n [placeholder]=\"'processLinkConfiguration.selectVersion' | translate\"\n [disabled]=\"!process.value\"\n (selected)=\"versionSelected($event)\"\n [appendInline]=\"true\"\n [cdsLayer]=\"1\"\n >\n <cds-dropdown-list\n [items]=\"versionListItems$ | async\"\n onclick=\"event.stopPropagation()\"\n ></cds-dropdown-list>\n </cds-dropdown>\n\n <cds-dropdown\n [label]=\"'processLinkConfiguration.activity' | translate\"\n [placeholder]=\"'processLinkConfiguration.selectActivity' | translate\"\n [disabled]=\"!process.value || !version.value\"\n (selected)=\"activitySelected($event)\"\n [appendInline]=\"true\"\n [cdsLayer]=\"1\"\n >\n <cds-dropdown-list\n [items]=\"activityListItems$ | async\"\n onclick=\"event.stopPropagation()\"\n ></cds-dropdown-list>\n </cds-dropdown>\n\n <button cdsButton [disabled]=\"!importPluginForm.valid\" (click)=\"onSubmit()\" [cdsLayer]=\"1\">\n {{ 'processLinkConfiguration.importConfiguration' | translate }}\n </button>\n </div>\n</cds-toggletip>\n", styles: [":host ::ng-deep .cds--popover-content{max-inline-size:unset}.process-link-configuration-import-button{margin-bottom:16px}.process-link-configuration-select{width:400px;max-inline-size:400px;display:flex;flex-direction:column;gap:16px}.process-link-configuration-select .cds--btn{width:100%;max-width:unset}\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"] }]
|
|
132
|
+
}], ctorParameters: () => [{ type: i1.FormBuilder }, { type: i2.ProcessLinkService }, { type: i3.IconService }, { type: i0.ElementRef }], propDecorators: { pluginActionKey: [{
|
|
133
|
+
type: Input
|
|
134
|
+
}], configurationEvent: [{
|
|
135
|
+
type: Output
|
|
136
|
+
}] } });
|
|
137
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"import-plugin-configuration.component.js","sourceRoot":"","sources":["../../../../../../../projects/valtimo/process-link/src/lib/components/import-plugin-configuration/import-plugin-configuration.component.ts","../../../../../../../projects/valtimo/process-link/src/lib/components/import-plugin-configuration/import-plugin-configuration.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 {AfterViewInit, Component, ElementRef, EventEmitter, Input, Output} from '@angular/core';\nimport {AbstractControl, FormBuilder, FormControl, Validators} from '@angular/forms';\nimport {BehaviorSubject, combineLatest, map, Observable, startWith, Subject} from 'rxjs';\nimport {CompatiblePluginProcessLinks, ProcessLink} from '../../models';\nimport {ProcessLinkService} from '../../services';\nimport {IconService, ListItem} from 'carbon-components-angular';\nimport {Upload16} from '@carbon/icons';\n\n@Component({\n  selector: 'valtimo-import-plugin-configuration',\n  templateUrl: './import-plugin-configuration.component.html',\n  styleUrls: ['./import-plugin-configuration.component.scss'],\n})\nexport class ImportPluginConfigurationComponent implements AfterViewInit {\n  @Input() public set pluginActionKey(value: string) {\n    this.importPluginForm.reset();\n    this.fetchCompatiblePluginProcessLinks(value);\n  }\n\n  @Output() public readonly configurationEvent = new EventEmitter<\n    ProcessLink['actionProperties']\n  >();\n\n  public readonly open$ = new Subject<boolean>();\n\n  private readonly _compatiblePluginProcessLinksSubject$ = new BehaviorSubject<\n    CompatiblePluginProcessLinks[]\n  >([]);\n\n  public readonly compatiblePluginProcessLinks$ =\n    this._compatiblePluginProcessLinksSubject$.asObservable();\n\n  public readonly importPluginForm = this.formBuilder.group({\n    process: new FormControl('', Validators.required),\n    version: new FormControl('', Validators.required),\n    activity: new FormControl('', Validators.required),\n  });\n\n  public get process(): AbstractControl<string> {\n    return this.importPluginForm.get('process');\n  }\n\n  public readonly processListItems$: Observable<ListItem[]> = combineLatest([\n    this._compatiblePluginProcessLinksSubject$,\n    this.process.valueChanges.pipe(startWith('')),\n  ]).pipe(\n    map(\n      ([compatibleProcessLinks, processValue]) =>\n        compatibleProcessLinks?.map(compatibleProcessLink => ({\n          content: compatibleProcessLink.processDefinitionKey,\n          selected: processValue === compatibleProcessLink.processDefinitionKey,\n        })) || []\n    )\n  );\n\n  public get version(): AbstractControl<string> {\n    return this.importPluginForm.get('version');\n  }\n\n  public readonly versionListItems$: Observable<ListItem[]> = combineLatest([\n    this._compatiblePluginProcessLinksSubject$,\n    this.process.valueChanges.pipe(startWith('')),\n    this.version.valueChanges.pipe(startWith('')),\n  ]).pipe(\n    map(([compatibleProcessLinks, processValue, versionValue]) =>\n      !processValue\n        ? []\n        : compatibleProcessLinks\n            .find(compatibleLinks => compatibleLinks.processDefinitionKey === processValue)\n            ?.versions.sort((a, b) => Number(b.version) - Number(a.version))\n            .map(versionItem => ({\n              content: versionItem.version,\n              selected: versionItem.version === versionValue,\n            })) || []\n    )\n  );\n\n  public get activity(): AbstractControl<string> {\n    return this.importPluginForm.get('activity');\n  }\n\n  public readonly activityListItems$: Observable<ListItem[]> = combineLatest([\n    this._compatiblePluginProcessLinksSubject$,\n    this.process.valueChanges.pipe(startWith('')),\n    this.version.valueChanges.pipe(startWith('')),\n    this.activity.valueChanges.pipe(startWith('')),\n  ]).pipe(\n    map(([compatibleProcessLinks, processValue, versionValue, activityValue]) =>\n      !processValue || !versionValue\n        ? []\n        : compatibleProcessLinks\n            .find(compatibleLinks => compatibleLinks.processDefinitionKey === processValue)\n            .versions.find(versionItem => versionItem.version === versionValue)\n            .processLinks.map(processLinkItem => ({\n              content: processLinkItem.activityId,\n              selected: processLinkItem.activityId === activityValue,\n            }))\n    )\n  );\n\n  constructor(\n    private readonly formBuilder: FormBuilder,\n    private readonly processLinkService: ProcessLinkService,\n    private readonly iconService: IconService,\n    private readonly elementRef: ElementRef<HTMLElement>\n  ) {\n    this.iconService.register(Upload16);\n  }\n\n  public ngAfterViewInit(): void {\n    const button = this.elementRef.nativeElement.querySelector('button.cds--toggletip-button');\n    if (!button) return;\n    button.classList.remove('cds--toggletip-button');\n  }\n\n  public onSubmit(): void {\n    this.configurationEvent.emit(\n      this._compatiblePluginProcessLinksSubject$\n        .getValue()\n        .find(\n          compatiblePluginProcessLinks =>\n            compatiblePluginProcessLinks.processDefinitionKey === this.process.value\n        )\n        .versions.find(versionItem => versionItem.version === this.version.value)\n        .processLinks.find(processLinkItem => processLinkItem.activityId === this.activity.value)\n        .actionProperties\n    );\n\n    // needed to reliably trigger toggle tip closure\n    this.open$.next(true);\n    setTimeout(() => this.open$.next(false));\n\n    this.importPluginForm.reset();\n  }\n\n  private fetchCompatiblePluginProcessLinks(pluginActionKey: string): void {\n    this.processLinkService\n      .getCompatiblePluginProcessLinks(pluginActionKey)\n      .subscribe(res => this._compatiblePluginProcessLinksSubject$.next(res));\n  }\n\n  public processSelected(event: {item: ListItem}): void {\n    this.process.setValue(event?.item?.content);\n    this.version.setValue('');\n    this.activity.setValue('');\n  }\n\n  public versionSelected(event: {item: ListItem}): void {\n    this.version.setValue(event?.item?.content);\n    this.activity.setValue('');\n  }\n\n  public activitySelected(event: {item: ListItem}): void {\n    this.activity.setValue(event?.item?.content);\n  }\n}\n","<!--\n  ~ Copyright 2015-2024 Ritense BV, the Netherlands.\n  ~\n  ~ Licensed under EUPL, Version 1.2 (the \"License\");\n  ~ you may not use this file except in compliance with the License.\n  ~ You may obtain a copy of the License at\n  ~\n  ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n  ~\n  ~ Unless required by applicable law or agreed to in writing, software\n  ~ distributed under the License is distributed on an \"AS IS\" basis,\n  ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n  ~ See the License for the specific language governing permissions and\n  ~ limitations under the License.\n  -->\n\n<cds-toggletip align=\"right-bottom\" [autoAlign]=\"true\" [isOpen]=\"open$ | async\">\n  <button\n    class=\"process-link-configuration-import-button\"\n    [disabled]=\"((compatiblePluginProcessLinks$ | async) || []).length === 0\"\n    cdsToggletipButton\n    cdsButton=\"ghost\"\n  >\n    {{ 'processLinkConfiguration.importConfiguration' | translate }}\n\n    <svg class=\"cds--btn__icon\" cdsIcon=\"upload\" size=\"16\"></svg>\n  </button>\n\n  <div cdsToggletipContent data-carbon-theme=\"g90\" class=\"process-link-configuration-select\">\n    <cds-dropdown\n      [label]=\"'processLinkConfiguration.process' | translate\"\n      [placeholder]=\"'processLinkConfiguration.selectProcess' | translate\"\n      (selected)=\"processSelected($event)\"\n      [appendInline]=\"true\"\n      [cdsLayer]=\"1\"\n    >\n      <cds-dropdown-list\n        [items]=\"processListItems$ | async\"\n        onclick=\"event.stopPropagation()\"\n      ></cds-dropdown-list>\n    </cds-dropdown>\n\n    <cds-dropdown\n      [label]=\"'processLinkConfiguration.version' | translate\"\n      [placeholder]=\"'processLinkConfiguration.selectVersion' | translate\"\n      [disabled]=\"!process.value\"\n      (selected)=\"versionSelected($event)\"\n      [appendInline]=\"true\"\n      [cdsLayer]=\"1\"\n    >\n      <cds-dropdown-list\n        [items]=\"versionListItems$ | async\"\n        onclick=\"event.stopPropagation()\"\n      ></cds-dropdown-list>\n    </cds-dropdown>\n\n    <cds-dropdown\n      [label]=\"'processLinkConfiguration.activity' | translate\"\n      [placeholder]=\"'processLinkConfiguration.selectActivity' | translate\"\n      [disabled]=\"!process.value || !version.value\"\n      (selected)=\"activitySelected($event)\"\n      [appendInline]=\"true\"\n      [cdsLayer]=\"1\"\n    >\n      <cds-dropdown-list\n        [items]=\"activityListItems$ | async\"\n        onclick=\"event.stopPropagation()\"\n      ></cds-dropdown-list>\n    </cds-dropdown>\n\n    <button cdsButton [disabled]=\"!importPluginForm.valid\" (click)=\"onSubmit()\" [cdsLayer]=\"1\">\n      {{ 'processLinkConfiguration.importConfiguration' | translate }}\n    </button>\n  </div>\n</cds-toggletip>\n"]}
|