@indigina/kendo 1.1.3 → 1.1.4
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/esm2020/lib/widgets/entity-list/entity-list.component.mjs +8 -8
- package/fesm2015/indigina-kendo.mjs +7 -7
- package/fesm2015/indigina-kendo.mjs.map +1 -1
- package/fesm2020/indigina-kendo.mjs +7 -7
- package/fesm2020/indigina-kendo.mjs.map +1 -1
- package/lib/widgets/entity-list/entity-list.component.d.ts +2 -2
- package/package.json +1 -1
|
@@ -125,6 +125,13 @@ export class EntityListComponent {
|
|
|
125
125
|
preserveFragment: true,
|
|
126
126
|
});
|
|
127
127
|
}
|
|
128
|
+
getData() {
|
|
129
|
+
this.loadings++;
|
|
130
|
+
this.service.getPage(this.gridState).subscribe((page) => {
|
|
131
|
+
this.page = page;
|
|
132
|
+
this.loadings--;
|
|
133
|
+
});
|
|
134
|
+
}
|
|
128
135
|
async remove(entity) {
|
|
129
136
|
this.loadings++;
|
|
130
137
|
this.service.delete(entity.id).subscribe(() => {
|
|
@@ -139,13 +146,6 @@ export class EntityListComponent {
|
|
|
139
146
|
});
|
|
140
147
|
this.getData();
|
|
141
148
|
}
|
|
142
|
-
getData() {
|
|
143
|
-
this.loadings++;
|
|
144
|
-
this.service.getPage(this.gridState).subscribe((page) => {
|
|
145
|
-
this.page = page;
|
|
146
|
-
this.loadings--;
|
|
147
|
-
});
|
|
148
|
-
}
|
|
149
149
|
getFilter() {
|
|
150
150
|
const filter = {
|
|
151
151
|
logic: 'and',
|
|
@@ -198,4 +198,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.1", ngImpor
|
|
|
198
198
|
type: ViewChild,
|
|
199
199
|
args: ['confirmDialog', { static: true }]
|
|
200
200
|
}] } });
|
|
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  private 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  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  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 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"]}
|
|
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"]}
|
|
@@ -2270,6 +2270,13 @@ class EntityListComponent {
|
|
|
2270
2270
|
preserveFragment: true,
|
|
2271
2271
|
});
|
|
2272
2272
|
}
|
|
2273
|
+
getData() {
|
|
2274
|
+
this.loadings++;
|
|
2275
|
+
this.service.getPage(this.gridState).subscribe((page) => {
|
|
2276
|
+
this.page = page;
|
|
2277
|
+
this.loadings--;
|
|
2278
|
+
});
|
|
2279
|
+
}
|
|
2273
2280
|
remove(entity) {
|
|
2274
2281
|
return __awaiter(this, void 0, void 0, function* () {
|
|
2275
2282
|
this.loadings++;
|
|
@@ -2286,13 +2293,6 @@ class EntityListComponent {
|
|
|
2286
2293
|
this.getData();
|
|
2287
2294
|
});
|
|
2288
2295
|
}
|
|
2289
|
-
getData() {
|
|
2290
|
-
this.loadings++;
|
|
2291
|
-
this.service.getPage(this.gridState).subscribe((page) => {
|
|
2292
|
-
this.page = page;
|
|
2293
|
-
this.loadings--;
|
|
2294
|
-
});
|
|
2295
|
-
}
|
|
2296
2296
|
getFilter() {
|
|
2297
2297
|
const filter = {
|
|
2298
2298
|
logic: 'and',
|