@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.
- package/esm2022/lib/widgets/entity-edit/dropdowns/field-dropdown/field-dropdown.component.mjs +40 -40
- package/esm2022/lib/widgets/multicheck-filter/multicheck-filter.component.mjs +7 -4
- package/fesm2022/indigina-kendo.mjs +62 -60
- package/fesm2022/indigina-kendo.mjs.map +1 -1
- package/lib/widgets/entity-edit/dropdowns/field-dropdown/field-dropdown.component.d.ts +7 -9
- package/lib/widgets/multicheck-filter/multicheck-filter.component.d.ts +2 -1
- package/package.json +1 -1
package/esm2022/lib/widgets/entity-edit/dropdowns/field-dropdown/field-dropdown.component.mjs
CHANGED
|
@@ -26,21 +26,6 @@ export class FieldDropdownComponent extends FieldComponent {
|
|
|
26
26
|
this.setData();
|
|
27
27
|
this.setDefaultItem();
|
|
28
28
|
}
|
|
29
|
-
setDefaultItem() {
|
|
30
|
-
this.defaultItem = {
|
|
31
|
-
name: this.setDefaultName(),
|
|
32
|
-
id: null,
|
|
33
|
-
};
|
|
34
|
-
if (this.textField !== defaultFieldName) {
|
|
35
|
-
this.setTextFieldForDefaultItem();
|
|
36
|
-
}
|
|
37
|
-
}
|
|
38
|
-
setTextFieldForDefaultItem() {
|
|
39
|
-
this.defaultItem[this.textField] = this.setDefaultName();
|
|
40
|
-
}
|
|
41
|
-
setDefaultName() {
|
|
42
|
-
return this.translate.instant(this.defaultName || SelectValue);
|
|
43
|
-
}
|
|
44
29
|
ngOnChanges() {
|
|
45
30
|
super.ngOnChanges();
|
|
46
31
|
this.setData();
|
|
@@ -48,42 +33,53 @@ export class FieldDropdownComponent extends FieldComponent {
|
|
|
48
33
|
onValueChange(event) {
|
|
49
34
|
let entity = undefined;
|
|
50
35
|
if (event !== null) {
|
|
51
|
-
entity = this.
|
|
52
|
-
? this.getEntityFromDataById(event)
|
|
53
|
-
: this.getEntityById(event);
|
|
36
|
+
entity = this.getEntityById(event);
|
|
54
37
|
}
|
|
55
38
|
this.emitSelectedEntity(entity || this.defaultItem);
|
|
56
39
|
}
|
|
57
40
|
setData() {
|
|
58
41
|
if (this.data) {
|
|
59
|
-
this.
|
|
42
|
+
let dataSubject = new BehaviorSubject(this.data);
|
|
43
|
+
this.data$ = dataSubject.asObservable();
|
|
44
|
+
this.handleSelectedEntity();
|
|
60
45
|
}
|
|
61
46
|
else {
|
|
62
47
|
this.data$ = this.service
|
|
63
48
|
.getPage(this.filter ? { filter: this.filter } : {})
|
|
64
49
|
.pipe(tap((x) => {
|
|
65
50
|
this.items = x.data;
|
|
66
|
-
|
|
67
|
-
this.handleSelectedEntityValues(this.selectedItem.id);
|
|
68
|
-
}
|
|
69
|
-
else {
|
|
70
|
-
this.updateControlWithSelectedEntity(this.control.value);
|
|
71
|
-
}
|
|
51
|
+
this.handleSelectedEntity();
|
|
72
52
|
}), map((x) => x.data));
|
|
73
53
|
}
|
|
74
54
|
}
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
55
|
+
setDefaultItem() {
|
|
56
|
+
this.defaultItem = {
|
|
57
|
+
name: this.setDefaultName(),
|
|
58
|
+
id: null,
|
|
59
|
+
};
|
|
60
|
+
if (this.textField !== defaultFieldName) {
|
|
61
|
+
this.setTextFieldForDefaultItem();
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
setTextFieldForDefaultItem() {
|
|
65
|
+
this.defaultItem[this.textField] = this.setDefaultName();
|
|
66
|
+
}
|
|
67
|
+
setDefaultName() {
|
|
68
|
+
return this.translate.instant(this.defaultName || SelectValue);
|
|
78
69
|
}
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
70
|
+
handleSelectedEntity() {
|
|
71
|
+
if (this.selectedItem) {
|
|
72
|
+
const selectedEntity = this.updateControlValue(this.selectedItem.id);
|
|
73
|
+
if (selectedEntity?.id) {
|
|
74
|
+
this.onValueChange(selectedEntity.id);
|
|
75
|
+
this.writeSelectedEntityValue(selectedEntity.id);
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
else {
|
|
79
|
+
this.updateControlValue(this.control.value);
|
|
84
80
|
}
|
|
85
81
|
}
|
|
86
|
-
|
|
82
|
+
updateControlValue(entityId) {
|
|
87
83
|
const entity = this.getEntityById(entityId);
|
|
88
84
|
if (entity) {
|
|
89
85
|
this.setControlValue(entity);
|
|
@@ -93,11 +89,15 @@ export class FieldDropdownComponent extends FieldComponent {
|
|
|
93
89
|
}
|
|
94
90
|
return entity;
|
|
95
91
|
}
|
|
96
|
-
getEntityFromDataById(entityId) {
|
|
97
|
-
return this.data.find((x) => x.id === entityId);
|
|
98
|
-
}
|
|
99
92
|
getEntityById(entityId) {
|
|
100
|
-
|
|
93
|
+
let entity;
|
|
94
|
+
if (this.data) {
|
|
95
|
+
entity = this.data.find((x) => x.id === entityId);
|
|
96
|
+
}
|
|
97
|
+
else {
|
|
98
|
+
entity = this.items.find((x) => x.id === entityId);
|
|
99
|
+
}
|
|
100
|
+
return entity;
|
|
101
101
|
}
|
|
102
102
|
setControlValue(entity) {
|
|
103
103
|
this.control.setValue(entity.id);
|
|
@@ -109,7 +109,7 @@ export class FieldDropdownComponent extends FieldComponent {
|
|
|
109
109
|
this.selectedChange.emit(entity);
|
|
110
110
|
}
|
|
111
111
|
writeSelectedEntityValue(selectedEntityId) {
|
|
112
|
-
this.kendoDropDown
|
|
112
|
+
this.kendoDropDown?.writeValue(selectedEntityId);
|
|
113
113
|
}
|
|
114
114
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.0", ngImport: i0, type: FieldDropdownComponent, deps: [{ token: i1.FormGroupDirective }, { token: i0.ElementRef }, { token: i2.TranslateService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
115
115
|
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.0", type: FieldDropdownComponent, selector: "field-dropdown", inputs: { service: "service", rebind: "rebind", filter: "filter", defaultName: "defaultName", selectedItem: "selectedItem", data: "data", textField: "textField" }, outputs: { selectedChange: "selectedChange" }, viewQueries: [{ propertyName: "kendoDropDown", first: true, predicate: ["inputElement"], descendants: true }], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<div class=\"form-group\">\n <label\n for=\"{{ '_' + fieldName }}\"\n class=\"col-md-3 control-label\"\n translate=\"{{ labelKey }}\"\n ></label>\n <div class=\"col-md-9\" *ngIf=\"control\">\n <kendo-dropdownlist\n id=\"{{ '_' + fieldName }}\"\n [formControl]=\"control\"\n [data]=\"data$ | async\"\n [textField]=\"textField\"\n valueField=\"id\"\n [valuePrimitive]=\"true\"\n [defaultItem]=\"defaultItem\"\n (valueChange)=\"onValueChange($event)\"\n #inputElement\n >\n </kendo-dropdownlist>\n\n <div class=\"bg-danger\" *ngIf=\"control.invalid && control.touched\">\n <span *ngIf=\"control.errors['required']\">{{\n \"Required\" | translate : { param0: labelKey | translate }\n }}</span>\n <span *ngIf=\"control.errors['serverErrorMsg']\">{{\n control.errors[\"serverErrorMsg\"]\n }}</span>\n </div>\n </div>\n</div>\n", dependencies: [{ kind: "directive", type: i2.TranslateDirective, selector: "[translate],[ngx-translate]", inputs: ["translate", "translateParams"] }, { kind: "component", type: i3.DropDownListComponent, selector: "kendo-dropdownlist", inputs: ["customIconClass", "showStickyHeader", "icon", "svgIcon", "loading", "data", "value", "textField", "valueField", "adaptiveMode", "title", "subtitle", "popupSettings", "listHeight", "defaultItem", "disabled", "itemDisabled", "readonly", "filterable", "virtual", "ignoreCase", "delay", "valuePrimitive", "tabindex", "tabIndex", "size", "rounded", "fillMode", "leftRightArrowsNavigation", "id"], outputs: ["valueChange", "filterChange", "selectionChange", "open", "opened", "close", "closed", "focus", "blur"], exportAs: ["kendoDropDownList"] }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i2.TranslatePipe, name: "translate" }, { kind: "pipe", type: i4.AsyncPipe, name: "async" }], viewProviders: [
|
|
@@ -141,4 +141,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.0", ngImpor
|
|
|
141
141
|
type: ViewChild,
|
|
142
142
|
args: ['inputElement']
|
|
143
143
|
}] } });
|
|
144
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"field-dropdown.component.js","sourceRoot":"","sources":["../../../../../../../../projects/kendo/src/lib/widgets/entity-edit/dropdowns/field-dropdown/field-dropdown.component.ts","../../../../../../../../projects/kendo/src/lib/widgets/entity-edit/dropdowns/dropdown.component.html"],"names":[],"mappings":"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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":"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","sourcesContent":["import {\n  Component,\n  Input,\n  ElementRef,\n  ChangeDetectionStrategy,\n  Output,\n  EventEmitter,\n  ViewChild,\n} from '@angular/core';\nimport {\n  ControlContainer,\n  FormGroupDirective,\n  AbstractControl,\n} from '@angular/forms';\nimport { CompositeFilterDescriptor } from '@progress/kendo-data-query';\nimport { BehaviorSubject, map, Observable, tap } from 'rxjs';\nimport { FieldComponent } from '../../../../angular/forms/widgets/field/field.component';\nimport { NamedModel } from '../../../../angular/models/NamedModel';\nimport { IGetPageService } from '../../../../services/get-page.service.interface';\nimport { TranslateService } from '@ngx-translate/core';\nimport { DropDownListComponent } from '@progress/kendo-angular-dropdowns';\n\nconst SelectValue: string = 'Select value';\nconst defaultFieldName: string = 'name';\n\n@Component({\n  selector: 'field-dropdown',\n  templateUrl: '../dropdown.component.html',\n  viewProviders: [\n    { provide: ControlContainer, useExisting: FormGroupDirective },\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class FieldDropdownComponent extends FieldComponent<string> {\n  @Input() service: IGetPageService<NamedModel>;\n  @Input() rebind: string;\n  @Input() filter?: CompositeFilterDescriptor;\n  @Input() defaultName?: string;\n  @Input() selectedItem?: NamedModel;\n  @Input() data?: NamedModel[];\n  @Input() textField: string = defaultFieldName;\n  @Output() selectedChange: EventEmitter<NamedModel | number | string> =\n    new EventEmitter();\n  @ViewChild('inputElement')\n  private kendoDropDown: DropDownListComponent;\n\n  private items: NamedModel[];\n  public defaultItem: NamedModel;\n  public data$: Observable<NamedModel[]>;\n  get control(): AbstractControl {\n    return this.parent.form.get(this.fieldName);\n  }\n\n  constructor(\n    public parent: FormGroupDirective,\n    public eref: ElementRef,\n    private translate: TranslateService,\n  ) {\n    super(parent, eref, null);\n  }\n\n  ngOnInit(): void {\n    super.ngOnInit();\n    this.setData();\n    this.setDefaultItem();\n  }\n\n  ngOnChanges(): void {\n    super.ngOnChanges();\n    this.setData();\n  }\n\n  public onValueChange(event: string): void {\n    let entity: NamedModel | undefined = undefined;\n    if (event !== null) {\n      entity = this.getEntityById(event);\n    }\n\n    this.emitSelectedEntity(entity || this.defaultItem);\n  }\n\n  public setData(): void {\n    if (this.data) {\n      let dataSubject: BehaviorSubject<NamedModel[]> = new BehaviorSubject<\n        NamedModel[]\n      >(this.data);\n      this.data$ = dataSubject.asObservable();\n      this.handleSelectedEntity();\n    } else {\n      this.data$ = this.service\n        .getPage(this.filter ? { filter: this.filter } : {})\n        .pipe(\n          tap((x) => {\n            this.items = x.data;\n            this.handleSelectedEntity();\n          }),\n          map((x) => x.data),\n        );\n    }\n  }\n\n  private setDefaultItem(): void {\n    this.defaultItem = {\n      name: this.setDefaultName(),\n      id: null,\n    };\n    if (this.textField !== defaultFieldName) {\n      this.setTextFieldForDefaultItem();\n    }\n  }\n\n  private setTextFieldForDefaultItem(): void {\n    this.defaultItem[this.textField] = this.setDefaultName();\n  }\n\n  private setDefaultName(): string {\n    return this.translate.instant(this.defaultName || SelectValue);\n  }\n\n  private handleSelectedEntity(): void {\n    if (this.selectedItem) {\n      const selectedEntity: NamedModel = this.updateControlValue(\n        this.selectedItem.id,\n      );\n      if (selectedEntity?.id) {\n        this.onValueChange(selectedEntity.id);\n        this.writeSelectedEntityValue(selectedEntity.id);\n      }\n    } else {\n      this.updateControlValue(this.control.value);\n    }\n  }\n\n  private updateControlValue(entityId: string): NamedModel {\n    const entity: NamedModel = this.getEntityById(entityId);\n    if (entity) {\n      this.setControlValue(entity);\n    } else {\n      this.resetControlValue();\n    }\n\n    return entity;\n  }\n\n  private getEntityById(entityId: string): NamedModel {\n    let entity: NamedModel;\n    if (this.data) {\n      entity = this.data.find((x) => x.id === entityId);\n    } else {\n      entity = this.items.find((x) => x.id === entityId);\n    }\n\n    return entity;\n  }\n\n  private setControlValue(entity: NamedModel): void {\n    this.control.setValue(entity.id);\n  }\n\n  private resetControlValue(): void {\n    this.control.reset();\n  }\n\n  private emitSelectedEntity(entity: NamedModel): void {\n    this.selectedChange.emit(entity);\n  }\n\n  private writeSelectedEntityValue(selectedEntityId: string): void {\n    this.kendoDropDown?.writeValue(selectedEntityId);\n  }\n}\n","<div class=\"form-group\">\n  <label\n    for=\"{{ '_' + fieldName }}\"\n    class=\"col-md-3 control-label\"\n    translate=\"{{ labelKey }}\"\n  ></label>\n  <div class=\"col-md-9\" *ngIf=\"control\">\n    <kendo-dropdownlist\n      id=\"{{ '_' + fieldName }}\"\n      [formControl]=\"control\"\n      [data]=\"data$ | async\"\n      [textField]=\"textField\"\n      valueField=\"id\"\n      [valuePrimitive]=\"true\"\n      [defaultItem]=\"defaultItem\"\n      (valueChange)=\"onValueChange($event)\"\n      #inputElement\n    >\n    </kendo-dropdownlist>\n\n    <div class=\"bg-danger\" *ngIf=\"control.invalid && control.touched\">\n      <span *ngIf=\"control.errors['required']\">{{\n        \"Required\" | translate : { param0: labelKey | translate }\n      }}</span>\n      <span *ngIf=\"control.errors['serverErrorMsg']\">{{\n        control.errors[\"serverErrorMsg\"]\n      }}</span>\n    </div>\n  </div>\n</div>\n"]}
|
|
@@ -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:
|
|
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:
|
|
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,
|
|
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.
|
|
2925
|
-
? this.getEntityFromDataById(event)
|
|
2926
|
-
: this.getEntityById(event);
|
|
2909
|
+
entity = this.getEntityById(event);
|
|
2927
2910
|
}
|
|
2928
2911
|
this.emitSelectedEntity(entity || this.defaultItem);
|
|
2929
2912
|
}
|
|
2930
2913
|
setData() {
|
|
2931
2914
|
if (this.data) {
|
|
2932
|
-
this.
|
|
2915
|
+
let dataSubject = new BehaviorSubject(this.data);
|
|
2916
|
+
this.data$ = dataSubject.asObservable();
|
|
2917
|
+
this.handleSelectedEntity();
|
|
2933
2918
|
}
|
|
2934
2919
|
else {
|
|
2935
2920
|
this.data$ = this.service
|
|
2936
2921
|
.getPage(this.filter ? { filter: this.filter } : {})
|
|
2937
2922
|
.pipe(tap$1((x) => {
|
|
2938
2923
|
this.items = x.data;
|
|
2939
|
-
|
|
2940
|
-
this.handleSelectedEntityValues(this.selectedItem.id);
|
|
2941
|
-
}
|
|
2942
|
-
else {
|
|
2943
|
-
this.updateControlWithSelectedEntity(this.control.value);
|
|
2944
|
-
}
|
|
2924
|
+
this.handleSelectedEntity();
|
|
2945
2925
|
}), map$1((x) => x.data));
|
|
2946
2926
|
}
|
|
2947
2927
|
}
|
|
2948
|
-
|
|
2949
|
-
|
|
2950
|
-
|
|
2928
|
+
setDefaultItem() {
|
|
2929
|
+
this.defaultItem = {
|
|
2930
|
+
name: this.setDefaultName(),
|
|
2931
|
+
id: null,
|
|
2932
|
+
};
|
|
2933
|
+
if (this.textField !== defaultFieldName) {
|
|
2934
|
+
this.setTextFieldForDefaultItem();
|
|
2935
|
+
}
|
|
2936
|
+
}
|
|
2937
|
+
setTextFieldForDefaultItem() {
|
|
2938
|
+
this.defaultItem[this.textField] = this.setDefaultName();
|
|
2951
2939
|
}
|
|
2952
|
-
|
|
2953
|
-
|
|
2954
|
-
|
|
2955
|
-
|
|
2956
|
-
|
|
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
|
-
|
|
2955
|
+
updateControlValue(entityId) {
|
|
2960
2956
|
const entity = this.getEntityById(entityId);
|
|
2961
2957
|
if (entity) {
|
|
2962
2958
|
this.setControlValue(entity);
|
|
@@ -2966,11 +2962,15 @@ class FieldDropdownComponent extends FieldComponent {
|
|
|
2966
2962
|
}
|
|
2967
2963
|
return entity;
|
|
2968
2964
|
}
|
|
2969
|
-
getEntityFromDataById(entityId) {
|
|
2970
|
-
return this.data.find((x) => x.id === entityId);
|
|
2971
|
-
}
|
|
2972
2965
|
getEntityById(entityId) {
|
|
2973
|
-
|
|
2966
|
+
let entity;
|
|
2967
|
+
if (this.data) {
|
|
2968
|
+
entity = this.data.find((x) => x.id === entityId);
|
|
2969
|
+
}
|
|
2970
|
+
else {
|
|
2971
|
+
entity = this.items.find((x) => x.id === entityId);
|
|
2972
|
+
}
|
|
2973
|
+
return entity;
|
|
2974
2974
|
}
|
|
2975
2975
|
setControlValue(entity) {
|
|
2976
2976
|
this.control.setValue(entity.id);
|
|
@@ -2982,7 +2982,7 @@ class FieldDropdownComponent extends FieldComponent {
|
|
|
2982
2982
|
this.selectedChange.emit(entity);
|
|
2983
2983
|
}
|
|
2984
2984
|
writeSelectedEntityValue(selectedEntityId) {
|
|
2985
|
-
this.kendoDropDown
|
|
2985
|
+
this.kendoDropDown?.writeValue(selectedEntityId);
|
|
2986
2986
|
}
|
|
2987
2987
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.0", ngImport: i0, type: FieldDropdownComponent, deps: [{ token: i1$3.FormGroupDirective }, { token: i0.ElementRef }, { token: i2.TranslateService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
2988
2988
|
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.0", type: FieldDropdownComponent, selector: "field-dropdown", inputs: { service: "service", rebind: "rebind", filter: "filter", defaultName: "defaultName", selectedItem: "selectedItem", data: "data", textField: "textField" }, outputs: { selectedChange: "selectedChange" }, viewQueries: [{ propertyName: "kendoDropDown", first: true, predicate: ["inputElement"], descendants: true }], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<div class=\"form-group\">\n <label\n for=\"{{ '_' + fieldName }}\"\n class=\"col-md-3 control-label\"\n translate=\"{{ labelKey }}\"\n ></label>\n <div class=\"col-md-9\" *ngIf=\"control\">\n <kendo-dropdownlist\n id=\"{{ '_' + fieldName }}\"\n [formControl]=\"control\"\n [data]=\"data$ | async\"\n [textField]=\"textField\"\n valueField=\"id\"\n [valuePrimitive]=\"true\"\n [defaultItem]=\"defaultItem\"\n (valueChange)=\"onValueChange($event)\"\n #inputElement\n >\n </kendo-dropdownlist>\n\n <div class=\"bg-danger\" *ngIf=\"control.invalid && control.touched\">\n <span *ngIf=\"control.errors['required']\">{{\n \"Required\" | translate : { param0: labelKey | translate }\n }}</span>\n <span *ngIf=\"control.errors['serverErrorMsg']\">{{\n control.errors[\"serverErrorMsg\"]\n }}</span>\n </div>\n </div>\n</div>\n", dependencies: [{ kind: "directive", type: i2.TranslateDirective, selector: "[translate],[ngx-translate]", inputs: ["translate", "translateParams"] }, { kind: "component", type: i5.DropDownListComponent, selector: "kendo-dropdownlist", inputs: ["customIconClass", "showStickyHeader", "icon", "svgIcon", "loading", "data", "value", "textField", "valueField", "adaptiveMode", "title", "subtitle", "popupSettings", "listHeight", "defaultItem", "disabled", "itemDisabled", "readonly", "filterable", "virtual", "ignoreCase", "delay", "valuePrimitive", "tabindex", "tabIndex", "size", "rounded", "fillMode", "leftRightArrowsNavigation", "id"], outputs: ["valueChange", "filterChange", "selectionChange", "open", "opened", "close", "closed", "focus", "blur"], exportAs: ["kendoDropDownList"] }, { kind: "directive", type: i1$3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1$3.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "directive", type: i2$1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i2.TranslatePipe, name: "translate" }, { kind: "pipe", type: i2$1.AsyncPipe, name: "async" }], viewProviders: [
|
|
@@ -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:
|
|
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:
|
|
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";
|