@acorex/components 7.9.0 → 7.10.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.
- package/common/lib/classes/datalist.class.d.ts +21 -0
- package/common/lib/classes/datasource.class.d.ts +31 -14
- package/data-table/index.d.ts +1 -0
- package/data-table/lib/data-table.component.d.ts +2 -2
- package/data-table/lib/data-table.module.d.ts +9 -7
- package/data-table/lib/data-table2.component.d.ts +37 -0
- package/drawer/lib/drawer.component.d.ts +2 -1
- package/esm2022/common/lib/classes/datalist.class.mjs +44 -2
- package/esm2022/common/lib/classes/datasource.class.mjs +18 -11
- package/esm2022/data-table/index.mjs +2 -1
- package/esm2022/data-table/lib/data-table.component.mjs +3 -4
- package/esm2022/data-table/lib/data-table.module.mjs +6 -4
- package/esm2022/data-table/lib/data-table2.component.mjs +118 -0
- package/esm2022/drawer/lib/drawer-container.component.mjs +1 -1
- package/esm2022/drawer/lib/drawer.component.mjs +8 -8
- package/esm2022/list/lib/list.component.mjs +5 -48
- package/esm2022/popup/lib/popup.interface.mjs +1 -1
- package/esm2022/popup/lib/popup.service.mjs +3 -1
- package/esm2022/progress-bar/lib/progress-bar.component.mjs +50 -5
- package/esm2022/select-box/lib/select-box.component.mjs +4 -5
- package/esm2022/selection-list/lib/selection-list.component.mjs +16 -4
- package/esm2022/uploader/lib/uploader-list.component.mjs +2 -2
- package/fesm2022/acorex-components-common.mjs +62 -12
- package/fesm2022/acorex-components-common.mjs.map +1 -1
- package/fesm2022/acorex-components-data-table.mjs +119 -9
- package/fesm2022/acorex-components-data-table.mjs.map +1 -1
- package/fesm2022/acorex-components-drawer.mjs +7 -7
- package/fesm2022/acorex-components-drawer.mjs.map +1 -1
- package/fesm2022/acorex-components-list.mjs +5 -48
- package/fesm2022/acorex-components-list.mjs.map +1 -1
- package/fesm2022/acorex-components-popup.mjs +2 -0
- package/fesm2022/acorex-components-popup.mjs.map +1 -1
- package/fesm2022/acorex-components-progress-bar.mjs +49 -4
- package/fesm2022/acorex-components-progress-bar.mjs.map +1 -1
- package/fesm2022/acorex-components-select-box.mjs +3 -4
- package/fesm2022/acorex-components-select-box.mjs.map +1 -1
- package/fesm2022/acorex-components-selection-list.mjs +15 -3
- package/fesm2022/acorex-components-selection-list.mjs.map +1 -1
- package/fesm2022/acorex-components-uploader.mjs +1 -1
- package/fesm2022/acorex-components-uploader.mjs.map +1 -1
- package/list/lib/list.component.d.ts +2 -22
- package/package.json +1 -1
- package/popup/lib/popup.interface.d.ts +3 -1
- package/progress-bar/lib/progress-bar.component.d.ts +12 -2
- package/select-box/lib/select-box.component.d.ts +4 -4
- package/selection-list/lib/selection-list.component.d.ts +4 -1
@@ -1,3 +1,6 @@
|
|
1
|
+
import { CollectionViewer, DataSource } from "@angular/cdk/collections";
|
2
|
+
import { Observable } from "rxjs";
|
3
|
+
import { AXDataSource } from "./datasource.class";
|
1
4
|
export interface AXDataListQuery {
|
2
5
|
take?: number;
|
3
6
|
skip?: number;
|
@@ -9,3 +12,21 @@ export interface AXDataListFetchCallbackResult {
|
|
9
12
|
}
|
10
13
|
export type AXDataListFetchDataCallback = (e: AXDataListQuery) => Promise<AXDataListFetchCallbackResult>;
|
11
14
|
export type AXDataListItems = Array<any> | AXDataListFetchDataCallback;
|
15
|
+
export declare class AXListDataSource<T = unknown> extends DataSource<T> {
|
16
|
+
private config;
|
17
|
+
private debounceTime;
|
18
|
+
private subscription;
|
19
|
+
source: AXDataSource<T>;
|
20
|
+
private dataStream;
|
21
|
+
/**
|
22
|
+
* @ignore
|
23
|
+
*/
|
24
|
+
constructor(config: {
|
25
|
+
source: AXDataSource<T>;
|
26
|
+
debounceTime?: number;
|
27
|
+
});
|
28
|
+
connect(collectionViewer: CollectionViewer): Observable<T[]>;
|
29
|
+
disconnect(): void;
|
30
|
+
private getPageForIndex;
|
31
|
+
refresh(): void;
|
32
|
+
}
|
@@ -1,32 +1,47 @@
|
|
1
|
-
import { ListIterateeCustom } from 'lodash';
|
2
1
|
import { Subject } from 'rxjs';
|
3
|
-
export type
|
4
|
-
|
2
|
+
export type AXDataSourceOperator = {
|
3
|
+
type: 'equal' | 'isNull' | 'isEmpty' | 'lt' | 'lte' | 'gt' | 'gte' | 'startsWith' | 'endsWith' | 'contains';
|
4
|
+
negative?: boolean;
|
5
|
+
};
|
6
|
+
export type AXDataSourceLogic = 'and' | 'or';
|
7
|
+
export type AXDataSourceFilterOption = {
|
8
|
+
field: string;
|
9
|
+
value?: unknown;
|
10
|
+
operator: AXDataSourceOperator;
|
11
|
+
logic?: AXDataSourceLogic;
|
12
|
+
filters?: AXDataSourceFilterOption[];
|
13
|
+
};
|
14
|
+
export type AXDataSourceSortOption = {
|
15
|
+
field: string;
|
16
|
+
dir: 'asc' | 'desc';
|
17
|
+
};
|
18
|
+
export interface AXDataSourceQuery {
|
5
19
|
take?: number;
|
6
20
|
skip?: number;
|
7
|
-
|
21
|
+
filter?: AXDataSourceFilterOption;
|
22
|
+
sort?: AXDataSourceSortOption[];
|
8
23
|
}
|
9
24
|
export interface AXDataSourceCallbackResult<T> {
|
10
25
|
items: Array<T>;
|
11
26
|
total: number;
|
12
27
|
}
|
13
|
-
export type AXDataSourceLoadCallback<T> = (e: AXDataSourceQuery
|
28
|
+
export type AXDataSourceLoadCallback<T> = (e: AXDataSourceQuery) => Promise<AXDataSourceCallbackResult<T>>;
|
14
29
|
export type AXDataSourceByKeyCallback<T> = (key: unknown) => Promise<T>;
|
15
|
-
export interface
|
30
|
+
export interface AXDataSourceConfig<T = unknown> {
|
16
31
|
key?: string;
|
17
32
|
pageSize: number;
|
18
33
|
load: AXDataSourceLoadCallback<T>;
|
19
34
|
byKey?: AXDataSourceByKeyCallback<T>;
|
20
35
|
}
|
21
|
-
export interface
|
36
|
+
export interface AXDataSourceChangedEvent<T = unknown> {
|
22
37
|
cachedItems: Array<T>;
|
23
38
|
items: Array<T>;
|
24
39
|
totalCount: number;
|
25
40
|
totalPages: number;
|
26
41
|
page: number;
|
27
42
|
}
|
28
|
-
export declare class
|
29
|
-
config:
|
43
|
+
export declare class AXDataSource<T = unknown> {
|
44
|
+
config: AXDataSourceConfig<T>;
|
30
45
|
private _totalCount;
|
31
46
|
private get totalCount();
|
32
47
|
private get totalPages();
|
@@ -37,20 +52,22 @@ export declare class AXDateSource<T = unknown> {
|
|
37
52
|
private fetchedPages;
|
38
53
|
private _page;
|
39
54
|
private _query;
|
40
|
-
onChanged: Subject<
|
55
|
+
onChanged: Subject<AXDataSourceChangedEvent<T>>;
|
41
56
|
onLoadingChanged: Subject<boolean>;
|
42
57
|
private _isLoading;
|
43
58
|
get isLoading(): boolean;
|
44
|
-
constructor(config:
|
59
|
+
constructor(config: AXDataSourceConfig<T>);
|
45
60
|
private load;
|
46
61
|
private setLoadingState;
|
47
62
|
setPage(page: number): void;
|
48
|
-
filter(
|
49
|
-
|
63
|
+
filter(value: AXDataSourceFilterOption): void;
|
64
|
+
sort(...value: AXDataSourceSortOption[]): void;
|
65
|
+
clearFilter(): void;
|
66
|
+
private reset;
|
50
67
|
refresh(): void;
|
51
68
|
find(key: unknown): T | Promise<T>;
|
52
69
|
}
|
53
70
|
export declare function convertArrayToDataSource<T>(items: T[], options?: {
|
54
71
|
key: string;
|
55
72
|
pageSize: number;
|
56
|
-
}):
|
73
|
+
}): AXDataSource;
|
package/data-table/index.d.ts
CHANGED
@@ -5,8 +5,8 @@ import * as i0 from "@angular/core";
|
|
5
5
|
export declare class AXDataTableComponent extends MXBaseComponent implements AXPagedComponentInterface {
|
6
6
|
protected _columns: QueryList<AXDataColumnComponent>;
|
7
7
|
onPageChanged: EventEmitter<AXValueChangedEvent<number>>;
|
8
|
-
rowTemplate?: TemplateRef<
|
9
|
-
emptyTemplate?: TemplateRef<
|
8
|
+
rowTemplate?: TemplateRef<unknown>;
|
9
|
+
emptyTemplate?: TemplateRef<unknown>;
|
10
10
|
showHeader: boolean;
|
11
11
|
private _pageSize;
|
12
12
|
get pageSize(): number;
|
@@ -1,13 +1,15 @@
|
|
1
1
|
import * as i0 from "@angular/core";
|
2
2
|
import * as i1 from "./data-table.component";
|
3
|
-
import * as i2 from "./data-
|
4
|
-
import * as i3 from "
|
5
|
-
import * as i4 from "@
|
6
|
-
import * as i5 from "@
|
7
|
-
import * as i6 from "@acorex/
|
8
|
-
import * as i7 from "@acorex/components/
|
3
|
+
import * as i2 from "./data-table2.component";
|
4
|
+
import * as i3 from "./data-column.directive";
|
5
|
+
import * as i4 from "@angular/common";
|
6
|
+
import * as i5 from "@angular/cdk/scrolling";
|
7
|
+
import * as i6 from "@acorex/core/translation";
|
8
|
+
import * as i7 from "@acorex/components/result";
|
9
|
+
import * as i8 from "@acorex/components/loading";
|
10
|
+
import * as i9 from "@acorex/components/decorators";
|
9
11
|
export declare class AXDataTableModule {
|
10
12
|
static ɵfac: i0.ɵɵFactoryDeclaration<AXDataTableModule, never>;
|
11
|
-
static ɵmod: i0.ɵɵNgModuleDeclaration<AXDataTableModule, [typeof i1.AXDataTableComponent, typeof i2.AXDataColumnComponent], [typeof
|
13
|
+
static ɵmod: i0.ɵɵNgModuleDeclaration<AXDataTableModule, [typeof i1.AXDataTableComponent, typeof i2.AXDataTable2Component, typeof i3.AXDataColumnComponent], [typeof i4.CommonModule, typeof i5.ScrollingModule, typeof i6.AXTranslationModule, typeof i7.AXResultModule, typeof i8.AXLoadingModule, typeof i9.AXDecoratorModule], [typeof i1.AXDataTableComponent, typeof i2.AXDataTable2Component, typeof i3.AXDataColumnComponent]>;
|
12
14
|
static ɵinj: i0.ɵɵInjectorDeclaration<AXDataTableModule>;
|
13
15
|
}
|
@@ -0,0 +1,37 @@
|
|
1
|
+
import { AXValueChangedEvent, MXBaseComponent, AXListDataSource, AXDataSource, AXEvent } from '@acorex/components/common';
|
2
|
+
import { ElementRef, EventEmitter, QueryList, TemplateRef } from '@angular/core';
|
3
|
+
import { AXDataColumnComponent } from './data-column.directive';
|
4
|
+
import * as i0 from "@angular/core";
|
5
|
+
export interface AXDataTableScrollIndexChanged extends AXEvent {
|
6
|
+
index: number;
|
7
|
+
}
|
8
|
+
export declare class AXDataTable2Component extends MXBaseComponent {
|
9
|
+
protected columns: QueryList<AXDataColumnComponent>;
|
10
|
+
onPageChanged: EventEmitter<AXValueChangedEvent<number>>;
|
11
|
+
rowTemplate?: TemplateRef<unknown>;
|
12
|
+
emptyTemplate?: TemplateRef<unknown>;
|
13
|
+
loadingTemplate: TemplateRef<unknown>;
|
14
|
+
showHeader: boolean;
|
15
|
+
private _pageSize;
|
16
|
+
get pageSize(): number;
|
17
|
+
set pageSize(v: number);
|
18
|
+
fetchDataMode: 'auto' | 'manual';
|
19
|
+
dataSource: AXDataSource<unknown>;
|
20
|
+
protected listDataSource: AXListDataSource<unknown>;
|
21
|
+
protected isLoading: boolean;
|
22
|
+
protected hasItems: boolean;
|
23
|
+
private lastIndex;
|
24
|
+
itemHeight: number | 'auto';
|
25
|
+
protected width: string;
|
26
|
+
private viewport;
|
27
|
+
onScrolledIndexChanged: EventEmitter<AXDataTableScrollIndexChanged>;
|
28
|
+
trackByIdx(i: any): any;
|
29
|
+
ngOnInit(): void;
|
30
|
+
headerContainer: ElementRef;
|
31
|
+
protected _handleOnscrolledIndexChange(e: number): void;
|
32
|
+
ngDoCheck(): void;
|
33
|
+
render(): void;
|
34
|
+
refresh(): void;
|
35
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<AXDataTable2Component, never>;
|
36
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<AXDataTable2Component, "ax-data-table2", never, { "rowTemplate": { "alias": "rowTemplate"; "required": false; }; "emptyTemplate": { "alias": "emptyTemplate"; "required": false; }; "loadingTemplate": { "alias": "loadingTemplate"; "required": false; }; "showHeader": { "alias": "showHeader"; "required": false; }; "pageSize": { "alias": "pageSize"; "required": false; }; "fetchDataMode": { "alias": "fetchDataMode"; "required": false; }; "dataSource": { "alias": "dataSource"; "required": false; }; "itemHeight": { "alias": "itemHeight"; "required": false; }; }, { "onPageChanged": "onPageChanged"; "onScrolledIndexChanged": "onScrolledIndexChanged"; }, ["columns"], ["ax-header", "ax-footer"], false, never>;
|
37
|
+
}
|
@@ -18,7 +18,7 @@ export declare class AXDrawerComponent extends MXBaseComponent {
|
|
18
18
|
private _collapsed;
|
19
19
|
get collapsed(): boolean;
|
20
20
|
set collapsed(v: boolean);
|
21
|
-
|
21
|
+
ngAfterContentInit(): void;
|
22
22
|
internalOptionChanged(option: MXComponentOptionChanged): void;
|
23
23
|
ngDoCheck(): void;
|
24
24
|
private _detectBoundingSize;
|
@@ -28,6 +28,7 @@ export declare class AXDrawerComponent extends MXBaseComponent {
|
|
28
28
|
open(): void;
|
29
29
|
private get __hostClass();
|
30
30
|
private _backdropElement;
|
31
|
+
private _loaded;
|
31
32
|
private _addBackdrop;
|
32
33
|
private _removeBackdrop;
|
33
34
|
static ɵfac: i0.ɵɵFactoryDeclaration<AXDrawerComponent, never>;
|
@@ -1,2 +1,44 @@
|
|
1
|
-
|
2
|
-
|
1
|
+
import { DataSource } from "@angular/cdk/collections";
|
2
|
+
import { BehaviorSubject, Subscription, debounceTime, distinctUntilChanged } from "rxjs";
|
3
|
+
export class AXListDataSource extends DataSource {
|
4
|
+
/**
|
5
|
+
* @ignore
|
6
|
+
*/
|
7
|
+
constructor(config) {
|
8
|
+
super();
|
9
|
+
this.config = config;
|
10
|
+
this.debounceTime = 0;
|
11
|
+
this.subscription = new Subscription();
|
12
|
+
this.source = config.source;
|
13
|
+
if (config.debounceTime)
|
14
|
+
this.debounceTime = config.debounceTime;
|
15
|
+
//
|
16
|
+
this.dataStream = new BehaviorSubject(this.config.source.cachedItems);
|
17
|
+
this.source.onChanged.subscribe((data) => {
|
18
|
+
this.dataStream.next(data.cachedItems);
|
19
|
+
});
|
20
|
+
}
|
21
|
+
connect(collectionViewer) {
|
22
|
+
this.subscription.add(collectionViewer.viewChange
|
23
|
+
.pipe(debounceTime(this.debounceTime))
|
24
|
+
.pipe(distinctUntilChanged())
|
25
|
+
.subscribe((range) => {
|
26
|
+
const startPage = this.getPageForIndex(range.start);
|
27
|
+
const endPage = this.getPageForIndex(range.end - 1);
|
28
|
+
for (let i = startPage; i <= endPage; i++) {
|
29
|
+
this.source.setPage(i);
|
30
|
+
}
|
31
|
+
}));
|
32
|
+
return this.dataStream;
|
33
|
+
}
|
34
|
+
disconnect() {
|
35
|
+
this.subscription.unsubscribe();
|
36
|
+
}
|
37
|
+
getPageForIndex(index) {
|
38
|
+
return Math.floor(index / this.source.config.pageSize);
|
39
|
+
}
|
40
|
+
refresh() {
|
41
|
+
this.source.refresh();
|
42
|
+
}
|
43
|
+
}
|
44
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0YWxpc3QuY2xhc3MuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvY29tbW9uL3NyYy9saWIvY2xhc3Nlcy9kYXRhbGlzdC5jbGFzcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQW9CLFVBQVUsRUFBRSxNQUFNLDBCQUEwQixDQUFDO0FBQ3hFLE9BQU8sRUFBRSxlQUFlLEVBQWMsWUFBWSxFQUFFLFlBQVksRUFBRSxvQkFBb0IsRUFBRSxNQUFNLE1BQU0sQ0FBQztBQXFCckcsTUFBTSxPQUFPLGdCQUE4QixTQUFRLFVBQWE7SUFNOUQ7O09BRUc7SUFDSCxZQUFvQixNQUEwRDtRQUM1RSxLQUFLLEVBQUUsQ0FBQztRQURVLFdBQU0sR0FBTixNQUFNLENBQW9EO1FBUnRFLGlCQUFZLEdBQUcsQ0FBQyxDQUFDO1FBQ2pCLGlCQUFZLEdBQUcsSUFBSSxZQUFZLEVBQUUsQ0FBQztRQVN4QyxJQUFJLENBQUMsTUFBTSxHQUFHLE1BQU0sQ0FBQyxNQUFNLENBQUM7UUFDNUIsSUFBSSxNQUFNLENBQUMsWUFBWTtZQUFFLElBQUksQ0FBQyxZQUFZLEdBQUcsTUFBTSxDQUFDLFlBQVksQ0FBQztRQUNqRSxFQUFFO1FBQ0YsSUFBSSxDQUFDLFVBQVUsR0FBRyxJQUFJLGVBQWUsQ0FBTSxJQUFJLENBQUMsTUFBTSxDQUFDLE1BQU0sQ0FBQyxXQUFXLENBQUMsQ0FBQztRQUMzRSxJQUFJLENBQUMsTUFBTSxDQUFDLFNBQVMsQ0FBQyxTQUFTLENBQUMsQ0FBQyxJQUFJLEVBQUUsRUFBRTtZQUN2QyxJQUFJLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLENBQUM7UUFDekMsQ0FBQyxDQUFDLENBQUM7SUFDTCxDQUFDO0lBRUQsT0FBTyxDQUFDLGdCQUFrQztRQUN4QyxJQUFJLENBQUMsWUFBWSxDQUFDLEdBQUcsQ0FDbkIsZ0JBQWdCLENBQUMsVUFBVTthQUN4QixJQUFJLENBQUMsWUFBWSxDQUFDLElBQUksQ0FBQyxZQUFZLENBQUMsQ0FBQzthQUNyQyxJQUFJLENBQUMsb0JBQW9CLEVBQUUsQ0FBQzthQUM1QixTQUFTLENBQUMsQ0FBQyxLQUFLLEVBQUUsRUFBRTtZQUNuQixNQUFNLFNBQVMsR0FBRyxJQUFJLENBQUMsZUFBZSxDQUFDLEtBQUssQ0FBQyxLQUFLLENBQUMsQ0FBQztZQUNwRCxNQUFNLE9BQU8sR0FBRyxJQUFJLENBQUMsZUFBZSxDQUFDLEtBQUssQ0FBQyxHQUFHLEdBQUcsQ0FBQyxDQUFDLENBQUM7WUFDcEQsS0FBSyxJQUFJLENBQUMsR0FBRyxTQUFTLEVBQUUsQ0FBQyxJQUFJLE9BQU8sRUFBRSxDQUFDLEVBQUUsRUFBRTtnQkFDekMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLENBQUM7YUFDeEI7UUFDSCxDQUFDLENBQUMsQ0FDTCxDQUFDO1FBQ0YsT0FBTyxJQUFJLENBQUMsVUFBVSxDQUFDO0lBQ3pCLENBQUM7SUFFRCxVQUFVO1FBQ1IsSUFBSSxDQUFDLFlBQVksQ0FBQyxXQUFXLEVBQUUsQ0FBQztJQUNsQyxDQUFDO0lBRU8sZUFBZSxDQUFDLEtBQWE7UUFDbkMsT0FBTyxJQUFJLENBQUMsS0FBSyxDQUFDLEtBQUssR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDLE1BQU0sQ0FBQyxRQUFRLENBQUMsQ0FBQztJQUN6RCxDQUFDO0lBRUQsT0FBTztRQUNMLElBQUksQ0FBQyxNQUFNLENBQUMsT0FBTyxFQUFFLENBQUM7SUFDeEIsQ0FBQztDQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29sbGVjdGlvblZpZXdlciwgRGF0YVNvdXJjZSB9IGZyb20gXCJAYW5ndWxhci9jZGsvY29sbGVjdGlvbnNcIjtcbmltcG9ydCB7IEJlaGF2aW9yU3ViamVjdCwgT2JzZXJ2YWJsZSwgU3Vic2NyaXB0aW9uLCBkZWJvdW5jZVRpbWUsIGRpc3RpbmN0VW50aWxDaGFuZ2VkIH0gZnJvbSBcInJ4anNcIjtcbmltcG9ydCB7IEFYRGF0YVNvdXJjZSB9IGZyb20gXCIuL2RhdGFzb3VyY2UuY2xhc3NcIjtcblxuXG5leHBvcnQgaW50ZXJmYWNlIEFYRGF0YUxpc3RRdWVyeSB7XG4gIHRha2U/OiBudW1iZXI7XG4gIHNraXA/OiBudW1iZXI7XG4gIHNlYXJjaFF1ZXJ5Pzogc3RyaW5nO1xufVxuZXhwb3J0IGludGVyZmFjZSBBWERhdGFMaXN0RmV0Y2hDYWxsYmFja1Jlc3VsdCB7XG4gIGl0ZW1zOiBBcnJheTxhbnk+O1xuICB0b3RhbDogbnVtYmVyO1xufVxuXG5leHBvcnQgdHlwZSBBWERhdGFMaXN0RmV0Y2hEYXRhQ2FsbGJhY2sgPSAoZTogQVhEYXRhTGlzdFF1ZXJ5KSA9PiBQcm9taXNlPEFYRGF0YUxpc3RGZXRjaENhbGxiYWNrUmVzdWx0PjtcblxuZXhwb3J0IHR5cGUgQVhEYXRhTGlzdEl0ZW1zID0gQXJyYXk8YW55PiB8IEFYRGF0YUxpc3RGZXRjaERhdGFDYWxsYmFjaztcblxuXG5cblxuZXhwb3J0IGNsYXNzIEFYTGlzdERhdGFTb3VyY2U8VCA9IHVua25vd24+IGV4dGVuZHMgRGF0YVNvdXJjZTxUPiB7XG4gIHByaXZhdGUgZGVib3VuY2VUaW1lID0gMDtcbiAgcHJpdmF0ZSBzdWJzY3JpcHRpb24gPSBuZXcgU3Vic2NyaXB0aW9uKCk7XG4gIHB1YmxpYyBzb3VyY2U6IEFYRGF0YVNvdXJjZTxUPjtcbiAgcHJpdmF0ZSBkYXRhU3RyZWFtOiBCZWhhdmlvclN1YmplY3Q8VFtdPjtcblxuICAvKipcbiAgICogQGlnbm9yZVxuICAgKi9cbiAgY29uc3RydWN0b3IocHJpdmF0ZSBjb25maWc6IHsgc291cmNlOiBBWERhdGFTb3VyY2U8VD47IGRlYm91bmNlVGltZT86IG51bWJlciB9KSB7XG4gICAgc3VwZXIoKTtcbiAgICB0aGlzLnNvdXJjZSA9IGNvbmZpZy5zb3VyY2U7XG4gICAgaWYgKGNvbmZpZy5kZWJvdW5jZVRpbWUpIHRoaXMuZGVib3VuY2VUaW1lID0gY29uZmlnLmRlYm91bmNlVGltZTtcbiAgICAvL1xuICAgIHRoaXMuZGF0YVN0cmVhbSA9IG5ldyBCZWhhdmlvclN1YmplY3Q8VFtdPih0aGlzLmNvbmZpZy5zb3VyY2UuY2FjaGVkSXRlbXMpO1xuICAgIHRoaXMuc291cmNlLm9uQ2hhbmdlZC5zdWJzY3JpYmUoKGRhdGEpID0+IHtcbiAgICAgIHRoaXMuZGF0YVN0cmVhbS5uZXh0KGRhdGEuY2FjaGVkSXRlbXMpO1xuICAgIH0pO1xuICB9XG5cbiAgY29ubmVjdChjb2xsZWN0aW9uVmlld2VyOiBDb2xsZWN0aW9uVmlld2VyKTogT2JzZXJ2YWJsZTxUW10+IHtcbiAgICB0aGlzLnN1YnNjcmlwdGlvbi5hZGQoXG4gICAgICBjb2xsZWN0aW9uVmlld2VyLnZpZXdDaGFuZ2VcbiAgICAgICAgLnBpcGUoZGVib3VuY2VUaW1lKHRoaXMuZGVib3VuY2VUaW1lKSlcbiAgICAgICAgLnBpcGUoZGlzdGluY3RVbnRpbENoYW5nZWQoKSlcbiAgICAgICAgLnN1YnNjcmliZSgocmFuZ2UpID0+IHtcbiAgICAgICAgICBjb25zdCBzdGFydFBhZ2UgPSB0aGlzLmdldFBhZ2VGb3JJbmRleChyYW5nZS5zdGFydCk7XG4gICAgICAgICAgY29uc3QgZW5kUGFnZSA9IHRoaXMuZ2V0UGFnZUZvckluZGV4KHJhbmdlLmVuZCAtIDEpO1xuICAgICAgICAgIGZvciAobGV0IGkgPSBzdGFydFBhZ2U7IGkgPD0gZW5kUGFnZTsgaSsrKSB7XG4gICAgICAgICAgICB0aGlzLnNvdXJjZS5zZXRQYWdlKGkpO1xuICAgICAgICAgIH1cbiAgICAgICAgfSksXG4gICAgKTtcbiAgICByZXR1cm4gdGhpcy5kYXRhU3RyZWFtO1xuICB9XG5cbiAgZGlzY29ubmVjdCgpOiB2b2lkIHtcbiAgICB0aGlzLnN1YnNjcmlwdGlvbi51bnN1YnNjcmliZSgpO1xuICB9XG5cbiAgcHJpdmF0ZSBnZXRQYWdlRm9ySW5kZXgoaW5kZXg6IG51bWJlcik6IG51bWJlciB7XG4gICAgcmV0dXJuIE1hdGguZmxvb3IoaW5kZXggLyB0aGlzLnNvdXJjZS5jb25maWcucGFnZVNpemUpO1xuICB9XG5cbiAgcmVmcmVzaCgpIHtcbiAgICB0aGlzLnNvdXJjZS5yZWZyZXNoKCk7XG4gIH1cbn1cblxuIl19
|
@@ -1,6 +1,6 @@
|
|
1
1
|
import { filter } from 'lodash-es';
|
2
2
|
import { Subject } from 'rxjs';
|
3
|
-
export class
|
3
|
+
export class AXDataSource {
|
4
4
|
get totalCount() {
|
5
5
|
return this._totalCount;
|
6
6
|
}
|
@@ -69,13 +69,18 @@ export class AXDateSource {
|
|
69
69
|
this.load();
|
70
70
|
}
|
71
71
|
}
|
72
|
-
filter(
|
73
|
-
this.
|
74
|
-
|
75
|
-
|
72
|
+
filter(value) {
|
73
|
+
this._query.filter = value;
|
74
|
+
}
|
75
|
+
sort(...value) {
|
76
|
+
this._query.sort = value;
|
77
|
+
}
|
78
|
+
clearFilter() {
|
79
|
+
this._query.filter = null;
|
76
80
|
}
|
77
81
|
reset() {
|
78
|
-
this._query.
|
82
|
+
this._query.filter = null;
|
83
|
+
this._query.sort = null;
|
79
84
|
this._query.skip = 0;
|
80
85
|
this._cachedItems = new Array(this.config.pageSize);
|
81
86
|
this.fetchedPages.clear();
|
@@ -83,9 +88,11 @@ export class AXDateSource {
|
|
83
88
|
this._totalCount = 0;
|
84
89
|
}
|
85
90
|
refresh() {
|
86
|
-
const
|
91
|
+
const currentFilter = this._query.filter;
|
92
|
+
const currentSort = this._query.sort;
|
87
93
|
this.reset();
|
88
|
-
this._query.
|
94
|
+
this._query.filter = currentFilter;
|
95
|
+
this._query.sort = currentSort;
|
89
96
|
this.load();
|
90
97
|
}
|
91
98
|
find(key) {
|
@@ -100,7 +107,7 @@ export function convertArrayToDataSource(items, options = { key: 'id', pageSize:
|
|
100
107
|
key: options.key,
|
101
108
|
pageSize: options.pageSize,
|
102
109
|
load: (e) => {
|
103
|
-
const result = e.
|
110
|
+
const result = e.filter ? filter(items, e.filter) : items;
|
104
111
|
return Promise.resolve({
|
105
112
|
items: result.slice(e.skip, e.skip + e.take),
|
106
113
|
total: result.length,
|
@@ -108,6 +115,6 @@ export function convertArrayToDataSource(items, options = { key: 'id', pageSize:
|
|
108
115
|
},
|
109
116
|
byKey: (v) => Promise.resolve(items.find((c) => c[options.key] == v)),
|
110
117
|
};
|
111
|
-
return new
|
118
|
+
return new AXDataSource(config);
|
112
119
|
}
|
113
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datasource.class.js","sourceRoot":"","sources":["../../../../../../../libs/components/common/src/lib/classes/datasource.class.ts"],"names":[],"mappings":"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","sourcesContent":["import { ListIterateeCustom } from 'lodash';\nimport { filter } from 'lodash-es';\nimport { Subject } from 'rxjs';\n\nexport type AXDateSourceFilterPredicate<T> = ListIterateeCustom<T, boolean>;\nexport interface AXDataSourceQuery<T> {\n  take?: number;\n  skip?: number;\n  predicate?: AXDateSourceFilterPredicate<T>;\n}\nexport interface AXDataSourceCallbackResult<T> {\n  items: Array<T>;\n  total: number;\n}\n\nexport type AXDataSourceLoadCallback<T> = (e: AXDataSourceQuery<T>) => Promise<AXDataSourceCallbackResult<T>>;\nexport type AXDataSourceByKeyCallback<T> = (key: unknown) => Promise<T>;\n\nexport interface AXDateSourceConfig<T = unknown> {\n  key?: string;\n  pageSize: number;\n  load: AXDataSourceLoadCallback<T>;\n  byKey?: AXDataSourceByKeyCallback<T>;\n}\n\nexport interface AXDateSourceChangedEvent<T = unknown> {\n  cachedItems: Array<T>;\n  items: Array<T>;\n  totalCount: number;\n  totalPages: number;\n  page: number;\n}\n\nexport class AXDateSource<T = unknown> {\n  config!: AXDateSourceConfig<T>;\n\n  private _totalCount = 0;\n  private get totalCount(): number {\n    return this._totalCount;\n  }\n\n  private get totalPages(): number {\n    return Math.floor(this.totalCount / this.config.pageSize);\n  }\n\n  private _cachedItems: T[];\n  public get cachedItems(): T[] {\n    return this._cachedItems;\n  }\n\n  private _items: T[] = [];\n  public get items(): T[] {\n    return this._items;\n  }\n\n  private fetchedPages = new Set<number>();\n  private _page = 0;\n  private _query: AXDataSourceQuery<T>;\n\n  public onChanged = new Subject<AXDateSourceChangedEvent<T>>();\n\n  public onLoadingChanged = new Subject<boolean>();\n  private _isLoading = false;\n  public get isLoading(): boolean {\n    return this._isLoading;\n  }\n\n  constructor(config: AXDateSourceConfig<T>) {\n    this.config = config;\n    this._cachedItems = new Array(this.config.pageSize);\n    this._items = new Array(0);\n    this._query = { skip: 0, take: this.config.pageSize };\n  }\n\n  private load() {\n    const page = this._page;\n    if (this.fetchedPages.has(page)) {\n      return;\n    }\n    this.setLoadingState(true);\n    this.fetchedPages.add(page);\n    this._query.skip = page * this.config.pageSize;\n    this.config\n      .load({ ...this._query })\n      .then((result) => {\n        if (this._totalCount != result.total) {\n          this._cachedItems = new Array(result.total);\n          this._totalCount = result.total;\n        }\n        this._items = result.items;\n        this._cachedItems.splice(page * this.config.pageSize, this.config.pageSize, ...result.items);\n        const event = {\n          cachedItems: this.cachedItems,\n          items: this.items,\n          page: page,\n          totalCount: this.totalCount,\n          totalPages: this.totalPages,\n        };\n        this.onChanged.next(event);\n      })\n      .finally(() => {\n        this.setLoadingState(false);\n      });\n  }\n\n  private setLoadingState(value: boolean) {\n    this._isLoading = value;\n    this.onLoadingChanged.next(this._isLoading);\n  }\n\n  public setPage(page: number) {\n    if (this._page != page || this._items.length == 0) {\n      this._page = page;\n      this.load();\n    }\n  }\n\n  public filter(predicate: AXDateSourceFilterPredicate<T> = null) {\n    this.reset();\n    this._query.predicate = predicate;\n    this.load();\n  }\n  public reset() {\n    this._query.predicate = null;\n    this._query.skip = 0;\n    this._cachedItems = new Array(this.config.pageSize);\n    this.fetchedPages.clear();\n    this._page = 0;\n    this._totalCount = 0;\n  }\n\n  public refresh() {\n    const currentPredicate = this._query.predicate;\n    this.reset();\n    this._query.predicate = currentPredicate;\n    this.load();\n  }\n\n  find(key: unknown): T | Promise<T> {\n    const fromCache = this.cachedItems.find(\n      (c) => (!this.config.key && c == key) || (c && this.config.key && c[this.config.key] == key),\n    );\n    if (fromCache) return fromCache;\n    return this.config.byKey ? this.config.byKey(key) : null;\n  }\n}\n\nexport function convertArrayToDataSource<T>(\n  items: T[],\n  options: { key: string; pageSize: number } = { key: 'id', pageSize: 20 },\n): AXDateSource {\n  const config: AXDateSourceConfig = {\n    key: options.key,\n    pageSize: options.pageSize,\n    load: (e: AXDataSourceQuery<T>) => {\n      const result = e.predicate ? filter(items, e.predicate) : items;\n      return Promise.resolve({\n        items: result.slice(e.skip, e.skip + e.take),\n        total: result.length,\n      });\n    },\n    byKey: (v: unknown) => Promise.resolve<T>(items.find((c) => c[options.key] == v)),\n  };\n  return new AXDateSource(config);\n}\n"]}
|
120
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datasource.class.js","sourceRoot":"","sources":["../../../../../../../libs/components/common/src/lib/classes/datasource.class.ts"],"names":[],"mappings":"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","sourcesContent":["import { filter } from 'lodash-es';\nimport { Subject } from 'rxjs';\n\nexport type AXDataSourceOperator = {\n  type: 'equal' | 'isNull' | 'isEmpty' | 'lt' | 'lte' | 'gt' | 'gte' | 'startsWith' | 'endsWith' | 'contains'\n  negative?: boolean\n};\nexport type AXDataSourceLogic = 'and' | 'or';\n\nexport type AXDataSourceFilterOption = {\n  field: string,\n  value?: unknown,\n  operator: AXDataSourceOperator;\n  logic?: AXDataSourceLogic;\n  filters?: AXDataSourceFilterOption[];\n};\nexport type AXDataSourceSortOption = { field: string, dir: 'asc' | 'desc' };\n\nexport interface AXDataSourceQuery {\n  take?: number;\n  skip?: number;\n  filter?: AXDataSourceFilterOption;\n  sort?: AXDataSourceSortOption[];\n}\nexport interface AXDataSourceCallbackResult<T> {\n  items: Array<T>;\n  total: number;\n}\n\nexport type AXDataSourceLoadCallback<T> = (e: AXDataSourceQuery) => Promise<AXDataSourceCallbackResult<T>>;\nexport type AXDataSourceByKeyCallback<T> = (key: unknown) => Promise<T>;\n\nexport interface AXDataSourceConfig<T = unknown> {\n  key?: string;\n  pageSize: number;\n  load: AXDataSourceLoadCallback<T>;\n  byKey?: AXDataSourceByKeyCallback<T>;\n}\n\nexport interface AXDataSourceChangedEvent<T = unknown> {\n  cachedItems: Array<T>;\n  items: Array<T>;\n  totalCount: number;\n  totalPages: number;\n  page: number;\n}\n\nexport class AXDataSource<T = unknown> {\n  config!: AXDataSourceConfig<T>;\n\n  private _totalCount = 0;\n  private get totalCount(): number {\n    return this._totalCount;\n  }\n\n  private get totalPages(): number {\n    return Math.floor(this.totalCount / this.config.pageSize);\n  }\n\n  private _cachedItems: T[];\n  public get cachedItems(): T[] {\n    return this._cachedItems;\n  }\n\n  private _items: T[] = [];\n  public get items(): T[] {\n    return this._items;\n  }\n\n  private fetchedPages = new Set<number>();\n  private _page = 0;\n  private _query: AXDataSourceQuery;\n\n  public onChanged = new Subject<AXDataSourceChangedEvent<T>>();\n\n  public onLoadingChanged = new Subject<boolean>();\n  private _isLoading = false;\n  public get isLoading(): boolean {\n    return this._isLoading;\n  }\n\n  constructor(config: AXDataSourceConfig<T>) {\n    this.config = config;\n    this._cachedItems = new Array(this.config.pageSize);\n    this._items = new Array(0);\n    this._query = { skip: 0, take: this.config.pageSize };\n  }\n\n  private load() {\n    const page = this._page;\n    if (this.fetchedPages.has(page)) {\n      return;\n    }\n    this.setLoadingState(true);\n    this.fetchedPages.add(page);\n    this._query.skip = page * this.config.pageSize;\n    this.config\n      .load({ ...this._query })\n      .then((result) => {\n        if (this._totalCount != result.total) {\n          this._cachedItems = new Array(result.total);\n          this._totalCount = result.total;\n        }\n        this._items = result.items;\n        this._cachedItems.splice(page * this.config.pageSize, this.config.pageSize, ...result.items);\n        const event = {\n          cachedItems: this.cachedItems,\n          items: this.items,\n          page: page,\n          totalCount: this.totalCount,\n          totalPages: this.totalPages,\n        };\n        this.onChanged.next(event);\n      })\n      .finally(() => {\n        this.setLoadingState(false);\n      });\n  }\n\n  private setLoadingState(value: boolean) {\n    this._isLoading = value;\n    this.onLoadingChanged.next(this._isLoading);\n  }\n\n  public setPage(page: number) {\n    if (this._page != page || this._items.length == 0) {\n      this._page = page;\n      this.load();\n    }\n  }\n\n  public filter(value: AXDataSourceFilterOption) {\n    this._query.filter = value;\n  }\n\n  public sort(...value: AXDataSourceSortOption[]) {\n    this._query.sort = value;\n  }\n\n  public clearFilter() {\n    this._query.filter = null\n  }\n\n  private reset() {\n    this._query.filter = null;\n    this._query.sort = null;\n    this._query.skip = 0;\n    this._cachedItems = new Array(this.config.pageSize);\n    this.fetchedPages.clear();\n    this._page = 0;\n    this._totalCount = 0;\n  }\n\n  public refresh() {\n    const currentFilter = this._query.filter;\n    const currentSort = this._query.sort;\n    this.reset();\n    this._query.filter = currentFilter;\n    this._query.sort = currentSort;\n    this.load();\n  }\n\n  find(key: unknown): T | Promise<T> {\n    const fromCache = this.cachedItems.find(\n      (c) => (!this.config.key && c == key) || (c && this.config.key && c[this.config.key] == key),\n    );\n    if (fromCache) return fromCache;\n    return this.config.byKey ? this.config.byKey(key) : null;\n  }\n}\n\nexport function convertArrayToDataSource<T>(\n  items: T[],\n  options: { key: string; pageSize: number } = { key: 'id', pageSize: 20 },\n): AXDataSource {\n  const config: AXDataSourceConfig = {\n    key: options.key,\n    pageSize: options.pageSize,\n    load: (e: AXDataSourceQuery) => {\n      const result = e.filter ? filter(items, e.filter) : items;\n      return Promise.resolve({\n        items: result.slice(e.skip, e.skip + e.take),\n        total: result.length,\n      });\n    },\n    byKey: (v: unknown) => Promise.resolve<T>(items.find((c) => c[options.key] == v)),\n  };\n  return new AXDataSource(config);\n}\n"]}
|
@@ -1,4 +1,5 @@
|
|
1
1
|
export * from './lib/data-column.directive';
|
2
2
|
export * from './lib/data-table.component';
|
3
3
|
export * from './lib/data-table.module';
|
4
|
-
|
4
|
+
export * from './lib/data-table2.component';
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvZGF0YS10YWJsZS9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyw2QkFBNkIsQ0FBQztBQUM1QyxjQUFjLDRCQUE0QixDQUFDO0FBQzNDLGNBQWMseUJBQXlCLENBQUM7QUFDeEMsY0FBYyw2QkFBNkIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vbGliL2RhdGEtY29sdW1uLmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9kYXRhLXRhYmxlLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9kYXRhLXRhYmxlLm1vZHVsZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9kYXRhLXRhYmxlMi5jb21wb25lbnQnO1xuIl19
|
@@ -8,7 +8,6 @@ import * as i3 from "@acorex/core/translation";
|
|
8
8
|
export class AXDataTableComponent extends MXBaseComponent {
|
9
9
|
constructor() {
|
10
10
|
super(...arguments);
|
11
|
-
this._columns = {};
|
12
11
|
this.onPageChanged = new EventEmitter();
|
13
12
|
this.showHeader = true;
|
14
13
|
this._pageSize = 20;
|
@@ -111,11 +110,11 @@ export class AXDataTableComponent extends MXBaseComponent {
|
|
111
110
|
this._fetchData();
|
112
111
|
}
|
113
112
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.6", ngImport: i0, type: AXDataTableComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
|
114
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.6", type: AXDataTableComponent, selector: "ax-data-table", inputs: { rowTemplate: "rowTemplate", emptyTemplate: "emptyTemplate", showHeader: "showHeader", pageSize: "pageSize", fetchDataMode: "fetchDataMode", items: "items" }, outputs: { onPageChanged: "onPageChanged" }, providers: [{ provide: AXPagedComponent, useExisting: AXDataTableComponent }], queries: [{ propertyName: "_columns", predicate: AXDataColumnComponent }], usesInheritance: true, ngImport: i0, template: "<ng-content select=\"ax-header\">\n</ng-content>\n<div class=\"ax-wrapper\">\n <!-- [axIsLoading]=\"isLoading\" -->\n <table class=\"ax-table ax-table-bordered\" tabindex=\"0\">\n <thead *ngIf=\"showHeader\">\n <tr>\n <th *ngFor=\"let c of _columns\">\n <ng-template [ngIf]=\"c.headerTemplate\" [ngIfElse]=\"captionTpl\">\n <ng-container *ngTemplateOutlet=\"c.headerTemplate\"></ng-container>\n </ng-template>\n <ng-template #captionTpl>\n {{c.caption}}\n </ng-template>\n </th>\n </tr>\n </thead>\n <tbody>\n <ng-container *ngIf=\"displayItems.length; else emptyTpl\">\n <ng-container *ngFor=\"let d of displayItems;let rIndex=index\">\n <ng-template [ngIf]=\"rowTemplate\" [ngIfElse]=\"rowTpl\">\n <ng-container *ngTemplateOutlet=\"rowTemplate;context: { $implicit: {data:d,rowIndex:rIndex} }\">\n </ng-container>\n </ng-template>\n <ng-template #rowTpl>\n <tr>\n <ng-container *ngFor=\"let c of _columns\">\n <ng-template [ngIf]=\"c.cellTemplate\" [ngIfElse]=\"cellTpl\">\n <ng-container *ngTemplateOutlet=\"c.cellTemplate;context: { $implicit: {data:d,rowIndex:rIndex} }\">\n </ng-container>\n </ng-template>\n <ng-template #cellTpl>\n <td [attr.data-label]=\"c.caption\" tabindex=\"0\">\n {{d[c.valueField]}}\n </td>\n </ng-template>\n </ng-container>\n </tr>\n </ng-template>\n </ng-container>\n </ng-container>\n <ng-template #emptyTpl>\n <tr>\n <td [attr.colspan]=\"_columns.length\">\n <ng-template [ngIf]=\"emptyTemplate\" [ngIfElse]=\"defaultEmptyTemplate\">\n <ng-container *ngTemplateOutlet=\"emptyTemplate\"></ng-container>\n </ng-template>\n <ng-template #defaultEmptyTemplate>\n <ax-result type=\"empty\" caption=\" {{'common.no-result-found' | trans }}\"></ax-result>\n </ng-template>\n </td>\n </tr>\n </ng-template>\n </tbody>\n </table>\n</div>\n<ng-content select=\"ax-footer\">\n</ng-content>", styles: ["ax-data-table{display:flex;flex-direction:column;border-radius:var(--ax-rounded-border-default);border:1px solid;border-color:rgba(var(--ax-color-border-default));outline-color:transparent}ax-data-table .ax-wrapper{display:flex;flex:1 1 0%;overflow:auto}ax-data-table>ax-header{border-bottom:1px solid;border-color:rgba(var(--ax-color-border-default))}ax-data-table>ax-footer{border-top:1px solid;border-color:rgba(var(--ax-color-border-default))}ax-data-table table{position:relative;border:0}ax-data-table table thead{position:sticky;top:0}ax-data-table table td,ax-data-table table th{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i2.AXResultComponent, selector: "ax-result", inputs: ["type", "caption", "description"] }, { kind: "pipe", type: i3.AXTranslatorPipe, name: "trans" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
|
113
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.6", type: AXDataTableComponent, selector: "ax-data-table", inputs: { rowTemplate: "rowTemplate", emptyTemplate: "emptyTemplate", showHeader: "showHeader", pageSize: "pageSize", fetchDataMode: "fetchDataMode", items: "items" }, outputs: { onPageChanged: "onPageChanged" }, providers: [{ provide: AXPagedComponent, useExisting: AXDataTableComponent }], queries: [{ propertyName: "_columns", predicate: AXDataColumnComponent }], usesInheritance: true, ngImport: i0, template: "<ng-content select=\"ax-header\">\n</ng-content>\n<div class=\"ax-wrapper\">\n <!-- [axIsLoading]=\"isLoading\" -->\n <table class=\"ax-table ax-table-bordered\" tabindex=\"0\">\n <thead *ngIf=\"showHeader\">\n <tr>\n <th *ngFor=\"let c of _columns\">\n <ng-template [ngIf]=\"c.headerTemplate\" [ngIfElse]=\"captionTpl\">\n <ng-container *ngTemplateOutlet=\"c.headerTemplate\"></ng-container>\n </ng-template>\n <ng-template #captionTpl>\n {{c.caption}}\n </ng-template>\n </th>\n </tr>\n </thead>\n <tbody>\n <ng-container *ngIf=\"displayItems.length; else emptyTpl\">\n <ng-container *ngFor=\"let d of displayItems;let rIndex=index\">\n <ng-template [ngIf]=\"rowTemplate\" [ngIfElse]=\"rowTpl\">\n <ng-container *ngTemplateOutlet=\"rowTemplate;context: { $implicit: {data:d,rowIndex:rIndex} }\">\n </ng-container>\n </ng-template>\n <ng-template #rowTpl>\n <tr>\n <ng-container *ngFor=\"let c of _columns\">\n <ng-template [ngIf]=\"c.cellTemplate\" [ngIfElse]=\"cellTpl\">\n <ng-container *ngTemplateOutlet=\"c.cellTemplate;context: { $implicit: {data:d,rowIndex:rIndex} }\">\n </ng-container>\n </ng-template>\n <ng-template #cellTpl>\n <td [attr.data-label]=\"c.caption\" tabindex=\"0\">\n {{d[c.valueField]}}\n </td>\n </ng-template>\n </ng-container>\n </tr>\n </ng-template>\n </ng-container>\n </ng-container>\n <ng-template #emptyTpl>\n <tr>\n <td [attr.colspan]=\"_columns.length\">\n <ng-template [ngIf]=\"emptyTemplate\" [ngIfElse]=\"defaultEmptyTemplate\">\n <ng-container *ngTemplateOutlet=\"emptyTemplate\"></ng-container>\n </ng-template>\n <ng-template #defaultEmptyTemplate>\n <ax-result type=\"empty\" caption=\" {{'common.no-result-found' | trans }}\"></ax-result>\n </ng-template>\n </td>\n </tr>\n </ng-template>\n </tbody>\n </table>\n</div>\n<ng-content select=\"ax-footer\">\n</ng-content>", styles: ["ax-data-table{display:flex;flex-direction:column;border-radius:var(--ax-rounded-border-default);border:1px solid;border-color:rgba(var(--ax-color-border-default));outline-color:transparent}ax-data-table .ax-wrapper{display:flex;flex:1 1 0%;overflow:auto}ax-data-table>ax-header{border-bottom:1px solid;border-color:rgba(var(--ax-color-border-default))}ax-data-table>ax-footer{border-top:1px solid;border-color:rgba(var(--ax-color-border-default))}ax-data-table table{position:relative;border:0}ax-data-table table thead{position:sticky;top:0}ax-data-table table tbody{height:100%}ax-data-table table td,ax-data-table table th{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}ax-data-table2{border-radius:var(--ax-rounded-border-default);border:1px solid;border-color:rgba(var(--ax-color-border-default));height:100%;font-size:.875rem;overflow-y:hidden;overflow-x:hidden}ax-data-table2 table{table-layout:fixed}ax-data-table2 .ax-table-header{border-start-start-radius:var(--ax-rounded-border-default);border-start-end-radius:var(--ax-rounded-border-default);background-color:rgba(var(--ax-color-on-surface));border-collapse:collapse;overflow:hidden}ax-data-table2 .ax-table-header th{text-transform:uppercase;font-weight:500;text-align:start;padding:.875rem 1rem;border-block-end:1px solid;border-inline-end:1px solid;border-color:rgba(var(--ax-color-border-default))}ax-data-table2 .ax-table-header th:last-child{border-inline-end:0px solid}ax-data-table2 .ax-table-body{border-collapse:collapse}ax-data-table2 .ax-table-body tr:last-child td{border-block-end:none}ax-data-table2 .ax-table-body td{text-align:start;padding:.875rem 1rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;border-block-end:1px solid;border-inline-end:1px solid;border-color:rgba(var(--ax-color-border-default))}ax-data-table2 .ax-table-body td:last-child{border-inline-end:0px solid}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i2.AXResultComponent, selector: "ax-result", inputs: ["type", "caption", "description"] }, { kind: "pipe", type: i3.AXTranslatorPipe, name: "trans" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
|
115
114
|
}
|
116
115
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.6", ngImport: i0, type: AXDataTableComponent, decorators: [{
|
117
116
|
type: Component,
|
118
|
-
args: [{ selector: 'ax-data-table', encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, providers: [{ provide: AXPagedComponent, useExisting: AXDataTableComponent }], template: "<ng-content select=\"ax-header\">\n</ng-content>\n<div class=\"ax-wrapper\">\n <!-- [axIsLoading]=\"isLoading\" -->\n <table class=\"ax-table ax-table-bordered\" tabindex=\"0\">\n <thead *ngIf=\"showHeader\">\n <tr>\n <th *ngFor=\"let c of _columns\">\n <ng-template [ngIf]=\"c.headerTemplate\" [ngIfElse]=\"captionTpl\">\n <ng-container *ngTemplateOutlet=\"c.headerTemplate\"></ng-container>\n </ng-template>\n <ng-template #captionTpl>\n {{c.caption}}\n </ng-template>\n </th>\n </tr>\n </thead>\n <tbody>\n <ng-container *ngIf=\"displayItems.length; else emptyTpl\">\n <ng-container *ngFor=\"let d of displayItems;let rIndex=index\">\n <ng-template [ngIf]=\"rowTemplate\" [ngIfElse]=\"rowTpl\">\n <ng-container *ngTemplateOutlet=\"rowTemplate;context: { $implicit: {data:d,rowIndex:rIndex} }\">\n </ng-container>\n </ng-template>\n <ng-template #rowTpl>\n <tr>\n <ng-container *ngFor=\"let c of _columns\">\n <ng-template [ngIf]=\"c.cellTemplate\" [ngIfElse]=\"cellTpl\">\n <ng-container *ngTemplateOutlet=\"c.cellTemplate;context: { $implicit: {data:d,rowIndex:rIndex} }\">\n </ng-container>\n </ng-template>\n <ng-template #cellTpl>\n <td [attr.data-label]=\"c.caption\" tabindex=\"0\">\n {{d[c.valueField]}}\n </td>\n </ng-template>\n </ng-container>\n </tr>\n </ng-template>\n </ng-container>\n </ng-container>\n <ng-template #emptyTpl>\n <tr>\n <td [attr.colspan]=\"_columns.length\">\n <ng-template [ngIf]=\"emptyTemplate\" [ngIfElse]=\"defaultEmptyTemplate\">\n <ng-container *ngTemplateOutlet=\"emptyTemplate\"></ng-container>\n </ng-template>\n <ng-template #defaultEmptyTemplate>\n <ax-result type=\"empty\" caption=\" {{'common.no-result-found' | trans }}\"></ax-result>\n </ng-template>\n </td>\n </tr>\n </ng-template>\n </tbody>\n </table>\n</div>\n<ng-content select=\"ax-footer\">\n</ng-content>", styles: ["ax-data-table{display:flex;flex-direction:column;border-radius:var(--ax-rounded-border-default);border:1px solid;border-color:rgba(var(--ax-color-border-default));outline-color:transparent}ax-data-table .ax-wrapper{display:flex;flex:1 1 0%;overflow:auto}ax-data-table>ax-header{border-bottom:1px solid;border-color:rgba(var(--ax-color-border-default))}ax-data-table>ax-footer{border-top:1px solid;border-color:rgba(var(--ax-color-border-default))}ax-data-table table{position:relative;border:0}ax-data-table table thead{position:sticky;top:0}ax-data-table table td,ax-data-table table th{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}\n"] }]
|
117
|
+
args: [{ selector: 'ax-data-table', encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, providers: [{ provide: AXPagedComponent, useExisting: AXDataTableComponent }], template: "<ng-content select=\"ax-header\">\n</ng-content>\n<div class=\"ax-wrapper\">\n <!-- [axIsLoading]=\"isLoading\" -->\n <table class=\"ax-table ax-table-bordered\" tabindex=\"0\">\n <thead *ngIf=\"showHeader\">\n <tr>\n <th *ngFor=\"let c of _columns\">\n <ng-template [ngIf]=\"c.headerTemplate\" [ngIfElse]=\"captionTpl\">\n <ng-container *ngTemplateOutlet=\"c.headerTemplate\"></ng-container>\n </ng-template>\n <ng-template #captionTpl>\n {{c.caption}}\n </ng-template>\n </th>\n </tr>\n </thead>\n <tbody>\n <ng-container *ngIf=\"displayItems.length; else emptyTpl\">\n <ng-container *ngFor=\"let d of displayItems;let rIndex=index\">\n <ng-template [ngIf]=\"rowTemplate\" [ngIfElse]=\"rowTpl\">\n <ng-container *ngTemplateOutlet=\"rowTemplate;context: { $implicit: {data:d,rowIndex:rIndex} }\">\n </ng-container>\n </ng-template>\n <ng-template #rowTpl>\n <tr>\n <ng-container *ngFor=\"let c of _columns\">\n <ng-template [ngIf]=\"c.cellTemplate\" [ngIfElse]=\"cellTpl\">\n <ng-container *ngTemplateOutlet=\"c.cellTemplate;context: { $implicit: {data:d,rowIndex:rIndex} }\">\n </ng-container>\n </ng-template>\n <ng-template #cellTpl>\n <td [attr.data-label]=\"c.caption\" tabindex=\"0\">\n {{d[c.valueField]}}\n </td>\n </ng-template>\n </ng-container>\n </tr>\n </ng-template>\n </ng-container>\n </ng-container>\n <ng-template #emptyTpl>\n <tr>\n <td [attr.colspan]=\"_columns.length\">\n <ng-template [ngIf]=\"emptyTemplate\" [ngIfElse]=\"defaultEmptyTemplate\">\n <ng-container *ngTemplateOutlet=\"emptyTemplate\"></ng-container>\n </ng-template>\n <ng-template #defaultEmptyTemplate>\n <ax-result type=\"empty\" caption=\" {{'common.no-result-found' | trans }}\"></ax-result>\n </ng-template>\n </td>\n </tr>\n </ng-template>\n </tbody>\n </table>\n</div>\n<ng-content select=\"ax-footer\">\n</ng-content>", styles: ["ax-data-table{display:flex;flex-direction:column;border-radius:var(--ax-rounded-border-default);border:1px solid;border-color:rgba(var(--ax-color-border-default));outline-color:transparent}ax-data-table .ax-wrapper{display:flex;flex:1 1 0%;overflow:auto}ax-data-table>ax-header{border-bottom:1px solid;border-color:rgba(var(--ax-color-border-default))}ax-data-table>ax-footer{border-top:1px solid;border-color:rgba(var(--ax-color-border-default))}ax-data-table table{position:relative;border:0}ax-data-table table thead{position:sticky;top:0}ax-data-table table tbody{height:100%}ax-data-table table td,ax-data-table table th{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}ax-data-table2{border-radius:var(--ax-rounded-border-default);border:1px solid;border-color:rgba(var(--ax-color-border-default));height:100%;font-size:.875rem;overflow-y:hidden;overflow-x:hidden}ax-data-table2 table{table-layout:fixed}ax-data-table2 .ax-table-header{border-start-start-radius:var(--ax-rounded-border-default);border-start-end-radius:var(--ax-rounded-border-default);background-color:rgba(var(--ax-color-on-surface));border-collapse:collapse;overflow:hidden}ax-data-table2 .ax-table-header th{text-transform:uppercase;font-weight:500;text-align:start;padding:.875rem 1rem;border-block-end:1px solid;border-inline-end:1px solid;border-color:rgba(var(--ax-color-border-default))}ax-data-table2 .ax-table-header th:last-child{border-inline-end:0px solid}ax-data-table2 .ax-table-body{border-collapse:collapse}ax-data-table2 .ax-table-body tr:last-child td{border-block-end:none}ax-data-table2 .ax-table-body td{text-align:start;padding:.875rem 1rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;border-block-end:1px solid;border-inline-end:1px solid;border-color:rgba(var(--ax-color-border-default))}ax-data-table2 .ax-table-body td:last-child{border-inline-end:0px solid}\n"] }]
|
119
118
|
}], propDecorators: { _columns: [{
|
120
119
|
type: ContentChildren,
|
121
120
|
args: [AXDataColumnComponent]
|
@@ -134,4 +133,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.6", ngImpor
|
|
134
133
|
}], items: [{
|
135
134
|
type: Input
|
136
135
|
}] } });
|
137
|
-
//# 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  AXDataListFetchDataCallback,\n  AXDataListItems,\n  AXPagedComponent,\n  AXPagedComponentInterface,\n  AXValueChangedEvent,\n  MXBaseComponent,\n} from '@acorex/components/common';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  ContentChildren,\n  EventEmitter,\n  Input,\n  Output,\n  QueryList,\n  TemplateRef,\n  ViewEncapsulation,\n} from '@angular/core';\n\nimport { AXDataColumnComponent } from './data-column.directive';\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 extends MXBaseComponent implements AXPagedComponentInterface {\n  @ContentChildren(AXDataColumnComponent)\n  protected _columns: QueryList<AXDataColumnComponent> = {} as QueryList<AXDataColumnComponent>;\n\n  @Output()\n  onPageChanged: EventEmitter<AXValueChangedEvent<number>> = new EventEmitter<AXValueChangedEvent<number>>();\n\n  @Input()\n  rowTemplate?: TemplateRef<any>;\n\n  @Input()\n  emptyTemplate?: TemplateRef<any>;\n\n  @Input()\n  showHeader: boolean = true;\n\n  private _pageSize: number = 20;\n  @Input()\n  public get pageSize(): number {\n    return this._pageSize;\n  }\n  public set pageSize(v: number) {\n    this._pageSize = v;\n  }\n\n  @Input()\n  fetchDataMode: 'auto' | 'manual' = 'auto';\n\n  private _currentPage: number = 1;\n\n  private _loadedItems: any[] = [];\n  private _totalItems: number = 0;\n\n  private _isLazy: boolean = false;\n  protected _isLoading: boolean = false;\n\n  get totalCount(): number {\n    return this._totalItems;\n  }\n\n  protected get isLazy(): boolean {\n    return this._isLazy;\n  }\n\n  protected get isLoading(): boolean {\n    return this._isLoading;\n  }\n\n  protected get loadedCount(): number {\n    return this._loadedItems?.length || 0;\n  }\n\n  private _items: AXDataListItems = [];\n\n  @Input()\n  get items(): AXDataListItems {\n    return this._items;\n  }\n  set items(v: AXDataListItems) {\n    if (Array.isArray(v)) {\n      this._items = v;\n    } else if (typeof v === 'function') {\n      this._isLazy = true;\n      this._items = v;\n    } else {\n      this._items = [];\n    }\n  }\n\n  get displayItems(): any[] {\n    if (Array.isArray(this.items)) {\n      return (this._items || []) as any[];\n    } else if (typeof this._items == 'function') {\n      return this._loadedItems || [];\n    }\n    return [];\n  }\n\n  ngAfterViewInit(): void {\n    if (this.fetchDataMode == 'auto') this._fetchData();\n  }\n\n  _fetchData(opts?: { searchQuery?: string }) {\n    const skip = (this._currentPage - 1) * this.pageSize,\n      take = this.pageSize;\n    if (\n      (this.loadedCount >= this.totalCount && this.totalCount != 0) ||\n      this._isLoading ||\n      !this._isLazy ||\n      skip > this.totalCount\n    ) {\n      return;\n    }\n    if (this._items) {\n      this._isLoading = true;\n      this.cdr.markForCheck();\n      const fetchFn = this._items as AXDataListFetchDataCallback;\n      fetchFn({ skip, take, searchQuery: opts?.searchQuery })\n        .then((c) => {\n          if (Array.isArray(c)) {\n            this._loadedItems = c;\n            this._totalItems = c.length;\n          } else {\n            this._totalItems = c.total || c.items?.length || 0;\n            this._loadedItems = [...new Set(c.items)];\n          }\n        })\n        .finally(() => {\n          this._isLoading = false;\n          this.onPageChanged.next({\n            component: this,\n            isUserInteraction: false,\n            name: 'page',\n            value: this._currentPage,\n          });\n          this.cdr.markForCheck();\n        });\n    }\n  }\n\n  refresh() {\n    this._totalItems = 0;\n    this._loadedItems = [];\n    this._fetchData();\n  }\n\n  goToPage(page: number) {\n    this._currentPage = page;\n    this._fetchData();\n  }\n}\n","<ng-content select=\"ax-header\">\n</ng-content>\n<div class=\"ax-wrapper\">\n  <!-- [axIsLoading]=\"isLoading\" -->\n  <table class=\"ax-table ax-table-bordered\" tabindex=\"0\">\n    <thead *ngIf=\"showHeader\">\n      <tr>\n        <th *ngFor=\"let c of _columns\">\n          <ng-template [ngIf]=\"c.headerTemplate\" [ngIfElse]=\"captionTpl\">\n            <ng-container *ngTemplateOutlet=\"c.headerTemplate\"></ng-container>\n          </ng-template>\n          <ng-template #captionTpl>\n            {{c.caption}}\n          </ng-template>\n        </th>\n      </tr>\n    </thead>\n    <tbody>\n      <ng-container *ngIf=\"displayItems.length; else emptyTpl\">\n        <ng-container *ngFor=\"let d of displayItems;let rIndex=index\">\n          <ng-template [ngIf]=\"rowTemplate\" [ngIfElse]=\"rowTpl\">\n            <ng-container *ngTemplateOutlet=\"rowTemplate;context: { $implicit: {data:d,rowIndex:rIndex} }\">\n            </ng-container>\n          </ng-template>\n          <ng-template #rowTpl>\n            <tr>\n              <ng-container *ngFor=\"let c of _columns\">\n                <ng-template [ngIf]=\"c.cellTemplate\" [ngIfElse]=\"cellTpl\">\n                  <ng-container *ngTemplateOutlet=\"c.cellTemplate;context: { $implicit: {data:d,rowIndex:rIndex} }\">\n                  </ng-container>\n                </ng-template>\n                <ng-template #cellTpl>\n                  <td [attr.data-label]=\"c.caption\" tabindex=\"0\">\n                    {{d[c.valueField]}}\n                  </td>\n                </ng-template>\n              </ng-container>\n            </tr>\n          </ng-template>\n        </ng-container>\n      </ng-container>\n      <ng-template #emptyTpl>\n        <tr>\n          <td [attr.colspan]=\"_columns.length\">\n            <ng-template [ngIf]=\"emptyTemplate\" [ngIfElse]=\"defaultEmptyTemplate\">\n              <ng-container *ngTemplateOutlet=\"emptyTemplate\"></ng-container>\n            </ng-template>\n            <ng-template #defaultEmptyTemplate>\n              <ax-result type=\"empty\" caption=\" {{'common.no-result-found' | trans }}\"></ax-result>\n            </ng-template>\n          </td>\n        </tr>\n      </ng-template>\n    </tbody>\n  </table>\n</div>\n<ng-content select=\"ax-footer\">\n</ng-content>"]}
|
136
|
+
//# 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  AXDataListFetchDataCallback,\n  AXDataListItems,\n  AXPagedComponent,\n  AXPagedComponentInterface,\n  AXValueChangedEvent,\n  MXBaseComponent,\n} from '@acorex/components/common';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  ContentChildren,\n  EventEmitter,\n  Input,\n  Output,\n  QueryList,\n  TemplateRef,\n  ViewEncapsulation,\n} from '@angular/core';\n\nimport { AXDataColumnComponent } from './data-column.directive';\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 extends MXBaseComponent implements AXPagedComponentInterface {\n  @ContentChildren(AXDataColumnComponent)\n  protected _columns: QueryList<AXDataColumnComponent>;\n\n  @Output()\n  onPageChanged: EventEmitter<AXValueChangedEvent<number>> = new EventEmitter<AXValueChangedEvent<number>>();\n\n  @Input()\n  rowTemplate?: TemplateRef<unknown>;\n\n  @Input()\n  emptyTemplate?: TemplateRef<unknown>;\n\n  @Input()\n  showHeader: boolean = true;\n\n  private _pageSize = 20;\n  @Input()\n  public get pageSize(): number {\n    return this._pageSize;\n  }\n  public set pageSize(v: number) {\n    this._pageSize = v;\n  }\n\n  @Input()\n  fetchDataMode: 'auto' | 'manual' = 'auto';\n\n  private _currentPage = 1;\n\n  private _loadedItems: any[] = [];\n  private _totalItems = 0;\n\n  private _isLazy = false;\n\n  protected _isLoading = false;\n\n  get totalCount(): number {\n    return this._totalItems;\n  }\n\n  protected get isLazy(): boolean {\n    return this._isLazy;\n  }\n\n  protected get isLoading(): boolean {\n    return this._isLoading;\n  }\n\n  protected get loadedCount(): number {\n    return this._loadedItems?.length || 0;\n  }\n\n  private _items: AXDataListItems = [];\n\n  @Input()\n  get items(): AXDataListItems {\n    return this._items;\n  }\n  set items(v: AXDataListItems) {\n    if (Array.isArray(v)) {\n      this._items = v;\n    } else if (typeof v === 'function') {\n      this._isLazy = true;\n      this._items = v;\n    } else {\n      this._items = [];\n    }\n  }\n\n  get displayItems(): any[] {\n    if (Array.isArray(this.items)) {\n      return (this._items || []) as any[];\n    } else if (typeof this._items == 'function') {\n      return this._loadedItems || [];\n    }\n    return [];\n  }\n\n  ngAfterViewInit(): void {\n    if (this.fetchDataMode == 'auto') this._fetchData();\n  }\n\n  _fetchData(opts?: { searchQuery?: string }) {\n    const skip = (this._currentPage - 1) * this.pageSize,\n      take = this.pageSize;\n    if (\n      (this.loadedCount >= this.totalCount && this.totalCount != 0) ||\n      this._isLoading ||\n      !this._isLazy ||\n      skip > this.totalCount\n    ) {\n      return;\n    }\n    if (this._items) {\n      this._isLoading = true;\n      this.cdr.markForCheck();\n      const fetchFn = this._items as AXDataListFetchDataCallback;\n      fetchFn({ skip, take, searchQuery: opts?.searchQuery })\n        .then((c) => {\n          if (Array.isArray(c)) {\n            this._loadedItems = c;\n            this._totalItems = c.length;\n          } else {\n            this._totalItems = c.total || c.items?.length || 0;\n            this._loadedItems = [...new Set(c.items)];\n          }\n        })\n        .finally(() => {\n          this._isLoading = false;\n          this.onPageChanged.next({\n            component: this,\n            isUserInteraction: false,\n            name: 'page',\n            value: this._currentPage,\n          });\n          this.cdr.markForCheck();\n        });\n    }\n  }\n\n  refresh() {\n    this._totalItems = 0;\n    this._loadedItems = [];\n    this._fetchData();\n  }\n\n  goToPage(page: number) {\n    this._currentPage = page;\n    this._fetchData();\n  }\n}\n","<ng-content select=\"ax-header\">\n</ng-content>\n<div class=\"ax-wrapper\">\n  <!-- [axIsLoading]=\"isLoading\" -->\n  <table class=\"ax-table ax-table-bordered\" tabindex=\"0\">\n    <thead *ngIf=\"showHeader\">\n      <tr>\n        <th *ngFor=\"let c of _columns\">\n          <ng-template [ngIf]=\"c.headerTemplate\" [ngIfElse]=\"captionTpl\">\n            <ng-container *ngTemplateOutlet=\"c.headerTemplate\"></ng-container>\n          </ng-template>\n          <ng-template #captionTpl>\n            {{c.caption}}\n          </ng-template>\n        </th>\n      </tr>\n    </thead>\n    <tbody>\n      <ng-container *ngIf=\"displayItems.length; else emptyTpl\">\n        <ng-container *ngFor=\"let d of displayItems;let rIndex=index\">\n          <ng-template [ngIf]=\"rowTemplate\" [ngIfElse]=\"rowTpl\">\n            <ng-container *ngTemplateOutlet=\"rowTemplate;context: { $implicit: {data:d,rowIndex:rIndex} }\">\n            </ng-container>\n          </ng-template>\n          <ng-template #rowTpl>\n            <tr>\n              <ng-container *ngFor=\"let c of _columns\">\n                <ng-template [ngIf]=\"c.cellTemplate\" [ngIfElse]=\"cellTpl\">\n                  <ng-container *ngTemplateOutlet=\"c.cellTemplate;context: { $implicit: {data:d,rowIndex:rIndex} }\">\n                  </ng-container>\n                </ng-template>\n                <ng-template #cellTpl>\n                  <td [attr.data-label]=\"c.caption\" tabindex=\"0\">\n                    {{d[c.valueField]}}\n                  </td>\n                </ng-template>\n              </ng-container>\n            </tr>\n          </ng-template>\n        </ng-container>\n      </ng-container>\n      <ng-template #emptyTpl>\n        <tr>\n          <td [attr.colspan]=\"_columns.length\">\n            <ng-template [ngIf]=\"emptyTemplate\" [ngIfElse]=\"defaultEmptyTemplate\">\n              <ng-container *ngTemplateOutlet=\"emptyTemplate\"></ng-container>\n            </ng-template>\n            <ng-template #defaultEmptyTemplate>\n              <ax-result type=\"empty\" caption=\" {{'common.no-result-found' | trans }}\"></ax-result>\n            </ng-template>\n          </td>\n        </tr>\n      </ng-template>\n    </tbody>\n  </table>\n</div>\n<ng-content select=\"ax-footer\">\n</ng-content>"]}
|
@@ -6,12 +6,14 @@ import { CommonModule } from '@angular/common';
|
|
6
6
|
import { NgModule } from '@angular/core';
|
7
7
|
import { AXDataColumnComponent } from './data-column.directive';
|
8
8
|
import { AXDataTableComponent } from './data-table.component';
|
9
|
+
import { AXDataTable2Component } from './data-table2.component';
|
10
|
+
import { ScrollingModule } from '@angular/cdk/scrolling';
|
9
11
|
import * as i0 from "@angular/core";
|
10
|
-
const COMPONENT = [AXDataTableComponent, AXDataColumnComponent];
|
11
|
-
const MODULES = [CommonModule, AXTranslationModule, AXResultModule, AXLoadingModule, AXDecoratorModule];
|
12
|
+
const COMPONENT = [AXDataTableComponent, AXDataTable2Component, AXDataColumnComponent];
|
13
|
+
const MODULES = [CommonModule, ScrollingModule, AXTranslationModule, AXResultModule, AXLoadingModule, AXDecoratorModule];
|
12
14
|
export class AXDataTableModule {
|
13
15
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.6", ngImport: i0, type: AXDataTableModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
14
|
-
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.2.6", ngImport: i0, type: AXDataTableModule, declarations: [AXDataTableComponent, AXDataColumnComponent], imports: [CommonModule, AXTranslationModule, AXResultModule, AXLoadingModule, AXDecoratorModule], exports: [AXDataTableComponent, AXDataColumnComponent] }); }
|
16
|
+
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.2.6", ngImport: i0, type: AXDataTableModule, declarations: [AXDataTableComponent, AXDataTable2Component, AXDataColumnComponent], imports: [CommonModule, ScrollingModule, AXTranslationModule, AXResultModule, AXLoadingModule, AXDecoratorModule], exports: [AXDataTableComponent, AXDataTable2Component, AXDataColumnComponent] }); }
|
15
17
|
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.6", ngImport: i0, type: AXDataTableModule, imports: [MODULES] }); }
|
16
18
|
}
|
17
19
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.6", ngImport: i0, type: AXDataTableModule, decorators: [{
|
@@ -23,4 +25,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.6", ngImpor
|
|
23
25
|
providers: [],
|
24
26
|
}]
|
25
27
|
}] });
|
26
|
-
//# sourceMappingURL=data:application/json;base64,
|
28
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0YS10YWJsZS5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvZGF0YS10YWJsZS9zcmMvbGliL2RhdGEtdGFibGUubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLCtCQUErQixDQUFDO0FBQ2xFLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQztBQUM3RCxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFDM0QsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDL0QsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDaEUsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDOUQsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDaEUsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLHdCQUF3QixDQUFDOztBQUV6RCxNQUFNLFNBQVMsR0FBRyxDQUFDLG9CQUFvQixFQUFFLHFCQUFxQixFQUFFLHFCQUFxQixDQUFDLENBQUM7QUFDdkYsTUFBTSxPQUFPLEdBQUcsQ0FBQyxZQUFZLEVBQUUsZUFBZSxFQUFFLG1CQUFtQixFQUFFLGNBQWMsRUFBRSxlQUFlLEVBQUUsaUJBQWlCLENBQUMsQ0FBQztBQVF6SCxNQUFNLE9BQU8saUJBQWlCOzhHQUFqQixpQkFBaUI7K0dBQWpCLGlCQUFpQixpQkFUWCxvQkFBb0IsRUFBRSxxQkFBcUIsRUFBRSxxQkFBcUIsYUFDcEUsWUFBWSxFQUFFLGVBQWUsRUFBRSxtQkFBbUIsRUFBRSxjQUFjLEVBQUUsZUFBZSxFQUFFLGlCQUFpQixhQURwRyxvQkFBb0IsRUFBRSxxQkFBcUIsRUFBRSxxQkFBcUI7K0dBU3hFLGlCQUFpQixZQUpmLE9BQU87OzJGQUlULGlCQUFpQjtrQkFON0IsUUFBUTttQkFBQztvQkFDUixZQUFZLEVBQUUsQ0FBQyxHQUFHLFNBQVMsQ0FBQztvQkFDNUIsT0FBTyxFQUFFLENBQUMsR0FBRyxPQUFPLENBQUM7b0JBQ3JCLE9BQU8sRUFBRSxDQUFDLEdBQUcsU0FBUyxDQUFDO29CQUN2QixTQUFTLEVBQUUsRUFBRTtpQkFDZCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEFYRGVjb3JhdG9yTW9kdWxlIH0gZnJvbSAnQGFjb3JleC9jb21wb25lbnRzL2RlY29yYXRvcnMnO1xuaW1wb3J0IHsgQVhMb2FkaW5nTW9kdWxlIH0gZnJvbSAnQGFjb3JleC9jb21wb25lbnRzL2xvYWRpbmcnO1xuaW1wb3J0IHsgQVhSZXN1bHRNb2R1bGUgfSBmcm9tICdAYWNvcmV4L2NvbXBvbmVudHMvcmVzdWx0JztcbmltcG9ydCB7IEFYVHJhbnNsYXRpb25Nb2R1bGUgfSBmcm9tICdAYWNvcmV4L2NvcmUvdHJhbnNsYXRpb24nO1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBBWERhdGFDb2x1bW5Db21wb25lbnQgfSBmcm9tICcuL2RhdGEtY29sdW1uLmRpcmVjdGl2ZSc7XG5pbXBvcnQgeyBBWERhdGFUYWJsZUNvbXBvbmVudCB9IGZyb20gJy4vZGF0YS10YWJsZS5jb21wb25lbnQnO1xuaW1wb3J0IHsgQVhEYXRhVGFibGUyQ29tcG9uZW50IH0gZnJvbSAnLi9kYXRhLXRhYmxlMi5jb21wb25lbnQnO1xuaW1wb3J0IHsgU2Nyb2xsaW5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY2RrL3Njcm9sbGluZyc7XG5cbmNvbnN0IENPTVBPTkVOVCA9IFtBWERhdGFUYWJsZUNvbXBvbmVudCwgQVhEYXRhVGFibGUyQ29tcG9uZW50LCBBWERhdGFDb2x1bW5Db21wb25lbnRdO1xuY29uc3QgTU9EVUxFUyA9IFtDb21tb25Nb2R1bGUsIFNjcm9sbGluZ01vZHVsZSwgQVhUcmFuc2xhdGlvbk1vZHVsZSwgQVhSZXN1bHRNb2R1bGUsIEFYTG9hZGluZ01vZHVsZSwgQVhEZWNvcmF0b3JNb2R1bGVdO1xuXG5ATmdNb2R1bGUoe1xuICBkZWNsYXJhdGlvbnM6IFsuLi5DT01QT05FTlRdLFxuICBpbXBvcnRzOiBbLi4uTU9EVUxFU10sXG4gIGV4cG9ydHM6IFsuLi5DT01QT05FTlRdLFxuICBwcm92aWRlcnM6IFtdLFxufSlcbmV4cG9ydCBjbGFzcyBBWERhdGFUYWJsZU1vZHVsZSB7IH1cbiJdfQ==
|