@den4ik92/ng2-smart-table 2.1.2 → 3.0.1

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.
Files changed (57) hide show
  1. package/esm2022/lib/components/cell/cell-edit-mode/custom-edit.component.mjs +5 -5
  2. package/esm2022/lib/components/cell/cell-edit-mode/default-edit.component.mjs +10 -11
  3. package/esm2022/lib/components/cell/cell-edit-mode/edit-cell-default.mjs +3 -3
  4. package/esm2022/lib/components/cell/cell-edit-mode/edit-cell.component.mjs +42 -31
  5. package/esm2022/lib/components/cell/cell-editors/checkbox-editor.component.mjs +4 -4
  6. package/esm2022/lib/components/cell/cell-editors/default-editor.mjs +3 -3
  7. package/esm2022/lib/components/cell/cell-editors/input-editor.component.mjs +4 -4
  8. package/esm2022/lib/components/cell/cell-editors/select-editor.component.mjs +30 -26
  9. package/esm2022/lib/components/cell/cell-editors/textarea-editor.component.mjs +4 -4
  10. package/esm2022/lib/components/cell/cell-view-mode/custom-view.component.mjs +9 -45
  11. package/esm2022/lib/components/cell/cell-view-mode/view-cell.component.mjs +30 -15
  12. package/esm2022/lib/components/cell/cell.component.mjs +26 -19
  13. package/esm2022/lib/components/cell/cell.module.mjs +4 -4
  14. package/esm2022/lib/components/filter/custom-filter.component.mjs +5 -5
  15. package/esm2022/lib/components/filter/default-filter.component.mjs +58 -46
  16. package/esm2022/lib/components/filter/filter-default.mjs +3 -3
  17. package/esm2022/lib/components/filter/filter-types/checkbox-filter.component.mjs +15 -11
  18. package/esm2022/lib/components/filter/filter-types/default-filter.mjs +4 -4
  19. package/esm2022/lib/components/filter/filter-types/input-filter.component.mjs +5 -5
  20. package/esm2022/lib/components/filter/filter-types/select-filter.component.mjs +23 -19
  21. package/esm2022/lib/components/filter/filter.component.mjs +56 -41
  22. package/esm2022/lib/components/filter/filter.module.mjs +4 -4
  23. package/esm2022/lib/components/pager/pager.component.mjs +128 -108
  24. package/esm2022/lib/components/pager/pager.module.mjs +4 -4
  25. package/esm2022/lib/components/tbody/cells/create-cancel.component.mjs +24 -27
  26. package/esm2022/lib/components/tbody/cells/custom.component.mjs +24 -23
  27. package/esm2022/lib/components/tbody/cells/edit-delete.component.mjs +168 -163
  28. package/esm2022/lib/components/tbody/tbody.component.mjs +5 -5
  29. package/esm2022/lib/components/tbody/tbody.module.mjs +4 -4
  30. package/esm2022/lib/components/thead/cells/actions-title.component.mjs +5 -5
  31. package/esm2022/lib/components/thead/cells/actions.component.mjs +3 -3
  32. package/esm2022/lib/components/thead/cells/add-button.component.mjs +15 -12
  33. package/esm2022/lib/components/thead/cells/checkbox-select-all.component.mjs +3 -3
  34. package/esm2022/lib/components/thead/cells/column-title.component.mjs +3 -3
  35. package/esm2022/lib/components/thead/cells/title/title.component.mjs +28 -20
  36. package/esm2022/lib/components/thead/rows/thead-filters-row.component.mjs +58 -43
  37. package/esm2022/lib/components/thead/rows/thead-form-row.component.mjs +75 -50
  38. package/esm2022/lib/components/thead/rows/thead-titles-row.component.mjs +42 -26
  39. package/esm2022/lib/components/thead/thead.component.mjs +8 -9
  40. package/esm2022/lib/components/thead/thead.module.mjs +4 -4
  41. package/esm2022/lib/lib/data-set/cell.mjs +1 -1
  42. package/esm2022/lib/lib/data-set/column.mjs +1 -1
  43. package/esm2022/lib/lib/data-set/data-set.mjs +1 -1
  44. package/esm2022/lib/lib/data-source/local/local.data-source.mjs +1 -1
  45. package/esm2022/lib/lib/data-source/local/local.sorter.mjs +1 -1
  46. package/esm2022/lib/lib/grid.mjs +1 -1
  47. package/esm2022/lib/lib/helpers.mjs +1 -1
  48. package/esm2022/lib/ng2-smart-table.component.mjs +7 -7
  49. package/esm2022/lib/ng2-smart-table.module.mjs +4 -4
  50. package/esm2022/public-api.mjs +3 -2
  51. package/fesm2022/den4ik92-ng2-smart-table.mjs +2449 -2314
  52. package/fesm2022/den4ik92-ng2-smart-table.mjs.map +1 -1
  53. package/lib/components/cell/cell-view-mode/custom-view.component.d.ts +2 -13
  54. package/lib/components/thead/rows/thead-form-row.component.d.ts +4 -4
  55. package/lib/ng2-smart-table.component.d.ts +2 -2
  56. package/package.json +4 -4
  57. package/public-api.d.ts +3 -2
@@ -1,9 +1,8 @@
1
1
  import { Component } from '@angular/core';
2
2
  import { FilterDefault } from './filter-default';
3
3
  import * as i0 from "@angular/core";
4
- import * as i1 from "@angular/common";
5
- import * as i2 from "./default-filter.component";
6
- import * as i3 from "./custom-filter.component";
4
+ import * as i1 from "./default-filter.component";
5
+ import * as i2 from "./custom-filter.component";
7
6
  export class FilterComponent extends FilterDefault {
8
7
  ngOnChanges(changes) {
9
8
  if (changes['source']) {
@@ -27,45 +26,61 @@ export class FilterComponent extends FilterDefault {
27
26
  });
28
27
  }
29
28
  }
30
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: FilterComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
31
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: FilterComponent, selector: "ng2-smart-table-filter", usesInheritance: true, usesOnChanges: true, ngImport: i0, template: `
32
- <div class="ng2-smart-filter" *ngIf="column.isFilterable" [ngSwitch]="column.getFilterType()">
33
- <custom-table-filter *ngSwitchCase="'custom'"
34
- [query]="query"
35
- [column]="column"
36
- [source]="source"
37
- [inputClass]="inputClass"
38
- (filter)="onFilter($event)">
39
- </custom-table-filter>
40
- <default-table-filter *ngSwitchDefault
41
- [query]="query"
42
- [column]="column"
43
- [source]="source"
44
- [inputClass]="inputClass"
45
- (filter)="onFilter($event)">
46
- </default-table-filter>
47
- </div>
48
- `, isInline: true, styles: [":host .ng2-smart-filter ::ng-deep input,:host .ng2-smart-filter ::ng-deep select{width:100%;line-height:normal;padding:.375em .75em;font-weight:400}:host .ng2-smart-filter ::ng-deep input[type=search]{box-sizing:inherit}:host .ng2-smart-filter ::ng-deep .completer-dropdown-holder{font-weight:400}:host .ng2-smart-filter ::ng-deep a{font-weight:400}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i1.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "directive", type: i1.NgSwitchDefault, selector: "[ngSwitchDefault]" }, { kind: "component", type: i2.DefaultFilterComponent, selector: "default-table-filter" }, { kind: "component", type: i3.CustomFilterComponent, selector: "custom-table-filter" }] }); }
29
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FilterComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
30
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: FilterComponent, selector: "ng2-smart-table-filter", usesInheritance: true, usesOnChanges: true, ngImport: i0, template: `
31
+ @if (column.isFilterable) {
32
+ <div class="ng2-smart-filter">
33
+ @switch (column.getFilterType()) {
34
+ @case ('custom') {
35
+ <custom-table-filter
36
+ [query]="query"
37
+ [column]="column"
38
+ [source]="source"
39
+ [inputClass]="inputClass"
40
+ (filter)="onFilter($event)">
41
+ </custom-table-filter>
42
+ }
43
+ @default {
44
+ <default-table-filter
45
+ [query]="query"
46
+ [column]="column"
47
+ [source]="source"
48
+ [inputClass]="inputClass"
49
+ (filter)="onFilter($event)">
50
+ </default-table-filter>
51
+ }
52
+ }
53
+ </div>
54
+ }
55
+ `, isInline: true, styles: [":host .ng2-smart-filter ::ng-deep input,:host .ng2-smart-filter ::ng-deep select{width:100%;line-height:normal;padding:.375em .75em;font-weight:400}:host .ng2-smart-filter ::ng-deep input[type=search]{box-sizing:inherit}:host .ng2-smart-filter ::ng-deep .completer-dropdown-holder{font-weight:400}:host .ng2-smart-filter ::ng-deep a{font-weight:400}\n"], dependencies: [{ kind: "component", type: i1.DefaultFilterComponent, selector: "default-table-filter" }, { kind: "component", type: i2.CustomFilterComponent, selector: "custom-table-filter" }] }); }
49
56
  }
50
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: FilterComponent, decorators: [{
57
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FilterComponent, decorators: [{
51
58
  type: Component,
52
59
  args: [{ selector: 'ng2-smart-table-filter', template: `
53
- <div class="ng2-smart-filter" *ngIf="column.isFilterable" [ngSwitch]="column.getFilterType()">
54
- <custom-table-filter *ngSwitchCase="'custom'"
55
- [query]="query"
56
- [column]="column"
57
- [source]="source"
58
- [inputClass]="inputClass"
59
- (filter)="onFilter($event)">
60
- </custom-table-filter>
61
- <default-table-filter *ngSwitchDefault
62
- [query]="query"
63
- [column]="column"
64
- [source]="source"
65
- [inputClass]="inputClass"
66
- (filter)="onFilter($event)">
67
- </default-table-filter>
68
- </div>
69
- `, styles: [":host .ng2-smart-filter ::ng-deep input,:host .ng2-smart-filter ::ng-deep select{width:100%;line-height:normal;padding:.375em .75em;font-weight:400}:host .ng2-smart-filter ::ng-deep input[type=search]{box-sizing:inherit}:host .ng2-smart-filter ::ng-deep .completer-dropdown-holder{font-weight:400}:host .ng2-smart-filter ::ng-deep a{font-weight:400}\n"] }]
60
+ @if (column.isFilterable) {
61
+ <div class="ng2-smart-filter">
62
+ @switch (column.getFilterType()) {
63
+ @case ('custom') {
64
+ <custom-table-filter
65
+ [query]="query"
66
+ [column]="column"
67
+ [source]="source"
68
+ [inputClass]="inputClass"
69
+ (filter)="onFilter($event)">
70
+ </custom-table-filter>
71
+ }
72
+ @default {
73
+ <default-table-filter
74
+ [query]="query"
75
+ [column]="column"
76
+ [source]="source"
77
+ [inputClass]="inputClass"
78
+ (filter)="onFilter($event)">
79
+ </default-table-filter>
80
+ }
81
+ }
82
+ </div>
83
+ }
84
+ `, styles: [":host .ng2-smart-filter ::ng-deep input,:host .ng2-smart-filter ::ng-deep select{width:100%;line-height:normal;padding:.375em .75em;font-weight:400}:host .ng2-smart-filter ::ng-deep input[type=search]{box-sizing:inherit}:host .ng2-smart-filter ::ng-deep .completer-dropdown-holder{font-weight:400}:host .ng2-smart-filter ::ng-deep a{font-weight:400}\n"] }]
70
85
  }] });
71
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsdGVyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25nMi1zbWFydC10YWJsZS9zcmMvbGliL2NvbXBvbmVudHMvZmlsdGVyL2ZpbHRlci5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBNEIsTUFBTSxlQUFlLENBQUM7QUFDcEUsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLGtCQUFrQixDQUFDOzs7OztBQXlCakQsTUFBTSxPQUFPLGVBQWdCLFNBQVEsYUFBYTtJQUdoRCxXQUFXLENBQUMsT0FBc0I7UUFDaEMsSUFBSSxPQUFPLENBQUMsUUFBUSxDQUFDLEVBQUU7WUFDckIsSUFBSSxDQUFDLE9BQU8sQ0FBQyxRQUFRLENBQUMsQ0FBQyxXQUFXLElBQUksSUFBSSxDQUFDLGNBQWMsRUFBRTtnQkFDekQsSUFBSSxDQUFDLGNBQWMsQ0FBQyxXQUFXLEVBQUUsQ0FBQzthQUNuQztZQUNELElBQUksQ0FBQyxjQUFjLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQyxTQUFTLEVBQUUsQ0FBQyxTQUFTLENBQUMsQ0FBQyxXQUFXLEVBQUUsRUFBRTtnQkFDdEUsTUFBTSxVQUFVLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQyxTQUFTLEVBQUUsQ0FBQztnQkFDM0MsSUFBSSxVQUFVLElBQUksVUFBVSxDQUFDLE9BQU8sSUFBSSxVQUFVLENBQUMsT0FBTyxDQUFDLE1BQU0sS0FBSyxDQUFDLEVBQUU7b0JBQ3ZFLElBQUksQ0FBQyxLQUFLLEdBQUcsRUFBRSxDQUFDO29CQUVoQixrRkFBa0Y7b0JBQ2xGLHNHQUFzRztpQkFDdkc7cUJBQU0sSUFBSSxVQUFVLElBQUksVUFBVSxDQUFDLE9BQU8sSUFBSSxVQUFVLENBQUMsT0FBTyxDQUFDLE1BQU0sR0FBRyxDQUFDLEVBQUU7b0JBQzVFLFVBQVUsQ0FBQyxPQUFPLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBTSxFQUFFLENBQU0sRUFBRSxFQUFFO3dCQUM1QyxJQUFJLENBQUMsQ0FBQyxLQUFLLElBQUksSUFBSSxDQUFDLE1BQU0sQ0FBQyxFQUFFLEVBQUU7NEJBQzdCLElBQUksQ0FBQyxLQUFLLEdBQUcsQ0FBQyxDQUFDLE1BQU0sQ0FBQzt5QkFDdkI7b0JBQ0gsQ0FBQyxDQUFDLENBQUM7aUJBQ0o7WUFDSCxDQUFDLENBQUMsQ0FBQztTQUNKO0lBQ0gsQ0FBQzsrR0F4QlUsZUFBZTttR0FBZixlQUFlLDBHQW5CaEI7Ozs7Ozs7Ozs7Ozs7Ozs7O0tBaUJQOzs0RkFFUSxlQUFlO2tCQXRCM0IsU0FBUzsrQkFDRSx3QkFBd0IsWUFFeEI7Ozs7Ozs7Ozs7Ozs7Ozs7O0tBaUJQIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBPbkNoYW5nZXMsIFNpbXBsZUNoYW5nZXMgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEZpbHRlckRlZmF1bHQgfSBmcm9tICcuL2ZpbHRlci1kZWZhdWx0JztcbmltcG9ydCB7IFN1YnNjcmlwdGlvbiB9IGZyb20gJ3J4anMnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICduZzItc21hcnQtdGFibGUtZmlsdGVyJyxcbiAgc3R5bGVVcmxzOiBbJy4vZmlsdGVyLmNvbXBvbmVudC5zY3NzJ10sXG4gIHRlbXBsYXRlOiBgXG4gICAgICA8ZGl2IGNsYXNzPVwibmcyLXNtYXJ0LWZpbHRlclwiICpuZ0lmPVwiY29sdW1uLmlzRmlsdGVyYWJsZVwiIFtuZ1N3aXRjaF09XCJjb2x1bW4uZ2V0RmlsdGVyVHlwZSgpXCI+XG4gICAgICAgIDxjdXN0b20tdGFibGUtZmlsdGVyICpuZ1N3aXRjaENhc2U9XCInY3VzdG9tJ1wiXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgIFtxdWVyeV09XCJxdWVyeVwiXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgIFtjb2x1bW5dPVwiY29sdW1uXCJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgW3NvdXJjZV09XCJzb3VyY2VcIlxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICBbaW5wdXRDbGFzc109XCJpbnB1dENsYXNzXCJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKGZpbHRlcik9XCJvbkZpbHRlcigkZXZlbnQpXCI+XG4gICAgICAgIDwvY3VzdG9tLXRhYmxlLWZpbHRlcj5cbiAgICAgICAgPGRlZmF1bHQtdGFibGUtZmlsdGVyICpuZ1N3aXRjaERlZmF1bHRcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFtxdWVyeV09XCJxdWVyeVwiXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICBbY29sdW1uXT1cImNvbHVtblwiXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICBbc291cmNlXT1cInNvdXJjZVwiXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICBbaW5wdXRDbGFzc109XCJpbnB1dENsYXNzXCJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIChmaWx0ZXIpPVwib25GaWx0ZXIoJGV2ZW50KVwiPlxuICAgICAgICA8L2RlZmF1bHQtdGFibGUtZmlsdGVyPlxuICAgICAgPC9kaXY+XG4gICAgYCxcbn0pXG5leHBvcnQgY2xhc3MgRmlsdGVyQ29tcG9uZW50IGV4dGVuZHMgRmlsdGVyRGVmYXVsdCBpbXBsZW1lbnRzIE9uQ2hhbmdlcyB7XG4gIHByb3RlY3RlZCBkYXRhQ2hhbmdlZFN1Yj86IFN1YnNjcmlwdGlvbjtcblxuICBuZ09uQ2hhbmdlcyhjaGFuZ2VzOiBTaW1wbGVDaGFuZ2VzKSB7XG4gICAgaWYgKGNoYW5nZXNbJ3NvdXJjZSddKSB7XG4gICAgICBpZiAoIWNoYW5nZXNbJ3NvdXJjZSddLmZpcnN0Q2hhbmdlICYmIHRoaXMuZGF0YUNoYW5nZWRTdWIpIHtcbiAgICAgICAgdGhpcy5kYXRhQ2hhbmdlZFN1Yi51bnN1YnNjcmliZSgpO1xuICAgICAgfVxuICAgICAgdGhpcy5kYXRhQ2hhbmdlZFN1YiA9IHRoaXMuc291cmNlLm9uQ2hhbmdlZCgpLnN1YnNjcmliZSgoZGF0YUNoYW5nZXMpID0+IHtcbiAgICAgICAgY29uc3QgZmlsdGVyQ29uZiA9IHRoaXMuc291cmNlLmdldEZpbHRlcigpO1xuICAgICAgICBpZiAoZmlsdGVyQ29uZiAmJiBmaWx0ZXJDb25mLmZpbHRlcnMgJiYgZmlsdGVyQ29uZi5maWx0ZXJzLmxlbmd0aCA9PT0gMCkge1xuICAgICAgICAgIHRoaXMucXVlcnkgPSAnJztcblxuICAgICAgICAgIC8vIGFkZCBhIGNoZWNrIGZvciBleGlzdGluZyBmaWx0ZXJzIGFuIHNldCB0aGUgcXVlcnkgaWYgb25lIGV4aXN0cyBmb3IgdGhpcyBjb2x1bW5cbiAgICAgICAgICAvLyB0aGlzIGNvdmVycyBpbnN0YW5jZXMgd2hlcmUgdGhlIGZpbHRlciBpcyBzZXQgYnkgdXNlciBjb2RlIHdoaWxlIG1haW50YWluaW5nIGV4aXN0aW5nIGZ1bmN0aW9uYWxpdHlcbiAgICAgICAgfSBlbHNlIGlmIChmaWx0ZXJDb25mICYmIGZpbHRlckNvbmYuZmlsdGVycyAmJiBmaWx0ZXJDb25mLmZpbHRlcnMubGVuZ3RoID4gMCkge1xuICAgICAgICAgIGZpbHRlckNvbmYuZmlsdGVycy5mb3JFYWNoKChrOiBhbnksIHY6IGFueSkgPT4ge1xuICAgICAgICAgICAgaWYgKGsuZmllbGQgPT0gdGhpcy5jb2x1bW4uaWQpIHtcbiAgICAgICAgICAgICAgdGhpcy5xdWVyeSA9IGsuc2VhcmNoO1xuICAgICAgICAgICAgfVxuICAgICAgICAgIH0pO1xuICAgICAgICB9XG4gICAgICB9KTtcbiAgICB9XG4gIH1cbn1cbiJdfQ==
86
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsdGVyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25nMi1zbWFydC10YWJsZS9zcmMvbGliL2NvbXBvbmVudHMvZmlsdGVyL2ZpbHRlci5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBNEIsTUFBTSxlQUFlLENBQUM7QUFDcEUsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLGtCQUFrQixDQUFDOzs7O0FBaUNqRCxNQUFNLE9BQU8sZUFBZ0IsU0FBUSxhQUFhO0lBR2hELFdBQVcsQ0FBQyxPQUFzQjtRQUNoQyxJQUFJLE9BQU8sQ0FBQyxRQUFRLENBQUMsRUFBRSxDQUFDO1lBQ3RCLElBQUksQ0FBQyxPQUFPLENBQUMsUUFBUSxDQUFDLENBQUMsV0FBVyxJQUFJLElBQUksQ0FBQyxjQUFjLEVBQUUsQ0FBQztnQkFDMUQsSUFBSSxDQUFDLGNBQWMsQ0FBQyxXQUFXLEVBQUUsQ0FBQztZQUNwQyxDQUFDO1lBQ0QsSUFBSSxDQUFDLGNBQWMsR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDLFNBQVMsRUFBRSxDQUFDLFNBQVMsQ0FBQyxDQUFDLFdBQVcsRUFBRSxFQUFFO2dCQUN0RSxNQUFNLFVBQVUsR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDLFNBQVMsRUFBRSxDQUFDO2dCQUMzQyxJQUFJLFVBQVUsSUFBSSxVQUFVLENBQUMsT0FBTyxJQUFJLFVBQVUsQ0FBQyxPQUFPLENBQUMsTUFBTSxLQUFLLENBQUMsRUFBRSxDQUFDO29CQUN4RSxJQUFJLENBQUMsS0FBSyxHQUFHLEVBQUUsQ0FBQztvQkFFaEIsa0ZBQWtGO29CQUNsRixzR0FBc0c7Z0JBQ3hHLENBQUM7cUJBQU0sSUFBSSxVQUFVLElBQUksVUFBVSxDQUFDLE9BQU8sSUFBSSxVQUFVLENBQUMsT0FBTyxDQUFDLE1BQU0sR0FBRyxDQUFDLEVBQUUsQ0FBQztvQkFDN0UsVUFBVSxDQUFDLE9BQU8sQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFNLEVBQUUsQ0FBTSxFQUFFLEVBQUU7d0JBQzVDLElBQUksQ0FBQyxDQUFDLEtBQUssSUFBSSxJQUFJLENBQUMsTUFBTSxDQUFDLEVBQUUsRUFBRSxDQUFDOzRCQUM5QixJQUFJLENBQUMsS0FBSyxHQUFHLENBQUMsQ0FBQyxNQUFNLENBQUM7d0JBQ3hCLENBQUM7b0JBQ0gsQ0FBQyxDQUFDLENBQUM7Z0JBQ0wsQ0FBQztZQUNILENBQUMsQ0FBQyxDQUFDO1FBQ0wsQ0FBQztJQUNILENBQUM7K0dBeEJVLGVBQWU7bUdBQWYsZUFBZSwwR0EzQmhCOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O09BeUJMOzs0RkFFTSxlQUFlO2tCQTlCM0IsU0FBUzsrQkFDRSx3QkFBd0IsWUFFeEI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7T0F5QkwiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIE9uQ2hhbmdlcywgU2ltcGxlQ2hhbmdlcyB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRmlsdGVyRGVmYXVsdCB9IGZyb20gJy4vZmlsdGVyLWRlZmF1bHQnO1xuaW1wb3J0IHsgU3Vic2NyaXB0aW9uIH0gZnJvbSAncnhqcyc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ25nMi1zbWFydC10YWJsZS1maWx0ZXInLFxuICBzdHlsZVVybHM6IFsnLi9maWx0ZXIuY29tcG9uZW50LnNjc3MnXSxcbiAgdGVtcGxhdGU6IGBcbiAgICAgIEBpZiAoY29sdW1uLmlzRmlsdGVyYWJsZSkge1xuICAgICAgICA8ZGl2IGNsYXNzPVwibmcyLXNtYXJ0LWZpbHRlclwiPlxuICAgICAgICAgIEBzd2l0Y2ggKGNvbHVtbi5nZXRGaWx0ZXJUeXBlKCkpIHtcbiAgICAgICAgICAgIEBjYXNlICgnY3VzdG9tJykge1xuICAgICAgICAgICAgICA8Y3VzdG9tLXRhYmxlLWZpbHRlclxuICAgICAgICAgICAgICAgIFtxdWVyeV09XCJxdWVyeVwiXG4gICAgICAgICAgICAgICAgW2NvbHVtbl09XCJjb2x1bW5cIlxuICAgICAgICAgICAgICAgIFtzb3VyY2VdPVwic291cmNlXCJcbiAgICAgICAgICAgICAgICBbaW5wdXRDbGFzc109XCJpbnB1dENsYXNzXCJcbiAgICAgICAgICAgICAgICAoZmlsdGVyKT1cIm9uRmlsdGVyKCRldmVudClcIj5cbiAgICAgICAgICAgICAgPC9jdXN0b20tdGFibGUtZmlsdGVyPlxuICAgICAgICAgICAgfVxuICAgICAgICAgICAgQGRlZmF1bHQge1xuICAgICAgICAgICAgICA8ZGVmYXVsdC10YWJsZS1maWx0ZXJcbiAgICAgICAgICAgICAgICBbcXVlcnldPVwicXVlcnlcIlxuICAgICAgICAgICAgICAgIFtjb2x1bW5dPVwiY29sdW1uXCJcbiAgICAgICAgICAgICAgICBbc291cmNlXT1cInNvdXJjZVwiXG4gICAgICAgICAgICAgICAgW2lucHV0Q2xhc3NdPVwiaW5wdXRDbGFzc1wiXG4gICAgICAgICAgICAgICAgKGZpbHRlcik9XCJvbkZpbHRlcigkZXZlbnQpXCI+XG4gICAgICAgICAgICAgIDwvZGVmYXVsdC10YWJsZS1maWx0ZXI+XG4gICAgICAgICAgICB9XG4gICAgICAgICAgfVxuICAgICAgICA8L2Rpdj5cbiAgICAgIH1cbiAgICAgIGAsXG59KVxuZXhwb3J0IGNsYXNzIEZpbHRlckNvbXBvbmVudCBleHRlbmRzIEZpbHRlckRlZmF1bHQgaW1wbGVtZW50cyBPbkNoYW5nZXMge1xuICBwcm90ZWN0ZWQgZGF0YUNoYW5nZWRTdWI/OiBTdWJzY3JpcHRpb247XG5cbiAgbmdPbkNoYW5nZXMoY2hhbmdlczogU2ltcGxlQ2hhbmdlcykge1xuICAgIGlmIChjaGFuZ2VzWydzb3VyY2UnXSkge1xuICAgICAgaWYgKCFjaGFuZ2VzWydzb3VyY2UnXS5maXJzdENoYW5nZSAmJiB0aGlzLmRhdGFDaGFuZ2VkU3ViKSB7XG4gICAgICAgIHRoaXMuZGF0YUNoYW5nZWRTdWIudW5zdWJzY3JpYmUoKTtcbiAgICAgIH1cbiAgICAgIHRoaXMuZGF0YUNoYW5nZWRTdWIgPSB0aGlzLnNvdXJjZS5vbkNoYW5nZWQoKS5zdWJzY3JpYmUoKGRhdGFDaGFuZ2VzKSA9PiB7XG4gICAgICAgIGNvbnN0IGZpbHRlckNvbmYgPSB0aGlzLnNvdXJjZS5nZXRGaWx0ZXIoKTtcbiAgICAgICAgaWYgKGZpbHRlckNvbmYgJiYgZmlsdGVyQ29uZi5maWx0ZXJzICYmIGZpbHRlckNvbmYuZmlsdGVycy5sZW5ndGggPT09IDApIHtcbiAgICAgICAgICB0aGlzLnF1ZXJ5ID0gJyc7XG5cbiAgICAgICAgICAvLyBhZGQgYSBjaGVjayBmb3IgZXhpc3RpbmcgZmlsdGVycyBhbiBzZXQgdGhlIHF1ZXJ5IGlmIG9uZSBleGlzdHMgZm9yIHRoaXMgY29sdW1uXG4gICAgICAgICAgLy8gdGhpcyBjb3ZlcnMgaW5zdGFuY2VzIHdoZXJlIHRoZSBmaWx0ZXIgaXMgc2V0IGJ5IHVzZXIgY29kZSB3aGlsZSBtYWludGFpbmluZyBleGlzdGluZyBmdW5jdGlvbmFsaXR5XG4gICAgICAgIH0gZWxzZSBpZiAoZmlsdGVyQ29uZiAmJiBmaWx0ZXJDb25mLmZpbHRlcnMgJiYgZmlsdGVyQ29uZi5maWx0ZXJzLmxlbmd0aCA+IDApIHtcbiAgICAgICAgICBmaWx0ZXJDb25mLmZpbHRlcnMuZm9yRWFjaCgoazogYW55LCB2OiBhbnkpID0+IHtcbiAgICAgICAgICAgIGlmIChrLmZpZWxkID09IHRoaXMuY29sdW1uLmlkKSB7XG4gICAgICAgICAgICAgIHRoaXMucXVlcnkgPSBrLnNlYXJjaDtcbiAgICAgICAgICAgIH1cbiAgICAgICAgICB9KTtcbiAgICAgICAgfVxuICAgICAgfSk7XG4gICAgfVxuICB9XG59XG4iXX0=
@@ -21,8 +21,8 @@ const FILTER_COMPONENTS = [
21
21
  SelectFilterComponent,
22
22
  ];
23
23
  export class FilterModule {
24
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: FilterModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
25
- static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.2.12", ngImport: i0, type: FilterModule, declarations: [FilterDefault,
24
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FilterModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
25
+ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "17.3.12", ngImport: i0, type: FilterModule, declarations: [FilterDefault,
26
26
  DefaultFilter,
27
27
  FilterComponent,
28
28
  DefaultFilterComponent,
@@ -39,11 +39,11 @@ export class FilterModule {
39
39
  CheckboxFilterComponent,
40
40
  InputFilterComponent,
41
41
  SelectFilterComponent] }); }
42
- static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: FilterModule, imports: [CommonModule,
42
+ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FilterModule, imports: [CommonModule,
43
43
  FormsModule,
44
44
  ReactiveFormsModule] }); }
45
45
  }
46
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: FilterModule, decorators: [{
46
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FilterModule, decorators: [{
47
47
  type: NgModule,
48
48
  args: [{
49
49
  imports: [
@@ -99,118 +99,138 @@ export class PagerComponent {
99
99
  this.source.refresh();
100
100
  this.initPages();
101
101
  }
102
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: PagerComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
103
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: PagerComponent, selector: "ng2-smart-table-pager", inputs: { source: "source", perPageSelect: "perPageSelect" }, outputs: { changePage: "changePage" }, usesOnChanges: true, ngImport: i0, template: `
104
- <nav *ngIf="shouldShow()" class="ng2-smart-pagination-nav">
105
- <ul class="ng2-smart-pagination pagination">
106
- <li class="ng2-smart-page-item page-item" [ngClass]="{disabled: getPage() == 1}">
107
- <a class="ng2-smart-page-link page-link" href="#"
108
- (click)="getPage() == 1 ? false : paginate(1)" aria-label="First">
109
- <span aria-hidden="true">&laquo;</span>
110
- <span class="sr-only">First</span>
111
- </a>
112
- </li>
113
- <li class="ng2-smart-page-item page-item" [ngClass]="{disabled: getPage() == 1}">
114
- <a class="ng2-smart-page-link page-link page-link-prev" href="#"
115
- (click)="getPage() == 1 ? false : prev()" aria-label="Prev">
116
- <span aria-hidden="true">&lt;</span>
117
- <span class="sr-only">Prev</span>
118
- </a>
119
- </li>
120
- <li class="ng2-smart-page-item page-item"
121
- [ngClass]="{active: getPage() == page}" *ngFor="let page of getPages()">
122
- <span class="ng2-smart-page-link page-link"
123
- *ngIf="getPage() == page">{{ page }} <span class="sr-only">(current)</span></span>
124
- <a class="ng2-smart-page-link page-link" href="#"
125
- (click)="paginate(page)" *ngIf="getPage() != page">{{ page }}</a>
126
- </li>
127
-
128
- <li class="ng2-smart-page-item page-item"
129
- [ngClass]="{disabled: getPage() == getLast()}">
130
- <a class="ng2-smart-page-link page-link page-link-next" href="#"
131
- (click)="getPage() == getLast() ? false : next()" aria-label="Next">
132
- <span aria-hidden="true">&gt;</span>
133
- <span class="sr-only">Next</span>
134
- </a>
135
- </li>
136
-
137
- <li class="ng2-smart-page-item page-item"
138
- [ngClass]="{disabled: getPage() == getLast()}">
139
- <a class="ng2-smart-page-link page-link" href="#"
140
- (click)="getPage() == getLast() ? false : paginate(getLast())" aria-label="Last">
141
- <span aria-hidden="true">&raquo;</span>
142
- <span class="sr-only">Last</span>
143
- </a>
144
- </li>
145
- </ul>
146
- </nav>
102
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: PagerComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
103
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: PagerComponent, selector: "ng2-smart-table-pager", inputs: { source: "source", perPageSelect: "perPageSelect" }, outputs: { changePage: "changePage" }, usesOnChanges: true, ngImport: i0, template: `
104
+ @if (shouldShow()) {
105
+ <nav class="ng2-smart-pagination-nav">
106
+ <ul class="ng2-smart-pagination pagination">
107
+ <li class="ng2-smart-page-item page-item" [ngClass]="{disabled: getPage() == 1}">
108
+ <a class="ng2-smart-page-link page-link" href="#"
109
+ (click)="getPage() == 1 ? false : paginate(1)" aria-label="First">
110
+ <span aria-hidden="true">&laquo;</span>
111
+ <span class="sr-only">First</span>
112
+ </a>
113
+ </li>
114
+ <li class="ng2-smart-page-item page-item" [ngClass]="{disabled: getPage() == 1}">
115
+ <a class="ng2-smart-page-link page-link page-link-prev" href="#"
116
+ (click)="getPage() == 1 ? false : prev()" aria-label="Prev">
117
+ <span aria-hidden="true">&lt;</span>
118
+ <span class="sr-only">Prev</span>
119
+ </a>
120
+ </li>
121
+ @for (page of getPages(); track page) {
122
+ <li class="ng2-smart-page-item page-item"
123
+ [ngClass]="{active: getPage() == page}">
124
+ @if (getPage() == page) {
125
+ <span class="ng2-smart-page-link page-link"
126
+ >{{ page }} <span class="sr-only">(current)</span></span>
127
+ }
128
+ @if (getPage() != page) {
129
+ <a class="ng2-smart-page-link page-link" href="#"
130
+ (click)="paginate(page)">{{ page }}</a>
131
+ }
132
+ </li>
133
+ }
134
+ <li class="ng2-smart-page-item page-item"
135
+ [ngClass]="{disabled: getPage() == getLast()}">
136
+ <a class="ng2-smart-page-link page-link page-link-next" href="#"
137
+ (click)="getPage() == getLast() ? false : next()" aria-label="Next">
138
+ <span aria-hidden="true">&gt;</span>
139
+ <span class="sr-only">Next</span>
140
+ </a>
141
+ </li>
142
+ <li class="ng2-smart-page-item page-item"
143
+ [ngClass]="{disabled: getPage() == getLast()}">
144
+ <a class="ng2-smart-page-link page-link" href="#"
145
+ (click)="getPage() == getLast() ? false : paginate(getLast())" aria-label="Last">
146
+ <span aria-hidden="true">&raquo;</span>
147
+ <span class="sr-only">Last</span>
148
+ </a>
149
+ </li>
150
+ </ul>
151
+ </nav>
152
+ }
147
153
 
148
- <nav *ngIf="perPageSelect && perPageSelect.length > 0" class="ng2-smart-pagination-per-page">
149
- <label for="per-page">
150
- Per Page:
151
- </label>
152
- <select (change)="onChangePerPage()" [(ngModel)]="currentPerPage" id="per-page">
153
- <option *ngFor="let item of perPageSelect" [value]="item">{{ item }}</option>
154
- </select>
155
- </nav>
156
- `, isInline: true, styles: [".ng2-smart-pagination{display:inline-flex;font-size:.875em;padding:0}.ng2-smart-pagination .sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}.ng2-smart-pagination .ng2-smart-page-item{display:inline}.ng2-smart-pagination .page-link-next,.ng2-smart-pagination .page-link-prev{font-size:10px}:host{display:flex;justify-content:space-between}:host select{margin:1rem 0 1rem 1rem}:host label{margin:1rem 0 1rem 1rem;line-height:2.5rem}\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"] }, { kind: "directive", type: i2.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i2.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i2.SelectControlValueAccessor, selector: "select:not([multiple])[formControlName],select:not([multiple])[formControl],select:not([multiple])[ngModel]", inputs: ["compareWith"] }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }] }); }
154
+ @if (perPageSelect && perPageSelect.length > 0) {
155
+ <nav class="ng2-smart-pagination-per-page">
156
+ <label for="per-page">
157
+ Per Page:
158
+ </label>
159
+ <select (change)="onChangePerPage()" [(ngModel)]="currentPerPage" id="per-page">
160
+ @for (item of perPageSelect; track item) {
161
+ <option [value]="item">{{ item }}</option>
162
+ }
163
+ </select>
164
+ </nav>
165
+ }
166
+ `, isInline: true, styles: [".ng2-smart-pagination{display:inline-flex;font-size:.875em;padding:0}.ng2-smart-pagination .sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}.ng2-smart-pagination .ng2-smart-page-item{display:inline}.ng2-smart-pagination .page-link-next,.ng2-smart-pagination .page-link-prev{font-size:10px}:host{display:flex;justify-content:space-between}:host select{margin:1rem 0 1rem 1rem}:host label{margin:1rem 0 1rem 1rem;line-height:2.5rem}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i2.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i2.SelectControlValueAccessor, selector: "select:not([multiple])[formControlName],select:not([multiple])[formControl],select:not([multiple])[ngModel]", inputs: ["compareWith"] }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }] }); }
157
167
  }
158
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: PagerComponent, decorators: [{
168
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: PagerComponent, decorators: [{
159
169
  type: Component,
160
170
  args: [{ selector: 'ng2-smart-table-pager', template: `
161
- <nav *ngIf="shouldShow()" class="ng2-smart-pagination-nav">
162
- <ul class="ng2-smart-pagination pagination">
163
- <li class="ng2-smart-page-item page-item" [ngClass]="{disabled: getPage() == 1}">
164
- <a class="ng2-smart-page-link page-link" href="#"
165
- (click)="getPage() == 1 ? false : paginate(1)" aria-label="First">
166
- <span aria-hidden="true">&laquo;</span>
167
- <span class="sr-only">First</span>
168
- </a>
169
- </li>
170
- <li class="ng2-smart-page-item page-item" [ngClass]="{disabled: getPage() == 1}">
171
- <a class="ng2-smart-page-link page-link page-link-prev" href="#"
172
- (click)="getPage() == 1 ? false : prev()" aria-label="Prev">
173
- <span aria-hidden="true">&lt;</span>
174
- <span class="sr-only">Prev</span>
175
- </a>
176
- </li>
177
- <li class="ng2-smart-page-item page-item"
178
- [ngClass]="{active: getPage() == page}" *ngFor="let page of getPages()">
179
- <span class="ng2-smart-page-link page-link"
180
- *ngIf="getPage() == page">{{ page }} <span class="sr-only">(current)</span></span>
181
- <a class="ng2-smart-page-link page-link" href="#"
182
- (click)="paginate(page)" *ngIf="getPage() != page">{{ page }}</a>
183
- </li>
184
-
185
- <li class="ng2-smart-page-item page-item"
186
- [ngClass]="{disabled: getPage() == getLast()}">
187
- <a class="ng2-smart-page-link page-link page-link-next" href="#"
188
- (click)="getPage() == getLast() ? false : next()" aria-label="Next">
189
- <span aria-hidden="true">&gt;</span>
190
- <span class="sr-only">Next</span>
191
- </a>
192
- </li>
193
-
194
- <li class="ng2-smart-page-item page-item"
195
- [ngClass]="{disabled: getPage() == getLast()}">
196
- <a class="ng2-smart-page-link page-link" href="#"
197
- (click)="getPage() == getLast() ? false : paginate(getLast())" aria-label="Last">
198
- <span aria-hidden="true">&raquo;</span>
199
- <span class="sr-only">Last</span>
200
- </a>
201
- </li>
202
- </ul>
203
- </nav>
171
+ @if (shouldShow()) {
172
+ <nav class="ng2-smart-pagination-nav">
173
+ <ul class="ng2-smart-pagination pagination">
174
+ <li class="ng2-smart-page-item page-item" [ngClass]="{disabled: getPage() == 1}">
175
+ <a class="ng2-smart-page-link page-link" href="#"
176
+ (click)="getPage() == 1 ? false : paginate(1)" aria-label="First">
177
+ <span aria-hidden="true">&laquo;</span>
178
+ <span class="sr-only">First</span>
179
+ </a>
180
+ </li>
181
+ <li class="ng2-smart-page-item page-item" [ngClass]="{disabled: getPage() == 1}">
182
+ <a class="ng2-smart-page-link page-link page-link-prev" href="#"
183
+ (click)="getPage() == 1 ? false : prev()" aria-label="Prev">
184
+ <span aria-hidden="true">&lt;</span>
185
+ <span class="sr-only">Prev</span>
186
+ </a>
187
+ </li>
188
+ @for (page of getPages(); track page) {
189
+ <li class="ng2-smart-page-item page-item"
190
+ [ngClass]="{active: getPage() == page}">
191
+ @if (getPage() == page) {
192
+ <span class="ng2-smart-page-link page-link"
193
+ >{{ page }} <span class="sr-only">(current)</span></span>
194
+ }
195
+ @if (getPage() != page) {
196
+ <a class="ng2-smart-page-link page-link" href="#"
197
+ (click)="paginate(page)">{{ page }}</a>
198
+ }
199
+ </li>
200
+ }
201
+ <li class="ng2-smart-page-item page-item"
202
+ [ngClass]="{disabled: getPage() == getLast()}">
203
+ <a class="ng2-smart-page-link page-link page-link-next" href="#"
204
+ (click)="getPage() == getLast() ? false : next()" aria-label="Next">
205
+ <span aria-hidden="true">&gt;</span>
206
+ <span class="sr-only">Next</span>
207
+ </a>
208
+ </li>
209
+ <li class="ng2-smart-page-item page-item"
210
+ [ngClass]="{disabled: getPage() == getLast()}">
211
+ <a class="ng2-smart-page-link page-link" href="#"
212
+ (click)="getPage() == getLast() ? false : paginate(getLast())" aria-label="Last">
213
+ <span aria-hidden="true">&raquo;</span>
214
+ <span class="sr-only">Last</span>
215
+ </a>
216
+ </li>
217
+ </ul>
218
+ </nav>
219
+ }
204
220
 
205
- <nav *ngIf="perPageSelect && perPageSelect.length > 0" class="ng2-smart-pagination-per-page">
206
- <label for="per-page">
207
- Per Page:
208
- </label>
209
- <select (change)="onChangePerPage()" [(ngModel)]="currentPerPage" id="per-page">
210
- <option *ngFor="let item of perPageSelect" [value]="item">{{ item }}</option>
211
- </select>
212
- </nav>
213
- `, styles: [".ng2-smart-pagination{display:inline-flex;font-size:.875em;padding:0}.ng2-smart-pagination .sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}.ng2-smart-pagination .ng2-smart-page-item{display:inline}.ng2-smart-pagination .page-link-next,.ng2-smart-pagination .page-link-prev{font-size:10px}:host{display:flex;justify-content:space-between}:host select{margin:1rem 0 1rem 1rem}:host label{margin:1rem 0 1rem 1rem;line-height:2.5rem}\n"] }]
221
+ @if (perPageSelect && perPageSelect.length > 0) {
222
+ <nav class="ng2-smart-pagination-per-page">
223
+ <label for="per-page">
224
+ Per Page:
225
+ </label>
226
+ <select (change)="onChangePerPage()" [(ngModel)]="currentPerPage" id="per-page">
227
+ @for (item of perPageSelect; track item) {
228
+ <option [value]="item">{{ item }}</option>
229
+ }
230
+ </select>
231
+ </nav>
232
+ }
233
+ `, styles: [".ng2-smart-pagination{display:inline-flex;font-size:.875em;padding:0}.ng2-smart-pagination .sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}.ng2-smart-pagination .ng2-smart-page-item{display:inline}.ng2-smart-pagination .page-link-next,.ng2-smart-pagination .page-link-prev{font-size:10px}:host{display:flex;justify-content:space-between}:host select{margin:1rem 0 1rem 1rem}:host label{margin:1rem 0 1rem 1rem;line-height:2.5rem}\n"] }]
214
234
  }], propDecorators: { source: [{
215
235
  type: Input
216
236
  }], perPageSelect: [{
@@ -218,4 +238,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
218
238
  }], changePage: [{
219
239
  type: Output
220
240
  }] } });
221
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pager.component.js","sourceRoot":"","sources":["../../../../../../projects/ng2-smart-table/src/lib/components/pager/pager.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { SmartTablePagingItem } from './../../lib/interfaces/smart-table.models';\nimport { Component, Input, Output, EventEmitter, OnChanges, SimpleChanges } from '@angular/core';\nimport { Subscription } from 'rxjs';\nimport { LocalDataSource } from '../../lib/data-source/local/local.data-source';\n\n@Component({\n  selector: 'ng2-smart-table-pager',\n  styleUrls: ['./pager.component.scss'],\n  template: `\n    <nav *ngIf=\"shouldShow()\" class=\"ng2-smart-pagination-nav\">\n      <ul class=\"ng2-smart-pagination pagination\">\n        <li class=\"ng2-smart-page-item page-item\" [ngClass]=\"{disabled: getPage() == 1}\">\n          <a class=\"ng2-smart-page-link page-link\" href=\"#\"\n          (click)=\"getPage() == 1 ? false : paginate(1)\" aria-label=\"First\">\n            <span aria-hidden=\"true\">&laquo;</span>\n            <span class=\"sr-only\">First</span>\n          </a>\n        </li>\n        <li class=\"ng2-smart-page-item page-item\" [ngClass]=\"{disabled: getPage() == 1}\">\n          <a class=\"ng2-smart-page-link page-link page-link-prev\" href=\"#\"\n             (click)=\"getPage() == 1 ? false : prev()\" aria-label=\"Prev\">\n            <span aria-hidden=\"true\">&lt;</span>\n            <span class=\"sr-only\">Prev</span>\n          </a>\n        </li>\n        <li class=\"ng2-smart-page-item page-item\"\n        [ngClass]=\"{active: getPage() == page}\" *ngFor=\"let page of getPages()\">\n          <span class=\"ng2-smart-page-link page-link\"\n          *ngIf=\"getPage() == page\">{{ page }} <span class=\"sr-only\">(current)</span></span>\n          <a class=\"ng2-smart-page-link page-link\" href=\"#\"\n          (click)=\"paginate(page)\" *ngIf=\"getPage() != page\">{{ page }}</a>\n        </li>\n\n        <li class=\"ng2-smart-page-item page-item\"\n            [ngClass]=\"{disabled: getPage() == getLast()}\">\n          <a class=\"ng2-smart-page-link page-link page-link-next\" href=\"#\"\n             (click)=\"getPage() == getLast() ? false : next()\" aria-label=\"Next\">\n            <span aria-hidden=\"true\">&gt;</span>\n            <span class=\"sr-only\">Next</span>\n          </a>\n        </li>\n        \n        <li class=\"ng2-smart-page-item page-item\"\n        [ngClass]=\"{disabled: getPage() == getLast()}\">\n          <a class=\"ng2-smart-page-link page-link\" href=\"#\"\n          (click)=\"getPage() == getLast() ? false : paginate(getLast())\" aria-label=\"Last\">\n            <span aria-hidden=\"true\">&raquo;</span>\n            <span class=\"sr-only\">Last</span>\n          </a>\n        </li>\n      </ul>\n    </nav>\n    \n    <nav *ngIf=\"perPageSelect && perPageSelect.length > 0\" class=\"ng2-smart-pagination-per-page\">\n      <label for=\"per-page\">\n        Per Page:\n      </label>\n      <select (change)=\"onChangePerPage()\" [(ngModel)]=\"currentPerPage\" id=\"per-page\">\n        <option *ngFor=\"let item of perPageSelect\" [value]=\"item\">{{ item }}</option>\n      </select>\n    </nav>\n  `,\n})\nexport class PagerComponent implements OnChanges {\n\n  @Input() source!: LocalDataSource;\n  @Input() perPageSelect: number[] = [];\n\n  @Output() changePage = new EventEmitter<any>();\n\n  currentPerPage: number = 0;\n\n  protected pages: number[] = [];\n  protected page: number = 1;\n  protected count: number = 0;\n  protected perPage: number = 0;\n\n  protected dataChangedSub: Subscription | undefined;\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes['source']) {\n      if (!changes['source'].firstChange && this.dataChangedSub) {\n        this.dataChangedSub.unsubscribe();\n      }\n      this.dataChangedSub = this.source.onChanged().subscribe((dataChanges) => {\n        const paging: SmartTablePagingItem | false = this.source.getPaging();\n        if (paging) {\n          this.page = paging.page;\n          this.perPage = paging.perPage;\n        }\n        this.currentPerPage = this.perPage;\n        this.count = this.source.count();\n        if (this.isPageOutOfBounce()) {\n          this.source.setPage(--this.page);\n        }\n\n        this.processPageChange(dataChanges);\n        this.initPages();\n      });\n    }\n  }\n\n  /**\n   * We change the page here depending on the action performed against data source\n   * if a new element was added to the end of the table - then change the page to the last\n   * if a new element was added to the beginning of the table - then to the first page\n   * @param changes\n   */\n  processPageChange(changes: any) {\n    if (changes['action'] === 'prepend') {\n      this.source.setPage(1);\n    }\n    if (changes['action'] === 'append') {\n      this.source.setPage(this.getLast());\n    }\n  }\n\n  shouldShow(): boolean {\n    return this.source.count() > this.perPage;\n  }\n\n  paginate(page: number): boolean {\n    this.source.setPage(page);\n    this.page = page;\n    this.changePage.emit({ page });\n    return false;\n  }\n\n  next(): boolean {\n    return this.paginate(this.getPage() + 1);\n  }\n\n  prev(): boolean {\n    return this.paginate(this.getPage() - 1);\n  }\n\n  getPage(): number {\n    return this.page;\n  }\n\n  getPages(): number[] {\n    return this.pages;\n  }\n\n  getLast(): number {\n    return Math.ceil(this.count / this.perPage);\n  }\n\n  isPageOutOfBounce(): boolean {\n    return (this.page * this.perPage) >= (this.count + this.perPage) && this.page > 1;\n  }\n\n  initPages() {\n    const pagesCount = this.getLast();\n    let showPagesCount = 4;\n    showPagesCount = pagesCount < showPagesCount ? pagesCount : showPagesCount;\n    this.pages = [];\n\n    if (this.shouldShow()) {\n\n      let middleOne = Math.ceil(showPagesCount / 2);\n      middleOne = this.page >= middleOne ? this.page : middleOne;\n\n      let lastOne = middleOne + Math.floor(showPagesCount / 2);\n      lastOne = lastOne >= pagesCount ? pagesCount : lastOne;\n\n      const firstOne = lastOne - showPagesCount + 1;\n\n      for (let i = firstOne; i <= lastOne; i++) {\n        this.pages.push(i);\n      }\n    }\n  }\n\n  onChangePerPage() {\n    const paging: SmartTablePagingItem | false = this.source.getPaging(); \n    if (paging) {\n      paging.perPage = this.currentPerPage * 1;\n    }\n    this.source.refresh();\n    this.initPages();\n  }\n}\n"]}
241
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pager.component.js","sourceRoot":"","sources":["../../../../../../projects/ng2-smart-table/src/lib/components/pager/pager.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { SmartTablePagingItem } from './../../lib/interfaces/smart-table.models';\nimport { Component, Input, Output, EventEmitter, OnChanges, SimpleChanges } from '@angular/core';\nimport { Subscription } from 'rxjs';\nimport { LocalDataSource } from '../../lib/data-source/local/local.data-source';\n\n@Component({\n  selector: 'ng2-smart-table-pager',\n  styleUrls: ['./pager.component.scss'],\n  template: `\n    @if (shouldShow()) {\n      <nav class=\"ng2-smart-pagination-nav\">\n        <ul class=\"ng2-smart-pagination pagination\">\n          <li class=\"ng2-smart-page-item page-item\" [ngClass]=\"{disabled: getPage() == 1}\">\n            <a class=\"ng2-smart-page-link page-link\" href=\"#\"\n              (click)=\"getPage() == 1 ? false : paginate(1)\" aria-label=\"First\">\n              <span aria-hidden=\"true\">&laquo;</span>\n              <span class=\"sr-only\">First</span>\n            </a>\n          </li>\n          <li class=\"ng2-smart-page-item page-item\" [ngClass]=\"{disabled: getPage() == 1}\">\n            <a class=\"ng2-smart-page-link page-link page-link-prev\" href=\"#\"\n              (click)=\"getPage() == 1 ? false : prev()\" aria-label=\"Prev\">\n              <span aria-hidden=\"true\">&lt;</span>\n              <span class=\"sr-only\">Prev</span>\n            </a>\n          </li>\n          @for (page of getPages(); track page) {\n            <li class=\"ng2-smart-page-item page-item\"\n              [ngClass]=\"{active: getPage() == page}\">\n              @if (getPage() == page) {\n                <span class=\"ng2-smart-page-link page-link\"\n                  >{{ page }} <span class=\"sr-only\">(current)</span></span>\n                }\n                @if (getPage() != page) {\n                  <a class=\"ng2-smart-page-link page-link\" href=\"#\"\n                  (click)=\"paginate(page)\">{{ page }}</a>\n                }\n              </li>\n            }\n            <li class=\"ng2-smart-page-item page-item\"\n              [ngClass]=\"{disabled: getPage() == getLast()}\">\n              <a class=\"ng2-smart-page-link page-link page-link-next\" href=\"#\"\n                (click)=\"getPage() == getLast() ? false : next()\" aria-label=\"Next\">\n                <span aria-hidden=\"true\">&gt;</span>\n                <span class=\"sr-only\">Next</span>\n              </a>\n            </li>\n            <li class=\"ng2-smart-page-item page-item\"\n              [ngClass]=\"{disabled: getPage() == getLast()}\">\n              <a class=\"ng2-smart-page-link page-link\" href=\"#\"\n                (click)=\"getPage() == getLast() ? false : paginate(getLast())\" aria-label=\"Last\">\n                <span aria-hidden=\"true\">&raquo;</span>\n                <span class=\"sr-only\">Last</span>\n              </a>\n            </li>\n          </ul>\n        </nav>\n      }\n    \n      @if (perPageSelect && perPageSelect.length > 0) {\n        <nav class=\"ng2-smart-pagination-per-page\">\n          <label for=\"per-page\">\n            Per Page:\n          </label>\n          <select (change)=\"onChangePerPage()\" [(ngModel)]=\"currentPerPage\" id=\"per-page\">\n            @for (item of perPageSelect; track item) {\n              <option [value]=\"item\">{{ item }}</option>\n            }\n          </select>\n        </nav>\n      }\n    `,\n})\nexport class PagerComponent implements OnChanges {\n\n  @Input() source!: LocalDataSource;\n  @Input() perPageSelect: number[] = [];\n\n  @Output() changePage = new EventEmitter<any>();\n\n  currentPerPage: number = 0;\n\n  protected pages: number[] = [];\n  protected page: number = 1;\n  protected count: number = 0;\n  protected perPage: number = 0;\n\n  protected dataChangedSub: Subscription | undefined;\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes['source']) {\n      if (!changes['source'].firstChange && this.dataChangedSub) {\n        this.dataChangedSub.unsubscribe();\n      }\n      this.dataChangedSub = this.source.onChanged().subscribe((dataChanges) => {\n        const paging: SmartTablePagingItem | false = this.source.getPaging();\n        if (paging) {\n          this.page = paging.page;\n          this.perPage = paging.perPage;\n        }\n        this.currentPerPage = this.perPage;\n        this.count = this.source.count();\n        if (this.isPageOutOfBounce()) {\n          this.source.setPage(--this.page);\n        }\n\n        this.processPageChange(dataChanges);\n        this.initPages();\n      });\n    }\n  }\n\n  /**\n   * We change the page here depending on the action performed against data source\n   * if a new element was added to the end of the table - then change the page to the last\n   * if a new element was added to the beginning of the table - then to the first page\n   * @param changes\n   */\n  processPageChange(changes: any) {\n    if (changes['action'] === 'prepend') {\n      this.source.setPage(1);\n    }\n    if (changes['action'] === 'append') {\n      this.source.setPage(this.getLast());\n    }\n  }\n\n  shouldShow(): boolean {\n    return this.source.count() > this.perPage;\n  }\n\n  paginate(page: number): boolean {\n    this.source.setPage(page);\n    this.page = page;\n    this.changePage.emit({ page });\n    return false;\n  }\n\n  next(): boolean {\n    return this.paginate(this.getPage() + 1);\n  }\n\n  prev(): boolean {\n    return this.paginate(this.getPage() - 1);\n  }\n\n  getPage(): number {\n    return this.page;\n  }\n\n  getPages(): number[] {\n    return this.pages;\n  }\n\n  getLast(): number {\n    return Math.ceil(this.count / this.perPage);\n  }\n\n  isPageOutOfBounce(): boolean {\n    return (this.page * this.perPage) >= (this.count + this.perPage) && this.page > 1;\n  }\n\n  initPages() {\n    const pagesCount = this.getLast();\n    let showPagesCount = 4;\n    showPagesCount = pagesCount < showPagesCount ? pagesCount : showPagesCount;\n    this.pages = [];\n\n    if (this.shouldShow()) {\n\n      let middleOne = Math.ceil(showPagesCount / 2);\n      middleOne = this.page >= middleOne ? this.page : middleOne;\n\n      let lastOne = middleOne + Math.floor(showPagesCount / 2);\n      lastOne = lastOne >= pagesCount ? pagesCount : lastOne;\n\n      const firstOne = lastOne - showPagesCount + 1;\n\n      for (let i = firstOne; i <= lastOne; i++) {\n        this.pages.push(i);\n      }\n    }\n  }\n\n  onChangePerPage() {\n    const paging: SmartTablePagingItem | false = this.source.getPaging(); \n    if (paging) {\n      paging.perPage = this.currentPerPage * 1;\n    }\n    this.source.refresh();\n    this.initPages();\n  }\n}\n"]}
@@ -4,13 +4,13 @@ import { FormsModule } from '@angular/forms';
4
4
  import { PagerComponent } from './pager.component';
5
5
  import * as i0 from "@angular/core";
6
6
  export class PagerModule {
7
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: PagerModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
8
- static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.2.12", ngImport: i0, type: PagerModule, declarations: [PagerComponent], imports: [CommonModule,
7
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: PagerModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
8
+ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "17.3.12", ngImport: i0, type: PagerModule, declarations: [PagerComponent], imports: [CommonModule,
9
9
  FormsModule], exports: [PagerComponent] }); }
10
- static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: PagerModule, imports: [CommonModule,
10
+ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: PagerModule, imports: [CommonModule,
11
11
  FormsModule] }); }
12
12
  }
13
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: PagerModule, decorators: [{
13
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: PagerModule, decorators: [{
14
14
  type: NgModule,
15
15
  args: [{
16
16
  imports: [