@valtimo/dossier-management 12.6.1 → 12.8.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (38) hide show
  1. package/esm2022/lib/components/dossier-management-detail/dossier-management-detail.component.mjs +2 -2
  2. package/esm2022/lib/components/dossier-management-list-columns/dossier-management-list-columns.component.mjs +1 -1
  3. package/esm2022/lib/components/dossier-management-search-fields/dossier-management-search-fields.component.mjs +1 -1
  4. package/esm2022/lib/components/dossier-management-widget-configurators/collection/dossier-management-widget-collection.component.mjs +22 -10
  5. package/esm2022/lib/components/dossier-management-widget-configurators/custom/dossier-management-widget-custom.component.mjs +17 -12
  6. package/esm2022/lib/components/dossier-management-widget-configurators/fields/column/dossier-management-widget-fields-column.component.mjs +18 -5
  7. package/esm2022/lib/components/dossier-management-widget-configurators/fields/dossier-management-widget-fields.component.mjs +15 -10
  8. package/esm2022/lib/components/dossier-management-widget-configurators/formio/dossier-management-widget-formio.component.mjs +14 -9
  9. package/esm2022/lib/components/dossier-management-widget-configurators/index.mjs +4 -3
  10. package/esm2022/lib/components/dossier-management-widget-configurators/process-selector/dossier-management-widget-process-selector.component.mjs +100 -0
  11. package/esm2022/lib/components/dossier-management-widget-configurators/table/dossier-management-widget-table.component.mjs +23 -11
  12. package/esm2022/lib/components/dossier-management-widget-tab/editor/dossier-management-widgets-editor.component.mjs +12 -1
  13. package/esm2022/lib/components/dossier-management-widget-wizard/dossier-management-widget-wizard.component.mjs +2 -2
  14. package/esm2022/lib/services/widget-wizard.service.mjs +5 -2
  15. package/fesm2022/valtimo-dossier-management.mjs +512 -371
  16. package/fesm2022/valtimo-dossier-management.mjs.map +1 -1
  17. package/lib/components/dossier-management-detail/dossier-management-detail.component.d.ts.map +1 -1
  18. package/lib/components/dossier-management-widget-configurators/collection/dossier-management-widget-collection.component.d.ts +10 -3
  19. package/lib/components/dossier-management-widget-configurators/collection/dossier-management-widget-collection.component.d.ts.map +1 -1
  20. package/lib/components/dossier-management-widget-configurators/custom/dossier-management-widget-custom.component.d.ts +8 -5
  21. package/lib/components/dossier-management-widget-configurators/custom/dossier-management-widget-custom.component.d.ts.map +1 -1
  22. package/lib/components/dossier-management-widget-configurators/fields/column/dossier-management-widget-fields-column.component.d.ts +6 -2
  23. package/lib/components/dossier-management-widget-configurators/fields/column/dossier-management-widget-fields-column.component.d.ts.map +1 -1
  24. package/lib/components/dossier-management-widget-configurators/fields/dossier-management-widget-fields.component.d.ts +6 -2
  25. package/lib/components/dossier-management-widget-configurators/fields/dossier-management-widget-fields.component.d.ts.map +1 -1
  26. package/lib/components/dossier-management-widget-configurators/formio/dossier-management-widget-formio.component.d.ts +4 -1
  27. package/lib/components/dossier-management-widget-configurators/formio/dossier-management-widget-formio.component.d.ts.map +1 -1
  28. package/lib/components/dossier-management-widget-configurators/index.d.ts +3 -2
  29. package/lib/components/dossier-management-widget-configurators/index.d.ts.map +1 -1
  30. package/lib/components/dossier-management-widget-configurators/process-selector/dossier-management-widget-process-selector.component.d.ts +29 -0
  31. package/lib/components/dossier-management-widget-configurators/process-selector/dossier-management-widget-process-selector.component.d.ts.map +1 -0
  32. package/lib/components/dossier-management-widget-configurators/table/dossier-management-widget-table.component.d.ts +10 -3
  33. package/lib/components/dossier-management-widget-configurators/table/dossier-management-widget-table.component.d.ts.map +1 -1
  34. package/lib/components/dossier-management-widget-tab/editor/dossier-management-widgets-editor.component.d.ts +1 -0
  35. package/lib/components/dossier-management-widget-tab/editor/dossier-management-widgets-editor.component.d.ts.map +1 -1
  36. package/lib/services/widget-wizard.service.d.ts +2 -1
  37. package/lib/services/widget-wizard.service.d.ts.map +1 -1
  38. package/package.json +1 -1
@@ -13,35 +13,39 @@
13
13
  * See the License for the specific language governing permissions and
14
14
  * limitations under the License.
15
15
  */
16
- import { ChangeDetectionStrategy, Component, EventEmitter, Inject, Optional, Output, } from '@angular/core';
17
16
  import { CommonModule } from '@angular/common';
18
- import { TranslateModule } from '@ngx-translate/core';
19
- import { DropdownModule, InputModule, SelectModule } from 'carbon-components-angular';
17
+ import { ChangeDetectionStrategy, Component, EventEmitter, Inject, Optional, Output, } from '@angular/core';
20
18
  import { ReactiveFormsModule, Validators } from '@angular/forms';
19
+ import { TranslateModule } from '@ngx-translate/core';
21
20
  import { CARBON_THEME, CurrentCarbonTheme } from '@valtimo/components';
22
21
  import { CUSTOM_CASE_WIDGET_TOKEN, } from '@valtimo/dossier';
22
+ import { DropdownModule, InputModule, SelectModule } from 'carbon-components-angular';
23
23
  import { BehaviorSubject, combineLatest, filter, map, Subscription } from 'rxjs';
24
+ import { DossierManagementWidgetProcessSelectorComponent } from '../process-selector/dossier-management-widget-process-selector.component';
24
25
  import * as i0 from "@angular/core";
25
26
  import * as i1 from "@valtimo/components";
26
27
  import * as i2 from "@angular/forms";
27
28
  import * as i3 from "../../../services";
28
- import * as i4 from "@angular/common";
29
- import * as i5 from "@ngx-translate/core";
30
- import * as i6 from "carbon-components-angular";
29
+ import * as i4 from "@angular/router";
30
+ import * as i5 from "@angular/common";
31
+ import * as i6 from "@ngx-translate/core";
32
+ import * as i7 from "carbon-components-angular";
31
33
  export class DossierManagementWidgetCustomComponent {
32
34
  get widgetTitle() {
33
35
  return this.form.get('widgetTitle');
34
36
  }
35
- constructor(customCaseWidgetConfig, cdsThemeService, fb, widgetWizardService) {
37
+ constructor(customCaseWidgetConfig, cdsThemeService, fb, widgetWizardService, route) {
36
38
  this.customCaseWidgetConfig = customCaseWidgetConfig;
37
39
  this.cdsThemeService = cdsThemeService;
38
40
  this.fb = fb;
39
41
  this.widgetWizardService = widgetWizardService;
42
+ this.route = route;
40
43
  this.changeValidEvent = new EventEmitter();
41
44
  this.form = this.fb.group({
42
45
  widgetTitle: this.fb.control(this.widgetWizardService.widgetTitle(), Validators.required),
43
46
  });
44
47
  this.theme$ = this.cdsThemeService.currentTheme$.pipe(map((theme) => theme === CurrentCarbonTheme.G10 ? CARBON_THEME.WHITE : CARBON_THEME.G90));
48
+ this.documentDefinitionName$ = this.route.paramMap.pipe(map((paramMap) => paramMap.get('name') ?? ''));
45
49
  this._selectedCustomComponentKey$ = new BehaviorSubject(null);
46
50
  this._customCaseWidgetConfig$ = new BehaviorSubject({});
47
51
  this.componentListItems$ = combineLatest([
@@ -80,8 +84,8 @@ export class DossierManagementWidgetCustomComponent {
80
84
  this._selectedCustomComponentKey$.next(componentKey);
81
85
  this.changeValidEvent.emit(true);
82
86
  }
83
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DossierManagementWidgetCustomComponent, deps: [{ token: CUSTOM_CASE_WIDGET_TOKEN, optional: true }, { token: i1.CdsThemeService }, { token: i2.FormBuilder }, { token: i3.WidgetWizardService }], target: i0.ɵɵFactoryTarget.Component }); }
84
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: DossierManagementWidgetCustomComponent, isStandalone: true, selector: "ng-component", outputs: { changeValidEvent: "changeValidEvent" }, 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<form\n class=\"valtimo-dossier-management-widget-custom\"\n [formGroup]=\"form\"\n [attr.data-carbon-theme]=\"theme$ | async\"\n>\n <cds-text-label class=\"valtimo-dossier-management-widget-field__input\">\n {{ 'widgetTabManagement.content.widgetTitle' | translate }}\n\n <input\n formControlName=\"widgetTitle\"\n cdsText\n [placeholder]=\"'widgetTabManagement.content.widgetTitlePlaceholder' | translate\"\n type=\"text\"\n />\n </cds-text-label>\n\n <cds-label class=\"dropdown-label\">\n {{ 'widgetTabManagement.content.custom.selectComponent' | translate }}\n\n <cds-dropdown\n *ngIf=\"componentListItems$ | async as componentListItems\"\n [appendInline]=\"false\"\n [placeholder]=\"'widgetTabManagement.content.custom.placeholder' | translate\"\n [disabled]=\"componentListItems.length === 0\"\n (selected)=\"componentDropDownChange($event)\"\n >\n <cds-dropdown-list [items]=\"componentListItems\"> </cds-dropdown-list>\n </cds-dropdown>\n </cds-label>\n</form>\n", styles: [".valtimo-dossier-management-widget-custom{display:flex;flex-direction:column}.valtimo-dossier-management-widget-custom>*:first-child{margin-bottom:16px}.valtimo-dossier-management-widget-custom ::ng-deep .dropdown-label label{display:flex;flex-direction:column;width:100%}.valtimo-dossier-management-widget-custom ::ng-deep .dropdown-label cds-dropdown{margin-top:8px}\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: "ngmodule", type: CommonModule }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i4.AsyncPipe, name: "async" }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i5.TranslatePipe, name: "translate" }, { kind: "ngmodule", type: InputModule }, { kind: "component", type: i6.Label, selector: "cds-label, ibm-label", inputs: ["labelInputID", "disabled", "skeleton", "helperText", "invalidText", "invalid", "warn", "warnText", "ariaLabel"] }, { kind: "component", type: i6.TextInputLabelComponent, selector: "cds-text-label, ibm-text-label", inputs: ["labelInputID", "disabled", "skeleton", "labelTemplate", "textInputTemplate", "helperText", "invalidText", "invalid", "warn", "warnText", "ariaLabel"] }, { kind: "directive", type: i6.TextInput, selector: "[cdsText], [ibmText]", inputs: ["theme", "size", "invalid", "warn", "skeleton"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i2.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i2.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i2.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "ngmodule", type: SelectModule }, { kind: "ngmodule", type: DropdownModule }, { kind: "component", type: i6.Dropdown, selector: "cds-dropdown, ibm-dropdown", inputs: ["id", "label", "hideLabel", "helperText", "placeholder", "displayValue", "clearText", "size", "type", "theme", "disabled", "skeleton", "inline", "disableArrowKeys", "invalid", "invalidText", "warn", "warnText", "appendInline", "scrollableContainer", "itemValueKey", "selectionFeedback", "menuButtonLabel", "selectedLabel", "dropUp"], outputs: ["selected", "onClose", "close"] }, { kind: "component", type: i6.DropdownList, selector: "cds-dropdown-list, ibm-dropdown-list", inputs: ["ariaLabel", "items", "listTpl", "type", "showTitles"], outputs: ["select", "scroll", "blurIntent"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
87
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DossierManagementWidgetCustomComponent, deps: [{ token: CUSTOM_CASE_WIDGET_TOKEN, optional: true }, { token: i1.CdsThemeService }, { token: i2.FormBuilder }, { token: i3.WidgetWizardService }, { token: i4.ActivatedRoute }], target: i0.ɵɵFactoryTarget.Component }); }
88
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: DossierManagementWidgetCustomComponent, isStandalone: true, selector: "ng-component", outputs: { changeValidEvent: "changeValidEvent" }, 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<form\n class=\"valtimo-dossier-management-widget-custom\"\n [formGroup]=\"form\"\n [attr.data-carbon-theme]=\"theme$ | async\"\n>\n <cds-text-label class=\"valtimo-dossier-management-widget-field__input\">\n {{ 'widgetTabManagement.content.widgetTitle' | translate }}\n\n <input\n formControlName=\"widgetTitle\"\n cdsText\n [placeholder]=\"'widgetTabManagement.content.widgetTitlePlaceholder' | translate\"\n type=\"text\"\n />\n </cds-text-label>\n\n <valtimo-dossier-management-widget-process-selector\n [documentDefinitionName]=\"documentDefinitionName$ | async\"\n ></valtimo-dossier-management-widget-process-selector>\n\n <cds-label class=\"dropdown-label\">\n {{ 'widgetTabManagement.content.custom.selectComponent' | translate }}\n\n <cds-dropdown\n *ngIf=\"componentListItems$ | async as componentListItems\"\n [appendInline]=\"false\"\n [placeholder]=\"'widgetTabManagement.content.custom.placeholder' | translate\"\n [disabled]=\"componentListItems.length === 0\"\n (selected)=\"componentDropDownChange($event)\"\n >\n <cds-dropdown-list [items]=\"componentListItems\"> </cds-dropdown-list>\n </cds-dropdown>\n </cds-label>\n</form>\n", styles: [".valtimo-dossier-management-widget-custom{display:flex;flex-direction:column;gap:16px}.valtimo-dossier-management-widget-custom ::ng-deep .dropdown-label label{display:flex;flex-direction:column;width:100%}.valtimo-dossier-management-widget-custom ::ng-deep .dropdown-label cds-dropdown{margin-top:8px}\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: "ngmodule", type: CommonModule }, { kind: "directive", type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i5.AsyncPipe, name: "async" }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i6.TranslatePipe, name: "translate" }, { kind: "ngmodule", type: InputModule }, { kind: "component", type: i7.Label, selector: "cds-label, ibm-label", inputs: ["labelInputID", "disabled", "skeleton", "helperText", "invalidText", "invalid", "warn", "warnText", "ariaLabel"] }, { kind: "component", type: i7.TextInputLabelComponent, selector: "cds-text-label, ibm-text-label", inputs: ["labelInputID", "disabled", "skeleton", "labelTemplate", "textInputTemplate", "helperText", "invalidText", "invalid", "warn", "warnText", "ariaLabel"] }, { kind: "directive", type: i7.TextInput, selector: "[cdsText], [ibmText]", inputs: ["theme", "size", "invalid", "warn", "skeleton"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i2.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i2.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i2.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "ngmodule", type: SelectModule }, { kind: "ngmodule", type: DropdownModule }, { kind: "component", type: i7.Dropdown, selector: "cds-dropdown, ibm-dropdown", inputs: ["id", "label", "hideLabel", "helperText", "placeholder", "displayValue", "clearText", "size", "type", "theme", "disabled", "skeleton", "inline", "disableArrowKeys", "invalid", "invalidText", "warn", "warnText", "appendInline", "scrollableContainer", "itemValueKey", "selectionFeedback", "menuButtonLabel", "selectedLabel", "dropUp"], outputs: ["selected", "onClose", "close"] }, { kind: "component", type: i7.DropdownList, selector: "cds-dropdown-list, ibm-dropdown-list", inputs: ["ariaLabel", "items", "listTpl", "type", "showTitles"], outputs: ["select", "scroll", "blurIntent"] }, { kind: "component", type: DossierManagementWidgetProcessSelectorComponent, selector: "valtimo-dossier-management-widget-process-selector", inputs: ["documentDefinitionName"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
85
89
  }
86
90
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DossierManagementWidgetCustomComponent, decorators: [{
87
91
  type: Component,
@@ -92,13 +96,14 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
92
96
  ReactiveFormsModule,
93
97
  SelectModule,
94
98
  DropdownModule,
95
- ], 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<form\n class=\"valtimo-dossier-management-widget-custom\"\n [formGroup]=\"form\"\n [attr.data-carbon-theme]=\"theme$ | async\"\n>\n <cds-text-label class=\"valtimo-dossier-management-widget-field__input\">\n {{ 'widgetTabManagement.content.widgetTitle' | translate }}\n\n <input\n formControlName=\"widgetTitle\"\n cdsText\n [placeholder]=\"'widgetTabManagement.content.widgetTitlePlaceholder' | translate\"\n type=\"text\"\n />\n </cds-text-label>\n\n <cds-label class=\"dropdown-label\">\n {{ 'widgetTabManagement.content.custom.selectComponent' | translate }}\n\n <cds-dropdown\n *ngIf=\"componentListItems$ | async as componentListItems\"\n [appendInline]=\"false\"\n [placeholder]=\"'widgetTabManagement.content.custom.placeholder' | translate\"\n [disabled]=\"componentListItems.length === 0\"\n (selected)=\"componentDropDownChange($event)\"\n >\n <cds-dropdown-list [items]=\"componentListItems\"> </cds-dropdown-list>\n </cds-dropdown>\n </cds-label>\n</form>\n", styles: [".valtimo-dossier-management-widget-custom{display:flex;flex-direction:column}.valtimo-dossier-management-widget-custom>*:first-child{margin-bottom:16px}.valtimo-dossier-management-widget-custom ::ng-deep .dropdown-label label{display:flex;flex-direction:column;width:100%}.valtimo-dossier-management-widget-custom ::ng-deep .dropdown-label cds-dropdown{margin-top:8px}\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"] }]
99
+ DossierManagementWidgetProcessSelectorComponent,
100
+ ], 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<form\n class=\"valtimo-dossier-management-widget-custom\"\n [formGroup]=\"form\"\n [attr.data-carbon-theme]=\"theme$ | async\"\n>\n <cds-text-label class=\"valtimo-dossier-management-widget-field__input\">\n {{ 'widgetTabManagement.content.widgetTitle' | translate }}\n\n <input\n formControlName=\"widgetTitle\"\n cdsText\n [placeholder]=\"'widgetTabManagement.content.widgetTitlePlaceholder' | translate\"\n type=\"text\"\n />\n </cds-text-label>\n\n <valtimo-dossier-management-widget-process-selector\n [documentDefinitionName]=\"documentDefinitionName$ | async\"\n ></valtimo-dossier-management-widget-process-selector>\n\n <cds-label class=\"dropdown-label\">\n {{ 'widgetTabManagement.content.custom.selectComponent' | translate }}\n\n <cds-dropdown\n *ngIf=\"componentListItems$ | async as componentListItems\"\n [appendInline]=\"false\"\n [placeholder]=\"'widgetTabManagement.content.custom.placeholder' | translate\"\n [disabled]=\"componentListItems.length === 0\"\n (selected)=\"componentDropDownChange($event)\"\n >\n <cds-dropdown-list [items]=\"componentListItems\"> </cds-dropdown-list>\n </cds-dropdown>\n </cds-label>\n</form>\n", styles: [".valtimo-dossier-management-widget-custom{display:flex;flex-direction:column;gap:16px}.valtimo-dossier-management-widget-custom ::ng-deep .dropdown-label label{display:flex;flex-direction:column;width:100%}.valtimo-dossier-management-widget-custom ::ng-deep .dropdown-label cds-dropdown{margin-top:8px}\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"] }]
96
101
  }], ctorParameters: () => [{ type: undefined, decorators: [{
97
102
  type: Optional
98
103
  }, {
99
104
  type: Inject,
100
105
  args: [CUSTOM_CASE_WIDGET_TOKEN]
101
- }] }, { type: i1.CdsThemeService }, { type: i2.FormBuilder }, { type: i3.WidgetWizardService }], propDecorators: { changeValidEvent: [{
106
+ }] }, { type: i1.CdsThemeService }, { type: i2.FormBuilder }, { type: i3.WidgetWizardService }, { type: i4.ActivatedRoute }], propDecorators: { changeValidEvent: [{
102
107
  type: Output
103
108
  }] } });
104
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dossier-management-widget-custom.component.js","sourceRoot":"","sources":["../../../../../../../../projects/valtimo/dossier-management/src/lib/components/dossier-management-widget-configurators/custom/dossier-management-widget-custom.component.ts","../../../../../../../../projects/valtimo/dossier-management/src/lib/components/dossier-management-widget-configurators/custom/dossier-management-widget-custom.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 {\n  ChangeDetectionStrategy,\n  Component,\n  EventEmitter,\n  Inject,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n} from '@angular/core';\nimport {CommonModule} from '@angular/common';\nimport {TranslateModule} from '@ngx-translate/core';\nimport {DropdownModule, InputModule, SelectModule} from 'carbon-components-angular';\nimport {AbstractControl, FormBuilder, ReactiveFormsModule, Validators} from '@angular/forms';\nimport {WidgetContentComponent} from '../../../models';\nimport {CARBON_THEME, CdsThemeService, CurrentCarbonTheme} from '@valtimo/components';\nimport {WidgetWizardService} from '../../../services';\nimport {\n  CUSTOM_CASE_WIDGET_TOKEN,\n  CustomCaseWidgetConfig,\n  WidgetCustomContent,\n} from '@valtimo/dossier';\nimport {BehaviorSubject, combineLatest, filter, map, Observable, Subscription} from 'rxjs';\nimport {ListItem} from 'carbon-components-angular/dropdown/list-item.interface';\n\n@Component({\n  templateUrl: './dossier-management-widget-custom.component.html',\n  styleUrls: ['./dossier-management-widget-custom.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [\n    CommonModule,\n    TranslateModule,\n    InputModule,\n    ReactiveFormsModule,\n    SelectModule,\n    DropdownModule,\n  ],\n})\nexport class DossierManagementWidgetCustomComponent\n  implements WidgetContentComponent, OnDestroy, OnInit\n{\n  @Output() public readonly changeValidEvent = new EventEmitter<boolean>();\n\n  public readonly form = this.fb.group({\n    widgetTitle: this.fb.control(this.widgetWizardService.widgetTitle(), Validators.required),\n  });\n\n  public get widgetTitle(): AbstractControl<string> {\n    return this.form.get('widgetTitle');\n  }\n\n  public readonly theme$ = this.cdsThemeService.currentTheme$.pipe(\n    map((theme: CurrentCarbonTheme) =>\n      theme === CurrentCarbonTheme.G10 ? CARBON_THEME.WHITE : CARBON_THEME.G90\n    )\n  );\n\n  private readonly _selectedCustomComponentKey$ = new BehaviorSubject<string | null>(null);\n  private readonly _customCaseWidgetConfig$ = new BehaviorSubject<CustomCaseWidgetConfig>({});\n\n  public readonly componentListItems$: Observable<ListItem[]> = combineLatest([\n    this._customCaseWidgetConfig$,\n    this._selectedCustomComponentKey$,\n  ]).pipe(\n    filter(([config]) => !!config),\n    map(([config, selectedKey]) =>\n      Object.keys(config).reduce(\n        (acc, curr) => [...acc, {content: curr, selected: curr === selectedKey}],\n        []\n      )\n    )\n  );\n\n  private readonly _subscriptions = new Subscription();\n\n  constructor(\n    @Optional()\n    @Inject(CUSTOM_CASE_WIDGET_TOKEN)\n    private readonly customCaseWidgetConfig: CustomCaseWidgetConfig,\n    private readonly cdsThemeService: CdsThemeService,\n    private readonly fb: FormBuilder,\n    private readonly widgetWizardService: WidgetWizardService\n  ) {\n    if (customCaseWidgetConfig) this._customCaseWidgetConfig$.next(customCaseWidgetConfig);\n  }\n\n  public componentDropDownChange(event: {\n    item: {content: string; selected: boolean};\n    isUpdate: boolean;\n  }): void {\n    const componentKey = event?.item?.content;\n\n    if (!componentKey) return;\n\n    this._selectedCustomComponentKey$.next(componentKey);\n    this.widgetWizardService.widgetContent.set({componentKey});\n    this.changeValidEvent.emit(true);\n  }\n\n  public ngOnInit(): void {\n    this.openTitleSubscription();\n    this.prefill();\n  }\n\n  public ngOnDestroy(): void {\n    this._subscriptions.unsubscribe();\n  }\n\n  private openTitleSubscription(): void {\n    this._subscriptions.add(\n      this.widgetTitle.valueChanges.subscribe(title => {\n        this.widgetWizardService.widgetTitle.set(title);\n      })\n    );\n  }\n\n  private prefill(): void {\n    const componentKey = (this.widgetWizardService.widgetContent() as WidgetCustomContent)\n      ?.componentKey;\n\n    if (!componentKey || Object.keys(this.customCaseWidgetConfig || {}).length === 0) return;\n\n    this._selectedCustomComponentKey$.next(componentKey);\n    this.changeValidEvent.emit(true);\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<form\n  class=\"valtimo-dossier-management-widget-custom\"\n  [formGroup]=\"form\"\n  [attr.data-carbon-theme]=\"theme$ | async\"\n>\n  <cds-text-label class=\"valtimo-dossier-management-widget-field__input\">\n    {{ 'widgetTabManagement.content.widgetTitle' | translate }}\n\n    <input\n      formControlName=\"widgetTitle\"\n      cdsText\n      [placeholder]=\"'widgetTabManagement.content.widgetTitlePlaceholder' | translate\"\n      type=\"text\"\n    />\n  </cds-text-label>\n\n  <cds-label class=\"dropdown-label\">\n    {{ 'widgetTabManagement.content.custom.selectComponent' | translate }}\n\n    <cds-dropdown\n      *ngIf=\"componentListItems$ | async as componentListItems\"\n      [appendInline]=\"false\"\n      [placeholder]=\"'widgetTabManagement.content.custom.placeholder' | translate\"\n      [disabled]=\"componentListItems.length === 0\"\n      (selected)=\"componentDropDownChange($event)\"\n    >\n      <cds-dropdown-list [items]=\"componentListItems\"> </cds-dropdown-list>\n    </cds-dropdown>\n  </cds-label>\n</form>\n"]}
109
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dossier-management-widget-custom.component.js","sourceRoot":"","sources":["../../../../../../../../projects/valtimo/dossier-management/src/lib/components/dossier-management-widget-configurators/custom/dossier-management-widget-custom.component.ts","../../../../../../../../projects/valtimo/dossier-management/src/lib/components/dossier-management-widget-configurators/custom/dossier-management-widget-custom.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 {CommonModule} from '@angular/common';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  EventEmitter,\n  Inject,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n} from '@angular/core';\nimport {AbstractControl, FormBuilder, ReactiveFormsModule, Validators} from '@angular/forms';\nimport {ActivatedRoute, ParamMap} from '@angular/router';\nimport {TranslateModule} from '@ngx-translate/core';\nimport {CARBON_THEME, CdsThemeService, CurrentCarbonTheme} from '@valtimo/components';\nimport {\n  CUSTOM_CASE_WIDGET_TOKEN,\n  CustomCaseWidgetConfig,\n  WidgetCustomContent,\n} from '@valtimo/dossier';\nimport {DropdownModule, InputModule, SelectModule} from 'carbon-components-angular';\nimport {ListItem} from 'carbon-components-angular/dropdown/list-item.interface';\nimport {BehaviorSubject, combineLatest, filter, map, Observable, Subscription} from 'rxjs';\nimport {WidgetContentComponent} from '../../../models';\nimport {WidgetWizardService} from '../../../services';\nimport {DossierManagementWidgetProcessSelectorComponent} from '../process-selector/dossier-management-widget-process-selector.component';\n\n@Component({\n  templateUrl: './dossier-management-widget-custom.component.html',\n  styleUrls: ['./dossier-management-widget-custom.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [\n    CommonModule,\n    TranslateModule,\n    InputModule,\n    ReactiveFormsModule,\n    SelectModule,\n    DropdownModule,\n    DossierManagementWidgetProcessSelectorComponent,\n  ],\n})\nexport class DossierManagementWidgetCustomComponent\n  implements WidgetContentComponent, OnDestroy, OnInit\n{\n  @Output() public readonly changeValidEvent = new EventEmitter<boolean>();\n\n  public readonly form = this.fb.group({\n    widgetTitle: this.fb.control(this.widgetWizardService.widgetTitle(), Validators.required),\n  });\n\n  public get widgetTitle(): AbstractControl<string> {\n    return this.form.get('widgetTitle');\n  }\n\n  public readonly theme$ = this.cdsThemeService.currentTheme$.pipe(\n    map((theme: CurrentCarbonTheme) =>\n      theme === CurrentCarbonTheme.G10 ? CARBON_THEME.WHITE : CARBON_THEME.G90\n    )\n  );\n\n  public readonly documentDefinitionName$: Observable<string> = this.route.paramMap.pipe(\n    map((paramMap: ParamMap) => paramMap.get('name') ?? '')\n  );\n\n  private readonly _selectedCustomComponentKey$ = new BehaviorSubject<string | null>(null);\n  private readonly _customCaseWidgetConfig$ = new BehaviorSubject<CustomCaseWidgetConfig>({});\n\n  public readonly componentListItems$: Observable<ListItem[]> = combineLatest([\n    this._customCaseWidgetConfig$,\n    this._selectedCustomComponentKey$,\n  ]).pipe(\n    filter(([config]) => !!config),\n    map(([config, selectedKey]) =>\n      Object.keys(config).reduce(\n        (acc, curr) => [...acc, {content: curr, selected: curr === selectedKey}],\n        []\n      )\n    )\n  );\n\n  private readonly _subscriptions = new Subscription();\n\n  constructor(\n    @Optional()\n    @Inject(CUSTOM_CASE_WIDGET_TOKEN)\n    private readonly customCaseWidgetConfig: CustomCaseWidgetConfig,\n    private readonly cdsThemeService: CdsThemeService,\n    private readonly fb: FormBuilder,\n    private readonly widgetWizardService: WidgetWizardService,\n    private readonly route: ActivatedRoute\n  ) {\n    if (customCaseWidgetConfig) this._customCaseWidgetConfig$.next(customCaseWidgetConfig);\n  }\n\n  public componentDropDownChange(event: {\n    item: {content: string; selected: boolean};\n    isUpdate: boolean;\n  }): void {\n    const componentKey = event?.item?.content;\n\n    if (!componentKey) return;\n\n    this._selectedCustomComponentKey$.next(componentKey);\n    this.widgetWizardService.widgetContent.set({componentKey});\n    this.changeValidEvent.emit(true);\n  }\n\n  public ngOnInit(): void {\n    this.openTitleSubscription();\n    this.prefill();\n  }\n\n  public ngOnDestroy(): void {\n    this._subscriptions.unsubscribe();\n  }\n\n  private openTitleSubscription(): void {\n    this._subscriptions.add(\n      this.widgetTitle.valueChanges.subscribe(title => {\n        this.widgetWizardService.widgetTitle.set(title);\n      })\n    );\n  }\n\n  private prefill(): void {\n    const componentKey = (this.widgetWizardService.widgetContent() as WidgetCustomContent)\n      ?.componentKey;\n\n    if (!componentKey || Object.keys(this.customCaseWidgetConfig || {}).length === 0) return;\n\n    this._selectedCustomComponentKey$.next(componentKey);\n    this.changeValidEvent.emit(true);\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<form\n  class=\"valtimo-dossier-management-widget-custom\"\n  [formGroup]=\"form\"\n  [attr.data-carbon-theme]=\"theme$ | async\"\n>\n  <cds-text-label class=\"valtimo-dossier-management-widget-field__input\">\n    {{ 'widgetTabManagement.content.widgetTitle' | translate }}\n\n    <input\n      formControlName=\"widgetTitle\"\n      cdsText\n      [placeholder]=\"'widgetTabManagement.content.widgetTitlePlaceholder' | translate\"\n      type=\"text\"\n    />\n  </cds-text-label>\n\n  <valtimo-dossier-management-widget-process-selector\n    [documentDefinitionName]=\"documentDefinitionName$ | async\"\n  ></valtimo-dossier-management-widget-process-selector>\n\n  <cds-label class=\"dropdown-label\">\n    {{ 'widgetTabManagement.content.custom.selectComponent' | translate }}\n\n    <cds-dropdown\n      *ngIf=\"componentListItems$ | async as componentListItems\"\n      [appendInline]=\"false\"\n      [placeholder]=\"'widgetTabManagement.content.custom.placeholder' | translate\"\n      [disabled]=\"componentListItems.length === 0\"\n      (selected)=\"componentDropDownChange($event)\"\n    >\n      <cds-dropdown-list [items]=\"componentListItems\"> </cds-dropdown-list>\n    </cds-dropdown>\n  </cds-label>\n</form>\n"]}