@indigina/kendo 1.2.57 → 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.
@@ -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.data
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.setInputData();
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
- if (this.selectedItem) {
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
- setInputData() {
76
- let dataSubject = new BehaviorSubject(this.data);
77
- this.data$ = dataSubject.asObservable();
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
- handleSelectedEntityValues(entityId) {
80
- const selectedEntity = this.updateControlWithSelectedEntity(entityId);
81
- if (selectedEntity?.id) {
82
- this.onValueChange(selectedEntity.id);
83
- this.writeSelectedEntityValue(selectedEntity.id);
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
- updateControlWithSelectedEntity(entityId) {
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
- return this.items.find((x) => x.id === entityId);
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.writeValue(selectedEntityId);
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":"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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  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":"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;IAgBhE,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;QAhB5B,cAAS,GAAW,gBAAgB,CAAC;QACpC,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;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,aAAa,CAAC,KAAK,CAAC,CAAC;SACpC;QAED,IAAI,CAAC,kBAAkB,CAAC,MAAM,IAAI,IAAI,CAAC,WAAW,CAAC,CAAC;IACtD,CAAC;IAEM,OAAO;QACZ,IAAI,IAAI,CAAC,IAAI,EAAE;YACb,IAAI,WAAW,GAAkC,IAAI,eAAe,CAElE,IAAI,CAAC,IAAI,CAAC,CAAC;YACb,IAAI,CAAC,KAAK,GAAG,WAAW,CAAC,YAAY,EAAE,CAAC;YACxC,IAAI,CAAC,oBAAoB,EAAE,CAAC;SAC7B;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,CAAC,oBAAoB,EAAE,CAAC;YAC9B,CAAC,CAAC,EACF,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CACnB,CAAC;SACL;IACH,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;IAEO,oBAAoB;QAC1B,IAAI,IAAI,CAAC,YAAY,EAAE;YACrB,MAAM,cAAc,GAAe,IAAI,CAAC,kBAAkB,CACxD,IAAI,CAAC,YAAY,CAAC,EAAE,CACrB,CAAC;YACF,IAAI,cAAc,EAAE,EAAE,EAAE;gBACtB,IAAI,CAAC,aAAa,CAAC,cAAc,CAAC,EAAE,CAAC,CAAC;gBACtC,IAAI,CAAC,wBAAwB,CAAC,cAAc,CAAC,EAAE,CAAC,CAAC;aAClD;SACF;aAAM;YACL,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;SAC7C;IACH,CAAC;IAEO,kBAAkB,CAAC,QAAgB;QACzC,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,aAAa,CAAC,QAAgB;QACpC,IAAI,MAAkB,CAAC;QACvB,IAAI,IAAI,CAAC,IAAI,EAAE;YACb,MAAM,GAAG,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,QAAQ,CAAC,CAAC;SACnD;aAAM;YACL,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,QAAQ,CAAC,CAAC;SACpD;QAED,OAAO,MAAM,CAAC;IAChB,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;IAEO,kBAAkB,CAAC,MAAkB;QAC3C,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IACnC,CAAC;IAEO,wBAAwB,CAAC,gBAAwB;QACvD,IAAI,CAAC,aAAa,EAAE,UAAU,CAAC,gBAAgB,CAAC,CAAC;IACnD,CAAC;8GAxIU,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;+IAGtC,OAAO;sBAAf,KAAK;gBACG,MAAM;sBAAd,KAAK;gBACG,MAAM;sBAAd,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,YAAY;sBAApB,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACI,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() 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"]}
@@ -1,5 +1,6 @@
1
1
  import { Component, Input, Output, EventEmitter, } from '@angular/core';
2
2
  import { distinct, filterBy, } from '@progress/kendo-data-query';
3
+ import { Operators } from '../../models/Operators';
3
4
  import * as i0 from "@angular/core";
4
5
  import * as i1 from "@angular/common";
5
6
  const defaultValueKey = 'id';
@@ -47,7 +48,7 @@ export class MulticheckFilterComponent {
47
48
  this.filterService.filter({
48
49
  filters: this.value.map((value) => ({
49
50
  field: this.field,
50
- operator: 'eq',
51
+ operator: this.operator ?? Operators.eq,
51
52
  value,
52
53
  })),
53
54
  logic: 'or',
@@ -57,14 +58,14 @@ export class MulticheckFilterComponent {
57
58
  this.currentData = distinct([
58
59
  ...this.currentData.filter((dataItem) => this.value.some((val) => val === dataItem.id)),
59
60
  ...filterBy(this.data, {
60
- operator: 'contains',
61
+ operator: Operators.contains,
61
62
  field: 'name',
62
63
  value: e.target.value,
63
64
  }),
64
65
  ], 'name');
65
66
  }
66
67
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.0", ngImport: i0, type: MulticheckFilterComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
67
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.0", type: MulticheckFilterComponent, selector: "multicheck-filter", inputs: { currentFilter: "currentFilter", data: "data", filterService: "filterService", field: "field", valueField: "valueField" }, outputs: { valueChange: "valueChange" }, ngImport: i0, template: "<ul>\n <li *ngIf=\"showFilter\">\n <input class=\"k-textbox\" (input)=\"onInput($event)\" />\n </li>\n <li\n *ngFor=\"let item of currentData; let i = index\"\n (click)=\"onSelectionChange(item)\"\n [ngClass]=\"{ 'k-state-selected': isItemSelected(item) }\"\n >\n <input\n type=\"checkbox\"\n style=\"margin-right: 5px\"\n id=\"chk-{{ item.id }}\"\n class=\"k-checkbox\"\n [checked]=\"isItemSelected(item)\"\n />\n <label\n class=\"k-multiselect-checkbox k-checkbox-label\"\n for=\"chk-{{ item.id }}\"\n >\n {{ item.name }}\n </label>\n </li>\n</ul>\n", styles: ["ul{list-style-type:none;height:200px;overflow-y:scroll;padding-left:0;padding-right:12px}ul>li{padding:8px 12px;border:1px solid rgba(0,0,0,.08);border-bottom:none}ul>li:last-of-type{border-bottom:1px solid rgba(0,0,0,.08)}.k-multiselect-checkbox{pointer-events:none}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] }); }
68
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.0", type: MulticheckFilterComponent, selector: "multicheck-filter", inputs: { currentFilter: "currentFilter", data: "data", filterService: "filterService", field: "field", valueField: "valueField", operator: "operator" }, outputs: { valueChange: "valueChange" }, ngImport: i0, template: "<ul>\n <li *ngIf=\"showFilter\">\n <input class=\"k-textbox\" (input)=\"onInput($event)\" />\n </li>\n <li\n *ngFor=\"let item of currentData; let i = index\"\n (click)=\"onSelectionChange(item)\"\n [ngClass]=\"{ 'k-state-selected': isItemSelected(item) }\"\n >\n <input\n type=\"checkbox\"\n style=\"margin-right: 5px\"\n id=\"chk-{{ item.id }}\"\n class=\"k-checkbox\"\n [checked]=\"isItemSelected(item)\"\n />\n <label\n class=\"k-multiselect-checkbox k-checkbox-label\"\n for=\"chk-{{ item.id }}\"\n >\n {{ item.name }}\n </label>\n </li>\n</ul>\n", styles: ["ul{list-style-type:none;height:200px;overflow-y:scroll;padding-left:0;padding-right:12px}ul>li{padding:8px 12px;border:1px solid rgba(0,0,0,.08);border-bottom:none}ul>li:last-of-type{border-bottom:1px solid rgba(0,0,0,.08)}.k-multiselect-checkbox{pointer-events:none}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] }); }
68
69
  }
69
70
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.0", ngImport: i0, type: MulticheckFilterComponent, decorators: [{
70
71
  type: Component,
@@ -79,7 +80,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.0", ngImpor
79
80
  type: Input
80
81
  }], valueField: [{
81
82
  type: Input
83
+ }], operator: [{
84
+ type: Input
82
85
  }], valueChange: [{
83
86
  type: Output
84
87
  }] } });
85
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"multicheck-filter.component.js","sourceRoot":"","sources":["../../../../../../projects/kendo/src/lib/widgets/multicheck-filter/multicheck-filter.component.ts","../../../../../../projects/kendo/src/lib/widgets/multicheck-filter/multicheck-filter.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  Input,\n  Output,\n  EventEmitter,\n  AfterViewInit,\n} from '@angular/core';\nimport {\n  CompositeFilterDescriptor,\n  distinct,\n  filterBy,\n  FilterDescriptor,\n} from '@progress/kendo-data-query';\nimport { FilterService } from '@progress/kendo-angular-grid';\nimport { NamedModel } from '../../angular/models/NamedModel';\n\nconst defaultValueKey = 'id';\n\n@Component({\n  selector: 'multicheck-filter',\n  templateUrl: './multicheck-filter.component.html',\n  styleUrls: ['./multicheck-filter.component.css'],\n})\nexport class MulticheckFilterComponent implements AfterViewInit {\n  @Input() public currentFilter: CompositeFilterDescriptor;\n  @Input() public data: NamedModel[];\n  @Input() public filterService: FilterService;\n  @Input() public field: string;\n  @Input() public valueField: string;\n  @Output() public valueChange = new EventEmitter<number[]>();\n\n  public currentData: NamedModel[];\n  public showFilter = true;\n  private value: string[] = [];\n  private filters: FilterDescriptor[] = [];\n  private get ValueKey(): string {\n    return this.valueField ? this.valueField : defaultValueKey;\n  }\n\n  public ngAfterViewInit() {\n    this.currentData = this.data;\n    if (this.currentData && this.currentData.length) {\n      this.traverseFilters(this.currentFilter);\n      this.value = this.filters.map((f: FilterDescriptor) => f.value);\n      this.showFilter = typeof this.currentData[0].name === 'string';\n    }\n  }\n\n  traverseFilters(filters: CompositeFilterDescriptor | FilterDescriptor) {\n    let compositeFilterDescriptor = filters as CompositeFilterDescriptor;\n    if (compositeFilterDescriptor.filters) {\n      for (let i = 0; i < compositeFilterDescriptor.filters.length; i++) {\n        const innerFilter = compositeFilterDescriptor.filters[\n          i\n        ] as FilterDescriptor;\n        if (innerFilter.value && innerFilter.field === this.field) {\n          this.filters.push(innerFilter);\n        }\n\n        this.traverseFilters(innerFilter);\n      }\n    }\n  }\n\n  public isItemSelected(item: NamedModel) {\n    return this.value.some((x) => x === item[this.ValueKey]);\n  }\n\n  public onSelectionChange(item: NamedModel) {\n    const selectedValue = item[this.ValueKey];\n    if (this.value.some((x) => x === selectedValue)) {\n      this.value = this.value.filter((x) => x !== selectedValue);\n    } else {\n      this.value.push(selectedValue);\n    }\n\n    this.filterService.filter({\n      filters: this.value.map((value) => ({\n        field: this.field,\n        operator: 'eq',\n        value,\n      })),\n      logic: 'or',\n    });\n  }\n\n  public onInput(e: any) {\n    this.currentData = distinct(\n      [\n        ...this.currentData.filter((dataItem) =>\n          this.value.some((val) => val === dataItem.id)\n        ),\n        ...filterBy(this.data, {\n          operator: 'contains',\n          field: 'name',\n          value: e.target.value,\n        }),\n      ],\n      'name'\n    );\n  }\n}\n","<ul>\n  <li *ngIf=\"showFilter\">\n    <input class=\"k-textbox\" (input)=\"onInput($event)\" />\n  </li>\n  <li\n    *ngFor=\"let item of currentData; let i = index\"\n    (click)=\"onSelectionChange(item)\"\n    [ngClass]=\"{ 'k-state-selected': isItemSelected(item) }\"\n  >\n    <input\n      type=\"checkbox\"\n      style=\"margin-right: 5px\"\n      id=\"chk-{{ item.id }}\"\n      class=\"k-checkbox\"\n      [checked]=\"isItemSelected(item)\"\n    />\n    <label\n      class=\"k-multiselect-checkbox k-checkbox-label\"\n      for=\"chk-{{ item.id }}\"\n    >\n      {{ item.name }}\n    </label>\n  </li>\n</ul>\n"]}
88
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"multicheck-filter.component.js","sourceRoot":"","sources":["../../../../../../projects/kendo/src/lib/widgets/multicheck-filter/multicheck-filter.component.ts","../../../../../../projects/kendo/src/lib/widgets/multicheck-filter/multicheck-filter.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  Input,\n  Output,\n  EventEmitter,\n  AfterViewInit,\n} from '@angular/core';\nimport {\n  CompositeFilterDescriptor,\n  distinct,\n  filterBy,\n  FilterDescriptor,\n} from '@progress/kendo-data-query';\nimport { FilterService } from '@progress/kendo-angular-grid';\nimport { NamedModel } from '../../angular/models/NamedModel';\nimport { Operators } from '../../models/Operators';\n\nconst defaultValueKey = 'id';\n\n@Component({\n  selector: 'multicheck-filter',\n  templateUrl: './multicheck-filter.component.html',\n  styleUrls: ['./multicheck-filter.component.css'],\n})\nexport class MulticheckFilterComponent implements AfterViewInit {\n  @Input() public currentFilter: CompositeFilterDescriptor;\n  @Input() public data: NamedModel[];\n  @Input() public filterService: FilterService;\n  @Input() public field: string;\n  @Input() public valueField: string;\n  @Input() public operator?: string;\n  @Output() public valueChange = new EventEmitter<number[]>();\n\n  public currentData: NamedModel[];\n  public showFilter = true;\n  private value: string[] = [];\n  private filters: FilterDescriptor[] = [];\n  private get ValueKey(): string {\n    return this.valueField ? this.valueField : defaultValueKey;\n  }\n\n  public ngAfterViewInit() {\n    this.currentData = this.data;\n    if (this.currentData && this.currentData.length) {\n      this.traverseFilters(this.currentFilter);\n      this.value = this.filters.map((f: FilterDescriptor) => f.value);\n      this.showFilter = typeof this.currentData[0].name === 'string';\n    }\n  }\n\n  traverseFilters(filters: CompositeFilterDescriptor | FilterDescriptor) {\n    let compositeFilterDescriptor = filters as CompositeFilterDescriptor;\n    if (compositeFilterDescriptor.filters) {\n      for (let i = 0; i < compositeFilterDescriptor.filters.length; i++) {\n        const innerFilter = compositeFilterDescriptor.filters[\n          i\n        ] as FilterDescriptor;\n        if (innerFilter.value && innerFilter.field === this.field) {\n          this.filters.push(innerFilter);\n        }\n\n        this.traverseFilters(innerFilter);\n      }\n    }\n  }\n\n  public isItemSelected(item: NamedModel) {\n    return this.value.some((x) => x === item[this.ValueKey]);\n  }\n\n  public onSelectionChange(item: NamedModel) {\n    const selectedValue = item[this.ValueKey];\n    if (this.value.some((x) => x === selectedValue)) {\n      this.value = this.value.filter((x) => x !== selectedValue);\n    } else {\n      this.value.push(selectedValue);\n    }\n\n    this.filterService.filter({\n      filters: this.value.map((value) => ({\n        field: this.field,\n        operator: this.operator ?? Operators.eq,\n        value,\n      })),\n      logic: 'or',\n    });\n  }\n\n  public onInput(e: any) {\n    this.currentData = distinct(\n      [\n        ...this.currentData.filter((dataItem) =>\n          this.value.some((val) => val === dataItem.id)\n        ),\n        ...filterBy(this.data, {\n          operator: Operators.contains,\n          field: 'name',\n          value: e.target.value,\n        }),\n      ],\n      'name'\n    );\n  }\n}\n","<ul>\n  <li *ngIf=\"showFilter\">\n    <input class=\"k-textbox\" (input)=\"onInput($event)\" />\n  </li>\n  <li\n    *ngFor=\"let item of currentData; let i = index\"\n    (click)=\"onSelectionChange(item)\"\n    [ngClass]=\"{ 'k-state-selected': isItemSelected(item) }\"\n  >\n    <input\n      type=\"checkbox\"\n      style=\"margin-right: 5px\"\n      id=\"chk-{{ item.id }}\"\n      class=\"k-checkbox\"\n      [checked]=\"isItemSelected(item)\"\n    />\n    <label\n      class=\"k-multiselect-checkbox k-checkbox-label\"\n      for=\"chk-{{ item.id }}\"\n    >\n      {{ item.name }}\n    </label>\n  </li>\n</ul>\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.data
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.setInputData();
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
- if (this.selectedItem) {
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
- setInputData() {
2949
- let dataSubject = new BehaviorSubject(this.data);
2950
- this.data$ = dataSubject.asObservable();
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();
2951
2939
  }
2952
- handleSelectedEntityValues(entityId) {
2953
- const selectedEntity = this.updateControlWithSelectedEntity(entityId);
2954
- if (selectedEntity?.id) {
2955
- this.onValueChange(selectedEntity.id);
2956
- this.writeSelectedEntityValue(selectedEntity.id);
2940
+ setDefaultName() {
2941
+ return this.translate.instant(this.defaultName || SelectValue$1);
2942
+ }
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
- updateControlWithSelectedEntity(entityId) {
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
- return this.items.find((x) => x.id === entityId);
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.writeValue(selectedEntityId);
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: [
@@ -3447,6 +3447,24 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.0", ngImpor
3447
3447
  }]
3448
3448
  }] });
3449
3449
 
3450
+ var Operators;
3451
+ (function (Operators) {
3452
+ Operators["eq"] = "eq";
3453
+ Operators["neq"] = "neq";
3454
+ Operators["isnull"] = "isnull";
3455
+ Operators["isnotnull"] = "isnotnull";
3456
+ Operators["lt"] = "lt";
3457
+ Operators["lte"] = "lte";
3458
+ Operators["gt"] = "gt";
3459
+ Operators["gte"] = "gte";
3460
+ Operators["startswith"] = "startswith";
3461
+ Operators["endswith"] = "endswith";
3462
+ Operators["contains"] = "contains";
3463
+ Operators["doesnotcontain"] = "doesnotcontain";
3464
+ Operators["isempty"] = "isempty";
3465
+ Operators["isnotempty"] = "isnotempty";
3466
+ })(Operators || (Operators = {}));
3467
+
3450
3468
  const defaultValueKey = 'id';
3451
3469
  class MulticheckFilterComponent {
3452
3470
  constructor() {
@@ -3492,7 +3510,7 @@ class MulticheckFilterComponent {
3492
3510
  this.filterService.filter({
3493
3511
  filters: this.value.map((value) => ({
3494
3512
  field: this.field,
3495
- operator: 'eq',
3513
+ operator: this.operator ?? Operators.eq,
3496
3514
  value,
3497
3515
  })),
3498
3516
  logic: 'or',
@@ -3502,14 +3520,14 @@ class MulticheckFilterComponent {
3502
3520
  this.currentData = distinct([
3503
3521
  ...this.currentData.filter((dataItem) => this.value.some((val) => val === dataItem.id)),
3504
3522
  ...filterBy(this.data, {
3505
- operator: 'contains',
3523
+ operator: Operators.contains,
3506
3524
  field: 'name',
3507
3525
  value: e.target.value,
3508
3526
  }),
3509
3527
  ], 'name');
3510
3528
  }
3511
3529
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.0", ngImport: i0, type: MulticheckFilterComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
3512
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.0", type: MulticheckFilterComponent, selector: "multicheck-filter", inputs: { currentFilter: "currentFilter", data: "data", filterService: "filterService", field: "field", valueField: "valueField" }, outputs: { valueChange: "valueChange" }, ngImport: i0, template: "<ul>\n <li *ngIf=\"showFilter\">\n <input class=\"k-textbox\" (input)=\"onInput($event)\" />\n </li>\n <li\n *ngFor=\"let item of currentData; let i = index\"\n (click)=\"onSelectionChange(item)\"\n [ngClass]=\"{ 'k-state-selected': isItemSelected(item) }\"\n >\n <input\n type=\"checkbox\"\n style=\"margin-right: 5px\"\n id=\"chk-{{ item.id }}\"\n class=\"k-checkbox\"\n [checked]=\"isItemSelected(item)\"\n />\n <label\n class=\"k-multiselect-checkbox k-checkbox-label\"\n for=\"chk-{{ item.id }}\"\n >\n {{ item.name }}\n </label>\n </li>\n</ul>\n", styles: ["ul{list-style-type:none;height:200px;overflow-y:scroll;padding-left:0;padding-right:12px}ul>li{padding:8px 12px;border:1px solid rgba(0,0,0,.08);border-bottom:none}ul>li:last-of-type{border-bottom:1px solid rgba(0,0,0,.08)}.k-multiselect-checkbox{pointer-events:none}\n"], dependencies: [{ kind: "directive", type: i2$1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2$1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2$1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] }); }
3530
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.0", type: MulticheckFilterComponent, selector: "multicheck-filter", inputs: { currentFilter: "currentFilter", data: "data", filterService: "filterService", field: "field", valueField: "valueField", operator: "operator" }, outputs: { valueChange: "valueChange" }, ngImport: i0, template: "<ul>\n <li *ngIf=\"showFilter\">\n <input class=\"k-textbox\" (input)=\"onInput($event)\" />\n </li>\n <li\n *ngFor=\"let item of currentData; let i = index\"\n (click)=\"onSelectionChange(item)\"\n [ngClass]=\"{ 'k-state-selected': isItemSelected(item) }\"\n >\n <input\n type=\"checkbox\"\n style=\"margin-right: 5px\"\n id=\"chk-{{ item.id }}\"\n class=\"k-checkbox\"\n [checked]=\"isItemSelected(item)\"\n />\n <label\n class=\"k-multiselect-checkbox k-checkbox-label\"\n for=\"chk-{{ item.id }}\"\n >\n {{ item.name }}\n </label>\n </li>\n</ul>\n", styles: ["ul{list-style-type:none;height:200px;overflow-y:scroll;padding-left:0;padding-right:12px}ul>li{padding:8px 12px;border:1px solid rgba(0,0,0,.08);border-bottom:none}ul>li:last-of-type{border-bottom:1px solid rgba(0,0,0,.08)}.k-multiselect-checkbox{pointer-events:none}\n"], dependencies: [{ kind: "directive", type: i2$1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2$1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2$1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] }); }
3513
3531
  }
3514
3532
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.0", ngImport: i0, type: MulticheckFilterComponent, decorators: [{
3515
3533
  type: Component,
@@ -3524,6 +3542,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.0", ngImpor
3524
3542
  type: Input
3525
3543
  }], valueField: [{
3526
3544
  type: Input
3545
+ }], operator: [{
3546
+ type: Input
3527
3547
  }], valueChange: [{
3528
3548
  type: Output
3529
3549
  }] } });
@@ -3815,24 +3835,6 @@ var MemberTypes;
3815
3835
  MemberTypes["User"] = "User";
3816
3836
  })(MemberTypes || (MemberTypes = {}));
3817
3837
 
3818
- var Operators;
3819
- (function (Operators) {
3820
- Operators["eq"] = "eq";
3821
- Operators["neq"] = "neq";
3822
- Operators["isnull"] = "isnull";
3823
- Operators["isnotnull"] = "isnotnull";
3824
- Operators["lt"] = "lt";
3825
- Operators["lte"] = "lte";
3826
- Operators["gt"] = "gt";
3827
- Operators["gte"] = "gte";
3828
- Operators["startswith"] = "startswith";
3829
- Operators["endswith"] = "endswith";
3830
- Operators["contains"] = "contains";
3831
- Operators["doesnotcontain"] = "doesnotcontain";
3832
- Operators["isempty"] = "isempty";
3833
- Operators["isnotempty"] = "isnotempty";
3834
- })(Operators || (Operators = {}));
3835
-
3836
3838
  var PermissionTypes;
3837
3839
  (function (PermissionTypes) {
3838
3840
  PermissionTypes["Create"] = "Create";