@indigina/kendo 1.2.70 → 1.2.71

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.
@@ -43,14 +43,16 @@ export class FieldDropdownComponent extends FieldComponent {
43
43
  if (this.data) {
44
44
  let dataSubject = new BehaviorSubject(this.data);
45
45
  this.data$ = dataSubject.asObservable();
46
- this.handleSelectedEntity();
46
+ if (this.selectedItem) {
47
+ this.handleSelectedEntity();
48
+ }
47
49
  }
48
50
  else {
49
51
  this.data$ = this.service
50
52
  .getPage(this.filter ? { filter: this.filter } : {})
51
53
  .pipe(tap((response) => {
52
54
  this.items = response.data;
53
- this.handleSelectedEntity();
55
+ this.handleSelectedItem();
54
56
  }), map((response) => response.data));
55
57
  }
56
58
  }
@@ -65,18 +67,21 @@ export class FieldDropdownComponent extends FieldComponent {
65
67
  setDefaultName() {
66
68
  return this.translate.instant(this.defaultName || SelectValue);
67
69
  }
68
- handleSelectedEntity() {
70
+ handleSelectedItem() {
69
71
  if (this.selectedItem) {
70
- const selectedEntity = this.updateControlValue(this.selectedItem[this.valueField]);
71
- if (selectedEntity && selectedEntity[this.valueField] !== null) {
72
- this.onValueChange(selectedEntity[this.valueField]);
73
- this.writeSelectedEntityValue(selectedEntity[this.valueField]);
74
- }
72
+ this.handleSelectedEntity();
75
73
  }
76
74
  else {
77
75
  this.updateControlValue(this.control.value);
78
76
  }
79
77
  }
78
+ handleSelectedEntity() {
79
+ const selectedEntity = this.updateControlValue(this.selectedItem[this.valueField]);
80
+ if (selectedEntity && selectedEntity[this.valueField] !== null) {
81
+ this.onValueChange(selectedEntity[this.valueField]);
82
+ this.writeSelectedEntityValue(selectedEntity[this.valueField]);
83
+ }
84
+ }
80
85
  updateControlValue(value) {
81
86
  const entity = this.getEntityByValue(value);
82
87
  if (entity) {
@@ -139,4 +144,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.4", ngImpor
139
144
  type: ViewChild,
140
145
  args: ['inputElement']
141
146
  }] } });
142
- //# 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';\nconst defaultValueField: string = 'id';\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  @Input() valueField: string = defaultValueField;\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.getEntityByValue(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((response) => {\n            this.items = response.data;\n            this.handleSelectedEntity();\n          }),\n          map((response) => response.data),\n        );\n    }\n  }\n\n  private setDefaultItem(): void {\n    this.defaultItem = {\n      name: this.setDefaultName(),\n      id: null,\n      [this.textField]: this.setDefaultName(),\n      [this.valueField]: null,\n    };\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[this.valueField],\n      );\n      if (selectedEntity && selectedEntity[this.valueField] !== null) {\n        this.onValueChange(selectedEntity[this.valueField]);\n        this.writeSelectedEntityValue(selectedEntity[this.valueField]);\n      }\n    } else {\n      this.updateControlValue(this.control.value);\n    }\n  }\n\n  private updateControlValue(value: string): NamedModel {\n    const entity: NamedModel = this.getEntityByValue(value);\n    if (entity) {\n      this.setControlValue(entity);\n    } else {\n      this.resetControlValue();\n    }\n\n    return entity;\n  }\n\n  private getEntityByValue(value: string): NamedModel {\n    if (this.data) {\n      return this.data.find((x) => x[this.valueField] === value);\n    } else {\n      return this.items.find((x) => x[this.valueField] === value);\n    }\n  }\n\n  private setControlValue(entity: NamedModel): void {\n    this.control.setValue(entity[this.valueField]);\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(value: string): void {\n    this.kendoDropDown?.writeValue(value);\n  }\n}\n","<div class=\"form-group\">\n  <label for=\"{{ '_' + fieldName }}\" class=\"col-md-3 control-label\">{{\n    labelKey | translate\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]=\"valueField\"\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"]}
147
+ //# 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';\nconst defaultValueField: string = 'id';\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  @Input() valueField: string = defaultValueField;\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.getEntityByValue(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      if (this.selectedItem) {\n        this.handleSelectedEntity();\n      }\n    } else {\n      this.data$ = this.service\n        .getPage(this.filter ? { filter: this.filter } : {})\n        .pipe(\n          tap((response) => {\n            this.items = response.data;\n            this.handleSelectedItem();\n          }),\n          map((response) => response.data),\n        );\n    }\n  }\n\n  private setDefaultItem(): void {\n    this.defaultItem = {\n      name: this.setDefaultName(),\n      id: null,\n      [this.textField]: this.setDefaultName(),\n      [this.valueField]: null,\n    };\n  }\n\n  private setDefaultName(): string {\n    return this.translate.instant(this.defaultName || SelectValue);\n  }\n\n  private handleSelectedItem(): void {\n    if (this.selectedItem) {\n      this.handleSelectedEntity();\n    } else {\n      this.updateControlValue(this.control.value);\n    }\n  }\n\n  private handleSelectedEntity(): void {\n    const selectedEntity: NamedModel = this.updateControlValue(\n      this.selectedItem[this.valueField],\n    );\n    if (selectedEntity && selectedEntity[this.valueField] !== null) {\n      this.onValueChange(selectedEntity[this.valueField]);\n      this.writeSelectedEntityValue(selectedEntity[this.valueField]);\n    }\n  }\n\n  private updateControlValue(value: string): NamedModel {\n    const entity: NamedModel = this.getEntityByValue(value);\n    if (entity) {\n      this.setControlValue(entity);\n    } else {\n      this.resetControlValue();\n    }\n\n    return entity;\n  }\n\n  private getEntityByValue(value: string): NamedModel {\n    if (this.data) {\n      return this.data.find((x) => x[this.valueField] === value);\n    } else {\n      return this.items.find((x) => x[this.valueField] === value);\n    }\n  }\n\n  private setControlValue(entity: NamedModel): void {\n    this.control.setValue(entity[this.valueField]);\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(value: string): void {\n    this.kendoDropDown?.writeValue(value);\n  }\n}\n","<div class=\"form-group\">\n  <label for=\"{{ '_' + fieldName }}\" class=\"col-md-3 control-label\">{{\n    labelKey | translate\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]=\"valueField\"\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"]}
@@ -2981,14 +2981,16 @@ class FieldDropdownComponent extends FieldComponent {
2981
2981
  if (this.data) {
2982
2982
  let dataSubject = new BehaviorSubject(this.data);
2983
2983
  this.data$ = dataSubject.asObservable();
2984
- this.handleSelectedEntity();
2984
+ if (this.selectedItem) {
2985
+ this.handleSelectedEntity();
2986
+ }
2985
2987
  }
2986
2988
  else {
2987
2989
  this.data$ = this.service
2988
2990
  .getPage(this.filter ? { filter: this.filter } : {})
2989
2991
  .pipe(tap$1((response) => {
2990
2992
  this.items = response.data;
2991
- this.handleSelectedEntity();
2993
+ this.handleSelectedItem();
2992
2994
  }), map$1((response) => response.data));
2993
2995
  }
2994
2996
  }
@@ -3003,18 +3005,21 @@ class FieldDropdownComponent extends FieldComponent {
3003
3005
  setDefaultName() {
3004
3006
  return this.translate.instant(this.defaultName || SelectValue$1);
3005
3007
  }
3006
- handleSelectedEntity() {
3008
+ handleSelectedItem() {
3007
3009
  if (this.selectedItem) {
3008
- const selectedEntity = this.updateControlValue(this.selectedItem[this.valueField]);
3009
- if (selectedEntity && selectedEntity[this.valueField] !== null) {
3010
- this.onValueChange(selectedEntity[this.valueField]);
3011
- this.writeSelectedEntityValue(selectedEntity[this.valueField]);
3012
- }
3010
+ this.handleSelectedEntity();
3013
3011
  }
3014
3012
  else {
3015
3013
  this.updateControlValue(this.control.value);
3016
3014
  }
3017
3015
  }
3016
+ handleSelectedEntity() {
3017
+ const selectedEntity = this.updateControlValue(this.selectedItem[this.valueField]);
3018
+ if (selectedEntity && selectedEntity[this.valueField] !== null) {
3019
+ this.onValueChange(selectedEntity[this.valueField]);
3020
+ this.writeSelectedEntityValue(selectedEntity[this.valueField]);
3021
+ }
3022
+ }
3018
3023
  updateControlValue(value) {
3019
3024
  const entity = this.getEntityByValue(value);
3020
3025
  if (entity) {