@indigina/kendo 1.1.7 → 1.1.10

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.
@@ -5,28 +5,35 @@ import * as i0 from "@angular/core";
5
5
  import * as i1 from "@angular/forms";
6
6
  import * as i2 from "@ngx-translate/core";
7
7
  import * as i3 from "@angular/common";
8
- const emptyString = '';
8
+ const defaultValue = null;
9
9
  export class NumberInputComponent extends FieldInputComponent {
10
10
  constructor(parent, eref) {
11
11
  super(parent, eref);
12
12
  this.parent = parent;
13
13
  this.eref = eref;
14
14
  this.isPositive = false;
15
- this.type = 'number';
15
+ this.type = 'text';
16
16
  }
17
17
  ngAfterContentInit() {
18
18
  const control = this.parent.form.get(this.fieldName);
19
+ control.setValue(this.presetDefaultValue(control.value));
19
20
  control.valueChanges.subscribe((value) => {
20
- if (value !== this.cachedValue) {
21
+ value = this.presetDefaultValue(value);
22
+ if (value !== this.cachedValue &&
23
+ value !== defaultValue &&
24
+ !value.endsWith('.')) {
21
25
  this.cachedValue =
22
26
  (!this.isPositive && (value || value === 0)) ||
23
- (this.isPositive && value >= 0 && value !== emptyString)
27
+ (this.isPositive && value >= 0)
24
28
  ? +value
25
- : emptyString;
29
+ : defaultValue;
26
30
  control.setValue(this.cachedValue);
27
31
  }
28
32
  });
29
33
  }
34
+ presetDefaultValue(value) {
35
+ return value == '' ? defaultValue : value;
36
+ }
30
37
  }
31
38
  NumberInputComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.1", ngImport: i0, type: NumberInputComponent, deps: [{ token: i1.FormGroupDirective }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
32
39
  NumberInputComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.1", type: NumberInputComponent, selector: "number-input", inputs: { isPositive: "isPositive" }, usesInheritance: true, ngImport: i0, template: "<div class=\"form-group\">\n <label\n for=\"{{ id }}\"\n class=\"col-md-3 control-label\"\n translate=\"{{ labelKey }}\"\n ></label>\n <div class=\"col-md-9\">\n <input\n [formControlName]=\"fieldName\"\n id=\"{{ id }}\"\n [type]=\"type\"\n class=\"k-input\"\n autocomplete=\"new-{{ fieldName }}\"\n placeholder=\"{{ labelKey | translate }}\"\n [attr.disabled]=\"disabled ? disabledKey : null\"\n />\n <ng-content></ng-content>\n <div\n class=\"bg-danger\"\n *ngIf=\"\n parent.form.get(fieldName) &&\n parent.form.get(fieldName).invalid &&\n parent.form.get(fieldName).touched\n \"\n >\n <span *ngIf=\"parent.form.get(fieldName).errors['required']\">{{\n 'Required' | translate: { param0: labelKey | translate }\n }}</span>\n <span *ngIf=\"parent.form.get(fieldName).errors['email']\">{{\n 'ValidEmail' | translate\n }}</span>\n <span *ngIf=\"parent.form.get(fieldName).errors['serverErrorMsg']\">{{\n parent.form.get(fieldName).errors['serverErrorMsg']\n }}</span>\n </div>\n </div>\n</div>\n", directives: [{ type: i2.TranslateDirective, selector: "[translate],[ngx-translate]", inputs: ["translate", "translateParams"] }, { type: i1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i1.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], pipes: { "translate": i2.TranslatePipe }, viewProviders: [
@@ -40,4 +47,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.1", ngImpor
40
47
  }], ctorParameters: function () { return [{ type: i1.FormGroupDirective }, { type: i0.ElementRef }]; }, propDecorators: { isPositive: [{
41
48
  type: Input
42
49
  }] } });
43
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibnVtYmVyLWlucHV0LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2tlbmRvL3NyYy9saWIvYW5ndWxhci9mb3Jtcy93aWRnZXRzL2ZpZWxkL2ZpZWxkLWlucHV0L251bWJlci1pbnB1dC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9rZW5kby9zcmMvbGliL2FuZ3VsYXIvZm9ybXMvd2lkZ2V0cy9maWVsZC9maWVsZC1pbnB1dC9maWVsZC1pbnB1dC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFjLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUM3RCxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUN0RSxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQzs7Ozs7QUFFOUQsTUFBTSxXQUFXLEdBQUcsRUFBRSxDQUFDO0FBU3ZCLE1BQU0sT0FBTyxvQkFBcUIsU0FBUSxtQkFBbUI7SUFDM0QsWUFBbUIsTUFBMEIsRUFBUyxJQUFnQjtRQUNwRSxLQUFLLENBQUMsTUFBTSxFQUFFLElBQUksQ0FBQyxDQUFDO1FBREgsV0FBTSxHQUFOLE1BQU0sQ0FBb0I7UUFBUyxTQUFJLEdBQUosSUFBSSxDQUFZO1FBSzdELGVBQVUsR0FBWSxLQUFLLENBQUM7UUFIbkMsSUFBSSxDQUFDLElBQUksR0FBRyxRQUFRLENBQUM7SUFDdkIsQ0FBQztJQU1ELGtCQUFrQjtRQUNoQixNQUFNLE9BQU8sR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDO1FBQ3JELE9BQU8sQ0FBQyxZQUFZLENBQUMsU0FBUyxDQUFDLENBQUMsS0FBSyxFQUFFLEVBQUU7WUFDdkMsSUFBSSxLQUFLLEtBQUssSUFBSSxDQUFDLFdBQVcsRUFBRTtnQkFDOUIsSUFBSSxDQUFDLFdBQVc7b0JBQ2QsQ0FBQyxDQUFDLElBQUksQ0FBQyxVQUFVLElBQUksQ0FBQyxLQUFLLElBQUksS0FBSyxLQUFLLENBQUMsQ0FBQyxDQUFDO3dCQUM1QyxDQUFDLElBQUksQ0FBQyxVQUFVLElBQUksS0FBSyxJQUFJLENBQUMsSUFBSSxLQUFLLEtBQUssV0FBVyxDQUFDO3dCQUN0RCxDQUFDLENBQUMsQ0FBQyxLQUFLO3dCQUNSLENBQUMsQ0FBQyxXQUFXLENBQUM7Z0JBRWxCLE9BQU8sQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxDQUFDO2FBQ3BDO1FBQ0gsQ0FBQyxDQUFDLENBQUM7SUFDTCxDQUFDOztpSEF2QlUsb0JBQW9CO3FHQUFwQixvQkFBb0IsaUhDYmpDLDRuQ0FxQ0EsNnVCRDVCaUI7UUFDYixFQUFFLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxXQUFXLEVBQUUsa0JBQWtCLEVBQUU7S0FDL0Q7MkZBRVUsb0JBQW9CO2tCQVBoQyxTQUFTOytCQUNFLGNBQWMsaUJBRVQ7d0JBQ2IsRUFBRSxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsV0FBVyxFQUFFLGtCQUFrQixFQUFFO3FCQUMvRDtrSUFRUSxVQUFVO3NCQUFsQixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBFbGVtZW50UmVmLCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQ29udHJvbENvbnRhaW5lciwgRm9ybUdyb3VwRGlyZWN0aXZlIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuaW1wb3J0IHsgRmllbGRJbnB1dENvbXBvbmVudCB9IGZyb20gJy4vZmllbGQtaW5wdXQuY29tcG9uZW50JztcblxuY29uc3QgZW1wdHlTdHJpbmcgPSAnJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnbnVtYmVyLWlucHV0JyxcbiAgdGVtcGxhdGVVcmw6ICcuL2ZpZWxkLWlucHV0LmNvbXBvbmVudC5odG1sJyxcbiAgdmlld1Byb3ZpZGVyczogW1xuICAgIHsgcHJvdmlkZTogQ29udHJvbENvbnRhaW5lciwgdXNlRXhpc3Rpbmc6IEZvcm1Hcm91cERpcmVjdGl2ZSB9LFxuICBdLFxufSlcbmV4cG9ydCBjbGFzcyBOdW1iZXJJbnB1dENvbXBvbmVudCBleHRlbmRzIEZpZWxkSW5wdXRDb21wb25lbnQge1xuICBjb25zdHJ1Y3RvcihwdWJsaWMgcGFyZW50OiBGb3JtR3JvdXBEaXJlY3RpdmUsIHB1YmxpYyBlcmVmOiBFbGVtZW50UmVmKSB7XG4gICAgc3VwZXIocGFyZW50LCBlcmVmKTtcbiAgICB0aGlzLnR5cGUgPSAnbnVtYmVyJztcbiAgfVxuXG4gIEBJbnB1dCgpIGlzUG9zaXRpdmU6IGJvb2xlYW4gPSBmYWxzZTtcblxuICBwcml2YXRlIGNhY2hlZFZhbHVlOiBudW1iZXIgfCBzdHJpbmc7XG5cbiAgbmdBZnRlckNvbnRlbnRJbml0KCkge1xuICAgIGNvbnN0IGNvbnRyb2wgPSB0aGlzLnBhcmVudC5mb3JtLmdldCh0aGlzLmZpZWxkTmFtZSk7XG4gICAgY29udHJvbC52YWx1ZUNoYW5nZXMuc3Vic2NyaWJlKCh2YWx1ZSkgPT4ge1xuICAgICAgaWYgKHZhbHVlICE9PSB0aGlzLmNhY2hlZFZhbHVlKSB7XG4gICAgICAgIHRoaXMuY2FjaGVkVmFsdWUgPVxuICAgICAgICAgICghdGhpcy5pc1Bvc2l0aXZlICYmICh2YWx1ZSB8fCB2YWx1ZSA9PT0gMCkpIHx8XG4gICAgICAgICAgKHRoaXMuaXNQb3NpdGl2ZSAmJiB2YWx1ZSA+PSAwICYmIHZhbHVlICE9PSBlbXB0eVN0cmluZylcbiAgICAgICAgICAgID8gK3ZhbHVlXG4gICAgICAgICAgICA6IGVtcHR5U3RyaW5nO1xuXG4gICAgICAgIGNvbnRyb2wuc2V0VmFsdWUodGhpcy5jYWNoZWRWYWx1ZSk7XG4gICAgICB9XG4gICAgfSk7XG4gIH1cbn1cbiIsIjxkaXYgY2xhc3M9XCJmb3JtLWdyb3VwXCI+XG4gIDxsYWJlbFxuICAgIGZvcj1cInt7IGlkIH19XCJcbiAgICBjbGFzcz1cImNvbC1tZC0zIGNvbnRyb2wtbGFiZWxcIlxuICAgIHRyYW5zbGF0ZT1cInt7IGxhYmVsS2V5IH19XCJcbiAgPjwvbGFiZWw+XG4gIDxkaXYgY2xhc3M9XCJjb2wtbWQtOVwiPlxuICAgIDxpbnB1dFxuICAgICAgW2Zvcm1Db250cm9sTmFtZV09XCJmaWVsZE5hbWVcIlxuICAgICAgaWQ9XCJ7eyBpZCB9fVwiXG4gICAgICBbdHlwZV09XCJ0eXBlXCJcbiAgICAgIGNsYXNzPVwiay1pbnB1dFwiXG4gICAgICBhdXRvY29tcGxldGU9XCJuZXcte3sgZmllbGROYW1lIH19XCJcbiAgICAgIHBsYWNlaG9sZGVyPVwie3sgbGFiZWxLZXkgfCB0cmFuc2xhdGUgfX1cIlxuICAgICAgW2F0dHIuZGlzYWJsZWRdPVwiZGlzYWJsZWQgPyBkaXNhYmxlZEtleSA6IG51bGxcIlxuICAgIC8+XG4gICAgPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PlxuICAgIDxkaXZcbiAgICAgIGNsYXNzPVwiYmctZGFuZ2VyXCJcbiAgICAgICpuZ0lmPVwiXG4gICAgICAgIHBhcmVudC5mb3JtLmdldChmaWVsZE5hbWUpICYmXG4gICAgICAgIHBhcmVudC5mb3JtLmdldChmaWVsZE5hbWUpLmludmFsaWQgJiZcbiAgICAgICAgcGFyZW50LmZvcm0uZ2V0KGZpZWxkTmFtZSkudG91Y2hlZFxuICAgICAgXCJcbiAgICA+XG4gICAgICA8c3BhbiAqbmdJZj1cInBhcmVudC5mb3JtLmdldChmaWVsZE5hbWUpLmVycm9yc1sncmVxdWlyZWQnXVwiPnt7XG4gICAgICAgICdSZXF1aXJlZCcgfCB0cmFuc2xhdGU6IHsgcGFyYW0wOiBsYWJlbEtleSB8IHRyYW5zbGF0ZSB9XG4gICAgICB9fTwvc3Bhbj5cbiAgICAgIDxzcGFuICpuZ0lmPVwicGFyZW50LmZvcm0uZ2V0KGZpZWxkTmFtZSkuZXJyb3JzWydlbWFpbCddXCI+e3tcbiAgICAgICAgJ1ZhbGlkRW1haWwnIHwgdHJhbnNsYXRlXG4gICAgICB9fTwvc3Bhbj5cbiAgICAgIDxzcGFuICpuZ0lmPVwicGFyZW50LmZvcm0uZ2V0KGZpZWxkTmFtZSkuZXJyb3JzWydzZXJ2ZXJFcnJvck1zZyddXCI+e3tcbiAgICAgICAgcGFyZW50LmZvcm0uZ2V0KGZpZWxkTmFtZSkuZXJyb3JzWydzZXJ2ZXJFcnJvck1zZyddXG4gICAgICB9fTwvc3Bhbj5cbiAgICA8L2Rpdj5cbiAgPC9kaXY+XG48L2Rpdj5cbiJdfQ==
50
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibnVtYmVyLWlucHV0LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2tlbmRvL3NyYy9saWIvYW5ndWxhci9mb3Jtcy93aWRnZXRzL2ZpZWxkL2ZpZWxkLWlucHV0L251bWJlci1pbnB1dC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9rZW5kby9zcmMvbGliL2FuZ3VsYXIvZm9ybXMvd2lkZ2V0cy9maWVsZC9maWVsZC1pbnB1dC9maWVsZC1pbnB1dC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFjLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUM3RCxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUN0RSxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQzs7Ozs7QUFFOUQsTUFBTSxZQUFZLEdBQUcsSUFBSSxDQUFDO0FBUzFCLE1BQU0sT0FBTyxvQkFBcUIsU0FBUSxtQkFBbUI7SUFDM0QsWUFBbUIsTUFBMEIsRUFBUyxJQUFnQjtRQUNwRSxLQUFLLENBQUMsTUFBTSxFQUFFLElBQUksQ0FBQyxDQUFDO1FBREgsV0FBTSxHQUFOLE1BQU0sQ0FBb0I7UUFBUyxTQUFJLEdBQUosSUFBSSxDQUFZO1FBSzdELGVBQVUsR0FBWSxLQUFLLENBQUM7UUFIbkMsSUFBSSxDQUFDLElBQUksR0FBRyxNQUFNLENBQUM7SUFDckIsQ0FBQztJQU1ELGtCQUFrQjtRQUNoQixNQUFNLE9BQU8sR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDO1FBQ3JELE9BQU8sQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLGtCQUFrQixDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDO1FBQ3pELE9BQU8sQ0FBQyxZQUFZLENBQUMsU0FBUyxDQUFDLENBQUMsS0FBSyxFQUFFLEVBQUU7WUFDdkMsS0FBSyxHQUFHLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxLQUFLLENBQUMsQ0FBQztZQUN2QyxJQUNFLEtBQUssS0FBSyxJQUFJLENBQUMsV0FBVztnQkFDMUIsS0FBSyxLQUFLLFlBQVk7Z0JBQ3RCLENBQUMsS0FBSyxDQUFDLFFBQVEsQ0FBQyxHQUFHLENBQUMsRUFDcEI7Z0JBQ0EsSUFBSSxDQUFDLFdBQVc7b0JBQ2QsQ0FBQyxDQUFDLElBQUksQ0FBQyxVQUFVLElBQUksQ0FBQyxLQUFLLElBQUksS0FBSyxLQUFLLENBQUMsQ0FBQyxDQUFDO3dCQUM1QyxDQUFDLElBQUksQ0FBQyxVQUFVLElBQUksS0FBSyxJQUFJLENBQUMsQ0FBQzt3QkFDN0IsQ0FBQyxDQUFDLENBQUMsS0FBSzt3QkFDUixDQUFDLENBQUMsWUFBWSxDQUFDO2dCQUVuQixPQUFPLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsQ0FBQzthQUNwQztRQUNILENBQUMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztJQUVPLGtCQUFrQixDQUFDLEtBQXNCO1FBQy9DLE9BQU8sS0FBSyxJQUFJLEVBQUUsQ0FBQyxDQUFDLENBQUMsWUFBWSxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUM7SUFDNUMsQ0FBQzs7aUhBakNVLG9CQUFvQjtxR0FBcEIsb0JBQW9CLGlIQ2JqQyw0bkNBcUNBLDZ1QkQ1QmlCO1FBQ2IsRUFBRSxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsV0FBVyxFQUFFLGtCQUFrQixFQUFFO0tBQy9EOzJGQUVVLG9CQUFvQjtrQkFQaEMsU0FBUzsrQkFDRSxjQUFjLGlCQUVUO3dCQUNiLEVBQUUsT0FBTyxFQUFFLGdCQUFnQixFQUFFLFdBQVcsRUFBRSxrQkFBa0IsRUFBRTtxQkFDL0Q7a0lBUVEsVUFBVTtzQkFBbEIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgRWxlbWVudFJlZiwgSW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENvbnRyb2xDb250YWluZXIsIEZvcm1Hcm91cERpcmVjdGl2ZSB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcbmltcG9ydCB7IEZpZWxkSW5wdXRDb21wb25lbnQgfSBmcm9tICcuL2ZpZWxkLWlucHV0LmNvbXBvbmVudCc7XG5cbmNvbnN0IGRlZmF1bHRWYWx1ZSA9IG51bGw7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ251bWJlci1pbnB1dCcsXG4gIHRlbXBsYXRlVXJsOiAnLi9maWVsZC1pbnB1dC5jb21wb25lbnQuaHRtbCcsXG4gIHZpZXdQcm92aWRlcnM6IFtcbiAgICB7IHByb3ZpZGU6IENvbnRyb2xDb250YWluZXIsIHVzZUV4aXN0aW5nOiBGb3JtR3JvdXBEaXJlY3RpdmUgfSxcbiAgXSxcbn0pXG5leHBvcnQgY2xhc3MgTnVtYmVySW5wdXRDb21wb25lbnQgZXh0ZW5kcyBGaWVsZElucHV0Q29tcG9uZW50IHtcbiAgY29uc3RydWN0b3IocHVibGljIHBhcmVudDogRm9ybUdyb3VwRGlyZWN0aXZlLCBwdWJsaWMgZXJlZjogRWxlbWVudFJlZikge1xuICAgIHN1cGVyKHBhcmVudCwgZXJlZik7XG4gICAgdGhpcy50eXBlID0gJ3RleHQnO1xuICB9XG5cbiAgQElucHV0KCkgaXNQb3NpdGl2ZTogYm9vbGVhbiA9IGZhbHNlO1xuXG4gIHByaXZhdGUgY2FjaGVkVmFsdWU6IG51bWJlciB8IHN0cmluZztcblxuICBuZ0FmdGVyQ29udGVudEluaXQoKSB7XG4gICAgY29uc3QgY29udHJvbCA9IHRoaXMucGFyZW50LmZvcm0uZ2V0KHRoaXMuZmllbGROYW1lKTtcbiAgICBjb250cm9sLnNldFZhbHVlKHRoaXMucHJlc2V0RGVmYXVsdFZhbHVlKGNvbnRyb2wudmFsdWUpKTtcbiAgICBjb250cm9sLnZhbHVlQ2hhbmdlcy5zdWJzY3JpYmUoKHZhbHVlKSA9PiB7XG4gICAgICB2YWx1ZSA9IHRoaXMucHJlc2V0RGVmYXVsdFZhbHVlKHZhbHVlKTtcbiAgICAgIGlmIChcbiAgICAgICAgdmFsdWUgIT09IHRoaXMuY2FjaGVkVmFsdWUgJiZcbiAgICAgICAgdmFsdWUgIT09IGRlZmF1bHRWYWx1ZSAmJlxuICAgICAgICAhdmFsdWUuZW5kc1dpdGgoJy4nKVxuICAgICAgKSB7XG4gICAgICAgIHRoaXMuY2FjaGVkVmFsdWUgPVxuICAgICAgICAgICghdGhpcy5pc1Bvc2l0aXZlICYmICh2YWx1ZSB8fCB2YWx1ZSA9PT0gMCkpIHx8XG4gICAgICAgICAgKHRoaXMuaXNQb3NpdGl2ZSAmJiB2YWx1ZSA+PSAwKVxuICAgICAgICAgICAgPyArdmFsdWVcbiAgICAgICAgICAgIDogZGVmYXVsdFZhbHVlO1xuXG4gICAgICAgIGNvbnRyb2wuc2V0VmFsdWUodGhpcy5jYWNoZWRWYWx1ZSk7XG4gICAgICB9XG4gICAgfSk7XG4gIH1cblxuICBwcml2YXRlIHByZXNldERlZmF1bHRWYWx1ZSh2YWx1ZTogbnVtYmVyIHwgc3RyaW5nKTogbnVtYmVyIHwgc3RyaW5nIHtcbiAgICByZXR1cm4gdmFsdWUgPT0gJycgPyBkZWZhdWx0VmFsdWUgOiB2YWx1ZTtcbiAgfVxufVxuIiwiPGRpdiBjbGFzcz1cImZvcm0tZ3JvdXBcIj5cbiAgPGxhYmVsXG4gICAgZm9yPVwie3sgaWQgfX1cIlxuICAgIGNsYXNzPVwiY29sLW1kLTMgY29udHJvbC1sYWJlbFwiXG4gICAgdHJhbnNsYXRlPVwie3sgbGFiZWxLZXkgfX1cIlxuICA+PC9sYWJlbD5cbiAgPGRpdiBjbGFzcz1cImNvbC1tZC05XCI+XG4gICAgPGlucHV0XG4gICAgICBbZm9ybUNvbnRyb2xOYW1lXT1cImZpZWxkTmFtZVwiXG4gICAgICBpZD1cInt7IGlkIH19XCJcbiAgICAgIFt0eXBlXT1cInR5cGVcIlxuICAgICAgY2xhc3M9XCJrLWlucHV0XCJcbiAgICAgIGF1dG9jb21wbGV0ZT1cIm5ldy17eyBmaWVsZE5hbWUgfX1cIlxuICAgICAgcGxhY2Vob2xkZXI9XCJ7eyBsYWJlbEtleSB8IHRyYW5zbGF0ZSB9fVwiXG4gICAgICBbYXR0ci5kaXNhYmxlZF09XCJkaXNhYmxlZCA/IGRpc2FibGVkS2V5IDogbnVsbFwiXG4gICAgLz5cbiAgICA8bmctY29udGVudD48L25nLWNvbnRlbnQ+XG4gICAgPGRpdlxuICAgICAgY2xhc3M9XCJiZy1kYW5nZXJcIlxuICAgICAgKm5nSWY9XCJcbiAgICAgICAgcGFyZW50LmZvcm0uZ2V0KGZpZWxkTmFtZSkgJiZcbiAgICAgICAgcGFyZW50LmZvcm0uZ2V0KGZpZWxkTmFtZSkuaW52YWxpZCAmJlxuICAgICAgICBwYXJlbnQuZm9ybS5nZXQoZmllbGROYW1lKS50b3VjaGVkXG4gICAgICBcIlxuICAgID5cbiAgICAgIDxzcGFuICpuZ0lmPVwicGFyZW50LmZvcm0uZ2V0KGZpZWxkTmFtZSkuZXJyb3JzWydyZXF1aXJlZCddXCI+e3tcbiAgICAgICAgJ1JlcXVpcmVkJyB8IHRyYW5zbGF0ZTogeyBwYXJhbTA6IGxhYmVsS2V5IHwgdHJhbnNsYXRlIH1cbiAgICAgIH19PC9zcGFuPlxuICAgICAgPHNwYW4gKm5nSWY9XCJwYXJlbnQuZm9ybS5nZXQoZmllbGROYW1lKS5lcnJvcnNbJ2VtYWlsJ11cIj57e1xuICAgICAgICAnVmFsaWRFbWFpbCcgfCB0cmFuc2xhdGVcbiAgICAgIH19PC9zcGFuPlxuICAgICAgPHNwYW4gKm5nSWY9XCJwYXJlbnQuZm9ybS5nZXQoZmllbGROYW1lKS5lcnJvcnNbJ3NlcnZlckVycm9yTXNnJ11cIj57e1xuICAgICAgICBwYXJlbnQuZm9ybS5nZXQoZmllbGROYW1lKS5lcnJvcnNbJ3NlcnZlckVycm9yTXNnJ11cbiAgICAgIH19PC9zcGFuPlxuICAgIDwvZGl2PlxuICA8L2Rpdj5cbjwvZGl2PlxuIl19
@@ -1,4 +1,5 @@
1
- import { Component, ViewChild, Input, EventEmitter, Output, } from '@angular/core';
1
+ import { Component, EventEmitter, Input, Output, ViewChild } from '@angular/core';
2
+ import { map } from 'rxjs/operators';
2
3
  import { urlDeserialize, urlSerialize } from './UrlSerializer';
3
4
  import * as i0 from "@angular/core";
4
5
  import * as i1 from "@ngx-translate/core";
@@ -34,7 +35,7 @@ export class EntityListComponent {
34
35
  }
35
36
  this.getFilteredData();
36
37
  }
37
- async ngOnInit() {
38
+ ngOnInit() {
38
39
  this.gridFields = (this.fields || [])
39
40
  .concat(this.defaultFields)
40
41
  .sort((left, right) => (left.position || 0) - (right.position || 0));
@@ -43,7 +44,7 @@ export class EntityListComponent {
43
44
  this.route.fragment.subscribe(async (fragment) => {
44
45
  await this.restoreGridState(new URLSearchParams(fragment));
45
46
  });
46
- this.route.firstChild.params.subscribe(async (params) => {
47
+ this.route.firstChild.params.subscribe((params) => {
47
48
  if (params.id) {
48
49
  this.selected[0] = params.id;
49
50
  }
@@ -132,9 +133,11 @@ export class EntityListComponent {
132
133
  this.loadings--;
133
134
  });
134
135
  }
135
- async remove(entity) {
136
+ remove(entity) {
136
137
  this.loadings++;
137
- this.service.delete(entity.id).subscribe(() => {
138
+ this.service
139
+ .delete(entity.id)
140
+ .pipe(map(() => {
138
141
  if (this.selected.length &&
139
142
  this.selected[this.selected.length - 1] === entity.id) {
140
143
  this.router.navigate(['../'], {
@@ -143,8 +146,10 @@ export class EntityListComponent {
143
146
  });
144
147
  }
145
148
  this.loadings--;
149
+ }))
150
+ .subscribe(() => {
151
+ this.getData();
146
152
  });
147
- this.getData();
148
153
  }
149
154
  getFilter() {
150
155
  const filter = {
@@ -198,4 +203,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.1", ngImpor
198
203
  type: ViewChild,
199
204
  args: ['confirmDialog', { static: true }]
200
205
  }] } });
201
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"entity-list.component.js","sourceRoot":"","sources":["../../../../../../projects/kendo/src/lib/widgets/entity-list/entity-list.component.ts","../../../../../../projects/kendo/src/lib/widgets/entity-list/entity-list.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Observable } from 'rxjs';\nimport {\n  Component,\n  OnInit,\n  ViewChild,\n  Input,\n  EventEmitter,\n  OnChanges,\n  SimpleChanges,\n  Output,\n} from '@angular/core';\nimport { Router, ActivatedRoute, Params } from '@angular/router';\nimport {\n  State,\n  FilterDescriptor,\n  CompositeFilterDescriptor,\n  SortDescriptor,\n} from '@progress/kendo-data-query';\nimport {\n  DataStateChangeEvent,\n  RowClassArgs,\n} from '@progress/kendo-angular-grid';\nimport { Field } from './Field';\nimport { Command } from './Command';\nimport { urlDeserialize, urlSerialize } from './UrlSerializer';\nimport { ConfirmDialogComponent } from '../confirm-dialog/confirm-dialog.component';\nimport { IEntityService } from '../../services/IEntityService';\nimport { Page } from '../../models/Page';\nimport { TranslateService } from '@ngx-translate/core';\nimport { NamedModel } from '../../angular/models/NamedModel';\nimport { IdentifiedModel } from '../../angular/models/IdentifiedModel';\n\nconst nameField = 'name';\n\n@Component({\n  selector: 'entity-list',\n  templateUrl: './entity-list.component.html',\n  styleUrls: ['./entity-list.component.css'],\n})\nexport class EntityListComponent implements OnInit, OnChanges {\n  @Input()\n  public service: IEntityService<NamedModel>;\n  @Input()\n  public filters: Array<FilterDescriptor | CompositeFilterDescriptor>;\n  @Input()\n  public fields?: Field[];\n  @Input()\n  public commands?: Command[];\n  @Input()\n  public rowClass?: (dataItem: NamedModel, index: number) => {};\n  @Input()\n  public defaultSort?: SortDescriptor[];\n  @Output()\n  public filterChange = new EventEmitter<CompositeFilterDescriptor>();\n  @ViewChild('confirmDialog', { static: true })\n  public dialog: ConfirmDialogComponent;\n  public gridState: State = {};\n  public page: Page<NamedModel>;\n  public loadings = 0;\n  public searchTerm: string;\n  public selected: string[] = [];\n  public gridFields: Field[] = [];\n  private defaultFields: Field[] = [\n    { name: 'name', label: 'Name', sortable: true, position: 0 },\n  ];\n\n  constructor(\n    private translate: TranslateService,\n    private route: ActivatedRoute,\n    private router: Router\n  ) {\n    this.getAllData = this.getAllData.bind(this);\n    this.getRowClass = this.getRowClass.bind(this);\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (!changes.filters || changes.filters.firstChange) {\n      return;\n    }\n\n    this.getFilteredData();\n  }\n\n  async ngOnInit() {\n    this.gridFields = (this.fields || [])\n      .concat(this.defaultFields)\n      .sort((left, right) => (left.position || 0) - (right.position || 0));\n    this.filters = this.filters ? this.filters : [];\n    this.commands = this.commands ? this.commands : [];\n    this.route.fragment.subscribe(async (fragment: string) => {\n      await this.restoreGridState(new URLSearchParams(fragment));\n    });\n\n    this.route.firstChild.params.subscribe(async (params: Params) => {\n      if (params.id) {\n        this.selected[0] = params.id;\n      } else {\n        this.selected.pop();\n      }\n    });\n  }\n\n  public removeHandler({ dataItem }) {\n    this.dialog.open(\n      this.translate.instant('Confirmation.Delete') +\n        ': \"' +\n        dataItem.name +\n        '\"?',\n      () => this.remove(dataItem)\n    );\n  }\n\n  public selectItem({ dataItem }) {\n    this.router.navigate([dataItem.id], {\n      relativeTo: this.route,\n      fragment: urlSerialize(this.gridState),\n    });\n  }\n\n  public onActivate(child: { saved: EventEmitter<NamedModel> }) {\n    if (child.saved) {\n      child.saved.subscribe((data: { id: string; name: string }) =>\n        this.updateGrid(data)\n      );\n    }\n  }\n\n  public onDeactivate(child: { saved: EventEmitter<NamedModel> }) {\n    if (child.saved) {\n      child.saved.unsubscribe();\n    }\n  }\n\n  public dataStateChange(state: DataStateChangeEvent) {\n    Object.keys(state).forEach((key) => {\n      this.gridState[key] = isNaN(state.skip)\n        ? this.gridState[key]\n        : state[key];\n    });\n\n    this.router.navigate([], {\n      relativeTo: this.route,\n      fragment: urlSerialize(this.gridState),\n    });\n  }\n\n  public onSearch(value: string) {\n    this.searchTerm = value;\n    this.gridState.skip = 0;\n    this.getFilteredData();\n  }\n\n  public getAllData(): Observable<Page<NamedModel>> {\n    const state = Object.assign({}, this.gridState);\n    delete state.skip;\n    delete state.take;\n\n    return this.service.getPage(state);\n  }\n\n  public getRowClass(context: RowClassArgs): Object {\n    return this.rowClass && context\n      ? this.rowClass(context.dataItem, context.index)\n      : {};\n  }\n\n  protected getFilteredData() {\n    this.gridState.filter = this.getFilter();\n    this.router.navigate([], {\n      relativeTo: this.route,\n      fragment: urlSerialize(this.gridState),\n    });\n  }\n\n  protected updateGrid(data: NamedModel) {\n    const exists = this.page.data.filter((x) => x.id === data.id);\n    if (exists.length) {\n      this.page.data[this.page.data.indexOf(exists[0])] = data;\n\n      return;\n    }\n\n    this.page.total++;\n    this.page.data.splice(0, 0, data);\n    if (this.page.data.length > this.gridState.take) {\n      this.page.data.splice(this.page.data.length - 1, 1);\n    }\n\n    this.selected[0] = data.id;\n    this.router.navigate([data.id], {\n      relativeTo: this.route,\n      preserveFragment: true,\n    });\n  }\n\n  protected getData() {\n    this.loadings++;\n    this.service.getPage(this.gridState).subscribe((page) => {\n      this.page = page;\n      this.loadings--;\n    });\n  }\n\n  private async remove(entity: IdentifiedModel) {\n    this.loadings++;\n    this.service.delete(entity.id).subscribe(() => {\n      if (\n        this.selected.length &&\n        this.selected[this.selected.length - 1] === entity.id\n      ) {\n        this.router.navigate(['../'], {\n          preserveFragment: true,\n          relativeTo: this.route.firstChild,\n        });\n      }\n      this.loadings--;\n    });\n    this.getData();\n  }\n\n  private getFilter(): CompositeFilterDescriptor {\n    const filter: CompositeFilterDescriptor = {\n      logic: 'and',\n      filters: this.searchTerm\n        ? [\n            { field: nameField, operator: 'contains', value: this.searchTerm },\n            ...this.filters,\n          ]\n        : this.filters,\n    };\n\n    return filter;\n  }\n\n  private onFilterChange() {\n    const filter: any = this.gridState.filter?.filters.find(\n      (x: FilterDescriptor) => x.field === nameField\n    );\n    this.searchTerm = filter?.value;\n    this.filterChange.emit(this.gridState.filter);\n  }\n\n  private async restoreGridState(params: URLSearchParams) {\n    const defaultGridState: State = {\n      sort: this.defaultSort || [{ field: nameField, dir: 'asc' }],\n      skip: 0,\n      take: 10,\n    };\n\n    const state = urlDeserialize(params);\n    this.gridState = state.hasOwnProperty('take') ? state : defaultGridState;\n    this.onFilterChange();\n    this.getData();\n  }\n}\n","<div class=\"row\">\n  <div class=\"col-md-4\">\n    <header class=\"header-page-bg\"></header>\n    <div class=\"panel search-panel hero-unit\">\n      <div class=\"header-selection-field\">\n        <label for=\"searchinput\" class=\"title-field\" translate=\"Search\"></label>\n        <input\n          kendoTextBox\n          class=\"quick-filter input input-field\"\n          title=\"\"\n          id=\"searchinput\"\n          type=\"text\"\n          appDebounce\n          (debounceKeyup)=\"onSearch($event.target.value)\"\n          [ngModel]=\"searchTerm\"\n          [debounceTime]=\"600\"\n        />\n      </div>\n      <ng-content></ng-content>\n      <div class=\"divide-line\"></div>\n\n      <kendo-grid\n        [data]=\"page\"\n        [pageSize]=\"gridState.take\"\n        [skip]=\"gridState.skip\"\n        [sort]=\"gridState.sort\"\n        [pageable]=\"true\"\n        [sortable]=\"true\"\n        [style.maxHeight.px]=\"480\"\n        (remove)=\"removeHandler($event)\"\n        (dataStateChange)=\"dataStateChange($event)\"\n        [loading]=\"loadings > 0\"\n        (cellClick)=\"selectItem($event)\"\n        culture\n        class=\"rows-pointable\"\n        kendoGridSelectBy=\"id\"\n        [selectedKeys]=\"selected\"\n        [rowClass]=\"getRowClass\"\n      >\n        <ng-template kendoGridToolbarTemplate>\n          <excel-export-button></excel-export-button>\n        </ng-template>\n        <kendo-grid-excel [fetchData]=\"getAllData\"></kendo-grid-excel>\n        <kendo-grid-command-column width=\"65\">\n          <ng-template kendoGridCellTemplate>\n            <button\n              kendoGridRemoveCommand\n              requirePermission\n              permissionType=\"Delete\"\n            >\n              <i class=\"k-icon glyphicon glyphicon-trash\"></i>\n            </button>\n          </ng-template>\n        </kendo-grid-command-column>\n        <kendo-grid-column\n          *ngFor=\"let field of gridFields\"\n          field=\"{{ field.name }}\"\n          title=\"{{ field.label | translate }}\"\n          [sortable]=\"field.sortable !== false\"\n        >\n        </kendo-grid-column>\n        <kendo-grid-command-column width=\"65\" *ngIf=\"commands.length > 0\">\n          <ng-template kendoGridCellTemplate let-dataItem>\n            <button\n              *ngFor=\"let command of commands\"\n              (click)=\"command.handler(dataItem)\"\n              title=\"{{ command.title | translate }}\"\n              class=\"k-button\"\n            >\n              <i *ngIf=\"command.iconClass\" class=\"{{ command.iconClass }}\"></i>\n              {{ command.name | translate }}\n            </button>\n          </ng-template>\n        </kendo-grid-command-column>\n        <ng-template kendoGridNoRecordsTemplate>\n          {{ 'Messages.NoRecords' | translate }}\n        </ng-template>\n        <ng-template kendoPagerTemplate>\n          <kendo-grid-spacer></kendo-grid-spacer>\n          <kendo-pager-prev-buttons></kendo-pager-prev-buttons>\n          <kendo-pager-numeric-buttons\n            [buttonCount]=\"10\"\n          ></kendo-pager-numeric-buttons>\n          <kendo-pager-next-buttons></kendo-pager-next-buttons>\n          <kendo-pager-info></kendo-pager-info>\n        </ng-template>\n      </kendo-grid>\n    </div>\n  </div>\n  <router-outlet\n    (activate)=\"onActivate($event)\"\n    (deactivate)=\"onDeactivate($event)\"\n  ></router-outlet>\n</div>\n<confirm-dialog #confirmDialog></confirm-dialog>\n"]}
206
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"entity-list.component.js","sourceRoot":"","sources":["../../../../../../projects/kendo/src/lib/widgets/entity-list/entity-list.component.ts","../../../../../../projects/kendo/src/lib/widgets/entity-list/entity-list.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnChanges, OnInit, Output, SimpleChanges, ViewChild } from '@angular/core'\nimport { ActivatedRoute, Params, Router } from '@angular/router'\nimport { TranslateService } from '@ngx-translate/core'\nimport { DataStateChangeEvent, RowClassArgs } from '@progress/kendo-angular-grid'\nimport { CompositeFilterDescriptor, FilterDescriptor, SortDescriptor, State } from '@progress/kendo-data-query'\nimport { Observable } from 'rxjs'\nimport { map } from 'rxjs/operators'\nimport { IdentifiedModel } from '../../angular/models/IdentifiedModel'\nimport { NamedModel } from '../../angular/models/NamedModel'\nimport { Page } from '../../models/Page'\nimport { IEntityService } from '../../services/IEntityService'\nimport { ConfirmDialogComponent } from '../confirm-dialog/confirm-dialog.component'\nimport { Command } from './Command'\nimport { Field } from './Field'\nimport { urlDeserialize, urlSerialize } from './UrlSerializer'\n\nconst nameField = 'name';\n\n@Component({\n  selector: 'entity-list',\n  templateUrl: './entity-list.component.html',\n  styleUrls: ['./entity-list.component.css'],\n})\nexport class EntityListComponent implements OnInit, OnChanges {\n  @Input()\n  public service: IEntityService<NamedModel>;\n  @Input()\n  public filters: Array<FilterDescriptor | CompositeFilterDescriptor>;\n  @Input()\n  public fields?: Field[];\n  @Input()\n  public commands?: Command[];\n  @Input()\n  public rowClass?: (dataItem: NamedModel, index: number) => {};\n  @Input()\n  public defaultSort?: SortDescriptor[];\n  @Output()\n  public filterChange = new EventEmitter<CompositeFilterDescriptor>();\n  @ViewChild('confirmDialog', { static: true })\n  public dialog: ConfirmDialogComponent;\n  public gridState: State = {};\n  public page: Page<NamedModel>;\n  public loadings = 0;\n  public searchTerm: string;\n  public selected: string[] = [];\n  public gridFields: Field[] = [];\n  private defaultFields: Field[] = [\n    { name: 'name', label: 'Name', sortable: true, position: 0 },\n  ];\n\n  constructor(\n    private translate: TranslateService,\n    private route: ActivatedRoute,\n    private router: Router\n  ) {\n    this.getAllData = this.getAllData.bind(this);\n    this.getRowClass = this.getRowClass.bind(this);\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (!changes.filters || changes.filters.firstChange) {\n      return;\n    }\n\n    this.getFilteredData();\n  }\n\n  ngOnInit() {\n    this.gridFields = (this.fields || [])\n      .concat(this.defaultFields)\n      .sort((left, right) => (left.position || 0) - (right.position || 0));\n    this.filters = this.filters ? this.filters : [];\n    this.commands = this.commands ? this.commands : [];\n    this.route.fragment.subscribe(async (fragment: string) => {\n      await this.restoreGridState(new URLSearchParams(fragment));\n    });\n\n    this.route.firstChild.params.subscribe((params: Params) => {\n      if (params.id) {\n        this.selected[0] = params.id;\n      } else {\n        this.selected.pop();\n      }\n    });\n  }\n\n  public removeHandler({ dataItem }) {\n    this.dialog.open(\n      this.translate.instant('Confirmation.Delete') +\n        ': \"' +\n        dataItem.name +\n        '\"?',\n      () => this.remove(dataItem)\n    );\n  }\n\n  public selectItem({ dataItem }) {\n    this.router.navigate([dataItem.id], {\n      relativeTo: this.route,\n      fragment: urlSerialize(this.gridState),\n    });\n  }\n\n  public onActivate(child: { saved: EventEmitter<NamedModel> }) {\n    if (child.saved) {\n      child.saved.subscribe((data: { id: string; name: string }) =>\n        this.updateGrid(data)\n      );\n    }\n  }\n\n  public onDeactivate(child: { saved: EventEmitter<NamedModel> }) {\n    if (child.saved) {\n      child.saved.unsubscribe();\n    }\n  }\n\n  public dataStateChange(state: DataStateChangeEvent) {\n    Object.keys(state).forEach((key) => {\n      this.gridState[key] = isNaN(state.skip)\n        ? this.gridState[key]\n        : state[key];\n    });\n\n    this.router.navigate([], {\n      relativeTo: this.route,\n      fragment: urlSerialize(this.gridState),\n    });\n  }\n\n  public onSearch(value: string) {\n    this.searchTerm = value;\n    this.gridState.skip = 0;\n    this.getFilteredData();\n  }\n\n  public getAllData(): Observable<Page<NamedModel>> {\n    const state = Object.assign({}, this.gridState);\n    delete state.skip;\n    delete state.take;\n\n    return this.service.getPage(state);\n  }\n\n  public getRowClass(context: RowClassArgs): Object {\n    return this.rowClass && context\n      ? this.rowClass(context.dataItem, context.index)\n      : {};\n  }\n\n  protected getFilteredData() {\n    this.gridState.filter = this.getFilter();\n    this.router.navigate([], {\n      relativeTo: this.route,\n      fragment: urlSerialize(this.gridState),\n    });\n  }\n\n  protected updateGrid(data: NamedModel) {\n    const exists = this.page.data.filter((x) => x.id === data.id);\n    if (exists.length) {\n      this.page.data[this.page.data.indexOf(exists[0])] = data;\n\n      return;\n    }\n\n    this.page.total++;\n    this.page.data.splice(0, 0, data);\n    if (this.page.data.length > this.gridState.take) {\n      this.page.data.splice(this.page.data.length - 1, 1);\n    }\n\n    this.selected[0] = data.id;\n    this.router.navigate([data.id], {\n      relativeTo: this.route,\n      preserveFragment: true,\n    });\n  }\n\n  protected getData() {\n    this.loadings++;\n    this.service.getPage(this.gridState).subscribe((page) => {\n      this.page = page;\n      this.loadings--;\n    });\n  }\n\n  private remove(entity: IdentifiedModel) {\n    this.loadings++;\n    this.service\n      .delete(entity.id)\n      .pipe(\n        map(() => {\n          if (\n            this.selected.length &&\n            this.selected[this.selected.length - 1] === entity.id\n          ) {\n            this.router.navigate(['../'], {\n              preserveFragment: true,\n              relativeTo: this.route.firstChild,\n            });\n          }\n          this.loadings--;\n        })\n      )\n      .subscribe(() => {\n        this.getData();\n      });\n  }\n\n  private getFilter(): CompositeFilterDescriptor {\n    const filter: CompositeFilterDescriptor = {\n      logic: 'and',\n      filters: this.searchTerm\n        ? [\n            { field: nameField, operator: 'contains', value: this.searchTerm },\n            ...this.filters,\n          ]\n        : this.filters,\n    };\n\n    return filter;\n  }\n\n  private onFilterChange() {\n    const filter: any = this.gridState.filter?.filters.find(\n      (x: FilterDescriptor) => x.field === nameField\n    );\n    this.searchTerm = filter?.value;\n    this.filterChange.emit(this.gridState.filter);\n  }\n\n  private async restoreGridState(params: URLSearchParams) {\n    const defaultGridState: State = {\n      sort: this.defaultSort || [{ field: nameField, dir: 'asc' }],\n      skip: 0,\n      take: 10,\n    };\n\n    const state = urlDeserialize(params);\n    this.gridState = state.hasOwnProperty('take') ? state : defaultGridState;\n    this.onFilterChange();\n    this.getData();\n  }\n}\n","<div class=\"row\">\n  <div class=\"col-md-4\">\n    <header class=\"header-page-bg\"></header>\n    <div class=\"panel search-panel hero-unit\">\n      <div class=\"header-selection-field\">\n        <label for=\"searchinput\" class=\"title-field\" translate=\"Search\"></label>\n        <input\n          kendoTextBox\n          class=\"quick-filter input input-field\"\n          title=\"\"\n          id=\"searchinput\"\n          type=\"text\"\n          appDebounce\n          (debounceKeyup)=\"onSearch($event.target.value)\"\n          [ngModel]=\"searchTerm\"\n          [debounceTime]=\"600\"\n        />\n      </div>\n      <ng-content></ng-content>\n      <div class=\"divide-line\"></div>\n\n      <kendo-grid\n        [data]=\"page\"\n        [pageSize]=\"gridState.take\"\n        [skip]=\"gridState.skip\"\n        [sort]=\"gridState.sort\"\n        [pageable]=\"true\"\n        [sortable]=\"true\"\n        [style.maxHeight.px]=\"480\"\n        (remove)=\"removeHandler($event)\"\n        (dataStateChange)=\"dataStateChange($event)\"\n        [loading]=\"loadings > 0\"\n        (cellClick)=\"selectItem($event)\"\n        culture\n        class=\"rows-pointable\"\n        kendoGridSelectBy=\"id\"\n        [selectedKeys]=\"selected\"\n        [rowClass]=\"getRowClass\"\n      >\n        <ng-template kendoGridToolbarTemplate>\n          <excel-export-button></excel-export-button>\n        </ng-template>\n        <kendo-grid-excel [fetchData]=\"getAllData\"></kendo-grid-excel>\n        <kendo-grid-command-column width=\"65\">\n          <ng-template kendoGridCellTemplate>\n            <button\n              kendoGridRemoveCommand\n              requirePermission\n              permissionType=\"Delete\"\n            >\n              <i class=\"k-icon glyphicon glyphicon-trash\"></i>\n            </button>\n          </ng-template>\n        </kendo-grid-command-column>\n        <kendo-grid-column\n          *ngFor=\"let field of gridFields\"\n          field=\"{{ field.name }}\"\n          title=\"{{ field.label | translate }}\"\n          [sortable]=\"field.sortable !== false\"\n        >\n        </kendo-grid-column>\n        <kendo-grid-command-column width=\"65\" *ngIf=\"commands.length > 0\">\n          <ng-template kendoGridCellTemplate let-dataItem>\n            <button\n              *ngFor=\"let command of commands\"\n              (click)=\"command.handler(dataItem)\"\n              title=\"{{ command.title | translate }}\"\n              class=\"k-button\"\n            >\n              <i *ngIf=\"command.iconClass\" class=\"{{ command.iconClass }}\"></i>\n              {{ command.name | translate }}\n            </button>\n          </ng-template>\n        </kendo-grid-command-column>\n        <ng-template kendoGridNoRecordsTemplate>\n          {{ 'Messages.NoRecords' | translate }}\n        </ng-template>\n        <ng-template kendoPagerTemplate>\n          <kendo-grid-spacer></kendo-grid-spacer>\n          <kendo-pager-prev-buttons></kendo-pager-prev-buttons>\n          <kendo-pager-numeric-buttons\n            [buttonCount]=\"10\"\n          ></kendo-pager-numeric-buttons>\n          <kendo-pager-next-buttons></kendo-pager-next-buttons>\n          <kendo-pager-info></kendo-pager-info>\n        </ng-template>\n      </kendo-grid>\n    </div>\n  </div>\n  <router-outlet\n    (activate)=\"onActivate($event)\"\n    (deactivate)=\"onDeactivate($event)\"\n  ></router-outlet>\n</div>\n<confirm-dialog #confirmDialog></confirm-dialog>\n"]}
@@ -10,13 +10,13 @@ export class FieldDropdownlistComponent {
10
10
  }
11
11
  async ngOnInit() {
12
12
  this.defaultItem = { id: null, name: this.translate.instant(All) };
13
- await this.getData();
14
- this.translate.onLangChange.subscribe((event) => {
13
+ this.getData();
14
+ this.translate.onLangChange.subscribe((_event) => {
15
15
  this.defaultItem = { id: null, name: this.translate.instant(All) };
16
16
  });
17
17
  }
18
18
  getData() {
19
- this.service.getPage({}).subscribe((data) => {
19
+ this.service.getPage({ sort: this.sort }).subscribe((data) => {
20
20
  this.data = data.data;
21
21
  if (this.initialSelectedId) {
22
22
  const selectedItem = this.data.find((x) => x.id === this.initialSelectedId);
@@ -34,7 +34,7 @@ export class FieldDropdownlistComponent {
34
34
  }
35
35
  }
36
36
  FieldDropdownlistComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.1", ngImport: i0, type: FieldDropdownlistComponent, deps: [{ token: i1.TranslateService }], target: i0.ɵɵFactoryTarget.Component });
37
- FieldDropdownlistComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.1", type: FieldDropdownlistComponent, selector: "field-dropdownlist", inputs: { service: "service", label: "label" }, outputs: { valueChange: "valueChange" }, viewQueries: [{ propertyName: "kendoDropDown", first: true, predicate: ["inputElement"], descendants: true }], ngImport: i0, template: "<div class=\"header-selection-field\">\n <label\n for=\"{{ '_' + label }}\"\n class=\"title-field\"\n translate=\"{{ label }}\"\n ></label>\n <kendo-dropdownlist\n [data]=\"data\"\n textField=\"name\"\n valueField=\"id\"\n id=\"{{ '_' + label }}\"\n (valueChange)=\"onValueChange($event)\"\n [defaultItem]=\"defaultItem\"\n #inputElement\n >\n </kendo-dropdownlist>\n</div>\n", styles: [""], components: [{ type: i2.DropDownListComponent, selector: "kendo-dropdownlist", inputs: ["listHeight", "disabled", "readonly", "filterable", "ignoreCase", "delay", "tabindex", "id", "data", "value", "popupSettings", "itemDisabled", "virtual", "valuePrimitive", "tabIndex", "size", "rounded", "fillMode", "iconClass", "loading", "textField", "valueField", "defaultItem"], outputs: ["valueChange", "filterChange", "selectionChange", "open", "opened", "close", "closed", "focus", "blur"], exportAs: ["kendoDropDownList"] }], directives: [{ type: i1.TranslateDirective, selector: "[translate],[ngx-translate]", inputs: ["translate", "translateParams"] }] });
37
+ FieldDropdownlistComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.1", type: FieldDropdownlistComponent, selector: "field-dropdownlist", inputs: { service: "service", label: "label", sort: "sort" }, outputs: { valueChange: "valueChange" }, viewQueries: [{ propertyName: "kendoDropDown", first: true, predicate: ["inputElement"], descendants: true }], ngImport: i0, template: "<div class=\"header-selection-field\">\n <label\n for=\"{{ '_' + label }}\"\n class=\"title-field\"\n translate=\"{{ label }}\"\n ></label>\n <kendo-dropdownlist\n [data]=\"data\"\n textField=\"name\"\n valueField=\"id\"\n id=\"{{ '_' + label }}\"\n (valueChange)=\"onValueChange($event)\"\n [defaultItem]=\"defaultItem\"\n #inputElement\n >\n </kendo-dropdownlist>\n</div>\n", styles: [""], components: [{ type: i2.DropDownListComponent, selector: "kendo-dropdownlist", inputs: ["listHeight", "disabled", "readonly", "filterable", "ignoreCase", "delay", "tabindex", "id", "data", "value", "popupSettings", "itemDisabled", "virtual", "valuePrimitive", "tabIndex", "size", "rounded", "fillMode", "iconClass", "loading", "textField", "valueField", "defaultItem"], outputs: ["valueChange", "filterChange", "selectionChange", "open", "opened", "close", "closed", "focus", "blur"], exportAs: ["kendoDropDownList"] }], directives: [{ type: i1.TranslateDirective, selector: "[translate],[ngx-translate]", inputs: ["translate", "translateParams"] }] });
38
38
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.1", ngImport: i0, type: FieldDropdownlistComponent, decorators: [{
39
39
  type: Component,
40
40
  args: [{ selector: 'field-dropdownlist', template: "<div class=\"header-selection-field\">\n <label\n for=\"{{ '_' + label }}\"\n class=\"title-field\"\n translate=\"{{ label }}\"\n ></label>\n <kendo-dropdownlist\n [data]=\"data\"\n textField=\"name\"\n valueField=\"id\"\n id=\"{{ '_' + label }}\"\n (valueChange)=\"onValueChange($event)\"\n [defaultItem]=\"defaultItem\"\n #inputElement\n >\n </kendo-dropdownlist>\n</div>\n", styles: [""] }]
@@ -42,10 +42,12 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.1", ngImpor
42
42
  type: Input
43
43
  }], label: [{
44
44
  type: Input
45
+ }], sort: [{
46
+ type: Input
45
47
  }], valueChange: [{
46
48
  type: Output
47
49
  }], kendoDropDown: [{
48
50
  type: ViewChild,
49
51
  args: ['inputElement']
50
52
  }] } });
51
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmllbGQtZHJvcGRvd25saXN0LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2tlbmRvL3NyYy9saWIvd2lkZ2V0cy9lbnRpdHktbGlzdC9maWVsZC1kcm9wZG93bmxpc3QvZmllbGQtZHJvcGRvd25saXN0LmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2tlbmRvL3NyYy9saWIvd2lkZ2V0cy9lbnRpdHktbGlzdC9maWVsZC1kcm9wZG93bmxpc3QvZmllbGQtZHJvcGRvd25saXN0LmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFDTCxTQUFTLEVBQ1QsS0FBSyxFQUNMLE1BQU0sRUFFTixZQUFZLEVBQ1osU0FBUyxHQUNWLE1BQU0sZUFBZSxDQUFDOzs7O0FBTXZCLE1BQU0sR0FBRyxHQUFHLEtBQUssQ0FBQztBQU9sQixNQUFNLE9BQU8sMEJBQTBCO0lBY3JDLFlBQW9CLFNBQTJCO1FBQTNCLGNBQVMsR0FBVCxTQUFTLENBQWtCO1FBUi9DLGdCQUFXLEdBQUcsSUFBSSxZQUFZLEVBQWMsQ0FBQztJQVFLLENBQUM7SUFFbkQsS0FBSyxDQUFDLFFBQVE7UUFDWixJQUFJLENBQUMsV0FBVyxHQUFHLEVBQUUsRUFBRSxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsSUFBSSxDQUFDLFNBQVMsQ0FBQyxPQUFPLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQztRQUNuRSxNQUFNLElBQUksQ0FBQyxPQUFPLEVBQUUsQ0FBQztRQUNyQixJQUFJLENBQUMsU0FBUyxDQUFDLFlBQVksQ0FBQyxTQUFTLENBQUMsQ0FBQyxLQUFzQixFQUFFLEVBQUU7WUFDL0QsSUFBSSxDQUFDLFdBQVcsR0FBRyxFQUFFLEVBQUUsRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLElBQUksQ0FBQyxTQUFTLENBQUMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUM7UUFDckUsQ0FBQyxDQUFDLENBQUM7SUFDTCxDQUFDO0lBRU8sT0FBTztRQUNiLElBQUksQ0FBQyxPQUFPLENBQUMsT0FBTyxDQUFDLEVBQUUsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxDQUFDLElBQUksRUFBRSxFQUFFO1lBQzFDLElBQUksQ0FBQyxJQUFJLEdBQUcsSUFBSSxDQUFDLElBQUksQ0FBQztZQUN0QixJQUFJLElBQUksQ0FBQyxpQkFBaUIsRUFBRTtnQkFDMUIsTUFBTSxZQUFZLEdBQUcsSUFBSSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQ2pDLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDLENBQUMsRUFBRSxLQUFLLElBQUksQ0FBQyxpQkFBaUIsQ0FDdkMsQ0FBQztnQkFFRixJQUFJLFlBQVksRUFBRTtvQkFDaEIsSUFBSSxDQUFDLGFBQWEsQ0FBQyxVQUFVLENBQUMsWUFBWSxDQUFDLENBQUM7aUJBQzdDO2FBQ0Y7UUFDSCxDQUFDLENBQUMsQ0FBQztJQUNMLENBQUM7SUFFRCxhQUFhLENBQUMsS0FBaUI7UUFDN0IsSUFBSSxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDL0IsQ0FBQztJQUVNLGNBQWMsQ0FBQyxFQUFVO1FBQzlCLElBQUksQ0FBQyxpQkFBaUIsR0FBRyxFQUFFLENBQUM7SUFDOUIsQ0FBQzs7dUhBN0NVLDBCQUEwQjsyR0FBMUIsMEJBQTBCLGtRQ3BCdkMsNFpBaUJBOzJGREdhLDBCQUEwQjtrQkFMdEMsU0FBUzsrQkFDRSxvQkFBb0I7dUdBTTlCLE9BQU87c0JBRE4sS0FBSztnQkFHTixLQUFLO3NCQURKLEtBQUs7Z0JBR04sV0FBVztzQkFEVixNQUFNO2dCQUdDLGFBQWE7c0JBRHBCLFNBQVM7dUJBQUMsY0FBYyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIENvbXBvbmVudCxcbiAgSW5wdXQsXG4gIE91dHB1dCxcbiAgT25Jbml0LFxuICBFdmVudEVtaXR0ZXIsXG4gIFZpZXdDaGlsZCxcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBEcm9wRG93bkxpc3RDb21wb25lbnQgfSBmcm9tICdAcHJvZ3Jlc3Mva2VuZG8tYW5ndWxhci1kcm9wZG93bnMnO1xuaW1wb3J0IHsgSUVudGl0eVNlcnZpY2UgfSBmcm9tICcuLi8uLi8uLi9zZXJ2aWNlcy9JRW50aXR5U2VydmljZSc7XG5pbXBvcnQgeyBMYW5nQ2hhbmdlRXZlbnQsIFRyYW5zbGF0ZVNlcnZpY2UgfSBmcm9tICdAbmd4LXRyYW5zbGF0ZS9jb3JlJztcbmltcG9ydCB7IE5hbWVkTW9kZWwgfSBmcm9tICcuLi8uLi8uLi9hbmd1bGFyL21vZGVscy9OYW1lZE1vZGVsJztcblxuY29uc3QgQWxsID0gJ0FsbCc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2ZpZWxkLWRyb3Bkb3dubGlzdCcsXG4gIHRlbXBsYXRlVXJsOiAnLi9maWVsZC1kcm9wZG93bmxpc3QuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9maWVsZC1kcm9wZG93bmxpc3QuY29tcG9uZW50LmNzcyddLFxufSlcbmV4cG9ydCBjbGFzcyBGaWVsZERyb3Bkb3dubGlzdENvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XG4gIEBJbnB1dCgpXG4gIHNlcnZpY2U6IElFbnRpdHlTZXJ2aWNlPE5hbWVkTW9kZWw+O1xuICBASW5wdXQoKVxuICBsYWJlbDogc3RyaW5nO1xuICBAT3V0cHV0KClcbiAgdmFsdWVDaGFuZ2UgPSBuZXcgRXZlbnRFbWl0dGVyPE5hbWVkTW9kZWw+KCk7XG4gIEBWaWV3Q2hpbGQoJ2lucHV0RWxlbWVudCcpXG4gIHByaXZhdGUga2VuZG9Ecm9wRG93bjogRHJvcERvd25MaXN0Q29tcG9uZW50O1xuICBwcml2YXRlIGluaXRpYWxTZWxlY3RlZElkOiBzdHJpbmc7XG5cbiAgcHVibGljIGRlZmF1bHRJdGVtOiBOYW1lZE1vZGVsO1xuICBwdWJsaWMgZGF0YTogTmFtZWRNb2RlbFtdO1xuXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgdHJhbnNsYXRlOiBUcmFuc2xhdGVTZXJ2aWNlKSB7fVxuXG4gIGFzeW5jIG5nT25Jbml0KCk6IFByb21pc2U8dm9pZD4ge1xuICAgIHRoaXMuZGVmYXVsdEl0ZW0gPSB7IGlkOiBudWxsLCBuYW1lOiB0aGlzLnRyYW5zbGF0ZS5pbnN0YW50KEFsbCkgfTtcbiAgICBhd2FpdCB0aGlzLmdldERhdGEoKTtcbiAgICB0aGlzLnRyYW5zbGF0ZS5vbkxhbmdDaGFuZ2Uuc3Vic2NyaWJlKChldmVudDogTGFuZ0NoYW5nZUV2ZW50KSA9PiB7XG4gICAgICB0aGlzLmRlZmF1bHRJdGVtID0geyBpZDogbnVsbCwgbmFtZTogdGhpcy50cmFuc2xhdGUuaW5zdGFudChBbGwpIH07XG4gICAgfSk7XG4gIH1cblxuICBwcml2YXRlIGdldERhdGEoKSB7XG4gICAgdGhpcy5zZXJ2aWNlLmdldFBhZ2Uoe30pLnN1YnNjcmliZSgoZGF0YSkgPT4ge1xuICAgICAgdGhpcy5kYXRhID0gZGF0YS5kYXRhO1xuICAgICAgaWYgKHRoaXMuaW5pdGlhbFNlbGVjdGVkSWQpIHtcbiAgICAgICAgY29uc3Qgc2VsZWN0ZWRJdGVtID0gdGhpcy5kYXRhLmZpbmQoXG4gICAgICAgICAgKHgpID0+IHguaWQgPT09IHRoaXMuaW5pdGlhbFNlbGVjdGVkSWRcbiAgICAgICAgKTtcblxuICAgICAgICBpZiAoc2VsZWN0ZWRJdGVtKSB7XG4gICAgICAgICAgdGhpcy5rZW5kb0Ryb3BEb3duLndyaXRlVmFsdWUoc2VsZWN0ZWRJdGVtKTtcbiAgICAgICAgfVxuICAgICAgfVxuICAgIH0pO1xuICB9XG5cbiAgb25WYWx1ZUNoYW5nZShldmVudDogTmFtZWRNb2RlbCkge1xuICAgIHRoaXMudmFsdWVDaGFuZ2UuZW1pdChldmVudCk7XG4gIH1cblxuICBwdWJsaWMgaW5pdFNlbGVjdGVkSWQoaWQ6IHN0cmluZyk6IHZvaWQge1xuICAgIHRoaXMuaW5pdGlhbFNlbGVjdGVkSWQgPSBpZDtcbiAgfVxufVxuIiwiPGRpdiBjbGFzcz1cImhlYWRlci1zZWxlY3Rpb24tZmllbGRcIj5cbiAgPGxhYmVsXG4gICAgZm9yPVwie3sgJ18nICsgbGFiZWwgfX1cIlxuICAgIGNsYXNzPVwidGl0bGUtZmllbGRcIlxuICAgIHRyYW5zbGF0ZT1cInt7IGxhYmVsIH19XCJcbiAgPjwvbGFiZWw+XG4gIDxrZW5kby1kcm9wZG93bmxpc3RcbiAgICBbZGF0YV09XCJkYXRhXCJcbiAgICB0ZXh0RmllbGQ9XCJuYW1lXCJcbiAgICB2YWx1ZUZpZWxkPVwiaWRcIlxuICAgIGlkPVwie3sgJ18nICsgbGFiZWwgfX1cIlxuICAgICh2YWx1ZUNoYW5nZSk9XCJvblZhbHVlQ2hhbmdlKCRldmVudClcIlxuICAgIFtkZWZhdWx0SXRlbV09XCJkZWZhdWx0SXRlbVwiXG4gICAgI2lucHV0RWxlbWVudFxuICA+XG4gIDwva2VuZG8tZHJvcGRvd25saXN0PlxuPC9kaXY+XG4iXX0=
53
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmllbGQtZHJvcGRvd25saXN0LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2tlbmRvL3NyYy9saWIvd2lkZ2V0cy9lbnRpdHktbGlzdC9maWVsZC1kcm9wZG93bmxpc3QvZmllbGQtZHJvcGRvd25saXN0LmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2tlbmRvL3NyYy9saWIvd2lkZ2V0cy9lbnRpdHktbGlzdC9maWVsZC1kcm9wZG93bmxpc3QvZmllbGQtZHJvcGRvd25saXN0LmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFDTCxTQUFTLEVBQ1QsS0FBSyxFQUNMLE1BQU0sRUFFTixZQUFZLEVBQ1osU0FBUyxHQUNWLE1BQU0sZUFBZSxDQUFDOzs7O0FBT3ZCLE1BQU0sR0FBRyxHQUFHLEtBQUssQ0FBQztBQU9sQixNQUFNLE9BQU8sMEJBQTBCO0lBZ0JyQyxZQUFvQixTQUEyQjtRQUEzQixjQUFTLEdBQVQsU0FBUyxDQUFrQjtRQVIvQyxnQkFBVyxHQUFHLElBQUksWUFBWSxFQUFjLENBQUM7SUFRSyxDQUFDO0lBRW5ELEtBQUssQ0FBQyxRQUFRO1FBQ1osSUFBSSxDQUFDLFdBQVcsR0FBRyxFQUFFLEVBQUUsRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLElBQUksQ0FBQyxTQUFTLENBQUMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUM7UUFDbkUsSUFBSSxDQUFDLE9BQU8sRUFBRSxDQUFDO1FBQ2YsSUFBSSxDQUFDLFNBQVMsQ0FBQyxZQUFZLENBQUMsU0FBUyxDQUFDLENBQUMsTUFBdUIsRUFBRSxFQUFFO1lBQ2hFLElBQUksQ0FBQyxXQUFXLEdBQUcsRUFBRSxFQUFFLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxJQUFJLENBQUMsU0FBUyxDQUFDLE9BQU8sQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDO1FBQ3JFLENBQUMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztJQUVPLE9BQU87UUFDYixJQUFJLENBQUMsT0FBTyxDQUFDLE9BQU8sQ0FBQyxFQUFFLElBQUksRUFBRSxJQUFJLENBQUMsSUFBSSxFQUFFLENBQUMsQ0FBQyxTQUFTLENBQUMsQ0FBQyxJQUFJLEVBQUUsRUFBRTtZQUMzRCxJQUFJLENBQUMsSUFBSSxHQUFHLElBQUksQ0FBQyxJQUFJLENBQUM7WUFDdEIsSUFBSSxJQUFJLENBQUMsaUJBQWlCLEVBQUU7Z0JBQzFCLE1BQU0sWUFBWSxHQUFHLElBQUksQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUNqQyxDQUFDLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQyxDQUFDLEVBQUUsS0FBSyxJQUFJLENBQUMsaUJBQWlCLENBQ3ZDLENBQUM7Z0JBRUYsSUFBSSxZQUFZLEVBQUU7b0JBQ2hCLElBQUksQ0FBQyxhQUFhLENBQUMsVUFBVSxDQUFDLFlBQVksQ0FBQyxDQUFDO2lCQUM3QzthQUNGO1FBQ0gsQ0FBQyxDQUFDLENBQUM7SUFDTCxDQUFDO0lBRUQsYUFBYSxDQUFDLEtBQWlCO1FBQzdCLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQy9CLENBQUM7SUFFTSxjQUFjLENBQUMsRUFBVTtRQUM5QixJQUFJLENBQUMsaUJBQWlCLEdBQUcsRUFBRSxDQUFDO0lBQzlCLENBQUM7O3VIQS9DVSwwQkFBMEI7MkdBQTFCLDBCQUEwQixnUkNyQnZDLDRaQWlCQTsyRkRJYSwwQkFBMEI7a0JBTHRDLFNBQVM7K0JBQ0Usb0JBQW9CO3VHQU05QixPQUFPO3NCQUROLEtBQUs7Z0JBR04sS0FBSztzQkFESixLQUFLO2dCQUdOLElBQUk7c0JBREgsS0FBSztnQkFHTixXQUFXO3NCQURWLE1BQU07Z0JBR0MsYUFBYTtzQkFEcEIsU0FBUzt1QkFBQyxjQUFjIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgQ29tcG9uZW50LFxuICBJbnB1dCxcbiAgT3V0cHV0LFxuICBPbkluaXQsXG4gIEV2ZW50RW1pdHRlcixcbiAgVmlld0NoaWxkLFxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IERyb3BEb3duTGlzdENvbXBvbmVudCB9IGZyb20gJ0Bwcm9ncmVzcy9rZW5kby1hbmd1bGFyLWRyb3Bkb3ducyc7XG5pbXBvcnQgeyBJRW50aXR5U2VydmljZSB9IGZyb20gJy4uLy4uLy4uL3NlcnZpY2VzL0lFbnRpdHlTZXJ2aWNlJztcbmltcG9ydCB7IExhbmdDaGFuZ2VFdmVudCwgVHJhbnNsYXRlU2VydmljZSB9IGZyb20gJ0BuZ3gtdHJhbnNsYXRlL2NvcmUnO1xuaW1wb3J0IHsgTmFtZWRNb2RlbCB9IGZyb20gJy4uLy4uLy4uL2FuZ3VsYXIvbW9kZWxzL05hbWVkTW9kZWwnO1xuaW1wb3J0IHsgU29ydERlc2NyaXB0b3IgfSBmcm9tICdAcHJvZ3Jlc3Mva2VuZG8tZGF0YS1xdWVyeSc7XG5cbmNvbnN0IEFsbCA9ICdBbGwnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdmaWVsZC1kcm9wZG93bmxpc3QnLFxuICB0ZW1wbGF0ZVVybDogJy4vZmllbGQtZHJvcGRvd25saXN0LmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vZmllbGQtZHJvcGRvd25saXN0LmNvbXBvbmVudC5jc3MnXSxcbn0pXG5leHBvcnQgY2xhc3MgRmllbGREcm9wZG93bmxpc3RDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xuICBASW5wdXQoKVxuICBzZXJ2aWNlOiBJRW50aXR5U2VydmljZTxOYW1lZE1vZGVsPjtcbiAgQElucHV0KClcbiAgbGFiZWw6IHN0cmluZztcbiAgQElucHV0KClcbiAgc29ydD86IFNvcnREZXNjcmlwdG9yW107XG4gIEBPdXRwdXQoKVxuICB2YWx1ZUNoYW5nZSA9IG5ldyBFdmVudEVtaXR0ZXI8TmFtZWRNb2RlbD4oKTtcbiAgQFZpZXdDaGlsZCgnaW5wdXRFbGVtZW50JylcbiAgcHJpdmF0ZSBrZW5kb0Ryb3BEb3duOiBEcm9wRG93bkxpc3RDb21wb25lbnQ7XG4gIHByaXZhdGUgaW5pdGlhbFNlbGVjdGVkSWQ6IHN0cmluZztcblxuICBwdWJsaWMgZGVmYXVsdEl0ZW06IE5hbWVkTW9kZWw7XG4gIHB1YmxpYyBkYXRhOiBOYW1lZE1vZGVsW107XG5cbiAgY29uc3RydWN0b3IocHJpdmF0ZSB0cmFuc2xhdGU6IFRyYW5zbGF0ZVNlcnZpY2UpIHt9XG5cbiAgYXN5bmMgbmdPbkluaXQoKTogUHJvbWlzZTx2b2lkPiB7XG4gICAgdGhpcy5kZWZhdWx0SXRlbSA9IHsgaWQ6IG51bGwsIG5hbWU6IHRoaXMudHJhbnNsYXRlLmluc3RhbnQoQWxsKSB9O1xuICAgIHRoaXMuZ2V0RGF0YSgpO1xuICAgIHRoaXMudHJhbnNsYXRlLm9uTGFuZ0NoYW5nZS5zdWJzY3JpYmUoKF9ldmVudDogTGFuZ0NoYW5nZUV2ZW50KSA9PiB7XG4gICAgICB0aGlzLmRlZmF1bHRJdGVtID0geyBpZDogbnVsbCwgbmFtZTogdGhpcy50cmFuc2xhdGUuaW5zdGFudChBbGwpIH07XG4gICAgfSk7XG4gIH1cblxuICBwcml2YXRlIGdldERhdGEoKSB7XG4gICAgdGhpcy5zZXJ2aWNlLmdldFBhZ2UoeyBzb3J0OiB0aGlzLnNvcnQgfSkuc3Vic2NyaWJlKChkYXRhKSA9PiB7XG4gICAgICB0aGlzLmRhdGEgPSBkYXRhLmRhdGE7XG4gICAgICBpZiAodGhpcy5pbml0aWFsU2VsZWN0ZWRJZCkge1xuICAgICAgICBjb25zdCBzZWxlY3RlZEl0ZW0gPSB0aGlzLmRhdGEuZmluZChcbiAgICAgICAgICAoeCkgPT4geC5pZCA9PT0gdGhpcy5pbml0aWFsU2VsZWN0ZWRJZFxuICAgICAgICApO1xuXG4gICAgICAgIGlmIChzZWxlY3RlZEl0ZW0pIHtcbiAgICAgICAgICB0aGlzLmtlbmRvRHJvcERvd24ud3JpdGVWYWx1ZShzZWxlY3RlZEl0ZW0pO1xuICAgICAgICB9XG4gICAgICB9XG4gICAgfSk7XG4gIH1cblxuICBvblZhbHVlQ2hhbmdlKGV2ZW50OiBOYW1lZE1vZGVsKSB7XG4gICAgdGhpcy52YWx1ZUNoYW5nZS5lbWl0KGV2ZW50KTtcbiAgfVxuXG4gIHB1YmxpYyBpbml0U2VsZWN0ZWRJZChpZDogc3RyaW5nKTogdm9pZCB7XG4gICAgdGhpcy5pbml0aWFsU2VsZWN0ZWRJZCA9IGlkO1xuICB9XG59XG4iLCI8ZGl2IGNsYXNzPVwiaGVhZGVyLXNlbGVjdGlvbi1maWVsZFwiPlxuICA8bGFiZWxcbiAgICBmb3I9XCJ7eyAnXycgKyBsYWJlbCB9fVwiXG4gICAgY2xhc3M9XCJ0aXRsZS1maWVsZFwiXG4gICAgdHJhbnNsYXRlPVwie3sgbGFiZWwgfX1cIlxuICA+PC9sYWJlbD5cbiAgPGtlbmRvLWRyb3Bkb3dubGlzdFxuICAgIFtkYXRhXT1cImRhdGFcIlxuICAgIHRleHRGaWVsZD1cIm5hbWVcIlxuICAgIHZhbHVlRmllbGQ9XCJpZFwiXG4gICAgaWQ9XCJ7eyAnXycgKyBsYWJlbCB9fVwiXG4gICAgKHZhbHVlQ2hhbmdlKT1cIm9uVmFsdWVDaGFuZ2UoJGV2ZW50KVwiXG4gICAgW2RlZmF1bHRJdGVtXT1cImRlZmF1bHRJdGVtXCJcbiAgICAjaW5wdXRFbGVtZW50XG4gID5cbiAgPC9rZW5kby1kcm9wZG93bmxpc3Q+XG48L2Rpdj5cbiJdfQ==
@@ -174,28 +174,35 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.1", ngImpor
174
174
  type: Input
175
175
  }] } });
176
176
 
177
- const emptyString = '';
177
+ const defaultValue = null;
178
178
  class NumberInputComponent extends FieldInputComponent {
179
179
  constructor(parent, eref) {
180
180
  super(parent, eref);
181
181
  this.parent = parent;
182
182
  this.eref = eref;
183
183
  this.isPositive = false;
184
- this.type = 'number';
184
+ this.type = 'text';
185
185
  }
186
186
  ngAfterContentInit() {
187
187
  const control = this.parent.form.get(this.fieldName);
188
+ control.setValue(this.presetDefaultValue(control.value));
188
189
  control.valueChanges.subscribe((value) => {
189
- if (value !== this.cachedValue) {
190
+ value = this.presetDefaultValue(value);
191
+ if (value !== this.cachedValue &&
192
+ value !== defaultValue &&
193
+ !value.endsWith('.')) {
190
194
  this.cachedValue =
191
195
  (!this.isPositive && (value || value === 0)) ||
192
- (this.isPositive && value >= 0 && value !== emptyString)
196
+ (this.isPositive && value >= 0)
193
197
  ? +value
194
- : emptyString;
198
+ : defaultValue;
195
199
  control.setValue(this.cachedValue);
196
200
  }
197
201
  });
198
202
  }
203
+ presetDefaultValue(value) {
204
+ return value == '' ? defaultValue : value;
205
+ }
199
206
  }
200
207
  NumberInputComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.1", ngImport: i0, type: NumberInputComponent, deps: [{ token: i1$3.FormGroupDirective }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
201
208
  NumberInputComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.1", type: NumberInputComponent, selector: "number-input", inputs: { isPositive: "isPositive" }, usesInheritance: true, ngImport: i0, template: "<div class=\"form-group\">\n <label\n for=\"{{ id }}\"\n class=\"col-md-3 control-label\"\n translate=\"{{ labelKey }}\"\n ></label>\n <div class=\"col-md-9\">\n <input\n [formControlName]=\"fieldName\"\n id=\"{{ id }}\"\n [type]=\"type\"\n class=\"k-input\"\n autocomplete=\"new-{{ fieldName }}\"\n placeholder=\"{{ labelKey | translate }}\"\n [attr.disabled]=\"disabled ? disabledKey : null\"\n />\n <ng-content></ng-content>\n <div\n class=\"bg-danger\"\n *ngIf=\"\n parent.form.get(fieldName) &&\n parent.form.get(fieldName).invalid &&\n parent.form.get(fieldName).touched\n \"\n >\n <span *ngIf=\"parent.form.get(fieldName).errors['required']\">{{\n 'Required' | translate: { param0: labelKey | translate }\n }}</span>\n <span *ngIf=\"parent.form.get(fieldName).errors['email']\">{{\n 'ValidEmail' | translate\n }}</span>\n <span *ngIf=\"parent.form.get(fieldName).errors['serverErrorMsg']\">{{\n parent.form.get(fieldName).errors['serverErrorMsg']\n }}</span>\n </div>\n </div>\n</div>\n", directives: [{ type: i1.TranslateDirective, selector: "[translate],[ngx-translate]", inputs: ["translate", "translateParams"] }, { type: i1$3.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i1$3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i1$3.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { type: i3$1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], pipes: { "translate": i1.TranslatePipe }, viewProviders: [
@@ -1888,23 +1895,21 @@ class EntityListComponent {
1888
1895
  this.getFilteredData();
1889
1896
  }
1890
1897
  ngOnInit() {
1891
- return __awaiter(this, void 0, void 0, function* () {
1892
- this.gridFields = (this.fields || [])
1893
- .concat(this.defaultFields)
1894
- .sort((left, right) => (left.position || 0) - (right.position || 0));
1895
- this.filters = this.filters ? this.filters : [];
1896
- this.commands = this.commands ? this.commands : [];
1897
- this.route.fragment.subscribe((fragment) => __awaiter(this, void 0, void 0, function* () {
1898
- yield this.restoreGridState(new URLSearchParams(fragment));
1899
- }));
1900
- this.route.firstChild.params.subscribe((params) => __awaiter(this, void 0, void 0, function* () {
1901
- if (params.id) {
1902
- this.selected[0] = params.id;
1903
- }
1904
- else {
1905
- this.selected.pop();
1906
- }
1907
- }));
1898
+ this.gridFields = (this.fields || [])
1899
+ .concat(this.defaultFields)
1900
+ .sort((left, right) => (left.position || 0) - (right.position || 0));
1901
+ this.filters = this.filters ? this.filters : [];
1902
+ this.commands = this.commands ? this.commands : [];
1903
+ this.route.fragment.subscribe((fragment) => __awaiter(this, void 0, void 0, function* () {
1904
+ yield this.restoreGridState(new URLSearchParams(fragment));
1905
+ }));
1906
+ this.route.firstChild.params.subscribe((params) => {
1907
+ if (params.id) {
1908
+ this.selected[0] = params.id;
1909
+ }
1910
+ else {
1911
+ this.selected.pop();
1912
+ }
1908
1913
  });
1909
1914
  }
1910
1915
  removeHandler({ dataItem }) {
@@ -1988,18 +1993,20 @@ class EntityListComponent {
1988
1993
  });
1989
1994
  }
1990
1995
  remove(entity) {
1991
- return __awaiter(this, void 0, void 0, function* () {
1992
- this.loadings++;
1993
- this.service.delete(entity.id).subscribe(() => {
1994
- if (this.selected.length &&
1995
- this.selected[this.selected.length - 1] === entity.id) {
1996
- this.router.navigate(['../'], {
1997
- preserveFragment: true,
1998
- relativeTo: this.route.firstChild,
1999
- });
2000
- }
2001
- this.loadings--;
2002
- });
1996
+ this.loadings++;
1997
+ this.service
1998
+ .delete(entity.id)
1999
+ .pipe(map(() => {
2000
+ if (this.selected.length &&
2001
+ this.selected[this.selected.length - 1] === entity.id) {
2002
+ this.router.navigate(['../'], {
2003
+ preserveFragment: true,
2004
+ relativeTo: this.route.firstChild,
2005
+ });
2006
+ }
2007
+ this.loadings--;
2008
+ }))
2009
+ .subscribe(() => {
2003
2010
  this.getData();
2004
2011
  });
2005
2012
  }
@@ -2414,14 +2421,14 @@ class FieldDropdownlistComponent {
2414
2421
  ngOnInit() {
2415
2422
  return __awaiter(this, void 0, void 0, function* () {
2416
2423
  this.defaultItem = { id: null, name: this.translate.instant(All) };
2417
- yield this.getData();
2418
- this.translate.onLangChange.subscribe((event) => {
2424
+ this.getData();
2425
+ this.translate.onLangChange.subscribe((_event) => {
2419
2426
  this.defaultItem = { id: null, name: this.translate.instant(All) };
2420
2427
  });
2421
2428
  });
2422
2429
  }
2423
2430
  getData() {
2424
- this.service.getPage({}).subscribe((data) => {
2431
+ this.service.getPage({ sort: this.sort }).subscribe((data) => {
2425
2432
  this.data = data.data;
2426
2433
  if (this.initialSelectedId) {
2427
2434
  const selectedItem = this.data.find((x) => x.id === this.initialSelectedId);
@@ -2439,7 +2446,7 @@ class FieldDropdownlistComponent {
2439
2446
  }
2440
2447
  }
2441
2448
  FieldDropdownlistComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.1", ngImport: i0, type: FieldDropdownlistComponent, deps: [{ token: i1.TranslateService }], target: i0.ɵɵFactoryTarget.Component });
2442
- FieldDropdownlistComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.1", type: FieldDropdownlistComponent, selector: "field-dropdownlist", inputs: { service: "service", label: "label" }, outputs: { valueChange: "valueChange" }, viewQueries: [{ propertyName: "kendoDropDown", first: true, predicate: ["inputElement"], descendants: true }], ngImport: i0, template: "<div class=\"header-selection-field\">\n <label\n for=\"{{ '_' + label }}\"\n class=\"title-field\"\n translate=\"{{ label }}\"\n ></label>\n <kendo-dropdownlist\n [data]=\"data\"\n textField=\"name\"\n valueField=\"id\"\n id=\"{{ '_' + label }}\"\n (valueChange)=\"onValueChange($event)\"\n [defaultItem]=\"defaultItem\"\n #inputElement\n >\n </kendo-dropdownlist>\n</div>\n", styles: [""], components: [{ type: i3$4.DropDownListComponent, selector: "kendo-dropdownlist", inputs: ["listHeight", "disabled", "readonly", "filterable", "ignoreCase", "delay", "tabindex", "id", "data", "value", "popupSettings", "itemDisabled", "virtual", "valuePrimitive", "tabIndex", "size", "rounded", "fillMode", "iconClass", "loading", "textField", "valueField", "defaultItem"], outputs: ["valueChange", "filterChange", "selectionChange", "open", "opened", "close", "closed", "focus", "blur"], exportAs: ["kendoDropDownList"] }], directives: [{ type: i1.TranslateDirective, selector: "[translate],[ngx-translate]", inputs: ["translate", "translateParams"] }] });
2449
+ FieldDropdownlistComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.1", type: FieldDropdownlistComponent, selector: "field-dropdownlist", inputs: { service: "service", label: "label", sort: "sort" }, outputs: { valueChange: "valueChange" }, viewQueries: [{ propertyName: "kendoDropDown", first: true, predicate: ["inputElement"], descendants: true }], ngImport: i0, template: "<div class=\"header-selection-field\">\n <label\n for=\"{{ '_' + label }}\"\n class=\"title-field\"\n translate=\"{{ label }}\"\n ></label>\n <kendo-dropdownlist\n [data]=\"data\"\n textField=\"name\"\n valueField=\"id\"\n id=\"{{ '_' + label }}\"\n (valueChange)=\"onValueChange($event)\"\n [defaultItem]=\"defaultItem\"\n #inputElement\n >\n </kendo-dropdownlist>\n</div>\n", styles: [""], components: [{ type: i3$4.DropDownListComponent, selector: "kendo-dropdownlist", inputs: ["listHeight", "disabled", "readonly", "filterable", "ignoreCase", "delay", "tabindex", "id", "data", "value", "popupSettings", "itemDisabled", "virtual", "valuePrimitive", "tabIndex", "size", "rounded", "fillMode", "iconClass", "loading", "textField", "valueField", "defaultItem"], outputs: ["valueChange", "filterChange", "selectionChange", "open", "opened", "close", "closed", "focus", "blur"], exportAs: ["kendoDropDownList"] }], directives: [{ type: i1.TranslateDirective, selector: "[translate],[ngx-translate]", inputs: ["translate", "translateParams"] }] });
2443
2450
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.1", ngImport: i0, type: FieldDropdownlistComponent, decorators: [{
2444
2451
  type: Component,
2445
2452
  args: [{ selector: 'field-dropdownlist', template: "<div class=\"header-selection-field\">\n <label\n for=\"{{ '_' + label }}\"\n class=\"title-field\"\n translate=\"{{ label }}\"\n ></label>\n <kendo-dropdownlist\n [data]=\"data\"\n textField=\"name\"\n valueField=\"id\"\n id=\"{{ '_' + label }}\"\n (valueChange)=\"onValueChange($event)\"\n [defaultItem]=\"defaultItem\"\n #inputElement\n >\n </kendo-dropdownlist>\n</div>\n", styles: [""] }]
@@ -2447,6 +2454,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.1", ngImpor
2447
2454
  type: Input
2448
2455
  }], label: [{
2449
2456
  type: Input
2457
+ }], sort: [{
2458
+ type: Input
2450
2459
  }], valueChange: [{
2451
2460
  type: Output
2452
2461
  }], kendoDropDown: [{