@indigina/kendo 1.2.44 → 1.2.46
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 +9 -6
- package/esm2022/lib/widgets/entity-edit/dropdowns/object-dropdown/object-dropdown.component.mjs +17 -5
- package/fesm2022/indigina-kendo.mjs +23 -9
- package/fesm2022/indigina-kendo.mjs.map +1 -1
- package/lib/widgets/entity-edit/dropdowns/field-dropdown/field-dropdown.component.d.ts +1 -0
- package/lib/widgets/entity-edit/dropdowns/object-dropdown/object-dropdown.component.d.ts +7 -2
- package/package.json +1 -1
package/esm2022/lib/widgets/entity-edit/dropdowns/field-dropdown/field-dropdown.component.mjs
CHANGED
|
@@ -47,13 +47,13 @@ export class FieldDropdownComponent extends FieldComponent {
|
|
|
47
47
|
this.setData();
|
|
48
48
|
}
|
|
49
49
|
onValueChange(event) {
|
|
50
|
+
let entity = undefined;
|
|
50
51
|
if (event !== null) {
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
else {
|
|
55
|
-
this.emitSelectedEntity(this.defaultItem);
|
|
52
|
+
entity = this.data
|
|
53
|
+
? this.getEntityFromDataById(event)
|
|
54
|
+
: this.getEntityById(event);
|
|
56
55
|
}
|
|
56
|
+
this.emitSelectedEntity(entity || this.defaultItem);
|
|
57
57
|
}
|
|
58
58
|
setData() {
|
|
59
59
|
if (this.data) {
|
|
@@ -85,6 +85,9 @@ export class FieldDropdownComponent extends FieldComponent {
|
|
|
85
85
|
getEntityById(entityId) {
|
|
86
86
|
return this.items.find((x) => x.id === entityId);
|
|
87
87
|
}
|
|
88
|
+
getEntityFromDataById(entityId) {
|
|
89
|
+
return this.data.find((x) => x.id === entityId);
|
|
90
|
+
}
|
|
88
91
|
updateControlWithSelectedEntity(entityId) {
|
|
89
92
|
const entity = this.getEntityById(entityId);
|
|
90
93
|
if (entity) {
|
|
@@ -142,4 +145,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.6", ngImpor
|
|
|
142
145
|
type: ViewChild,
|
|
143
146
|
args: ['inputElement']
|
|
144
147
|
}] } });
|
|
145
|
-
//# 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()\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  public firstLoad: boolean = true;\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    if (event !== null) {\n      const entity: NamedModel = this.getEntityById(event);\n      this.emitSelectedEntity(entity);\n    } else {\n      this.emitSelectedEntity(this.defaultItem);\n    }\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.canUpdateWithSelectedItem()) {\n              const selectedItem: NamedModel =\n                this.updateControlWithSelectedEntity(this.selectedItem.id);\n              this.writeSelectedItemValueIfExists(selectedItem);\n            } else {\n              this.updateControlWithSelectedEntity(this.control.value);\n            }\n\n            this.setFirstLoadFalse();\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  private canUpdateWithSelectedItem(): boolean {\n    return this.selectedItem && this.firstLoad;\n  }\n\n  private getEntityById(entityId: string): NamedModel {\n    return this.items.find((x) => x.id === entityId);\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 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 writeSelectedItemValueIfExists(selectedItem: NamedModel): void {\n    if (selectedItem) {\n      this.kendoDropDown.writeValue(selectedItem.id);\n    }\n  }\n\n  private setFirstLoadFalse(): void {\n    this.firstLoad = false;\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"]}
|
|
148
|
+
//# 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()\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  public firstLoad: boolean = true;\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.canUpdateWithSelectedItem()) {\n              const selectedItem: NamedModel =\n                this.updateControlWithSelectedEntity(this.selectedItem.id);\n              this.writeSelectedItemValueIfExists(selectedItem);\n            } else {\n              this.updateControlWithSelectedEntity(this.control.value);\n            }\n\n            this.setFirstLoadFalse();\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  private canUpdateWithSelectedItem(): boolean {\n    return this.selectedItem && this.firstLoad;\n  }\n\n  private getEntityById(entityId: string): NamedModel {\n    return this.items.find((x) => x.id === entityId);\n  }\n\n  private getEntityFromDataById(entityId: string): NamedModel {\n    return this.data.find((x) => x.id === entityId);\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 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 writeSelectedItemValueIfExists(selectedItem: NamedModel): void {\n    if (selectedItem) {\n      this.kendoDropDown.writeValue(selectedItem.id);\n    }\n  }\n\n  private setFirstLoadFalse(): void {\n    this.firstLoad = false;\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"]}
|
package/esm2022/lib/widgets/entity-edit/dropdowns/object-dropdown/object-dropdown.component.mjs
CHANGED
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output, } from '@angular/core';
|
|
2
2
|
import { FieldComponent } from '../../../../angular/forms/widgets/field/field.component';
|
|
3
3
|
import { ControlContainer, FormGroupDirective, } from '@angular/forms';
|
|
4
|
+
import { BehaviorSubject } from 'rxjs';
|
|
4
5
|
import * as i0 from "@angular/core";
|
|
5
6
|
import * as i1 from "@angular/forms";
|
|
6
7
|
import * as i2 from "@ngx-translate/core";
|
|
@@ -21,6 +22,7 @@ export class ObjectDropdownComponent extends FieldComponent {
|
|
|
21
22
|
}
|
|
22
23
|
ngOnInit() {
|
|
23
24
|
super.ngOnInit();
|
|
25
|
+
this.setInputData();
|
|
24
26
|
this.writeSelectedItemIfExists(this.selectedItem);
|
|
25
27
|
this.setDefaultItem();
|
|
26
28
|
}
|
|
@@ -32,17 +34,25 @@ export class ObjectDropdownComponent extends FieldComponent {
|
|
|
32
34
|
}
|
|
33
35
|
ngOnChanges() {
|
|
34
36
|
super.ngOnChanges();
|
|
37
|
+
this.setInputData();
|
|
35
38
|
this.writeSelectedItemIfExists(this.selectedItem);
|
|
36
39
|
}
|
|
40
|
+
setInputData() {
|
|
41
|
+
let dataSubject = new BehaviorSubject(this.data);
|
|
42
|
+
this.data$ = dataSubject.asObservable();
|
|
43
|
+
}
|
|
37
44
|
onValueChange(event) {
|
|
38
45
|
if (event !== null) {
|
|
39
|
-
const
|
|
40
|
-
this.emitSelectedEntity(
|
|
46
|
+
const entity = this.getEntityByValue(event);
|
|
47
|
+
this.emitSelectedEntity(entity);
|
|
41
48
|
}
|
|
42
49
|
else {
|
|
43
50
|
this.emitSelectedEntity(this.defaultItem);
|
|
44
51
|
}
|
|
45
52
|
}
|
|
53
|
+
getEntityByValue(event) {
|
|
54
|
+
return this.data.find((x) => x.value === event);
|
|
55
|
+
}
|
|
46
56
|
emitSelectedEntity(entity) {
|
|
47
57
|
this.selectedChange.emit(entity);
|
|
48
58
|
}
|
|
@@ -62,7 +72,7 @@ export class ObjectDropdownComponent extends FieldComponent {
|
|
|
62
72
|
this.firstLoad = false;
|
|
63
73
|
}
|
|
64
74
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.6", ngImport: i0, type: ObjectDropdownComponent, deps: [{ token: i1.FormGroupDirective }, { token: i0.ElementRef }, { token: i2.TranslateService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
65
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.6", type: ObjectDropdownComponent, selector: "object-dropdown", inputs: { fieldName: "fieldName", labelKey: "labelKey", data: "data", selectedItem: "selectedItem", defaultName: "defaultName" }, outputs: { selectedChange: "selectedChange" }, 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\"\n [textField]=\"'description'\"\n [valueField]=\"'value'\"\n [valuePrimitive]=\"true\"\n [defaultItem]=\"defaultItem\"\n (valueChange)=\"onValueChange($event)\"\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: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.TranslateDirective, selector: "[translate],[ngx-translate]", inputs: ["translate", "translateParams"] }, { kind: "component", type: i4.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: "pipe", type: i2.TranslatePipe, name: "translate" }], viewProviders: [
|
|
75
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.6", type: ObjectDropdownComponent, selector: "object-dropdown", inputs: { fieldName: "fieldName", labelKey: "labelKey", data: "data", selectedItem: "selectedItem", defaultName: "defaultName", rebind: "rebind" }, outputs: { selectedChange: "selectedChange" }, 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]=\"'description'\"\n [valueField]=\"'value'\"\n [valuePrimitive]=\"true\"\n [defaultItem]=\"defaultItem\"\n (valueChange)=\"onValueChange($event)\"\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: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.TranslateDirective, selector: "[translate],[ngx-translate]", inputs: ["translate", "translateParams"] }, { kind: "component", type: i4.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: "pipe", type: i3.AsyncPipe, name: "async" }, { kind: "pipe", type: i2.TranslatePipe, name: "translate" }], viewProviders: [
|
|
66
76
|
{ provide: ControlContainer, useExisting: FormGroupDirective },
|
|
67
77
|
], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
68
78
|
}
|
|
@@ -70,7 +80,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.6", ngImpor
|
|
|
70
80
|
type: Component,
|
|
71
81
|
args: [{ selector: 'object-dropdown', viewProviders: [
|
|
72
82
|
{ provide: ControlContainer, useExisting: FormGroupDirective },
|
|
73
|
-
], changeDetection: ChangeDetectionStrategy.OnPush, 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\"\n [textField]=\"'description'\"\n [valueField]=\"'value'\"\n [valuePrimitive]=\"true\"\n [defaultItem]=\"defaultItem\"\n (valueChange)=\"onValueChange($event)\"\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" }]
|
|
83
|
+
], changeDetection: ChangeDetectionStrategy.OnPush, 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]=\"'description'\"\n [valueField]=\"'value'\"\n [valuePrimitive]=\"true\"\n [defaultItem]=\"defaultItem\"\n (valueChange)=\"onValueChange($event)\"\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" }]
|
|
74
84
|
}], ctorParameters: () => [{ type: i1.FormGroupDirective }, { type: i0.ElementRef }, { type: i2.TranslateService }], propDecorators: { fieldName: [{
|
|
75
85
|
type: Input
|
|
76
86
|
}], labelKey: [{
|
|
@@ -81,7 +91,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.6", ngImpor
|
|
|
81
91
|
type: Input
|
|
82
92
|
}], defaultName: [{
|
|
83
93
|
type: Input
|
|
94
|
+
}], rebind: [{
|
|
95
|
+
type: Input
|
|
84
96
|
}], selectedChange: [{
|
|
85
97
|
type: Output
|
|
86
98
|
}] } });
|
|
87
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
99
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"object-dropdown.component.js","sourceRoot":"","sources":["../../../../../../../../projects/kendo/src/lib/widgets/entity-edit/dropdowns/object-dropdown/object-dropdown.component.ts","../../../../../../../../projects/kendo/src/lib/widgets/entity-edit/dropdowns/object-dropdown/object-dropdown.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  Output,\n} from '@angular/core';\nimport { FieldComponent } from '../../../../angular/forms/widgets/field/field.component';\nimport {\n  AbstractControl,\n  ControlContainer,\n  FormGroupDirective,\n} from '@angular/forms';\nimport { TranslateService } from '@ngx-translate/core';\nimport { SimpleObject, valueTypes } from '../SimpleObject';\nimport { BehaviorSubject, Observable } from 'rxjs';\n\nconst SelectValue: string = 'Select value';\n\n@Component({\n  selector: 'object-dropdown',\n  templateUrl: './object-dropdown.component.html',\n  viewProviders: [\n    { provide: ControlContainer, useExisting: FormGroupDirective },\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class ObjectDropdownComponent extends FieldComponent<valueTypes> {\n  @Input()\n  fieldName: string;\n  @Input()\n  labelKey: string;\n  @Input()\n  data: SimpleObject[];\n  @Input()\n  selectedItem?: valueTypes;\n  @Input()\n  defaultName?: string;\n  @Input()\n  rebind: string;\n  @Output() selectedChange: EventEmitter<SimpleObject> =\n    new EventEmitter<SimpleObject>();\n\n  public firstLoad: boolean = true;\n  public defaultItem: SimpleObject;\n  public data$: Observable<SimpleObject[]>;\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.setInputData();\n    this.writeSelectedItemIfExists(this.selectedItem);\n    this.setDefaultItem();\n  }\n\n  private setDefaultItem(): void {\n    this.defaultItem = {\n      value: null,\n      description: this.translate.instant(this.defaultName || SelectValue),\n    };\n  }\n\n  ngOnChanges(): void {\n    super.ngOnChanges();\n    this.setInputData();\n    this.writeSelectedItemIfExists(this.selectedItem);\n  }\n\n  private setInputData(): void {\n    let dataSubject: BehaviorSubject<SimpleObject[]> = new BehaviorSubject<\n      SimpleObject[]\n    >(this.data);\n    this.data$ = dataSubject.asObservable();\n  }\n\n  public onValueChange(event: valueTypes): void {\n    if (event !== null) {\n      const entity: SimpleObject = this.getEntityByValue(event);\n      this.emitSelectedEntity(entity);\n    } else {\n      this.emitSelectedEntity(this.defaultItem);\n    }\n  }\n\n  private getEntityByValue(event: valueTypes): SimpleObject {\n    return this.data.find((x) => x.value === event);\n  }\n\n  public emitSelectedEntity(entity: SimpleObject): void {\n    this.selectedChange.emit(entity);\n  }\n\n  private writeSelectedItemIfExists(selectedItem: valueTypes): void {\n    if (this.canUpdateWithSelectedItem()) {\n      this.setControlValue(selectedItem);\n    }\n\n    this.setFirstLoadFalse();\n  }\n\n  private canUpdateWithSelectedItem(): boolean {\n    return this.selectedItem && this.firstLoad;\n  }\n\n  private setControlValue(value: valueTypes): void {\n    this.control.setValue(value);\n  }\n\n  private setFirstLoadFalse(): void {\n    this.firstLoad = false;\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]=\"'description'\"\n      [valueField]=\"'value'\"\n      [valuePrimitive]=\"true\"\n      [defaultItem]=\"defaultItem\"\n      (valueChange)=\"onValueChange($event)\"\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"]}
|
|
@@ -3063,13 +3063,13 @@ class FieldDropdownComponent extends FieldComponent {
|
|
|
3063
3063
|
this.setData();
|
|
3064
3064
|
}
|
|
3065
3065
|
onValueChange(event) {
|
|
3066
|
+
let entity = undefined;
|
|
3066
3067
|
if (event !== null) {
|
|
3067
|
-
|
|
3068
|
-
|
|
3069
|
-
|
|
3070
|
-
else {
|
|
3071
|
-
this.emitSelectedEntity(this.defaultItem);
|
|
3068
|
+
entity = this.data
|
|
3069
|
+
? this.getEntityFromDataById(event)
|
|
3070
|
+
: this.getEntityById(event);
|
|
3072
3071
|
}
|
|
3072
|
+
this.emitSelectedEntity(entity || this.defaultItem);
|
|
3073
3073
|
}
|
|
3074
3074
|
setData() {
|
|
3075
3075
|
if (this.data) {
|
|
@@ -3101,6 +3101,9 @@ class FieldDropdownComponent extends FieldComponent {
|
|
|
3101
3101
|
getEntityById(entityId) {
|
|
3102
3102
|
return this.items.find((x) => x.id === entityId);
|
|
3103
3103
|
}
|
|
3104
|
+
getEntityFromDataById(entityId) {
|
|
3105
|
+
return this.data.find((x) => x.id === entityId);
|
|
3106
|
+
}
|
|
3104
3107
|
updateControlWithSelectedEntity(entityId) {
|
|
3105
3108
|
const entity = this.getEntityById(entityId);
|
|
3106
3109
|
if (entity) {
|
|
@@ -3823,6 +3826,7 @@ class ObjectDropdownComponent extends FieldComponent {
|
|
|
3823
3826
|
}
|
|
3824
3827
|
ngOnInit() {
|
|
3825
3828
|
super.ngOnInit();
|
|
3829
|
+
this.setInputData();
|
|
3826
3830
|
this.writeSelectedItemIfExists(this.selectedItem);
|
|
3827
3831
|
this.setDefaultItem();
|
|
3828
3832
|
}
|
|
@@ -3834,17 +3838,25 @@ class ObjectDropdownComponent extends FieldComponent {
|
|
|
3834
3838
|
}
|
|
3835
3839
|
ngOnChanges() {
|
|
3836
3840
|
super.ngOnChanges();
|
|
3841
|
+
this.setInputData();
|
|
3837
3842
|
this.writeSelectedItemIfExists(this.selectedItem);
|
|
3838
3843
|
}
|
|
3844
|
+
setInputData() {
|
|
3845
|
+
let dataSubject = new BehaviorSubject(this.data);
|
|
3846
|
+
this.data$ = dataSubject.asObservable();
|
|
3847
|
+
}
|
|
3839
3848
|
onValueChange(event) {
|
|
3840
3849
|
if (event !== null) {
|
|
3841
|
-
const
|
|
3842
|
-
this.emitSelectedEntity(
|
|
3850
|
+
const entity = this.getEntityByValue(event);
|
|
3851
|
+
this.emitSelectedEntity(entity);
|
|
3843
3852
|
}
|
|
3844
3853
|
else {
|
|
3845
3854
|
this.emitSelectedEntity(this.defaultItem);
|
|
3846
3855
|
}
|
|
3847
3856
|
}
|
|
3857
|
+
getEntityByValue(event) {
|
|
3858
|
+
return this.data.find((x) => x.value === event);
|
|
3859
|
+
}
|
|
3848
3860
|
emitSelectedEntity(entity) {
|
|
3849
3861
|
this.selectedChange.emit(entity);
|
|
3850
3862
|
}
|
|
@@ -3864,7 +3876,7 @@ class ObjectDropdownComponent extends FieldComponent {
|
|
|
3864
3876
|
this.firstLoad = false;
|
|
3865
3877
|
}
|
|
3866
3878
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.6", ngImport: i0, type: ObjectDropdownComponent, deps: [{ token: i1$4.FormGroupDirective }, { token: i0.ElementRef }, { token: i1$1.TranslateService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
3867
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.6", type: ObjectDropdownComponent, selector: "object-dropdown", inputs: { fieldName: "fieldName", labelKey: "labelKey", data: "data", selectedItem: "selectedItem", defaultName: "defaultName" }, outputs: { selectedChange: "selectedChange" }, 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\"\n [textField]=\"'description'\"\n [valueField]=\"'value'\"\n [valuePrimitive]=\"true\"\n [defaultItem]=\"defaultItem\"\n (valueChange)=\"onValueChange($event)\"\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.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1$1.TranslateDirective, selector: "[translate],[ngx-translate]", inputs: ["translate", "translateParams"] }, { kind: "component", type: i4$2.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$4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1$4.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "pipe", type: i1$1.TranslatePipe, name: "translate" }], viewProviders: [
|
|
3879
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.6", type: ObjectDropdownComponent, selector: "object-dropdown", inputs: { fieldName: "fieldName", labelKey: "labelKey", data: "data", selectedItem: "selectedItem", defaultName: "defaultName", rebind: "rebind" }, outputs: { selectedChange: "selectedChange" }, 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]=\"'description'\"\n [valueField]=\"'value'\"\n [valuePrimitive]=\"true\"\n [defaultItem]=\"defaultItem\"\n (valueChange)=\"onValueChange($event)\"\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.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1$1.TranslateDirective, selector: "[translate],[ngx-translate]", inputs: ["translate", "translateParams"] }, { kind: "component", type: i4$2.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$4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1$4.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }, { kind: "pipe", type: i1$1.TranslatePipe, name: "translate" }], viewProviders: [
|
|
3868
3880
|
{ provide: ControlContainer, useExisting: FormGroupDirective },
|
|
3869
3881
|
], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
3870
3882
|
}
|
|
@@ -3872,7 +3884,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.6", ngImpor
|
|
|
3872
3884
|
type: Component,
|
|
3873
3885
|
args: [{ selector: 'object-dropdown', viewProviders: [
|
|
3874
3886
|
{ provide: ControlContainer, useExisting: FormGroupDirective },
|
|
3875
|
-
], changeDetection: ChangeDetectionStrategy.OnPush, 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\"\n [textField]=\"'description'\"\n [valueField]=\"'value'\"\n [valuePrimitive]=\"true\"\n [defaultItem]=\"defaultItem\"\n (valueChange)=\"onValueChange($event)\"\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" }]
|
|
3887
|
+
], changeDetection: ChangeDetectionStrategy.OnPush, 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]=\"'description'\"\n [valueField]=\"'value'\"\n [valuePrimitive]=\"true\"\n [defaultItem]=\"defaultItem\"\n (valueChange)=\"onValueChange($event)\"\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" }]
|
|
3876
3888
|
}], ctorParameters: () => [{ type: i1$4.FormGroupDirective }, { type: i0.ElementRef }, { type: i1$1.TranslateService }], propDecorators: { fieldName: [{
|
|
3877
3889
|
type: Input
|
|
3878
3890
|
}], labelKey: [{
|
|
@@ -3883,6 +3895,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.6", ngImpor
|
|
|
3883
3895
|
type: Input
|
|
3884
3896
|
}], defaultName: [{
|
|
3885
3897
|
type: Input
|
|
3898
|
+
}], rebind: [{
|
|
3899
|
+
type: Input
|
|
3886
3900
|
}], selectedChange: [{
|
|
3887
3901
|
type: Output
|
|
3888
3902
|
}] } });
|