@indigina/kendo 1.2.58 → 1.2.59
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/widgets/entity-edit/dropdowns/field-dropdown/field-dropdown.component.mjs +40 -40
- package/fesm2022/indigina-kendo.mjs +39 -39
- package/fesm2022/indigina-kendo.mjs.map +1 -1
- package/lib/widgets/entity-edit/dropdowns/field-dropdown/field-dropdown.component.d.ts +7 -9
- package/package.json +1 -1
package/esm2022/lib/widgets/entity-edit/dropdowns/field-dropdown/field-dropdown.component.mjs
CHANGED
|
@@ -26,21 +26,6 @@ export class FieldDropdownComponent extends FieldComponent {
|
|
|
26
26
|
this.setData();
|
|
27
27
|
this.setDefaultItem();
|
|
28
28
|
}
|
|
29
|
-
setDefaultItem() {
|
|
30
|
-
this.defaultItem = {
|
|
31
|
-
name: this.setDefaultName(),
|
|
32
|
-
id: null,
|
|
33
|
-
};
|
|
34
|
-
if (this.textField !== defaultFieldName) {
|
|
35
|
-
this.setTextFieldForDefaultItem();
|
|
36
|
-
}
|
|
37
|
-
}
|
|
38
|
-
setTextFieldForDefaultItem() {
|
|
39
|
-
this.defaultItem[this.textField] = this.setDefaultName();
|
|
40
|
-
}
|
|
41
|
-
setDefaultName() {
|
|
42
|
-
return this.translate.instant(this.defaultName || SelectValue);
|
|
43
|
-
}
|
|
44
29
|
ngOnChanges() {
|
|
45
30
|
super.ngOnChanges();
|
|
46
31
|
this.setData();
|
|
@@ -48,42 +33,53 @@ export class FieldDropdownComponent extends FieldComponent {
|
|
|
48
33
|
onValueChange(event) {
|
|
49
34
|
let entity = undefined;
|
|
50
35
|
if (event !== null) {
|
|
51
|
-
entity = this.
|
|
52
|
-
? this.getEntityFromDataById(event)
|
|
53
|
-
: this.getEntityById(event);
|
|
36
|
+
entity = this.getEntityById(event);
|
|
54
37
|
}
|
|
55
38
|
this.emitSelectedEntity(entity || this.defaultItem);
|
|
56
39
|
}
|
|
57
40
|
setData() {
|
|
58
41
|
if (this.data) {
|
|
59
|
-
this.
|
|
42
|
+
let dataSubject = new BehaviorSubject(this.data);
|
|
43
|
+
this.data$ = dataSubject.asObservable();
|
|
44
|
+
this.handleSelectedEntity();
|
|
60
45
|
}
|
|
61
46
|
else {
|
|
62
47
|
this.data$ = this.service
|
|
63
48
|
.getPage(this.filter ? { filter: this.filter } : {})
|
|
64
49
|
.pipe(tap((x) => {
|
|
65
50
|
this.items = x.data;
|
|
66
|
-
|
|
67
|
-
this.handleSelectedEntityValues(this.selectedItem.id);
|
|
68
|
-
}
|
|
69
|
-
else {
|
|
70
|
-
this.updateControlWithSelectedEntity(this.control.value);
|
|
71
|
-
}
|
|
51
|
+
this.handleSelectedEntity();
|
|
72
52
|
}), map((x) => x.data));
|
|
73
53
|
}
|
|
74
54
|
}
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
55
|
+
setDefaultItem() {
|
|
56
|
+
this.defaultItem = {
|
|
57
|
+
name: this.setDefaultName(),
|
|
58
|
+
id: null,
|
|
59
|
+
};
|
|
60
|
+
if (this.textField !== defaultFieldName) {
|
|
61
|
+
this.setTextFieldForDefaultItem();
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
setTextFieldForDefaultItem() {
|
|
65
|
+
this.defaultItem[this.textField] = this.setDefaultName();
|
|
66
|
+
}
|
|
67
|
+
setDefaultName() {
|
|
68
|
+
return this.translate.instant(this.defaultName || SelectValue);
|
|
78
69
|
}
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
70
|
+
handleSelectedEntity() {
|
|
71
|
+
if (this.selectedItem) {
|
|
72
|
+
const selectedEntity = this.updateControlValue(this.selectedItem.id);
|
|
73
|
+
if (selectedEntity?.id) {
|
|
74
|
+
this.onValueChange(selectedEntity.id);
|
|
75
|
+
this.writeSelectedEntityValue(selectedEntity.id);
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
else {
|
|
79
|
+
this.updateControlValue(this.control.value);
|
|
84
80
|
}
|
|
85
81
|
}
|
|
86
|
-
|
|
82
|
+
updateControlValue(entityId) {
|
|
87
83
|
const entity = this.getEntityById(entityId);
|
|
88
84
|
if (entity) {
|
|
89
85
|
this.setControlValue(entity);
|
|
@@ -93,11 +89,15 @@ export class FieldDropdownComponent extends FieldComponent {
|
|
|
93
89
|
}
|
|
94
90
|
return entity;
|
|
95
91
|
}
|
|
96
|
-
getEntityFromDataById(entityId) {
|
|
97
|
-
return this.data.find((x) => x.id === entityId);
|
|
98
|
-
}
|
|
99
92
|
getEntityById(entityId) {
|
|
100
|
-
|
|
93
|
+
let entity;
|
|
94
|
+
if (this.data) {
|
|
95
|
+
entity = this.data.find((x) => x.id === entityId);
|
|
96
|
+
}
|
|
97
|
+
else {
|
|
98
|
+
entity = this.items.find((x) => x.id === entityId);
|
|
99
|
+
}
|
|
100
|
+
return entity;
|
|
101
101
|
}
|
|
102
102
|
setControlValue(entity) {
|
|
103
103
|
this.control.setValue(entity.id);
|
|
@@ -109,7 +109,7 @@ export class FieldDropdownComponent extends FieldComponent {
|
|
|
109
109
|
this.selectedChange.emit(entity);
|
|
110
110
|
}
|
|
111
111
|
writeSelectedEntityValue(selectedEntityId) {
|
|
112
|
-
this.kendoDropDown
|
|
112
|
+
this.kendoDropDown?.writeValue(selectedEntityId);
|
|
113
113
|
}
|
|
114
114
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.0", ngImport: i0, type: FieldDropdownComponent, deps: [{ token: i1.FormGroupDirective }, { token: i0.ElementRef }, { token: i2.TranslateService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
115
115
|
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.0", type: FieldDropdownComponent, selector: "field-dropdown", inputs: { service: "service", rebind: "rebind", filter: "filter", defaultName: "defaultName", selectedItem: "selectedItem", data: "data", textField: "textField" }, outputs: { selectedChange: "selectedChange" }, viewQueries: [{ propertyName: "kendoDropDown", first: true, predicate: ["inputElement"], descendants: true }], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<div class=\"form-group\">\n <label\n for=\"{{ '_' + fieldName }}\"\n class=\"col-md-3 control-label\"\n translate=\"{{ labelKey }}\"\n ></label>\n <div class=\"col-md-9\" *ngIf=\"control\">\n <kendo-dropdownlist\n id=\"{{ '_' + fieldName }}\"\n [formControl]=\"control\"\n [data]=\"data$ | async\"\n [textField]=\"textField\"\n valueField=\"id\"\n [valuePrimitive]=\"true\"\n [defaultItem]=\"defaultItem\"\n (valueChange)=\"onValueChange($event)\"\n #inputElement\n >\n </kendo-dropdownlist>\n\n <div class=\"bg-danger\" *ngIf=\"control.invalid && control.touched\">\n <span *ngIf=\"control.errors['required']\">{{\n \"Required\" | translate : { param0: labelKey | translate }\n }}</span>\n <span *ngIf=\"control.errors['serverErrorMsg']\">{{\n control.errors[\"serverErrorMsg\"]\n }}</span>\n </div>\n </div>\n</div>\n", dependencies: [{ kind: "directive", type: i2.TranslateDirective, selector: "[translate],[ngx-translate]", inputs: ["translate", "translateParams"] }, { kind: "component", type: i3.DropDownListComponent, selector: "kendo-dropdownlist", inputs: ["customIconClass", "showStickyHeader", "icon", "svgIcon", "loading", "data", "value", "textField", "valueField", "adaptiveMode", "title", "subtitle", "popupSettings", "listHeight", "defaultItem", "disabled", "itemDisabled", "readonly", "filterable", "virtual", "ignoreCase", "delay", "valuePrimitive", "tabindex", "tabIndex", "size", "rounded", "fillMode", "leftRightArrowsNavigation", "id"], outputs: ["valueChange", "filterChange", "selectionChange", "open", "opened", "close", "closed", "focus", "blur"], exportAs: ["kendoDropDownList"] }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i2.TranslatePipe, name: "translate" }, { kind: "pipe", type: i4.AsyncPipe, name: "async" }], viewProviders: [
|
|
@@ -141,4 +141,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.0", ngImpor
|
|
|
141
141
|
type: ViewChild,
|
|
142
142
|
args: ['inputElement']
|
|
143
143
|
}] } });
|
|
144
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"field-dropdown.component.js","sourceRoot":"","sources":["../../../../../../../../projects/kendo/src/lib/widgets/entity-edit/dropdowns/field-dropdown/field-dropdown.component.ts","../../../../../../../../projects/kendo/src/lib/widgets/entity-edit/dropdowns/dropdown.component.html"],"names":[],"mappings":"AAAA,OAAO,EACL,SAAS,EACT,KAAK,EAEL,uBAAuB,EACvB,MAAM,EACN,YAAY,EACZ,SAAS,GACV,MAAM,eAAe,CAAC;AACvB,OAAO,EACL,gBAAgB,EAChB,kBAAkB,GAEnB,MAAM,gBAAgB,CAAC;AAExB,OAAO,EAAE,eAAe,EAAE,GAAG,EAAc,GAAG,EAAE,MAAM,MAAM,CAAC;AAC7D,OAAO,EAAE,cAAc,EAAE,MAAM,yDAAyD,CAAC;;;;;;AAMzF,MAAM,WAAW,GAAW,cAAc,CAAC;AAC3C,MAAM,gBAAgB,GAAW,MAAM,CAAC;AAUxC,MAAM,OAAO,sBAAuB,SAAQ,cAAsB;IAuBhE,IAAI,OAAO;QACT,OAAO,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;IAC9C,CAAC;IAED,YACS,MAA0B,EAC1B,IAAgB,EACf,SAA2B;QAEnC,KAAK,CAAC,MAAM,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;QAJnB,WAAM,GAAN,MAAM,CAAoB;QAC1B,SAAI,GAAJ,IAAI,CAAY;QACf,cAAS,GAAT,SAAS,CAAkB;QAhBrC,cAAS,GAAW,gBAAgB,CAAC;QAC3B,mBAAc,GACtB,IAAI,YAAY,EAAE,CAAC;IAiBrB,CAAC;IAED,QAAQ;QACN,KAAK,CAAC,QAAQ,EAAE,CAAC;QACjB,IAAI,CAAC,OAAO,EAAE,CAAC;QACf,IAAI,CAAC,cAAc,EAAE,CAAC;IACxB,CAAC;IAEO,cAAc;QACpB,IAAI,CAAC,WAAW,GAAG;YACjB,IAAI,EAAE,IAAI,CAAC,cAAc,EAAE;YAC3B,EAAE,EAAE,IAAI;SACT,CAAC;QACF,IAAI,IAAI,CAAC,SAAS,KAAK,gBAAgB,EAAE;YACvC,IAAI,CAAC,0BAA0B,EAAE,CAAC;SACnC;IACH,CAAC;IAEO,0BAA0B;QAChC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,IAAI,CAAC,cAAc,EAAE,CAAC;IAC3D,CAAC;IAEO,cAAc;QACpB,OAAO,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,IAAI,CAAC,WAAW,IAAI,WAAW,CAAC,CAAC;IACjE,CAAC;IAED,WAAW;QACT,KAAK,CAAC,WAAW,EAAE,CAAC;QACpB,IAAI,CAAC,OAAO,EAAE,CAAC;IACjB,CAAC;IAEM,aAAa,CAAC,KAAa;QAChC,IAAI,MAAM,GAA2B,SAAS,CAAC;QAC/C,IAAI,KAAK,KAAK,IAAI,EAAE;YAClB,MAAM,GAAG,IAAI,CAAC,IAAI;gBAChB,CAAC,CAAC,IAAI,CAAC,qBAAqB,CAAC,KAAK,CAAC;gBACnC,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;SAC/B;QAED,IAAI,CAAC,kBAAkB,CAAC,MAAM,IAAI,IAAI,CAAC,WAAW,CAAC,CAAC;IACtD,CAAC;IAED,OAAO;QACL,IAAI,IAAI,CAAC,IAAI,EAAE;YACb,IAAI,CAAC,YAAY,EAAE,CAAC;SACrB;aAAM;YACL,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,OAAO;iBACtB,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,MAAM,EAAE,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;iBACnD,IAAI,CACH,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE;gBACR,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC,IAAI,CAAC;gBACpB,IAAI,IAAI,CAAC,YAAY,EAAE;oBACrB,IAAI,CAAC,0BAA0B,CAAC,IAAI,CAAC,YAAY,CAAC,EAAE,CAAC,CAAC;iBACvD;qBAAM;oBACL,IAAI,CAAC,+BAA+B,CAAC,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;iBAC1D;YACH,CAAC,CAAC,EACF,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CACnB,CAAC;SACL;IACH,CAAC;IAEO,YAAY;QAClB,IAAI,WAAW,GAAkC,IAAI,eAAe,CAElE,IAAI,CAAC,IAAI,CAAC,CAAC;QACb,IAAI,CAAC,KAAK,GAAG,WAAW,CAAC,YAAY,EAAE,CAAC;IAC1C,CAAC;IAEM,0BAA0B,CAAC,QAAgB;QAChD,MAAM,cAAc,GAClB,IAAI,CAAC,+BAA+B,CAAC,QAAQ,CAAC,CAAC;QACjD,IAAI,cAAc,EAAE,EAAE,EAAE;YACtB,IAAI,CAAC,aAAa,CAAC,cAAc,CAAC,EAAE,CAAC,CAAC;YACtC,IAAI,CAAC,wBAAwB,CAAC,cAAc,CAAC,EAAE,CAAC,CAAC;SAClD;IACH,CAAC;IAEO,+BAA+B,CAAC,QAAgB;QACtD,MAAM,MAAM,GAAe,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC;QACxD,IAAI,MAAM,EAAE;YACV,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,CAAC;SAC9B;aAAM;YACL,IAAI,CAAC,iBAAiB,EAAE,CAAC;SAC1B;QAED,OAAO,MAAM,CAAC;IAChB,CAAC;IAEO,qBAAqB,CAAC,QAAgB;QAC5C,OAAO,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,QAAQ,CAAC,CAAC;IAClD,CAAC;IAEM,aAAa,CAAC,QAAgB;QACnC,OAAO,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,QAAQ,CAAC,CAAC;IACnD,CAAC;IAEO,eAAe,CAAC,MAAkB;QACxC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;IACnC,CAAC;IAEO,iBAAiB;QACvB,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,CAAC;IACvB,CAAC;IAEM,kBAAkB,CAAC,MAAkB;QAC1C,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IACnC,CAAC;IAEO,wBAAwB,CAAC,gBAAwB;QACvD,IAAI,CAAC,aAAa,CAAC,UAAU,CAAC,gBAAgB,CAAC,CAAC;IAClD,CAAC;8GAhJU,sBAAsB;kGAAtB,sBAAsB,oaCjCnC,i6BA8BA,sxCDFiB;YACb,EAAE,OAAO,EAAE,gBAAgB,EAAE,WAAW,EAAE,kBAAkB,EAAE;SAC/D;;2FAGU,sBAAsB;kBARlC,SAAS;+BACE,gBAAgB,iBAEX;wBACb,EAAE,OAAO,EAAE,gBAAgB,EAAE,WAAW,EAAE,kBAAkB,EAAE;qBAC/D,mBACgB,uBAAuB,CAAC,MAAM;+IAI/C,OAAO;sBADN,KAAK;gBAGN,MAAM;sBADL,KAAK;gBAGN,MAAM;sBADL,KAAK;gBAGN,WAAW;sBADV,KAAK;gBAGN,YAAY;sBADX,KAAK;gBAGN,IAAI;sBADH,KAAK;gBAGN,SAAS;sBADR,KAAK;gBAEI,cAAc;sBAAvB,MAAM;gBAGC,aAAa;sBADpB,SAAS;uBAAC,cAAc","sourcesContent":["import {\n  Component,\n  Input,\n  ElementRef,\n  ChangeDetectionStrategy,\n  Output,\n  EventEmitter,\n  ViewChild,\n} from '@angular/core';\nimport {\n  ControlContainer,\n  FormGroupDirective,\n  AbstractControl,\n} from '@angular/forms';\nimport { CompositeFilterDescriptor } from '@progress/kendo-data-query';\nimport { BehaviorSubject, map, Observable, tap } from 'rxjs';\nimport { FieldComponent } from '../../../../angular/forms/widgets/field/field.component';\nimport { NamedModel } from '../../../../angular/models/NamedModel';\nimport { IGetPageService } from '../../../../services/get-page.service.interface';\nimport { TranslateService } from '@ngx-translate/core';\nimport { DropDownListComponent } from '@progress/kendo-angular-dropdowns';\n\nconst SelectValue: string = 'Select value';\nconst defaultFieldName: string = 'name';\n\n@Component({\n  selector: 'field-dropdown',\n  templateUrl: '../dropdown.component.html',\n  viewProviders: [\n    { provide: ControlContainer, useExisting: FormGroupDirective },\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class FieldDropdownComponent extends FieldComponent<string> {\n  @Input()\n  service: IGetPageService<NamedModel>;\n  @Input()\n  rebind: string;\n  @Input()\n  filter?: CompositeFilterDescriptor;\n  @Input()\n  defaultName?: string;\n  @Input()\n  selectedItem?: NamedModel;\n  @Input()\n  data?: NamedModel[];\n  @Input()\n  textField: string = defaultFieldName;\n  @Output() selectedChange: EventEmitter<NamedModel | number | string> =\n    new EventEmitter();\n  @ViewChild('inputElement')\n  private kendoDropDown: DropDownListComponent;\n\n  private items: NamedModel[];\n  public defaultItem: NamedModel;\n  public data$: Observable<NamedModel[]>;\n  get control(): AbstractControl {\n    return this.parent.form.get(this.fieldName);\n  }\n\n  constructor(\n    public parent: FormGroupDirective,\n    public eref: ElementRef,\n    private translate: TranslateService,\n  ) {\n    super(parent, eref, null);\n  }\n\n  ngOnInit(): void {\n    super.ngOnInit();\n    this.setData();\n    this.setDefaultItem();\n  }\n\n  private setDefaultItem(): void {\n    this.defaultItem = {\n      name: this.setDefaultName(),\n      id: null,\n    };\n    if (this.textField !== defaultFieldName) {\n      this.setTextFieldForDefaultItem();\n    }\n  }\n\n  private setTextFieldForDefaultItem(): void {\n    this.defaultItem[this.textField] = this.setDefaultName();\n  }\n\n  private setDefaultName(): string {\n    return this.translate.instant(this.defaultName || SelectValue);\n  }\n\n  ngOnChanges(): void {\n    super.ngOnChanges();\n    this.setData();\n  }\n\n  public onValueChange(event: string): void {\n    let entity: NamedModel | undefined = undefined;\n    if (event !== null) {\n      entity = this.data\n        ? this.getEntityFromDataById(event)\n        : this.getEntityById(event);\n    }\n\n    this.emitSelectedEntity(entity || this.defaultItem);\n  }\n\n  setData(): void {\n    if (this.data) {\n      this.setInputData();\n    } else {\n      this.data$ = this.service\n        .getPage(this.filter ? { filter: this.filter } : {})\n        .pipe(\n          tap((x) => {\n            this.items = x.data;\n            if (this.selectedItem) {\n              this.handleSelectedEntityValues(this.selectedItem.id);\n            } else {\n              this.updateControlWithSelectedEntity(this.control.value);\n            }\n          }),\n          map((x) => x.data),\n        );\n    }\n  }\n\n  private setInputData(): void {\n    let dataSubject: BehaviorSubject<NamedModel[]> = new BehaviorSubject<\n      NamedModel[]\n    >(this.data);\n    this.data$ = dataSubject.asObservable();\n  }\n\n  public handleSelectedEntityValues(entityId: string): void {\n    const selectedEntity: NamedModel =\n      this.updateControlWithSelectedEntity(entityId);\n    if (selectedEntity?.id) {\n      this.onValueChange(selectedEntity.id);\n      this.writeSelectedEntityValue(selectedEntity.id);\n    }\n  }\n\n  private updateControlWithSelectedEntity(entityId: string): NamedModel {\n    const entity: NamedModel = this.getEntityById(entityId);\n    if (entity) {\n      this.setControlValue(entity);\n    } else {\n      this.resetControlValue();\n    }\n\n    return entity;\n  }\n\n  private getEntityFromDataById(entityId: string): NamedModel {\n    return this.data.find((x) => x.id === entityId);\n  }\n\n  public getEntityById(entityId: string): NamedModel {\n    return this.items.find((x) => x.id === entityId);\n  }\n\n  private setControlValue(entity: NamedModel): void {\n    this.control.setValue(entity.id);\n  }\n\n  private resetControlValue(): void {\n    this.control.reset();\n  }\n\n  public emitSelectedEntity(entity: NamedModel): void {\n    this.selectedChange.emit(entity);\n  }\n\n  private writeSelectedEntityValue(selectedEntityId: string): void {\n    this.kendoDropDown.writeValue(selectedEntityId);\n  }\n}\n","<div class=\"form-group\">\n  <label\n    for=\"{{ '_' + fieldName }}\"\n    class=\"col-md-3 control-label\"\n    translate=\"{{ labelKey }}\"\n  ></label>\n  <div class=\"col-md-9\" *ngIf=\"control\">\n    <kendo-dropdownlist\n      id=\"{{ '_' + fieldName }}\"\n      [formControl]=\"control\"\n      [data]=\"data$ | async\"\n      [textField]=\"textField\"\n      valueField=\"id\"\n      [valuePrimitive]=\"true\"\n      [defaultItem]=\"defaultItem\"\n      (valueChange)=\"onValueChange($event)\"\n      #inputElement\n    >\n    </kendo-dropdownlist>\n\n    <div class=\"bg-danger\" *ngIf=\"control.invalid && control.touched\">\n      <span *ngIf=\"control.errors['required']\">{{\n        \"Required\" | translate : { param0: labelKey | translate }\n      }}</span>\n      <span *ngIf=\"control.errors['serverErrorMsg']\">{{\n        control.errors[\"serverErrorMsg\"]\n      }}</span>\n    </div>\n  </div>\n</div>\n"]}
|
|
144
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"field-dropdown.component.js","sourceRoot":"","sources":["../../../../../../../../projects/kendo/src/lib/widgets/entity-edit/dropdowns/field-dropdown/field-dropdown.component.ts","../../../../../../../../projects/kendo/src/lib/widgets/entity-edit/dropdowns/dropdown.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  Input,\n  ElementRef,\n  ChangeDetectionStrategy,\n  Output,\n  EventEmitter,\n  ViewChild,\n} from '@angular/core';\nimport {\n  ControlContainer,\n  FormGroupDirective,\n  AbstractControl,\n} from '@angular/forms';\nimport { CompositeFilterDescriptor } from '@progress/kendo-data-query';\nimport { BehaviorSubject, map, Observable, tap } from 'rxjs';\nimport { FieldComponent } from '../../../../angular/forms/widgets/field/field.component';\nimport { NamedModel } from '../../../../angular/models/NamedModel';\nimport { IGetPageService } from '../../../../services/get-page.service.interface';\nimport { TranslateService } from '@ngx-translate/core';\nimport { DropDownListComponent } from '@progress/kendo-angular-dropdowns';\n\nconst SelectValue: string = 'Select value';\nconst defaultFieldName: string = 'name';\n\n@Component({\n  selector: 'field-dropdown',\n  templateUrl: '../dropdown.component.html',\n  viewProviders: [\n    { provide: ControlContainer, useExisting: FormGroupDirective },\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class FieldDropdownComponent extends FieldComponent<string> {\n  @Input() service: IGetPageService<NamedModel>;\n  @Input() rebind: string;\n  @Input() filter?: CompositeFilterDescriptor;\n  @Input() defaultName?: string;\n  @Input() selectedItem?: NamedModel;\n  @Input() data?: NamedModel[];\n  @Input() textField: string = defaultFieldName;\n  @Output() selectedChange: EventEmitter<NamedModel | number | string> =\n    new EventEmitter();\n  @ViewChild('inputElement')\n  private kendoDropDown: DropDownListComponent;\n\n  private items: NamedModel[];\n  public defaultItem: NamedModel;\n  public data$: Observable<NamedModel[]>;\n  get control(): AbstractControl {\n    return this.parent.form.get(this.fieldName);\n  }\n\n  constructor(\n    public parent: FormGroupDirective,\n    public eref: ElementRef,\n    private translate: TranslateService,\n  ) {\n    super(parent, eref, null);\n  }\n\n  ngOnInit(): void {\n    super.ngOnInit();\n    this.setData();\n    this.setDefaultItem();\n  }\n\n  ngOnChanges(): void {\n    super.ngOnChanges();\n    this.setData();\n  }\n\n  public onValueChange(event: string): void {\n    let entity: NamedModel | undefined = undefined;\n    if (event !== null) {\n      entity = this.getEntityById(event);\n    }\n\n    this.emitSelectedEntity(entity || this.defaultItem);\n  }\n\n  public setData(): void {\n    if (this.data) {\n      let dataSubject: BehaviorSubject<NamedModel[]> = new BehaviorSubject<\n        NamedModel[]\n      >(this.data);\n      this.data$ = dataSubject.asObservable();\n      this.handleSelectedEntity();\n    } else {\n      this.data$ = this.service\n        .getPage(this.filter ? { filter: this.filter } : {})\n        .pipe(\n          tap((x) => {\n            this.items = x.data;\n            this.handleSelectedEntity();\n          }),\n          map((x) => x.data),\n        );\n    }\n  }\n\n  private setDefaultItem(): void {\n    this.defaultItem = {\n      name: this.setDefaultName(),\n      id: null,\n    };\n    if (this.textField !== defaultFieldName) {\n      this.setTextFieldForDefaultItem();\n    }\n  }\n\n  private setTextFieldForDefaultItem(): void {\n    this.defaultItem[this.textField] = this.setDefaultName();\n  }\n\n  private setDefaultName(): string {\n    return this.translate.instant(this.defaultName || SelectValue);\n  }\n\n  private handleSelectedEntity(): void {\n    if (this.selectedItem) {\n      const selectedEntity: NamedModel = this.updateControlValue(\n        this.selectedItem.id,\n      );\n      if (selectedEntity?.id) {\n        this.onValueChange(selectedEntity.id);\n        this.writeSelectedEntityValue(selectedEntity.id);\n      }\n    } else {\n      this.updateControlValue(this.control.value);\n    }\n  }\n\n  private updateControlValue(entityId: string): NamedModel {\n    const entity: NamedModel = this.getEntityById(entityId);\n    if (entity) {\n      this.setControlValue(entity);\n    } else {\n      this.resetControlValue();\n    }\n\n    return entity;\n  }\n\n  private getEntityById(entityId: string): NamedModel {\n    let entity: NamedModel;\n    if (this.data) {\n      entity = this.data.find((x) => x.id === entityId);\n    } else {\n      entity = this.items.find((x) => x.id === entityId);\n    }\n\n    return entity;\n  }\n\n  private setControlValue(entity: NamedModel): void {\n    this.control.setValue(entity.id);\n  }\n\n  private resetControlValue(): void {\n    this.control.reset();\n  }\n\n  private emitSelectedEntity(entity: NamedModel): void {\n    this.selectedChange.emit(entity);\n  }\n\n  private writeSelectedEntityValue(selectedEntityId: string): void {\n    this.kendoDropDown?.writeValue(selectedEntityId);\n  }\n}\n","<div class=\"form-group\">\n  <label\n    for=\"{{ '_' + fieldName }}\"\n    class=\"col-md-3 control-label\"\n    translate=\"{{ labelKey }}\"\n  ></label>\n  <div class=\"col-md-9\" *ngIf=\"control\">\n    <kendo-dropdownlist\n      id=\"{{ '_' + fieldName }}\"\n      [formControl]=\"control\"\n      [data]=\"data$ | async\"\n      [textField]=\"textField\"\n      valueField=\"id\"\n      [valuePrimitive]=\"true\"\n      [defaultItem]=\"defaultItem\"\n      (valueChange)=\"onValueChange($event)\"\n      #inputElement\n    >\n    </kendo-dropdownlist>\n\n    <div class=\"bg-danger\" *ngIf=\"control.invalid && control.touched\">\n      <span *ngIf=\"control.errors['required']\">{{\n        \"Required\" | translate : { param0: labelKey | translate }\n      }}</span>\n      <span *ngIf=\"control.errors['serverErrorMsg']\">{{\n        control.errors[\"serverErrorMsg\"]\n      }}</span>\n    </div>\n  </div>\n</div>\n"]}
|
|
@@ -2899,21 +2899,6 @@ class FieldDropdownComponent extends FieldComponent {
|
|
|
2899
2899
|
this.setData();
|
|
2900
2900
|
this.setDefaultItem();
|
|
2901
2901
|
}
|
|
2902
|
-
setDefaultItem() {
|
|
2903
|
-
this.defaultItem = {
|
|
2904
|
-
name: this.setDefaultName(),
|
|
2905
|
-
id: null,
|
|
2906
|
-
};
|
|
2907
|
-
if (this.textField !== defaultFieldName) {
|
|
2908
|
-
this.setTextFieldForDefaultItem();
|
|
2909
|
-
}
|
|
2910
|
-
}
|
|
2911
|
-
setTextFieldForDefaultItem() {
|
|
2912
|
-
this.defaultItem[this.textField] = this.setDefaultName();
|
|
2913
|
-
}
|
|
2914
|
-
setDefaultName() {
|
|
2915
|
-
return this.translate.instant(this.defaultName || SelectValue$1);
|
|
2916
|
-
}
|
|
2917
2902
|
ngOnChanges() {
|
|
2918
2903
|
super.ngOnChanges();
|
|
2919
2904
|
this.setData();
|
|
@@ -2921,42 +2906,53 @@ class FieldDropdownComponent extends FieldComponent {
|
|
|
2921
2906
|
onValueChange(event) {
|
|
2922
2907
|
let entity = undefined;
|
|
2923
2908
|
if (event !== null) {
|
|
2924
|
-
entity = this.
|
|
2925
|
-
? this.getEntityFromDataById(event)
|
|
2926
|
-
: this.getEntityById(event);
|
|
2909
|
+
entity = this.getEntityById(event);
|
|
2927
2910
|
}
|
|
2928
2911
|
this.emitSelectedEntity(entity || this.defaultItem);
|
|
2929
2912
|
}
|
|
2930
2913
|
setData() {
|
|
2931
2914
|
if (this.data) {
|
|
2932
|
-
this.
|
|
2915
|
+
let dataSubject = new BehaviorSubject(this.data);
|
|
2916
|
+
this.data$ = dataSubject.asObservable();
|
|
2917
|
+
this.handleSelectedEntity();
|
|
2933
2918
|
}
|
|
2934
2919
|
else {
|
|
2935
2920
|
this.data$ = this.service
|
|
2936
2921
|
.getPage(this.filter ? { filter: this.filter } : {})
|
|
2937
2922
|
.pipe(tap$1((x) => {
|
|
2938
2923
|
this.items = x.data;
|
|
2939
|
-
|
|
2940
|
-
this.handleSelectedEntityValues(this.selectedItem.id);
|
|
2941
|
-
}
|
|
2942
|
-
else {
|
|
2943
|
-
this.updateControlWithSelectedEntity(this.control.value);
|
|
2944
|
-
}
|
|
2924
|
+
this.handleSelectedEntity();
|
|
2945
2925
|
}), map$1((x) => x.data));
|
|
2946
2926
|
}
|
|
2947
2927
|
}
|
|
2948
|
-
|
|
2949
|
-
|
|
2950
|
-
|
|
2928
|
+
setDefaultItem() {
|
|
2929
|
+
this.defaultItem = {
|
|
2930
|
+
name: this.setDefaultName(),
|
|
2931
|
+
id: null,
|
|
2932
|
+
};
|
|
2933
|
+
if (this.textField !== defaultFieldName) {
|
|
2934
|
+
this.setTextFieldForDefaultItem();
|
|
2935
|
+
}
|
|
2936
|
+
}
|
|
2937
|
+
setTextFieldForDefaultItem() {
|
|
2938
|
+
this.defaultItem[this.textField] = this.setDefaultName();
|
|
2939
|
+
}
|
|
2940
|
+
setDefaultName() {
|
|
2941
|
+
return this.translate.instant(this.defaultName || SelectValue$1);
|
|
2951
2942
|
}
|
|
2952
|
-
|
|
2953
|
-
|
|
2954
|
-
|
|
2955
|
-
|
|
2956
|
-
|
|
2943
|
+
handleSelectedEntity() {
|
|
2944
|
+
if (this.selectedItem) {
|
|
2945
|
+
const selectedEntity = this.updateControlValue(this.selectedItem.id);
|
|
2946
|
+
if (selectedEntity?.id) {
|
|
2947
|
+
this.onValueChange(selectedEntity.id);
|
|
2948
|
+
this.writeSelectedEntityValue(selectedEntity.id);
|
|
2949
|
+
}
|
|
2950
|
+
}
|
|
2951
|
+
else {
|
|
2952
|
+
this.updateControlValue(this.control.value);
|
|
2957
2953
|
}
|
|
2958
2954
|
}
|
|
2959
|
-
|
|
2955
|
+
updateControlValue(entityId) {
|
|
2960
2956
|
const entity = this.getEntityById(entityId);
|
|
2961
2957
|
if (entity) {
|
|
2962
2958
|
this.setControlValue(entity);
|
|
@@ -2966,11 +2962,15 @@ class FieldDropdownComponent extends FieldComponent {
|
|
|
2966
2962
|
}
|
|
2967
2963
|
return entity;
|
|
2968
2964
|
}
|
|
2969
|
-
getEntityFromDataById(entityId) {
|
|
2970
|
-
return this.data.find((x) => x.id === entityId);
|
|
2971
|
-
}
|
|
2972
2965
|
getEntityById(entityId) {
|
|
2973
|
-
|
|
2966
|
+
let entity;
|
|
2967
|
+
if (this.data) {
|
|
2968
|
+
entity = this.data.find((x) => x.id === entityId);
|
|
2969
|
+
}
|
|
2970
|
+
else {
|
|
2971
|
+
entity = this.items.find((x) => x.id === entityId);
|
|
2972
|
+
}
|
|
2973
|
+
return entity;
|
|
2974
2974
|
}
|
|
2975
2975
|
setControlValue(entity) {
|
|
2976
2976
|
this.control.setValue(entity.id);
|
|
@@ -2982,7 +2982,7 @@ class FieldDropdownComponent extends FieldComponent {
|
|
|
2982
2982
|
this.selectedChange.emit(entity);
|
|
2983
2983
|
}
|
|
2984
2984
|
writeSelectedEntityValue(selectedEntityId) {
|
|
2985
|
-
this.kendoDropDown
|
|
2985
|
+
this.kendoDropDown?.writeValue(selectedEntityId);
|
|
2986
2986
|
}
|
|
2987
2987
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.0", ngImport: i0, type: FieldDropdownComponent, deps: [{ token: i1$3.FormGroupDirective }, { token: i0.ElementRef }, { token: i2.TranslateService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
2988
2988
|
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.0", type: FieldDropdownComponent, selector: "field-dropdown", inputs: { service: "service", rebind: "rebind", filter: "filter", defaultName: "defaultName", selectedItem: "selectedItem", data: "data", textField: "textField" }, outputs: { selectedChange: "selectedChange" }, viewQueries: [{ propertyName: "kendoDropDown", first: true, predicate: ["inputElement"], descendants: true }], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<div class=\"form-group\">\n <label\n for=\"{{ '_' + fieldName }}\"\n class=\"col-md-3 control-label\"\n translate=\"{{ labelKey }}\"\n ></label>\n <div class=\"col-md-9\" *ngIf=\"control\">\n <kendo-dropdownlist\n id=\"{{ '_' + fieldName }}\"\n [formControl]=\"control\"\n [data]=\"data$ | async\"\n [textField]=\"textField\"\n valueField=\"id\"\n [valuePrimitive]=\"true\"\n [defaultItem]=\"defaultItem\"\n (valueChange)=\"onValueChange($event)\"\n #inputElement\n >\n </kendo-dropdownlist>\n\n <div class=\"bg-danger\" *ngIf=\"control.invalid && control.touched\">\n <span *ngIf=\"control.errors['required']\">{{\n \"Required\" | translate : { param0: labelKey | translate }\n }}</span>\n <span *ngIf=\"control.errors['serverErrorMsg']\">{{\n control.errors[\"serverErrorMsg\"]\n }}</span>\n </div>\n </div>\n</div>\n", dependencies: [{ kind: "directive", type: i2.TranslateDirective, selector: "[translate],[ngx-translate]", inputs: ["translate", "translateParams"] }, { kind: "component", type: i5.DropDownListComponent, selector: "kendo-dropdownlist", inputs: ["customIconClass", "showStickyHeader", "icon", "svgIcon", "loading", "data", "value", "textField", "valueField", "adaptiveMode", "title", "subtitle", "popupSettings", "listHeight", "defaultItem", "disabled", "itemDisabled", "readonly", "filterable", "virtual", "ignoreCase", "delay", "valuePrimitive", "tabindex", "tabIndex", "size", "rounded", "fillMode", "leftRightArrowsNavigation", "id"], outputs: ["valueChange", "filterChange", "selectionChange", "open", "opened", "close", "closed", "focus", "blur"], exportAs: ["kendoDropDownList"] }, { kind: "directive", type: i1$3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1$3.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "directive", type: i2$1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i2.TranslatePipe, name: "translate" }, { kind: "pipe", type: i2$1.AsyncPipe, name: "async" }], viewProviders: [
|