@acorex/components 18.14.1-next.5 → 18.15.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (82) hide show
  1. package/comment/lib/comment-container/comment-container.component.d.ts +1 -0
  2. package/common/lib/components/value-component.class.d.ts +1 -0
  3. package/common/lib/directives/auto-focus.directive.d.ts +1 -0
  4. package/common/lib/directives/ripple.directive.d.ts +1 -0
  5. package/data-table/lib/columns/data-table-column-resizable.directive.d.ts +1 -0
  6. package/data-table/lib/data-table/data-table.component.d.ts +61 -60
  7. package/data-table/lib/infinite-scroll-data-table/infinite-scroll-data-table.component.d.ts +7 -6
  8. package/drawer/lib/drawer/drawer-item/drawer.component.d.ts +2 -0
  9. package/esm2022/audio-wave/lib/audio-wave.component.mjs +79 -14
  10. package/esm2022/avatar/lib/avatar.component.mjs +2 -2
  11. package/esm2022/button/lib/button.component.mjs +2 -2
  12. package/esm2022/calendar/lib/calendar-range.component.mjs +2 -2
  13. package/esm2022/calendar/lib/calendar.component.mjs +3 -3
  14. package/esm2022/comment/lib/comment-container/comment-container.component.mjs +7 -3
  15. package/esm2022/common/lib/components/value-component.class.mjs +4 -2
  16. package/esm2022/common/lib/directives/auto-focus.directive.mjs +5 -3
  17. package/esm2022/common/lib/directives/inverted-color.directive.mjs +1 -1
  18. package/esm2022/common/lib/directives/ripple.directive.mjs +5 -3
  19. package/esm2022/conversation/lib/conversation-message/conversation-message.component.mjs +2 -2
  20. package/esm2022/conversation/lib/conversation-messages/conversation-message-voice/conversation-message-voice.component.mjs +2 -2
  21. package/esm2022/cron-job/index.mjs +1 -1
  22. package/esm2022/cron-job/lib/cron-job-container/cron-job-container.component.mjs +3 -3
  23. package/esm2022/cron-job/lib/day/day.component.mjs +3 -3
  24. package/esm2022/cron-job/lib/hours/hours.component.mjs +3 -3
  25. package/esm2022/cron-job/lib/minutes/minutes.component.mjs +3 -3
  26. package/esm2022/cron-job/lib/month/month.component.mjs +3 -3
  27. package/esm2022/cron-job/lib/seconds/seconds.component.mjs +3 -3
  28. package/esm2022/cron-job/lib/year/year.component.mjs +3 -3
  29. package/esm2022/data-table/lib/columns/data-table-column-resizable.directive.mjs +9 -7
  30. package/esm2022/data-table/lib/data-table/data-table.component.mjs +71 -67
  31. package/esm2022/data-table/lib/infinite-scroll-data-table/infinite-scroll-data-table.component.mjs +16 -11
  32. package/esm2022/drawer/lib/drawer/drawer-item/drawer.component.mjs +5 -2
  33. package/esm2022/list/lib/list.component.mjs +17 -5
  34. package/esm2022/loading/lib/loading-spinner.component.mjs +2 -2
  35. package/esm2022/loading-dialog/lib/loading-dialog.component.mjs +2 -2
  36. package/esm2022/menu/lib/context-menu.component.mjs +28 -21
  37. package/esm2022/password-box/lib/password-box.component.mjs +13 -5
  38. package/esm2022/password-box/lib/password-box.module.mjs +19 -3
  39. package/esm2022/password-box/lib/password-strength-validation/password-strength-validation.component.mjs +36 -14
  40. package/esm2022/popover/lib/popover.component.mjs +5 -3
  41. package/esm2022/popup/lib/popup.component.mjs +2 -2
  42. package/esm2022/uploader/lib/uploader-zone.directive.mjs +7 -5
  43. package/fesm2022/acorex-components-audio-wave.mjs +78 -13
  44. package/fesm2022/acorex-components-audio-wave.mjs.map +1 -1
  45. package/fesm2022/acorex-components-avatar.mjs +2 -2
  46. package/fesm2022/acorex-components-avatar.mjs.map +1 -1
  47. package/fesm2022/acorex-components-button.mjs +2 -2
  48. package/fesm2022/acorex-components-calendar.mjs +4 -4
  49. package/fesm2022/acorex-components-calendar.mjs.map +1 -1
  50. package/fesm2022/acorex-components-comment.mjs +7 -4
  51. package/fesm2022/acorex-components-comment.mjs.map +1 -1
  52. package/fesm2022/acorex-components-common.mjs +6 -3
  53. package/fesm2022/acorex-components-common.mjs.map +1 -1
  54. package/fesm2022/acorex-components-conversation.mjs +2 -2
  55. package/fesm2022/acorex-components-conversation.mjs.map +1 -1
  56. package/fesm2022/acorex-components-cron-job.mjs +14 -14
  57. package/fesm2022/acorex-components-cron-job.mjs.map +1 -1
  58. package/fesm2022/acorex-components-data-table.mjs +89 -81
  59. package/fesm2022/acorex-components-data-table.mjs.map +1 -1
  60. package/fesm2022/acorex-components-drawer.mjs +4 -2
  61. package/fesm2022/acorex-components-drawer.mjs.map +1 -1
  62. package/fesm2022/acorex-components-list.mjs +16 -4
  63. package/fesm2022/acorex-components-list.mjs.map +1 -1
  64. package/fesm2022/acorex-components-loading-dialog.mjs +2 -2
  65. package/fesm2022/acorex-components-loading.mjs +2 -2
  66. package/fesm2022/acorex-components-loading.mjs.map +1 -1
  67. package/fesm2022/acorex-components-menu.mjs +24 -18
  68. package/fesm2022/acorex-components-menu.mjs.map +1 -1
  69. package/fesm2022/acorex-components-password-box.mjs +65 -19
  70. package/fesm2022/acorex-components-password-box.mjs.map +1 -1
  71. package/fesm2022/acorex-components-popover.mjs +4 -3
  72. package/fesm2022/acorex-components-popover.mjs.map +1 -1
  73. package/fesm2022/acorex-components-popup.mjs +2 -2
  74. package/fesm2022/acorex-components-uploader.mjs +7 -6
  75. package/fesm2022/acorex-components-uploader.mjs.map +1 -1
  76. package/menu/lib/context-menu.component.d.ts +2 -1
  77. package/package.json +1 -1
  78. package/password-box/lib/password-box.component.d.ts +9 -1
  79. package/password-box/lib/password-box.module.d.ts +3 -1
  80. package/password-box/lib/password-strength-validation/password-strength-validation.component.d.ts +23 -1
  81. package/popover/lib/popover.component.d.ts +1 -0
  82. package/uploader/lib/uploader-zone.directive.d.ts +1 -0
@@ -1,8 +1,9 @@
1
1
  import { AXHtmlUtil, AXUnsubscriber } from '@acorex/core/utils';
2
2
  import { moveItemInArray } from '@angular/cdk/drag-drop';
3
+ import { DOCUMENT } from '@angular/common';
3
4
  import { ChangeDetectionStrategy, Component, ContentChildren, EventEmitter, Input, NgZone, Output, QueryList, TemplateRef, ViewChild, ViewEncapsulation, computed, inject, signal, } from '@angular/core';
4
5
  import { Subject, buffer, debounceTime, filter } from 'rxjs';
5
- import { AXBaseDataTable } from '../base-data-table.class';
6
+ import { AXBaseDataTable, } from '../base-data-table.class';
6
7
  import { AXDataTableColumnComponent } from '../columns/data-table-column';
7
8
  import { AXDataTableTextColumnComponent } from '../columns/data-text-column.component';
8
9
  import * as i0 from "@angular/core";
@@ -23,6 +24,7 @@ export class AXDataTableComponent extends AXBaseDataTable {
23
24
  super(...arguments);
24
25
  this._unsubscriber = inject(AXUnsubscriber);
25
26
  this._zone = inject(NgZone);
27
+ this.document = inject(DOCUMENT);
26
28
  /**
27
29
  * @ignore
28
30
  */
@@ -104,73 +106,73 @@ export class AXDataTableComponent extends AXBaseDataTable {
104
106
  */
105
107
  this.fixedHeader = true;
106
108
  /**
107
- * Indicates if the table footer should be displayed.
108
- *
109
- * @defaultValue `false`
110
- */
109
+ * Indicates if the table footer should be displayed.
110
+ *
111
+ * @defaultValue `false`
112
+ */
111
113
  this.showFooter = false;
112
114
  /**
113
- * Indicates if the table footer should be fixed.
114
- *
115
- * @defaultValue `true`
116
- */
115
+ * Indicates if the table footer should be fixed.
116
+ *
117
+ * @defaultValue `true`
118
+ */
117
119
  this.fixedFooter = true;
118
120
  /**
119
- * Specifies the height of each item in the table.
120
- *
121
- * @defaultValue `40`
122
- */
121
+ * Specifies the height of each item in the table.
122
+ *
123
+ * @defaultValue `40`
124
+ */
123
125
  this.itemHeight = 40;
124
126
  /**
125
- * Enables or disables row reordering.
126
- *
127
- * @defaultValue `false`
128
- */
127
+ * Enables or disables row reordering.
128
+ *
129
+ * @defaultValue `false`
130
+ */
129
131
  this.allowReordering = false;
130
132
  /**
131
- * Enables or disables paging.
132
- *
133
- * @defaultValue `true`
134
- */
133
+ * Enables or disables paging.
134
+ *
135
+ * @defaultValue `true`
136
+ */
135
137
  this.paging = true;
136
138
  /**
137
- * Specifies how data should be fetched.
138
- *
139
- * @defaultValue `'auto'`
140
- */
139
+ * Specifies how data should be fetched.
140
+ *
141
+ * @defaultValue `'auto'`
142
+ */
141
143
  this.fetchDataMode = 'auto';
142
144
  /**
143
- * Configuration for loading state.
144
- *
145
- * @defaultValue `{ enabled: true, animation: true }`
146
- */
145
+ * Configuration for loading state.
146
+ *
147
+ * @defaultValue `{ enabled: true, animation: true }`
148
+ */
147
149
  this.loading = {
148
150
  enabled: true,
149
151
  animation: true,
150
152
  };
151
153
  /**
152
- * Emits when the focused row changes.
153
- *
154
- * @event
155
- */
154
+ * Emits when the focused row changes.
155
+ *
156
+ * @event
157
+ */
156
158
  this.focusedRowChange = new EventEmitter();
157
159
  /**
158
- * Emits when a row is clicked.
159
- *
160
- * @event onRowClick
161
- */
160
+ * Emits when a row is clicked.
161
+ *
162
+ * @event onRowClick
163
+ */
162
164
  this.onRowClick = new EventEmitter();
163
165
  /**
164
- * Emits when a row is double-clicked.
165
- *
166
- * @event onRowDbClick
167
- */
166
+ * Emits when a row is double-clicked.
167
+ *
168
+ * @event onRowDbClick
169
+ */
168
170
  this.onRowDbClick = new EventEmitter();
169
171
  /**
170
- * Emits when the order of columns changes.
171
- *
172
- * @event onColumnsOrderChanged
173
- */
172
+ * Emits when the order of columns changes.
173
+ *
174
+ * @event onColumnsOrderChanged
175
+ */
174
176
  this.onColumnsOrderChanged = new EventEmitter();
175
177
  /**
176
178
  * @ignore
@@ -181,7 +183,9 @@ export class AXDataTableComponent extends AXBaseDataTable {
181
183
  */
182
184
  this.onResizeColumnMove = (event) => {
183
185
  const diffX = event.pageX - this.resizeColumnProp.startX;
184
- const newWidth = this.rtl ? this.resizeColumnProp.startWidth - diffX : this.resizeColumnProp.startWidth + diffX;
186
+ const newWidth = this.rtl
187
+ ? this.resizeColumnProp.startWidth - diffX
188
+ : this.resizeColumnProp.startWidth + diffX;
185
189
  this.resizeColumnProp.thElement.style.width = `${Math.max(100, newWidth)}px`;
186
190
  this.resizeColumnProp.thElement.setAttribute('new-width', `${newWidth}`);
187
191
  };
@@ -189,24 +193,24 @@ export class AXDataTableComponent extends AXBaseDataTable {
189
193
  * @ignore
190
194
  */
191
195
  this.onResizeColumnEnd = () => {
192
- document.removeEventListener('mousemove', this.onResizeColumnMove);
193
- document.removeEventListener('mouseup', this.onResizeColumnEnd);
196
+ this.document.removeEventListener('mousemove', this.onResizeColumnMove);
197
+ this.document.removeEventListener('mouseup', this.onResizeColumnEnd);
194
198
  const newWidth = parseInt(this.resizeColumnProp.thElement.attributes.getNamedItem('new-width').value);
195
199
  this.columns.get(this.resizeColumnProp.columnIndex).width = `${Math.max(100, newWidth)}px`;
196
200
  this.resetResizingProcess();
197
201
  };
198
202
  }
199
203
  /**
200
- * Gets the currently focused row.
201
- */
204
+ * Gets the currently focused row.
205
+ */
202
206
  get focusedRow() {
203
207
  return this._focusedRow;
204
208
  }
205
209
  /**
206
- * Sets the currently focused row and emits the change event.
207
- *
208
- * @param v - The row to be focused.
209
- */
210
+ * Sets the currently focused row and emits the change event.
211
+ *
212
+ * @param v - The row to be focused.
213
+ */
210
214
  set focusedRow(v) {
211
215
  this._focusedRow = v;
212
216
  this.focusedRowChange.emit(v);
@@ -320,13 +324,13 @@ export class AXDataTableComponent extends AXBaseDataTable {
320
324
  });
321
325
  }
322
326
  /**
323
- * Handles the click event on a column header.
324
- * Toggles the sorting direction or removes the sort if already sorted.
325
- *
326
- * @param e - The mouse event triggered by the click.
327
- * @param column - The column that was clicked.
328
- * @ignore
329
- */
327
+ * Handles the click event on a column header.
328
+ * Toggles the sorting direction or removes the sort if already sorted.
329
+ *
330
+ * @param e - The mouse event triggered by the click.
331
+ * @param column - The column that was clicked.
332
+ * @ignore
333
+ */
330
334
  handleColumnClick(e, column) {
331
335
  if (column instanceof AXDataTableTextColumnComponent) {
332
336
  const sort = this.dataSource.query.sort.find((c) => c.field == column.dataField);
@@ -358,9 +362,9 @@ export class AXDataTableComponent extends AXBaseDataTable {
358
362
  return undefined;
359
363
  }
360
364
  /**
361
- * Refreshes the data in the data source and resets the data pager to the first page.
362
- * @ignore
363
- */
365
+ * Refreshes the data in the data source and resets the data pager to the first page.
366
+ * @ignore
367
+ */
364
368
  refresh() {
365
369
  this.dataSource.refresh();
366
370
  if (this.dataPager) {
@@ -384,8 +388,8 @@ export class AXDataTableComponent extends AXBaseDataTable {
384
388
  this.resizeColumnProp.startWidth = parseInt(this.resizeColumnProp.thElement.style.width);
385
389
  this.resizeColumnProp.columnIndex = columnIndex;
386
390
  this._zone.runOutsideAngular(() => {
387
- document.addEventListener('mousemove', this.onResizeColumnMove);
388
- document.addEventListener('mouseup', this.onResizeColumnEnd);
391
+ this.document.addEventListener('mousemove', this.onResizeColumnMove);
392
+ this.document.addEventListener('mouseup', this.onResizeColumnEnd);
389
393
  });
390
394
  }
391
395
  /**
@@ -501,4 +505,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImpor
501
505
  type: ContentChildren,
502
506
  args: [AXDataTableColumnComponent]
503
507
  }] } });
504
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-table.component.js","sourceRoot":"","sources":["../../../../../../../libs/components/data-table/src/lib/data-table/data-table.component.ts","../../../../../../../libs/components/data-table/src/lib/data-table/data-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AXDataPagerChangedEvent } from '@acorex/components/data-pager';\nimport { AXHtmlUtil, AXUnsubscriber } from '@acorex/core/utils';\nimport { CdkDragDrop, moveItemInArray } from '@angular/cdk/drag-drop';\nimport {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  Component,\n  ContentChildren,\n  EventEmitter,\n  Input,\n  NgZone,\n  OnInit,\n  Output,\n  QueryList,\n  Signal,\n  TemplateRef,\n  ViewChild,\n  ViewEncapsulation,\n  WritableSignal,\n  computed,\n  inject,\n  signal,\n} from '@angular/core';\nimport { Subject, buffer, debounceTime, filter } from 'rxjs';\nimport { AXBaseDataTable, AXColumnsOrderChangedEvent, AXDataTableRowClick, AXDataTableRowDbClick } from '../base-data-table.class';\nimport { AXDataTableColumnComponent } from '../columns/data-table-column';\nimport { AXDataTableTextColumnComponent } from '../columns/data-text-column.component';\n\n/**\n * Component for displaying and managing a data table with advanced features.\n *\n * @category Components\n */\n@Component({\n  selector: 'ax-data-table',\n  templateUrl: './data-table.component.html',\n  styleUrls: ['./data-table.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  host: { ngSkipHydration: 'true' },\n  inputs: ['dataSource'],\n  outputs: ['selectedRowsChange'],\n  providers: [\n    {\n      provide: AXBaseDataTable,\n      useExisting: AXDataTableComponent,\n    },\n    AXUnsubscriber,\n  ],\n})\nexport class AXDataTableComponent extends AXBaseDataTable implements OnInit, AfterViewInit {\n  private _unsubscriber = inject(AXUnsubscriber);\n  private _zone = inject(NgZone);\n\n  /**\n   *  @ignore\n   */\n  @ViewChild('dataPager') dataPager;\n\n  /**\n   *  @ignore\n   */\n  protected rtl!: boolean;\n\n  /**\n   *  @ignore\n   */\n  protected displayedRows: WritableSignal<any[]> = signal([]);\n\n  /**\n   *  @ignore\n   */\n  protected page: WritableSignal<number> = signal(0);\n\n  /**\n   *  @ignore\n   */\n  protected pageSize: WritableSignal<number> = signal(0);\n\n  /**\n   *  @ignore\n   */\n  protected isLoading: WritableSignal<boolean> = signal(true);\n\n  /**\n   *  @ignore\n   */\n  protected columnsList: WritableSignal<any[]> = signal([]);\n\n  /**\n   *  @ignore\n   */\n  protected endFixedColumnsList: Signal<any[]> = computed(() => this.columnsList().filter((c) => c.fixed === 'end'));\n\n  /**\n   *  @ignore\n   */\n  protected startFixedColumnsList: Signal<any[]> = computed(() => this.columnsList().filter((c) => c.fixed === 'start'));\n\n  /**\n   *  @ignore\n   */\n  protected normalColumnsList: Signal<any[]> = computed(() => this.columnsList().filter((c) => c.fixed !== 'end' && c.fixed !== 'start'));\n\n  /**\n   *  @ignore\n   */\n  protected resizeColumnProp = {\n    startX: 0,\n    startWidth: 0,\n    columnIndex: 0,\n    newColumnWidth: 0,\n    thElement: null,\n  };\n\n  /**\n   *  @ignore\n   */\n  protected hasItems = false;\n\n  /**\n   *  @ignore\n   */\n  protected totalRows = 0;\n\n  /**\n   *  @ignore\n   */\n  protected currentPage = 0;\n\n  /**\n   *  @ignore\n   */\n  protected totalPages = 0;\n\n  /**\n   *  @ignore\n   */\n  protected startRowIndex = 0;\n\n  /**\n   * Template for custom row content.\n   */\n  @Input()\n  rowTemplate?: TemplateRef<unknown>;\n\n  /**\n   * Template to display when the table is empty.\n   */\n  @Input()\n  emptyTemplate?: TemplateRef<unknown>;\n\n/**\n * Defines if alternative row styling should be applied.\n * \n * @defaultValue `true`\n */\n  @Input()\n  alternative = true;\n\n  /**\n   * Indicates if the table header should be displayed.\n   *\n   * @defaultValue `true`\n   */\n  @Input()\n  showHeader = true;\n\n  /**\n   * Indicates if the table header should be fixed.\n   *\n   * @defaultValue `true`\n   */\n  @Input()\n  fixedHeader = true;\n\n   /**\n   * Indicates if the table footer should be displayed.\n   * \n   * @defaultValue `false`\n   */\n  @Input()\n  showFooter = false;\n\n    /**\n   * Indicates if the table footer should be fixed.\n   * \n   * @defaultValue `true`\n   */\n  @Input()\n  fixedFooter = true;\n\n    /**\n   * Specifies the height of each item in the table.\n   * \n   * @defaultValue `40`\n   */\n  @Input()\n  itemHeight: number | 'auto' = 40;\n\n   /**\n   * Enables or disables row reordering.\n   * \n   * @defaultValue `false`\n   */\n  @Input()\n  allowReordering = false;\n\n    /**\n   * Enables or disables paging.\n   * \n   * @defaultValue `true`\n   */\n  @Input()\n  paging = true;\n\n    /**\n   * Specifies how data should be fetched.\n   * \n   * @defaultValue `'auto'`\n   */\n  @Input()\n  fetchDataMode: 'auto' | 'manual' = 'auto';\n\n    /**\n   * Configuration for loading state.\n   * \n   * @defaultValue `{ enabled: true, animation: true }`\n   */\n  @Input()\n  loading: {\n    enabled: boolean;\n    animation: boolean;\n    loadingTemplate?: TemplateRef<unknown>;\n  } = {\n    enabled: true,\n    animation: true,\n  };\n\n  /**\n   *  @ignore\n   */\n  private _focusedRow: unknown;\n\n  /**\n * Gets the currently focused row.\n */\n  @Input()\n  public get focusedRow(): unknown {\n    return this._focusedRow;\n  }\n\n  /**\n * Sets the currently focused row and emits the change event.\n *\n * @param v - The row to be focused.\n */\n  public set focusedRow(v: unknown) {\n    this._focusedRow = v;\n    this.focusedRowChange.emit(v);\n  }\n\n\n  /**\n * Emits when the focused row changes.\n * \n * @event \n */\n  @Output()\n  focusedRowChange: EventEmitter<unknown> = new EventEmitter<unknown>();\n\n  /**\n * Emits when a row is clicked.\n * \n * @event onRowClick\n */\n  @Output()\n  onRowClick: EventEmitter<AXDataTableRowClick> = new EventEmitter<AXDataTableRowClick>();\n\n  /**\n * Emits when a row is double-clicked.\n * \n * @event onRowDbClick\n */\n  @Output()\n  onRowDbClick: EventEmitter<AXDataTableRowDbClick> = new EventEmitter<AXDataTableRowDbClick>();\n\n  /**\n * Emits when the order of columns changes.\n * \n * @event onColumnsOrderChanged\n */\n  @Output()\n  onColumnsOrderChanged: EventEmitter<AXColumnsOrderChangedEvent> = new EventEmitter<AXColumnsOrderChangedEvent>();\n\n  /**\n   *  @ignore\n   */\n  private clickSubject = new Subject<{ event: MouseEvent; item: any }>();\n\n  /**\n   *  @ignore\n   */\n  @ContentChildren(AXDataTableColumnComponent)\n  protected columns: QueryList<AXDataTableColumnComponent>;\n\n  /**\n   *  @ignore\n   */\n  override ngOnInit() {\n    super.ngOnInit();\n    this.rtl = AXHtmlUtil.isRtl(this.getHostElement());\n    this.dataSource.useCache = false;\n    if (this.fetchDataMode == 'auto') {\n      this.dataSource.setPage(0);\n    }\n    this.displayedRows.set(new Array(this.dataSource.pageSize));\n    this.totalRows = this.dataSource.items.length;\n    this.dataSource.onLoadingChanged.pipe(this._unsubscriber.takeUntilDestroy).subscribe((data) => {\n      this.isLoading.set(data);\n    });\n\n    this.dataSource.onChanged.pipe(this._unsubscriber.takeUntilDestroy).subscribe((data) => {\n      this.displayedRows.set(data.items);\n      this.totalRows = data.totalCount;\n      this.hasItems = data.totalCount > 0;\n    });\n\n    this.pageSize.set(this.dataSource.pageSize);\n\n    //\n    this.clickSubject\n      .pipe(\n        buffer(this.clickSubject.pipe(debounceTime(250))),\n        filter((clickArray) => clickArray.length === 2),\n      )\n      .subscribe((clickArray) => {\n        this.handleRowDoubleClick(clickArray[0].event, clickArray[0].item);\n      });\n  }\n\n  /**\n   *  @ignore\n   */\n  ngAfterViewInit(): void {\n    this.calculateStickyColumnsPositions();\n    this.columnsList.set(this.columns.toArray());\n    this.columns.changes.pipe(this._unsubscriber.takeUntilDestroy).subscribe((cols) => {\n      this.columnsList.set(cols.toArray());\n    });\n  }\n\n  /**\n   *  @ignore\n   */\n  protected drop(event: CdkDragDrop<any, any, any>) {\n    const clonedColumns = [...this.columnsList()];\n    moveItemInArray(clonedColumns, event.previousIndex, event.currentIndex);\n    this.columnsList.set(clonedColumns);\n\n    this.onColumnsOrderChanged.emit({\n      component: this,\n      data: { event },\n      isUserInteraction: true,\n    });\n  }\n\n  /**\n   *  @ignore\n   */\n  protected handleRowClick(event: MouseEvent, item: unknown) {\n    this.handleRowSingleClick(event, item);\n    this.clickSubject.next({ event, item });\n  }\n\n  /**\n   *  @ignore\n   */\n  private handleRowSingleClick(event: Event, item: any): void {\n    if (this.focusedRow == item) {\n      this.focusedRow = null;\n    } else {\n      this.focusedRow = item;\n    }\n    //\n    this.onRowClick.emit({\n      component: this,\n      data: item,\n      isUserInteraction: true,\n    });\n  }\n\n  /**\n   *  @ignore\n   */\n  protected onPageChanged(event: AXDataPagerChangedEvent) {\n    if (event.isUserInteraction) {\n      const pageChanged = event.page - 1 != this.page();\n      const pageSizeChanged = event.take != this.pageSize();\n\n      if (pageChanged || pageSizeChanged) {\n        if (pageChanged) {\n          this.page.set(event.page - 1);\n          this.dataSource.setPage(this.page());\n        }\n\n        if (pageSizeChanged) {\n          this.pageSize.set(event.take);\n          this.dataSource.setPageSize(this.pageSize());\n        }\n\n        // Update displayed rows and data source\n        this.displayedRows.set(new Array(this.pageSize()));\n      }\n    }\n  }\n\n  /**\n   *  @ignore\n   */\n  protected handleRowDoubleClick(e: MouseEvent, item: unknown) {\n    this.focusedRow = item;\n    //\n    this.onRowDbClick.emit({\n      component: this,\n      data: item,\n      isUserInteraction: true,\n    });\n  }\n\n  /**\n * Handles the click event on a column header.\n * Toggles the sorting direction or removes the sort if already sorted.\n * \n * @param e - The mouse event triggered by the click.\n * @param column - The column that was clicked.\n * @ignore\n */\n  handleColumnClick(e: MouseEvent, column: AXDataTableColumnComponent) {\n    if (column instanceof AXDataTableTextColumnComponent) {\n      const sort = this.dataSource.query.sort.find((c) => c.field == column.dataField);\n      if (!sort) {\n        this.dataSource.query.sort.push({\n          field: column.dataField,\n          dir: 'asc',\n        });\n      } else {\n        if (sort.dir == 'asc') {\n          sort.dir = 'desc';\n        } else {\n          this.dataSource.query.sort = this.dataSource.query.sort.filter((c) => c != sort);\n        }\n      }\n      this.refresh();\n    }\n  }\n\n  /**\n   *  @ignore\n   */\n  protected getSort(column: AXDataTableColumnComponent): string | undefined {\n    if (column instanceof AXDataTableTextColumnComponent) {\n      const sort = this.dataSource.query.sort.find((c) => c.field == column.dataField);\n      return sort ? (sort.dir == 'asc' ? 'ax-icon-arrow-long-down' : 'ax-icon-arrow-long-up') : undefined;\n    }\n    return undefined;\n  }\n\n  /**\n * Refreshes the data in the data source and resets the data pager to the first page.\n * @ignore\n */\n  public refresh() {\n    this.dataSource.refresh();\n    if (this.dataPager) {\n      this.dataPager.goFirstPage();\n    }\n  }\n\n  /**\n   *  @ignore\n   */\n  protected calculateRowIndex(index: number) {\n    return this.dataSource.pageSize * this.page() + index;\n  }\n\n  /**\n   *  @ignore\n   */\n  protected onResizeColumnStart(event: MouseEvent, columnIndex: number): void {\n    event.preventDefault();\n    event.stopPropagation();\n\n    this.resizeColumnProp.startX = event.pageX;\n    this.resizeColumnProp.thElement = (event.target as HTMLElement).parentElement;\n    this.resizeColumnProp.startWidth = parseInt(this.resizeColumnProp.thElement.style.width);\n    this.resizeColumnProp.columnIndex = columnIndex;\n    this._zone.runOutsideAngular(() => {\n      document.addEventListener('mousemove', this.onResizeColumnMove);\n      document.addEventListener('mouseup', this.onResizeColumnEnd);\n    });\n  }\n\n  /**\n   *  @ignore\n   */\n  private onResizeColumnMove = (event: MouseEvent): void => {\n    const diffX = event.pageX - this.resizeColumnProp.startX;\n    const newWidth = this.rtl ? this.resizeColumnProp.startWidth - diffX : this.resizeColumnProp.startWidth + diffX;\n    this.resizeColumnProp.thElement.style.width = `${Math.max(100, newWidth)}px`;\n    this.resizeColumnProp.thElement.setAttribute('new-width', `${newWidth}`);\n  };\n\n  /**\n   *  @ignore\n   */\n  private onResizeColumnEnd = (): void => {\n    document.removeEventListener('mousemove', this.onResizeColumnMove);\n    document.removeEventListener('mouseup', this.onResizeColumnEnd);\n\n    const newWidth = parseInt(this.resizeColumnProp.thElement.attributes.getNamedItem('new-width').value);\n    this.columns.get(this.resizeColumnProp.columnIndex).width = `${Math.max(100, newWidth)}px`;\n    this.resetResizingProcess();\n  };\n\n  /**\n   *  @ignore\n   */\n  private resetResizingProcess() {\n    this.resizeColumnProp.thElement.removeAttribute('new-width');\n    this.resizeColumnProp = {\n      startX: 0,\n      startWidth: 0,\n      columnIndex: 0,\n      newColumnWidth: 0,\n      thElement: null,\n    };\n  }\n\n  /**\n   *  @ignore\n   */\n  private calculateStickyColumnsPositions() {\n    let totalWidth = 0;\n    let accumulatedWidthFromStart = 0;\n    this.columns.forEach((column) => {\n      const width = parseInt(column.width as string);\n      if (!isNaN(width)) {\n        totalWidth += width;\n      }\n    });\n    let lastStartColumn: AXDataTableColumnComponent;\n\n    this.columns.forEach((column) => {\n      const width = parseInt(column.width as string);\n\n      if (column.fixed === 'start' && !isNaN(width)) {\n        column['stickyStart'] = accumulatedWidthFromStart + 'px';\n        lastStartColumn = column;\n      }\n\n      if (!isNaN(width)) {\n        accumulatedWidthFromStart += width;\n      }\n    });\n    if (lastStartColumn) lastStartColumn['isLastFixedColumn'] = true;\n\n    let accumulatedWidthFromEnd = 0;\n    let firstEndColumn: AXDataTableColumnComponent;\n\n    for (let i = this.columns.length - 1; i >= 0; i--) {\n      const column = this.columns.get(i);\n\n      const width = parseInt(column.width as string);\n\n      if (column.fixed === 'end' && !isNaN(width)) {\n        column['stickyEnd'] = accumulatedWidthFromEnd + 'px';\n        firstEndColumn = column;\n      }\n\n      if (!isNaN(width)) {\n        accumulatedWidthFromEnd += width;\n      }\n    }\n    if (firstEndColumn) firstEndColumn['isFirstFixedColumn'] = true;\n  }\n}\n","<ng-content select=\"ax-header\"> </ng-content>\n@if (!displayedRows().length) {\n  <div class=\"ax-data-table-empty-data\">\n    @if (emptyTemplate) {\n      <ng-container *ngTemplateOutlet=\"emptyTemplate\"></ng-container>\n    } @else {\n      <span>No Record Found!</span>\n    }\n  </div>\n}\n<div class=\"ax-data-table-wrapper\">\n  <table>\n    @if (showHeader) {\n      <thead [ngClass]=\"{ 'ax-data-table-sticky-header': fixedHeader }\">\n        <tr\n          [cdkDropListDisabled]=\"!allowReordering\"\n          cdkDropList\n          cdkScrollable\n          cdkDropListOrientation=\"horizontal\"\n          (cdkDropListDropped)=\"drop($event)\"\n        >\n          @for (c of startFixedColumnsList(); track $index) {\n            <th\n              cdkDrag\n              [cdkDragDisabled]=\"true\"\n              cdkDragLockAxis=\"x\"\n              class=\"ax-data-table-head-cell sticky-start\"\n              [class.ax-interactive]=\"c.allowSorting\"\n              (click)=\"c.allowSorting ? handleColumnClick($event, c) : null\"\n              [class.ax-data-table-sticky-header-cell]=\"c.fixed && c.width\"\n              [style.width]=\"c.width\"\n              [class.isLast]=\"c['isLastFixedColumn']\"\n              [style.--sticky-start]=\"c['stickyStart']\"\n            >\n              <div class=\"ax-caption\">\n                <ng-container\n                  *ngTemplateOutlet=\"c.renderHeaderTemplate; context: { $implicit: { data: c, rows: displayedRows(), rowIndex: $index } }\"\n                ></ng-container>\n                @if (getSort(c)) {\n                  <ax-icon icon=\"ax-icon {{ getSort(c) }}\"></ax-icon>\n                }\n              </div>\n            </th>\n          }\n          @for (c of normalColumnsList(); track $index) {\n            <th\n              cdkDrag\n              cdkDragLockAxis=\"x\"\n              class=\"ax-data-table-head-cell\"\n              [class.ax-interactive]=\"c.allowSorting\"\n              (click)=\"c.allowSorting ? handleColumnClick($event, c) : null\"\n              [class.ax-data-table-sticky-header-cell]=\"c.fixed && c.width\"\n              [style.width]=\"c.width\"\n            >\n              <div class=\"ax-caption\">\n                <ng-container\n                  *ngTemplateOutlet=\"c.renderHeaderTemplate; context: { $implicit: { data: c, rows: displayedRows(), rowIndex: $index } }\"\n                ></ng-container>\n                @if (getSort(c)) {\n                  <ax-icon icon=\"ax-icon {{ getSort(c) }}\"></ax-icon>\n                }\n              </div>\n              @if (c.allowResizing && !c.fixed) {\n                <div class=\"ax-resize-handle\" (mousedown)=\"onResizeColumnStart($event, this.startFixedColumnsList().length + $index)\"></div>\n              }\n            </th>\n          }\n          <th></th>\n          @for (c of endFixedColumnsList(); track $index) {\n            <th\n              cdkDrag\n              [cdkDragDisabled]=\"true\"\n              cdkDragLockAxis=\"x\"\n              class=\"ax-data-table-head-cell sticky-end\"\n              [class.ax-interactive]=\"c.allowSorting\"\n              (click)=\"c.allowSorting ? handleColumnClick($event, c) : null\"\n              [class.ax-data-table-sticky-header-cell]=\"c.fixed && c.width\"\n              [style.width]=\"c.width\"\n              [class.isFirst]=\"c['isFirstFixedColumn']\"\n              [style.--sticky-end]=\"c['stickyEnd']\"\n            >\n              <div class=\"ax-caption\">\n                <ng-container\n                  *ngTemplateOutlet=\"c.renderHeaderTemplate; context: { $implicit: { data: c, rows: displayedRows(), rowIndex: $index } }\"\n                ></ng-container>\n                @if (getSort(c)) {\n                  <ax-icon icon=\"ax-icon {{ getSort(c) }}\"></ax-icon>\n                }\n              </div>\n            </th>\n          }\n        </tr>\n      </thead>\n    }\n    <tbody [ngClass]=\"{ 'ax-data-table-row-alternative': alternative }\">\n      @for (row of displayedRows(); let rowIndex = $index; track rowIndex) {\n        @if (rowTemplate) {\n          <ng-container *ngTemplateOutlet=\"rowTemplate; context: { $implicit: { data: row, rowIndex: rowIndex } }\"> </ng-container>\n        } @else {\n          <tr\n            [class.ax-state-focused]=\"focusedRow && row === focusedRow\"\n            [attr.data-index]=\"rowIndex\"\n            [class.ax-state-selected]=\"selectedRows.includes(row)\"\n            style.height=\"{{ itemHeight }}px\"\n            style.max-height=\"{{ itemHeight }}px\"\n            (click)=\"handleRowClick($event, row)\"\n          >\n            @for (c of startFixedColumnsList(); track $index) {\n              <td\n                [style.width]=\"c.width\"\n                [class.ax-data-table-sticky-body-cell]=\"c.fixed && c.width\"\n                [class.sticky-start]=\"true\"\n                [class.isLast]=\"c['isLastFixedColumn']\"\n                [style.--sticky-start]=\"c['stickyStart']\"\n                [attr.data-label]=\"c.caption\"\n                tabindex=\"0\"\n                [class]=\"c.cssClass\"\n              >\n                @if (row && !isLoading()) {\n                  <ng-container\n                    *ngTemplateOutlet=\"c.renderCellTemplate; context: { $implicit: { data: row, rowIndex: calculateRowIndex(rowIndex) } }\"\n                  ></ng-container>\n                } @else {\n                  @if (c.loadingEnabled && loading.enabled) {\n                    @if (loading.loadingTemplate) {\n                      <ng-container *ngTemplateOutlet=\"loading.loadingTemplate\"></ng-container>\n                    } @else {\n                      <ax-skeleton [animated]=\"loading.animation\"></ax-skeleton>\n                    }\n                  }\n                }\n              </td>\n            }\n            @for (c of normalColumnsList(); track $index) {\n              <td\n                [style.width]=\"c.width\"\n                [class.ax-data-table-sticky-body-cell]=\"c.fixed && c.width\"\n                [attr.data-label]=\"c.caption\"\n                tabindex=\"0\"\n                [class]=\"c.cssClass\"\n              >\n                @if (row && !isLoading()) {\n                  <ng-container\n                    *ngTemplateOutlet=\"c.renderCellTemplate; context: { $implicit: { data: row, rowIndex: calculateRowIndex(rowIndex) } }\"\n                  ></ng-container>\n                } @else {\n                  @if (c.loadingEnabled && loading.enabled) {\n                    @if (loading.loadingTemplate) {\n                      <ng-container *ngTemplateOutlet=\"loading.loadingTemplate\"></ng-container>\n                    } @else {\n                      <ax-skeleton [animated]=\"loading.animation\"></ax-skeleton>\n                    }\n                  }\n                }\n              </td>\n            }\n            <td></td>\n            @for (c of endFixedColumnsList(); track $index) {\n              <td\n                [style.width]=\"c.width\"\n                [class.ax-data-table-sticky-body-cell]=\"c.fixed && c.width\"\n                [class.sticky-end]=\"true\"\n                [class.isFirst]=\"c['isFirstFixedColumn']\"\n                [style.--sticky-end]=\"c['stickyEnd']\"\n                [attr.data-label]=\"c.caption\"\n                tabindex=\"0\"\n                [class]=\"c.cssClass\"\n              >\n                @if (row && !isLoading()) {\n                  <ng-container\n                    *ngTemplateOutlet=\"c.renderCellTemplate; context: { $implicit: { data: row, rowIndex: calculateRowIndex(rowIndex) } }\"\n                  ></ng-container>\n                } @else {\n                  @if (c.loadingEnabled && loading.enabled) {\n                    @if (loading.loadingTemplate) {\n                      <ng-container *ngTemplateOutlet=\"loading.loadingTemplate\"></ng-container>\n                    } @else {\n                      <ax-skeleton [animated]=\"loading.animation\"></ax-skeleton>\n                    }\n                  }\n                }\n              </td>\n            }\n          </tr>\n        }\n      }\n\n      <tr class=\"empty-row\"></tr>\n    </tbody>\n    @if (showFooter) {\n      <tfoot [ngClass]=\"{ 'ax-data-table-sticky-footer': fixedFooter }\">\n        <tr>\n          @for (c of startFixedColumnsList(); track $index) {\n            <td\n              class=\"ax-data-table-sticky-footer-cell sticky-start\"\n              [class.ax-data-table-sticky-footer-cell]=\"c.fixed && c.width\"\n              [style.width]=\"c.width\"\n              [class.isLast]=\"c['isLastFixedColumn']\"\n              [style.--sticky-start]=\"c['stickyStart']\"\n            >\n              <div class=\"ax-caption\">\n                <ng-container\n                  *ngTemplateOutlet=\"c.renderFooterTemplate; context: { $implicit: { data: c, rows: displayedRows(), rowIndex: $index } }\"\n                ></ng-container>\n                @if (getSort(c)) {\n                  <ax-icon icon=\"ax-icon {{ getSort(c) }}\"></ax-icon>\n                }\n              </div>\n            </td>\n          }\n          @for (c of normalColumnsList(); track $index) {\n            <td\n              [class.ax-interactive]=\"c.allowSorting\"\n              (click)=\"c.allowSorting ? handleColumnClick($event, c) : null\"\n              [class.ax-data-table-sticky-header-cell]=\"c.fixed && c.width\"\n              [style.width]=\"c.width\"\n            >\n              <div class=\"ax-caption\">\n                <ng-container\n                  *ngTemplateOutlet=\"c.renderFooterTemplate; context: { $implicit: { data: c, rows: displayedRows(), rowIndex: $index } }\"\n                ></ng-container>\n                @if (getSort(c)) {\n                  <ax-icon icon=\"ax-icon {{ getSort(c) }}\"></ax-icon>\n                }\n              </div>\n              @if (c.allowResizing && !c.fixed) {\n                <div class=\"ax-resize-handle\" (mousedown)=\"onResizeColumnStart($event, this.startFixedColumnsList().length + $index)\"></div>\n              }\n            </td>\n          }\n          <td></td>\n          @for (c of endFixedColumnsList(); track $index) {\n            <td\n              class=\"ax-data-table-sticky-footer-cell sticky-end\"\n              [class.ax-interactive]=\"c.allowSorting\"\n              (click)=\"c.allowSorting ? handleColumnClick($event, c) : null\"\n              [class.ax-data-table-sticky-header-cell]=\"c.fixed && c.width\"\n              [style.width]=\"c.width\"\n              [class.isFirst]=\"c['isFirstFixedColumn']\"\n              [style.--sticky-end]=\"c['stickyEnd']\"\n            >\n              <div class=\"ax-caption\">\n                <ng-container\n                  *ngTemplateOutlet=\"c.renderFooterTemplate; context: { $implicit: { data: c, rows: displayedRows(), rowIndex: $index } }\"\n                ></ng-container>\n                @if (getSort(c)) {\n                  <ax-icon icon=\"ax-icon {{ getSort(c) }}\"></ax-icon>\n                }\n              </div>\n            </td>\n          }\n        </tr>\n      </tfoot>\n    }\n  </table>\n</div>\n\n@if (paging) {\n  <div class=\"ax-table-footer\" #footerContainer>\n    <ax-data-pager\n      #dataPager\n      [displayMode]=\"'custom'\"\n      (onChanged)=\"onPageChanged($event)\"\n      [total]=\"dataSource.totalCount\"\n      [size]=\"dataSource.pageSize\"\n      [isLoading]=\"isLoading()\"\n    >\n      <ax-prefix class=\"ax-data-table-numeric-paging\">\n        <ax-data-pager-numeric-selector> </ax-data-pager-numeric-selector>\n        <ax-data-pager-page-sizes> </ax-data-pager-page-sizes>\n      </ax-prefix>\n      <ax-prefix class=\"ax-data-table-input-paging\">\n        <ax-data-pager-prev-buttons> </ax-data-pager-prev-buttons>\n        <ax-data-pager-input-selector> </ax-data-pager-input-selector>\n        <ax-data-pager-next-buttons> </ax-data-pager-next-buttons>\n      </ax-prefix>\n      <ax-suffix class=\"ax-data-table-info\">\n        <ax-data-pager-info> </ax-data-pager-info>\n        <ax-button look=\"blank\" class=\"ax-sm\" (onClick)=\"refresh()\">\n          <ax-icon icon=\"ax-icon ax-icon-refresh\"></ax-icon>\n        </ax-button>\n      </ax-suffix>\n    </ax-data-pager>\n  </div>\n}\n<ng-content select=\"ax-footer\"> </ng-content>\n"]}
508
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-table.component.js","sourceRoot":"","sources":["../../../../../../../libs/components/data-table/src/lib/data-table/data-table.component.ts","../../../../../../../libs/components/data-table/src/lib/data-table/data-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AXDataPagerChangedEvent } from '@acorex/components/data-pager';\nimport { AXHtmlUtil, AXUnsubscriber } from '@acorex/core/utils';\nimport { CdkDragDrop, moveItemInArray } from '@angular/cdk/drag-drop';\nimport { DOCUMENT } from '@angular/common';\nimport {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  Component,\n  ContentChildren,\n  EventEmitter,\n  Input,\n  NgZone,\n  OnInit,\n  Output,\n  QueryList,\n  Signal,\n  TemplateRef,\n  ViewChild,\n  ViewEncapsulation,\n  WritableSignal,\n  computed,\n  inject,\n  signal,\n} from '@angular/core';\nimport { Subject, buffer, debounceTime, filter } from 'rxjs';\nimport {\n  AXBaseDataTable,\n  AXColumnsOrderChangedEvent,\n  AXDataTableRowClick,\n  AXDataTableRowDbClick,\n} from '../base-data-table.class';\nimport { AXDataTableColumnComponent } from '../columns/data-table-column';\nimport { AXDataTableTextColumnComponent } from '../columns/data-text-column.component';\n\n/**\n * Component for displaying and managing a data table with advanced features.\n *\n * @category Components\n */\n@Component({\n  selector: 'ax-data-table',\n  templateUrl: './data-table.component.html',\n  styleUrls: ['./data-table.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  host: { ngSkipHydration: 'true' },\n  inputs: ['dataSource'],\n  outputs: ['selectedRowsChange'],\n  providers: [\n    {\n      provide: AXBaseDataTable,\n      useExisting: AXDataTableComponent,\n    },\n    AXUnsubscriber,\n  ],\n})\nexport class AXDataTableComponent extends AXBaseDataTable implements OnInit, AfterViewInit {\n  private _unsubscriber = inject(AXUnsubscriber);\n  private _zone = inject(NgZone);\n  private document = inject(DOCUMENT);\n\n  /**\n   *  @ignore\n   */\n  @ViewChild('dataPager') dataPager;\n\n  /**\n   *  @ignore\n   */\n  protected rtl!: boolean;\n\n  /**\n   *  @ignore\n   */\n  protected displayedRows: WritableSignal<any[]> = signal([]);\n\n  /**\n   *  @ignore\n   */\n  protected page: WritableSignal<number> = signal(0);\n\n  /**\n   *  @ignore\n   */\n  protected pageSize: WritableSignal<number> = signal(0);\n\n  /**\n   *  @ignore\n   */\n  protected isLoading: WritableSignal<boolean> = signal(true);\n\n  /**\n   *  @ignore\n   */\n  protected columnsList: WritableSignal<any[]> = signal([]);\n\n  /**\n   *  @ignore\n   */\n  protected endFixedColumnsList: Signal<any[]> = computed(() =>\n    this.columnsList().filter((c) => c.fixed === 'end'),\n  );\n\n  /**\n   *  @ignore\n   */\n  protected startFixedColumnsList: Signal<any[]> = computed(() =>\n    this.columnsList().filter((c) => c.fixed === 'start'),\n  );\n\n  /**\n   *  @ignore\n   */\n  protected normalColumnsList: Signal<any[]> = computed(() =>\n    this.columnsList().filter((c) => c.fixed !== 'end' && c.fixed !== 'start'),\n  );\n\n  /**\n   *  @ignore\n   */\n  protected resizeColumnProp = {\n    startX: 0,\n    startWidth: 0,\n    columnIndex: 0,\n    newColumnWidth: 0,\n    thElement: null,\n  };\n\n  /**\n   *  @ignore\n   */\n  protected hasItems = false;\n\n  /**\n   *  @ignore\n   */\n  protected totalRows = 0;\n\n  /**\n   *  @ignore\n   */\n  protected currentPage = 0;\n\n  /**\n   *  @ignore\n   */\n  protected totalPages = 0;\n\n  /**\n   *  @ignore\n   */\n  protected startRowIndex = 0;\n\n  /**\n   * Template for custom row content.\n   */\n  @Input()\n  rowTemplate?: TemplateRef<unknown>;\n\n  /**\n   * Template to display when the table is empty.\n   */\n  @Input()\n  emptyTemplate?: TemplateRef<unknown>;\n\n  /**\n   * Defines if alternative row styling should be applied.\n   *\n   * @defaultValue `true`\n   */\n  @Input()\n  alternative = true;\n\n  /**\n   * Indicates if the table header should be displayed.\n   *\n   * @defaultValue `true`\n   */\n  @Input()\n  showHeader = true;\n\n  /**\n   * Indicates if the table header should be fixed.\n   *\n   * @defaultValue `true`\n   */\n  @Input()\n  fixedHeader = true;\n\n  /**\n   * Indicates if the table footer should be displayed.\n   *\n   * @defaultValue `false`\n   */\n  @Input()\n  showFooter = false;\n\n  /**\n   * Indicates if the table footer should be fixed.\n   *\n   * @defaultValue `true`\n   */\n  @Input()\n  fixedFooter = true;\n\n  /**\n   * Specifies the height of each item in the table.\n   *\n   * @defaultValue `40`\n   */\n  @Input()\n  itemHeight: number | 'auto' = 40;\n\n  /**\n   * Enables or disables row reordering.\n   *\n   * @defaultValue `false`\n   */\n  @Input()\n  allowReordering = false;\n\n  /**\n   * Enables or disables paging.\n   *\n   * @defaultValue `true`\n   */\n  @Input()\n  paging = true;\n\n  /**\n   * Specifies how data should be fetched.\n   *\n   * @defaultValue `'auto'`\n   */\n  @Input()\n  fetchDataMode: 'auto' | 'manual' = 'auto';\n\n  /**\n   * Configuration for loading state.\n   *\n   * @defaultValue `{ enabled: true, animation: true }`\n   */\n  @Input()\n  loading: {\n    enabled: boolean;\n    animation: boolean;\n    loadingTemplate?: TemplateRef<unknown>;\n  } = {\n    enabled: true,\n    animation: true,\n  };\n\n  /**\n   *  @ignore\n   */\n  private _focusedRow: unknown;\n\n  /**\n   * Gets the currently focused row.\n   */\n  @Input()\n  public get focusedRow(): unknown {\n    return this._focusedRow;\n  }\n\n  /**\n   * Sets the currently focused row and emits the change event.\n   *\n   * @param v - The row to be focused.\n   */\n  public set focusedRow(v: unknown) {\n    this._focusedRow = v;\n    this.focusedRowChange.emit(v);\n  }\n\n  /**\n   * Emits when the focused row changes.\n   *\n   * @event\n   */\n  @Output()\n  focusedRowChange: EventEmitter<unknown> = new EventEmitter<unknown>();\n\n  /**\n   * Emits when a row is clicked.\n   *\n   * @event onRowClick\n   */\n  @Output()\n  onRowClick: EventEmitter<AXDataTableRowClick> = new EventEmitter<AXDataTableRowClick>();\n\n  /**\n   * Emits when a row is double-clicked.\n   *\n   * @event onRowDbClick\n   */\n  @Output()\n  onRowDbClick: EventEmitter<AXDataTableRowDbClick> = new EventEmitter<AXDataTableRowDbClick>();\n\n  /**\n   * Emits when the order of columns changes.\n   *\n   * @event onColumnsOrderChanged\n   */\n  @Output()\n  onColumnsOrderChanged: EventEmitter<AXColumnsOrderChangedEvent> =\n    new EventEmitter<AXColumnsOrderChangedEvent>();\n\n  /**\n   *  @ignore\n   */\n  private clickSubject = new Subject<{ event: MouseEvent; item: any }>();\n\n  /**\n   *  @ignore\n   */\n  @ContentChildren(AXDataTableColumnComponent)\n  protected columns: QueryList<AXDataTableColumnComponent>;\n\n  /**\n   *  @ignore\n   */\n  override ngOnInit() {\n    super.ngOnInit();\n    this.rtl = AXHtmlUtil.isRtl(this.getHostElement());\n    this.dataSource.useCache = false;\n    if (this.fetchDataMode == 'auto') {\n      this.dataSource.setPage(0);\n    }\n    this.displayedRows.set(new Array(this.dataSource.pageSize));\n    this.totalRows = this.dataSource.items.length;\n    this.dataSource.onLoadingChanged.pipe(this._unsubscriber.takeUntilDestroy).subscribe((data) => {\n      this.isLoading.set(data);\n    });\n\n    this.dataSource.onChanged.pipe(this._unsubscriber.takeUntilDestroy).subscribe((data) => {\n      this.displayedRows.set(data.items);\n      this.totalRows = data.totalCount;\n      this.hasItems = data.totalCount > 0;\n    });\n\n    this.pageSize.set(this.dataSource.pageSize);\n\n    //\n    this.clickSubject\n      .pipe(\n        buffer(this.clickSubject.pipe(debounceTime(250))),\n        filter((clickArray) => clickArray.length === 2),\n      )\n      .subscribe((clickArray) => {\n        this.handleRowDoubleClick(clickArray[0].event, clickArray[0].item);\n      });\n  }\n\n  /**\n   *  @ignore\n   */\n  ngAfterViewInit(): void {\n    this.calculateStickyColumnsPositions();\n    this.columnsList.set(this.columns.toArray());\n    this.columns.changes.pipe(this._unsubscriber.takeUntilDestroy).subscribe((cols) => {\n      this.columnsList.set(cols.toArray());\n    });\n  }\n\n  /**\n   *  @ignore\n   */\n  protected drop(event: CdkDragDrop<any, any, any>) {\n    const clonedColumns = [...this.columnsList()];\n    moveItemInArray(clonedColumns, event.previousIndex, event.currentIndex);\n    this.columnsList.set(clonedColumns);\n\n    this.onColumnsOrderChanged.emit({\n      component: this,\n      data: { event },\n      isUserInteraction: true,\n    });\n  }\n\n  /**\n   *  @ignore\n   */\n  protected handleRowClick(event: MouseEvent, item: unknown) {\n    this.handleRowSingleClick(event, item);\n    this.clickSubject.next({ event, item });\n  }\n\n  /**\n   *  @ignore\n   */\n  private handleRowSingleClick(event: Event, item: any): void {\n    if (this.focusedRow == item) {\n      this.focusedRow = null;\n    } else {\n      this.focusedRow = item;\n    }\n    //\n    this.onRowClick.emit({\n      component: this,\n      data: item,\n      isUserInteraction: true,\n    });\n  }\n\n  /**\n   *  @ignore\n   */\n  protected onPageChanged(event: AXDataPagerChangedEvent) {\n    if (event.isUserInteraction) {\n      const pageChanged = event.page - 1 != this.page();\n      const pageSizeChanged = event.take != this.pageSize();\n\n      if (pageChanged || pageSizeChanged) {\n        if (pageChanged) {\n          this.page.set(event.page - 1);\n          this.dataSource.setPage(this.page());\n        }\n\n        if (pageSizeChanged) {\n          this.pageSize.set(event.take);\n          this.dataSource.setPageSize(this.pageSize());\n        }\n\n        // Update displayed rows and data source\n        this.displayedRows.set(new Array(this.pageSize()));\n      }\n    }\n  }\n\n  /**\n   *  @ignore\n   */\n  protected handleRowDoubleClick(e: MouseEvent, item: unknown) {\n    this.focusedRow = item;\n    //\n    this.onRowDbClick.emit({\n      component: this,\n      data: item,\n      isUserInteraction: true,\n    });\n  }\n\n  /**\n   * Handles the click event on a column header.\n   * Toggles the sorting direction or removes the sort if already sorted.\n   *\n   * @param e - The mouse event triggered by the click.\n   * @param column - The column that was clicked.\n   * @ignore\n   */\n  handleColumnClick(e: MouseEvent, column: AXDataTableColumnComponent) {\n    if (column instanceof AXDataTableTextColumnComponent) {\n      const sort = this.dataSource.query.sort.find((c) => c.field == column.dataField);\n      if (!sort) {\n        this.dataSource.query.sort.push({\n          field: column.dataField,\n          dir: 'asc',\n        });\n      } else {\n        if (sort.dir == 'asc') {\n          sort.dir = 'desc';\n        } else {\n          this.dataSource.query.sort = this.dataSource.query.sort.filter((c) => c != sort);\n        }\n      }\n      this.refresh();\n    }\n  }\n\n  /**\n   *  @ignore\n   */\n  protected getSort(column: AXDataTableColumnComponent): string | undefined {\n    if (column instanceof AXDataTableTextColumnComponent) {\n      const sort = this.dataSource.query.sort.find((c) => c.field == column.dataField);\n      return sort ? (sort.dir == 'asc' ? 'ax-icon-arrow-long-down' : 'ax-icon-arrow-long-up') : undefined;\n    }\n    return undefined;\n  }\n\n  /**\n   * Refreshes the data in the data source and resets the data pager to the first page.\n   * @ignore\n   */\n  public refresh() {\n    this.dataSource.refresh();\n    if (this.dataPager) {\n      this.dataPager.goFirstPage();\n    }\n  }\n\n  /**\n   *  @ignore\n   */\n  protected calculateRowIndex(index: number) {\n    return this.dataSource.pageSize * this.page() + index;\n  }\n\n  /**\n   *  @ignore\n   */\n  protected onResizeColumnStart(event: MouseEvent, columnIndex: number): void {\n    event.preventDefault();\n    event.stopPropagation();\n\n    this.resizeColumnProp.startX = event.pageX;\n    this.resizeColumnProp.thElement = (event.target as HTMLElement).parentElement;\n    this.resizeColumnProp.startWidth = parseInt(this.resizeColumnProp.thElement.style.width);\n    this.resizeColumnProp.columnIndex = columnIndex;\n    this._zone.runOutsideAngular(() => {\n      this.document.addEventListener('mousemove', this.onResizeColumnMove);\n      this.document.addEventListener('mouseup', this.onResizeColumnEnd);\n    });\n  }\n\n  /**\n   *  @ignore\n   */\n  private onResizeColumnMove = (event: MouseEvent): void => {\n    const diffX = event.pageX - this.resizeColumnProp.startX;\n    const newWidth = this.rtl\n      ? this.resizeColumnProp.startWidth - diffX\n      : this.resizeColumnProp.startWidth + diffX;\n    this.resizeColumnProp.thElement.style.width = `${Math.max(100, newWidth)}px`;\n    this.resizeColumnProp.thElement.setAttribute('new-width', `${newWidth}`);\n  };\n\n  /**\n   *  @ignore\n   */\n  private onResizeColumnEnd = (): void => {\n    this.document.removeEventListener('mousemove', this.onResizeColumnMove);\n    this.document.removeEventListener('mouseup', this.onResizeColumnEnd);\n\n    const newWidth = parseInt(this.resizeColumnProp.thElement.attributes.getNamedItem('new-width').value);\n    this.columns.get(this.resizeColumnProp.columnIndex).width = `${Math.max(100, newWidth)}px`;\n    this.resetResizingProcess();\n  };\n\n  /**\n   *  @ignore\n   */\n  private resetResizingProcess() {\n    this.resizeColumnProp.thElement.removeAttribute('new-width');\n    this.resizeColumnProp = {\n      startX: 0,\n      startWidth: 0,\n      columnIndex: 0,\n      newColumnWidth: 0,\n      thElement: null,\n    };\n  }\n\n  /**\n   *  @ignore\n   */\n  private calculateStickyColumnsPositions() {\n    let totalWidth = 0;\n    let accumulatedWidthFromStart = 0;\n    this.columns.forEach((column) => {\n      const width = parseInt(column.width as string);\n      if (!isNaN(width)) {\n        totalWidth += width;\n      }\n    });\n    let lastStartColumn: AXDataTableColumnComponent;\n\n    this.columns.forEach((column) => {\n      const width = parseInt(column.width as string);\n\n      if (column.fixed === 'start' && !isNaN(width)) {\n        column['stickyStart'] = accumulatedWidthFromStart + 'px';\n        lastStartColumn = column;\n      }\n\n      if (!isNaN(width)) {\n        accumulatedWidthFromStart += width;\n      }\n    });\n    if (lastStartColumn) lastStartColumn['isLastFixedColumn'] = true;\n\n    let accumulatedWidthFromEnd = 0;\n    let firstEndColumn: AXDataTableColumnComponent;\n\n    for (let i = this.columns.length - 1; i >= 0; i--) {\n      const column = this.columns.get(i);\n\n      const width = parseInt(column.width as string);\n\n      if (column.fixed === 'end' && !isNaN(width)) {\n        column['stickyEnd'] = accumulatedWidthFromEnd + 'px';\n        firstEndColumn = column;\n      }\n\n      if (!isNaN(width)) {\n        accumulatedWidthFromEnd += width;\n      }\n    }\n    if (firstEndColumn) firstEndColumn['isFirstFixedColumn'] = true;\n  }\n}\n","<ng-content select=\"ax-header\"> </ng-content>\n@if (!displayedRows().length) {\n  <div class=\"ax-data-table-empty-data\">\n    @if (emptyTemplate) {\n      <ng-container *ngTemplateOutlet=\"emptyTemplate\"></ng-container>\n    } @else {\n      <span>No Record Found!</span>\n    }\n  </div>\n}\n<div class=\"ax-data-table-wrapper\">\n  <table>\n    @if (showHeader) {\n      <thead [ngClass]=\"{ 'ax-data-table-sticky-header': fixedHeader }\">\n        <tr\n          [cdkDropListDisabled]=\"!allowReordering\"\n          cdkDropList\n          cdkScrollable\n          cdkDropListOrientation=\"horizontal\"\n          (cdkDropListDropped)=\"drop($event)\"\n        >\n          @for (c of startFixedColumnsList(); track $index) {\n            <th\n              cdkDrag\n              [cdkDragDisabled]=\"true\"\n              cdkDragLockAxis=\"x\"\n              class=\"ax-data-table-head-cell sticky-start\"\n              [class.ax-interactive]=\"c.allowSorting\"\n              (click)=\"c.allowSorting ? handleColumnClick($event, c) : null\"\n              [class.ax-data-table-sticky-header-cell]=\"c.fixed && c.width\"\n              [style.width]=\"c.width\"\n              [class.isLast]=\"c['isLastFixedColumn']\"\n              [style.--sticky-start]=\"c['stickyStart']\"\n            >\n              <div class=\"ax-caption\">\n                <ng-container\n                  *ngTemplateOutlet=\"c.renderHeaderTemplate; context: { $implicit: { data: c, rows: displayedRows(), rowIndex: $index } }\"\n                ></ng-container>\n                @if (getSort(c)) {\n                  <ax-icon icon=\"ax-icon {{ getSort(c) }}\"></ax-icon>\n                }\n              </div>\n            </th>\n          }\n          @for (c of normalColumnsList(); track $index) {\n            <th\n              cdkDrag\n              cdkDragLockAxis=\"x\"\n              class=\"ax-data-table-head-cell\"\n              [class.ax-interactive]=\"c.allowSorting\"\n              (click)=\"c.allowSorting ? handleColumnClick($event, c) : null\"\n              [class.ax-data-table-sticky-header-cell]=\"c.fixed && c.width\"\n              [style.width]=\"c.width\"\n            >\n              <div class=\"ax-caption\">\n                <ng-container\n                  *ngTemplateOutlet=\"c.renderHeaderTemplate; context: { $implicit: { data: c, rows: displayedRows(), rowIndex: $index } }\"\n                ></ng-container>\n                @if (getSort(c)) {\n                  <ax-icon icon=\"ax-icon {{ getSort(c) }}\"></ax-icon>\n                }\n              </div>\n              @if (c.allowResizing && !c.fixed) {\n                <div class=\"ax-resize-handle\" (mousedown)=\"onResizeColumnStart($event, this.startFixedColumnsList().length + $index)\"></div>\n              }\n            </th>\n          }\n          <th></th>\n          @for (c of endFixedColumnsList(); track $index) {\n            <th\n              cdkDrag\n              [cdkDragDisabled]=\"true\"\n              cdkDragLockAxis=\"x\"\n              class=\"ax-data-table-head-cell sticky-end\"\n              [class.ax-interactive]=\"c.allowSorting\"\n              (click)=\"c.allowSorting ? handleColumnClick($event, c) : null\"\n              [class.ax-data-table-sticky-header-cell]=\"c.fixed && c.width\"\n              [style.width]=\"c.width\"\n              [class.isFirst]=\"c['isFirstFixedColumn']\"\n              [style.--sticky-end]=\"c['stickyEnd']\"\n            >\n              <div class=\"ax-caption\">\n                <ng-container\n                  *ngTemplateOutlet=\"c.renderHeaderTemplate; context: { $implicit: { data: c, rows: displayedRows(), rowIndex: $index } }\"\n                ></ng-container>\n                @if (getSort(c)) {\n                  <ax-icon icon=\"ax-icon {{ getSort(c) }}\"></ax-icon>\n                }\n              </div>\n            </th>\n          }\n        </tr>\n      </thead>\n    }\n    <tbody [ngClass]=\"{ 'ax-data-table-row-alternative': alternative }\">\n      @for (row of displayedRows(); let rowIndex = $index; track rowIndex) {\n        @if (rowTemplate) {\n          <ng-container *ngTemplateOutlet=\"rowTemplate; context: { $implicit: { data: row, rowIndex: rowIndex } }\"> </ng-container>\n        } @else {\n          <tr\n            [class.ax-state-focused]=\"focusedRow && row === focusedRow\"\n            [attr.data-index]=\"rowIndex\"\n            [class.ax-state-selected]=\"selectedRows.includes(row)\"\n            style.height=\"{{ itemHeight }}px\"\n            style.max-height=\"{{ itemHeight }}px\"\n            (click)=\"handleRowClick($event, row)\"\n          >\n            @for (c of startFixedColumnsList(); track $index) {\n              <td\n                [style.width]=\"c.width\"\n                [class.ax-data-table-sticky-body-cell]=\"c.fixed && c.width\"\n                [class.sticky-start]=\"true\"\n                [class.isLast]=\"c['isLastFixedColumn']\"\n                [style.--sticky-start]=\"c['stickyStart']\"\n                [attr.data-label]=\"c.caption\"\n                tabindex=\"0\"\n                [class]=\"c.cssClass\"\n              >\n                @if (row && !isLoading()) {\n                  <ng-container\n                    *ngTemplateOutlet=\"c.renderCellTemplate; context: { $implicit: { data: row, rowIndex: calculateRowIndex(rowIndex) } }\"\n                  ></ng-container>\n                } @else {\n                  @if (c.loadingEnabled && loading.enabled) {\n                    @if (loading.loadingTemplate) {\n                      <ng-container *ngTemplateOutlet=\"loading.loadingTemplate\"></ng-container>\n                    } @else {\n                      <ax-skeleton [animated]=\"loading.animation\"></ax-skeleton>\n                    }\n                  }\n                }\n              </td>\n            }\n            @for (c of normalColumnsList(); track $index) {\n              <td\n                [style.width]=\"c.width\"\n                [class.ax-data-table-sticky-body-cell]=\"c.fixed && c.width\"\n                [attr.data-label]=\"c.caption\"\n                tabindex=\"0\"\n                [class]=\"c.cssClass\"\n              >\n                @if (row && !isLoading()) {\n                  <ng-container\n                    *ngTemplateOutlet=\"c.renderCellTemplate; context: { $implicit: { data: row, rowIndex: calculateRowIndex(rowIndex) } }\"\n                  ></ng-container>\n                } @else {\n                  @if (c.loadingEnabled && loading.enabled) {\n                    @if (loading.loadingTemplate) {\n                      <ng-container *ngTemplateOutlet=\"loading.loadingTemplate\"></ng-container>\n                    } @else {\n                      <ax-skeleton [animated]=\"loading.animation\"></ax-skeleton>\n                    }\n                  }\n                }\n              </td>\n            }\n            <td></td>\n            @for (c of endFixedColumnsList(); track $index) {\n              <td\n                [style.width]=\"c.width\"\n                [class.ax-data-table-sticky-body-cell]=\"c.fixed && c.width\"\n                [class.sticky-end]=\"true\"\n                [class.isFirst]=\"c['isFirstFixedColumn']\"\n                [style.--sticky-end]=\"c['stickyEnd']\"\n                [attr.data-label]=\"c.caption\"\n                tabindex=\"0\"\n                [class]=\"c.cssClass\"\n              >\n                @if (row && !isLoading()) {\n                  <ng-container\n                    *ngTemplateOutlet=\"c.renderCellTemplate; context: { $implicit: { data: row, rowIndex: calculateRowIndex(rowIndex) } }\"\n                  ></ng-container>\n                } @else {\n                  @if (c.loadingEnabled && loading.enabled) {\n                    @if (loading.loadingTemplate) {\n                      <ng-container *ngTemplateOutlet=\"loading.loadingTemplate\"></ng-container>\n                    } @else {\n                      <ax-skeleton [animated]=\"loading.animation\"></ax-skeleton>\n                    }\n                  }\n                }\n              </td>\n            }\n          </tr>\n        }\n      }\n\n      <tr class=\"empty-row\"></tr>\n    </tbody>\n    @if (showFooter) {\n      <tfoot [ngClass]=\"{ 'ax-data-table-sticky-footer': fixedFooter }\">\n        <tr>\n          @for (c of startFixedColumnsList(); track $index) {\n            <td\n              class=\"ax-data-table-sticky-footer-cell sticky-start\"\n              [class.ax-data-table-sticky-footer-cell]=\"c.fixed && c.width\"\n              [style.width]=\"c.width\"\n              [class.isLast]=\"c['isLastFixedColumn']\"\n              [style.--sticky-start]=\"c['stickyStart']\"\n            >\n              <div class=\"ax-caption\">\n                <ng-container\n                  *ngTemplateOutlet=\"c.renderFooterTemplate; context: { $implicit: { data: c, rows: displayedRows(), rowIndex: $index } }\"\n                ></ng-container>\n                @if (getSort(c)) {\n                  <ax-icon icon=\"ax-icon {{ getSort(c) }}\"></ax-icon>\n                }\n              </div>\n            </td>\n          }\n          @for (c of normalColumnsList(); track $index) {\n            <td\n              [class.ax-interactive]=\"c.allowSorting\"\n              (click)=\"c.allowSorting ? handleColumnClick($event, c) : null\"\n              [class.ax-data-table-sticky-header-cell]=\"c.fixed && c.width\"\n              [style.width]=\"c.width\"\n            >\n              <div class=\"ax-caption\">\n                <ng-container\n                  *ngTemplateOutlet=\"c.renderFooterTemplate; context: { $implicit: { data: c, rows: displayedRows(), rowIndex: $index } }\"\n                ></ng-container>\n                @if (getSort(c)) {\n                  <ax-icon icon=\"ax-icon {{ getSort(c) }}\"></ax-icon>\n                }\n              </div>\n              @if (c.allowResizing && !c.fixed) {\n                <div class=\"ax-resize-handle\" (mousedown)=\"onResizeColumnStart($event, this.startFixedColumnsList().length + $index)\"></div>\n              }\n            </td>\n          }\n          <td></td>\n          @for (c of endFixedColumnsList(); track $index) {\n            <td\n              class=\"ax-data-table-sticky-footer-cell sticky-end\"\n              [class.ax-interactive]=\"c.allowSorting\"\n              (click)=\"c.allowSorting ? handleColumnClick($event, c) : null\"\n              [class.ax-data-table-sticky-header-cell]=\"c.fixed && c.width\"\n              [style.width]=\"c.width\"\n              [class.isFirst]=\"c['isFirstFixedColumn']\"\n              [style.--sticky-end]=\"c['stickyEnd']\"\n            >\n              <div class=\"ax-caption\">\n                <ng-container\n                  *ngTemplateOutlet=\"c.renderFooterTemplate; context: { $implicit: { data: c, rows: displayedRows(), rowIndex: $index } }\"\n                ></ng-container>\n                @if (getSort(c)) {\n                  <ax-icon icon=\"ax-icon {{ getSort(c) }}\"></ax-icon>\n                }\n              </div>\n            </td>\n          }\n        </tr>\n      </tfoot>\n    }\n  </table>\n</div>\n\n@if (paging) {\n  <div class=\"ax-table-footer\" #footerContainer>\n    <ax-data-pager\n      #dataPager\n      [displayMode]=\"'custom'\"\n      (onChanged)=\"onPageChanged($event)\"\n      [total]=\"dataSource.totalCount\"\n      [size]=\"dataSource.pageSize\"\n      [isLoading]=\"isLoading()\"\n    >\n      <ax-prefix class=\"ax-data-table-numeric-paging\">\n        <ax-data-pager-numeric-selector> </ax-data-pager-numeric-selector>\n        <ax-data-pager-page-sizes> </ax-data-pager-page-sizes>\n      </ax-prefix>\n      <ax-prefix class=\"ax-data-table-input-paging\">\n        <ax-data-pager-prev-buttons> </ax-data-pager-prev-buttons>\n        <ax-data-pager-input-selector> </ax-data-pager-input-selector>\n        <ax-data-pager-next-buttons> </ax-data-pager-next-buttons>\n      </ax-prefix>\n      <ax-suffix class=\"ax-data-table-info\">\n        <ax-data-pager-info> </ax-data-pager-info>\n        <ax-button look=\"blank\" class=\"ax-sm\" (onClick)=\"refresh()\">\n          <ax-icon icon=\"ax-icon ax-icon-refresh\"></ax-icon>\n        </ax-button>\n      </ax-suffix>\n    </ax-data-pager>\n  </div>\n}\n<ng-content select=\"ax-footer\"> </ng-content>\n"]}