@valtimo/process-link 12.5.1 → 12.6.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 (37) hide show
  1. package/esm2022/lib/components/form-display-configuration/form-display-configuration.component.mjs +15 -5
  2. package/esm2022/lib/components/plugin-action-configuration/plugin-action-configuration.component.mjs +7 -5
  3. package/esm2022/lib/components/process-link-modal/process-link-modal.component.mjs +8 -6
  4. package/esm2022/lib/components/select-form/select-form.component.mjs +16 -10
  5. package/esm2022/lib/components/select-form-flow/select-form-flow.component.mjs +14 -9
  6. package/esm2022/lib/components/select-plugin-action/select-plugin-action.component.mjs +7 -8
  7. package/esm2022/lib/components/select-url/select-url.component.mjs +13 -22
  8. package/esm2022/lib/models/process-link.model.mjs +1 -1
  9. package/esm2022/lib/process-link.module.mjs +9 -12
  10. package/esm2022/lib/services/process-link-state.service.mjs +2 -2
  11. package/esm2022/lib/services/process-link.service.mjs +20 -19
  12. package/esm2022/lib/services/url-resolver.service.mjs +1 -1
  13. package/esm2022/lib/services/url-validator.service.mjs +1 -1
  14. package/fesm2022/valtimo-process-link.mjs +115 -103
  15. package/fesm2022/valtimo-process-link.mjs.map +1 -1
  16. package/lib/components/form-display-configuration/form-display-configuration.component.d.ts +9 -4
  17. package/lib/components/form-display-configuration/form-display-configuration.component.d.ts.map +1 -1
  18. package/lib/components/plugin-action-configuration/plugin-action-configuration.component.d.ts +9 -7
  19. package/lib/components/plugin-action-configuration/plugin-action-configuration.component.d.ts.map +1 -1
  20. package/lib/components/process-link-modal/process-link-modal.component.d.ts +4 -2
  21. package/lib/components/process-link-modal/process-link-modal.component.d.ts.map +1 -1
  22. package/lib/components/select-form/select-form.component.d.ts +5 -3
  23. package/lib/components/select-form/select-form.component.d.ts.map +1 -1
  24. package/lib/components/select-form-flow/select-form-flow.component.d.ts +4 -2
  25. package/lib/components/select-form-flow/select-form-flow.component.d.ts.map +1 -1
  26. package/lib/components/select-plugin-action/select-plugin-action.component.d.ts +1 -2
  27. package/lib/components/select-plugin-action/select-plugin-action.component.d.ts.map +1 -1
  28. package/lib/components/select-url/select-url.component.d.ts.map +1 -1
  29. package/lib/models/process-link.model.d.ts +25 -1
  30. package/lib/models/process-link.model.d.ts.map +1 -1
  31. package/lib/process-link.module.d.ts +1 -1
  32. package/lib/process-link.module.d.ts.map +1 -1
  33. package/lib/services/process-link.service.d.ts +4 -2
  34. package/lib/services/process-link.service.d.ts.map +1 -1
  35. package/lib/services/url-resolver.service.d.ts.map +1 -1
  36. package/lib/services/url-validator.service.d.ts.map +1 -1
  37. package/package.json +1 -1
@@ -34,6 +34,7 @@ export class SelectFormComponent {
34
34
  this.buttonService = buttonService;
35
35
  this.formDisplayValue = '';
36
36
  this.formSizeValue = '';
37
+ this.subtitlesValue = [];
37
38
  this.saving$ = this.stateService.saving$;
38
39
  this.formDefinitions$ = this.formService.getAllFormDefinitions();
39
40
  this.formDefinitionListItems$ = combineLatest([this.stateService.selectedProcessLink$, this.formDefinitions$]).pipe(map(([selectedProcessLink, formDefinitions]) => formDefinitions.map(definition => ({
@@ -50,7 +51,7 @@ export class SelectFormComponent {
50
51
  }));
51
52
  this._subscriptions = new Subscription();
52
53
  this.isUserTask$ = new BehaviorSubject(false);
53
- this.taskPanelToggle = this.configService.featureToggles?.enableTaskPanel;
54
+ this._taskPanelToggle = this.configService.featureToggles?.enableTaskPanel;
54
55
  }
55
56
  ngOnInit() {
56
57
  this.openBackButtonSubscription();
@@ -81,6 +82,9 @@ export class SelectFormComponent {
81
82
  selectedFormSizeValue(formSize) {
82
83
  this.formSizeValue = formSize;
83
84
  }
85
+ selectedSubtitlesValue(subtitles) {
86
+ this.subtitlesValue = subtitles;
87
+ }
84
88
  openBackButtonSubscription() {
85
89
  this._subscriptions.add(this.buttonService.backButtonClick$.subscribe(() => {
86
90
  this.stateService.setInitial();
@@ -114,11 +118,12 @@ export class SelectFormComponent {
114
118
  id: selectedProcessLink.id,
115
119
  formDefinitionId: this.selectedFormDefinition.id,
116
120
  viewModelEnabled,
117
- ...(this.taskPanelToggle &&
121
+ ...(this._taskPanelToggle &&
118
122
  isUserTask && {
119
123
  formDisplayType: this.formDisplayValue,
120
124
  }),
121
- ...(this.taskPanelToggle && isUserTask && { formSize: this.formSizeValue }),
125
+ ...(this._taskPanelToggle && isUserTask && { formSize: this.formSizeValue }),
126
+ ...(isUserTask && { subtitles: this.subtitlesValue }),
122
127
  };
123
128
  this.processLinkService.updateProcessLink(updateProcessLinkRequest).subscribe(() => {
124
129
  this.stateService.closeModal();
@@ -141,14 +146,15 @@ export class SelectFormComponent {
141
146
  processLinkType: processLinkTypeId,
142
147
  activityId: modalParams.element.id,
143
148
  viewModelEnabled,
144
- ...(this.taskPanelToggle &&
145
- isUserTask && {
149
+ ...(isUserTask && {
146
150
  formDisplayType: this.formDisplayValue,
147
151
  }),
148
- ...(this.taskPanelToggle &&
149
- isUserTask && {
152
+ ...(isUserTask && {
150
153
  formSize: this.formSizeValue,
151
154
  }),
155
+ ...(isUserTask && {
156
+ subtitles: this.subtitlesValue,
157
+ }),
152
158
  })))
153
159
  .subscribe(() => {
154
160
  this.stateService.closeModal();
@@ -157,10 +163,10 @@ export class SelectFormComponent {
157
163
  });
158
164
  }
159
165
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: SelectFormComponent, deps: [{ token: i1.ConfigService }, { token: i2.FormService }, { token: i3.ProcessLinkStateService }, { token: i3.ProcessLinkService }, { token: i3.ProcessLinkButtonService }], target: i0.ɵɵFactoryTarget.Component }); }
160
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: SelectFormComponent, selector: "valtimo-select-form", 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 formDefinitions: formDefinitionListItems$ | async,\n saving: saving$ | async,\n } as obs\"\n>\n <p class=\"step-description\">\n {{ 'processLinkConfiguration.chooseFormDescription' | translate }}\n </p>\n <div class=\"select-form\">\n <cds-combo-box\n [appendInline]=\"true\"\n [disabled]=\"!obs.formDefinitions || obs.saving\"\n [items]=\"obs.formDefinitions || []\"\n [placeholder]=\"'interface.typeToSearch' | translate\"\n (selected)=\"selectFormDefinition($event)\"\n [label]=\"'processLinkSteps.selectForm' | translate\"\n ><cds-dropdown-list></cds-dropdown-list\n ></cds-combo-box>\n <br />\n\n <valtimo-form-display-configuration\n [selectedFormDefinition]=\"selectedFormDefinition\"\n (formDisplayValue)=\"selectedFormDisplayValue($event)\"\n (formSizeValue)=\"selectedFormSizeValue($event)\"\n ></valtimo-form-display-configuration>\n </div>\n</ng-container>\n", styles: [".label-with-tooltip{display:flex;align-items:center}.select-form{display:flex;flex-direction:column;width:100%;margin-top:24px}\n/*!\n * Copyright 2015-2024 Ritense BV, the Netherlands.\n *\n * Licensed under EUPL, Version 1.2 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" basis,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n"], 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.FormDisplayConfigurationComponent, selector: "valtimo-form-display-configuration", inputs: ["selectedFormDefinition"], outputs: ["formDisplayValue", "formSizeValue"] }, { kind: "pipe", type: i4.AsyncPipe, name: "async" }, { kind: "pipe", type: i8.TranslatePipe, name: "translate" }] }); }
166
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: SelectFormComponent, selector: "valtimo-select-form", 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 formDefinitions: formDefinitionListItems$ | async,\n saving: saving$ | async,\n } as obs\"\n>\n <p class=\"step-description\">\n {{ 'processLinkConfiguration.chooseFormDescription' | translate }}\n </p>\n <div class=\"select-form\">\n <cds-combo-box\n [appendInline]=\"true\"\n [disabled]=\"!obs.formDefinitions || obs.saving\"\n [items]=\"obs.formDefinitions || []\"\n [placeholder]=\"'interface.typeToSearch' | translate\"\n (selected)=\"selectFormDefinition($event)\"\n [label]=\"'processLinkSteps.selectForm' | translate\"\n ><cds-dropdown-list></cds-dropdown-list\n ></cds-combo-box>\n <br />\n\n <valtimo-form-display-configuration\n [selectedFormDefinition]=\"selectedFormDefinition\"\n (formDisplayValue)=\"selectedFormDisplayValue($event)\"\n (formSizeValue)=\"selectedFormSizeValue($event)\"\n (subtitlesValue)=\"selectedSubtitlesValue($event)\"\n ></valtimo-form-display-configuration>\n </div>\n</ng-container>\n", styles: [".label-with-tooltip{display:flex;align-items:center}.select-form{display:flex;flex-direction:column;width:100%;margin-top:24px}\n/*!\n * Copyright 2015-2024 Ritense BV, the Netherlands.\n *\n * Licensed under EUPL, Version 1.2 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" basis,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n"], 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.FormDisplayConfigurationComponent, selector: "valtimo-form-display-configuration", inputs: ["selectedFormDefinition"], outputs: ["formDisplayValue", "formSizeValue", "subtitlesValue"] }, { kind: "pipe", type: i4.AsyncPipe, name: "async" }, { kind: "pipe", type: i8.TranslatePipe, name: "translate" }] }); }
161
167
  }
162
168
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: SelectFormComponent, decorators: [{
163
169
  type: Component,
164
- args: [{ selector: 'valtimo-select-form', template: "<!--\n ~ Copyright 2015-2024 Ritense BV, the Netherlands.\n ~\n ~ Licensed under EUPL, Version 1.2 (the \"License\");\n ~ you may not use this file except in compliance with the License.\n ~ You may obtain a copy of the License at\n ~\n ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n ~\n ~ Unless required by applicable law or agreed to in writing, software\n ~ distributed under the License is distributed on an \"AS IS\" basis,\n ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n ~ See the License for the specific language governing permissions and\n ~ limitations under the License.\n -->\n\n<ng-container\n *ngIf=\"{\n formDefinitions: formDefinitionListItems$ | async,\n saving: saving$ | async,\n } as obs\"\n>\n <p class=\"step-description\">\n {{ 'processLinkConfiguration.chooseFormDescription' | translate }}\n </p>\n <div class=\"select-form\">\n <cds-combo-box\n [appendInline]=\"true\"\n [disabled]=\"!obs.formDefinitions || obs.saving\"\n [items]=\"obs.formDefinitions || []\"\n [placeholder]=\"'interface.typeToSearch' | translate\"\n (selected)=\"selectFormDefinition($event)\"\n [label]=\"'processLinkSteps.selectForm' | translate\"\n ><cds-dropdown-list></cds-dropdown-list\n ></cds-combo-box>\n <br />\n\n <valtimo-form-display-configuration\n [selectedFormDefinition]=\"selectedFormDefinition\"\n (formDisplayValue)=\"selectedFormDisplayValue($event)\"\n (formSizeValue)=\"selectedFormSizeValue($event)\"\n ></valtimo-form-display-configuration>\n </div>\n</ng-container>\n", styles: [".label-with-tooltip{display:flex;align-items:center}.select-form{display:flex;flex-direction:column;width:100%;margin-top:24px}\n/*!\n * Copyright 2015-2024 Ritense BV, the Netherlands.\n *\n * Licensed under EUPL, Version 1.2 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" basis,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n"] }]
170
+ args: [{ selector: 'valtimo-select-form', template: "<!--\n ~ Copyright 2015-2024 Ritense BV, the Netherlands.\n ~\n ~ Licensed under EUPL, Version 1.2 (the \"License\");\n ~ you may not use this file except in compliance with the License.\n ~ You may obtain a copy of the License at\n ~\n ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n ~\n ~ Unless required by applicable law or agreed to in writing, software\n ~ distributed under the License is distributed on an \"AS IS\" basis,\n ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n ~ See the License for the specific language governing permissions and\n ~ limitations under the License.\n -->\n\n<ng-container\n *ngIf=\"{\n formDefinitions: formDefinitionListItems$ | async,\n saving: saving$ | async,\n } as obs\"\n>\n <p class=\"step-description\">\n {{ 'processLinkConfiguration.chooseFormDescription' | translate }}\n </p>\n <div class=\"select-form\">\n <cds-combo-box\n [appendInline]=\"true\"\n [disabled]=\"!obs.formDefinitions || obs.saving\"\n [items]=\"obs.formDefinitions || []\"\n [placeholder]=\"'interface.typeToSearch' | translate\"\n (selected)=\"selectFormDefinition($event)\"\n [label]=\"'processLinkSteps.selectForm' | translate\"\n ><cds-dropdown-list></cds-dropdown-list\n ></cds-combo-box>\n <br />\n\n <valtimo-form-display-configuration\n [selectedFormDefinition]=\"selectedFormDefinition\"\n (formDisplayValue)=\"selectedFormDisplayValue($event)\"\n (formSizeValue)=\"selectedFormSizeValue($event)\"\n (subtitlesValue)=\"selectedSubtitlesValue($event)\"\n ></valtimo-form-display-configuration>\n </div>\n</ng-container>\n", styles: [".label-with-tooltip{display:flex;align-items:center}.select-form{display:flex;flex-direction:column;width:100%;margin-top:24px}\n/*!\n * Copyright 2015-2024 Ritense BV, the Netherlands.\n *\n * Licensed under EUPL, Version 1.2 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" basis,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n"] }]
165
171
  }], ctorParameters: () => [{ type: i1.ConfigService }, { type: i2.FormService }, { type: i3.ProcessLinkStateService }, { type: i3.ProcessLinkService }, { type: i3.ProcessLinkButtonService }] });
166
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select-form.component.js","sourceRoot":"","sources":["../../../../../../../projects/valtimo/process-link/src/lib/components/select-form/select-form.component.ts","../../../../../../../projects/valtimo/process-link/src/lib/components/select-form/select-form.component.html"],"names":[],"mappings":"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","sourcesContent":["/*\n * Copyright 2015-2024 Ritense BV, the Netherlands.\n *\n * Licensed under EUPL, Version 1.2 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" basis,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport {Component, OnDestroy, OnInit} from '@angular/core';\nimport {FormService} from '@valtimo/form';\nimport {BehaviorSubject, combineLatest, map, Observable, Subscription, switchMap, tap} from 'rxjs';\nimport {\n  ProcessLinkButtonService,\n  ProcessLinkService,\n  ProcessLinkStateService,\n} from '../../services';\nimport {FormDefinitionListItem, FormProcessLinkUpdateRequestDto} from '../../models';\nimport {take} from 'rxjs/operators';\nimport {ConfigService} from '@valtimo/config';\n\n@Component({\n  selector: 'valtimo-select-form',\n  templateUrl: './select-form.component.html',\n  styleUrls: ['./select-form.component.scss'],\n})\nexport class SelectFormComponent implements OnInit, OnDestroy {\n  public formDisplayValue: string = '';\n  public formSizeValue: string = '';\n  public selectedFormDefinition!: FormDefinitionListItem;\n\n  public readonly saving$ = this.stateService.saving$;\n  private readonly formDefinitions$ = this.formService.getAllFormDefinitions();\n  public readonly formDefinitionListItems$: Observable<Array<FormDefinitionListItem>> =\n    combineLatest([this.stateService.selectedProcessLink$, this.formDefinitions$]).pipe(\n      map(([selectedProcessLink, formDefinitions]) =>\n        formDefinitions.map(definition => ({\n          content: definition.name,\n          id: definition.id,\n          selected: selectedProcessLink\n            ? selectedProcessLink.formDefinitionId === definition.id\n            : false,\n        }))\n      ),\n      tap(formDefinitionListItems => {\n        const selectedItem = formDefinitionListItems.find(item => item.selected);\n\n        if (selectedItem) {\n          this.selectFormDefinition(selectedItem);\n        }\n      })\n    );\n\n  private _subscriptions = new Subscription();\n  private isUserTask$ = new BehaviorSubject<boolean>(false);\n  private readonly taskPanelToggle = this.configService.featureToggles?.enableTaskPanel;\n\n  constructor(\n    private readonly configService: ConfigService,\n    private readonly formService: FormService,\n    private readonly stateService: ProcessLinkStateService,\n    private readonly processLinkService: ProcessLinkService,\n    private readonly buttonService: ProcessLinkButtonService\n  ) {}\n\n  public ngOnInit(): void {\n    this.openBackButtonSubscription();\n    this.openSaveButtonSubscription();\n    this._subscriptions.add(\n      combineLatest([\n        this.stateService.selectedProcessLink$,\n        this.stateService.modalParams$,\n      ]).subscribe(([selectedProcessLink, modalParams]) => {\n        if (selectedProcessLink) {\n          this.formDisplayValue = selectedProcessLink.formDisplayType;\n          this.formSizeValue = selectedProcessLink.formSize;\n        }\n\n        this.isUserTask$.next(modalParams?.element?.type === 'bpmn:UserTask');\n      })\n    );\n  }\n\n  public ngOnDestroy(): void {\n    this._subscriptions.unsubscribe();\n  }\n\n  public selectFormDefinition(formDefinition: FormDefinitionListItem): void {\n    this.selectedFormDefinition = formDefinition?.id ? formDefinition : null;\n\n    this.selectedFormDefinition\n      ? this.buttonService.enableSaveButton()\n      : this.buttonService.disableSaveButton();\n  }\n\n  public selectedFormDisplayValue(formDisplay: string): void {\n    this.formDisplayValue = formDisplay;\n  }\n\n  public selectedFormSizeValue(formSize: string): void {\n    this.formSizeValue = formSize;\n  }\n\n  private openBackButtonSubscription(): void {\n    this._subscriptions.add(\n      this.buttonService.backButtonClick$.subscribe(() => {\n        this.stateService.setInitial();\n      })\n    );\n  }\n\n  private openSaveButtonSubscription(): void {\n    this._subscriptions.add(\n      this.buttonService.saveButtonClick$.subscribe(() => {\n        this.stateService.startSaving();\n        this.saveProcessLink();\n      })\n    );\n  }\n\n  private saveProcessLink(): void {\n    this.stateService.selectedProcessLink$.pipe(take(1)).subscribe(selectedProcessLink => {\n      if (selectedProcessLink) {\n        this.updateProcessLink();\n      } else {\n        this.saveNewProcessLink();\n      }\n    });\n  }\n\n  private updateProcessLink(): void {\n    combineLatest([\n      this.stateService.selectedProcessLink$,\n      this.stateService.viewModelEnabled$,\n      this.isUserTask$,\n    ])\n      .pipe(take(1))\n      .subscribe(([selectedProcessLink, viewModelEnabled, isUserTask]) => {\n        const updateProcessLinkRequest: FormProcessLinkUpdateRequestDto = {\n          id: selectedProcessLink.id,\n          formDefinitionId: this.selectedFormDefinition.id,\n          viewModelEnabled,\n          ...(this.taskPanelToggle &&\n            isUserTask && {\n              formDisplayType: this.formDisplayValue,\n            }),\n          ...(this.taskPanelToggle && isUserTask && {formSize: this.formSizeValue}),\n        };\n\n        this.processLinkService.updateProcessLink(updateProcessLinkRequest).subscribe(\n          () => {\n            this.stateService.closeModal();\n          },\n          () => {\n            this.stateService.stopSaving();\n          }\n        );\n      });\n  }\n\n  private saveNewProcessLink(): void {\n    combineLatest([\n      this.stateService.modalParams$,\n      this.stateService.selectedProcessLinkTypeId$,\n      this.stateService.viewModelEnabled$,\n      this.isUserTask$,\n    ])\n      .pipe(\n        take(1),\n        switchMap(([modalParams, processLinkTypeId, viewModelEnabled, isUserTask]) =>\n          this.processLinkService.saveProcessLink({\n            formDefinitionId: this.selectedFormDefinition.id,\n            activityType: modalParams.element.activityListenerType,\n            processDefinitionId: modalParams.processDefinitionId,\n            processLinkType: processLinkTypeId,\n            activityId: modalParams.element.id,\n            viewModelEnabled,\n            ...(this.taskPanelToggle &&\n              isUserTask && {\n                formDisplayType: this.formDisplayValue,\n              }),\n            ...(this.taskPanelToggle &&\n              isUserTask && {\n                formSize: this.formSizeValue,\n              }),\n          })\n        )\n      )\n      .subscribe(\n        () => {\n          this.stateService.closeModal();\n        },\n        () => {\n          this.stateService.stopSaving();\n        }\n      );\n  }\n}\n","<!--\n  ~ Copyright 2015-2024 Ritense BV, the Netherlands.\n  ~\n  ~ Licensed under EUPL, Version 1.2 (the \"License\");\n  ~ you may not use this file except in compliance with the License.\n  ~ You may obtain a copy of the License at\n  ~\n  ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n  ~\n  ~ Unless required by applicable law or agreed to in writing, software\n  ~ distributed under the License is distributed on an \"AS IS\" basis,\n  ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n  ~ See the License for the specific language governing permissions and\n  ~ limitations under the License.\n  -->\n\n<ng-container\n  *ngIf=\"{\n    formDefinitions: formDefinitionListItems$ | async,\n    saving: saving$ | async,\n  } as obs\"\n>\n  <p class=\"step-description\">\n    {{ 'processLinkConfiguration.chooseFormDescription' | translate }}\n  </p>\n  <div class=\"select-form\">\n    <cds-combo-box\n      [appendInline]=\"true\"\n      [disabled]=\"!obs.formDefinitions || obs.saving\"\n      [items]=\"obs.formDefinitions || []\"\n      [placeholder]=\"'interface.typeToSearch' | translate\"\n      (selected)=\"selectFormDefinition($event)\"\n      [label]=\"'processLinkSteps.selectForm' | translate\"\n      ><cds-dropdown-list></cds-dropdown-list\n    ></cds-combo-box>\n    <br />\n\n    <valtimo-form-display-configuration\n      [selectedFormDefinition]=\"selectedFormDefinition\"\n      (formDisplayValue)=\"selectedFormDisplayValue($event)\"\n      (formSizeValue)=\"selectedFormSizeValue($event)\"\n    ></valtimo-form-display-configuration>\n  </div>\n</ng-container>\n"]}
172
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select-form.component.js","sourceRoot":"","sources":["../../../../../../../projects/valtimo/process-link/src/lib/components/select-form/select-form.component.ts","../../../../../../../projects/valtimo/process-link/src/lib/components/select-form/select-form.component.html"],"names":[],"mappings":"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","sourcesContent":["/*\n * Copyright 2015-2024 Ritense BV, the Netherlands.\n *\n * Licensed under EUPL, Version 1.2 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" basis,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\nimport {Component, OnDestroy, OnInit} from '@angular/core';\nimport {ConfigService} from '@valtimo/config';\nimport {FormService} from '@valtimo/form';\nimport {BehaviorSubject, combineLatest, map, Observable, Subscription, switchMap, tap} from 'rxjs';\nimport {take} from 'rxjs/operators';\nimport {FormDefinitionListItem, FormProcessLinkUpdateRequestDto} from '../../models';\nimport {\n  ProcessLinkButtonService,\n  ProcessLinkService,\n  ProcessLinkStateService,\n} from '../../services';\n\n@Component({\n  selector: 'valtimo-select-form',\n  templateUrl: './select-form.component.html',\n  styleUrls: ['./select-form.component.scss'],\n})\nexport class SelectFormComponent implements OnInit, OnDestroy {\n  public formDisplayValue: string = '';\n  public formSizeValue: string = '';\n  public subtitlesValue: string[] = [];\n  public selectedFormDefinition!: FormDefinitionListItem;\n\n  public readonly saving$ = this.stateService.saving$;\n  private readonly formDefinitions$ = this.formService.getAllFormDefinitions();\n  public readonly formDefinitionListItems$: Observable<Array<FormDefinitionListItem>> =\n    combineLatest([this.stateService.selectedProcessLink$, this.formDefinitions$]).pipe(\n      map(([selectedProcessLink, formDefinitions]) =>\n        formDefinitions.map(definition => ({\n          content: definition.name,\n          id: definition.id,\n          selected: selectedProcessLink\n            ? selectedProcessLink.formDefinitionId === definition.id\n            : false,\n        }))\n      ),\n      tap(formDefinitionListItems => {\n        const selectedItem = formDefinitionListItems.find(item => item.selected);\n\n        if (selectedItem) {\n          this.selectFormDefinition(selectedItem);\n        }\n      })\n    );\n\n  private _subscriptions = new Subscription();\n  private isUserTask$ = new BehaviorSubject<boolean>(false);\n  private readonly _taskPanelToggle = this.configService.featureToggles?.enableTaskPanel;\n\n  constructor(\n    private readonly configService: ConfigService,\n    private readonly formService: FormService,\n    private readonly stateService: ProcessLinkStateService,\n    private readonly processLinkService: ProcessLinkService,\n    private readonly buttonService: ProcessLinkButtonService\n  ) {}\n\n  public ngOnInit(): void {\n    this.openBackButtonSubscription();\n    this.openSaveButtonSubscription();\n    this._subscriptions.add(\n      combineLatest([\n        this.stateService.selectedProcessLink$,\n        this.stateService.modalParams$,\n      ]).subscribe(([selectedProcessLink, modalParams]) => {\n        if (selectedProcessLink) {\n          this.formDisplayValue = selectedProcessLink.formDisplayType;\n          this.formSizeValue = selectedProcessLink.formSize;\n        }\n\n        this.isUserTask$.next(modalParams?.element?.type === 'bpmn:UserTask');\n      })\n    );\n  }\n\n  public ngOnDestroy(): void {\n    this._subscriptions.unsubscribe();\n  }\n\n  public selectFormDefinition(formDefinition: FormDefinitionListItem): void {\n    this.selectedFormDefinition = formDefinition?.id ? formDefinition : null;\n\n    this.selectedFormDefinition\n      ? this.buttonService.enableSaveButton()\n      : this.buttonService.disableSaveButton();\n  }\n\n  public selectedFormDisplayValue(formDisplay: string): void {\n    this.formDisplayValue = formDisplay;\n  }\n\n  public selectedFormSizeValue(formSize: string): void {\n    this.formSizeValue = formSize;\n  }\n\n  public selectedSubtitlesValue(subtitles: string[]): void {\n    this.subtitlesValue = subtitles;\n  }\n\n  private openBackButtonSubscription(): void {\n    this._subscriptions.add(\n      this.buttonService.backButtonClick$.subscribe(() => {\n        this.stateService.setInitial();\n      })\n    );\n  }\n\n  private openSaveButtonSubscription(): void {\n    this._subscriptions.add(\n      this.buttonService.saveButtonClick$.subscribe(() => {\n        this.stateService.startSaving();\n        this.saveProcessLink();\n      })\n    );\n  }\n\n  private saveProcessLink(): void {\n    this.stateService.selectedProcessLink$.pipe(take(1)).subscribe(selectedProcessLink => {\n      if (selectedProcessLink) {\n        this.updateProcessLink();\n      } else {\n        this.saveNewProcessLink();\n      }\n    });\n  }\n\n  private updateProcessLink(): void {\n    combineLatest([\n      this.stateService.selectedProcessLink$,\n      this.stateService.viewModelEnabled$,\n      this.isUserTask$,\n    ])\n      .pipe(take(1))\n      .subscribe(([selectedProcessLink, viewModelEnabled, isUserTask]) => {\n        const updateProcessLinkRequest: FormProcessLinkUpdateRequestDto = {\n          id: selectedProcessLink.id,\n          formDefinitionId: this.selectedFormDefinition.id,\n          viewModelEnabled,\n          ...(this._taskPanelToggle &&\n            isUserTask && {\n              formDisplayType: this.formDisplayValue,\n            }),\n          ...(this._taskPanelToggle && isUserTask && {formSize: this.formSizeValue}),\n          ...(isUserTask && {subtitles: this.subtitlesValue}),\n        };\n\n        this.processLinkService.updateProcessLink(updateProcessLinkRequest).subscribe(\n          () => {\n            this.stateService.closeModal();\n          },\n          () => {\n            this.stateService.stopSaving();\n          }\n        );\n      });\n  }\n\n  private saveNewProcessLink(): void {\n    combineLatest([\n      this.stateService.modalParams$,\n      this.stateService.selectedProcessLinkTypeId$,\n      this.stateService.viewModelEnabled$,\n      this.isUserTask$,\n    ])\n      .pipe(\n        take(1),\n        switchMap(([modalParams, processLinkTypeId, viewModelEnabled, isUserTask]) =>\n          this.processLinkService.saveProcessLink({\n            formDefinitionId: this.selectedFormDefinition.id,\n            activityType: modalParams.element.activityListenerType,\n            processDefinitionId: modalParams.processDefinitionId,\n            processLinkType: processLinkTypeId,\n            activityId: modalParams.element.id,\n            viewModelEnabled,\n            ...(isUserTask && {\n              formDisplayType: this.formDisplayValue,\n            }),\n            ...(isUserTask && {\n              formSize: this.formSizeValue,\n            }),\n            ...(isUserTask && {\n              subtitles: this.subtitlesValue,\n            }),\n          })\n        )\n      )\n      .subscribe(\n        () => {\n          this.stateService.closeModal();\n        },\n        () => {\n          this.stateService.stopSaving();\n        }\n      );\n  }\n}\n","<!--\n  ~ Copyright 2015-2024 Ritense BV, the Netherlands.\n  ~\n  ~ Licensed under EUPL, Version 1.2 (the \"License\");\n  ~ you may not use this file except in compliance with the License.\n  ~ You may obtain a copy of the License at\n  ~\n  ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n  ~\n  ~ Unless required by applicable law or agreed to in writing, software\n  ~ distributed under the License is distributed on an \"AS IS\" basis,\n  ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n  ~ See the License for the specific language governing permissions and\n  ~ limitations under the License.\n  -->\n\n<ng-container\n  *ngIf=\"{\n    formDefinitions: formDefinitionListItems$ | async,\n    saving: saving$ | async,\n  } as obs\"\n>\n  <p class=\"step-description\">\n    {{ 'processLinkConfiguration.chooseFormDescription' | translate }}\n  </p>\n  <div class=\"select-form\">\n    <cds-combo-box\n      [appendInline]=\"true\"\n      [disabled]=\"!obs.formDefinitions || obs.saving\"\n      [items]=\"obs.formDefinitions || []\"\n      [placeholder]=\"'interface.typeToSearch' | translate\"\n      (selected)=\"selectFormDefinition($event)\"\n      [label]=\"'processLinkSteps.selectForm' | translate\"\n      ><cds-dropdown-list></cds-dropdown-list\n    ></cds-combo-box>\n    <br />\n\n    <valtimo-form-display-configuration\n      [selectedFormDefinition]=\"selectedFormDefinition\"\n      (formDisplayValue)=\"selectedFormDisplayValue($event)\"\n      (formSizeValue)=\"selectedFormSizeValue($event)\"\n      (subtitlesValue)=\"selectedSubtitlesValue($event)\"\n    ></valtimo-form-display-configuration>\n  </div>\n</ng-container>\n"]}
@@ -33,8 +33,10 @@ export class SelectFormFlowComponent {
33
33
  this.buttonService = buttonService;
34
34
  this.formDisplayValue = '';
35
35
  this.formSizeValue = '';
36
+ this.subtitlesValue = [];
36
37
  this.saving$ = this.stateService.saving$;
37
38
  this.formFlowDefinitions$ = this.formFlowService.getFormFlowDefinitions();
39
+ this._taskPanelToggle = this.configService.featureToggles?.enableTaskPanel;
38
40
  this.formFlowDefinitionListItems$ = combineLatest([this.stateService.selectedProcessLink$, this.formFlowDefinitions$]).pipe(map(([selectedProcessLink, formFlowDefinitions]) => formFlowDefinitions.map(definition => ({
39
41
  content: definition.name,
40
42
  id: definition.id,
@@ -49,7 +51,6 @@ export class SelectFormFlowComponent {
49
51
  }));
50
52
  this._subscriptions = new Subscription();
51
53
  this.isUserTask$ = new BehaviorSubject(false);
52
- this.taskPanelToggle = this.configService.featureToggles?.enableTaskPanel;
53
54
  }
54
55
  ngOnInit() {
55
56
  this.openBackButtonSubscription();
@@ -80,6 +81,9 @@ export class SelectFormFlowComponent {
80
81
  ? this.buttonService.enableSaveButton()
81
82
  : this.buttonService.disableSaveButton();
82
83
  }
84
+ selectedSubtitlesValue(subtitles) {
85
+ this.subtitlesValue = subtitles;
86
+ }
83
87
  openBackButtonSubscription() {
84
88
  this._subscriptions.add(this.buttonService.backButtonClick$.subscribe(() => {
85
89
  this.stateService.setInitial();
@@ -108,11 +112,12 @@ export class SelectFormFlowComponent {
108
112
  const updateProcessLinkRequest = {
109
113
  id: selectedProcessLink.id,
110
114
  formFlowDefinitionId: this.selectedFormFlowDefinition.id,
111
- ...(this.taskPanelToggle &&
115
+ ...(this._taskPanelToggle &&
112
116
  isUserTask && {
113
117
  formDisplayType: this.formDisplayValue,
114
118
  }),
115
- ...(this.taskPanelToggle && isUserTask && { formSize: this.formSizeValue }),
119
+ ...(this._taskPanelToggle && isUserTask && { formSize: this.formSizeValue }),
120
+ ...(isUserTask && { subtitles: this.subtitlesValue }),
116
121
  };
117
122
  this.processLinkService.updateProcessLink(updateProcessLinkRequest).subscribe(() => {
118
123
  this.stateService.closeModal();
@@ -133,11 +138,11 @@ export class SelectFormFlowComponent {
133
138
  processDefinitionId: modalParams.processDefinitionId,
134
139
  processLinkType: processLinkTypeId,
135
140
  activityId: modalParams.element.id,
136
- ...(this.taskPanelToggle &&
137
- isUserTask && {
141
+ ...(isUserTask && {
138
142
  formDisplayType: this.formDisplayValue,
139
143
  }),
140
- ...(this.taskPanelToggle && isUserTask && { formSize: this.formSizeValue }),
144
+ ...(isUserTask && { formSize: this.formSizeValue }),
145
+ ...(isUserTask && { subtitles: this.subtitlesValue }),
141
146
  })))
142
147
  .subscribe(() => {
143
148
  this.stateService.closeModal();
@@ -146,10 +151,10 @@ export class SelectFormFlowComponent {
146
151
  });
147
152
  }
148
153
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: SelectFormFlowComponent, deps: [{ token: i1.ConfigService }, { token: i2.FormFlowService }, { token: i2.ProcessLinkStateService }, { token: i2.ProcessLinkService }, { token: i2.ProcessLinkButtonService }], target: i0.ɵɵFactoryTarget.Component }); }
149
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: SelectFormFlowComponent, selector: "valtimo-select-form-flow", 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 formFlowDefinitions: formFlowDefinitionListItems$ | async,\n saving: saving$ | async,\n } as obs\"\n>\n <p class=\"step-description\">\n {{ 'processLinkConfiguration.chooseFormFlowDescription' | translate }}\n </p>\n <div class=\"select-form-flow\">\n <cds-combo-box\n [appendInline]=\"true\"\n [disabled]=\"!obs.formFlowDefinitions || obs.saving\"\n [items]=\"obs.formFlowDefinitions || []\"\n [placeholder]=\"'interface.typeToSearch' | translate\"\n (selected)=\"selectFormFlowDefinition($event)\"\n [label]=\"'processLinkSteps.selectFormFlow' | translate\"\n ><cds-dropdown-list></cds-dropdown-list\n ></cds-combo-box>\n <br />\n\n <valtimo-form-display-configuration\n [selectedFormDefinition]=\"selectedFormFlowDefinition\"\n (formDisplayValue)=\"selectedFormDisplayValue($event)\"\n (formSizeValue)=\"selectedFormSizeValue($event)\"\n ></valtimo-form-display-configuration>\n </div>\n</ng-container>\n", styles: [".label-with-tooltip{display:flex;align-items:center}.select-form-flow{display:flex;flex-direction:column;width:100%;margin-top:24px}\n/*!\n * Copyright 2015-2024 Ritense BV, the Netherlands.\n *\n * Licensed under EUPL, Version 1.2 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" basis,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n"], dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i4.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: i5.DropdownList, selector: "cds-dropdown-list, ibm-dropdown-list", inputs: ["ariaLabel", "items", "listTpl", "type", "showTitles"], outputs: ["select", "scroll", "blurIntent"] }, { kind: "component", type: i6.FormDisplayConfigurationComponent, selector: "valtimo-form-display-configuration", inputs: ["selectedFormDefinition"], outputs: ["formDisplayValue", "formSizeValue"] }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }, { kind: "pipe", type: i7.TranslatePipe, name: "translate" }] }); }
154
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: SelectFormFlowComponent, selector: "valtimo-select-form-flow", 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 formFlowDefinitions: formFlowDefinitionListItems$ | async,\n saving: saving$ | async,\n } as obs\"\n>\n <p class=\"step-description\">\n {{ 'processLinkConfiguration.chooseFormFlowDescription' | translate }}\n </p>\n <div class=\"select-form-flow\">\n <cds-combo-box\n [appendInline]=\"true\"\n [disabled]=\"!obs.formFlowDefinitions || obs.saving\"\n [items]=\"obs.formFlowDefinitions || []\"\n [placeholder]=\"'interface.typeToSearch' | translate\"\n (selected)=\"selectFormFlowDefinition($event)\"\n [label]=\"'processLinkSteps.selectFormFlow' | translate\"\n ><cds-dropdown-list></cds-dropdown-list\n ></cds-combo-box>\n <br />\n\n <valtimo-form-display-configuration\n [selectedFormDefinition]=\"selectedFormFlowDefinition\"\n (formDisplayValue)=\"selectedFormDisplayValue($event)\"\n (formSizeValue)=\"selectedFormSizeValue($event)\"\n (subtitlesValue)=\"selectedSubtitlesValue($event)\"\n ></valtimo-form-display-configuration>\n </div>\n</ng-container>\n", styles: [".label-with-tooltip{display:flex;align-items:center}.select-form-flow{display:flex;flex-direction:column;width:100%;margin-top:24px}\n/*!\n * Copyright 2015-2024 Ritense BV, the Netherlands.\n *\n * Licensed under EUPL, Version 1.2 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" basis,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n"], dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i4.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: i5.DropdownList, selector: "cds-dropdown-list, ibm-dropdown-list", inputs: ["ariaLabel", "items", "listTpl", "type", "showTitles"], outputs: ["select", "scroll", "blurIntent"] }, { kind: "component", type: i6.FormDisplayConfigurationComponent, selector: "valtimo-form-display-configuration", inputs: ["selectedFormDefinition"], outputs: ["formDisplayValue", "formSizeValue", "subtitlesValue"] }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }, { kind: "pipe", type: i7.TranslatePipe, name: "translate" }] }); }
150
155
  }
151
156
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: SelectFormFlowComponent, decorators: [{
152
157
  type: Component,
153
- args: [{ selector: 'valtimo-select-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<ng-container\n *ngIf=\"{\n formFlowDefinitions: formFlowDefinitionListItems$ | async,\n saving: saving$ | async,\n } as obs\"\n>\n <p class=\"step-description\">\n {{ 'processLinkConfiguration.chooseFormFlowDescription' | translate }}\n </p>\n <div class=\"select-form-flow\">\n <cds-combo-box\n [appendInline]=\"true\"\n [disabled]=\"!obs.formFlowDefinitions || obs.saving\"\n [items]=\"obs.formFlowDefinitions || []\"\n [placeholder]=\"'interface.typeToSearch' | translate\"\n (selected)=\"selectFormFlowDefinition($event)\"\n [label]=\"'processLinkSteps.selectFormFlow' | translate\"\n ><cds-dropdown-list></cds-dropdown-list\n ></cds-combo-box>\n <br />\n\n <valtimo-form-display-configuration\n [selectedFormDefinition]=\"selectedFormFlowDefinition\"\n (formDisplayValue)=\"selectedFormDisplayValue($event)\"\n (formSizeValue)=\"selectedFormSizeValue($event)\"\n ></valtimo-form-display-configuration>\n </div>\n</ng-container>\n", styles: [".label-with-tooltip{display:flex;align-items:center}.select-form-flow{display:flex;flex-direction:column;width:100%;margin-top:24px}\n/*!\n * Copyright 2015-2024 Ritense BV, the Netherlands.\n *\n * Licensed under EUPL, Version 1.2 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" basis,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n"] }]
158
+ args: [{ selector: 'valtimo-select-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<ng-container\n *ngIf=\"{\n formFlowDefinitions: formFlowDefinitionListItems$ | async,\n saving: saving$ | async,\n } as obs\"\n>\n <p class=\"step-description\">\n {{ 'processLinkConfiguration.chooseFormFlowDescription' | translate }}\n </p>\n <div class=\"select-form-flow\">\n <cds-combo-box\n [appendInline]=\"true\"\n [disabled]=\"!obs.formFlowDefinitions || obs.saving\"\n [items]=\"obs.formFlowDefinitions || []\"\n [placeholder]=\"'interface.typeToSearch' | translate\"\n (selected)=\"selectFormFlowDefinition($event)\"\n [label]=\"'processLinkSteps.selectFormFlow' | translate\"\n ><cds-dropdown-list></cds-dropdown-list\n ></cds-combo-box>\n <br />\n\n <valtimo-form-display-configuration\n [selectedFormDefinition]=\"selectedFormFlowDefinition\"\n (formDisplayValue)=\"selectedFormDisplayValue($event)\"\n (formSizeValue)=\"selectedFormSizeValue($event)\"\n (subtitlesValue)=\"selectedSubtitlesValue($event)\"\n ></valtimo-form-display-configuration>\n </div>\n</ng-container>\n", styles: [".label-with-tooltip{display:flex;align-items:center}.select-form-flow{display:flex;flex-direction:column;width:100%;margin-top:24px}\n/*!\n * Copyright 2015-2024 Ritense BV, the Netherlands.\n *\n * Licensed under EUPL, Version 1.2 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" basis,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n"] }]
154
159
  }], ctorParameters: () => [{ type: i1.ConfigService }, { type: i2.FormFlowService }, { type: i2.ProcessLinkStateService }, { type: i2.ProcessLinkService }, { type: i2.ProcessLinkButtonService }] });
155
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select-form-flow.component.js","sourceRoot":"","sources":["../../../../../../../projects/valtimo/process-link/src/lib/components/select-form-flow/select-form-flow.component.ts","../../../../../../../projects/valtimo/process-link/src/lib/components/select-form-flow/select-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, OnDestroy, OnInit} from '@angular/core';\nimport {BehaviorSubject, combineLatest, map, Observable, Subscription, switchMap, tap} from 'rxjs';\nimport {\n  FormFlowService,\n  ProcessLinkButtonService,\n  ProcessLinkService,\n  ProcessLinkStateService,\n} from '../../services';\nimport {FormDefinitionListItem, FormFlowProcessLinkUpdateRequestDto} from '../../models';\nimport {take} from 'rxjs/operators';\nimport {ConfigService} from '@valtimo/config';\n\n@Component({\n  selector: 'valtimo-select-form-flow',\n  templateUrl: './select-form-flow.component.html',\n  styleUrls: ['./select-form-flow.component.scss'],\n})\nexport class SelectFormFlowComponent implements OnInit, OnDestroy {\n  public formDisplayValue: string = '';\n  public formSizeValue: string = '';\n  public selectedFormFlowDefinition!: FormDefinitionListItem;\n  public readonly saving$ = this.stateService.saving$;\n  private readonly formFlowDefinitions$ = this.formFlowService.getFormFlowDefinitions();\n\n  public readonly formFlowDefinitionListItems$: Observable<Array<FormDefinitionListItem>> =\n    combineLatest([this.stateService.selectedProcessLink$, this.formFlowDefinitions$]).pipe(\n      map(([selectedProcessLink, formFlowDefinitions]) =>\n        formFlowDefinitions.map(definition => ({\n          content: definition.name,\n          id: definition.id,\n          selected: selectedProcessLink\n            ? selectedProcessLink.formFlowDefinitionId === definition.id\n            : false,\n        }))\n      ),\n      tap(formFlowDefinitionListItems => {\n        const selectedItem = formFlowDefinitionListItems.find(item => item.selected);\n\n        if (selectedItem) {\n          this.selectFormFlowDefinition(selectedItem);\n        }\n      })\n    );\n\n  private _subscriptions = new Subscription();\n  private isUserTask$ = new BehaviorSubject<boolean>(false);\n  private readonly taskPanelToggle = this.configService.featureToggles?.enableTaskPanel;\n\n  constructor(\n    private readonly configService: ConfigService,\n    private readonly formFlowService: FormFlowService,\n    private readonly stateService: ProcessLinkStateService,\n    private readonly processLinkService: ProcessLinkService,\n    private readonly buttonService: ProcessLinkButtonService\n  ) {}\n\n  ngOnInit(): void {\n    this.openBackButtonSubscription();\n    this.openSaveButtonSubscription();\n    this._subscriptions.add(\n      combineLatest([\n        this.stateService.selectedProcessLink$,\n        this.stateService.modalParams$,\n      ]).subscribe(([selectedProcessLink, modalParams]) => {\n        if (selectedProcessLink) {\n          this.formDisplayValue = selectedProcessLink.formDisplayType;\n          this.formSizeValue = selectedProcessLink.formSize;\n        }\n\n        this.isUserTask$.next(modalParams?.element?.type === 'bpmn:UserTask');\n      })\n    );\n  }\n\n  ngOnDestroy(): void {\n    this._subscriptions.unsubscribe();\n  }\n\n  public selectedFormDisplayValue(formDisplay: string): void {\n    this.formDisplayValue = formDisplay;\n  }\n\n  public selectedFormSizeValue(formSize: string): void {\n    this.formSizeValue = formSize;\n  }\n\n  public selectFormFlowDefinition(formFlowDefinition: FormDefinitionListItem): void {\n    this.selectedFormFlowDefinition = formFlowDefinition?.id ? formFlowDefinition : null;\n\n    this.selectedFormFlowDefinition\n      ? this.buttonService.enableSaveButton()\n      : this.buttonService.disableSaveButton();\n  }\n\n  private openBackButtonSubscription(): void {\n    this._subscriptions.add(\n      this.buttonService.backButtonClick$.subscribe(() => {\n        this.stateService.setInitial();\n      })\n    );\n  }\n\n  private openSaveButtonSubscription(): void {\n    this._subscriptions.add(\n      this.buttonService.saveButtonClick$.subscribe(() => {\n        this.stateService.startSaving();\n        this.saveFormFlowLink();\n      })\n    );\n  }\n\n  private saveFormFlowLink(): void {\n    this.stateService.selectedProcessLink$.pipe(take(1)).subscribe(selectedProcessLink => {\n      if (selectedProcessLink) {\n        this.updateProcessLink();\n      } else {\n        this.saveNewProcessLink();\n      }\n    });\n  }\n\n  private updateProcessLink(): void {\n    combineLatest(this.stateService.selectedProcessLink$, this.isUserTask$)\n      .pipe(take(1))\n      .subscribe(([selectedProcessLink, isUserTask]) => {\n        const updateProcessLinkRequest: FormFlowProcessLinkUpdateRequestDto = {\n          id: selectedProcessLink.id,\n          formFlowDefinitionId: this.selectedFormFlowDefinition.id,\n          ...(this.taskPanelToggle &&\n            isUserTask && {\n              formDisplayType: this.formDisplayValue,\n            }),\n          ...(this.taskPanelToggle && isUserTask && {formSize: this.formSizeValue}),\n        };\n\n        this.processLinkService.updateProcessLink(updateProcessLinkRequest).subscribe(\n          () => {\n            this.stateService.closeModal();\n          },\n          () => {\n            this.stateService.stopSaving();\n          }\n        );\n      });\n  }\n\n  private saveNewProcessLink(): void {\n    combineLatest([\n      this.stateService.modalParams$,\n      this.stateService.selectedProcessLinkTypeId$,\n      this.isUserTask$,\n    ])\n      .pipe(\n        take(1),\n        switchMap(([modalParams, processLinkTypeId, isUserTask]) =>\n          this.processLinkService.saveProcessLink({\n            formFlowDefinitionId: this.selectedFormFlowDefinition.id,\n            activityType: modalParams.element.activityListenerType,\n            processDefinitionId: modalParams.processDefinitionId,\n            processLinkType: processLinkTypeId,\n            activityId: modalParams.element.id,\n            ...(this.taskPanelToggle &&\n              isUserTask && {\n                formDisplayType: this.formDisplayValue,\n              }),\n            ...(this.taskPanelToggle && isUserTask && {formSize: this.formSizeValue}),\n          })\n        )\n      )\n      .subscribe(\n        () => {\n          this.stateService.closeModal();\n        },\n        () => {\n          this.stateService.stopSaving();\n        }\n      );\n  }\n}\n","<!--\n  ~ Copyright 2015-2024 Ritense BV, the Netherlands.\n  ~\n  ~ Licensed under EUPL, Version 1.2 (the \"License\");\n  ~ you may not use this file except in compliance with the License.\n  ~ You may obtain a copy of the License at\n  ~\n  ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n  ~\n  ~ Unless required by applicable law or agreed to in writing, software\n  ~ distributed under the License is distributed on an \"AS IS\" basis,\n  ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n  ~ See the License for the specific language governing permissions and\n  ~ limitations under the License.\n  -->\n\n<ng-container\n  *ngIf=\"{\n    formFlowDefinitions: formFlowDefinitionListItems$ | async,\n    saving: saving$ | async,\n  } as obs\"\n>\n  <p class=\"step-description\">\n    {{ 'processLinkConfiguration.chooseFormFlowDescription' | translate }}\n  </p>\n  <div class=\"select-form-flow\">\n    <cds-combo-box\n      [appendInline]=\"true\"\n      [disabled]=\"!obs.formFlowDefinitions || obs.saving\"\n      [items]=\"obs.formFlowDefinitions || []\"\n      [placeholder]=\"'interface.typeToSearch' | translate\"\n      (selected)=\"selectFormFlowDefinition($event)\"\n      [label]=\"'processLinkSteps.selectFormFlow' | translate\"\n      ><cds-dropdown-list></cds-dropdown-list\n    ></cds-combo-box>\n    <br />\n\n    <valtimo-form-display-configuration\n      [selectedFormDefinition]=\"selectedFormFlowDefinition\"\n      (formDisplayValue)=\"selectedFormDisplayValue($event)\"\n      (formSizeValue)=\"selectedFormSizeValue($event)\"\n    ></valtimo-form-display-configuration>\n  </div>\n</ng-container>\n"]}
160
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select-form-flow.component.js","sourceRoot":"","sources":["../../../../../../../projects/valtimo/process-link/src/lib/components/select-form-flow/select-form-flow.component.ts","../../../../../../../projects/valtimo/process-link/src/lib/components/select-form-flow/select-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 */\nimport {Component, OnDestroy, OnInit} from '@angular/core';\nimport {BehaviorSubject, combineLatest, map, Observable, Subscription, switchMap, tap} from 'rxjs';\nimport {take} from 'rxjs/operators';\nimport {FormDefinitionListItem, FormFlowProcessLinkUpdateRequestDto} from '../../models';\nimport {\n  FormFlowService,\n  ProcessLinkButtonService,\n  ProcessLinkService,\n  ProcessLinkStateService,\n} from '../../services';\nimport {ConfigService} from '@valtimo/config';\n\n@Component({\n  selector: 'valtimo-select-form-flow',\n  templateUrl: './select-form-flow.component.html',\n  styleUrls: ['./select-form-flow.component.scss'],\n})\nexport class SelectFormFlowComponent implements OnInit, OnDestroy {\n  public formDisplayValue: string = '';\n  public formSizeValue: string = '';\n  public selectedFormFlowDefinition!: FormDefinitionListItem;\n  public subtitlesValue: string[] = [];\n  public readonly saving$ = this.stateService.saving$;\n  private readonly formFlowDefinitions$ = this.formFlowService.getFormFlowDefinitions();\n  private readonly _taskPanelToggle = this.configService.featureToggles?.enableTaskPanel;\n\n  public readonly formFlowDefinitionListItems$: Observable<Array<FormDefinitionListItem>> =\n    combineLatest([this.stateService.selectedProcessLink$, this.formFlowDefinitions$]).pipe(\n      map(([selectedProcessLink, formFlowDefinitions]) =>\n        formFlowDefinitions.map(definition => ({\n          content: definition.name,\n          id: definition.id,\n          selected: selectedProcessLink\n            ? selectedProcessLink.formFlowDefinitionId === definition.id\n            : false,\n        }))\n      ),\n      tap(formFlowDefinitionListItems => {\n        const selectedItem = formFlowDefinitionListItems.find(item => item.selected);\n\n        if (selectedItem) {\n          this.selectFormFlowDefinition(selectedItem);\n        }\n      })\n    );\n\n  private _subscriptions = new Subscription();\n  private isUserTask$ = new BehaviorSubject<boolean>(false);\n\n  constructor(\n    private readonly configService: ConfigService,\n    private readonly formFlowService: FormFlowService,\n    private readonly stateService: ProcessLinkStateService,\n    private readonly processLinkService: ProcessLinkService,\n    private readonly buttonService: ProcessLinkButtonService\n  ) {}\n\n  ngOnInit(): void {\n    this.openBackButtonSubscription();\n    this.openSaveButtonSubscription();\n    this._subscriptions.add(\n      combineLatest([\n        this.stateService.selectedProcessLink$,\n        this.stateService.modalParams$,\n      ]).subscribe(([selectedProcessLink, modalParams]) => {\n        if (selectedProcessLink) {\n          this.formDisplayValue = selectedProcessLink.formDisplayType;\n          this.formSizeValue = selectedProcessLink.formSize;\n        }\n\n        this.isUserTask$.next(modalParams?.element?.type === 'bpmn:UserTask');\n      })\n    );\n  }\n\n  ngOnDestroy(): void {\n    this._subscriptions.unsubscribe();\n  }\n\n  public selectedFormDisplayValue(formDisplay: string): void {\n    this.formDisplayValue = formDisplay;\n  }\n\n  public selectedFormSizeValue(formSize: string): void {\n    this.formSizeValue = formSize;\n  }\n\n  public selectFormFlowDefinition(formFlowDefinition: FormDefinitionListItem): void {\n    this.selectedFormFlowDefinition = formFlowDefinition?.id ? formFlowDefinition : null;\n\n    this.selectedFormFlowDefinition\n      ? this.buttonService.enableSaveButton()\n      : this.buttonService.disableSaveButton();\n  }\n\n  public selectedSubtitlesValue(subtitles: string[]): void {\n    this.subtitlesValue = subtitles;\n  }\n\n  private openBackButtonSubscription(): void {\n    this._subscriptions.add(\n      this.buttonService.backButtonClick$.subscribe(() => {\n        this.stateService.setInitial();\n      })\n    );\n  }\n\n  private openSaveButtonSubscription(): void {\n    this._subscriptions.add(\n      this.buttonService.saveButtonClick$.subscribe(() => {\n        this.stateService.startSaving();\n        this.saveFormFlowLink();\n      })\n    );\n  }\n\n  private saveFormFlowLink(): void {\n    this.stateService.selectedProcessLink$.pipe(take(1)).subscribe(selectedProcessLink => {\n      if (selectedProcessLink) {\n        this.updateProcessLink();\n      } else {\n        this.saveNewProcessLink();\n      }\n    });\n  }\n\n  private updateProcessLink(): void {\n    combineLatest(this.stateService.selectedProcessLink$, this.isUserTask$)\n      .pipe(take(1))\n      .subscribe(([selectedProcessLink, isUserTask]) => {\n        const updateProcessLinkRequest: FormFlowProcessLinkUpdateRequestDto = {\n          id: selectedProcessLink.id,\n          formFlowDefinitionId: this.selectedFormFlowDefinition.id,\n          ...(this._taskPanelToggle &&\n            isUserTask && {\n              formDisplayType: this.formDisplayValue,\n            }),\n          ...(this._taskPanelToggle && isUserTask && {formSize: this.formSizeValue}),\n          ...(isUserTask && {subtitles: this.subtitlesValue}),\n        };\n\n        this.processLinkService.updateProcessLink(updateProcessLinkRequest).subscribe(\n          () => {\n            this.stateService.closeModal();\n          },\n          () => {\n            this.stateService.stopSaving();\n          }\n        );\n      });\n  }\n\n  private saveNewProcessLink(): void {\n    combineLatest([\n      this.stateService.modalParams$,\n      this.stateService.selectedProcessLinkTypeId$,\n      this.isUserTask$,\n    ])\n      .pipe(\n        take(1),\n        switchMap(([modalParams, processLinkTypeId, isUserTask]) =>\n          this.processLinkService.saveProcessLink({\n            formFlowDefinitionId: this.selectedFormFlowDefinition.id,\n            activityType: modalParams.element.activityListenerType,\n            processDefinitionId: modalParams.processDefinitionId,\n            processLinkType: processLinkTypeId,\n            activityId: modalParams.element.id,\n            ...(isUserTask && {\n              formDisplayType: this.formDisplayValue,\n            }),\n            ...(isUserTask && {formSize: this.formSizeValue}),\n            ...(isUserTask && {subtitles: this.subtitlesValue}),\n          })\n        )\n      )\n      .subscribe(\n        () => {\n          this.stateService.closeModal();\n        },\n        () => {\n          this.stateService.stopSaving();\n        }\n      );\n  }\n}\n","<!--\n  ~ Copyright 2015-2024 Ritense BV, the Netherlands.\n  ~\n  ~ Licensed under EUPL, Version 1.2 (the \"License\");\n  ~ you may not use this file except in compliance with the License.\n  ~ You may obtain a copy of the License at\n  ~\n  ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n  ~\n  ~ Unless required by applicable law or agreed to in writing, software\n  ~ distributed under the License is distributed on an \"AS IS\" basis,\n  ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n  ~ See the License for the specific language governing permissions and\n  ~ limitations under the License.\n  -->\n\n<ng-container\n  *ngIf=\"{\n    formFlowDefinitions: formFlowDefinitionListItems$ | async,\n    saving: saving$ | async,\n  } as obs\"\n>\n  <p class=\"step-description\">\n    {{ 'processLinkConfiguration.chooseFormFlowDescription' | translate }}\n  </p>\n  <div class=\"select-form-flow\">\n    <cds-combo-box\n      [appendInline]=\"true\"\n      [disabled]=\"!obs.formFlowDefinitions || obs.saving\"\n      [items]=\"obs.formFlowDefinitions || []\"\n      [placeholder]=\"'interface.typeToSearch' | translate\"\n      (selected)=\"selectFormFlowDefinition($event)\"\n      [label]=\"'processLinkSteps.selectFormFlow' | translate\"\n      ><cds-dropdown-list></cds-dropdown-list\n    ></cds-combo-box>\n    <br />\n\n    <valtimo-form-display-configuration\n      [selectedFormDefinition]=\"selectedFormFlowDefinition\"\n      (formDisplayValue)=\"selectedFormDisplayValue($event)\"\n      (formSizeValue)=\"selectedFormSizeValue($event)\"\n      (subtitlesValue)=\"selectedSubtitlesValue($event)\"\n    ></valtimo-form-display-configuration>\n  </div>\n</ng-container>\n"]}
@@ -19,10 +19,9 @@ import { switchMap, take } from 'rxjs/operators';
19
19
  import * as i0 from "@angular/core";
20
20
  import * as i1 from "../../services";
21
21
  import * as i2 from "@valtimo/plugin";
22
- import * as i3 from "../../services/plugin-state.service";
23
- import * as i4 from "@angular/common";
24
- import * as i5 from "carbon-components-angular";
25
- import * as i6 from "@ngx-translate/core";
22
+ import * as i3 from "@angular/common";
23
+ import * as i4 from "carbon-components-angular";
24
+ import * as i5 from "@ngx-translate/core";
26
25
  export class SelectPluginActionComponent {
27
26
  constructor(buttonService, pluginManagementService, stateService, stepService) {
28
27
  this.buttonService = buttonService;
@@ -65,11 +64,11 @@ export class SelectPluginActionComponent {
65
64
  this.stepService.setConfigurePluginActionSteps();
66
65
  }));
67
66
  }
68
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: SelectPluginActionComponent, deps: [{ token: i1.ProcessLinkButtonService }, { token: i2.PluginManagementService }, { token: i3.PluginStateService }, { token: i1.ProcessLinkStepService }], target: i0.ɵɵFactoryTarget.Component }); }
69
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: SelectPluginActionComponent, selector: "valtimo-select-plugin-action", 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 *ngIf=\"pluginFunctions$ | async as pluginFunctions; else loading\">\n <div class=\"choose-plugin-action\" *ngIf=\"pluginFunctions?.length > 0\">\n <p class=\"step-description\">\n {{ 'processLinkConfiguration.choosePluginActionDescription' | translate }}\n </p>\n <div class=\"action-tiles\">\n <cds-tile-group\n [multiple]=\"false\"\n *ngIf=\"{selectedPluginDefinition: selectedPluginDefinition$ | async} as obs\"\n (selected)=\"selected($event)\"\n >\n <cds-selection-tile\n *ngFor=\"let pluginFunction of pluginFunctions\"\n [value]=\"stringify(pluginFunction)\"\n [selected]=\"false\"\n >{{\n pluginFunction.key | pluginTranslate: obs.selectedPluginDefinition.key | async\n }}</cds-selection-tile\n >\n </cds-tile-group>\n </div>\n </div>\n <ng-container *ngIf=\"!pluginFunctions || pluginFunctions?.length === 0\">\n <ng-container *ngTemplateOutlet=\"noPluginFunctionsTemplate\"> </ng-container>\n </ng-container>\n</ng-container>\n\n<ng-template #noPluginFunctionsTemplate>\n <p class=\"step-description\">\n {{ 'processLink.noPluginFunctions' | translate }}\n </p>\n</ng-template>\n\n<ng-template #loading>\n <div class=\"loading-container\">\n <cds-loading></cds-loading>\n </div>\n</ng-template>\n", styles: [".btn-back{position:absolute}.cards-container{display:flex;flex-flow:row wrap;width:100%}.card{width:calc(33.3% - 20px);margin-right:30px}.card:nth-child(3n+3){margin-right:0}.card-header{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.loading-container{display:flex;justify-content:center;margin-top:40px;flex-direction:row}.action-tiles{margin-top:24px;width:calc(100% + 8px);margin-left:-8px}::ng-deep .choose-plugin-action cds-selection-tile{display:flex;width:calc(33.3% - 8px)}::ng-deep .choose-plugin-action .cds--tile{width:100%}::ng-deep .choose-plugin-action cds-tile-group fieldset{display:flex;flex-direction:row;flex-wrap:wrap}::ng-deep .choose-plugin-action cds-selection-tile{margin-left:8px}::ng-deep .choose-plugin-action cds-selection-tile:nth-child(n+4){margin-top:8px}::ng-deep .action-tiles .cds--tile{background-color:var(--cds-layer-02, #ffffff)}::ng-deep .action-tiles .cds--tile:hover{background:var(--cds-layer-hover)}\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: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i5.Loading, selector: "cds-loading, ibm-loading", inputs: ["title", "isActive", "size", "overlay"] }, { kind: "component", type: i5.SelectionTile, selector: "cds-selection-tile, ibm-selection-tile", inputs: ["theme", "id", "selected", "value", "disabled"], outputs: ["change"] }, { kind: "component", type: i5.TileGroup, selector: "cds-tile-group, ibm-tile-group", inputs: ["name", "multiple", "legend"], outputs: ["selected"] }, { kind: "pipe", type: i4.AsyncPipe, name: "async" }, { kind: "pipe", type: i6.TranslatePipe, name: "translate" }, { kind: "pipe", type: i2.PluginTranslatePipe, name: "pluginTranslate" }] }); }
67
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: SelectPluginActionComponent, deps: [{ token: i1.ProcessLinkButtonService }, { token: i2.PluginManagementService }, { token: i1.PluginStateService }, { token: i1.ProcessLinkStepService }], target: i0.ɵɵFactoryTarget.Component }); }
68
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: SelectPluginActionComponent, selector: "valtimo-select-plugin-action", 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 *ngIf=\"pluginFunctions$ | async as pluginFunctions; else loading\">\n <div class=\"choose-plugin-action\" *ngIf=\"pluginFunctions?.length > 0\">\n <p class=\"step-description\">\n {{ 'processLinkConfiguration.choosePluginActionDescription' | translate }}\n </p>\n <div class=\"action-tiles\">\n <cds-tile-group\n [multiple]=\"false\"\n *ngIf=\"{selectedPluginDefinition: selectedPluginDefinition$ | async} as obs\"\n (selected)=\"selected($event)\"\n >\n <cds-selection-tile\n *ngFor=\"let pluginFunction of pluginFunctions\"\n [value]=\"stringify(pluginFunction)\"\n [selected]=\"false\"\n >{{\n pluginFunction.key | pluginTranslate: obs.selectedPluginDefinition.key | async\n }}</cds-selection-tile\n >\n </cds-tile-group>\n </div>\n </div>\n <ng-container *ngIf=\"!pluginFunctions || pluginFunctions?.length === 0\">\n <ng-container *ngTemplateOutlet=\"noPluginFunctionsTemplate\"> </ng-container>\n </ng-container>\n</ng-container>\n\n<ng-template #noPluginFunctionsTemplate>\n <p class=\"step-description\">\n {{ 'processLink.noPluginFunctions' | translate }}\n </p>\n</ng-template>\n\n<ng-template #loading>\n <div class=\"loading-container\">\n <cds-loading></cds-loading>\n </div>\n</ng-template>\n", styles: [".btn-back{position:absolute}.cards-container{display:flex;flex-flow:row wrap;width:100%}.card{width:calc(33.3% - 20px);margin-right:30px}.card:nth-child(3n+3){margin-right:0}.card-header{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.loading-container{display:flex;justify-content:center;margin-top:40px;flex-direction:row}.action-tiles{margin-top:24px;width:calc(100% + 8px);margin-left:-8px}::ng-deep .choose-plugin-action cds-selection-tile{display:flex;width:calc(33.3% - 8px)}::ng-deep .choose-plugin-action .cds--tile{width:100%}::ng-deep .choose-plugin-action cds-tile-group fieldset{display:flex;flex-direction:row;flex-wrap:wrap}::ng-deep .choose-plugin-action cds-selection-tile{margin-left:8px}::ng-deep .choose-plugin-action cds-selection-tile:nth-child(n+4){margin-top:8px}::ng-deep .action-tiles .cds--tile{background-color:var(--cds-layer-02, #ffffff)}::ng-deep .action-tiles .cds--tile:hover{background:var(--cds-layer-hover)}\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.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i4.Loading, selector: "cds-loading, ibm-loading", inputs: ["title", "isActive", "size", "overlay"] }, { kind: "component", type: i4.SelectionTile, selector: "cds-selection-tile, ibm-selection-tile", inputs: ["theme", "id", "selected", "value", "disabled"], outputs: ["change"] }, { kind: "component", type: i4.TileGroup, selector: "cds-tile-group, ibm-tile-group", inputs: ["name", "multiple", "legend"], outputs: ["selected"] }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }, { kind: "pipe", type: i5.TranslatePipe, name: "translate" }, { kind: "pipe", type: i2.PluginTranslatePipe, name: "pluginTranslate" }] }); }
70
69
  }
71
70
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: SelectPluginActionComponent, decorators: [{
72
71
  type: Component,
73
72
  args: [{ selector: 'valtimo-select-plugin-action', 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 *ngIf=\"pluginFunctions$ | async as pluginFunctions; else loading\">\n <div class=\"choose-plugin-action\" *ngIf=\"pluginFunctions?.length > 0\">\n <p class=\"step-description\">\n {{ 'processLinkConfiguration.choosePluginActionDescription' | translate }}\n </p>\n <div class=\"action-tiles\">\n <cds-tile-group\n [multiple]=\"false\"\n *ngIf=\"{selectedPluginDefinition: selectedPluginDefinition$ | async} as obs\"\n (selected)=\"selected($event)\"\n >\n <cds-selection-tile\n *ngFor=\"let pluginFunction of pluginFunctions\"\n [value]=\"stringify(pluginFunction)\"\n [selected]=\"false\"\n >{{\n pluginFunction.key | pluginTranslate: obs.selectedPluginDefinition.key | async\n }}</cds-selection-tile\n >\n </cds-tile-group>\n </div>\n </div>\n <ng-container *ngIf=\"!pluginFunctions || pluginFunctions?.length === 0\">\n <ng-container *ngTemplateOutlet=\"noPluginFunctionsTemplate\"> </ng-container>\n </ng-container>\n</ng-container>\n\n<ng-template #noPluginFunctionsTemplate>\n <p class=\"step-description\">\n {{ 'processLink.noPluginFunctions' | translate }}\n </p>\n</ng-template>\n\n<ng-template #loading>\n <div class=\"loading-container\">\n <cds-loading></cds-loading>\n </div>\n</ng-template>\n", styles: [".btn-back{position:absolute}.cards-container{display:flex;flex-flow:row wrap;width:100%}.card{width:calc(33.3% - 20px);margin-right:30px}.card:nth-child(3n+3){margin-right:0}.card-header{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.loading-container{display:flex;justify-content:center;margin-top:40px;flex-direction:row}.action-tiles{margin-top:24px;width:calc(100% + 8px);margin-left:-8px}::ng-deep .choose-plugin-action cds-selection-tile{display:flex;width:calc(33.3% - 8px)}::ng-deep .choose-plugin-action .cds--tile{width:100%}::ng-deep .choose-plugin-action cds-tile-group fieldset{display:flex;flex-direction:row;flex-wrap:wrap}::ng-deep .choose-plugin-action cds-selection-tile{margin-left:8px}::ng-deep .choose-plugin-action cds-selection-tile:nth-child(n+4){margin-top:8px}::ng-deep .action-tiles .cds--tile{background-color:var(--cds-layer-02, #ffffff)}::ng-deep .action-tiles .cds--tile:hover{background:var(--cds-layer-hover)}\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"] }]
74
- }], ctorParameters: () => [{ type: i1.ProcessLinkButtonService }, { type: i2.PluginManagementService }, { type: i3.PluginStateService }, { type: i1.ProcessLinkStepService }] });
75
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select-plugin-action.component.js","sourceRoot":"","sources":["../../../../../../../projects/valtimo/process-link/src/lib/components/select-plugin-action/select-plugin-action.component.ts","../../../../../../../projects/valtimo/process-link/src/lib/components/select-plugin-action/select-plugin-action.component.html"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;GAcG;AACH,OAAO,EAAC,SAAS,EAAoB,MAAM,eAAe,CAAC;AAE3D,OAAO,EAAa,EAAE,EAAE,YAAY,EAAC,MAAM,MAAM,CAAC;AAClD,OAAO,EAAC,SAAS,EAAE,IAAI,EAAC,MAAM,gBAAgB,CAAC;;;;;;;;AAU/C,MAAM,OAAO,2BAA2B;IAgBtC,YACmB,aAAuC,EACvC,uBAAgD,EAChD,YAAgC,EAChC,WAAmC;QAHnC,kBAAa,GAAb,aAAa,CAA0B;QACvC,4BAAuB,GAAvB,uBAAuB,CAAyB;QAChD,iBAAY,GAAZ,YAAY,CAAoB;QAChC,gBAAW,GAAX,WAAW,CAAwB;QAnBtC,qBAAgB,GAC9B,IAAI,CAAC,YAAY,CAAC,yBAAyB,CAAC,IAAI,CAC9C,SAAS,CAAC,kBAAkB,CAAC,EAAE,CAC7B,kBAAkB;YAChB,CAAC,CAAC,IAAI,CAAC,uBAAuB,CAAC,kBAAkB,CAAC,kBAAkB,CAAC,GAAG,CAAC;YACzE,CAAC,CAAC,EAAE,CAAC,SAAS,CAAC,CAClB,CACF,CAAC;QACY,8BAAyB,GACvC,IAAI,CAAC,YAAY,CAAC,yBAAyB,CAAC;QAC9B,4BAAuB,GACrC,IAAI,CAAC,YAAY,CAAC,uBAAuB,CAAC;QAEpC,mBAAc,GAAG,IAAI,YAAY,EAAE,CAAC;IAOzC,CAAC;IAEG,QAAQ;QACb,IAAI,CAAC,0BAA0B,EAAE,CAAC;QAClC,IAAI,CAAC,0BAA0B,EAAE,CAAC;IACpC,CAAC;IAEM,WAAW;QAChB,IAAI,CAAC,cAAc,CAAC,WAAW,EAAE,CAAC;IACpC,CAAC;IAEM,cAAc,CAAC,cAA8B;QAClD,IAAI,CAAC,YAAY,CAAC,oBAAoB,CAAC,cAAc,CAAC,CAAC;IACzD,CAAC;IAEM,QAAQ,CAAC,KAAsB;QACpC,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC;QAC7C,IAAI,CAAC,aAAa,CAAC,gBAAgB,EAAE,CAAC;IACxC,CAAC;IAEM,SAAS,CAAC,MAAc;QAC7B,OAAO,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;IAChC,CAAC;IAEO,0BAA0B;QAChC,IAAI,CAAC,aAAa,CAAC,gBAAgB;aAChC,IAAI,CACH,SAAS,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,WAAW,CAAC,sBAAsB,CAAC,EACxD,IAAI,CAAC,CAAC,CAAC,CACR;aACA,SAAS,CAAC,CAAC,YAAqB,EAAE,EAAE;YACnC,IAAI,CAAC,WAAW,CAAC,uBAAuB,CAAC,QAAQ,EAAE,YAAY,CAAC,CAAC;QACnE,CAAC,CAAC,CAAC;IACP,CAAC;IAEO,0BAA0B;QAChC,IAAI,CAAC,cAAc,CAAC,GAAG,CACrB,IAAI,CAAC,aAAa,CAAC,gBAAgB,CAAC,SAAS,CAAC,GAAG,EAAE;YACjD,IAAI,CAAC,WAAW,CAAC,6BAA6B,EAAE,CAAC;QACnD,CAAC,CAAC,CACH,CAAC;IACJ,CAAC;+GA9DU,2BAA2B;mGAA3B,2BAA2B,oEC5BxC,m+DAsDA;;4FD1Ba,2BAA2B;kBALvC,SAAS;+BACE,8BAA8B","sourcesContent":["/*\n * Copyright 2015-2024 Ritense BV, the Netherlands.\n *\n * Licensed under EUPL, Version 1.2 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" basis,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\nimport {Component, OnDestroy, OnInit} from '@angular/core';\nimport {PluginDefinition, PluginFunction, PluginManagementService} from '@valtimo/plugin';\nimport {Observable, of, Subscription} from 'rxjs';\nimport {switchMap, take} from 'rxjs/operators';\n\nimport {ProcessLinkButtonService, ProcessLinkStepService} from '../../services';\nimport {PluginStateService} from '../../services/plugin-state.service';\n\n@Component({\n  selector: 'valtimo-select-plugin-action',\n  templateUrl: './select-plugin-action.component.html',\n  styleUrls: ['./select-plugin-action.component.scss'],\n})\nexport class SelectPluginActionComponent implements OnInit, OnDestroy {\n  public readonly pluginFunctions$: Observable<Array<PluginFunction> | undefined> =\n    this.stateService.selectedPluginDefinition$.pipe(\n      switchMap(selectedDefinition =>\n        selectedDefinition\n          ? this.pluginManagementService.getPluginFunctions(selectedDefinition.key)\n          : of(undefined)\n      )\n    );\n  public readonly selectedPluginDefinition$: Observable<PluginDefinition> =\n    this.stateService.selectedPluginDefinition$;\n  public readonly selectedPluginFunction$: Observable<PluginFunction> =\n    this.stateService.selectedPluginFunction$;\n\n  private _subscriptions = new Subscription();\n\n  constructor(\n    private readonly buttonService: ProcessLinkButtonService,\n    private readonly pluginManagementService: PluginManagementService,\n    private readonly stateService: PluginStateService,\n    private readonly stepService: ProcessLinkStepService\n  ) {}\n\n  public ngOnInit(): void {\n    this.openBackButtonSubscription();\n    this.openNextButtonSubscription();\n  }\n\n  public ngOnDestroy(): void {\n    this._subscriptions.unsubscribe();\n  }\n\n  public selectFunction(pluginFunction: PluginFunction): void {\n    this.stateService.selectPluginFunction(pluginFunction);\n  }\n\n  public selected(event: {value: string}): void {\n    this.selectFunction(JSON.parse(event.value));\n    this.buttonService.enableNextButton();\n  }\n\n  public stringify(object: object): string {\n    return JSON.stringify(object);\n  }\n\n  private openBackButtonSubscription(): void {\n    this.buttonService.backButtonClick$\n      .pipe(\n        switchMap(() => this.stepService.hasOneProcessLinkType$),\n        take(1)\n      )\n      .subscribe((hasOneOption: boolean) => {\n        this.stepService.setProcessLinkTypeSteps('plugin', hasOneOption);\n      });\n  }\n\n  private openNextButtonSubscription(): void {\n    this._subscriptions.add(\n      this.buttonService.nextButtonClick$.subscribe(() => {\n        this.stepService.setConfigurePluginActionSteps();\n      })\n    );\n  }\n}\n","<!--\n  ~ Copyright 2015-2024 Ritense BV, the Netherlands.\n  ~\n  ~ Licensed under EUPL, Version 1.2 (the \"License\");\n  ~ you may not use this file except in compliance with the License.\n  ~ You may obtain a copy of the License at\n  ~\n  ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n  ~\n  ~ Unless required by applicable law or agreed to in writing, software\n  ~ distributed under the License is distributed on an \"AS IS\" basis,\n  ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n  ~ See the License for the specific language governing permissions and\n  ~ limitations under the License.\n  -->\n\n<ng-container *ngIf=\"pluginFunctions$ | async as pluginFunctions; else loading\">\n  <div class=\"choose-plugin-action\" *ngIf=\"pluginFunctions?.length > 0\">\n    <p class=\"step-description\">\n      {{ 'processLinkConfiguration.choosePluginActionDescription' | translate }}\n    </p>\n    <div class=\"action-tiles\">\n      <cds-tile-group\n        [multiple]=\"false\"\n        *ngIf=\"{selectedPluginDefinition: selectedPluginDefinition$ | async} as obs\"\n        (selected)=\"selected($event)\"\n      >\n        <cds-selection-tile\n          *ngFor=\"let pluginFunction of pluginFunctions\"\n          [value]=\"stringify(pluginFunction)\"\n          [selected]=\"false\"\n          >{{\n            pluginFunction.key | pluginTranslate: obs.selectedPluginDefinition.key | async\n          }}</cds-selection-tile\n        >\n      </cds-tile-group>\n    </div>\n  </div>\n  <ng-container *ngIf=\"!pluginFunctions || pluginFunctions?.length === 0\">\n    <ng-container *ngTemplateOutlet=\"noPluginFunctionsTemplate\"> </ng-container>\n  </ng-container>\n</ng-container>\n\n<ng-template #noPluginFunctionsTemplate>\n  <p class=\"step-description\">\n    {{ 'processLink.noPluginFunctions' | translate }}\n  </p>\n</ng-template>\n\n<ng-template #loading>\n  <div class=\"loading-container\">\n    <cds-loading></cds-loading>\n  </div>\n</ng-template>\n"]}
73
+ }], ctorParameters: () => [{ type: i1.ProcessLinkButtonService }, { type: i2.PluginManagementService }, { type: i1.PluginStateService }, { type: i1.ProcessLinkStepService }] });
74
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select-plugin-action.component.js","sourceRoot":"","sources":["../../../../../../../projects/valtimo/process-link/src/lib/components/select-plugin-action/select-plugin-action.component.ts","../../../../../../../projects/valtimo/process-link/src/lib/components/select-plugin-action/select-plugin-action.component.html"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;GAcG;AACH,OAAO,EAAC,SAAS,EAAoB,MAAM,eAAe,CAAC;AAE3D,OAAO,EAAa,EAAE,EAAE,YAAY,EAAC,MAAM,MAAM,CAAC;AAClD,OAAO,EAAC,SAAS,EAAE,IAAI,EAAC,MAAM,gBAAgB,CAAC;;;;;;;AAS/C,MAAM,OAAO,2BAA2B;IAgBtC,YACmB,aAAuC,EACvC,uBAAgD,EAChD,YAAgC,EAChC,WAAmC;QAHnC,kBAAa,GAAb,aAAa,CAA0B;QACvC,4BAAuB,GAAvB,uBAAuB,CAAyB;QAChD,iBAAY,GAAZ,YAAY,CAAoB;QAChC,gBAAW,GAAX,WAAW,CAAwB;QAnBtC,qBAAgB,GAC9B,IAAI,CAAC,YAAY,CAAC,yBAAyB,CAAC,IAAI,CAC9C,SAAS,CAAC,kBAAkB,CAAC,EAAE,CAC7B,kBAAkB;YAChB,CAAC,CAAC,IAAI,CAAC,uBAAuB,CAAC,kBAAkB,CAAC,kBAAkB,CAAC,GAAG,CAAC;YACzE,CAAC,CAAC,EAAE,CAAC,SAAS,CAAC,CAClB,CACF,CAAC;QACY,8BAAyB,GACvC,IAAI,CAAC,YAAY,CAAC,yBAAyB,CAAC;QAC9B,4BAAuB,GACrC,IAAI,CAAC,YAAY,CAAC,uBAAuB,CAAC;QAEpC,mBAAc,GAAG,IAAI,YAAY,EAAE,CAAC;IAOzC,CAAC;IAEG,QAAQ;QACb,IAAI,CAAC,0BAA0B,EAAE,CAAC;QAClC,IAAI,CAAC,0BAA0B,EAAE,CAAC;IACpC,CAAC;IAEM,WAAW;QAChB,IAAI,CAAC,cAAc,CAAC,WAAW,EAAE,CAAC;IACpC,CAAC;IAEM,cAAc,CAAC,cAA8B;QAClD,IAAI,CAAC,YAAY,CAAC,oBAAoB,CAAC,cAAc,CAAC,CAAC;IACzD,CAAC;IAEM,QAAQ,CAAC,KAAsB;QACpC,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC;QAC7C,IAAI,CAAC,aAAa,CAAC,gBAAgB,EAAE,CAAC;IACxC,CAAC;IAEM,SAAS,CAAC,MAAc;QAC7B,OAAO,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;IAChC,CAAC;IAEO,0BAA0B;QAChC,IAAI,CAAC,aAAa,CAAC,gBAAgB;aAChC,IAAI,CACH,SAAS,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,WAAW,CAAC,sBAAsB,CAAC,EACxD,IAAI,CAAC,CAAC,CAAC,CACR;aACA,SAAS,CAAC,CAAC,YAAqB,EAAE,EAAE;YACnC,IAAI,CAAC,WAAW,CAAC,uBAAuB,CAAC,QAAQ,EAAE,YAAY,CAAC,CAAC;QACnE,CAAC,CAAC,CAAC;IACP,CAAC;IAEO,0BAA0B;QAChC,IAAI,CAAC,cAAc,CAAC,GAAG,CACrB,IAAI,CAAC,aAAa,CAAC,gBAAgB,CAAC,SAAS,CAAC,GAAG,EAAE;YACjD,IAAI,CAAC,WAAW,CAAC,6BAA6B,EAAE,CAAC;QACnD,CAAC,CAAC,CACH,CAAC;IACJ,CAAC;+GA9DU,2BAA2B;mGAA3B,2BAA2B,oEC3BxC,m+DAsDA;;4FD3Ba,2BAA2B;kBALvC,SAAS;+BACE,8BAA8B","sourcesContent":["/*\n * Copyright 2015-2024 Ritense BV, the Netherlands.\n *\n * Licensed under EUPL, Version 1.2 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" basis,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\nimport {Component, OnDestroy, OnInit} from '@angular/core';\nimport {PluginDefinition, PluginFunction, PluginManagementService} from '@valtimo/plugin';\nimport {Observable, of, Subscription} from 'rxjs';\nimport {switchMap, take} from 'rxjs/operators';\n\nimport {ProcessLinkButtonService, ProcessLinkStepService, PluginStateService} from '../../services';\n\n@Component({\n  selector: 'valtimo-select-plugin-action',\n  templateUrl: './select-plugin-action.component.html',\n  styleUrls: ['./select-plugin-action.component.scss'],\n})\nexport class SelectPluginActionComponent implements OnInit, OnDestroy {\n  public readonly pluginFunctions$: Observable<Array<PluginFunction> | undefined> =\n    this.stateService.selectedPluginDefinition$.pipe(\n      switchMap(selectedDefinition =>\n        selectedDefinition\n          ? this.pluginManagementService.getPluginFunctions(selectedDefinition.key)\n          : of(undefined)\n      )\n    );\n  public readonly selectedPluginDefinition$: Observable<PluginDefinition> =\n    this.stateService.selectedPluginDefinition$;\n  public readonly selectedPluginFunction$: Observable<PluginFunction> =\n    this.stateService.selectedPluginFunction$;\n\n  private _subscriptions = new Subscription();\n\n  constructor(\n    private readonly buttonService: ProcessLinkButtonService,\n    private readonly pluginManagementService: PluginManagementService,\n    private readonly stateService: PluginStateService,\n    private readonly stepService: ProcessLinkStepService\n  ) {}\n\n  public ngOnInit(): void {\n    this.openBackButtonSubscription();\n    this.openNextButtonSubscription();\n  }\n\n  public ngOnDestroy(): void {\n    this._subscriptions.unsubscribe();\n  }\n\n  public selectFunction(pluginFunction: PluginFunction): void {\n    this.stateService.selectPluginFunction(pluginFunction);\n  }\n\n  public selected(event: {value: string}): void {\n    this.selectFunction(JSON.parse(event.value));\n    this.buttonService.enableNextButton();\n  }\n\n  public stringify(object: object): string {\n    return JSON.stringify(object);\n  }\n\n  private openBackButtonSubscription(): void {\n    this.buttonService.backButtonClick$\n      .pipe(\n        switchMap(() => this.stepService.hasOneProcessLinkType$),\n        take(1)\n      )\n      .subscribe((hasOneOption: boolean) => {\n        this.stepService.setProcessLinkTypeSteps('plugin', hasOneOption);\n      });\n  }\n\n  private openNextButtonSubscription(): void {\n    this._subscriptions.add(\n      this.buttonService.nextButtonClick$.subscribe(() => {\n        this.stepService.setConfigurePluginActionSteps();\n      })\n    );\n  }\n}\n","<!--\n  ~ Copyright 2015-2024 Ritense BV, the Netherlands.\n  ~\n  ~ Licensed under EUPL, Version 1.2 (the \"License\");\n  ~ you may not use this file except in compliance with the License.\n  ~ You may obtain a copy of the License at\n  ~\n  ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n  ~\n  ~ Unless required by applicable law or agreed to in writing, software\n  ~ distributed under the License is distributed on an \"AS IS\" basis,\n  ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n  ~ See the License for the specific language governing permissions and\n  ~ limitations under the License.\n  -->\n\n<ng-container *ngIf=\"pluginFunctions$ | async as pluginFunctions; else loading\">\n  <div class=\"choose-plugin-action\" *ngIf=\"pluginFunctions?.length > 0\">\n    <p class=\"step-description\">\n      {{ 'processLinkConfiguration.choosePluginActionDescription' | translate }}\n    </p>\n    <div class=\"action-tiles\">\n      <cds-tile-group\n        [multiple]=\"false\"\n        *ngIf=\"{selectedPluginDefinition: selectedPluginDefinition$ | async} as obs\"\n        (selected)=\"selected($event)\"\n      >\n        <cds-selection-tile\n          *ngFor=\"let pluginFunction of pluginFunctions\"\n          [value]=\"stringify(pluginFunction)\"\n          [selected]=\"false\"\n          >{{\n            pluginFunction.key | pluginTranslate: obs.selectedPluginDefinition.key | async\n          }}</cds-selection-tile\n        >\n      </cds-tile-group>\n    </div>\n  </div>\n  <ng-container *ngIf=\"!pluginFunctions || pluginFunctions?.length === 0\">\n    <ng-container *ngTemplateOutlet=\"noPluginFunctionsTemplate\"> </ng-container>\n  </ng-container>\n</ng-container>\n\n<ng-template #noPluginFunctionsTemplate>\n  <p class=\"step-description\">\n    {{ 'processLink.noPluginFunctions' | translate }}\n  </p>\n</ng-template>\n\n<ng-template #loading>\n  <div class=\"loading-container\">\n    <cds-loading></cds-loading>\n  </div>\n</ng-template>\n"]}