@swimlane/ngx-datatable 20.1.0 → 21.0.0-alpha.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 (139) hide show
  1. package/CHANGELOG.md +720 -0
  2. package/README.md +25 -4
  3. package/assets/app.css +4 -3
  4. package/assets/icons-reference.html +5 -1
  5. package/assets/icons.css +3 -2
  6. package/{fesm2020 → fesm2022}/swimlane-ngx-datatable.mjs +3404 -2536
  7. package/fesm2022/swimlane-ngx-datatable.mjs.map +1 -0
  8. package/index.css +224 -169
  9. package/index.scss +13 -3
  10. package/lib/components/body/body-cell.component.d.ts +28 -23
  11. package/lib/components/body/body-group-header-template.directive.d.ts +3 -4
  12. package/lib/components/body/body-group-header.directive.d.ts +14 -9
  13. package/lib/components/body/body-row-def.component.d.ts +34 -0
  14. package/lib/components/body/body-row-wrapper.component.d.ts +34 -22
  15. package/lib/components/body/body-row.component.d.ts +28 -34
  16. package/lib/components/body/body.component.d.ts +88 -69
  17. package/lib/components/body/ghost-loader/ghost-loader.component.d.ts +12 -0
  18. package/lib/components/body/progress-bar.component.d.ts +1 -1
  19. package/lib/components/body/scroller.component.d.ts +4 -7
  20. package/lib/components/body/selection.component.d.ts +21 -25
  21. package/lib/components/body/summary/summary-row.component.d.ts +4 -3
  22. package/lib/components/columns/column-cell.directive.d.ts +4 -3
  23. package/lib/components/columns/column-ghost-cell.directive.d.ts +6 -0
  24. package/lib/components/columns/column-header.directive.d.ts +3 -4
  25. package/lib/components/columns/column.directive.d.ts +43 -18
  26. package/lib/components/columns/tree.directive.d.ts +1 -2
  27. package/lib/components/datatable.component.d.ts +142 -76
  28. package/lib/components/footer/footer-template.directive.d.ts +3 -4
  29. package/lib/components/footer/footer.component.d.ts +3 -2
  30. package/lib/components/footer/footer.directive.d.ts +6 -4
  31. package/lib/components/footer/pager.component.d.ts +6 -4
  32. package/lib/components/header/header-cell.component.d.ts +18 -18
  33. package/lib/components/header/header.component.d.ts +41 -36
  34. package/lib/components/row-detail/row-detail-template.directive.d.ts +3 -4
  35. package/lib/components/row-detail/row-detail.directive.d.ts +9 -8
  36. package/lib/directives/disable-row.directive.d.ts +22 -0
  37. package/lib/directives/draggable.directive.d.ts +11 -8
  38. package/lib/directives/long-press.directive.d.ts +16 -5
  39. package/lib/directives/orderable.directive.d.ts +21 -10
  40. package/lib/directives/resizeable.directive.d.ts +7 -5
  41. package/lib/directives/visibility.directive.d.ts +2 -3
  42. package/lib/ngx-datatable.module.d.ts +29 -30
  43. package/lib/services/scrollbar-helper.service.d.ts +0 -1
  44. package/lib/types/internal.types.d.ts +31 -0
  45. package/lib/types/public.types.d.ts +142 -0
  46. package/lib/types/table-column.type.d.ts +39 -66
  47. package/lib/utils/column-helper.d.ts +2 -2
  48. package/lib/utils/column-prop-getters.d.ts +1 -1
  49. package/lib/utils/column.d.ts +7 -14
  50. package/lib/utils/keys.d.ts +6 -6
  51. package/lib/utils/math.d.ts +4 -3
  52. package/lib/utils/selection.d.ts +2 -2
  53. package/lib/utils/sort.d.ts +5 -5
  54. package/lib/utils/table-token.d.ts +7 -0
  55. package/lib/utils/tree.d.ts +2 -2
  56. package/package.json +9 -17
  57. package/public-api.d.ts +4 -11
  58. package/themes/_ghost.scss +22 -0
  59. package/themes/_rows.scss +22 -0
  60. package/themes/bootstrap.css +117 -65
  61. package/themes/bootstrap.scss +27 -3
  62. package/themes/dark.css +101 -70
  63. package/themes/dark.scss +12 -0
  64. package/themes/material.css +344 -260
  65. package/themes/material.scss +52 -11
  66. package/esm2020/lib/components/body/body-cell.component.mjs +0 -432
  67. package/esm2020/lib/components/body/body-group-header-template.directive.mjs +0 -16
  68. package/esm2020/lib/components/body/body-group-header.directive.mjs +0 -62
  69. package/esm2020/lib/components/body/body-row-wrapper.component.mjs +0 -140
  70. package/esm2020/lib/components/body/body-row.component.mjs +0 -262
  71. package/esm2020/lib/components/body/body.component.mjs +0 -863
  72. package/esm2020/lib/components/body/progress-bar.component.mjs +0 -27
  73. package/esm2020/lib/components/body/scroller.component.mjs +0 -91
  74. package/esm2020/lib/components/body/selection.component.mjs +0 -150
  75. package/esm2020/lib/components/body/summary/summary-row.component.mjs +0 -105
  76. package/esm2020/lib/components/columns/column-cell.directive.mjs +0 -14
  77. package/esm2020/lib/components/columns/column-header.directive.mjs +0 -14
  78. package/esm2020/lib/components/columns/column.directive.mjs +0 -98
  79. package/esm2020/lib/components/columns/tree.directive.mjs +0 -14
  80. package/esm2020/lib/components/datatable.component.mjs +0 -1008
  81. package/esm2020/lib/components/footer/footer-template.directive.mjs +0 -14
  82. package/esm2020/lib/components/footer/footer.component.mjs +0 -128
  83. package/esm2020/lib/components/footer/footer.directive.mjs +0 -35
  84. package/esm2020/lib/components/footer/pager.component.mjs +0 -181
  85. package/esm2020/lib/components/header/header-cell.component.mjs +0 -243
  86. package/esm2020/lib/components/header/header.component.mjs +0 -376
  87. package/esm2020/lib/components/row-detail/row-detail-template.directive.mjs +0 -16
  88. package/esm2020/lib/components/row-detail/row-detail.directive.mjs +0 -63
  89. package/esm2020/lib/directives/draggable.directive.mjs +0 -108
  90. package/esm2020/lib/directives/long-press.directive.mjs +0 -117
  91. package/esm2020/lib/directives/orderable.directive.mjs +0 -136
  92. package/esm2020/lib/directives/resizeable.directive.mjs +0 -93
  93. package/esm2020/lib/directives/visibility.directive.mjs +0 -63
  94. package/esm2020/lib/events.mjs +0 -7
  95. package/esm2020/lib/ngx-datatable.module.mjs +0 -139
  96. package/esm2020/lib/services/column-changes.service.mjs +0 -24
  97. package/esm2020/lib/services/dimensions-helper.service.mjs +0 -17
  98. package/esm2020/lib/services/scrollbar-helper.service.mjs +0 -37
  99. package/esm2020/lib/types/click.type.mjs +0 -6
  100. package/esm2020/lib/types/column-mode.type.mjs +0 -7
  101. package/esm2020/lib/types/contextmenu.type.mjs +0 -6
  102. package/esm2020/lib/types/selection.type.mjs +0 -9
  103. package/esm2020/lib/types/sort-direction.type.mjs +0 -6
  104. package/esm2020/lib/types/sort-prop-dir.type.mjs +0 -2
  105. package/esm2020/lib/types/sort.type.mjs +0 -6
  106. package/esm2020/lib/types/table-column.type.mjs +0 -2
  107. package/esm2020/lib/utils/camel-case.mjs +0 -28
  108. package/esm2020/lib/utils/column-helper.mjs +0 -95
  109. package/esm2020/lib/utils/column-prop-getters.mjs +0 -96
  110. package/esm2020/lib/utils/column.mjs +0 -69
  111. package/esm2020/lib/utils/elm-from-point.mjs +0 -38
  112. package/esm2020/lib/utils/id.mjs +0 -8
  113. package/esm2020/lib/utils/keys.mjs +0 -10
  114. package/esm2020/lib/utils/math.mjs +0 -146
  115. package/esm2020/lib/utils/prefixes.mjs +0 -38
  116. package/esm2020/lib/utils/row-height-cache.mjs +0 -138
  117. package/esm2020/lib/utils/selection.mjs +0 -40
  118. package/esm2020/lib/utils/sort.mjs +0 -127
  119. package/esm2020/lib/utils/throttle.mjs +0 -60
  120. package/esm2020/lib/utils/translate.mjs +0 -25
  121. package/esm2020/lib/utils/tree.mjs +0 -103
  122. package/esm2020/public-api.mjs +0 -64
  123. package/esm2020/swimlane-ngx-datatable.mjs +0 -5
  124. package/fesm2015/swimlane-ngx-datatable.mjs +0 -5979
  125. package/fesm2015/swimlane-ngx-datatable.mjs.map +0 -1
  126. package/fesm2020/swimlane-ngx-datatable.mjs.map +0 -1
  127. package/lib/events.d.ts +0 -3
  128. package/lib/services/dimensions-helper.service.d.ts +0 -10
  129. package/lib/types/click.type.d.ts +0 -4
  130. package/lib/types/column-mode.type.d.ts +0 -5
  131. package/lib/types/contextmenu.type.d.ts +0 -4
  132. package/lib/types/selection.type.d.ts +0 -7
  133. package/lib/types/sort-direction.type.d.ts +0 -4
  134. package/lib/types/sort-prop-dir.type.d.ts +0 -6
  135. package/lib/types/sort.type.d.ts +0 -4
  136. package/lib/utils/elm-from-point.d.ts +0 -8
  137. package/lib/utils/prefixes.d.ts +0 -1
  138. package/lib/utils/translate.d.ts +0 -1
  139. /package/{swimlane-ngx-datatable.d.ts → index.d.ts} +0 -0
@@ -1,4 +1,6 @@
1
1
  import { EventEmitter } from '@angular/core';
2
+ import { PagerPageEvent } from '../../types/public.types';
3
+ import { Page } from '../../types/internal.types';
2
4
  import * as i0 from "@angular/core";
3
5
  export declare class DataTablePagerComponent {
4
6
  pagerLeftArrowIcon: string;
@@ -12,17 +14,17 @@ export declare class DataTablePagerComponent {
12
14
  set page(val: number);
13
15
  get page(): number;
14
16
  get totalPages(): number;
15
- change: EventEmitter<any>;
17
+ change: EventEmitter<PagerPageEvent>;
16
18
  _count: number;
17
19
  _page: number;
18
20
  _size: number;
19
- pages: any;
21
+ pages: Page[];
20
22
  canPrevious(): boolean;
21
23
  canNext(): boolean;
22
24
  prevPage(): void;
23
25
  nextPage(): void;
24
26
  selectPage(page: number): void;
25
- calcPages(page?: number): any[];
27
+ calcPages(page?: number): Page[];
26
28
  static ɵfac: i0.ɵɵFactoryDeclaration<DataTablePagerComponent, never>;
27
- static ɵcmp: i0.ɵɵComponentDeclaration<DataTablePagerComponent, "datatable-pager", never, { "pagerLeftArrowIcon": "pagerLeftArrowIcon"; "pagerRightArrowIcon": "pagerRightArrowIcon"; "pagerPreviousIcon": "pagerPreviousIcon"; "pagerNextIcon": "pagerNextIcon"; "size": "size"; "count": "count"; "page": "page"; }, { "change": "change"; }, never, never>;
29
+ static ɵcmp: i0.ɵɵComponentDeclaration<DataTablePagerComponent, "datatable-pager", never, { "pagerLeftArrowIcon": { "alias": "pagerLeftArrowIcon"; "required": false; }; "pagerRightArrowIcon": { "alias": "pagerRightArrowIcon"; "required": false; }; "pagerPreviousIcon": { "alias": "pagerPreviousIcon"; "required": false; }; "pagerNextIcon": { "alias": "pagerNextIcon"; "required": false; }; "size": { "alias": "size"; "required": false; }; "count": { "alias": "count"; "required": false; }; "page": { "alias": "page"; "required": false; }; }, { "change": "change"; }, never, never, true, never>;
28
30
  }
@@ -1,18 +1,17 @@
1
- import { EventEmitter, ChangeDetectorRef } from '@angular/core';
2
- import { SortType } from '../../types/sort.type';
3
- import { SelectionType } from '../../types/selection.type';
1
+ import { EventEmitter, OnInit, TemplateRef } from '@angular/core';
4
2
  import { TableColumn } from '../../types/table-column.type';
5
- import { SortDirection } from '../../types/sort-direction.type';
3
+ import { HeaderCellContext, InnerSortEvent, SelectionType, SortDirection, SortPropDir, SortType } from '../../types/public.types';
6
4
  import * as i0 from "@angular/core";
7
- export declare class DataTableHeaderCellComponent {
5
+ export declare class DataTableHeaderCellComponent implements OnInit {
8
6
  private cd;
9
7
  sortType: SortType;
10
8
  sortAscendingIcon: string;
11
9
  sortDescendingIcon: string;
12
10
  sortUnsetIcon: string;
13
11
  isTarget: boolean;
14
- targetMarkerTemplate: any;
12
+ targetMarkerTemplate: TemplateRef<any>;
15
13
  targetMarkerContext: any;
14
+ enableClearingSortState: boolean;
16
15
  _allRowsSelected: boolean;
17
16
  set allRowsSelected(value: boolean);
18
17
  get allRowsSelected(): boolean;
@@ -20,33 +19,34 @@ export declare class DataTableHeaderCellComponent {
20
19
  set column(column: TableColumn);
21
20
  get column(): TableColumn;
22
21
  headerHeight: number;
23
- set sorts(val: any[]);
24
- get sorts(): any[];
25
- sort: EventEmitter<any>;
26
- select: EventEmitter<any>;
22
+ set sorts(val: SortPropDir[]);
23
+ get sorts(): SortPropDir[];
24
+ sort: EventEmitter<InnerSortEvent>;
25
+ select: EventEmitter<void>;
27
26
  columnContextmenu: EventEmitter<{
28
27
  event: MouseEvent;
29
- column: any;
28
+ column: TableColumn;
30
29
  }>;
31
- get columnCssClasses(): any;
30
+ get columnCssClasses(): string;
32
31
  get name(): string;
33
32
  get minWidth(): number;
34
33
  get maxWidth(): number;
35
34
  get width(): number;
35
+ get tabindex(): number;
36
36
  get isCheckboxable(): boolean;
37
- sortFn: any;
38
37
  sortClass: string;
39
38
  sortDir: SortDirection;
40
- selectFn: any;
41
- cellContext: any;
39
+ cellContext: HeaderCellContext;
42
40
  private _column;
43
41
  private _sorts;
44
- constructor(cd: ChangeDetectorRef);
42
+ constructor();
45
43
  onContextmenu($event: MouseEvent): void;
44
+ enter(): void;
46
45
  ngOnInit(): void;
47
- calcSortDir(sorts: any[]): any;
46
+ calcSortDir(sorts: SortPropDir[]): any;
47
+ private totalSortStatesApplied;
48
48
  onSort(): void;
49
49
  calcSortClass(sortDir: SortDirection): string;
50
50
  static ɵfac: i0.ɵɵFactoryDeclaration<DataTableHeaderCellComponent, never>;
51
- static ɵcmp: i0.ɵɵComponentDeclaration<DataTableHeaderCellComponent, "datatable-header-cell", never, { "sortType": "sortType"; "sortAscendingIcon": "sortAscendingIcon"; "sortDescendingIcon": "sortDescendingIcon"; "sortUnsetIcon": "sortUnsetIcon"; "isTarget": "isTarget"; "targetMarkerTemplate": "targetMarkerTemplate"; "targetMarkerContext": "targetMarkerContext"; "allRowsSelected": "allRowsSelected"; "selectionType": "selectionType"; "column": "column"; "headerHeight": "headerHeight"; "sorts": "sorts"; }, { "sort": "sort"; "select": "select"; "columnContextmenu": "columnContextmenu"; }, never, never>;
51
+ static ɵcmp: i0.ɵɵComponentDeclaration<DataTableHeaderCellComponent, "datatable-header-cell", never, { "sortType": { "alias": "sortType"; "required": false; }; "sortAscendingIcon": { "alias": "sortAscendingIcon"; "required": false; }; "sortDescendingIcon": { "alias": "sortDescendingIcon"; "required": false; }; "sortUnsetIcon": { "alias": "sortUnsetIcon"; "required": false; }; "isTarget": { "alias": "isTarget"; "required": false; }; "targetMarkerTemplate": { "alias": "targetMarkerTemplate"; "required": false; }; "targetMarkerContext": { "alias": "targetMarkerContext"; "required": false; }; "enableClearingSortState": { "alias": "enableClearingSortState"; "required": false; }; "allRowsSelected": { "alias": "allRowsSelected"; "required": false; }; "selectionType": { "alias": "selectionType"; "required": false; }; "column": { "alias": "column"; "required": false; }; "headerHeight": { "alias": "headerHeight"; "required": false; }; "sorts": { "alias": "sorts"; "required": false; }; }, { "sort": "sort"; "select": "select"; "columnContextmenu": "columnContextmenu"; }, never, never, true, never>;
52
52
  }
@@ -1,70 +1,75 @@
1
- import { EventEmitter, ChangeDetectorRef, OnDestroy } from '@angular/core';
2
- import { SortType } from '../../types/sort.type';
3
- import { SelectionType } from '../../types/selection.type';
4
- import { DataTableColumnDirective } from '../columns/column.directive';
1
+ import { EventEmitter, OnChanges, OnDestroy, SimpleChanges, TemplateRef } from '@angular/core';
2
+ import { ColumnResizeEvent, InnerSortEvent, ReorderEvent, SelectionType, SortDirection, SortEvent, SortPropDir, SortType } from '../../types/public.types';
3
+ import { NgStyle } from '@angular/common';
4
+ import { TableColumn } from '../../types/table-column.type';
5
+ import { OrderableReorderEvent, PinnedColumns, TargetChangedEvent } from '../../types/internal.types';
5
6
  import * as i0 from "@angular/core";
6
- export declare class DataTableHeaderComponent implements OnDestroy {
7
+ export declare class DataTableHeaderComponent implements OnDestroy, OnChanges {
7
8
  private cd;
8
- sortAscendingIcon: any;
9
- sortDescendingIcon: any;
10
- sortUnsetIcon: any;
9
+ private scrollbarHelper;
10
+ sortAscendingIcon: string;
11
+ sortDescendingIcon: string;
12
+ sortUnsetIcon: string;
11
13
  scrollbarH: boolean;
12
14
  dealsWithGroup: boolean;
13
- targetMarkerTemplate: any;
14
- targetMarkerContext: any;
15
+ targetMarkerTemplate: TemplateRef<unknown>;
16
+ enableClearingSortState: boolean;
15
17
  set innerWidth(val: number);
16
18
  get innerWidth(): number;
17
- sorts: any[];
19
+ sorts: SortPropDir[];
18
20
  sortType: SortType;
19
21
  allRowsSelected: boolean;
20
22
  selectionType: SelectionType;
21
23
  reorderable: boolean;
22
- dragEventTarget: any;
24
+ verticalScrollVisible: boolean;
25
+ dragEventTarget?: MouseEvent;
23
26
  set headerHeight(val: any);
24
27
  get headerHeight(): any;
25
- set columns(val: any[]);
28
+ set columns(val: TableColumn[]);
26
29
  get columns(): any[];
27
30
  set offsetX(val: number);
28
31
  get offsetX(): number;
29
- sort: EventEmitter<any>;
30
- reorder: EventEmitter<any>;
31
- resize: EventEmitter<any>;
32
- select: EventEmitter<any>;
32
+ sort: EventEmitter<SortEvent>;
33
+ reorder: EventEmitter<ReorderEvent>;
34
+ resize: EventEmitter<ColumnResizeEvent>;
35
+ resizing: EventEmitter<ColumnResizeEvent>;
36
+ select: EventEmitter<void>;
33
37
  columnContextmenu: EventEmitter<{
34
38
  event: MouseEvent;
35
- column: any;
39
+ column: TableColumn;
36
40
  }>;
37
- _columnsByPin: any;
41
+ _columnsByPin: PinnedColumns[];
38
42
  _columnGroupWidths: any;
39
43
  _innerWidth: number;
40
44
  _offsetX: number;
41
- _columns: any[];
45
+ _columns: TableColumn[];
42
46
  _headerHeight: string;
43
47
  _styleByGroup: {
44
- [prop: string]: {};
48
+ left: NgStyle['ngStyle'];
49
+ center: NgStyle['ngStyle'];
50
+ right: NgStyle['ngStyle'];
45
51
  };
46
52
  private destroyed;
47
- constructor(cd: ChangeDetectorRef);
53
+ ngOnChanges(changes: SimpleChanges): void;
48
54
  ngOnDestroy(): void;
49
55
  onLongPressStart({ event, model }: {
50
- event: any;
51
- model: any;
56
+ event: MouseEvent;
57
+ model: TableColumn;
52
58
  }): void;
53
- onLongPressEnd({ event, model }: {
54
- event: any;
55
- model: any;
59
+ onLongPressEnd({ model }: {
60
+ model: TableColumn;
56
61
  }): void;
57
62
  get headerWidth(): string;
58
- trackByGroups(index: number, colGroup: any): any;
59
- columnTrackingFn(index: number, column: any): any;
60
- onColumnResized(width: number, column: DataTableColumnDirective): void;
61
- onColumnReordered({ prevIndex, newIndex, model }: any): void;
62
- onTargetChanged({ prevIndex, newIndex, initialIndex }: any): void;
63
+ onColumnResized(width: number, column: TableColumn): void;
64
+ onColumnResizing(width: number, column: TableColumn): void;
65
+ private makeResizeEvent;
66
+ onColumnReordered({ prevIndex, newIndex, model }: OrderableReorderEvent): void;
67
+ onTargetChanged({ prevIndex, newIndex, initialIndex }: TargetChangedEvent): void;
63
68
  getColumn(index: number): any;
64
- onSort({ column, prevValue, newValue }: any): void;
65
- calcNewSorts(column: any, prevValue: number, newValue: number): any[];
69
+ onSort({ column, prevValue, newValue }: InnerSortEvent): void;
70
+ calcNewSorts(column: TableColumn, prevValue: SortDirection, newValue: SortDirection): SortPropDir[];
66
71
  setStylesByGroup(): void;
67
- calcStylesByGroup(group: string): any;
72
+ calcStylesByGroup(group: 'center' | 'right' | 'left'): NgStyle['ngStyle'];
68
73
  static ɵfac: i0.ɵɵFactoryDeclaration<DataTableHeaderComponent, never>;
69
- static ɵcmp: i0.ɵɵComponentDeclaration<DataTableHeaderComponent, "datatable-header", never, { "sortAscendingIcon": "sortAscendingIcon"; "sortDescendingIcon": "sortDescendingIcon"; "sortUnsetIcon": "sortUnsetIcon"; "scrollbarH": "scrollbarH"; "dealsWithGroup": "dealsWithGroup"; "targetMarkerTemplate": "targetMarkerTemplate"; "innerWidth": "innerWidth"; "sorts": "sorts"; "sortType": "sortType"; "allRowsSelected": "allRowsSelected"; "selectionType": "selectionType"; "reorderable": "reorderable"; "headerHeight": "headerHeight"; "columns": "columns"; "offsetX": "offsetX"; }, { "sort": "sort"; "reorder": "reorder"; "resize": "resize"; "select": "select"; "columnContextmenu": "columnContextmenu"; }, never, never>;
74
+ static ɵcmp: i0.ɵɵComponentDeclaration<DataTableHeaderComponent, "datatable-header", never, { "sortAscendingIcon": { "alias": "sortAscendingIcon"; "required": false; }; "sortDescendingIcon": { "alias": "sortDescendingIcon"; "required": false; }; "sortUnsetIcon": { "alias": "sortUnsetIcon"; "required": false; }; "scrollbarH": { "alias": "scrollbarH"; "required": false; }; "dealsWithGroup": { "alias": "dealsWithGroup"; "required": false; }; "targetMarkerTemplate": { "alias": "targetMarkerTemplate"; "required": false; }; "enableClearingSortState": { "alias": "enableClearingSortState"; "required": false; }; "innerWidth": { "alias": "innerWidth"; "required": false; }; "sorts": { "alias": "sorts"; "required": false; }; "sortType": { "alias": "sortType"; "required": false; }; "allRowsSelected": { "alias": "allRowsSelected"; "required": false; }; "selectionType": { "alias": "selectionType"; "required": false; }; "reorderable": { "alias": "reorderable"; "required": false; }; "verticalScrollVisible": { "alias": "verticalScrollVisible"; "required": false; }; "headerHeight": { "alias": "headerHeight"; "required": false; }; "columns": { "alias": "columns"; "required": false; }; "offsetX": { "alias": "offsetX"; "required": false; }; }, { "sort": "sort"; "reorder": "reorder"; "resize": "resize"; "resizing": "resizing"; "select": "select"; "columnContextmenu": "columnContextmenu"; }, never, never, true, never>;
70
75
  }
@@ -1,8 +1,7 @@
1
- import { TemplateRef } from '@angular/core';
1
+ import { RowDetailContext } from '../../types/public.types';
2
2
  import * as i0 from "@angular/core";
3
3
  export declare class DatatableRowDetailTemplateDirective {
4
- template: TemplateRef<any>;
5
- constructor(template: TemplateRef<any>);
4
+ static ngTemplateContextGuard(directive: DatatableRowDetailTemplateDirective, context: unknown): context is RowDetailContext;
6
5
  static ɵfac: i0.ɵɵFactoryDeclaration<DatatableRowDetailTemplateDirective, never>;
7
- static ɵdir: i0.ɵɵDirectiveDeclaration<DatatableRowDetailTemplateDirective, "[ngx-datatable-row-detail-template]", never, {}, {}, never>;
6
+ static ɵdir: i0.ɵɵDirectiveDeclaration<DatatableRowDetailTemplateDirective, "[ngx-datatable-row-detail-template]", never, {}, {}, never, never, true, never>;
8
7
  }
@@ -1,14 +1,15 @@
1
1
  import { EventEmitter, TemplateRef } from '@angular/core';
2
+ import { RowDetailContext } from '../../types/public.types';
2
3
  import * as i0 from "@angular/core";
3
- export declare class DatatableRowDetailDirective {
4
+ export declare class DatatableRowDetailDirective<TRow = any> {
4
5
  /**
5
6
  * The detail row height is required especially
6
7
  * when virtual scroll is enabled.
7
8
  */
8
- rowHeight: number | ((row?: any, index?: number) => number);
9
- _templateInput: TemplateRef<any>;
10
- _templateQuery: TemplateRef<any>;
11
- get template(): TemplateRef<any>;
9
+ rowHeight: number | ((row?: TRow, index?: number) => number);
10
+ _templateInput: TemplateRef<RowDetailContext<TRow>>;
11
+ _templateQuery: TemplateRef<RowDetailContext<TRow>>;
12
+ get template(): TemplateRef<RowDetailContext<TRow>>;
12
13
  /**
13
14
  * Row detail row visbility was toggled.
14
15
  */
@@ -16,7 +17,7 @@ export declare class DatatableRowDetailDirective {
16
17
  /**
17
18
  * Toggle the expansion of the row
18
19
  */
19
- toggleExpandRow(row: any): void;
20
+ toggleExpandRow(row: TRow): void;
20
21
  /**
21
22
  * API method to expand all the rows.
22
23
  */
@@ -25,6 +26,6 @@ export declare class DatatableRowDetailDirective {
25
26
  * API method to collapse all the rows.
26
27
  */
27
28
  collapseAllRows(): void;
28
- static ɵfac: i0.ɵɵFactoryDeclaration<DatatableRowDetailDirective, never>;
29
- static ɵdir: i0.ɵɵDirectiveDeclaration<DatatableRowDetailDirective, "ngx-datatable-row-detail", never, { "rowHeight": "rowHeight"; "_templateInput": "template"; }, { "toggle": "toggle"; }, ["_templateQuery"]>;
29
+ static ɵfac: i0.ɵɵFactoryDeclaration<DatatableRowDetailDirective<any>, never>;
30
+ static ɵdir: i0.ɵɵDirectiveDeclaration<DatatableRowDetailDirective<any>, "ngx-datatable-row-detail", never, { "rowHeight": { "alias": "rowHeight"; "required": false; }; "_templateInput": { "alias": "template"; "required": false; }; }, { "toggle": "toggle"; }, ["_templateQuery"], never, true, never>;
30
31
  }
@@ -0,0 +1,22 @@
1
+ import * as i0 from "@angular/core";
2
+ /**
3
+ * Row Disable Directive
4
+ * Use this to disable/enable all children elements
5
+ * Usage:
6
+ * To disable
7
+ * <div [disabled]="true" disable-row >
8
+ * </div>
9
+ * To enable
10
+ * <div [disabled]="false" disable-row >
11
+ * </div>
12
+ */
13
+ export declare class DisableRowDirective {
14
+ private element;
15
+ private _disabled;
16
+ set disabled(val: boolean);
17
+ get disabled(): boolean;
18
+ disableAllElements(): void;
19
+ static ɵfac: i0.ɵɵFactoryDeclaration<DisableRowDirective, never>;
20
+ static ɵdir: i0.ɵɵDirectiveDeclaration<DisableRowDirective, "[disable-row]", never, { "disabled": { "alias": "disabled"; "required": false; }; }, {}, never, never, true, never>;
21
+ static ngAcceptInputType_disabled: unknown;
22
+ }
@@ -1,5 +1,7 @@
1
- import { ElementRef, EventEmitter, OnDestroy, OnChanges, SimpleChanges } from '@angular/core';
1
+ import { EventEmitter, OnChanges, OnDestroy, SimpleChanges } from '@angular/core';
2
2
  import { Subscription } from 'rxjs';
3
+ import { TableColumn } from '../types/table-column.type';
4
+ import { DraggableDragEvent } from '../types/internal.types';
3
5
  import * as i0 from "@angular/core";
4
6
  /**
5
7
  * Draggable Directive for Angular2
@@ -11,16 +13,15 @@ import * as i0 from "@angular/core";
11
13
  */
12
14
  export declare class DraggableDirective implements OnDestroy, OnChanges {
13
15
  dragEventTarget: any;
14
- dragModel: any;
16
+ dragModel: TableColumn;
15
17
  dragX: boolean;
16
18
  dragY: boolean;
17
- dragStart: EventEmitter<any>;
18
- dragging: EventEmitter<any>;
19
- dragEnd: EventEmitter<any>;
20
- element: HTMLElement;
19
+ dragStart: EventEmitter<DraggableDragEvent>;
20
+ dragging: EventEmitter<DraggableDragEvent>;
21
+ dragEnd: EventEmitter<DraggableDragEvent>;
22
+ element: any;
21
23
  isDragging: boolean;
22
24
  subscription: Subscription;
23
- constructor(element: ElementRef);
24
25
  ngOnChanges(changes: SimpleChanges): void;
25
26
  ngOnDestroy(): void;
26
27
  onMouseup(event: MouseEvent): void;
@@ -31,5 +32,7 @@ export declare class DraggableDirective implements OnDestroy, OnChanges {
31
32
  }): void;
32
33
  private _destroySubscription;
33
34
  static ɵfac: i0.ɵɵFactoryDeclaration<DraggableDirective, never>;
34
- static ɵdir: i0.ɵɵDirectiveDeclaration<DraggableDirective, "[draggable]", never, { "dragEventTarget": "dragEventTarget"; "dragModel": "dragModel"; "dragX": "dragX"; "dragY": "dragY"; }, { "dragStart": "dragStart"; "dragging": "dragging"; "dragEnd": "dragEnd"; }, never>;
35
+ static ɵdir: i0.ɵɵDirectiveDeclaration<DraggableDirective, "[draggable]", never, { "dragEventTarget": { "alias": "dragEventTarget"; "required": false; }; "dragModel": { "alias": "dragModel"; "required": false; }; "dragX": { "alias": "dragX"; "required": false; }; "dragY": { "alias": "dragY"; "required": false; }; }, { "dragStart": "dragStart"; "dragging": "dragging"; "dragEnd": "dragEnd"; }, never, never, true, never>;
36
+ static ngAcceptInputType_dragX: unknown;
37
+ static ngAcceptInputType_dragY: unknown;
35
38
  }
@@ -1,13 +1,22 @@
1
1
  import { EventEmitter, OnDestroy } from '@angular/core';
2
2
  import { Subscription } from 'rxjs';
3
+ import { TableColumn } from '../types/table-column.type';
3
4
  import * as i0 from "@angular/core";
4
5
  export declare class LongPressDirective implements OnDestroy {
5
6
  pressEnabled: boolean;
6
- pressModel: any;
7
+ pressModel: TableColumn;
7
8
  duration: number;
8
- longPressStart: EventEmitter<any>;
9
- longPressing: EventEmitter<any>;
10
- longPressEnd: EventEmitter<any>;
9
+ longPressStart: EventEmitter<{
10
+ event: MouseEvent;
11
+ model: TableColumn;
12
+ }>;
13
+ longPressing: EventEmitter<{
14
+ event: MouseEvent;
15
+ model: TableColumn;
16
+ }>;
17
+ longPressEnd: EventEmitter<{
18
+ model: TableColumn;
19
+ }>;
11
20
  pressing: boolean;
12
21
  isLongPressing: boolean;
13
22
  timeout: any;
@@ -24,5 +33,7 @@ export declare class LongPressDirective implements OnDestroy {
24
33
  ngOnDestroy(): void;
25
34
  private _destroySubscription;
26
35
  static ɵfac: i0.ɵɵFactoryDeclaration<LongPressDirective, never>;
27
- static ɵdir: i0.ɵɵDirectiveDeclaration<LongPressDirective, "[long-press]", never, { "pressEnabled": "pressEnabled"; "pressModel": "pressModel"; "duration": "duration"; }, { "longPressStart": "longPressStart"; "longPressing": "longPressing"; "longPressEnd": "longPressEnd"; }, never>;
36
+ static ɵdir: i0.ɵɵDirectiveDeclaration<LongPressDirective, "[long-press]", never, { "pressEnabled": { "alias": "pressEnabled"; "required": false; }; "pressModel": { "alias": "pressModel"; "required": false; }; "duration": { "alias": "duration"; "required": false; }; }, { "longPressStart": "longPressStart"; "longPressing": "longPressing"; "longPressEnd": "longPressEnd"; }, never, never, true, never>;
37
+ static ngAcceptInputType_pressEnabled: unknown;
38
+ static ngAcceptInputType_duration: unknown;
28
39
  }
@@ -1,23 +1,34 @@
1
- import { EventEmitter, QueryList, KeyValueDiffers, AfterContentInit, OnDestroy } from '@angular/core';
1
+ import { AfterContentInit, EventEmitter, KeyValueDiffer, OnDestroy, QueryList } from '@angular/core';
2
2
  import { DraggableDirective } from './draggable.directive';
3
+ import { TableColumn } from '../types/table-column.type';
4
+ import { DraggableDragEvent, OrderableReorderEvent, TargetChangedEvent } from '../types/internal.types';
3
5
  import * as i0 from "@angular/core";
6
+ interface OrderPosition {
7
+ left: number;
8
+ right: number;
9
+ index: number;
10
+ element: HTMLElement;
11
+ }
4
12
  export declare class OrderableDirective implements AfterContentInit, OnDestroy {
5
13
  private document;
6
- reorder: EventEmitter<any>;
7
- targetChanged: EventEmitter<any>;
14
+ reorder: EventEmitter<OrderableReorderEvent>;
15
+ targetChanged: EventEmitter<TargetChangedEvent>;
8
16
  draggables: QueryList<DraggableDirective>;
9
- positions: any;
10
- differ: any;
17
+ positions: Record<string, OrderPosition>;
18
+ differ: KeyValueDiffer<string, DraggableDirective>;
11
19
  lastDraggingIndex: number;
12
- constructor(differs: KeyValueDiffers, document: any);
13
20
  ngAfterContentInit(): void;
14
21
  ngOnDestroy(): void;
15
22
  updateSubscriptions(): void;
16
23
  onDragStart(): void;
17
- onDragging({ element, model, event }: any): void;
18
- onDragEnd({ element, model, event }: any): void;
19
- isTarget(model: any, event: any): any;
24
+ onDragging({ element, model, event }: DraggableDragEvent): void;
25
+ onDragEnd({ element, model, event }: DraggableDragEvent): void;
26
+ isTarget(model: TableColumn, event: MouseEvent): {
27
+ pos: OrderPosition;
28
+ i: number;
29
+ };
20
30
  private createMapDiffs;
21
31
  static ɵfac: i0.ɵɵFactoryDeclaration<OrderableDirective, never>;
22
- static ɵdir: i0.ɵɵDirectiveDeclaration<OrderableDirective, "[orderable]", never, {}, { "reorder": "reorder"; "targetChanged": "targetChanged"; }, ["draggables"]>;
32
+ static ɵdir: i0.ɵɵDirectiveDeclaration<OrderableDirective, "[orderable]", never, {}, { "reorder": "reorder"; "targetChanged": "targetChanged"; }, ["draggables"], never, true, never>;
23
33
  }
34
+ export {};
@@ -1,4 +1,4 @@
1
- import { ElementRef, EventEmitter, OnDestroy, AfterViewInit, Renderer2 } from '@angular/core';
1
+ import { AfterViewInit, EventEmitter, OnDestroy } from '@angular/core';
2
2
  import { Subscription } from 'rxjs';
3
3
  import * as i0 from "@angular/core";
4
4
  export declare class ResizeableDirective implements OnDestroy, AfterViewInit {
@@ -7,11 +7,10 @@ export declare class ResizeableDirective implements OnDestroy, AfterViewInit {
7
7
  minWidth: number;
8
8
  maxWidth: number;
9
9
  resize: EventEmitter<any>;
10
- element: HTMLElement;
10
+ resizing: EventEmitter<any>;
11
+ element: any;
11
12
  subscription: Subscription;
12
- resizing: boolean;
13
13
  private resizeHandle;
14
- constructor(element: ElementRef, renderer: Renderer2);
15
14
  ngAfterViewInit(): void;
16
15
  ngOnDestroy(): void;
17
16
  onMouseup(): void;
@@ -19,5 +18,8 @@ export declare class ResizeableDirective implements OnDestroy, AfterViewInit {
19
18
  move(event: MouseEvent, initialWidth: number, mouseDownScreenX: number): void;
20
19
  private _destroySubscription;
21
20
  static ɵfac: i0.ɵɵFactoryDeclaration<ResizeableDirective, never>;
22
- static ɵdir: i0.ɵɵDirectiveDeclaration<ResizeableDirective, "[resizeable]", never, { "resizeEnabled": "resizeEnabled"; "minWidth": "minWidth"; "maxWidth": "maxWidth"; }, { "resize": "resize"; }, never>;
21
+ static ɵdir: i0.ɵɵDirectiveDeclaration<ResizeableDirective, "[resizeable]", never, { "resizeEnabled": { "alias": "resizeEnabled"; "required": false; }; "minWidth": { "alias": "minWidth"; "required": false; }; "maxWidth": { "alias": "maxWidth"; "required": false; }; }, { "resize": "resize"; "resizing": "resizing"; }, never, never, true, never>;
22
+ static ngAcceptInputType_resizeEnabled: unknown;
23
+ static ngAcceptInputType_minWidth: unknown;
24
+ static ngAcceptInputType_maxWidth: unknown;
23
25
  }
@@ -1,4 +1,4 @@
1
- import { EventEmitter, ElementRef, NgZone, OnInit, OnDestroy } from '@angular/core';
1
+ import { EventEmitter, OnDestroy, OnInit } from '@angular/core';
2
2
  import * as i0 from "@angular/core";
3
3
  /**
4
4
  * Visibility Observer Directive
@@ -17,11 +17,10 @@ export declare class VisibilityDirective implements OnInit, OnDestroy {
17
17
  isVisible: boolean;
18
18
  visible: EventEmitter<any>;
19
19
  timeout: any;
20
- constructor(element: ElementRef, zone: NgZone);
21
20
  ngOnInit(): void;
22
21
  ngOnDestroy(): void;
23
22
  onVisibilityChange(): void;
24
23
  runCheck(): void;
25
24
  static ɵfac: i0.ɵɵFactoryDeclaration<VisibilityDirective, never>;
26
- static ɵdir: i0.ɵɵDirectiveDeclaration<VisibilityDirective, "[visibilityObserver]", never, {}, { "visible": "visible"; }, never>;
25
+ static ɵdir: i0.ɵɵDirectiveDeclaration<VisibilityDirective, "[visibilityObserver]", never, {}, { "visible": "visible"; }, never, never, true, never>;
27
26
  }
@@ -1,34 +1,20 @@
1
1
  import { ModuleWithProviders } from '@angular/core';
2
2
  import * as i0 from "@angular/core";
3
3
  import * as i1 from "./components/footer/footer-template.directive";
4
- import * as i2 from "./directives/visibility.directive";
5
- import * as i3 from "./directives/draggable.directive";
6
- import * as i4 from "./directives/resizeable.directive";
7
- import * as i5 from "./directives/orderable.directive";
8
- import * as i6 from "./directives/long-press.directive";
9
- import * as i7 from "./components/body/scroller.component";
10
- import * as i8 from "./components/datatable.component";
11
- import * as i9 from "./components/columns/column.directive";
12
- import * as i10 from "./components/header/header.component";
13
- import * as i11 from "./components/header/header-cell.component";
14
- import * as i12 from "./components/body/body.component";
15
- import * as i13 from "./components/footer/footer.component";
16
- import * as i14 from "./components/footer/pager.component";
17
- import * as i15 from "./components/body/progress-bar.component";
18
- import * as i16 from "./components/body/body-row.component";
19
- import * as i17 from "./components/body/body-row-wrapper.component";
20
- import * as i18 from "./components/row-detail/row-detail.directive";
21
- import * as i19 from "./components/body/body-group-header.directive";
22
- import * as i20 from "./components/row-detail/row-detail-template.directive";
23
- import * as i21 from "./components/body/body-cell.component";
24
- import * as i22 from "./components/body/selection.component";
25
- import * as i23 from "./components/columns/column-header.directive";
26
- import * as i24 from "./components/columns/column-cell.directive";
27
- import * as i25 from "./components/columns/tree.directive";
28
- import * as i26 from "./components/footer/footer.directive";
29
- import * as i27 from "./components/body/body-group-header-template.directive";
30
- import * as i28 from "./components/body/summary/summary-row.component";
31
- import * as i29 from "@angular/common";
4
+ import * as i2 from "./components/datatable.component";
5
+ import * as i3 from "./components/columns/column.directive";
6
+ import * as i4 from "./components/footer/pager.component";
7
+ import * as i5 from "./components/row-detail/row-detail.directive";
8
+ import * as i6 from "./components/body/body-group-header.directive";
9
+ import * as i7 from "./components/row-detail/row-detail-template.directive";
10
+ import * as i8 from "./components/columns/column-header.directive";
11
+ import * as i9 from "./components/columns/column-cell.directive";
12
+ import * as i10 from "./components/columns/column-ghost-cell.directive";
13
+ import * as i11 from "./components/columns/tree.directive";
14
+ import * as i12 from "./components/footer/footer.directive";
15
+ import * as i13 from "./components/body/body-group-header-template.directive";
16
+ import * as i14 from "./directives/disable-row.directive";
17
+ import * as i15 from "./components/body/body-row-def.component";
32
18
  export declare class NgxDatatableModule {
33
19
  /**
34
20
  * Configure global configuration via INgxDatatableConfig
@@ -36,16 +22,29 @@ export declare class NgxDatatableModule {
36
22
  */
37
23
  static forRoot(configuration: INgxDatatableConfig): ModuleWithProviders<NgxDatatableModule>;
38
24
  static ɵfac: i0.ɵɵFactoryDeclaration<NgxDatatableModule, never>;
39
- static ɵmod: i0.ɵɵNgModuleDeclaration<NgxDatatableModule, [typeof i1.DataTableFooterTemplateDirective, typeof i2.VisibilityDirective, typeof i3.DraggableDirective, typeof i4.ResizeableDirective, typeof i5.OrderableDirective, typeof i6.LongPressDirective, typeof i7.ScrollerComponent, typeof i8.DatatableComponent, typeof i9.DataTableColumnDirective, typeof i10.DataTableHeaderComponent, typeof i11.DataTableHeaderCellComponent, typeof i12.DataTableBodyComponent, typeof i13.DataTableFooterComponent, typeof i14.DataTablePagerComponent, typeof i15.ProgressBarComponent, typeof i16.DataTableBodyRowComponent, typeof i17.DataTableRowWrapperComponent, typeof i18.DatatableRowDetailDirective, typeof i19.DatatableGroupHeaderDirective, typeof i20.DatatableRowDetailTemplateDirective, typeof i21.DataTableBodyCellComponent, typeof i22.DataTableSelectionComponent, typeof i23.DataTableColumnHeaderDirective, typeof i24.DataTableColumnCellDirective, typeof i25.DataTableColumnCellTreeToggle, typeof i26.DatatableFooterDirective, typeof i27.DatatableGroupHeaderTemplateDirective, typeof i28.DataTableSummaryRowComponent], [typeof i29.CommonModule], [typeof i8.DatatableComponent, typeof i18.DatatableRowDetailDirective, typeof i19.DatatableGroupHeaderDirective, typeof i20.DatatableRowDetailTemplateDirective, typeof i9.DataTableColumnDirective, typeof i23.DataTableColumnHeaderDirective, typeof i24.DataTableColumnCellDirective, typeof i25.DataTableColumnCellTreeToggle, typeof i1.DataTableFooterTemplateDirective, typeof i26.DatatableFooterDirective, typeof i14.DataTablePagerComponent, typeof i27.DatatableGroupHeaderTemplateDirective]>;
25
+ static ɵmod: i0.ɵɵNgModuleDeclaration<NgxDatatableModule, never, [typeof i1.DataTableFooterTemplateDirective, typeof i2.DatatableComponent, typeof i3.DataTableColumnDirective, typeof i4.DataTablePagerComponent, typeof i5.DatatableRowDetailDirective, typeof i6.DatatableGroupHeaderDirective, typeof i7.DatatableRowDetailTemplateDirective, typeof i8.DataTableColumnHeaderDirective, typeof i9.DataTableColumnCellDirective, typeof i10.DataTableColumnGhostCellDirective, typeof i11.DataTableColumnCellTreeToggle, typeof i12.DatatableFooterDirective, typeof i13.DatatableGroupHeaderTemplateDirective, typeof i14.DisableRowDirective, typeof i15.DatatableRowDefComponent, typeof i15.DatatableRowDefDirective], [typeof i2.DatatableComponent, typeof i5.DatatableRowDetailDirective, typeof i6.DatatableGroupHeaderDirective, typeof i7.DatatableRowDetailTemplateDirective, typeof i3.DataTableColumnDirective, typeof i8.DataTableColumnHeaderDirective, typeof i9.DataTableColumnCellDirective, typeof i10.DataTableColumnGhostCellDirective, typeof i11.DataTableColumnCellTreeToggle, typeof i1.DataTableFooterTemplateDirective, typeof i12.DatatableFooterDirective, typeof i4.DataTablePagerComponent, typeof i13.DatatableGroupHeaderTemplateDirective, typeof i14.DisableRowDirective, typeof i15.DatatableRowDefComponent, typeof i15.DatatableRowDefDirective]>;
40
26
  static ɵinj: i0.ɵɵInjectorDeclaration<NgxDatatableModule>;
41
27
  }
42
28
  /**
43
29
  * Interface definition for INgxDatatableConfig global configuration
44
30
  */
45
31
  export interface INgxDatatableConfig {
46
- messages: {
32
+ messages?: {
47
33
  emptyMessage: string;
48
34
  totalMessage: string;
49
35
  selectedMessage: string;
50
36
  };
37
+ cssClasses?: {
38
+ sortAscending: string;
39
+ sortDescending: string;
40
+ sortUnset: string;
41
+ pagerLeftArrow: string;
42
+ pagerRightArrow: string;
43
+ pagerPrevious: string;
44
+ pagerNext: string;
45
+ };
46
+ headerHeight?: number;
47
+ footerHeight?: number;
48
+ rowHeight?: number;
49
+ defaultColumnWidth?: number;
51
50
  }
@@ -6,7 +6,6 @@ import * as i0 from "@angular/core";
6
6
  export declare class ScrollbarHelper {
7
7
  private document;
8
8
  width: number;
9
- constructor(document: any);
10
9
  getWidth(): number;
11
10
  static ɵfac: i0.ɵɵFactoryDeclaration<ScrollbarHelper, never>;
12
11
  static ɵprov: i0.ɵɵInjectableDeclaration<ScrollbarHelper>;
@@ -0,0 +1,31 @@
1
+ import { TableColumn } from './table-column.type';
2
+ export type PinDirection = 'left' | 'center' | 'right';
3
+ export interface PinnedColumns {
4
+ type: PinDirection;
5
+ columns: TableColumn[];
6
+ }
7
+ export interface ColumnGroupWidth {
8
+ left: number;
9
+ center: number;
10
+ right: number;
11
+ total: number;
12
+ }
13
+ export interface OrderableReorderEvent {
14
+ prevIndex: number;
15
+ newIndex: number;
16
+ model: TableColumn;
17
+ }
18
+ export interface TargetChangedEvent {
19
+ newIndex?: number;
20
+ prevIndex: number;
21
+ initialIndex: number;
22
+ }
23
+ export interface Page {
24
+ number: number;
25
+ text: string;
26
+ }
27
+ export interface DraggableDragEvent {
28
+ event: MouseEvent;
29
+ element: HTMLElement;
30
+ model: TableColumn;
31
+ }