@valtimo/dossier-management 12.6.0 → 12.7.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/components/dossier-management-list-columns/dossier-management-list-columns.component.mjs +1 -1
- package/esm2022/lib/components/dossier-management-search-fields/dossier-management-search-fields.component.mjs +1 -1
- package/esm2022/lib/components/dossier-management-widget-configurators/collection/dossier-management-widget-collection.component.mjs +13 -8
- package/esm2022/lib/components/dossier-management-widget-configurators/custom/dossier-management-widget-custom.component.mjs +17 -12
- package/esm2022/lib/components/dossier-management-widget-configurators/fields/dossier-management-widget-fields.component.mjs +15 -10
- package/esm2022/lib/components/dossier-management-widget-configurators/formio/dossier-management-widget-formio.component.mjs +14 -9
- package/esm2022/lib/components/dossier-management-widget-configurators/index.mjs +4 -3
- package/esm2022/lib/components/dossier-management-widget-configurators/process-selector/dossier-management-widget-process-selector.component.mjs +100 -0
- package/esm2022/lib/components/dossier-management-widget-configurators/table/dossier-management-widget-table.component.mjs +14 -9
- package/esm2022/lib/components/dossier-management-widget-tab/editor/dossier-management-widgets-editor.component.mjs +12 -1
- package/esm2022/lib/components/dossier-management-widget-wizard/dossier-management-widget-wizard.component.mjs +2 -2
- package/esm2022/lib/services/widget-wizard.service.mjs +5 -2
- package/fesm2022/valtimo-dossier-management.mjs +482 -368
- package/fesm2022/valtimo-dossier-management.mjs.map +1 -1
- package/lib/components/dossier-management-widget-configurators/collection/dossier-management-widget-collection.component.d.ts +4 -1
- package/lib/components/dossier-management-widget-configurators/collection/dossier-management-widget-collection.component.d.ts.map +1 -1
- package/lib/components/dossier-management-widget-configurators/custom/dossier-management-widget-custom.component.d.ts +8 -5
- package/lib/components/dossier-management-widget-configurators/custom/dossier-management-widget-custom.component.d.ts.map +1 -1
- package/lib/components/dossier-management-widget-configurators/fields/dossier-management-widget-fields.component.d.ts +6 -2
- package/lib/components/dossier-management-widget-configurators/fields/dossier-management-widget-fields.component.d.ts.map +1 -1
- package/lib/components/dossier-management-widget-configurators/formio/dossier-management-widget-formio.component.d.ts +4 -1
- package/lib/components/dossier-management-widget-configurators/formio/dossier-management-widget-formio.component.d.ts.map +1 -1
- package/lib/components/dossier-management-widget-configurators/index.d.ts +3 -2
- package/lib/components/dossier-management-widget-configurators/index.d.ts.map +1 -1
- package/lib/components/dossier-management-widget-configurators/process-selector/dossier-management-widget-process-selector.component.d.ts +29 -0
- package/lib/components/dossier-management-widget-configurators/process-selector/dossier-management-widget-process-selector.component.d.ts.map +1 -0
- package/lib/components/dossier-management-widget-configurators/table/dossier-management-widget-table.component.d.ts +4 -1
- package/lib/components/dossier-management-widget-configurators/table/dossier-management-widget-table.component.d.ts.map +1 -1
- package/lib/components/dossier-management-widget-tab/editor/dossier-management-widgets-editor.component.d.ts +1 -0
- package/lib/components/dossier-management-widget-tab/editor/dossier-management-widgets-editor.component.d.ts.map +1 -1
- package/lib/services/widget-wizard.service.d.ts +2 -1
- package/lib/services/widget-wizard.service.d.ts.map +1 -1
- 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 {
|
|
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/
|
|
29
|
-
import * as i5 from "@
|
|
30
|
-
import * as i6 from "
|
|
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
|
|
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
|
-
|
|
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"]}
|
|
@@ -21,17 +21,20 @@ import { CARBON_THEME, CurrentCarbonTheme, InputLabelModule, } from '@valtimo/co
|
|
|
21
21
|
import { ButtonModule, IconModule, InputModule, Tab, TabsModule } from 'carbon-components-angular';
|
|
22
22
|
import { debounceTime, map, Subscription } from 'rxjs';
|
|
23
23
|
import { DossierManagementWidgetFieldsColumnComponent } from './column/dossier-management-widget-fields-column.component';
|
|
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
|
-
import * as i3 from "
|
|
28
|
-
import * as i4 from "
|
|
29
|
-
import * as i5 from "@
|
|
30
|
-
import * as i6 from "
|
|
28
|
+
import * as i3 from "@angular/router";
|
|
29
|
+
import * as i4 from "../../../services";
|
|
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 DossierManagementWidgetFieldsComponent {
|
|
32
|
-
constructor(cdsThemeService, fb, widgetWizardService) {
|
|
34
|
+
constructor(cdsThemeService, fb, route, widgetWizardService) {
|
|
33
35
|
this.cdsThemeService = cdsThemeService;
|
|
34
36
|
this.fb = fb;
|
|
37
|
+
this.route = route;
|
|
35
38
|
this.widgetWizardService = widgetWizardService;
|
|
36
39
|
this.class = 'valtimo-dossier-management-widget-field';
|
|
37
40
|
this.changeValidEvent = new EventEmitter();
|
|
@@ -47,6 +50,7 @@ export class DossierManagementWidgetFieldsComponent {
|
|
|
47
50
|
[index]: curr,
|
|
48
51
|
}), {}));
|
|
49
52
|
this.activeTab = signal(0);
|
|
53
|
+
this.documentDefinitionName$ = this.route.paramMap.pipe(map((paramMap) => paramMap.get('name') ?? ''));
|
|
50
54
|
this._subscriptions = new Subscription();
|
|
51
55
|
this._contentValid = signal(false);
|
|
52
56
|
}
|
|
@@ -113,8 +117,8 @@ export class DossierManagementWidgetFieldsComponent {
|
|
|
113
117
|
this._contentValid.set(event.valid);
|
|
114
118
|
this.changeValidEvent.emit(event.valid && this.form.valid);
|
|
115
119
|
}
|
|
116
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DossierManagementWidgetFieldsComponent, deps: [{ token: i1.CdsThemeService }, { token: i2.FormBuilder }, { token: i3.WidgetWizardService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
117
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: DossierManagementWidgetFieldsComponent, isStandalone: true, selector: "ng-component", outputs: { changeValidEvent: "changeValidEvent" }, host: { properties: { "class": "this.class" } }, viewQueries: [{ propertyName: "_tab", first: true, predicate: Tab, descendants: true }], ngImport: i0, template: "<!--\n ~ Copyright 2015-2024 Ritense BV, the Netherlands.\n ~\n ~ Licensed under EUPL, Version 1.2 (the \"License\");\n ~ you may not use this file except in compliance with the License.\n ~ You may obtain a copy of the License at\n ~\n ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n ~\n ~ Unless required by applicable law or agreed to in writing, software\n ~ distributed under the License is distributed on an \"AS IS\" basis,\n ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n ~ See the License for the specific language governing permissions and\n ~ limitations under the License.\n -->\n\n<p>{{ 'widgetTabManagement.content.description' | translate }}</p>\n\n<form [formGroup]=\"form\">\n <cds-text-label\n [attr.data-carbon-theme]=\"theme$ | async\"\n class=\"valtimo-dossier-management-widget-field__input\"\n >\n <v-input-label\n [title]=\"'widgetTabManagement.content.widgetTitle' | translate\"\n [tooltip]=\"'widgetTabManagement.content.widgetTitleTooltip' | translate\"\n >\n </v-input-label>\n\n <input\n formControlName=\"widgetTitle\"\n cdsText\n [placeholder]=\"'widgetTabManagement.content.widgetTitlePlaceholder' | translate\"\n type=\"text\"\n />\n </cds-text-label>\n</form>\n\n<cds-tabs type=\"contained\">\n @for (column of columns(); track $index) {\n <cds-tab\n [active]=\"activeTab() === $index\"\n [heading]=\"columnHeading\"\n [context]=\"{index: $index, count: $count}\"\n (selected)=\"onTabSelected($index)\"\n >\n <valtimo-dossier-management-widget-fields-column\n *ngIf=\"activeTab() === $index\"\n [isFieldWidget]=\"true\"\n [columnData]=\"selectedWidgetContent()?.[$index]\"\n (columnUpdateEvent)=\"onColumnUpdateEvent($event, $index)\"\n ></valtimo-dossier-management-widget-fields-column>\n </cds-tab>\n }\n <cds-tab\n *ngIf=\"columns().length < widgetWidth\"\n [heading]=\"addColumn\"\n [id]=\"'addColumn'\"\n class=\"valtimo-dossier-management-widget-field__add\"\n ></cds-tab>\n</cds-tabs>\n\n<ng-template #addColumn>\n <button\n cdsButton=\"ghost\"\n [iconOnly]=\"true\"\n (click)=\"$event.stopImmediatePropagation(); onAddColumnClick()\"\n >\n <svg class=\"cds--btn__icon\" cdsIcon=\"add\" size=\"16\"></svg>\n </button>\n</ng-template>\n\n<ng-template #columnHeading let-data>\n <div class=\"valtimo-dossier-management-widget-field__heading\">\n {{ 'widgetTabManagement.content.column' | translate: {number: data.index + 1} }}\n\n <button\n cdsButton=\"ghost\"\n [disabled]=\"data.count === 1\"\n [iconOnly]=\"true\"\n size=\"sm\"\n (click)=\"onDeleteColumnClick(data.index)\"\n >\n <svg class=\"cds--btn__icon\" cdsIcon=\"close\" size=\"16\"></svg>\n </button>\n </div>\n</ng-template>\n", styles: [".valtimo-dossier-management-widget-field{display:flex;flex-direction:column
|
|
120
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DossierManagementWidgetFieldsComponent, deps: [{ token: i1.CdsThemeService }, { token: i2.FormBuilder }, { token: i3.ActivatedRoute }, { token: i4.WidgetWizardService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
121
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: DossierManagementWidgetFieldsComponent, isStandalone: true, selector: "ng-component", outputs: { changeValidEvent: "changeValidEvent" }, host: { properties: { "class": "this.class" } }, viewQueries: [{ propertyName: "_tab", first: true, predicate: Tab, descendants: true }], ngImport: i0, template: "<!--\n ~ Copyright 2015-2024 Ritense BV, the Netherlands.\n ~\n ~ Licensed under EUPL, Version 1.2 (the \"License\");\n ~ you may not use this file except in compliance with the License.\n ~ You may obtain a copy of the License at\n ~\n ~ https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12\n ~\n ~ Unless required by applicable law or agreed to in writing, software\n ~ distributed under the License is distributed on an \"AS IS\" basis,\n ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n ~ See the License for the specific language governing permissions and\n ~ limitations under the License.\n -->\n\n<p>{{ 'widgetTabManagement.content.description' | translate }}</p>\n\n<form [formGroup]=\"form\">\n <cds-text-label\n [attr.data-carbon-theme]=\"theme$ | async\"\n class=\"valtimo-dossier-management-widget-field__input\"\n >\n <v-input-label\n [title]=\"'widgetTabManagement.content.widgetTitle' | translate\"\n [tooltip]=\"'widgetTabManagement.content.widgetTitleTooltip' | translate\"\n >\n </v-input-label>\n\n <input\n formControlName=\"widgetTitle\"\n cdsText\n [placeholder]=\"'widgetTabManagement.content.widgetTitlePlaceholder' | translate\"\n type=\"text\"\n />\n </cds-text-label>\n</form>\n\n<valtimo-dossier-management-widget-process-selector\n [documentDefinitionName]=\"documentDefinitionName$ | async\"\n></valtimo-dossier-management-widget-process-selector>\n\n<cds-tabs type=\"contained\">\n @for (column of columns(); track $index) {\n <cds-tab\n [active]=\"activeTab() === $index\"\n [heading]=\"columnHeading\"\n [context]=\"{index: $index, count: $count}\"\n (selected)=\"onTabSelected($index)\"\n >\n <valtimo-dossier-management-widget-fields-column\n *ngIf=\"activeTab() === $index\"\n [isFieldWidget]=\"true\"\n [columnData]=\"selectedWidgetContent()?.[$index]\"\n (columnUpdateEvent)=\"onColumnUpdateEvent($event, $index)\"\n ></valtimo-dossier-management-widget-fields-column>\n </cds-tab>\n }\n <cds-tab\n *ngIf=\"columns().length < widgetWidth\"\n [heading]=\"addColumn\"\n [id]=\"'addColumn'\"\n class=\"valtimo-dossier-management-widget-field__add\"\n ></cds-tab>\n</cds-tabs>\n\n<ng-template #addColumn>\n <button\n cdsButton=\"ghost\"\n [iconOnly]=\"true\"\n (click)=\"$event.stopImmediatePropagation(); onAddColumnClick()\"\n >\n <svg class=\"cds--btn__icon\" cdsIcon=\"add\" size=\"16\"></svg>\n </button>\n</ng-template>\n\n<ng-template #columnHeading let-data>\n <div class=\"valtimo-dossier-management-widget-field__heading\">\n {{ 'widgetTabManagement.content.column' | translate: {number: data.index + 1} }}\n\n <button\n cdsButton=\"ghost\"\n [disabled]=\"data.count === 1\"\n [iconOnly]=\"true\"\n size=\"sm\"\n (click)=\"onDeleteColumnClick(data.index)\"\n >\n <svg class=\"cds--btn__icon\" cdsIcon=\"close\" size=\"16\"></svg>\n </button>\n </div>\n</ng-template>\n", styles: [".valtimo-dossier-management-widget-field{display:flex;flex-direction:column;gap:16px}.valtimo-dossier-management-widget-field__input{max-width:288px}.valtimo-dossier-management-widget-field__heading{display:flex;align-items:center}.valtimo-dossier-management-widget-field #addColumn-header{padding:0!important}.valtimo-dossier-management-widget-field .cds--tabs__nav-item{padding-right:0!important}\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.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: TabsModule }, { kind: "component", type: i7.Tabs, selector: "cds-tabs, ibm-tabs", inputs: ["position", "cacheActive", "followFocus", "isNavigation", "ariaLabel", "ariaLabelledby", "type", "theme", "skeleton"] }, { kind: "component", type: i7.Tab, selector: "cds-tab, ibm-tab", inputs: ["heading", "title", "context", "active", "disabled", "tabIndex", "id", "cacheActive", "tabContent", "templateContext"], outputs: ["selected"] }, { kind: "ngmodule", type: IconModule }, { kind: "directive", type: i7.IconDirective, selector: "[cdsIcon], [ibmIcon]", inputs: ["ibmIcon", "cdsIcon", "size", "title", "ariaLabel", "ariaLabelledBy", "ariaHidden", "isFocusable"] }, { 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: ButtonModule }, { kind: "directive", type: i7.Button, selector: "[cdsButton], [ibmButton]", inputs: ["ibmButton", "cdsButton", "size", "skeleton", "iconOnly", "isExpressive"] }, { kind: "component", type: DossierManagementWidgetFieldsColumnComponent, selector: "valtimo-dossier-management-widget-fields-column", inputs: ["columnData", "addTranslateKey", "isFieldWidget", "fieldWidthDropdown"], outputs: ["columnUpdateEvent"] }, { kind: "component", type: DossierManagementWidgetProcessSelectorComponent, selector: "valtimo-dossier-management-widget-process-selector", inputs: ["documentDefinitionName"] }, { kind: "ngmodule", type: InputLabelModule }, { kind: "component", type: i1.InputLabelComponent, selector: "v-input-label", inputs: ["name", "tooltip", "largeMargin", "small", "noMargin", "title", "titleTranslationKey", "required", "disabled", "carbonTheme"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
|
|
118
122
|
}
|
|
119
123
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DossierManagementWidgetFieldsComponent, decorators: [{
|
|
120
124
|
type: Component,
|
|
@@ -127,9 +131,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
127
131
|
ReactiveFormsModule,
|
|
128
132
|
ButtonModule,
|
|
129
133
|
DossierManagementWidgetFieldsColumnComponent,
|
|
134
|
+
DossierManagementWidgetProcessSelectorComponent,
|
|
130
135
|
InputLabelModule,
|
|
131
|
-
], 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<p>{{ 'widgetTabManagement.content.description' | translate }}</p>\n\n<form [formGroup]=\"form\">\n <cds-text-label\n [attr.data-carbon-theme]=\"theme$ | async\"\n class=\"valtimo-dossier-management-widget-field__input\"\n >\n <v-input-label\n [title]=\"'widgetTabManagement.content.widgetTitle' | translate\"\n [tooltip]=\"'widgetTabManagement.content.widgetTitleTooltip' | translate\"\n >\n </v-input-label>\n\n <input\n formControlName=\"widgetTitle\"\n cdsText\n [placeholder]=\"'widgetTabManagement.content.widgetTitlePlaceholder' | translate\"\n type=\"text\"\n />\n </cds-text-label>\n</form>\n\n<cds-tabs type=\"contained\">\n @for (column of columns(); track $index) {\n <cds-tab\n [active]=\"activeTab() === $index\"\n [heading]=\"columnHeading\"\n [context]=\"{index: $index, count: $count}\"\n (selected)=\"onTabSelected($index)\"\n >\n <valtimo-dossier-management-widget-fields-column\n *ngIf=\"activeTab() === $index\"\n [isFieldWidget]=\"true\"\n [columnData]=\"selectedWidgetContent()?.[$index]\"\n (columnUpdateEvent)=\"onColumnUpdateEvent($event, $index)\"\n ></valtimo-dossier-management-widget-fields-column>\n </cds-tab>\n }\n <cds-tab\n *ngIf=\"columns().length < widgetWidth\"\n [heading]=\"addColumn\"\n [id]=\"'addColumn'\"\n class=\"valtimo-dossier-management-widget-field__add\"\n ></cds-tab>\n</cds-tabs>\n\n<ng-template #addColumn>\n <button\n cdsButton=\"ghost\"\n [iconOnly]=\"true\"\n (click)=\"$event.stopImmediatePropagation(); onAddColumnClick()\"\n >\n <svg class=\"cds--btn__icon\" cdsIcon=\"add\" size=\"16\"></svg>\n </button>\n</ng-template>\n\n<ng-template #columnHeading let-data>\n <div class=\"valtimo-dossier-management-widget-field__heading\">\n {{ 'widgetTabManagement.content.column' | translate: {number: data.index + 1} }}\n\n <button\n cdsButton=\"ghost\"\n [disabled]=\"data.count === 1\"\n [iconOnly]=\"true\"\n size=\"sm\"\n (click)=\"onDeleteColumnClick(data.index)\"\n >\n <svg class=\"cds--btn__icon\" cdsIcon=\"close\" size=\"16\"></svg>\n </button>\n </div>\n</ng-template>\n", styles: [".valtimo-dossier-management-widget-field{display:flex;flex-direction:column
|
|
132
|
-
}], ctorParameters: () => [{ type: i1.CdsThemeService }, { type: i2.FormBuilder }, { type: i3.WidgetWizardService }], propDecorators: { class: [{
|
|
136
|
+
], 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<p>{{ 'widgetTabManagement.content.description' | translate }}</p>\n\n<form [formGroup]=\"form\">\n <cds-text-label\n [attr.data-carbon-theme]=\"theme$ | async\"\n class=\"valtimo-dossier-management-widget-field__input\"\n >\n <v-input-label\n [title]=\"'widgetTabManagement.content.widgetTitle' | translate\"\n [tooltip]=\"'widgetTabManagement.content.widgetTitleTooltip' | translate\"\n >\n </v-input-label>\n\n <input\n formControlName=\"widgetTitle\"\n cdsText\n [placeholder]=\"'widgetTabManagement.content.widgetTitlePlaceholder' | translate\"\n type=\"text\"\n />\n </cds-text-label>\n</form>\n\n<valtimo-dossier-management-widget-process-selector\n [documentDefinitionName]=\"documentDefinitionName$ | async\"\n></valtimo-dossier-management-widget-process-selector>\n\n<cds-tabs type=\"contained\">\n @for (column of columns(); track $index) {\n <cds-tab\n [active]=\"activeTab() === $index\"\n [heading]=\"columnHeading\"\n [context]=\"{index: $index, count: $count}\"\n (selected)=\"onTabSelected($index)\"\n >\n <valtimo-dossier-management-widget-fields-column\n *ngIf=\"activeTab() === $index\"\n [isFieldWidget]=\"true\"\n [columnData]=\"selectedWidgetContent()?.[$index]\"\n (columnUpdateEvent)=\"onColumnUpdateEvent($event, $index)\"\n ></valtimo-dossier-management-widget-fields-column>\n </cds-tab>\n }\n <cds-tab\n *ngIf=\"columns().length < widgetWidth\"\n [heading]=\"addColumn\"\n [id]=\"'addColumn'\"\n class=\"valtimo-dossier-management-widget-field__add\"\n ></cds-tab>\n</cds-tabs>\n\n<ng-template #addColumn>\n <button\n cdsButton=\"ghost\"\n [iconOnly]=\"true\"\n (click)=\"$event.stopImmediatePropagation(); onAddColumnClick()\"\n >\n <svg class=\"cds--btn__icon\" cdsIcon=\"add\" size=\"16\"></svg>\n </button>\n</ng-template>\n\n<ng-template #columnHeading let-data>\n <div class=\"valtimo-dossier-management-widget-field__heading\">\n {{ 'widgetTabManagement.content.column' | translate: {number: data.index + 1} }}\n\n <button\n cdsButton=\"ghost\"\n [disabled]=\"data.count === 1\"\n [iconOnly]=\"true\"\n size=\"sm\"\n (click)=\"onDeleteColumnClick(data.index)\"\n >\n <svg class=\"cds--btn__icon\" cdsIcon=\"close\" size=\"16\"></svg>\n </button>\n </div>\n</ng-template>\n", styles: [".valtimo-dossier-management-widget-field{display:flex;flex-direction:column;gap:16px}.valtimo-dossier-management-widget-field__input{max-width:288px}.valtimo-dossier-management-widget-field__heading{display:flex;align-items:center}.valtimo-dossier-management-widget-field #addColumn-header{padding:0!important}.valtimo-dossier-management-widget-field .cds--tabs__nav-item{padding-right:0!important}\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"] }]
|
|
137
|
+
}], ctorParameters: () => [{ type: i1.CdsThemeService }, { type: i2.FormBuilder }, { type: i3.ActivatedRoute }, { type: i4.WidgetWizardService }], propDecorators: { class: [{
|
|
133
138
|
type: HostBinding,
|
|
134
139
|
args: ['class']
|
|
135
140
|
}], changeValidEvent: [{
|
|
@@ -138,4 +143,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
138
143
|
type: ViewChild,
|
|
139
144
|
args: [Tab]
|
|
140
145
|
}] } });
|
|
141
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dossier-management-widget-fields.component.js","sourceRoot":"","sources":["../../../../../../../../projects/valtimo/dossier-management/src/lib/components/dossier-management-widget-configurators/fields/dossier-management-widget-fields.component.ts","../../../../../../../../projects/valtimo/dossier-management/src/lib/components/dossier-management-widget-configurators/fields/dossier-management-widget-fields.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  AfterViewInit,\n  ChangeDetectionStrategy,\n  Component,\n  computed,\n  EventEmitter,\n  HostBinding,\n  OnDestroy,\n  OnInit,\n  Output,\n  signal,\n  ViewChild,\n  ViewEncapsulation,\n} from '@angular/core';\nimport {FormBuilder, ReactiveFormsModule, Validators} from '@angular/forms';\nimport {TranslateModule} from '@ngx-translate/core';\nimport {\n  CARBON_THEME,\n  CdsThemeService,\n  CurrentCarbonTheme,\n  InputLabelModule,\n} from '@valtimo/components';\nimport {FieldsCaseWidgetValue, WidgetFieldsContent} from '@valtimo/dossier';\nimport {ButtonModule, IconModule, InputModule, Tab, TabsModule} from 'carbon-components-angular';\nimport {debounceTime, map, Subscription} from 'rxjs';\nimport {WidgetContentComponent} from '../../../models';\nimport {WidgetWizardService} from '../../../services';\nimport {DossierManagementWidgetFieldsColumnComponent} from './column/dossier-management-widget-fields-column.component';\n\n@Component({\n  templateUrl: './dossier-management-widget-fields.component.html',\n  styleUrls: ['./dossier-management-widget-fields.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  standalone: true,\n  imports: [\n    CommonModule,\n    TranslateModule,\n    InputModule,\n    TabsModule,\n    IconModule,\n    ReactiveFormsModule,\n    ButtonModule,\n    DossierManagementWidgetFieldsColumnComponent,\n    InputLabelModule,\n  ],\n})\nexport class DossierManagementWidgetFieldsComponent\n  implements WidgetContentComponent, OnDestroy, OnInit, AfterViewInit\n{\n  @HostBinding('class') public readonly class = 'valtimo-dossier-management-widget-field';\n  @Output() public readonly changeValidEvent = new EventEmitter<boolean>();\n  @ViewChild(Tab) private readonly _tab: Tab;\n\n  public form = this.fb.group({\n    widgetTitle: this.fb.control(this.widgetWizardService.widgetTitle(), Validators.required),\n  });\n\n  public readonly columns = signal<null[]>([null]);\n  public readonly widgetWidth = this.widgetWizardService.widgetWidth();\n  public readonly selectedTabIndex = -1;\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  public readonly selectedWidgetContent = computed(() =>\n    (this.widgetWizardService.widgetContent() as WidgetFieldsContent)?.columns.reduce(\n      (acc, curr, index) => ({\n        ...acc,\n        [index]: curr,\n      }),\n      {}\n    )\n  );\n  public readonly activeTab = signal<number>(0);\n\n  private readonly _subscriptions = new Subscription();\n  private readonly _contentValid = signal<boolean>(false);\n\n  constructor(\n    private readonly cdsThemeService: CdsThemeService,\n    private readonly fb: FormBuilder,\n    private readonly widgetWizardService: WidgetWizardService\n  ) {}\n\n  public ngOnInit(): void {\n    this._subscriptions.add(\n      this.form.valueChanges.pipe(debounceTime(100)).subscribe(formValue => {\n        this.widgetWizardService.widgetTitle.set(formValue.widgetTitle ?? '');\n        this.changeValidEvent.emit(this.form.valid && this._contentValid());\n      })\n    );\n    const widgetContent = (this.widgetWizardService.widgetContent() as WidgetFieldsContent)\n      ?.columns;\n    if (!widgetContent) return;\n\n    this.columns.set(Object.keys(widgetContent).map(() => null));\n  }\n\n  public ngAfterViewInit(): void {\n    this._tab.tabIndex = -1;\n  }\n\n  public ngOnDestroy(): void {\n    this._subscriptions.unsubscribe();\n    this.changeValidEvent.emit(false);\n    this.form.reset();\n    this._contentValid.set(false);\n  }\n\n  public onAddColumnClick(): void {\n    this.columns.update(value => [...value, null]);\n    this.activeTab.set(this.columns().length - 1);\n    this.changeValidEvent.emit(false);\n  }\n\n  public onTabSelected(index: number): void {\n    this.activeTab.set(index);\n  }\n\n  public onDeleteColumnClick(index: number): void {\n    this.widgetWizardService.widgetContent.update(content => {\n      if (!content) return null;\n\n      const widgetContent = content as WidgetFieldsContent;\n\n      let tempIndex = index;\n      let tempContent = {...widgetContent};\n      while (tempIndex < this.columns().length - 1) {\n        tempContent.columns[tempIndex] = tempContent.columns[tempIndex + 1];\n        tempIndex++;\n      }\n      tempContent.columns.splice(tempIndex, 1);\n\n      return tempContent;\n    });\n\n    this.columns.update((columns: null[]) => {\n      const temp = columns;\n      temp.splice(index, 1);\n\n      return temp;\n    });\n\n    if (this.activeTab() !== index) return;\n\n    this.activeTab.set(-1);\n  }\n\n  public onColumnUpdateEvent(\n    event: {\n      data: FieldsCaseWidgetValue[];\n      valid: boolean;\n    },\n    columnIndex: number\n  ): void {\n    this.widgetWizardService.widgetContent.update(content => {\n      if (!content) return {columns: [event.data]};\n\n      const columns = (content as WidgetFieldsContent)?.columns.map((column, index) =>\n        index === columnIndex ? event.data : column\n      );\n      return {\n        columns: columnIndex > columns.length - 1 ? [...columns, event.data] : columns,\n      };\n    });\n    this._contentValid.set(event.valid);\n    this.changeValidEvent.emit(event.valid && this.form.valid);\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<p>{{ 'widgetTabManagement.content.description' | translate }}</p>\n\n<form [formGroup]=\"form\">\n  <cds-text-label\n    [attr.data-carbon-theme]=\"theme$ | async\"\n    class=\"valtimo-dossier-management-widget-field__input\"\n  >\n    <v-input-label\n      [title]=\"'widgetTabManagement.content.widgetTitle' | translate\"\n      [tooltip]=\"'widgetTabManagement.content.widgetTitleTooltip' | translate\"\n    >\n    </v-input-label>\n\n    <input\n      formControlName=\"widgetTitle\"\n      cdsText\n      [placeholder]=\"'widgetTabManagement.content.widgetTitlePlaceholder' | translate\"\n      type=\"text\"\n    />\n  </cds-text-label>\n</form>\n\n<cds-tabs type=\"contained\">\n  @for (column of columns(); track $index) {\n    <cds-tab\n      [active]=\"activeTab() === $index\"\n      [heading]=\"columnHeading\"\n      [context]=\"{index: $index, count: $count}\"\n      (selected)=\"onTabSelected($index)\"\n    >\n      <valtimo-dossier-management-widget-fields-column\n        *ngIf=\"activeTab() === $index\"\n        [isFieldWidget]=\"true\"\n        [columnData]=\"selectedWidgetContent()?.[$index]\"\n        (columnUpdateEvent)=\"onColumnUpdateEvent($event, $index)\"\n      ></valtimo-dossier-management-widget-fields-column>\n    </cds-tab>\n  }\n  <cds-tab\n    *ngIf=\"columns().length < widgetWidth\"\n    [heading]=\"addColumn\"\n    [id]=\"'addColumn'\"\n    class=\"valtimo-dossier-management-widget-field__add\"\n  ></cds-tab>\n</cds-tabs>\n\n<ng-template #addColumn>\n  <button\n    cdsButton=\"ghost\"\n    [iconOnly]=\"true\"\n    (click)=\"$event.stopImmediatePropagation(); onAddColumnClick()\"\n  >\n    <svg class=\"cds--btn__icon\" cdsIcon=\"add\" size=\"16\"></svg>\n  </button>\n</ng-template>\n\n<ng-template #columnHeading let-data>\n  <div class=\"valtimo-dossier-management-widget-field__heading\">\n    {{ 'widgetTabManagement.content.column' | translate: {number: data.index + 1} }}\n\n    <button\n      cdsButton=\"ghost\"\n      [disabled]=\"data.count === 1\"\n      [iconOnly]=\"true\"\n      size=\"sm\"\n      (click)=\"onDeleteColumnClick(data.index)\"\n    >\n      <svg class=\"cds--btn__icon\" cdsIcon=\"close\" size=\"16\"></svg>\n    </button>\n  </div>\n</ng-template>\n"]}
|
|
146
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dossier-management-widget-fields.component.js","sourceRoot":"","sources":["../../../../../../../../projects/valtimo/dossier-management/src/lib/components/dossier-management-widget-configurators/fields/dossier-management-widget-fields.component.ts","../../../../../../../../projects/valtimo/dossier-management/src/lib/components/dossier-management-widget-configurators/fields/dossier-management-widget-fields.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  AfterViewInit,\n  ChangeDetectionStrategy,\n  Component,\n  computed,\n  EventEmitter,\n  HostBinding,\n  OnDestroy,\n  OnInit,\n  Output,\n  signal,\n  ViewChild,\n  ViewEncapsulation,\n} from '@angular/core';\nimport {FormBuilder, ReactiveFormsModule, Validators} from '@angular/forms';\nimport {TranslateModule} from '@ngx-translate/core';\nimport {\n  CARBON_THEME,\n  CdsThemeService,\n  CurrentCarbonTheme,\n  InputLabelModule,\n} from '@valtimo/components';\nimport {FieldsCaseWidgetValue, WidgetFieldsContent} from '@valtimo/dossier';\nimport {ButtonModule, IconModule, InputModule, Tab, TabsModule} from 'carbon-components-angular';\nimport {debounceTime, map, Observable, Subscription} from 'rxjs';\nimport {WidgetContentComponent} from '../../../models';\nimport {WidgetWizardService} from '../../../services';\nimport {DossierManagementWidgetFieldsColumnComponent} from './column/dossier-management-widget-fields-column.component';\nimport {ActivatedRoute, ParamMap} from '@angular/router';\nimport {DossierManagementWidgetProcessSelectorComponent} from '../process-selector/dossier-management-widget-process-selector.component';\n\n@Component({\n  templateUrl: './dossier-management-widget-fields.component.html',\n  styleUrls: ['./dossier-management-widget-fields.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  standalone: true,\n  imports: [\n    CommonModule,\n    TranslateModule,\n    InputModule,\n    TabsModule,\n    IconModule,\n    ReactiveFormsModule,\n    ButtonModule,\n    DossierManagementWidgetFieldsColumnComponent,\n    DossierManagementWidgetProcessSelectorComponent,\n    InputLabelModule,\n  ],\n})\nexport class DossierManagementWidgetFieldsComponent\n  implements WidgetContentComponent, OnDestroy, OnInit, AfterViewInit\n{\n  @HostBinding('class') public readonly class = 'valtimo-dossier-management-widget-field';\n  @Output() public readonly changeValidEvent = new EventEmitter<boolean>();\n  @ViewChild(Tab) private readonly _tab: Tab;\n\n  public form = this.fb.group({\n    widgetTitle: this.fb.control(this.widgetWizardService.widgetTitle(), Validators.required),\n  });\n\n  public readonly columns = signal<null[]>([null]);\n  public readonly widgetWidth = this.widgetWizardService.widgetWidth();\n  public readonly selectedTabIndex = -1;\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  public readonly selectedWidgetContent = computed(() =>\n    (this.widgetWizardService.widgetContent() as WidgetFieldsContent)?.columns.reduce(\n      (acc, curr, index) => ({\n        ...acc,\n        [index]: curr,\n      }),\n      {}\n    )\n  );\n  public readonly activeTab = signal<number>(0);\n  public readonly documentDefinitionName$: Observable<string> = this.route.paramMap.pipe(\n    map((paramMap: ParamMap) => paramMap.get('name') ?? '')\n  );\n\n  private readonly _subscriptions = new Subscription();\n  private readonly _contentValid = signal<boolean>(false);\n\n  constructor(\n    private readonly cdsThemeService: CdsThemeService,\n    private readonly fb: FormBuilder,\n    private readonly route: ActivatedRoute,\n    private readonly widgetWizardService: WidgetWizardService\n  ) {}\n\n  public ngOnInit(): void {\n    this._subscriptions.add(\n      this.form.valueChanges.pipe(debounceTime(100)).subscribe(formValue => {\n        this.widgetWizardService.widgetTitle.set(formValue.widgetTitle ?? '');\n        this.changeValidEvent.emit(this.form.valid && this._contentValid());\n      })\n    );\n    const widgetContent = (this.widgetWizardService.widgetContent() as WidgetFieldsContent)\n      ?.columns;\n    if (!widgetContent) return;\n\n    this.columns.set(Object.keys(widgetContent).map(() => null));\n  }\n\n  public ngAfterViewInit(): void {\n    this._tab.tabIndex = -1;\n  }\n\n  public ngOnDestroy(): void {\n    this._subscriptions.unsubscribe();\n    this.changeValidEvent.emit(false);\n    this.form.reset();\n    this._contentValid.set(false);\n  }\n\n  public onAddColumnClick(): void {\n    this.columns.update(value => [...value, null]);\n    this.activeTab.set(this.columns().length - 1);\n    this.changeValidEvent.emit(false);\n  }\n\n  public onTabSelected(index: number): void {\n    this.activeTab.set(index);\n  }\n\n  public onDeleteColumnClick(index: number): void {\n    this.widgetWizardService.widgetContent.update(content => {\n      if (!content) return null;\n\n      const widgetContent = content as WidgetFieldsContent;\n\n      let tempIndex = index;\n      let tempContent = {...widgetContent};\n      while (tempIndex < this.columns().length - 1) {\n        tempContent.columns[tempIndex] = tempContent.columns[tempIndex + 1];\n        tempIndex++;\n      }\n      tempContent.columns.splice(tempIndex, 1);\n\n      return tempContent;\n    });\n\n    this.columns.update((columns: null[]) => {\n      const temp = columns;\n      temp.splice(index, 1);\n\n      return temp;\n    });\n\n    if (this.activeTab() !== index) return;\n\n    this.activeTab.set(-1);\n  }\n\n  public onColumnUpdateEvent(\n    event: {\n      data: FieldsCaseWidgetValue[];\n      valid: boolean;\n    },\n    columnIndex: number\n  ): void {\n    this.widgetWizardService.widgetContent.update(content => {\n      if (!content) return {columns: [event.data]};\n\n      const columns = (content as WidgetFieldsContent)?.columns.map((column, index) =>\n        index === columnIndex ? event.data : column\n      );\n      return {\n        columns: columnIndex > columns.length - 1 ? [...columns, event.data] : columns,\n      };\n    });\n    this._contentValid.set(event.valid);\n    this.changeValidEvent.emit(event.valid && this.form.valid);\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<p>{{ 'widgetTabManagement.content.description' | translate }}</p>\n\n<form [formGroup]=\"form\">\n  <cds-text-label\n    [attr.data-carbon-theme]=\"theme$ | async\"\n    class=\"valtimo-dossier-management-widget-field__input\"\n  >\n    <v-input-label\n      [title]=\"'widgetTabManagement.content.widgetTitle' | translate\"\n      [tooltip]=\"'widgetTabManagement.content.widgetTitleTooltip' | translate\"\n    >\n    </v-input-label>\n\n    <input\n      formControlName=\"widgetTitle\"\n      cdsText\n      [placeholder]=\"'widgetTabManagement.content.widgetTitlePlaceholder' | translate\"\n      type=\"text\"\n    />\n  </cds-text-label>\n</form>\n\n<valtimo-dossier-management-widget-process-selector\n  [documentDefinitionName]=\"documentDefinitionName$ | async\"\n></valtimo-dossier-management-widget-process-selector>\n\n<cds-tabs type=\"contained\">\n  @for (column of columns(); track $index) {\n    <cds-tab\n      [active]=\"activeTab() === $index\"\n      [heading]=\"columnHeading\"\n      [context]=\"{index: $index, count: $count}\"\n      (selected)=\"onTabSelected($index)\"\n    >\n      <valtimo-dossier-management-widget-fields-column\n        *ngIf=\"activeTab() === $index\"\n        [isFieldWidget]=\"true\"\n        [columnData]=\"selectedWidgetContent()?.[$index]\"\n        (columnUpdateEvent)=\"onColumnUpdateEvent($event, $index)\"\n      ></valtimo-dossier-management-widget-fields-column>\n    </cds-tab>\n  }\n  <cds-tab\n    *ngIf=\"columns().length < widgetWidth\"\n    [heading]=\"addColumn\"\n    [id]=\"'addColumn'\"\n    class=\"valtimo-dossier-management-widget-field__add\"\n  ></cds-tab>\n</cds-tabs>\n\n<ng-template #addColumn>\n  <button\n    cdsButton=\"ghost\"\n    [iconOnly]=\"true\"\n    (click)=\"$event.stopImmediatePropagation(); onAddColumnClick()\"\n  >\n    <svg class=\"cds--btn__icon\" cdsIcon=\"add\" size=\"16\"></svg>\n  </button>\n</ng-template>\n\n<ng-template #columnHeading let-data>\n  <div class=\"valtimo-dossier-management-widget-field__heading\">\n    {{ 'widgetTabManagement.content.column' | translate: {number: data.index + 1} }}\n\n    <button\n      cdsButton=\"ghost\"\n      [disabled]=\"data.count === 1\"\n      [iconOnly]=\"true\"\n      size=\"sm\"\n      (click)=\"onDeleteColumnClick(data.index)\"\n    >\n      <svg class=\"cds--btn__icon\" cdsIcon=\"close\" size=\"16\"></svg>\n    </button>\n  </div>\n</ng-template>\n"]}
|
|
@@ -20,23 +20,26 @@ import { TranslateModule } from '@ngx-translate/core';
|
|
|
20
20
|
import { CARBON_THEME, CurrentCarbonTheme } from '@valtimo/components';
|
|
21
21
|
import { DropdownModule, InputModule, SelectModule } from 'carbon-components-angular';
|
|
22
22
|
import { BehaviorSubject, combineLatest, filter, map, Subscription } from 'rxjs';
|
|
23
|
+
import { DossierManagementWidgetProcessSelectorComponent } from '../process-selector/dossier-management-widget-process-selector.component';
|
|
23
24
|
import * as i0 from "@angular/core";
|
|
24
25
|
import * as i1 from "@valtimo/components";
|
|
25
26
|
import * as i2 from "@angular/forms";
|
|
26
27
|
import * as i3 from "../../../services";
|
|
27
28
|
import * as i4 from "@valtimo/form";
|
|
28
|
-
import * as i5 from "@angular/
|
|
29
|
-
import * as i6 from "@
|
|
30
|
-
import * as i7 from "
|
|
29
|
+
import * as i5 from "@angular/router";
|
|
30
|
+
import * as i6 from "@angular/common";
|
|
31
|
+
import * as i7 from "@ngx-translate/core";
|
|
32
|
+
import * as i8 from "carbon-components-angular";
|
|
31
33
|
export class DossierManagementWidgetFormioComponent {
|
|
32
34
|
get widgetTitle() {
|
|
33
35
|
return this.form.get('widgetTitle');
|
|
34
36
|
}
|
|
35
|
-
constructor(cdsThemeService, fb, widgetWizardService, formService) {
|
|
37
|
+
constructor(cdsThemeService, fb, widgetWizardService, formService, route) {
|
|
36
38
|
this.cdsThemeService = cdsThemeService;
|
|
37
39
|
this.fb = fb;
|
|
38
40
|
this.widgetWizardService = widgetWizardService;
|
|
39
41
|
this.formService = formService;
|
|
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),
|
|
@@ -44,6 +47,7 @@ export class DossierManagementWidgetFormioComponent {
|
|
|
44
47
|
this.theme$ = this.cdsThemeService.currentTheme$.pipe(map((theme) => theme === CurrentCarbonTheme.G10 ? CARBON_THEME.WHITE : CARBON_THEME.G90));
|
|
45
48
|
this._selectedFormDefinitionId$ = new BehaviorSubject(null);
|
|
46
49
|
this._formDefinitionOptions$ = new BehaviorSubject([]);
|
|
50
|
+
this.documentDefinitionName$ = this.route.paramMap.pipe(map((paramMap) => paramMap.get('name') ?? ''));
|
|
47
51
|
this.formListItems$ = combineLatest([
|
|
48
52
|
this._formDefinitionOptions$,
|
|
49
53
|
this._selectedFormDefinitionId$,
|
|
@@ -88,8 +92,8 @@ export class DossierManagementWidgetFormioComponent {
|
|
|
88
92
|
this._selectedFormDefinitionId$.next(formDefinitionId);
|
|
89
93
|
this.changeValidEvent.emit(true);
|
|
90
94
|
}
|
|
91
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DossierManagementWidgetFormioComponent, deps: [{ token: i1.CdsThemeService }, { token: i2.FormBuilder }, { token: i3.WidgetWizardService }, { token: i4.FormService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
92
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: DossierManagementWidgetFormioComponent, 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-formio\"\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.formio.selectForm' | translate }}\n\n <cds-dropdown\n *ngIf=\"formListItems$ | async as formListItems\"\n [appendInline]=\"false\"\n [placeholder]=\"'widgetTabManagement.content.formio.placeholder' | translate\"\n [disabled]=\"formListItems.length === 0\"\n [dropUp]=\"false\"\n (selected)=\"componentDropDownChange($event)\"\n >\n <cds-dropdown-list [items]=\"formListItems\"> </cds-dropdown-list>\n </cds-dropdown>\n </cds-label>\n</form>\n", styles: [".valtimo-dossier-management-widget-formio{display:flex;flex-direction:column
|
|
95
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DossierManagementWidgetFormioComponent, deps: [{ token: i1.CdsThemeService }, { token: i2.FormBuilder }, { token: i3.WidgetWizardService }, { token: i4.FormService }, { token: i5.ActivatedRoute }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
96
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: DossierManagementWidgetFormioComponent, 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-formio\"\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.formio.selectForm' | translate }}\n\n <cds-dropdown\n *ngIf=\"formListItems$ | async as formListItems\"\n [appendInline]=\"false\"\n [placeholder]=\"'widgetTabManagement.content.formio.placeholder' | translate\"\n [disabled]=\"formListItems.length === 0\"\n [dropUp]=\"false\"\n (selected)=\"componentDropDownChange($event)\"\n >\n <cds-dropdown-list [items]=\"formListItems\"> </cds-dropdown-list>\n </cds-dropdown>\n </cds-label>\n</form>\n", styles: [".valtimo-dossier-management-widget-formio{display:flex;flex-direction:column;gap:16px}.valtimo-dossier-management-widget-formio ::ng-deep .dropdown-label label{display:flex;flex-direction:column;width:100%}.valtimo-dossier-management-widget-formio ::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: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i6.AsyncPipe, name: "async" }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i7.TranslatePipe, name: "translate" }, { kind: "ngmodule", type: InputModule }, { kind: "component", type: i8.Label, selector: "cds-label, ibm-label", inputs: ["labelInputID", "disabled", "skeleton", "helperText", "invalidText", "invalid", "warn", "warnText", "ariaLabel"] }, { kind: "component", type: i8.TextInputLabelComponent, selector: "cds-text-label, ibm-text-label", inputs: ["labelInputID", "disabled", "skeleton", "labelTemplate", "textInputTemplate", "helperText", "invalidText", "invalid", "warn", "warnText", "ariaLabel"] }, { kind: "directive", type: i8.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: i8.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: i8.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 }); }
|
|
93
97
|
}
|
|
94
98
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DossierManagementWidgetFormioComponent, decorators: [{
|
|
95
99
|
type: Component,
|
|
@@ -100,8 +104,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
100
104
|
ReactiveFormsModule,
|
|
101
105
|
SelectModule,
|
|
102
106
|
DropdownModule,
|
|
103
|
-
|
|
104
|
-
|
|
107
|
+
DossierManagementWidgetProcessSelectorComponent,
|
|
108
|
+
], 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-formio\"\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.formio.selectForm' | translate }}\n\n <cds-dropdown\n *ngIf=\"formListItems$ | async as formListItems\"\n [appendInline]=\"false\"\n [placeholder]=\"'widgetTabManagement.content.formio.placeholder' | translate\"\n [disabled]=\"formListItems.length === 0\"\n [dropUp]=\"false\"\n (selected)=\"componentDropDownChange($event)\"\n >\n <cds-dropdown-list [items]=\"formListItems\"> </cds-dropdown-list>\n </cds-dropdown>\n </cds-label>\n</form>\n", styles: [".valtimo-dossier-management-widget-formio{display:flex;flex-direction:column;gap:16px}.valtimo-dossier-management-widget-formio ::ng-deep .dropdown-label label{display:flex;flex-direction:column;width:100%}.valtimo-dossier-management-widget-formio ::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"] }]
|
|
109
|
+
}], ctorParameters: () => [{ type: i1.CdsThemeService }, { type: i2.FormBuilder }, { type: i3.WidgetWizardService }, { type: i4.FormService }, { type: i5.ActivatedRoute }], propDecorators: { changeValidEvent: [{
|
|
105
110
|
type: Output
|
|
106
111
|
}] } });
|
|
107
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dossier-management-widget-formio.component.js","sourceRoot":"","sources":["../../../../../../../../projects/valtimo/dossier-management/src/lib/components/dossier-management-widget-configurators/formio/dossier-management-widget-formio.component.ts","../../../../../../../../projects/valtimo/dossier-management/src/lib/components/dossier-management-widget-configurators/formio/dossier-management-widget-formio.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  OnDestroy,\n  OnInit,\n  Output,\n} from '@angular/core';\nimport {AbstractControl, FormBuilder, ReactiveFormsModule, Validators} from '@angular/forms';\nimport {TranslateModule} from '@ngx-translate/core';\nimport {CARBON_THEME, CdsThemeService, CurrentCarbonTheme} from '@valtimo/components';\nimport {WidgetFormioContent} from '@valtimo/dossier';\nimport {FormDefinitionOption, FormService} from '@valtimo/form';\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';\n\n@Component({\n  templateUrl: './dossier-management-widget-formio.component.html',\n  styleUrls: ['./dossier-management-widget-formio.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 DossierManagementWidgetFormioComponent\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 | null> | null {\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 _selectedFormDefinitionId$ = new BehaviorSubject<string | null>(null);\n\n  private readonly _formDefinitionOptions$ = new BehaviorSubject<FormDefinitionOption[]>([]);\n\n  public readonly formListItems$: Observable<ListItem[]> = combineLatest([\n    this._formDefinitionOptions$,\n    this._selectedFormDefinitionId$,\n  ]).pipe(\n    filter(([options]) => !!options),\n    map(([options, selectedFormId]) =>\n      options.map(option => ({\n        content: option.name,\n        id: option.name,\n        selected: option.name === selectedFormId,\n      }))\n    )\n  );\n\n  private readonly _subscriptions = new Subscription();\n\n  constructor(\n    private readonly cdsThemeService: CdsThemeService,\n    private readonly fb: FormBuilder,\n    private readonly widgetWizardService: WidgetWizardService,\n    private readonly formService: FormService\n  ) {}\n\n  public componentDropDownChange(event: {\n    item: {id: string; selected: boolean};\n    isUpdate: boolean;\n  }): void {\n    const formDefinitionId = event?.item?.id;\n\n    if (!formDefinitionId) return;\n\n    this._selectedFormDefinitionId$.next(formDefinitionId);\n    this.widgetWizardService.widgetContent.set({formDefinitionName: formDefinitionId});\n    this.changeValidEvent.emit(true);\n  }\n\n  public ngOnInit(): void {\n    this.fetchFormDefinition();\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 fetchFormDefinition(): void {\n    this.formService.getAllFormDefinitions().subscribe(definitions => {\n      this._formDefinitionOptions$.next(definitions);\n    });\n  }\n\n  private prefill(): void {\n    const formDefinitionId = (this.widgetWizardService.widgetContent() as WidgetFormioContent)\n      ?.formDefinitionName;\n\n    if (!formDefinitionId) return;\n\n    this._selectedFormDefinitionId$.next(formDefinitionId);\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-formio\"\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.formio.selectForm' | translate }}\n\n    <cds-dropdown\n      *ngIf=\"formListItems$ | async as formListItems\"\n      [appendInline]=\"false\"\n      [placeholder]=\"'widgetTabManagement.content.formio.placeholder' | translate\"\n      [disabled]=\"formListItems.length === 0\"\n      [dropUp]=\"false\"\n      (selected)=\"componentDropDownChange($event)\"\n    >\n      <cds-dropdown-list [items]=\"formListItems\"> </cds-dropdown-list>\n    </cds-dropdown>\n  </cds-label>\n</form>\n"]}
|
|
112
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dossier-management-widget-formio.component.js","sourceRoot":"","sources":["../../../../../../../../projects/valtimo/dossier-management/src/lib/components/dossier-management-widget-configurators/formio/dossier-management-widget-formio.component.ts","../../../../../../../../projects/valtimo/dossier-management/src/lib/components/dossier-management-widget-configurators/formio/dossier-management-widget-formio.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  OnDestroy,\n  OnInit,\n  Output,\n} from '@angular/core';\nimport {AbstractControl, FormBuilder, ReactiveFormsModule, Validators} from '@angular/forms';\nimport {TranslateModule} from '@ngx-translate/core';\nimport {CARBON_THEME, CdsThemeService, CurrentCarbonTheme} from '@valtimo/components';\nimport {WidgetFormioContent} from '@valtimo/dossier';\nimport {FormDefinitionOption, FormService} from '@valtimo/form';\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';\nimport {ActivatedRoute, ParamMap} from '@angular/router';\n\n@Component({\n  templateUrl: './dossier-management-widget-formio.component.html',\n  styleUrls: ['./dossier-management-widget-formio.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 DossierManagementWidgetFormioComponent\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 | null> | null {\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 _selectedFormDefinitionId$ = new BehaviorSubject<string | null>(null);\n\n  private readonly _formDefinitionOptions$ = new BehaviorSubject<FormDefinitionOption[]>([]);\n\n  public readonly documentDefinitionName$: Observable<string> = this.route.paramMap.pipe(\n    map((paramMap: ParamMap) => paramMap.get('name') ?? '')\n  );\n  public readonly formListItems$: Observable<ListItem[]> = combineLatest([\n    this._formDefinitionOptions$,\n    this._selectedFormDefinitionId$,\n  ]).pipe(\n    filter(([options]) => !!options),\n    map(([options, selectedFormId]) =>\n      options.map(option => ({\n        content: option.name,\n        id: option.name,\n        selected: option.name === selectedFormId,\n      }))\n    )\n  );\n\n  private readonly _subscriptions = new Subscription();\n\n  constructor(\n    private readonly cdsThemeService: CdsThemeService,\n    private readonly fb: FormBuilder,\n    private readonly widgetWizardService: WidgetWizardService,\n    private readonly formService: FormService,\n    private readonly route: ActivatedRoute\n  ) {}\n\n  public componentDropDownChange(event: {\n    item: {id: string; selected: boolean};\n    isUpdate: boolean;\n  }): void {\n    const formDefinitionId = event?.item?.id;\n\n    if (!formDefinitionId) return;\n\n    this._selectedFormDefinitionId$.next(formDefinitionId);\n    this.widgetWizardService.widgetContent.set({formDefinitionName: formDefinitionId});\n    this.changeValidEvent.emit(true);\n  }\n\n  public ngOnInit(): void {\n    this.fetchFormDefinition();\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 fetchFormDefinition(): void {\n    this.formService.getAllFormDefinitions().subscribe(definitions => {\n      this._formDefinitionOptions$.next(definitions);\n    });\n  }\n\n  private prefill(): void {\n    const formDefinitionId = (this.widgetWizardService.widgetContent() as WidgetFormioContent)\n      ?.formDefinitionName;\n\n    if (!formDefinitionId) return;\n\n    this._selectedFormDefinitionId$.next(formDefinitionId);\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-formio\"\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.formio.selectForm' | translate }}\n\n    <cds-dropdown\n      *ngIf=\"formListItems$ | async as formListItems\"\n      [appendInline]=\"false\"\n      [placeholder]=\"'widgetTabManagement.content.formio.placeholder' | translate\"\n      [disabled]=\"formListItems.length === 0\"\n      [dropUp]=\"false\"\n      (selected)=\"componentDropDownChange($event)\"\n    >\n      <cds-dropdown-list [items]=\"formListItems\"> </cds-dropdown-list>\n    </cds-dropdown>\n  </cds-label>\n</form>\n"]}
|