@qbs-origin/origin-form 0.6.2 → 0.6.5
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/formly/formly-checkboxes/formly-checkboxes.component.mjs +73 -0
- package/esm2022/lib/formly/formly-dictionary-dropdown-tree/formly-dictionary-dropdown-tree.component.mjs +52 -12
- package/esm2022/lib/formly/formly-field-stepper/formly-field-stepper.component.mjs +15 -3
- package/esm2022/lib/model-population.helper.mjs +45 -1
- package/esm2022/lib/models/forms.model.mjs +4 -2
- package/esm2022/lib/origin-form.component.mjs +61 -13
- package/esm2022/lib/origin-form.module.mjs +6 -1
- package/esm2022/lib/services/proxy.service.mjs +2 -2
- package/esm2022/lib/shared-components/dictionaries-tree.component.mjs +10 -3
- package/esm2022/lib/shared-components/treeview/treeview.component.mjs +19 -3
- package/fesm2022/qbs-origin-origin-form.mjs +268 -31
- package/fesm2022/qbs-origin-origin-form.mjs.map +1 -1
- package/lib/formly/formly-checkboxes/formly-checkboxes.component.d.ts +17 -0
- package/lib/formly/formly-dictionary-dropdown-tree/formly-dictionary-dropdown-tree.component.d.ts +3 -0
- package/lib/model-population.helper.d.ts +1 -0
- package/lib/models/forms.model.d.ts +7 -1
- package/lib/origin-form.module.d.ts +64 -63
- package/lib/shared-components/treeview/treeview.component.d.ts +1 -0
- package/package.json +2 -2
|
@@ -0,0 +1,73 @@
|
|
|
1
|
+
import { Component } from '@angular/core';
|
|
2
|
+
import { FieldType } from '@ngx-formly/core';
|
|
3
|
+
import { FormControl } from '@angular/forms';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "@angular/common";
|
|
6
|
+
import * as i2 from "ngx-markdown";
|
|
7
|
+
import * as i3 from "@angular/material/checkbox";
|
|
8
|
+
import * as i4 from "@ngx-formly/core";
|
|
9
|
+
import * as i5 from "../../others/external-link.directive";
|
|
10
|
+
export class FormlyCheckboxesComponent extends FieldType {
|
|
11
|
+
constructor() {
|
|
12
|
+
super(...arguments);
|
|
13
|
+
this.checkboxOptionsList = [];
|
|
14
|
+
this.title = '';
|
|
15
|
+
this.langIso = 'en';
|
|
16
|
+
this.selectedValues = [];
|
|
17
|
+
}
|
|
18
|
+
ngOnInit() {
|
|
19
|
+
this.langIso = this.props['currentLanguageIso'];
|
|
20
|
+
this.title = this.props['label'] || '';
|
|
21
|
+
if (this.props.required) {
|
|
22
|
+
this.title += ' *';
|
|
23
|
+
}
|
|
24
|
+
if (Array.isArray(this.to.options)) {
|
|
25
|
+
this.checkboxOptionsList = this.to.options;
|
|
26
|
+
}
|
|
27
|
+
// Initialize selected values from form control
|
|
28
|
+
const currentValue = this.formControl.value;
|
|
29
|
+
if (Array.isArray(currentValue)) {
|
|
30
|
+
this.selectedValues = currentValue;
|
|
31
|
+
}
|
|
32
|
+
else if (currentValue && currentValue.id) {
|
|
33
|
+
this.selectedValues = [currentValue];
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
get formControl() {
|
|
37
|
+
if (this.field.key) {
|
|
38
|
+
const keyPath = typeof this.field.key === 'string' || Array.isArray(this.field.key)
|
|
39
|
+
? this.field.key
|
|
40
|
+
: String(this.field.key);
|
|
41
|
+
return this.form.get(keyPath);
|
|
42
|
+
}
|
|
43
|
+
return new FormControl();
|
|
44
|
+
}
|
|
45
|
+
isChecked(option) {
|
|
46
|
+
return this.selectedValues.some((v) => v.id === option.value.id);
|
|
47
|
+
}
|
|
48
|
+
onCheckboxChange(event, option) {
|
|
49
|
+
if (event.checked) {
|
|
50
|
+
// Add to selection
|
|
51
|
+
if (!this.isChecked(option)) {
|
|
52
|
+
this.selectedValues = [...this.selectedValues, option.value];
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
else {
|
|
56
|
+
// Remove from selection
|
|
57
|
+
this.selectedValues = this.selectedValues.filter((v) => v.id !== option.value.id);
|
|
58
|
+
}
|
|
59
|
+
// Update form control with array of values
|
|
60
|
+
this.formControl.setValue(this.selectedValues);
|
|
61
|
+
// Notify parent component
|
|
62
|
+
if (this.props['onSelectedValuesChanged']) {
|
|
63
|
+
this.props['onSelectedValuesChanged'](this.selectedValues);
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: FormlyCheckboxesComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
|
|
67
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.14", type: FormlyCheckboxesComponent, selector: "formly-checkboxes", usesInheritance: true, ngImport: i0, template: "<div class=\"mat-mdc-text-field-wrapper mdc-checkbox-field\" appExternalLink>\n <label class=\"checkbox-label\">\n <markdown [data]=\"title\"></markdown>\n </label>\n <div *ngIf=\"checkboxOptionsList.length > 0\" class=\"checkbox-list\">\n <ng-container *ngFor=\"let option of checkboxOptionsList\">\n <div class=\"checkbox-item\">\n <mat-checkbox\n [checked]=\"isChecked(option)\"\n (change)=\"onCheckboxChange($event, option)\"\n color=\"primary\">\n {{ option.label }}\n </mat-checkbox>\n </div>\n </ng-container>\n </div>\n <div *ngIf=\"showError\" class=\"validation-error\">\n <formly-validation-message [field]=\"field\"></formly-validation-message>\n </div>\n</div>\n", styles: [".mdc-checkbox-field .checkbox-label{display:block;margin-bottom:8px}.mdc-checkbox-field .checkbox-list{display:flex;flex-direction:column;gap:4px}.mdc-checkbox-field .checkbox-item{padding:4px 0}.mdc-checkbox-field .validation-error{color:red;font-size:12px;margin-top:4px}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.MarkdownComponent, selector: "markdown, [markdown]", inputs: ["data", "src", "disableSanitizer", "inline", "clipboard", "clipboardButtonComponent", "clipboardButtonTemplate", "emoji", "katex", "katexOptions", "mermaid", "mermaidOptions", "lineHighlight", "line", "lineOffset", "lineNumbers", "start", "commandLine", "filterOutput", "host", "prompt", "output", "user"], outputs: ["error", "load", "ready"] }, { kind: "component", type: i3.MatCheckbox, selector: "mat-checkbox", inputs: ["aria-label", "aria-labelledby", "aria-describedby", "id", "required", "labelPosition", "name", "value", "disableRipple", "tabIndex", "color", "disabledInteractive", "checked", "disabled", "indeterminate"], outputs: ["change", "indeterminateChange"], exportAs: ["matCheckbox"] }, { kind: "component", type: i4.ɵFormlyValidationMessage, selector: "formly-validation-message", inputs: ["field"] }, { kind: "directive", type: i5.ExternalLinkDirective, selector: "[appExternalLink]" }] }); }
|
|
68
|
+
}
|
|
69
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: FormlyCheckboxesComponent, decorators: [{
|
|
70
|
+
type: Component,
|
|
71
|
+
args: [{ selector: 'formly-checkboxes', template: "<div class=\"mat-mdc-text-field-wrapper mdc-checkbox-field\" appExternalLink>\n <label class=\"checkbox-label\">\n <markdown [data]=\"title\"></markdown>\n </label>\n <div *ngIf=\"checkboxOptionsList.length > 0\" class=\"checkbox-list\">\n <ng-container *ngFor=\"let option of checkboxOptionsList\">\n <div class=\"checkbox-item\">\n <mat-checkbox\n [checked]=\"isChecked(option)\"\n (change)=\"onCheckboxChange($event, option)\"\n color=\"primary\">\n {{ option.label }}\n </mat-checkbox>\n </div>\n </ng-container>\n </div>\n <div *ngIf=\"showError\" class=\"validation-error\">\n <formly-validation-message [field]=\"field\"></formly-validation-message>\n </div>\n</div>\n", styles: [".mdc-checkbox-field .checkbox-label{display:block;margin-bottom:8px}.mdc-checkbox-field .checkbox-list{display:flex;flex-direction:column;gap:4px}.mdc-checkbox-field .checkbox-item{padding:4px 0}.mdc-checkbox-field .validation-error{color:red;font-size:12px;margin-top:4px}\n"] }]
|
|
72
|
+
}] });
|
|
73
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybWx5LWNoZWNrYm94ZXMuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvb3JpZ2luLWZvcm0vc3JjL2xpYi9mb3JtbHkvZm9ybWx5LWNoZWNrYm94ZXMvZm9ybWx5LWNoZWNrYm94ZXMuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvb3JpZ2luLWZvcm0vc3JjL2xpYi9mb3JtbHkvZm9ybWx5LWNoZWNrYm94ZXMvZm9ybWx5LWNoZWNrYm94ZXMuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBVSxNQUFNLGVBQWUsQ0FBQztBQUNsRCxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sa0JBQWtCLENBQUM7QUFDN0MsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLGdCQUFnQixDQUFDOzs7Ozs7O0FBUTdDLE1BQU0sT0FBTyx5QkFBMEIsU0FBUSxTQUFTO0lBTHhEOztRQU1FLHdCQUFtQixHQUFVLEVBQUUsQ0FBQztRQUNoQyxVQUFLLEdBQVcsRUFBRSxDQUFDO1FBQ25CLFlBQU8sR0FBVyxJQUFJLENBQUM7UUFDdkIsbUJBQWMsR0FBVSxFQUFFLENBQUM7S0F5RDVCO0lBdkRDLFFBQVE7UUFDTixJQUFJLENBQUMsT0FBTyxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsb0JBQW9CLENBQUMsQ0FBQztRQUNoRCxJQUFJLENBQUMsS0FBSyxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsT0FBTyxDQUFDLElBQUksRUFBRSxDQUFDO1FBQ3ZDLElBQUksSUFBSSxDQUFDLEtBQUssQ0FBQyxRQUFRLEVBQUUsQ0FBQztZQUN4QixJQUFJLENBQUMsS0FBSyxJQUFJLElBQUksQ0FBQztRQUNyQixDQUFDO1FBQ0QsSUFBSSxLQUFLLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsT0FBTyxDQUFDLEVBQUUsQ0FBQztZQUNuQyxJQUFJLENBQUMsbUJBQW1CLEdBQUcsSUFBSSxDQUFDLEVBQUUsQ0FBQyxPQUFPLENBQUM7UUFDN0MsQ0FBQztRQUVELCtDQUErQztRQUMvQyxNQUFNLFlBQVksR0FBRyxJQUFJLENBQUMsV0FBVyxDQUFDLEtBQUssQ0FBQztRQUM1QyxJQUFJLEtBQUssQ0FBQyxPQUFPLENBQUMsWUFBWSxDQUFDLEVBQUUsQ0FBQztZQUNoQyxJQUFJLENBQUMsY0FBYyxHQUFHLFlBQVksQ0FBQztRQUNyQyxDQUFDO2FBQU0sSUFBSSxZQUFZLElBQUksWUFBWSxDQUFDLEVBQUUsRUFBRSxDQUFDO1lBQzNDLElBQUksQ0FBQyxjQUFjLEdBQUcsQ0FBQyxZQUFZLENBQUMsQ0FBQztRQUN2QyxDQUFDO0lBQ0gsQ0FBQztJQUVELElBQWEsV0FBVztRQUN0QixJQUFJLElBQUksQ0FBQyxLQUFLLENBQUMsR0FBRyxFQUFFLENBQUM7WUFDbkIsTUFBTSxPQUFPLEdBQ1gsT0FBTyxJQUFJLENBQUMsS0FBSyxDQUFDLEdBQUcsS0FBSyxRQUFRLElBQUksS0FBSyxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQztnQkFDakUsQ0FBQyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsR0FBRztnQkFDaEIsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQyxDQUFDO1lBQzdCLE9BQU8sSUFBSSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsT0FBTyxDQUFnQixDQUFDO1FBQy9DLENBQUM7UUFDRCxPQUFPLElBQUksV0FBVyxFQUFFLENBQUM7SUFDM0IsQ0FBQztJQUVELFNBQVMsQ0FBQyxNQUFXO1FBQ25CLE9BQU8sSUFBSSxDQUFDLGNBQWMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUMsQ0FBQyxFQUFFLEtBQUssTUFBTSxDQUFDLEtBQUssQ0FBQyxFQUFFLENBQUMsQ0FBQztJQUNuRSxDQUFDO0lBRUQsZ0JBQWdCLENBQUMsS0FBd0IsRUFBRSxNQUFXO1FBQ3BELElBQUksS0FBSyxDQUFDLE9BQU8sRUFBRSxDQUFDO1lBQ2xCLG1CQUFtQjtZQUNuQixJQUFJLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxNQUFNLENBQUMsRUFBRSxDQUFDO2dCQUM1QixJQUFJLENBQUMsY0FBYyxHQUFHLENBQUMsR0FBRyxJQUFJLENBQUMsY0FBYyxFQUFFLE1BQU0sQ0FBQyxLQUFLLENBQUMsQ0FBQztZQUMvRCxDQUFDO1FBQ0gsQ0FBQzthQUFNLENBQUM7WUFDTix3QkFBd0I7WUFDeEIsSUFBSSxDQUFDLGNBQWMsR0FBRyxJQUFJLENBQUMsY0FBYyxDQUFDLE1BQU0sQ0FDOUMsQ0FBQyxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUMsQ0FBQyxFQUFFLEtBQUssTUFBTSxDQUFDLEtBQUssQ0FBQyxFQUFFLENBQ2hDLENBQUM7UUFDSixDQUFDO1FBRUQsMkNBQTJDO1FBQzNDLElBQUksQ0FBQyxXQUFXLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxjQUFjLENBQUMsQ0FBQztRQUUvQywwQkFBMEI7UUFDMUIsSUFBSSxJQUFJLENBQUMsS0FBSyxDQUFDLHlCQUF5QixDQUFDLEVBQUUsQ0FBQztZQUMxQyxJQUFJLENBQUMsS0FBSyxDQUFDLHlCQUF5QixDQUFDLENBQUMsSUFBSSxDQUFDLGNBQWMsQ0FBQyxDQUFDO1FBQzdELENBQUM7SUFDSCxDQUFDOytHQTVEVSx5QkFBeUI7bUdBQXpCLHlCQUF5QixnRkNWdEMsbXZCQW9CQTs7NEZEVmEseUJBQXlCO2tCQUxyQyxTQUFTOytCQUNFLG1CQUFtQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgT25Jbml0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBGaWVsZFR5cGUgfSBmcm9tICdAbmd4LWZvcm1seS9jb3JlJztcbmltcG9ydCB7IEZvcm1Db250cm9sIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuaW1wb3J0IHsgTWF0Q2hlY2tib3hDaGFuZ2UgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9jaGVja2JveCc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2Zvcm1seS1jaGVja2JveGVzJyxcbiAgdGVtcGxhdGVVcmw6ICcuL2Zvcm1seS1jaGVja2JveGVzLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vZm9ybWx5LWNoZWNrYm94ZXMuY29tcG9uZW50LnNjc3MnXSxcbn0pXG5leHBvcnQgY2xhc3MgRm9ybWx5Q2hlY2tib3hlc0NvbXBvbmVudCBleHRlbmRzIEZpZWxkVHlwZSBpbXBsZW1lbnRzIE9uSW5pdCB7XG4gIGNoZWNrYm94T3B0aW9uc0xpc3Q6IGFueVtdID0gW107XG4gIHRpdGxlOiBzdHJpbmcgPSAnJztcbiAgbGFuZ0lzbzogc3RyaW5nID0gJ2VuJztcbiAgc2VsZWN0ZWRWYWx1ZXM6IGFueVtdID0gW107XG5cbiAgbmdPbkluaXQoKTogdm9pZCB7XG4gICAgdGhpcy5sYW5nSXNvID0gdGhpcy5wcm9wc1snY3VycmVudExhbmd1YWdlSXNvJ107XG4gICAgdGhpcy50aXRsZSA9IHRoaXMucHJvcHNbJ2xhYmVsJ10gfHwgJyc7XG4gICAgaWYgKHRoaXMucHJvcHMucmVxdWlyZWQpIHtcbiAgICAgIHRoaXMudGl0bGUgKz0gJyAqJztcbiAgICB9XG4gICAgaWYgKEFycmF5LmlzQXJyYXkodGhpcy50by5vcHRpb25zKSkge1xuICAgICAgdGhpcy5jaGVja2JveE9wdGlvbnNMaXN0ID0gdGhpcy50by5vcHRpb25zO1xuICAgIH1cblxuICAgIC8vIEluaXRpYWxpemUgc2VsZWN0ZWQgdmFsdWVzIGZyb20gZm9ybSBjb250cm9sXG4gICAgY29uc3QgY3VycmVudFZhbHVlID0gdGhpcy5mb3JtQ29udHJvbC52YWx1ZTtcbiAgICBpZiAoQXJyYXkuaXNBcnJheShjdXJyZW50VmFsdWUpKSB7XG4gICAgICB0aGlzLnNlbGVjdGVkVmFsdWVzID0gY3VycmVudFZhbHVlO1xuICAgIH0gZWxzZSBpZiAoY3VycmVudFZhbHVlICYmIGN1cnJlbnRWYWx1ZS5pZCkge1xuICAgICAgdGhpcy5zZWxlY3RlZFZhbHVlcyA9IFtjdXJyZW50VmFsdWVdO1xuICAgIH1cbiAgfVxuXG4gIG92ZXJyaWRlIGdldCBmb3JtQ29udHJvbCgpOiBGb3JtQ29udHJvbCB7XG4gICAgaWYgKHRoaXMuZmllbGQua2V5KSB7XG4gICAgICBjb25zdCBrZXlQYXRoID1cbiAgICAgICAgdHlwZW9mIHRoaXMuZmllbGQua2V5ID09PSAnc3RyaW5nJyB8fCBBcnJheS5pc0FycmF5KHRoaXMuZmllbGQua2V5KVxuICAgICAgICAgID8gdGhpcy5maWVsZC5rZXlcbiAgICAgICAgICA6IFN0cmluZyh0aGlzLmZpZWxkLmtleSk7XG4gICAgICByZXR1cm4gdGhpcy5mb3JtLmdldChrZXlQYXRoKSBhcyBGb3JtQ29udHJvbDtcbiAgICB9XG4gICAgcmV0dXJuIG5ldyBGb3JtQ29udHJvbCgpO1xuICB9XG5cbiAgaXNDaGVja2VkKG9wdGlvbjogYW55KTogYm9vbGVhbiB7XG4gICAgcmV0dXJuIHRoaXMuc2VsZWN0ZWRWYWx1ZXMuc29tZSgodikgPT4gdi5pZCA9PT0gb3B0aW9uLnZhbHVlLmlkKTtcbiAgfVxuXG4gIG9uQ2hlY2tib3hDaGFuZ2UoZXZlbnQ6IE1hdENoZWNrYm94Q2hhbmdlLCBvcHRpb246IGFueSk6IHZvaWQge1xuICAgIGlmIChldmVudC5jaGVja2VkKSB7XG4gICAgICAvLyBBZGQgdG8gc2VsZWN0aW9uXG4gICAgICBpZiAoIXRoaXMuaXNDaGVja2VkKG9wdGlvbikpIHtcbiAgICAgICAgdGhpcy5zZWxlY3RlZFZhbHVlcyA9IFsuLi50aGlzLnNlbGVjdGVkVmFsdWVzLCBvcHRpb24udmFsdWVdO1xuICAgICAgfVxuICAgIH0gZWxzZSB7XG4gICAgICAvLyBSZW1vdmUgZnJvbSBzZWxlY3Rpb25cbiAgICAgIHRoaXMuc2VsZWN0ZWRWYWx1ZXMgPSB0aGlzLnNlbGVjdGVkVmFsdWVzLmZpbHRlcihcbiAgICAgICAgKHYpID0+IHYuaWQgIT09IG9wdGlvbi52YWx1ZS5pZFxuICAgICAgKTtcbiAgICB9XG5cbiAgICAvLyBVcGRhdGUgZm9ybSBjb250cm9sIHdpdGggYXJyYXkgb2YgdmFsdWVzXG4gICAgdGhpcy5mb3JtQ29udHJvbC5zZXRWYWx1ZSh0aGlzLnNlbGVjdGVkVmFsdWVzKTtcblxuICAgIC8vIE5vdGlmeSBwYXJlbnQgY29tcG9uZW50XG4gICAgaWYgKHRoaXMucHJvcHNbJ29uU2VsZWN0ZWRWYWx1ZXNDaGFuZ2VkJ10pIHtcbiAgICAgIHRoaXMucHJvcHNbJ29uU2VsZWN0ZWRWYWx1ZXNDaGFuZ2VkJ10odGhpcy5zZWxlY3RlZFZhbHVlcyk7XG4gICAgfVxuICB9XG59XG4iLCI8ZGl2IGNsYXNzPVwibWF0LW1kYy10ZXh0LWZpZWxkLXdyYXBwZXIgbWRjLWNoZWNrYm94LWZpZWxkXCIgYXBwRXh0ZXJuYWxMaW5rPlxuICA8bGFiZWwgY2xhc3M9XCJjaGVja2JveC1sYWJlbFwiPlxuICAgIDxtYXJrZG93biBbZGF0YV09XCJ0aXRsZVwiPjwvbWFya2Rvd24+XG4gIDwvbGFiZWw+XG4gIDxkaXYgKm5nSWY9XCJjaGVja2JveE9wdGlvbnNMaXN0Lmxlbmd0aCA+IDBcIiBjbGFzcz1cImNoZWNrYm94LWxpc3RcIj5cbiAgICA8bmctY29udGFpbmVyICpuZ0Zvcj1cImxldCBvcHRpb24gb2YgY2hlY2tib3hPcHRpb25zTGlzdFwiPlxuICAgICAgPGRpdiBjbGFzcz1cImNoZWNrYm94LWl0ZW1cIj5cbiAgICAgICAgPG1hdC1jaGVja2JveFxuICAgICAgICAgIFtjaGVja2VkXT1cImlzQ2hlY2tlZChvcHRpb24pXCJcbiAgICAgICAgICAoY2hhbmdlKT1cIm9uQ2hlY2tib3hDaGFuZ2UoJGV2ZW50LCBvcHRpb24pXCJcbiAgICAgICAgICBjb2xvcj1cInByaW1hcnlcIj5cbiAgICAgICAgICB7eyBvcHRpb24ubGFiZWwgfX1cbiAgICAgICAgPC9tYXQtY2hlY2tib3g+XG4gICAgICA8L2Rpdj5cbiAgICA8L25nLWNvbnRhaW5lcj5cbiAgPC9kaXY+XG4gIDxkaXYgKm5nSWY9XCJzaG93RXJyb3JcIiBjbGFzcz1cInZhbGlkYXRpb24tZXJyb3JcIj5cbiAgICA8Zm9ybWx5LXZhbGlkYXRpb24tbWVzc2FnZSBbZmllbGRdPVwiZmllbGRcIj48L2Zvcm1seS12YWxpZGF0aW9uLW1lc3NhZ2U+XG4gIDwvZGl2PlxuPC9kaXY+XG4iXX0=
|
|
@@ -28,6 +28,9 @@ export class FormlyDictionaryDropdownTreeComponent extends FieldType {
|
|
|
28
28
|
this.valuesIdsToShow = [];
|
|
29
29
|
this.selectedRelatedDictionaries = [];
|
|
30
30
|
this.dictionaryLabels = {};
|
|
31
|
+
// Multiple selection support
|
|
32
|
+
this.allowMultipleSelection = false;
|
|
33
|
+
this.selectedValues = [];
|
|
31
34
|
// NEW: Properties for preloaded dictionary data
|
|
32
35
|
this.preloadedDictionary = null;
|
|
33
36
|
this.preloadedDictionaries = null;
|
|
@@ -50,6 +53,10 @@ export class FormlyDictionaryDropdownTreeComponent extends FieldType {
|
|
|
50
53
|
if (this.props['dictionaryLabels']) {
|
|
51
54
|
this.dictionaryLabels = this.props['dictionaryLabels'];
|
|
52
55
|
}
|
|
56
|
+
// Initialize multiple selection
|
|
57
|
+
if (this.props['allowMultipleSelection']) {
|
|
58
|
+
this.allowMultipleSelection = this.props['allowMultipleSelection'];
|
|
59
|
+
}
|
|
53
60
|
// NEW: Initialize preloaded dictionary data
|
|
54
61
|
if (this.props['dictionaryData']) {
|
|
55
62
|
this.preloadedDictionary = this.props['dictionaryData'];
|
|
@@ -178,11 +185,24 @@ export class FormlyDictionaryDropdownTreeComponent extends FieldType {
|
|
|
178
185
|
}
|
|
179
186
|
onSelectedDictionaryValuesChanged(values) {
|
|
180
187
|
if (values && values.length > 0) {
|
|
181
|
-
this.
|
|
182
|
-
|
|
183
|
-
this.
|
|
188
|
+
if (this.allowMultipleSelection) {
|
|
189
|
+
// Multiple selection mode
|
|
190
|
+
this.selectedValues = values;
|
|
191
|
+
this.selectedValueIds = values.map(v => v.id);
|
|
192
|
+
this.formControl.setValue(values);
|
|
193
|
+
this.updateSelectedValueText();
|
|
194
|
+
if (this.props['onSelectedValuesChanged']) {
|
|
195
|
+
this.props['onSelectedValuesChanged'](values);
|
|
196
|
+
}
|
|
197
|
+
}
|
|
198
|
+
else {
|
|
199
|
+
// Single selection mode
|
|
200
|
+
this.selectedValue = values[0];
|
|
201
|
+
if (this.autocompleteTrigger) {
|
|
202
|
+
this.autocompleteTrigger.closePanel();
|
|
203
|
+
}
|
|
204
|
+
this.onSelectedValueChanged(this.selectedValue);
|
|
184
205
|
}
|
|
185
|
-
this.onSelectedValueChanged(this.selectedValue);
|
|
186
206
|
if (this.autoInput) {
|
|
187
207
|
this.autoInput.nativeElement.value = this.filteredText = '';
|
|
188
208
|
}
|
|
@@ -213,6 +233,23 @@ export class FormlyDictionaryDropdownTreeComponent extends FieldType {
|
|
|
213
233
|
}
|
|
214
234
|
}
|
|
215
235
|
updateSelectedValueText() {
|
|
236
|
+
if (this.allowMultipleSelection) {
|
|
237
|
+
// Multiple selection mode - show comma-separated values
|
|
238
|
+
const formValue = this.formControl?.value;
|
|
239
|
+
if (Array.isArray(formValue) && formValue.length > 0) {
|
|
240
|
+
this.selectedValues = formValue;
|
|
241
|
+
this.selectedValueIds = formValue.map(v => v.id);
|
|
242
|
+
const texts = formValue.map(v => this.getValueDisplayText(v));
|
|
243
|
+
this.selectedValueText = texts.join(', ');
|
|
244
|
+
}
|
|
245
|
+
else {
|
|
246
|
+
this.selectedValueText = '';
|
|
247
|
+
this.selectedValues = [];
|
|
248
|
+
this.selectedValueIds = [];
|
|
249
|
+
}
|
|
250
|
+
return;
|
|
251
|
+
}
|
|
252
|
+
// Single selection mode
|
|
216
253
|
if (!this.selectedValue) {
|
|
217
254
|
const formValue = this.formControl?.value;
|
|
218
255
|
if (formValue && typeof formValue === 'object' && formValue.id) {
|
|
@@ -229,24 +266,27 @@ export class FormlyDictionaryDropdownTreeComponent extends FieldType {
|
|
|
229
266
|
return;
|
|
230
267
|
}
|
|
231
268
|
}
|
|
232
|
-
|
|
269
|
+
this.selectedValueText = this.getValueDisplayText(this.selectedValue);
|
|
270
|
+
}
|
|
271
|
+
getValueDisplayText(value) {
|
|
272
|
+
if (!value)
|
|
273
|
+
return '';
|
|
274
|
+
const translation = value.translations?.find((t) => t.languageId === this.currentLanguageId ||
|
|
233
275
|
t.languageIso === this.currentLanguageIso);
|
|
234
276
|
if (translation) {
|
|
235
|
-
|
|
236
|
-
}
|
|
237
|
-
else {
|
|
238
|
-
this.selectedValueText = this.selectedValue.name || '';
|
|
277
|
+
return translation.value;
|
|
239
278
|
}
|
|
279
|
+
return value.name || '';
|
|
240
280
|
}
|
|
241
281
|
getDictionaryLabel(dictionaryId) {
|
|
242
282
|
return this.dictionaryLabels[dictionaryId] || '';
|
|
243
283
|
}
|
|
244
284
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: FormlyDictionaryDropdownTreeComponent, deps: [{ token: i1.DictionaryService }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
245
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.14", type: FormlyDictionaryDropdownTreeComponent, selector: "formly-dictionary-dropdown-tree", inputs: { dictionaryId: "dictionaryId" }, outputs: { selectedValue: "selectedValue" }, viewQueries: [{ propertyName: "autocompleteTrigger", first: true, predicate: MatAutocompleteTrigger, descendants: true }, { propertyName: "autoInput", first: true, predicate: ["autoInput"], descendants: true }], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<form>\n <mat-label class=\"component-data-label m-l-2\" [ngStyle]=\"labelStyle\">\n {{ label }}</mat-label\n >\n <mat-form-field class=\"full-width\">\n <input\n type=\"text\"\n placeholder=\"{{ selectedValueText }}\"\n #autoInput\n aria-label=\"Text\"\n matInput\n [matAutocomplete]=\"auto\"\n (input)=\"filterChanged($event)\"\n (focus)=\"openAutocomplete()\"\n />\n <mat-icon matSuffix (click)=\"toggleAutocomplete($event)\"\n >keyboard_arrow_down</mat-icon\n >\n <mat-autocomplete\n #matAutocomplete=\"matAutocomplete\"\n #auto=\"matAutocomplete\"\n autoActiveFirstOption\n (optionSelected)=\"\n onSelectedDictionaryValuesChanged([$event.option.value])\n \"\n >\n <mat-option disabled>{{\n formlyKeys.selectAnItem | translate\n }}</mat-option>\n <app-dictionaries-tree\n [allowCheckItems]=\"
|
|
285
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.14", type: FormlyDictionaryDropdownTreeComponent, selector: "formly-dictionary-dropdown-tree", inputs: { dictionaryId: "dictionaryId" }, outputs: { selectedValue: "selectedValue" }, viewQueries: [{ propertyName: "autocompleteTrigger", first: true, predicate: MatAutocompleteTrigger, descendants: true }, { propertyName: "autoInput", first: true, predicate: ["autoInput"], descendants: true }], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<form>\n <mat-label class=\"component-data-label m-l-2\" [ngStyle]=\"labelStyle\">\n {{ label }}</mat-label\n >\n <mat-form-field class=\"full-width\">\n <input\n type=\"text\"\n placeholder=\"{{ selectedValueText }}\"\n #autoInput\n aria-label=\"Text\"\n matInput\n [matAutocomplete]=\"auto\"\n (input)=\"filterChanged($event)\"\n (focus)=\"openAutocomplete()\"\n />\n <mat-icon matSuffix (click)=\"toggleAutocomplete($event)\"\n >keyboard_arrow_down</mat-icon\n >\n <mat-autocomplete\n #matAutocomplete=\"matAutocomplete\"\n #auto=\"matAutocomplete\"\n autoActiveFirstOption\n (optionSelected)=\"\n onSelectedDictionaryValuesChanged([$event.option.value])\n \"\n >\n <mat-option disabled>{{\n formlyKeys.selectAnItem | translate\n }}</mat-option>\n <app-dictionaries-tree\n [allowCheckItems]=\"allowMultipleSelection\"\n [drawReferenceDictionariesAsSeparateNode]=\"false\"\n [drawChildDictionariesAsSeparateNode]=\"false\"\n [drawRootNode]=\"false\"\n [filterText]=\"filteredText\"\n [allowSelectNonLeafNodes]=\"true\"\n [selectedValueIds]=\"selectedValueIds\"\n [languageId]=\"currentLanguageId\"\n [valuesIdsToShow]=\"valuesIdsToShow\"\n [selectedRelatedDictionaries]=\"selectedRelatedDictionaries\"\n [dictionaryLabels]=\"dictionaryLabels\"\n [preloadedDictionary]=\"preloadedDictionary\"\n [preloadedDictionaries]=\"preloadedDictionaries\"\n [usePreloadedData]=\"usePreloadedData\"\n (selectedDictionaryValuesChanged)=\"\n onSelectedDictionaryValuesChanged($event)\n \"\n >\n </app-dictionaries-tree>\n </mat-autocomplete>\n </mat-form-field>\n\n <formly-validation-message *ngIf=\"showError\" [field]=\"field\">\n </formly-validation-message>\n</form>\n", styles: ["formly-validation-message{color:red;font-size:12px}::ng-deep .mat-mdc-autocomplete-panel>app-dictionaries-tree>app-treeview>cdk-virtual-scroll-viewport{overflow:hidden}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "directive", type: i3.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i3.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i3.NgForm, selector: "form:not([ngNoForm]):not([formGroup]),ng-form,[ngForm]", inputs: ["ngFormOptions"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i4.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "component", type: i5.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i5.MatLabel, selector: "mat-label" }, { kind: "directive", type: i5.MatSuffix, selector: "[matSuffix], [matIconSuffix], [matTextSuffix]", inputs: ["matTextSuffix"] }, { kind: "component", type: i6.MatAutocomplete, selector: "mat-autocomplete", inputs: ["aria-label", "aria-labelledby", "displayWith", "autoActiveFirstOption", "autoSelectActiveOption", "requireSelection", "panelWidth", "disableRipple", "class", "hideSingleSelectionIndicator"], outputs: ["optionSelected", "opened", "closed", "optionActivated"], exportAs: ["matAutocomplete"] }, { kind: "component", type: i7.MatOption, selector: "mat-option", inputs: ["value", "id", "disabled"], outputs: ["onSelectionChange"], exportAs: ["matOption"] }, { kind: "directive", type: i6.MatAutocompleteTrigger, selector: "input[matAutocomplete], textarea[matAutocomplete]", inputs: ["matAutocomplete", "matAutocompletePosition", "matAutocompleteConnectedTo", "autocomplete", "matAutocompleteDisabled"], exportAs: ["matAutocompleteTrigger"] }, { kind: "component", type: i8.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i9.ɵFormlyValidationMessage, selector: "formly-validation-message", inputs: ["field"] }, { kind: "component", type: i10.DictionariesTreeComponent, selector: "app-dictionaries-tree", inputs: ["dictionaryId", "selectedValueIds", "allowCheckItems", "allowFilter", "drawReferenceDictionariesAsSeparateNode", "drawChildDictionariesAsSeparateNode", "drawRootNode", "filterText", "allowSelectNonLeafNodes", "languageId", "valuesIdsToShow", "hideParentArrow", "preloadedDictionary", "preloadedDictionaries", "usePreloadedData"], outputs: ["selectedDictionaryValuesChanged"] }, { kind: "pipe", type: i11.TranslatePipe, name: "translate" }] }); }
|
|
246
286
|
}
|
|
247
287
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: FormlyDictionaryDropdownTreeComponent, decorators: [{
|
|
248
288
|
type: Component,
|
|
249
|
-
args: [{ selector: 'formly-dictionary-dropdown-tree', template: "<form>\n <mat-label class=\"component-data-label m-l-2\" [ngStyle]=\"labelStyle\">\n {{ label }}</mat-label\n >\n <mat-form-field class=\"full-width\">\n <input\n type=\"text\"\n placeholder=\"{{ selectedValueText }}\"\n #autoInput\n aria-label=\"Text\"\n matInput\n [matAutocomplete]=\"auto\"\n (input)=\"filterChanged($event)\"\n (focus)=\"openAutocomplete()\"\n />\n <mat-icon matSuffix (click)=\"toggleAutocomplete($event)\"\n >keyboard_arrow_down</mat-icon\n >\n <mat-autocomplete\n #matAutocomplete=\"matAutocomplete\"\n #auto=\"matAutocomplete\"\n autoActiveFirstOption\n (optionSelected)=\"\n onSelectedDictionaryValuesChanged([$event.option.value])\n \"\n >\n <mat-option disabled>{{\n formlyKeys.selectAnItem | translate\n }}</mat-option>\n <app-dictionaries-tree\n [allowCheckItems]=\"
|
|
289
|
+
args: [{ selector: 'formly-dictionary-dropdown-tree', template: "<form>\n <mat-label class=\"component-data-label m-l-2\" [ngStyle]=\"labelStyle\">\n {{ label }}</mat-label\n >\n <mat-form-field class=\"full-width\">\n <input\n type=\"text\"\n placeholder=\"{{ selectedValueText }}\"\n #autoInput\n aria-label=\"Text\"\n matInput\n [matAutocomplete]=\"auto\"\n (input)=\"filterChanged($event)\"\n (focus)=\"openAutocomplete()\"\n />\n <mat-icon matSuffix (click)=\"toggleAutocomplete($event)\"\n >keyboard_arrow_down</mat-icon\n >\n <mat-autocomplete\n #matAutocomplete=\"matAutocomplete\"\n #auto=\"matAutocomplete\"\n autoActiveFirstOption\n (optionSelected)=\"\n onSelectedDictionaryValuesChanged([$event.option.value])\n \"\n >\n <mat-option disabled>{{\n formlyKeys.selectAnItem | translate\n }}</mat-option>\n <app-dictionaries-tree\n [allowCheckItems]=\"allowMultipleSelection\"\n [drawReferenceDictionariesAsSeparateNode]=\"false\"\n [drawChildDictionariesAsSeparateNode]=\"false\"\n [drawRootNode]=\"false\"\n [filterText]=\"filteredText\"\n [allowSelectNonLeafNodes]=\"true\"\n [selectedValueIds]=\"selectedValueIds\"\n [languageId]=\"currentLanguageId\"\n [valuesIdsToShow]=\"valuesIdsToShow\"\n [selectedRelatedDictionaries]=\"selectedRelatedDictionaries\"\n [dictionaryLabels]=\"dictionaryLabels\"\n [preloadedDictionary]=\"preloadedDictionary\"\n [preloadedDictionaries]=\"preloadedDictionaries\"\n [usePreloadedData]=\"usePreloadedData\"\n (selectedDictionaryValuesChanged)=\"\n onSelectedDictionaryValuesChanged($event)\n \"\n >\n </app-dictionaries-tree>\n </mat-autocomplete>\n </mat-form-field>\n\n <formly-validation-message *ngIf=\"showError\" [field]=\"field\">\n </formly-validation-message>\n</form>\n", styles: ["formly-validation-message{color:red;font-size:12px}::ng-deep .mat-mdc-autocomplete-panel>app-dictionaries-tree>app-treeview>cdk-virtual-scroll-viewport{overflow:hidden}\n"] }]
|
|
250
290
|
}], ctorParameters: () => [{ type: i1.DictionaryService }, { type: i0.ChangeDetectorRef }], propDecorators: { autocompleteTrigger: [{
|
|
251
291
|
type: ViewChild,
|
|
252
292
|
args: [MatAutocompleteTrigger]
|
|
@@ -258,4 +298,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
|
|
|
258
298
|
}], selectedValue: [{
|
|
259
299
|
type: Output
|
|
260
300
|
}] } });
|
|
261
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"formly-dictionary-dropdown-tree.component.js","sourceRoot":"","sources":["../../../../../../projects/origin-form/src/lib/formly/formly-dictionary-dropdown-tree/formly-dictionary-dropdown-tree.component.ts","../../../../../../projects/origin-form/src/lib/formly/formly-dictionary-dropdown-tree/formly-dictionary-dropdown-tree.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  ElementRef,\n  Input,\n  OnInit,\n  Output,\n  SimpleChanges,\n  ViewChild,\n  ChangeDetectorRef,\n} from '@angular/core';\nimport { MatAutocompleteTrigger } from '@angular/material/autocomplete';\nimport { FieldType } from '@ngx-formly/core';\nimport { take } from 'rxjs';\nimport { DictionaryValue, TranslationDto, Translation, DictionaryValueDto, DictionaryDto } from '../../models/dictionary.model';\nimport { Language } from '../../models/language.model';\nimport { EnvironmentType } from '../../others/environment-type';\nimport { DictionaryService } from '../../services/dictionary.service';\nimport { LabelKeys } from '../../enums/label.keys';\n\n\n@Component({\n  selector: 'formly-dictionary-dropdown-tree',\n  templateUrl: './formly-dictionary-dropdown-tree.component.html',\n  styleUrls: ['./formly-dictionary-dropdown-tree.component.scss'],\n})\nexport class FormlyDictionaryDropdownTreeComponent\n  extends FieldType\n  implements OnInit\n{\n  @ViewChild(MatAutocompleteTrigger)\n  autocompleteTrigger: MatAutocompleteTrigger;\n  @ViewChild('autoInput') autoInput: ElementRef;\n  @Input() dictionaryId: string;\n  @Output() selectedValue: DictionaryValue;\n  filteredText: string;\n  formlyKeys = LabelKeys.formly;\n  label: string;\n  currentLanguageIso: string;\n  currentLanguageId: number;\n  selectedValueText: string = '';\n  labelStyle: any = {};\n  selectedValueIds: number[] = [];\n  valuesIdsToShow: number[] = [];\n  selectedRelatedDictionaries: string[] = [];\n  dictionaryLabels: { [key: string]: string } = {};\n\n  // NEW: Properties for preloaded dictionary data\n  preloadedDictionary: DictionaryDto | null = null;\n  preloadedDictionaries: Map<string, DictionaryDto> | null = null;\n  usePreloadedData: boolean = false;\n\n  constructor(\n    private dictionaryService: DictionaryService,\n    private cdRef: ChangeDetectorRef\n  ) {\n    super();\n  }\n\n  ngOnInit(): void {\n    if (this.props['dictionaryId']) {\n      this.dictionaryId = this.props['dictionaryId'];\n    }\n    if (this.props['valuesIdsToShow']) {\n      this.valuesIdsToShow = this.props['valuesIdsToShow'];\n    }\n    if (this.props['value']) {\n      this.selectedValueText = this.props['value'];\n    }\n    if (this.props['selectedRelatedDictionaries']) {\n      this.selectedRelatedDictionaries =\n        this.props['selectedRelatedDictionaries'];\n    }\n    if (this.props['dictionaryLabels']) {\n      this.dictionaryLabels = this.props['dictionaryLabels'];\n    }\n\n    // NEW: Initialize preloaded dictionary data\n    if (this.props['dictionaryData']) {\n      this.preloadedDictionary = this.props['dictionaryData'];\n      this.usePreloadedData = true;\n    }\n    if (this.props['preloadedDictionaries']) {\n      this.preloadedDictionaries = this.props['preloadedDictionaries'];\n    }\n\n    this.label = this.props['label'] as string;\n    if (this.props.required) {\n      this.label += ' *';\n    }\n    this.currentLanguageIso = this.props['currentLanguageIso'] as string;\n    this.currentLanguageId = this.props['currentLanguageId'] as number;\n\n    if (this.props['design']) {\n      this.labelStyle = this.props['design']['.component-data-label'] || {};\n    }\n    if (\n      this.props['selectedValueIds'] &&\n      Array.isArray(this.props['selectedValueIds'])\n    ) {\n      this.selectedValueIds = this.props['selectedValueIds'];\n    }\n\n    const initialControlValue = this.formControl.value;\n    const dictionaryDefaultValueId = this.props['dictionaryDefaultValueId'] as\n      | number\n      | null;\n\n    if (\n      initialControlValue == null &&\n      dictionaryDefaultValueId != null &&\n      this.dictionaryId\n    ) {\n      const dictionary = this.props['dictionaryData'];\n      this.formControl.setValue(dictionaryDefaultValueId, {\n        emitEvent: false,\n      });\n\n      if (dictionary) {\n        const defaultValueDto = dictionary.values?.find(\n          (v: DictionaryValueDto) => v.id === dictionaryDefaultValueId\n        );\n        if (defaultValueDto) {\n          const valueToSet: DictionaryValue = {\n            id: defaultValueDto.id,\n            name: defaultValueDto.name,\n            translations:\n              defaultValueDto.valueTranslations?.map(\n                (t: TranslationDto): Translation => {\n                  const languages = this.props['languages'] as\n                    | Language[]\n                    | undefined;\n                  const lang = languages?.find((l) => l.id === t.languageId);\n                  return {\n                    languageId: t.languageId,\n                    languageIso: lang?.iso ?? '',\n                    value: t.value,\n                  };\n                }\n              ) || [],\n            active: defaultValueDto.active,\n            locked: defaultValueDto.locked,\n            childDictionaryId: defaultValueDto.childDictionaryId,\n            childDictionaryUUID: defaultValueDto.childDictionaryUUID,\n            referenceValues: [],\n          };\n\n          this.formControl.setValue(valueToSet, { emitEvent: false });\n          this.selectedValueIds = [defaultValueDto.id];\n          this.selectedValue = valueToSet;\n          this.updateSelectedValueText();\n          this.cdRef.markForCheck();\n        } else {\n          this.updateSelectedValueText();\n        }\n      } else {\n        console.warn(\n          'Dictionary data not preloaded, falling back to API call for:',\n          this.dictionaryId\n        );\n\n        this.dictionaryService\n          .getDictionary(this.dictionaryId, EnvironmentType.Config)\n          .pipe(take(1))\n          .subscribe(\n            (dto) => {\n              const defaultValueDto = dto.values?.find(\n                (v: DictionaryValueDto) => v.id === dictionaryDefaultValueId\n              );\n              if (defaultValueDto) {\n                const valueToSet: DictionaryValue = {\n                  id: defaultValueDto.id,\n                  name: defaultValueDto.name,\n                  translations:\n                    defaultValueDto.valueTranslations?.map(\n                      (t: TranslationDto): Translation => {\n                        const languages = this.props['languages'] as\n                          | Language[]\n                          | undefined;\n                        const lang = languages?.find(\n                          (l) => l.id === t.languageId\n                        );\n                        return {\n                          languageId: t.languageId,\n                          languageIso: lang?.iso ?? '',\n                          value: t.value,\n                        };\n                      }\n                    ) || [],\n                  active: defaultValueDto.active,\n                  locked: defaultValueDto.locked,\n                  childDictionaryId: defaultValueDto.childDictionaryId,\n                  childDictionaryUUID: defaultValueDto.childDictionaryUUID,\n                  referenceValues: [],\n                };\n\n                this.formControl.setValue(valueToSet, { emitEvent: false });\n                this.selectedValueIds = [defaultValueDto.id];\n                this.selectedValue = valueToSet;\n                this.updateSelectedValueText();\n                this.cdRef.markForCheck();\n              } else {\n                this.updateSelectedValueText();\n              }\n            },\n            (error) => {\n              console.error(\n                'Formly Dict: Failed to fetch details for default value',\n                error\n              );\n              this.updateSelectedValueText();\n            }\n          );\n      }\n    } else {\n      this.updateSelectedValueText();\n    }\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['model'] || changes['formControl']) {\n      this.updateSelectedValueIds();\n    }\n  }\n\n  updateSelectedValueIds(): void {\n    const modelValue = this.formControl?.value;\n\n    if (modelValue && Array.isArray(modelValue.selectedValueIds)) {\n      this.selectedValueIds = modelValue.selectedValueIds;\n    } else if (modelValue && modelValue.id) {\n      this.selectedValueIds = [modelValue.id];\n    }\n  }\n\n  onSelectedValueChanged(dictionaryValue: DictionaryValue) {\n    if (this.props['onSelectedValueChanged']) {\n      this.props['onSelectedValueChanged'](dictionaryValue);\n    }\n    this.updateSelectedValueText();\n  }\n\n  onSelectedDictionaryValuesChanged(values: DictionaryValue[]) {\n    if (values && values.length > 0) {\n      this.selectedValue = values[0];\n      if (this.autocompleteTrigger) {\n        this.autocompleteTrigger.closePanel();\n      }\n      this.onSelectedValueChanged(this.selectedValue);\n\n      if (this.autoInput) {\n        this.autoInput.nativeElement.value = this.filteredText = '';\n      }\n    }\n  }\n\n  filterChanged($event: any) {\n    if ($event.target) {\n      this.filteredText = $event.target.value;\n    }\n  }\n\n  toggleAutocomplete(event: MouseEvent) {\n    event.stopPropagation();\n    if (this.autocompleteTrigger) {\n      if (this.autocompleteTrigger.panelOpen) {\n        this.autocompleteTrigger.closePanel();\n      } else {\n        this.autocompleteTrigger.openPanel();\n        if (this.autoInput) {\n          this.autoInput.nativeElement.focus();\n        }\n      }\n    }\n  }\n\n  openAutocomplete() {\n    if (this.autocompleteTrigger && !this.autocompleteTrigger.panelOpen) {\n      this.autocompleteTrigger.openPanel();\n    }\n  }\n\n  private updateSelectedValueText(): void {\n    if (!this.selectedValue) {\n      const formValue = this.formControl?.value;\n      if (formValue && typeof formValue === 'object' && formValue.id) {\n        this.selectedValue = formValue as DictionaryValue;\n      } else {\n        const specificData = this.props?.['specificData'];\n        if (specificData && specificData.isMandatory !== true) {\n          this.props['required'] = specificData.isMandatory;\n          this.formControl.updateValueAndValidity();\n          this.formControl.setErrors(null);\n        }\n        this.selectedValueText = '';\n        return;\n      }\n    }\n\n    const translation = this.selectedValue.translations?.find(\n      (t) =>\n        t.languageId === this.currentLanguageId ||\n        t.languageIso === this.currentLanguageIso\n    );\n    if (translation) {\n      this.selectedValueText = translation.value;\n    } else {\n      this.selectedValueText = this.selectedValue.name || '';\n    }\n  }\n\n  getDictionaryLabel(dictionaryId: string): string {\n    return this.dictionaryLabels[dictionaryId] || '';\n  }\n}\n","<form>\n  <mat-label class=\"component-data-label m-l-2\" [ngStyle]=\"labelStyle\">\n    {{ label }}</mat-label\n  >\n  <mat-form-field class=\"full-width\">\n    <input\n      type=\"text\"\n      placeholder=\"{{ selectedValueText }}\"\n      #autoInput\n      aria-label=\"Text\"\n      matInput\n      [matAutocomplete]=\"auto\"\n      (input)=\"filterChanged($event)\"\n      (focus)=\"openAutocomplete()\"\n    />\n    <mat-icon matSuffix (click)=\"toggleAutocomplete($event)\"\n      >keyboard_arrow_down</mat-icon\n    >\n    <mat-autocomplete\n      #matAutocomplete=\"matAutocomplete\"\n      #auto=\"matAutocomplete\"\n      autoActiveFirstOption\n      (optionSelected)=\"\n        onSelectedDictionaryValuesChanged([$event.option.value])\n      \"\n    >\n      <mat-option disabled>{{\n        formlyKeys.selectAnItem | translate\n      }}</mat-option>\n      <app-dictionaries-tree\n        [allowCheckItems]=\"false\"\n        [drawReferenceDictionariesAsSeparateNode]=\"false\"\n        [drawChildDictionariesAsSeparateNode]=\"false\"\n        [drawRootNode]=\"false\"\n        [filterText]=\"filteredText\"\n        [allowSelectNonLeafNodes]=\"true\"\n        [selectedValueIds]=\"selectedValueIds\"\n        [languageId]=\"currentLanguageId\"\n        [valuesIdsToShow]=\"valuesIdsToShow\"\n        [selectedRelatedDictionaries]=\"selectedRelatedDictionaries\"\n        [dictionaryLabels]=\"dictionaryLabels\"\n        [preloadedDictionary]=\"preloadedDictionary\"\n        [preloadedDictionaries]=\"preloadedDictionaries\"\n        [usePreloadedData]=\"usePreloadedData\"\n        (selectedDictionaryValuesChanged)=\"\n          onSelectedDictionaryValuesChanged($event)\n        \"\n      >\n      </app-dictionaries-tree>\n    </mat-autocomplete>\n  </mat-form-field>\n\n  <formly-validation-message *ngIf=\"showError\" [field]=\"field\">\n  </formly-validation-message>\n</form>\n"]}
|
|
301
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"formly-dictionary-dropdown-tree.component.js","sourceRoot":"","sources":["../../../../../../projects/origin-form/src/lib/formly/formly-dictionary-dropdown-tree/formly-dictionary-dropdown-tree.component.ts","../../../../../../projects/origin-form/src/lib/formly/formly-dictionary-dropdown-tree/formly-dictionary-dropdown-tree.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  ElementRef,\n  Input,\n  OnInit,\n  Output,\n  SimpleChanges,\n  ViewChild,\n  ChangeDetectorRef,\n} from '@angular/core';\nimport { MatAutocompleteTrigger } from '@angular/material/autocomplete';\nimport { FieldType } from '@ngx-formly/core';\nimport { take } from 'rxjs';\nimport { DictionaryValue, TranslationDto, Translation, DictionaryValueDto, DictionaryDto } from '../../models/dictionary.model';\nimport { Language } from '../../models/language.model';\nimport { EnvironmentType } from '../../others/environment-type';\nimport { DictionaryService } from '../../services/dictionary.service';\nimport { LabelKeys } from '../../enums/label.keys';\n\n\n@Component({\n  selector: 'formly-dictionary-dropdown-tree',\n  templateUrl: './formly-dictionary-dropdown-tree.component.html',\n  styleUrls: ['./formly-dictionary-dropdown-tree.component.scss'],\n})\nexport class FormlyDictionaryDropdownTreeComponent\n  extends FieldType\n  implements OnInit\n{\n  @ViewChild(MatAutocompleteTrigger)\n  autocompleteTrigger: MatAutocompleteTrigger;\n  @ViewChild('autoInput') autoInput: ElementRef;\n  @Input() dictionaryId: string;\n  @Output() selectedValue: DictionaryValue;\n  filteredText: string;\n  formlyKeys = LabelKeys.formly;\n  label: string;\n  currentLanguageIso: string;\n  currentLanguageId: number;\n  selectedValueText: string = '';\n  labelStyle: any = {};\n  selectedValueIds: number[] = [];\n  valuesIdsToShow: number[] = [];\n  selectedRelatedDictionaries: string[] = [];\n  dictionaryLabels: { [key: string]: string } = {};\n\n  // Multiple selection support\n  allowMultipleSelection: boolean = false;\n  selectedValues: DictionaryValue[] = [];\n\n  // NEW: Properties for preloaded dictionary data\n  preloadedDictionary: DictionaryDto | null = null;\n  preloadedDictionaries: Map<string, DictionaryDto> | null = null;\n  usePreloadedData: boolean = false;\n\n  constructor(\n    private dictionaryService: DictionaryService,\n    private cdRef: ChangeDetectorRef\n  ) {\n    super();\n  }\n\n  ngOnInit(): void {\n    if (this.props['dictionaryId']) {\n      this.dictionaryId = this.props['dictionaryId'];\n    }\n    if (this.props['valuesIdsToShow']) {\n      this.valuesIdsToShow = this.props['valuesIdsToShow'];\n    }\n    if (this.props['value']) {\n      this.selectedValueText = this.props['value'];\n    }\n    if (this.props['selectedRelatedDictionaries']) {\n      this.selectedRelatedDictionaries =\n        this.props['selectedRelatedDictionaries'];\n    }\n    if (this.props['dictionaryLabels']) {\n      this.dictionaryLabels = this.props['dictionaryLabels'];\n    }\n\n    // Initialize multiple selection\n    if (this.props['allowMultipleSelection']) {\n      this.allowMultipleSelection = this.props['allowMultipleSelection'];\n    }\n\n    // NEW: Initialize preloaded dictionary data\n    if (this.props['dictionaryData']) {\n      this.preloadedDictionary = this.props['dictionaryData'];\n      this.usePreloadedData = true;\n    }\n    if (this.props['preloadedDictionaries']) {\n      this.preloadedDictionaries = this.props['preloadedDictionaries'];\n    }\n\n    this.label = this.props['label'] as string;\n    if (this.props.required) {\n      this.label += ' *';\n    }\n    this.currentLanguageIso = this.props['currentLanguageIso'] as string;\n    this.currentLanguageId = this.props['currentLanguageId'] as number;\n\n    if (this.props['design']) {\n      this.labelStyle = this.props['design']['.component-data-label'] || {};\n    }\n    if (\n      this.props['selectedValueIds'] &&\n      Array.isArray(this.props['selectedValueIds'])\n    ) {\n      this.selectedValueIds = this.props['selectedValueIds'];\n    }\n\n    const initialControlValue = this.formControl.value;\n    const dictionaryDefaultValueId = this.props['dictionaryDefaultValueId'] as\n      | number\n      | null;\n\n    if (\n      initialControlValue == null &&\n      dictionaryDefaultValueId != null &&\n      this.dictionaryId\n    ) {\n      const dictionary = this.props['dictionaryData'];\n      this.formControl.setValue(dictionaryDefaultValueId, {\n        emitEvent: false,\n      });\n\n      if (dictionary) {\n        const defaultValueDto = dictionary.values?.find(\n          (v: DictionaryValueDto) => v.id === dictionaryDefaultValueId\n        );\n        if (defaultValueDto) {\n          const valueToSet: DictionaryValue = {\n            id: defaultValueDto.id,\n            name: defaultValueDto.name,\n            translations:\n              defaultValueDto.valueTranslations?.map(\n                (t: TranslationDto): Translation => {\n                  const languages = this.props['languages'] as\n                    | Language[]\n                    | undefined;\n                  const lang = languages?.find((l) => l.id === t.languageId);\n                  return {\n                    languageId: t.languageId,\n                    languageIso: lang?.iso ?? '',\n                    value: t.value,\n                  };\n                }\n              ) || [],\n            active: defaultValueDto.active,\n            locked: defaultValueDto.locked,\n            childDictionaryId: defaultValueDto.childDictionaryId,\n            childDictionaryUUID: defaultValueDto.childDictionaryUUID,\n            referenceValues: [],\n          };\n\n          this.formControl.setValue(valueToSet, { emitEvent: false });\n          this.selectedValueIds = [defaultValueDto.id];\n          this.selectedValue = valueToSet;\n          this.updateSelectedValueText();\n          this.cdRef.markForCheck();\n        } else {\n          this.updateSelectedValueText();\n        }\n      } else {\n        console.warn(\n          'Dictionary data not preloaded, falling back to API call for:',\n          this.dictionaryId\n        );\n\n        this.dictionaryService\n          .getDictionary(this.dictionaryId, EnvironmentType.Config)\n          .pipe(take(1))\n          .subscribe(\n            (dto) => {\n              const defaultValueDto = dto.values?.find(\n                (v: DictionaryValueDto) => v.id === dictionaryDefaultValueId\n              );\n              if (defaultValueDto) {\n                const valueToSet: DictionaryValue = {\n                  id: defaultValueDto.id,\n                  name: defaultValueDto.name,\n                  translations:\n                    defaultValueDto.valueTranslations?.map(\n                      (t: TranslationDto): Translation => {\n                        const languages = this.props['languages'] as\n                          | Language[]\n                          | undefined;\n                        const lang = languages?.find(\n                          (l) => l.id === t.languageId\n                        );\n                        return {\n                          languageId: t.languageId,\n                          languageIso: lang?.iso ?? '',\n                          value: t.value,\n                        };\n                      }\n                    ) || [],\n                  active: defaultValueDto.active,\n                  locked: defaultValueDto.locked,\n                  childDictionaryId: defaultValueDto.childDictionaryId,\n                  childDictionaryUUID: defaultValueDto.childDictionaryUUID,\n                  referenceValues: [],\n                };\n\n                this.formControl.setValue(valueToSet, { emitEvent: false });\n                this.selectedValueIds = [defaultValueDto.id];\n                this.selectedValue = valueToSet;\n                this.updateSelectedValueText();\n                this.cdRef.markForCheck();\n              } else {\n                this.updateSelectedValueText();\n              }\n            },\n            (error) => {\n              console.error(\n                'Formly Dict: Failed to fetch details for default value',\n                error\n              );\n              this.updateSelectedValueText();\n            }\n          );\n      }\n    } else {\n      this.updateSelectedValueText();\n    }\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['model'] || changes['formControl']) {\n      this.updateSelectedValueIds();\n    }\n  }\n\n  updateSelectedValueIds(): void {\n    const modelValue = this.formControl?.value;\n\n    if (modelValue && Array.isArray(modelValue.selectedValueIds)) {\n      this.selectedValueIds = modelValue.selectedValueIds;\n    } else if (modelValue && modelValue.id) {\n      this.selectedValueIds = [modelValue.id];\n    }\n  }\n\n  onSelectedValueChanged(dictionaryValue: DictionaryValue) {\n    if (this.props['onSelectedValueChanged']) {\n      this.props['onSelectedValueChanged'](dictionaryValue);\n    }\n    this.updateSelectedValueText();\n  }\n\n  onSelectedDictionaryValuesChanged(values: DictionaryValue[]) {\n    if (values && values.length > 0) {\n      if (this.allowMultipleSelection) {\n        // Multiple selection mode\n        this.selectedValues = values;\n        this.selectedValueIds = values.map(v => v.id);\n        this.formControl.setValue(values);\n        this.updateSelectedValueText();\n\n        if (this.props['onSelectedValuesChanged']) {\n          this.props['onSelectedValuesChanged'](values);\n        }\n      } else {\n        // Single selection mode\n        this.selectedValue = values[0];\n        if (this.autocompleteTrigger) {\n          this.autocompleteTrigger.closePanel();\n        }\n        this.onSelectedValueChanged(this.selectedValue);\n      }\n\n      if (this.autoInput) {\n        this.autoInput.nativeElement.value = this.filteredText = '';\n      }\n    }\n  }\n\n  filterChanged($event: any) {\n    if ($event.target) {\n      this.filteredText = $event.target.value;\n    }\n  }\n\n  toggleAutocomplete(event: MouseEvent) {\n    event.stopPropagation();\n    if (this.autocompleteTrigger) {\n      if (this.autocompleteTrigger.panelOpen) {\n        this.autocompleteTrigger.closePanel();\n      } else {\n        this.autocompleteTrigger.openPanel();\n        if (this.autoInput) {\n          this.autoInput.nativeElement.focus();\n        }\n      }\n    }\n  }\n\n  openAutocomplete() {\n    if (this.autocompleteTrigger && !this.autocompleteTrigger.panelOpen) {\n      this.autocompleteTrigger.openPanel();\n    }\n  }\n\n  private updateSelectedValueText(): void {\n    if (this.allowMultipleSelection) {\n      // Multiple selection mode - show comma-separated values\n      const formValue = this.formControl?.value;\n      if (Array.isArray(formValue) && formValue.length > 0) {\n        this.selectedValues = formValue;\n        this.selectedValueIds = formValue.map(v => v.id);\n        const texts = formValue.map(v => this.getValueDisplayText(v));\n        this.selectedValueText = texts.join(', ');\n      } else {\n        this.selectedValueText = '';\n        this.selectedValues = [];\n        this.selectedValueIds = [];\n      }\n      return;\n    }\n\n    // Single selection mode\n    if (!this.selectedValue) {\n      const formValue = this.formControl?.value;\n      if (formValue && typeof formValue === 'object' && formValue.id) {\n        this.selectedValue = formValue as DictionaryValue;\n      } else {\n        const specificData = this.props?.['specificData'];\n        if (specificData && specificData.isMandatory !== true) {\n          this.props['required'] = specificData.isMandatory;\n          this.formControl.updateValueAndValidity();\n          this.formControl.setErrors(null);\n        }\n        this.selectedValueText = '';\n        return;\n      }\n    }\n\n    this.selectedValueText = this.getValueDisplayText(this.selectedValue);\n  }\n\n  private getValueDisplayText(value: DictionaryValue): string {\n    if (!value) return '';\n\n    const translation = value.translations?.find(\n      (t) =>\n        t.languageId === this.currentLanguageId ||\n        t.languageIso === this.currentLanguageIso\n    );\n    if (translation) {\n      return translation.value;\n    }\n    return value.name || '';\n  }\n\n  getDictionaryLabel(dictionaryId: string): string {\n    return this.dictionaryLabels[dictionaryId] || '';\n  }\n}\n","<form>\n  <mat-label class=\"component-data-label m-l-2\" [ngStyle]=\"labelStyle\">\n    {{ label }}</mat-label\n  >\n  <mat-form-field class=\"full-width\">\n    <input\n      type=\"text\"\n      placeholder=\"{{ selectedValueText }}\"\n      #autoInput\n      aria-label=\"Text\"\n      matInput\n      [matAutocomplete]=\"auto\"\n      (input)=\"filterChanged($event)\"\n      (focus)=\"openAutocomplete()\"\n    />\n    <mat-icon matSuffix (click)=\"toggleAutocomplete($event)\"\n      >keyboard_arrow_down</mat-icon\n    >\n    <mat-autocomplete\n      #matAutocomplete=\"matAutocomplete\"\n      #auto=\"matAutocomplete\"\n      autoActiveFirstOption\n      (optionSelected)=\"\n        onSelectedDictionaryValuesChanged([$event.option.value])\n      \"\n    >\n      <mat-option disabled>{{\n        formlyKeys.selectAnItem | translate\n      }}</mat-option>\n      <app-dictionaries-tree\n        [allowCheckItems]=\"allowMultipleSelection\"\n        [drawReferenceDictionariesAsSeparateNode]=\"false\"\n        [drawChildDictionariesAsSeparateNode]=\"false\"\n        [drawRootNode]=\"false\"\n        [filterText]=\"filteredText\"\n        [allowSelectNonLeafNodes]=\"true\"\n        [selectedValueIds]=\"selectedValueIds\"\n        [languageId]=\"currentLanguageId\"\n        [valuesIdsToShow]=\"valuesIdsToShow\"\n        [selectedRelatedDictionaries]=\"selectedRelatedDictionaries\"\n        [dictionaryLabels]=\"dictionaryLabels\"\n        [preloadedDictionary]=\"preloadedDictionary\"\n        [preloadedDictionaries]=\"preloadedDictionaries\"\n        [usePreloadedData]=\"usePreloadedData\"\n        (selectedDictionaryValuesChanged)=\"\n          onSelectedDictionaryValuesChanged($event)\n        \"\n      >\n      </app-dictionaries-tree>\n    </mat-autocomplete>\n  </mat-form-field>\n\n  <formly-validation-message *ngIf=\"showError\" [field]=\"field\">\n  </formly-validation-message>\n</form>\n"]}
|