@acorex/components 7.24.5 → 17.0.0

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 (65) hide show
  1. package/common/lib/classes/datasource.class.d.ts +2 -0
  2. package/data-table/index.d.ts +3 -2
  3. package/data-table/lib/base-data-table.class.d.ts +25 -0
  4. package/data-table/lib/columns/row-command-column.component.d.ts +2 -2
  5. package/data-table/lib/data-table/data-table.component.d.ts +52 -0
  6. package/data-table/lib/data-table.module.d.ts +21 -18
  7. package/data-table/lib/{data-table.component.d.ts → infinite-scroll-data-table/infinite-scroll-data-table.component.d.ts} +8 -22
  8. package/esm2022/button/lib/button.component.mjs +2 -2
  9. package/esm2022/common/lib/classes/datasource.class.mjs +8 -2
  10. package/esm2022/common/lib/components/selection-base.component.class.mjs +2 -2
  11. package/esm2022/data-pager/lib/data-pager.component.mjs +7 -11
  12. package/esm2022/data-table/index.mjs +4 -3
  13. package/esm2022/data-table/lib/base-data-table.class.mjs +36 -0
  14. package/esm2022/data-table/lib/columns/row-command-column.component.mjs +57 -69
  15. package/esm2022/data-table/lib/columns/row-index-column.component.mjs +7 -21
  16. package/esm2022/data-table/lib/columns/row-select-column.component.mjs +6 -18
  17. package/esm2022/data-table/lib/data-table/data-table.component.mjs +233 -0
  18. package/esm2022/data-table/lib/data-table.module.mjs +24 -7
  19. package/esm2022/data-table/lib/infinite-scroll-data-table/infinite-scroll-data-table.component.mjs +272 -0
  20. package/esm2022/otp/lib/otp.component.mjs +2 -2
  21. package/esm2022/phone-box/lib/phone-box.component.mjs +21 -38
  22. package/esm2022/select-box/lib/select-box.component.mjs +2 -2
  23. package/esm2022/text-area/lib/text-area.component.mjs +6 -22
  24. package/fesm2022/acorex-components-button.mjs +2 -2
  25. package/fesm2022/acorex-components-button.mjs.map +1 -1
  26. package/fesm2022/acorex-components-common.mjs +8 -2
  27. package/fesm2022/acorex-components-common.mjs.map +1 -1
  28. package/fesm2022/acorex-components-data-pager.mjs +5 -9
  29. package/fesm2022/acorex-components-data-pager.mjs.map +1 -1
  30. package/fesm2022/acorex-components-data-table.mjs +684 -470
  31. package/fesm2022/acorex-components-data-table.mjs.map +1 -1
  32. package/fesm2022/acorex-components-otp.mjs +2 -2
  33. package/fesm2022/acorex-components-otp.mjs.map +1 -1
  34. package/fesm2022/acorex-components-phone-box.mjs +22 -38
  35. package/fesm2022/acorex-components-phone-box.mjs.map +1 -1
  36. package/fesm2022/acorex-components-select-box.mjs +2 -2
  37. package/fesm2022/acorex-components-select-box.mjs.map +1 -1
  38. package/fesm2022/acorex-components-text-area.mjs +5 -21
  39. package/fesm2022/acorex-components-text-area.mjs.map +1 -1
  40. package/package.json +25 -31
  41. package/phone-box/lib/phone-box.component.d.ts +4 -13
  42. package/text-area/lib/text-area.component.d.ts +0 -1
  43. package/data-table-2/README.md +0 -3
  44. package/data-table-2/index.d.ts +0 -8
  45. package/data-table-2/lib/columns/data-table-column-resizable.directive.d.ts +0 -22
  46. package/data-table-2/lib/columns/data-table-column.d.ts +0 -22
  47. package/data-table-2/lib/columns/data-text-column.component.d.ts +0 -18
  48. package/data-table-2/lib/columns/row-command-column.component.d.ts +0 -40
  49. package/data-table-2/lib/columns/row-index-column.component.d.ts +0 -18
  50. package/data-table-2/lib/columns/row-select-column.component.d.ts +0 -14
  51. package/data-table-2/lib/data-table-2.component.d.ts +0 -61
  52. package/data-table-2/lib/data-table-2.module.d.ts +0 -24
  53. package/esm2022/data-table/lib/data-table.component.mjs +0 -290
  54. package/esm2022/data-table-2/acorex-components-data-table-2.mjs +0 -5
  55. package/esm2022/data-table-2/index.mjs +0 -9
  56. package/esm2022/data-table-2/lib/columns/data-table-column-resizable.directive.mjs +0 -59
  57. package/esm2022/data-table-2/lib/columns/data-table-column.mjs +0 -42
  58. package/esm2022/data-table-2/lib/columns/data-text-column.component.mjs +0 -81
  59. package/esm2022/data-table-2/lib/columns/row-command-column.component.mjs +0 -231
  60. package/esm2022/data-table-2/lib/columns/row-index-column.component.mjs +0 -71
  61. package/esm2022/data-table-2/lib/columns/row-select-column.component.mjs +0 -61
  62. package/esm2022/data-table-2/lib/data-table-2.component.mjs +0 -211
  63. package/esm2022/data-table-2/lib/data-table-2.module.mjs +0 -94
  64. package/fesm2022/acorex-components-data-table-2.mjs +0 -822
  65. package/fesm2022/acorex-components-data-table-2.mjs.map +0 -1
@@ -1,18 +0,0 @@
1
- import { TemplateRef } from '@angular/core';
2
- import { AXDataTableColumnComponent } from './data-table-column';
3
- import { AXFormatOptions } from '@acorex/core/format';
4
- import * as i0 from "@angular/core";
5
- export declare class AXDataTableTextColumnComponent extends AXDataTableColumnComponent {
6
- dataField: string;
7
- wrapText: boolean;
8
- private _template;
9
- get template(): TemplateRef<unknown>;
10
- get loadingEnabled(): boolean;
11
- get name(): string;
12
- private formatService;
13
- protected getDisplayText(rowData: unknown, dataField: string): string;
14
- format: string;
15
- formatOptions: AXFormatOptions;
16
- static ɵfac: i0.ɵɵFactoryDeclaration<AXDataTableTextColumnComponent, never>;
17
- static ɵcmp: i0.ɵɵComponentDeclaration<AXDataTableTextColumnComponent, "ax-text-column", never, { "width": { "alias": "width"; "required": false; }; "caption": { "alias": "caption"; "required": false; }; "headerTemplate": { "alias": "headerTemplate"; "required": false; }; "cellTemplate": { "alias": "cellTemplate"; "required": false; }; "allowSorting": { "alias": "allowSorting"; "required": false; }; "allowResizing": { "alias": "allowResizing"; "required": false; }; "fixed": { "alias": "fixed"; "required": false; }; "dataField": { "alias": "dataField"; "required": false; }; "wrapText": { "alias": "wrapText"; "required": false; }; "format": { "alias": "format"; "required": false; }; "formatOptions": { "alias": "formatOptions"; "required": false; }; }, {}, never, never, false, never>;
18
- }
@@ -1,40 +0,0 @@
1
- import { AXButtonItemComponent, AXButtonItemListItem } from '@acorex/components/button';
2
- import { AXButtonClickEvent, AXItemClickEvent } from '@acorex/components/common';
3
- import { ChangeDetectorRef, EventEmitter, TemplateRef } from '@angular/core';
4
- import { AXDataTable2Component } from '../data-table-2.component';
5
- import { AXDataTableColumnComponent } from './data-table-column';
6
- import * as i0 from "@angular/core";
7
- export interface AXRowCommandItem extends AXButtonItemListItem {
8
- }
9
- export interface AXRowCommandItemClickEvent extends AXButtonClickEvent {
10
- }
11
- export declare abstract class AXBaseRowCommandColumnComponent extends AXDataTableColumnComponent {
12
- protected grid: AXDataTable2Component;
13
- protected cdr: ChangeDetectorRef;
14
- allowSorting: boolean;
15
- get loadingEnabled(): boolean;
16
- get cssClass(): string;
17
- onItemClick: EventEmitter<AXRowCommandItemClickEvent>;
18
- }
19
- export declare class AXRowDropdownCommandColumnComponent extends AXBaseRowCommandColumnComponent {
20
- private _template;
21
- get template(): TemplateRef<unknown>;
22
- get name(): string;
23
- protected _items: AXRowCommandItem[];
24
- items: AXRowCommandItem[] | ((rowData: unknown) => AXRowCommandItem[] | Promise<AXRowCommandItem[]>);
25
- protected handleOnOpened(rowData: any): Promise<void>;
26
- protected handleOnClosed(): void;
27
- protected handleOnItemClick(e: AXItemClickEvent<AXButtonItemComponent>, data: unknown): void;
28
- static ɵfac: i0.ɵɵFactoryDeclaration<AXRowDropdownCommandColumnComponent, never>;
29
- static ɵcmp: i0.ɵɵComponentDeclaration<AXRowDropdownCommandColumnComponent, "ax-dropdown-command-column", never, { "width": { "alias": "width"; "required": false; }; "caption": { "alias": "caption"; "required": false; }; "fixed": { "alias": "fixed"; "required": false; }; "items": { "alias": "items"; "required": false; }; }, { "onItemClick": "onItemClick"; }, never, never, false, never>;
30
- }
31
- export declare class AXRowCommandColumnComponent extends AXBaseRowCommandColumnComponent {
32
- private _template;
33
- get template(): TemplateRef<unknown>;
34
- get name(): string;
35
- items: AXRowCommandItem[] | ((rowData: unknown) => AXRowCommandItem[]);
36
- protected getItems(rowData: unknown): AXRowCommandItem[];
37
- protected handleOnItemClick(e: MouseEvent, item: AXRowCommandItem, data: unknown): void;
38
- static ɵfac: i0.ɵɵFactoryDeclaration<AXRowCommandColumnComponent, never>;
39
- static ɵcmp: i0.ɵɵComponentDeclaration<AXRowCommandColumnComponent, "ax-command-column", never, { "width": { "alias": "width"; "required": false; }; "caption": { "alias": "caption"; "required": false; }; "fixed": { "alias": "fixed"; "required": false; }; "items": { "alias": "items"; "required": false; }; }, { "onItemClick": "onItemClick"; }, never, never, false, never>;
40
- }
@@ -1,18 +0,0 @@
1
- import { OnInit, TemplateRef } from '@angular/core';
2
- import { AXDataTableColumnComponent } from './data-table-column';
3
- import * as i0 from "@angular/core";
4
- export declare class AXRowIndexColumnComponent extends AXDataTableColumnComponent implements OnInit {
5
- private grid;
6
- private unsubscriber;
7
- private _template;
8
- get template(): TemplateRef<unknown>;
9
- get name(): string;
10
- padZero: boolean;
11
- protected formatCount: number;
12
- ngOnInit(): void;
13
- allowSorting: boolean;
14
- get loadingEnabled(): boolean;
15
- get cssClass(): string | undefined;
16
- static ɵfac: i0.ɵɵFactoryDeclaration<AXRowIndexColumnComponent, never>;
17
- static ɵcmp: i0.ɵɵComponentDeclaration<AXRowIndexColumnComponent, "ax-index-column", never, { "width": { "alias": "width"; "required": false; }; "caption": { "alias": "caption"; "required": false; }; "fixed": { "alias": "fixed"; "required": false; }; "padZero": { "alias": "padZero"; "required": false; }; }, {}, never, never, false, never>;
18
- }
@@ -1,14 +0,0 @@
1
- import { TemplateRef } from '@angular/core';
2
- import { AXDataTableColumnComponent } from './data-table-column';
3
- import * as i0 from "@angular/core";
4
- export declare class AXRowSelectColumnComponent extends AXDataTableColumnComponent {
5
- private grid;
6
- private _template;
7
- get template(): TemplateRef<unknown>;
8
- get name(): string;
9
- protected isSelected(item: unknown): boolean;
10
- protected handleChange(item: unknown): void;
11
- get loadingEnabled(): boolean;
12
- static ɵfac: i0.ɵɵFactoryDeclaration<AXRowSelectColumnComponent, never>;
13
- static ɵcmp: i0.ɵɵComponentDeclaration<AXRowSelectColumnComponent, "ax-select-column", never, { "width": { "alias": "width"; "required": false; }; "caption": { "alias": "caption"; "required": false; }; "fixed": { "alias": "fixed"; "required": false; }; }, {}, never, never, false, never>;
14
- }
@@ -1,61 +0,0 @@
1
- import { AXDataSource, AXEvent, MXBaseComponent } from '@acorex/components/common';
2
- import { AXDataPagerChangedEvent } from '@acorex/components/data-pager';
3
- import { AfterViewInit, EventEmitter, OnInit, QueryList, TemplateRef, WritableSignal } from '@angular/core';
4
- import { AXDataTableColumnComponent } from './columns/data-table-column';
5
- import * as i0 from "@angular/core";
6
- export interface AXDataTableScrollIndexChanged extends AXEvent {
7
- index: number;
8
- }
9
- export interface AXDataTableRowClick extends AXEvent {
10
- data?: any;
11
- }
12
- export interface AXDataTableRowDbClick extends AXDataTableRowClick {
13
- }
14
- export declare class AXDataTable2Component extends MXBaseComponent implements OnInit, AfterViewInit {
15
- protected displayedRows: WritableSignal<any[]>;
16
- ngAfterViewInit(): void;
17
- ngOnInit(): void;
18
- protected columns: QueryList<AXDataTableColumnComponent>;
19
- rowTemplate?: TemplateRef<unknown>;
20
- emptyTemplate?: TemplateRef<unknown>;
21
- showHeader: boolean;
22
- stickyHeader: boolean;
23
- itemHeight: number | 'auto';
24
- fetchDataMode: 'auto' | 'manual';
25
- dataSource: AXDataSource<unknown>;
26
- loading: {
27
- enabled: boolean;
28
- animation: boolean;
29
- loadingTemplate?: TemplateRef<unknown>;
30
- };
31
- private _focusedRow;
32
- get focusedRow(): unknown;
33
- set focusedRow(v: unknown);
34
- private _selectedRows;
35
- get selectedRows(): unknown[];
36
- set selectedRows(v: unknown[]);
37
- protected isLoading: boolean;
38
- protected hasItems: boolean;
39
- protected totalRows: number;
40
- protected currentPage: number;
41
- protected totalPages: number;
42
- protected startRowIndex: number;
43
- private lastIndex;
44
- focusedRowChange: EventEmitter<unknown>;
45
- onRowClick: EventEmitter<AXDataTableRowClick>;
46
- onRowDbClick: EventEmitter<AXDataTableRowDbClick>;
47
- private clickSubject;
48
- selectedRowsChange: EventEmitter<unknown[]>;
49
- selectRows(...rows: unknown[]): void;
50
- unSelectRows(...rows: unknown[]): void;
51
- protected handleRowClick(event: MouseEvent, item: unknown): void;
52
- private handleRowSingleClick;
53
- protected onPageChanged(event: AXDataPagerChangedEvent): void;
54
- protected handleRowDoubleClick(e: MouseEvent, item: unknown): void;
55
- handleColumnClick(e: MouseEvent, column: AXDataTableColumnComponent): void;
56
- protected getSort(column: AXDataTableColumnComponent): string | undefined;
57
- refresh(): void;
58
- private calculateStickyPositions;
59
- static ɵfac: i0.ɵɵFactoryDeclaration<AXDataTable2Component, never>;
60
- static ɵcmp: i0.ɵɵComponentDeclaration<AXDataTable2Component, "ax-data-table-2", never, { "rowTemplate": { "alias": "rowTemplate"; "required": false; }; "emptyTemplate": { "alias": "emptyTemplate"; "required": false; }; "showHeader": { "alias": "showHeader"; "required": false; }; "stickyHeader": { "alias": "stickyHeader"; "required": false; }; "itemHeight": { "alias": "itemHeight"; "required": false; }; "fetchDataMode": { "alias": "fetchDataMode"; "required": false; }; "dataSource": { "alias": "dataSource"; "required": false; }; "loading": { "alias": "loading"; "required": false; }; "focusedRow": { "alias": "focusedRow"; "required": false; }; "selectedRows": { "alias": "selectedRows"; "required": false; }; }, { "focusedRowChange": "focusedRowChange"; "onRowClick": "onRowClick"; "onRowDbClick": "onRowDbClick"; "selectedRowsChange": "selectedRowsChange"; }, ["columns"], ["ax-header", "ax-footer"], false, never>;
61
- }
@@ -1,24 +0,0 @@
1
- import * as i0 from "@angular/core";
2
- import * as i1 from "./data-table-2.component";
3
- import * as i2 from "./columns/data-text-column.component";
4
- import * as i3 from "./columns/row-index-column.component";
5
- import * as i4 from "./columns/row-select-column.component";
6
- import * as i5 from "./columns/row-command-column.component";
7
- import * as i6 from "./columns/data-table-column-resizable.directive";
8
- import * as i7 from "@angular/common";
9
- import * as i8 from "@acorex/components/common";
10
- import * as i9 from "@angular/cdk/scrolling";
11
- import * as i10 from "@acorex/core/translation";
12
- import * as i11 from "@acorex/components/result";
13
- import * as i12 from "@acorex/components/loading";
14
- import * as i13 from "@acorex/components/decorators";
15
- import * as i14 from "@acorex/components/skeleton";
16
- import * as i15 from "@acorex/components/button";
17
- import * as i16 from "@acorex/components/dropdown";
18
- import * as i17 from "@acorex/core/format";
19
- import * as i18 from "@acorex/components/data-pager";
20
- export declare class AXDataTable2Module {
21
- static ɵfac: i0.ɵɵFactoryDeclaration<AXDataTable2Module, never>;
22
- static ɵmod: i0.ɵɵNgModuleDeclaration<AXDataTable2Module, [typeof i1.AXDataTable2Component, typeof i2.AXDataTableTextColumnComponent, typeof i3.AXRowIndexColumnComponent, typeof i4.AXRowSelectColumnComponent, typeof i5.AXRowCommandColumnComponent, typeof i5.AXRowDropdownCommandColumnComponent, typeof i6.AXDataTableColumnResizableDirective], [typeof i7.CommonModule, typeof i8.AXCommonModule, typeof i9.ScrollingModule, typeof i10.AXTranslationModule, typeof i11.AXResultModule, typeof i12.AXLoadingModule, typeof i13.AXDecoratorModule, typeof i14.AXSkeletonModule, typeof i15.AXButtonModule, typeof i16.AXDropdownModule, typeof i17.AXFormatModule, typeof i18.AXDataPagerModule, typeof i8.AXRippleDirective], [typeof i1.AXDataTable2Component, typeof i2.AXDataTableTextColumnComponent, typeof i3.AXRowIndexColumnComponent, typeof i4.AXRowSelectColumnComponent, typeof i5.AXRowCommandColumnComponent, typeof i5.AXRowDropdownCommandColumnComponent, typeof i6.AXDataTableColumnResizableDirective]>;
23
- static ɵinj: i0.ɵɵInjectorDeclaration<AXDataTable2Module>;
24
- }
@@ -1,290 +0,0 @@
1
- import { AXDataSource, AXListDataSource, AXPagedComponent, MXBaseComponent, convertArrayToDataSource, } from '@acorex/components/common';
2
- import { ChangeDetectionStrategy, Component, ContentChildren, ElementRef, EventEmitter, Input, NgZone, Output, QueryList, TemplateRef, ViewChild, ViewEncapsulation, inject, } from '@angular/core';
3
- import { CdkVirtualScrollViewport } from '@angular/cdk/scrolling';
4
- import sum from 'lodash-es/sum';
5
- import { Subject, buffer, debounceTime, filter } from 'rxjs';
6
- import { AXDataTableColumnComponent } from './columns/data-table-column';
7
- import { AXDataTableTextColumnComponent } from './columns/data-text-column.component';
8
- import * as i0 from "@angular/core";
9
- import * as i1 from "@angular/common";
10
- import * as i2 from "@angular/cdk/scrolling";
11
- import * as i3 from "@acorex/components/decorators";
12
- import * as i4 from "@acorex/components/skeleton";
13
- import * as i5 from "@acorex/components/button";
14
- export class AXDataTableComponent extends MXBaseComponent {
15
- constructor() {
16
- super(...arguments);
17
- this.ngZone = inject(NgZone);
18
- this.onPageChanged = new EventEmitter();
19
- this.clickSubject = new Subject();
20
- this.onRowClick = new EventEmitter();
21
- this.onRowDbClick = new EventEmitter();
22
- this.showHeader = true;
23
- this.fetchDataMode = 'auto';
24
- this.dataSource = convertArrayToDataSource([]);
25
- this.loading = {
26
- enabled: true,
27
- animation: true,
28
- };
29
- this.isLoading = true;
30
- this.hasItems = false;
31
- this.totalRows = 0;
32
- this.currentPage = 0;
33
- this.totalPages = 0;
34
- this.startRowIndex = 0;
35
- this.lastIndex = 0;
36
- this.focusedRowChange = new EventEmitter();
37
- this.selectedRowsChange = new EventEmitter();
38
- this._selectedRows = [];
39
- this.itemHeight = 40;
40
- this.width = '100%';
41
- this.height = '100%';
42
- this.onScrolledIndexChanged = new EventEmitter();
43
- }
44
- startFixedColumn() {
45
- return this.columns?.toArray().filter((c) => c.fixed == 'start') ?? [];
46
- }
47
- endFixedColumn() {
48
- return this.columns?.toArray().filter((c) => c.fixed == 'end') ?? [];
49
- }
50
- notFixedColumn() {
51
- return this.columns?.toArray().filter((c) => !c.fixed) ?? [];
52
- }
53
- notFixedColumnCount() {
54
- return this.columns?.toArray().filter((c) => !c.fixed).length ?? 0;
55
- }
56
- fixedColumnCount() {
57
- return this.columns?.toArray().filter((c) => c.fixed).length ?? 0;
58
- }
59
- get focusedRow() {
60
- return this._focusedRow;
61
- }
62
- set focusedRow(v) {
63
- this._focusedRow = v;
64
- this.focusedRowChange.emit(v);
65
- }
66
- get selectedRows() {
67
- return this._selectedRows;
68
- }
69
- set selectedRows(v) {
70
- this._selectedRows = v;
71
- this.selectedRowsChange.emit(v);
72
- }
73
- selectRows(...rows) {
74
- this.selectedRows = [...this.selectedRows, ...rows];
75
- }
76
- unSelectRows(...rows) {
77
- this.selectedRows = this.selectedRows.filter((c) => !rows.includes(c));
78
- }
79
- trackByIdx(i) {
80
- return i;
81
- }
82
- ngOnInit() {
83
- super.ngOnInit();
84
- this.listDataSource = new AXListDataSource({
85
- source: this.dataSource,
86
- });
87
- this.listDataSource.source.onLoadingChanged.subscribe((data) => {
88
- this.isLoading = data;
89
- });
90
- this.listDataSource.source.onChanged.subscribe((data) => {
91
- this.totalRows = data.totalCount;
92
- this.hasItems = data.totalCount > 0;
93
- setTimeout(() => {
94
- this.render();
95
- }, 100);
96
- });
97
- //
98
- this.clickSubject
99
- .pipe(buffer(this.clickSubject.pipe(debounceTime(250))), filter((clickArray) => clickArray.length === 2))
100
- .subscribe((clickArray) => {
101
- this.handleRowDoubleClick(clickArray[0].event, clickArray[0].item);
102
- });
103
- }
104
- _handleOnscrolledIndexChange(e) {
105
- this.lastIndex = e;
106
- this.onScrolledIndexChanged.emit({
107
- component: this,
108
- index: this.lastIndex,
109
- isUserInteraction: true,
110
- });
111
- }
112
- ngDoCheck() {
113
- //this.copyFixedColumns();
114
- this.updateHScroll();
115
- //
116
- this.updateWidth();
117
- this.updateHeight();
118
- //
119
- this.updateTotalCount();
120
- }
121
- updateTotalCount() {
122
- this.startRowIndex = this.lastIndex;
123
- if (this.startRowIndex < 1)
124
- this.startRowIndex = 1;
125
- if (this.startRowIndex > this.totalRows)
126
- this.startRowIndex = this.totalRows;
127
- }
128
- updateHeight() {
129
- this.height = `calc(100% - ${(this.headerContainer?.nativeElement.clientHeight ?? 0) +
130
- (this.footerContainer?.nativeElement.clientHeight ?? 0)}px)`;
131
- }
132
- updateWidth() {
133
- if (this.columns && this.columns.length) {
134
- const sumPx = sum(this.columns
135
- .toArray()
136
- .map((c) => typeof c.width == 'number'
137
- ? c.width
138
- : Number(c.width.replace('px', ''))));
139
- this.width = `${Math.max(sumPx, this.getHostElement().clientWidth - 5)}px`;
140
- }
141
- }
142
- updateHScroll() {
143
- this.ngZone.runOutsideAngular(() => {
144
- if (this.headerContainer) {
145
- const headerContainer = this.headerContainer.nativeElement;
146
- const left = this.scrollableContainer.nativeElement.scrollLeft;
147
- headerContainer.style.transform = `translateX(${-left}px)`;
148
- }
149
- });
150
- }
151
- // Function to copy fixed columns
152
- copyFixedColumns() {
153
- const originalRows = Array.from(this.viewport._contentWrapper.nativeElement.querySelectorAll('tr'));
154
- const fixedColumnTable = this.getHostElement().querySelector('.ax-body-fixed-columns > table > tbody');
155
- fixedColumnTable.querySelectorAll('tr').forEach((n) => n.remove());
156
- for (const row of originalRows) {
157
- const fixedCells = Array.from(row.querySelectorAll('[data-fixed="start"]'));
158
- const fixedRow = document.createElement('tr');
159
- for (const cell of fixedCells) {
160
- const clonedCell = cell.cloneNode(true);
161
- fixedRow.appendChild(clonedCell);
162
- }
163
- fixedColumnTable.appendChild(fixedRow);
164
- }
165
- const scrollTop = this.getHostElement().querySelector('.cdk-virtual-scrollable').scrollTop;
166
- fixedColumnTable.style.transform = `translateY(${-scrollTop}px)`;
167
- }
168
- render() {
169
- this.viewport.checkViewportSize();
170
- this.viewport.scrollToIndex(this.lastIndex);
171
- this.cdr.markForCheck();
172
- }
173
- refresh() {
174
- this.lastIndex = 0;
175
- this.dataSource.refresh();
176
- }
177
- handleRowClick(event, item) {
178
- this.handleRowSingleClick(event, item);
179
- this.clickSubject.next({ event, item });
180
- }
181
- handleRowSingleClick(event, item) {
182
- if (this.focusedRow == item) {
183
- this.focusedRow = null;
184
- }
185
- else {
186
- this.focusedRow = item;
187
- }
188
- //
189
- this.onRowClick.emit({
190
- component: this,
191
- data: item,
192
- isUserInteraction: true,
193
- });
194
- }
195
- handleRowDoubleClick(e, item) {
196
- this.focusedRow = item;
197
- //
198
- this.onRowDbClick.emit({
199
- component: this,
200
- data: item,
201
- isUserInteraction: true,
202
- });
203
- }
204
- handleColumnClick(e, column) {
205
- if (column instanceof AXDataTableTextColumnComponent) {
206
- const sort = this.dataSource.query.sort.find((c) => c.field == column.dataField);
207
- if (!sort) {
208
- this.dataSource.query.sort.push({
209
- field: column.dataField,
210
- dir: 'asc',
211
- });
212
- }
213
- else {
214
- if (sort.dir == 'asc') {
215
- sort.dir = 'desc';
216
- }
217
- else {
218
- this.dataSource.query.sort = this.dataSource.query.sort.filter((c) => c != sort);
219
- }
220
- }
221
- this.refresh();
222
- }
223
- }
224
- getSort(column) {
225
- if (column instanceof AXDataTableTextColumnComponent) {
226
- const sort = this.dataSource.query.sort.find((c) => c.field == column.dataField);
227
- return sort
228
- ? sort.dir == 'asc'
229
- ? 'ax-icon-arrow-long-down'
230
- : 'ax-icon-arrow-long-up'
231
- : undefined;
232
- }
233
- return undefined;
234
- }
235
- _handleOnScroll() {
236
- this.updateHScroll();
237
- }
238
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.2", ngImport: i0, type: AXDataTableComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
239
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.2", type: AXDataTableComponent, selector: "ax-data-table", inputs: { rowTemplate: "rowTemplate", emptyTemplate: "emptyTemplate", showHeader: "showHeader", fetchDataMode: "fetchDataMode", dataSource: "dataSource", loading: "loading", focusedRow: "focusedRow", selectedRows: "selectedRows", itemHeight: "itemHeight" }, outputs: { onPageChanged: "onPageChanged", onRowClick: "onRowClick", onRowDbClick: "onRowDbClick", focusedRowChange: "focusedRowChange", selectedRowsChange: "selectedRowsChange", onScrolledIndexChanged: "onScrolledIndexChanged" }, providers: [{ provide: AXPagedComponent, useExisting: AXDataTableComponent }], queries: [{ propertyName: "columns", predicate: AXDataTableColumnComponent }], viewQueries: [{ propertyName: "viewport", first: true, predicate: CdkVirtualScrollViewport, descendants: true, static: true }, { propertyName: "headerContainer", first: true, predicate: ["headerContainer"], descendants: true }, { propertyName: "footerContainer", first: true, predicate: ["footerContainer"], descendants: true }, { propertyName: "scrollableContainer", first: true, predicate: ["scrolling"], descendants: true, static: true }], usesInheritance: true, ngImport: i0, template: "<ng-content select=\"ax-header\"> </ng-content>\n<!------------------- Header contents ------------------->\n@if(showHeader){\n<div class=\"ax-header-content\">\n <div class=\"ax-header-columns\">\n <table tabindex=\"0\" [style.width]=\"width\" #headerContainer>\n <thead>\n <tr>\n @for(c of notFixedColumn();track c.name)\n {\n <th [class.ax-interactive]=\"c.allowSorting\" (click)=\"c.allowSorting ? handleColumnClick($event, c) : null\"\n [style.width]=\"c.width\">\n @if(c.headerTemplate)\n {\n <ng-container *ngTemplateOutlet=\"c.headerTemplate\"></ng-container>\n }\n @else {\n <div class=\"ax-caption\">\n {{ c.caption }}\n @if(getSort(c)){\n <ax-icon icon=\"ax-icon {{ getSort(c) }}\"></ax-icon>\n }\n </div>\n }\n <!-- @if(c.allowResizing)\n {\n <div class=\"ax-resize-handle\" [ax-table-column-resizble]=\"c\"></div>\n } -->\n </th>\n }\n <th></th>\n </tr>\n </thead>\n </table>\n </div>\n</div>\n}\n\n<!------------------- Body contents ------------------->\n<div [style.height]=\"height\" class=\"ax-body-content\">\n <div class=\"ax-body-columns\">\n <div cdkVirtualScrollingElement #scrolling [style.height]=\"'100%'\" (scroll)=\"_handleOnScroll()\">\n <cdk-virtual-scroll-viewport [itemSize]=\"itemHeight\" [style.--item-height]=\"itemHeight + 'px'\"\n (scrolledIndexChange)=\"_handleOnscrolledIndexChange($event)\">\n <table tabindex=\"0\" class=\"ax-table-body ax-relative\" [style.width]=\"width\">\n <colgroup>\n @for(c of notFixedColumn();track c.name)\n {\n <col [style.width]=\"c.width\" />\n }\n <col />\n </colgroup>\n <tbody>\n <ng-container *cdkVirtualFor=\"\n let item of listDataSource;\n templateCacheSize: 100;\n let i = index;\n trackBy: trackByIdx;\n let rIndex = index\n \">\n <!------------------- custom row template------------------->\n @if (rowTemplate != null) {\n <ng-container *ngTemplateOutlet=\"rowTemplate; context: { $implicit: { data: item, rowIndex: rIndex } }\">\n </ng-container>\n } @else {\n <!------------------- normal row template------------------->\n <tr [class.ax-state-focused]=\"focusedRow && item === focusedRow\" [attr.data-index]=\"rIndex\"\n [class.ax-state-selected]=\"selectedRows.includes(item)\" (click)=\"handleRowClick($event, item)\">\n <!------------------- start fixed column ------------------->\n\n <!------------------- Not fixed column ------------------->\n @for (c of notFixedColumn(); track c.name) {\n <!------------------- custom cell template ------------------->\n @if (c.cellTemplate) {\n <ng-container\n *ngTemplateOutlet=\"c.cellTemplate;context: { $implicit: { data: item, rowIndex: rIndex } }\">\n </ng-container>\n } @else {\n <!------------------- default cell template ------------------->\n <td [attr.data-label]=\"c.caption\" tabindex=\"0\" [class]=\"c.cssClass\">\n @if (item) {\n <!------------------- render cell ------------------->\n <ng-container\n *ngTemplateOutlet=\"c.template;context: { $implicit: { data: item, rowIndex: rIndex } }\"></ng-container>\n }\n @else {\n <!------------------- render loading ------------------->\n @if (c.loadingEnabled && loading) {\n <ax-skeleton [animated]=\"loading.animation\"></ax-skeleton>\n }\n }\n </td>\n }\n }\n <td></td>\n </tr>\n }\n </ng-container>\n </tbody>\n </table>\n </cdk-virtual-scroll-viewport>\n </div>\n </div>\n</div>\n<div class=\"ax-table-footer\" #footerContainer>\n <div class=\"ax-table-info\">\n <div>Showing {{ startRowIndex }} of {{ totalRows }} items</div>\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 </div>\n <ng-content select=\"ax-footer\"> </ng-content>\n</div>", styles: [".ax-dark ax-data-table .ax-header-content th.ax-interactive:hover{background-color:rgba(var(--ax-color-neutral-500))!important}.ax-dark ax-data-table .ax-body-content tr:hover td:not(.ax-index-column){background-color:rgba(var(--ax-color-primary-800))!important;color:rgba(var(--ax-color-primary-fore))!important}.ax-dark ax-data-table .ax-body-content tr.ax-state-focused td:not(.ax-index-column){background-color:rgba(var(--ax-color-primary-900))!important;color:rgba(var(--ax-color-primary-fore))!important}.ax-dark ax-data-table .ax-body-content tr.ax-state-focused:hover td:not(.ax-index-column){background-color:rgba(var(--ax-color-primary-800))!important}.ax-dark ax-data-table .ax-body-content tr.ax-state-selected td:not(.ax-index-column){background-color:rgba(var(--ax-color-primary-900))!important;color:rgba(var(--ax-color-primary-fore))!important}.ax-dark ax-data-table .ax-body-content tr.ax-state-selected:hover td:not(.ax-index-column){background-color:rgba(var(--ax-color-primary-800))!important}ax-data-table{display:block;height:100%;overflow:hidden;border-radius:var(--ax-rounded-border-default);border-width:1px;border-color:rgba(var(--ax-color-border-default));font-size:.875rem;line-height:1.25rem}ax-data-table table{table-layout:fixed}ax-data-table .ax-header-content{position:relative;height:3rem;overflow:hidden}ax-data-table .ax-header-content .ax-header-fixed-columns{pointer-events:none;position:absolute;z-index:10}ax-data-table .ax-header-content .ax-header-fixed-columns th.ax-column-fixed{pointer-events:auto}ax-data-table .ax-header-content .ax-header-fixed-columns th:not(.ax-column-fixed){visibility:hidden;background-color:transparent}ax-data-table .ax-header-content .ax-header-columns{height:100%}ax-data-table .ax-header-content .ax-header-columns>table{height:100%;overflow:hidden;border-start-end-radius:var(--ax-rounded-border-default);border-start-start-radius:var(--ax-rounded-border-default)}ax-data-table .ax-header-content .ax-header-columns>table th{border-bottom-width:1px;border-inline-end-width:1px;border-style:solid;border-color:rgba(var(--ax-color-border-default));background-color:rgba(var(--ax-color-on-surface));padding:.75rem 1rem;text-align:start;font-weight:500;text-transform:uppercase;position:relative}ax-data-table .ax-header-content .ax-header-columns>table th.ax-interactive{cursor:pointer}ax-data-table .ax-header-content .ax-header-columns>table th.ax-interactive:hover{background-color:rgba(var(--ax-color-neutral-200))}ax-data-table .ax-header-content .ax-header-columns>table th .ax-resize-handle{position:absolute;right:0;top:0;bottom:0;width:4px;cursor:col-resize;background:transparent}ax-data-table .ax-header-content .ax-header-columns>table th .ax-resize-handle:hover{background-color:rgba(var(--ax-color-neutral-300))}ax-data-table .ax-header-content .ax-header-columns>table th .ax-caption{display:flex;align-items:center;gap:.5rem}ax-data-table .ax-header-content .ax-header-columns>table th:last-child{border-inline-end-width:0px}ax-data-table .ax-body-content{position:relative}ax-data-table .ax-body-content .ax-body-fixed-columns{pointer-events:none;position:absolute;z-index:10}ax-data-table .ax-body-content .ax-body-columns{height:100%}ax-data-table .ax-body-content .ax-body-columns table{border-collapse:collapse}ax-data-table .ax-body-content .ax-body-columns table tr:nth-child(2n) td{background-color:rgba(var(--ax-color-on-surface))}ax-data-table .ax-body-content .ax-body-columns table tr:nth-child(2n) ax-skeleton{width:25%}ax-data-table .ax-body-content .ax-body-columns table tr{height:2.5rem}ax-data-table .ax-body-content .ax-body-columns table tr:hover td:not(.ax-index-column){background-color:rgba(var(--ax-color-primary-200))}ax-data-table .ax-body-content .ax-body-columns table tr.ax-state-focused td:not(.ax-index-column){background-color:rgba(var(--ax-color-primary-200));color:rgba(var(--ax-color-primary-fore-tint))}ax-data-table .ax-body-content .ax-body-columns table tr.ax-state-focused:hover td:not(.ax-index-column){background-color:rgba(var(--ax-color-primary-300))}ax-data-table .ax-body-content .ax-body-columns table tr.ax-state-selected td:not(.ax-index-column){background-color:rgba(var(--ax-color-primary-300));color:rgba(var(--ax-color-primary-fore-tint))}ax-data-table .ax-body-content .ax-body-columns table tr.ax-state-selected:hover td:not(.ax-index-column){background-color:rgba(var(--ax-color-primary-400));color:rgba(var(--ax-color-primary-fore))}ax-data-table .ax-body-content .ax-body-columns table td{position:relative;min-width:2rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;border-bottom-width:1px;border-inline-end-width:1px;border-color:rgba(var(--ax-color-border-default));background-color:rgba(var(--ax-color-surface));padding:.5rem 1rem;vertical-align:middle}ax-data-table .ax-body-content .ax-body-columns table td.ax-index-column{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;background-color:rgba(var(--ax-color-on-surface));text-align:center}ax-data-table .ax-body-content .ax-body-columns table td.ax-command-column button.ax-state-disabled{position:relative!important;cursor:not-allowed!important;opacity:.5!important}ax-data-table .ax-body-content .ax-body-columns table td.ax-command-column>div{position:absolute;inset-inline-start:0px;top:50%;display:flex;width:100%;transform:translateY(-50%);align-items:center;justify-content:center}ax-data-table .ax-body-content .ax-body-columns table td.ax-command-column button{position:relative;cursor:pointer;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;border-radius:var(--ax-rounded-border-default);border-style:none;border-color:rgba(var(--ax-color-border-default));background-color:transparent;padding:.25rem;line-height:1;color:rgba(var(--ax-color-ghost-fore))}ax-data-table .ax-body-content .ax-body-columns table td.ax-command-column button:hover:not(ax-data-table .ax-body-content .ax-body-columns table td.ax-command-column button:hover.ax-state-selected,ax-data-table .ax-body-content .ax-body-columns table td.ax-command-column button:hover.ax-state-disabled){opacity:.75}ax-data-table .ax-body-content .ax-body-columns table td.ax-command-column button:active{opacity:1}ax-data-table .ax-body-content .ax-body-columns table td.ax-command-column button .ax-ripple{background-color:rgba(var(--ax-color-ghost-fore),.05)}ax-data-table .ax-body-content .ax-body-columns table td:last-child{border-inline-end-width:0px}ax-data-table .ax-body-content .ax-body-columns table td ax-skeleton{height:.875rem;width:33.333333%;border-radius:.375rem}ax-data-table .ax-table-footer{border-collapse:collapse;overflow:hidden;border-top-width:1px;border-color:rgba(var(--ax-color-border-default));padding:.5rem .875rem}ax-data-table .ax-table-footer .ax-table-info{display:flex;flex:1 1 0%;align-items:center;justify-content:space-between}\n"], dependencies: [{ kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i2.CdkFixedSizeVirtualScroll, selector: "cdk-virtual-scroll-viewport[itemSize]", inputs: ["itemSize", "minBufferPx", "maxBufferPx"] }, { kind: "directive", type: i2.CdkVirtualForOf, selector: "[cdkVirtualFor][cdkVirtualForOf]", inputs: ["cdkVirtualForOf", "cdkVirtualForTrackBy", "cdkVirtualForTemplate", "cdkVirtualForTemplateCacheSize"] }, { kind: "component", type: i2.CdkVirtualScrollViewport, selector: "cdk-virtual-scroll-viewport", inputs: ["orientation", "appendOnly"], outputs: ["scrolledIndexChange"] }, { kind: "directive", type: i2.CdkVirtualScrollableElement, selector: "[cdkVirtualScrollingElement]" }, { kind: "component", type: i3.AXDecoratorIconComponent, selector: "ax-icon", inputs: ["icon"] }, { kind: "component", type: i4.AXSkeletonComponent, selector: "ax-skeleton", inputs: ["animated"] }, { kind: "component", type: i5.AXButtonComponent, selector: "ax-button", inputs: ["disabled", "size", "tabIndex", "color", "look", "text", "toggleable", "selected", "type"], outputs: ["onBlur", "onFocus", "onClick", "selectedChange", "toggleableChange", "lookChange", "colorChange", "disabledChange"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
240
- }
241
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.2", ngImport: i0, type: AXDataTableComponent, decorators: [{
242
- type: Component,
243
- args: [{ selector: 'ax-data-table', encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, providers: [{ provide: AXPagedComponent, useExisting: AXDataTableComponent }], template: "<ng-content select=\"ax-header\"> </ng-content>\n<!------------------- Header contents ------------------->\n@if(showHeader){\n<div class=\"ax-header-content\">\n <div class=\"ax-header-columns\">\n <table tabindex=\"0\" [style.width]=\"width\" #headerContainer>\n <thead>\n <tr>\n @for(c of notFixedColumn();track c.name)\n {\n <th [class.ax-interactive]=\"c.allowSorting\" (click)=\"c.allowSorting ? handleColumnClick($event, c) : null\"\n [style.width]=\"c.width\">\n @if(c.headerTemplate)\n {\n <ng-container *ngTemplateOutlet=\"c.headerTemplate\"></ng-container>\n }\n @else {\n <div class=\"ax-caption\">\n {{ c.caption }}\n @if(getSort(c)){\n <ax-icon icon=\"ax-icon {{ getSort(c) }}\"></ax-icon>\n }\n </div>\n }\n <!-- @if(c.allowResizing)\n {\n <div class=\"ax-resize-handle\" [ax-table-column-resizble]=\"c\"></div>\n } -->\n </th>\n }\n <th></th>\n </tr>\n </thead>\n </table>\n </div>\n</div>\n}\n\n<!------------------- Body contents ------------------->\n<div [style.height]=\"height\" class=\"ax-body-content\">\n <div class=\"ax-body-columns\">\n <div cdkVirtualScrollingElement #scrolling [style.height]=\"'100%'\" (scroll)=\"_handleOnScroll()\">\n <cdk-virtual-scroll-viewport [itemSize]=\"itemHeight\" [style.--item-height]=\"itemHeight + 'px'\"\n (scrolledIndexChange)=\"_handleOnscrolledIndexChange($event)\">\n <table tabindex=\"0\" class=\"ax-table-body ax-relative\" [style.width]=\"width\">\n <colgroup>\n @for(c of notFixedColumn();track c.name)\n {\n <col [style.width]=\"c.width\" />\n }\n <col />\n </colgroup>\n <tbody>\n <ng-container *cdkVirtualFor=\"\n let item of listDataSource;\n templateCacheSize: 100;\n let i = index;\n trackBy: trackByIdx;\n let rIndex = index\n \">\n <!------------------- custom row template------------------->\n @if (rowTemplate != null) {\n <ng-container *ngTemplateOutlet=\"rowTemplate; context: { $implicit: { data: item, rowIndex: rIndex } }\">\n </ng-container>\n } @else {\n <!------------------- normal row template------------------->\n <tr [class.ax-state-focused]=\"focusedRow && item === focusedRow\" [attr.data-index]=\"rIndex\"\n [class.ax-state-selected]=\"selectedRows.includes(item)\" (click)=\"handleRowClick($event, item)\">\n <!------------------- start fixed column ------------------->\n\n <!------------------- Not fixed column ------------------->\n @for (c of notFixedColumn(); track c.name) {\n <!------------------- custom cell template ------------------->\n @if (c.cellTemplate) {\n <ng-container\n *ngTemplateOutlet=\"c.cellTemplate;context: { $implicit: { data: item, rowIndex: rIndex } }\">\n </ng-container>\n } @else {\n <!------------------- default cell template ------------------->\n <td [attr.data-label]=\"c.caption\" tabindex=\"0\" [class]=\"c.cssClass\">\n @if (item) {\n <!------------------- render cell ------------------->\n <ng-container\n *ngTemplateOutlet=\"c.template;context: { $implicit: { data: item, rowIndex: rIndex } }\"></ng-container>\n }\n @else {\n <!------------------- render loading ------------------->\n @if (c.loadingEnabled && loading) {\n <ax-skeleton [animated]=\"loading.animation\"></ax-skeleton>\n }\n }\n </td>\n }\n }\n <td></td>\n </tr>\n }\n </ng-container>\n </tbody>\n </table>\n </cdk-virtual-scroll-viewport>\n </div>\n </div>\n</div>\n<div class=\"ax-table-footer\" #footerContainer>\n <div class=\"ax-table-info\">\n <div>Showing {{ startRowIndex }} of {{ totalRows }} items</div>\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 </div>\n <ng-content select=\"ax-footer\"> </ng-content>\n</div>", styles: [".ax-dark ax-data-table .ax-header-content th.ax-interactive:hover{background-color:rgba(var(--ax-color-neutral-500))!important}.ax-dark ax-data-table .ax-body-content tr:hover td:not(.ax-index-column){background-color:rgba(var(--ax-color-primary-800))!important;color:rgba(var(--ax-color-primary-fore))!important}.ax-dark ax-data-table .ax-body-content tr.ax-state-focused td:not(.ax-index-column){background-color:rgba(var(--ax-color-primary-900))!important;color:rgba(var(--ax-color-primary-fore))!important}.ax-dark ax-data-table .ax-body-content tr.ax-state-focused:hover td:not(.ax-index-column){background-color:rgba(var(--ax-color-primary-800))!important}.ax-dark ax-data-table .ax-body-content tr.ax-state-selected td:not(.ax-index-column){background-color:rgba(var(--ax-color-primary-900))!important;color:rgba(var(--ax-color-primary-fore))!important}.ax-dark ax-data-table .ax-body-content tr.ax-state-selected:hover td:not(.ax-index-column){background-color:rgba(var(--ax-color-primary-800))!important}ax-data-table{display:block;height:100%;overflow:hidden;border-radius:var(--ax-rounded-border-default);border-width:1px;border-color:rgba(var(--ax-color-border-default));font-size:.875rem;line-height:1.25rem}ax-data-table table{table-layout:fixed}ax-data-table .ax-header-content{position:relative;height:3rem;overflow:hidden}ax-data-table .ax-header-content .ax-header-fixed-columns{pointer-events:none;position:absolute;z-index:10}ax-data-table .ax-header-content .ax-header-fixed-columns th.ax-column-fixed{pointer-events:auto}ax-data-table .ax-header-content .ax-header-fixed-columns th:not(.ax-column-fixed){visibility:hidden;background-color:transparent}ax-data-table .ax-header-content .ax-header-columns{height:100%}ax-data-table .ax-header-content .ax-header-columns>table{height:100%;overflow:hidden;border-start-end-radius:var(--ax-rounded-border-default);border-start-start-radius:var(--ax-rounded-border-default)}ax-data-table .ax-header-content .ax-header-columns>table th{border-bottom-width:1px;border-inline-end-width:1px;border-style:solid;border-color:rgba(var(--ax-color-border-default));background-color:rgba(var(--ax-color-on-surface));padding:.75rem 1rem;text-align:start;font-weight:500;text-transform:uppercase;position:relative}ax-data-table .ax-header-content .ax-header-columns>table th.ax-interactive{cursor:pointer}ax-data-table .ax-header-content .ax-header-columns>table th.ax-interactive:hover{background-color:rgba(var(--ax-color-neutral-200))}ax-data-table .ax-header-content .ax-header-columns>table th .ax-resize-handle{position:absolute;right:0;top:0;bottom:0;width:4px;cursor:col-resize;background:transparent}ax-data-table .ax-header-content .ax-header-columns>table th .ax-resize-handle:hover{background-color:rgba(var(--ax-color-neutral-300))}ax-data-table .ax-header-content .ax-header-columns>table th .ax-caption{display:flex;align-items:center;gap:.5rem}ax-data-table .ax-header-content .ax-header-columns>table th:last-child{border-inline-end-width:0px}ax-data-table .ax-body-content{position:relative}ax-data-table .ax-body-content .ax-body-fixed-columns{pointer-events:none;position:absolute;z-index:10}ax-data-table .ax-body-content .ax-body-columns{height:100%}ax-data-table .ax-body-content .ax-body-columns table{border-collapse:collapse}ax-data-table .ax-body-content .ax-body-columns table tr:nth-child(2n) td{background-color:rgba(var(--ax-color-on-surface))}ax-data-table .ax-body-content .ax-body-columns table tr:nth-child(2n) ax-skeleton{width:25%}ax-data-table .ax-body-content .ax-body-columns table tr{height:2.5rem}ax-data-table .ax-body-content .ax-body-columns table tr:hover td:not(.ax-index-column){background-color:rgba(var(--ax-color-primary-200))}ax-data-table .ax-body-content .ax-body-columns table tr.ax-state-focused td:not(.ax-index-column){background-color:rgba(var(--ax-color-primary-200));color:rgba(var(--ax-color-primary-fore-tint))}ax-data-table .ax-body-content .ax-body-columns table tr.ax-state-focused:hover td:not(.ax-index-column){background-color:rgba(var(--ax-color-primary-300))}ax-data-table .ax-body-content .ax-body-columns table tr.ax-state-selected td:not(.ax-index-column){background-color:rgba(var(--ax-color-primary-300));color:rgba(var(--ax-color-primary-fore-tint))}ax-data-table .ax-body-content .ax-body-columns table tr.ax-state-selected:hover td:not(.ax-index-column){background-color:rgba(var(--ax-color-primary-400));color:rgba(var(--ax-color-primary-fore))}ax-data-table .ax-body-content .ax-body-columns table td{position:relative;min-width:2rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;border-bottom-width:1px;border-inline-end-width:1px;border-color:rgba(var(--ax-color-border-default));background-color:rgba(var(--ax-color-surface));padding:.5rem 1rem;vertical-align:middle}ax-data-table .ax-body-content .ax-body-columns table td.ax-index-column{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;background-color:rgba(var(--ax-color-on-surface));text-align:center}ax-data-table .ax-body-content .ax-body-columns table td.ax-command-column button.ax-state-disabled{position:relative!important;cursor:not-allowed!important;opacity:.5!important}ax-data-table .ax-body-content .ax-body-columns table td.ax-command-column>div{position:absolute;inset-inline-start:0px;top:50%;display:flex;width:100%;transform:translateY(-50%);align-items:center;justify-content:center}ax-data-table .ax-body-content .ax-body-columns table td.ax-command-column button{position:relative;cursor:pointer;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;border-radius:var(--ax-rounded-border-default);border-style:none;border-color:rgba(var(--ax-color-border-default));background-color:transparent;padding:.25rem;line-height:1;color:rgba(var(--ax-color-ghost-fore))}ax-data-table .ax-body-content .ax-body-columns table td.ax-command-column button:hover:not(ax-data-table .ax-body-content .ax-body-columns table td.ax-command-column button:hover.ax-state-selected,ax-data-table .ax-body-content .ax-body-columns table td.ax-command-column button:hover.ax-state-disabled){opacity:.75}ax-data-table .ax-body-content .ax-body-columns table td.ax-command-column button:active{opacity:1}ax-data-table .ax-body-content .ax-body-columns table td.ax-command-column button .ax-ripple{background-color:rgba(var(--ax-color-ghost-fore),.05)}ax-data-table .ax-body-content .ax-body-columns table td:last-child{border-inline-end-width:0px}ax-data-table .ax-body-content .ax-body-columns table td ax-skeleton{height:.875rem;width:33.333333%;border-radius:.375rem}ax-data-table .ax-table-footer{border-collapse:collapse;overflow:hidden;border-top-width:1px;border-color:rgba(var(--ax-color-border-default));padding:.5rem .875rem}ax-data-table .ax-table-footer .ax-table-info{display:flex;flex:1 1 0%;align-items:center;justify-content:space-between}\n"] }]
244
- }], propDecorators: { columns: [{
245
- type: ContentChildren,
246
- args: [AXDataTableColumnComponent]
247
- }], onPageChanged: [{
248
- type: Output
249
- }], onRowClick: [{
250
- type: Output
251
- }], onRowDbClick: [{
252
- type: Output
253
- }], rowTemplate: [{
254
- type: Input
255
- }], emptyTemplate: [{
256
- type: Input
257
- }], showHeader: [{
258
- type: Input
259
- }], fetchDataMode: [{
260
- type: Input
261
- }], dataSource: [{
262
- type: Input
263
- }], loading: [{
264
- type: Input
265
- }], focusedRowChange: [{
266
- type: Output
267
- }], focusedRow: [{
268
- type: Input
269
- }], selectedRowsChange: [{
270
- type: Output
271
- }], selectedRows: [{
272
- type: Input
273
- }], itemHeight: [{
274
- type: Input
275
- }], viewport: [{
276
- type: ViewChild,
277
- args: [CdkVirtualScrollViewport, { static: true }]
278
- }], onScrolledIndexChanged: [{
279
- type: Output
280
- }], headerContainer: [{
281
- type: ViewChild,
282
- args: ['headerContainer']
283
- }], footerContainer: [{
284
- type: ViewChild,
285
- args: ['footerContainer']
286
- }], scrollableContainer: [{
287
- type: ViewChild,
288
- args: ['scrolling', { static: true }]
289
- }] } });
290
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-table.component.js","sourceRoot":"","sources":["../../../../../../libs/components/data-table/src/lib/data-table.component.ts","../../../../../../libs/components/data-table/src/lib/data-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AXDataSource,\n  AXEvent,\n  AXListDataSource,\n  AXPagedComponent,\n  AXValueChangedEvent,\n  MXBaseComponent,\n  convertArrayToDataSource,\n} from '@acorex/components/common';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  ContentChildren,\n  DoCheck,\n  ElementRef,\n  EventEmitter,\n  Input,\n  NgZone,\n  OnInit,\n  Output,\n  QueryList,\n  TemplateRef,\n  ViewChild,\n  ViewEncapsulation,\n  inject,\n} from '@angular/core';\n\nimport { CdkVirtualScrollViewport } from '@angular/cdk/scrolling';\nimport sum from 'lodash-es/sum';\nimport { Subject, buffer, debounceTime, filter } from 'rxjs';\nimport { AXDataTableColumnComponent } from './columns/data-table-column';\nimport { AXDataTableTextColumnComponent } from './columns/data-text-column.component';\n\nexport interface AXDataTableScrollIndexChanged extends AXEvent {\n  index: number;\n}\n\nexport interface AXDataTableRowClick extends AXEvent {\n  data?: any;\n}\n\nexport interface AXDataTableRowDbClick extends AXDataTableRowClick {}\n\n@Component({\n  selector: 'ax-data-table',\n  templateUrl: './data-table.component.html',\n  styleUrls: ['./data-table.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [{ provide: AXPagedComponent, useExisting: AXDataTableComponent }],\n})\nexport class AXDataTableComponent\n  extends MXBaseComponent\n  implements OnInit, DoCheck\n{\n  private ngZone = inject(NgZone);\n\n  @ContentChildren(AXDataTableColumnComponent)\n  protected columns: QueryList<AXDataTableColumnComponent>;\n\n  protected startFixedColumn(): AXDataTableColumnComponent[] {\n    return this.columns?.toArray().filter((c) => c.fixed == 'start') ?? [];\n  }\n\n  protected endFixedColumn(): AXDataTableColumnComponent[] {\n    return this.columns?.toArray().filter((c) => c.fixed == 'end') ?? [];\n  }\n\n  protected notFixedColumn(): AXDataTableColumnComponent[] {\n    return this.columns?.toArray().filter((c) => !c.fixed) ?? [];\n  }\n\n  protected notFixedColumnCount(): number {\n    return this.columns?.toArray().filter((c) => !c.fixed).length ?? 0;\n  }\n\n  protected fixedColumnCount(): number {\n    return this.columns?.toArray().filter((c) => c.fixed).length ?? 0;\n  }\n\n  @Output()\n  onPageChanged: EventEmitter<AXValueChangedEvent<number>> = new EventEmitter<\n    AXValueChangedEvent<number>\n  >();\n\n  private clickSubject = new Subject<{ event: MouseEvent; item: any }>();\n\n  @Output()\n  onRowClick: EventEmitter<AXDataTableRowClick> =\n    new EventEmitter<AXDataTableRowClick>();\n\n  @Output()\n  onRowDbClick: EventEmitter<AXDataTableRowDbClick> =\n    new EventEmitter<AXDataTableRowDbClick>();\n\n  @Input()\n  rowTemplate?: TemplateRef<unknown>;\n\n  @Input()\n  emptyTemplate?: TemplateRef<unknown>;\n\n  @Input()\n  showHeader = true;\n\n  @Input()\n  fetchDataMode: 'auto' | 'manual' = 'auto';\n\n  @Input()\n  dataSource: AXDataSource<unknown> = convertArrayToDataSource([]);\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  protected listDataSource: AXListDataSource<unknown>;\n  protected isLoading = true;\n  protected hasItems = false;\n  protected totalRows = 0;\n  protected currentPage = 0;\n  protected totalPages = 0;\n  protected startRowIndex = 0;\n  private lastIndex = 0;\n\n  @Output()\n  focusedRowChange: EventEmitter<unknown> = new EventEmitter<unknown>();\n\n  private _focusedRow: unknown;\n  @Input()\n  public get focusedRow(): unknown {\n    return this._focusedRow;\n  }\n  public set focusedRow(v: unknown) {\n    this._focusedRow = v;\n    this.focusedRowChange.emit(v);\n  }\n\n  @Output()\n  selectedRowsChange: EventEmitter<unknown[]> = new EventEmitter<unknown[]>();\n\n  private _selectedRows: unknown[] = [];\n  @Input()\n  public get selectedRows(): unknown[] {\n    return this._selectedRows;\n  }\n  public set selectedRows(v: unknown[]) {\n    this._selectedRows = v;\n    this.selectedRowsChange.emit(v);\n  }\n\n  public selectRows(...rows: unknown[]) {\n    this.selectedRows = [...this.selectedRows, ...rows];\n  }\n\n  public unSelectRows(...rows: unknown[]) {\n    this.selectedRows = this.selectedRows.filter((c) => !rows.includes(c));\n  }\n\n  @Input()\n  itemHeight: number | 'auto' = 40;\n\n  protected width = '100%';\n  protected height = '100%';\n\n  @ViewChild(CdkVirtualScrollViewport, { static: true })\n  private viewport: CdkVirtualScrollViewport;\n\n  @Output()\n  onScrolledIndexChanged: EventEmitter<AXDataTableScrollIndexChanged> =\n    new EventEmitter<AXDataTableScrollIndexChanged>();\n\n  trackByIdx(i) {\n    return i;\n  }\n\n  override ngOnInit() {\n    super.ngOnInit();\n    this.listDataSource = new AXListDataSource<unknown>({\n      source: this.dataSource,\n    });\n    this.listDataSource.source.onLoadingChanged.subscribe((data) => {\n      this.isLoading = data;\n    });\n    this.listDataSource.source.onChanged.subscribe((data) => {\n      this.totalRows = data.totalCount;\n      this.hasItems = data.totalCount > 0;\n      setTimeout(() => {\n        this.render();\n      }, 100);\n    });\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  @ViewChild('headerContainer') headerContainer: ElementRef<HTMLDivElement>;\n  @ViewChild('footerContainer') footerContainer: ElementRef;\n  @ViewChild('scrolling', { static: true })\n  scrollableContainer: ElementRef<HTMLDivElement>;\n\n  protected _handleOnscrolledIndexChange(e: number) {\n    this.lastIndex = e;\n    this.onScrolledIndexChanged.emit({\n      component: this,\n      index: this.lastIndex,\n      isUserInteraction: true,\n    });\n  }\n\n  ngDoCheck() {\n    //this.copyFixedColumns();\n    this.updateHScroll();\n    //\n    this.updateWidth();\n    this.updateHeight();\n    //\n    this.updateTotalCount();\n  }\n\n  private updateTotalCount() {\n    this.startRowIndex = this.lastIndex;\n    if (this.startRowIndex < 1) this.startRowIndex = 1;\n    if (this.startRowIndex > this.totalRows)\n      this.startRowIndex = this.totalRows;\n  }\n\n  private updateHeight() {\n    this.height = `calc(100% - ${\n      (this.headerContainer?.nativeElement.clientHeight ?? 0) +\n      (this.footerContainer?.nativeElement.clientHeight ?? 0)\n    }px)`;\n  }\n\n  private updateWidth() {\n    if (this.columns && this.columns.length) {\n      const sumPx = sum(\n        this.columns\n          .toArray()\n          .map((c) =>\n            typeof c.width == 'number'\n              ? c.width\n              : Number(c.width.replace('px', ''))\n          )\n      );\n      this.width = `${Math.max(\n        sumPx,\n        this.getHostElement().clientWidth - 5\n      )}px`;\n    }\n  }\n\n  private updateHScroll() {\n    this.ngZone.runOutsideAngular(() => {\n      if (this.headerContainer) {\n        const headerContainer = this.headerContainer.nativeElement;\n        const left = this.scrollableContainer.nativeElement.scrollLeft;\n        headerContainer.style.transform = `translateX(${-left}px)`;\n      }\n    });\n  }\n\n  // Function to copy fixed columns\n  private copyFixedColumns() {\n    const originalRows = Array.from(\n      this.viewport._contentWrapper.nativeElement.querySelectorAll('tr')\n    );\n    const fixedColumnTable =\n      this.getHostElement().querySelector<HTMLTableElement>(\n        '.ax-body-fixed-columns > table > tbody'\n      );\n    fixedColumnTable.querySelectorAll('tr').forEach((n) => n.remove());\n    for (const row of originalRows) {\n      const fixedCells = Array.from(\n        row.querySelectorAll('[data-fixed=\"start\"]')\n      );\n      const fixedRow = document.createElement('tr');\n      for (const cell of fixedCells) {\n        const clonedCell = cell.cloneNode(true);\n        fixedRow.appendChild(clonedCell);\n      }\n      fixedColumnTable.appendChild(fixedRow);\n    }\n    const scrollTop = this.getHostElement().querySelector(\n      '.cdk-virtual-scrollable'\n    ).scrollTop;\n    fixedColumnTable.style.transform = `translateY(${-scrollTop}px)`;\n  }\n\n  public render() {\n    this.viewport.checkViewportSize();\n    this.viewport.scrollToIndex(this.lastIndex);\n    this.cdr.markForCheck();\n  }\n\n  public refresh() {\n    this.lastIndex = 0;\n    this.dataSource.refresh();\n  }\n\n  protected handleRowClick(event: MouseEvent, item: unknown) {\n    this.handleRowSingleClick(event, item);\n    this.clickSubject.next({ event, item });\n  }\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  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  handleColumnClick(e: MouseEvent, column: AXDataTableColumnComponent) {\n    if (column instanceof AXDataTableTextColumnComponent) {\n      const sort = this.dataSource.query.sort.find(\n        (c) => c.field == column.dataField\n      );\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(\n            (c) => c != sort\n          );\n        }\n      }\n      this.refresh();\n    }\n  }\n\n  protected getSort(column: AXDataTableColumnComponent): string | undefined {\n    if (column instanceof AXDataTableTextColumnComponent) {\n      const sort = this.dataSource.query.sort.find(\n        (c) => c.field == column.dataField\n      );\n      return sort\n        ? sort.dir == 'asc'\n          ? 'ax-icon-arrow-long-down'\n          : 'ax-icon-arrow-long-up'\n        : undefined;\n    }\n    return undefined;\n  }\n\n  protected _handleOnScroll() {\n    this.updateHScroll();\n  }\n}\n","<ng-content select=\"ax-header\"> </ng-content>\n<!------------------- Header contents ------------------->\n@if(showHeader){\n<div class=\"ax-header-content\">\n  <div class=\"ax-header-columns\">\n    <table tabindex=\"0\" [style.width]=\"width\" #headerContainer>\n      <thead>\n        <tr>\n          @for(c of notFixedColumn();track c.name)\n          {\n          <th [class.ax-interactive]=\"c.allowSorting\" (click)=\"c.allowSorting ? handleColumnClick($event, c) : null\"\n            [style.width]=\"c.width\">\n            @if(c.headerTemplate)\n            {\n            <ng-container *ngTemplateOutlet=\"c.headerTemplate\"></ng-container>\n            }\n            @else {\n            <div class=\"ax-caption\">\n              {{ c.caption }}\n              @if(getSort(c)){\n              <ax-icon icon=\"ax-icon {{ getSort(c) }}\"></ax-icon>\n              }\n            </div>\n            }\n            <!-- @if(c.allowResizing)\n              {\n              <div class=\"ax-resize-handle\" [ax-table-column-resizble]=\"c\"></div>\n              } -->\n          </th>\n          }\n          <th></th>\n        </tr>\n      </thead>\n    </table>\n  </div>\n</div>\n}\n\n<!------------------- Body contents ------------------->\n<div [style.height]=\"height\" class=\"ax-body-content\">\n  <div class=\"ax-body-columns\">\n    <div cdkVirtualScrollingElement #scrolling [style.height]=\"'100%'\" (scroll)=\"_handleOnScroll()\">\n      <cdk-virtual-scroll-viewport [itemSize]=\"itemHeight\" [style.--item-height]=\"itemHeight + 'px'\"\n        (scrolledIndexChange)=\"_handleOnscrolledIndexChange($event)\">\n        <table tabindex=\"0\" class=\"ax-table-body ax-relative\" [style.width]=\"width\">\n          <colgroup>\n            @for(c of notFixedColumn();track c.name)\n            {\n            <col [style.width]=\"c.width\" />\n            }\n            <col />\n          </colgroup>\n          <tbody>\n            <ng-container *cdkVirtualFor=\"\n                let item of listDataSource;\n                templateCacheSize: 100;\n                let i = index;\n                trackBy: trackByIdx;\n                let rIndex = index\n              \">\n              <!------------------- custom row template------------------->\n              @if (rowTemplate != null) {\n              <ng-container *ngTemplateOutlet=\"rowTemplate; context: { $implicit: { data: item, rowIndex: rIndex } }\">\n              </ng-container>\n              } @else {\n              <!------------------- normal row template------------------->\n              <tr [class.ax-state-focused]=\"focusedRow && item === focusedRow\" [attr.data-index]=\"rIndex\"\n                [class.ax-state-selected]=\"selectedRows.includes(item)\" (click)=\"handleRowClick($event, item)\">\n                <!------------------- start fixed column ------------------->\n\n                <!------------------- Not fixed column ------------------->\n                @for (c of notFixedColumn(); track c.name) {\n                <!------------------- custom cell template ------------------->\n                @if (c.cellTemplate) {\n                <ng-container\n                  *ngTemplateOutlet=\"c.cellTemplate;context: { $implicit: { data: item, rowIndex: rIndex } }\">\n                </ng-container>\n                } @else {\n                <!------------------- default cell template ------------------->\n                <td [attr.data-label]=\"c.caption\" tabindex=\"0\" [class]=\"c.cssClass\">\n                  @if (item) {\n                  <!------------------- render cell ------------------->\n                  <ng-container\n                    *ngTemplateOutlet=\"c.template;context: { $implicit: { data: item, rowIndex: rIndex } }\"></ng-container>\n                  }\n                  @else {\n                  <!------------------- render loading ------------------->\n                  @if (c.loadingEnabled && loading) {\n                  <ax-skeleton [animated]=\"loading.animation\"></ax-skeleton>\n                  }\n                  }\n                </td>\n                }\n                }\n                <td></td>\n              </tr>\n              }\n            </ng-container>\n          </tbody>\n        </table>\n      </cdk-virtual-scroll-viewport>\n    </div>\n  </div>\n</div>\n<div class=\"ax-table-footer\" #footerContainer>\n  <div class=\"ax-table-info\">\n    <div>Showing {{ startRowIndex }} of {{ totalRows }} items</div>\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  </div>\n  <ng-content select=\"ax-footer\"> </ng-content>\n</div>"]}
@@ -1,5 +0,0 @@
1
- /**
2
- * Generated bundle index. Do not edit.
3
- */
4
- export * from './index';
5
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWNvcmV4LWNvbXBvbmVudHMtZGF0YS10YWJsZS0yLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL2RhdGEtdGFibGUtMi9zcmMvYWNvcmV4LWNvbXBvbmVudHMtZGF0YS10YWJsZS0yLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBRUgsY0FBYyxTQUFTLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEdlbmVyYXRlZCBidW5kbGUgaW5kZXguIERvIG5vdCBlZGl0LlxuICovXG5cbmV4cG9ydCAqIGZyb20gJy4vaW5kZXgnO1xuIl19
@@ -1,9 +0,0 @@
1
- export * from './lib/columns/data-table-column';
2
- export * from './lib/columns/data-table-column-resizable.directive';
3
- export * from './lib/columns/data-text-column.component';
4
- export * from './lib/columns/row-command-column.component';
5
- export * from './lib/columns/row-index-column.component';
6
- export * from './lib/columns/row-select-column.component';
7
- export * from './lib/data-table-2.component';
8
- export * from './lib/data-table-2.module';
9
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvZGF0YS10YWJsZS0yL3NyYy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLGlDQUFpQyxDQUFDO0FBQ2hELGNBQWMscURBQXFELENBQUM7QUFDcEUsY0FBYywwQ0FBMEMsQ0FBQztBQUN6RCxjQUFjLDRDQUE0QyxDQUFDO0FBQzNELGNBQWMsMENBQTBDLENBQUM7QUFDekQsY0FBYywyQ0FBMkMsQ0FBQztBQUMxRCxjQUFjLDhCQUE4QixDQUFDO0FBQzdDLGNBQWMsMkJBQTJCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2xpYi9jb2x1bW5zL2RhdGEtdGFibGUtY29sdW1uJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbHVtbnMvZGF0YS10YWJsZS1jb2x1bW4tcmVzaXphYmxlLmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb2x1bW5zL2RhdGEtdGV4dC1jb2x1bW4uY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbHVtbnMvcm93LWNvbW1hbmQtY29sdW1uLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb2x1bW5zL3Jvdy1pbmRleC1jb2x1bW4uY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbHVtbnMvcm93LXNlbGVjdC1jb2x1bW4uY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2RhdGEtdGFibGUtMi5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZGF0YS10YWJsZS0yLm1vZHVsZSc7XG4iXX0=