@acorex/components 7.24.5 → 17.0.0
Sign up to get free protection for your applications and to get access to all the features.
- package/common/lib/classes/datasource.class.d.ts +2 -0
- package/data-table/index.d.ts +3 -2
- package/data-table/lib/base-data-table.class.d.ts +25 -0
- package/data-table/lib/columns/row-command-column.component.d.ts +2 -2
- package/data-table/lib/data-table/data-table.component.d.ts +52 -0
- package/data-table/lib/data-table.module.d.ts +21 -18
- package/data-table/lib/{data-table.component.d.ts → infinite-scroll-data-table/infinite-scroll-data-table.component.d.ts} +8 -22
- package/esm2022/button/lib/button.component.mjs +2 -2
- package/esm2022/common/lib/classes/datasource.class.mjs +8 -2
- package/esm2022/common/lib/components/selection-base.component.class.mjs +2 -2
- package/esm2022/data-pager/lib/data-pager.component.mjs +7 -11
- package/esm2022/data-table/index.mjs +4 -3
- package/esm2022/data-table/lib/base-data-table.class.mjs +36 -0
- package/esm2022/data-table/lib/columns/row-command-column.component.mjs +57 -69
- package/esm2022/data-table/lib/columns/row-index-column.component.mjs +7 -21
- package/esm2022/data-table/lib/columns/row-select-column.component.mjs +6 -18
- package/esm2022/data-table/lib/data-table/data-table.component.mjs +233 -0
- package/esm2022/data-table/lib/data-table.module.mjs +24 -7
- package/esm2022/data-table/lib/infinite-scroll-data-table/infinite-scroll-data-table.component.mjs +272 -0
- package/esm2022/otp/lib/otp.component.mjs +2 -2
- package/esm2022/phone-box/lib/phone-box.component.mjs +21 -38
- package/esm2022/select-box/lib/select-box.component.mjs +2 -2
- package/esm2022/text-area/lib/text-area.component.mjs +6 -22
- package/fesm2022/acorex-components-button.mjs +2 -2
- package/fesm2022/acorex-components-button.mjs.map +1 -1
- package/fesm2022/acorex-components-common.mjs +8 -2
- package/fesm2022/acorex-components-common.mjs.map +1 -1
- package/fesm2022/acorex-components-data-pager.mjs +5 -9
- package/fesm2022/acorex-components-data-pager.mjs.map +1 -1
- package/fesm2022/acorex-components-data-table.mjs +684 -470
- package/fesm2022/acorex-components-data-table.mjs.map +1 -1
- package/fesm2022/acorex-components-otp.mjs +2 -2
- package/fesm2022/acorex-components-otp.mjs.map +1 -1
- package/fesm2022/acorex-components-phone-box.mjs +22 -38
- package/fesm2022/acorex-components-phone-box.mjs.map +1 -1
- package/fesm2022/acorex-components-select-box.mjs +2 -2
- package/fesm2022/acorex-components-select-box.mjs.map +1 -1
- package/fesm2022/acorex-components-text-area.mjs +5 -21
- package/fesm2022/acorex-components-text-area.mjs.map +1 -1
- package/package.json +25 -31
- package/phone-box/lib/phone-box.component.d.ts +4 -13
- package/text-area/lib/text-area.component.d.ts +0 -1
- package/data-table-2/README.md +0 -3
- package/data-table-2/index.d.ts +0 -8
- package/data-table-2/lib/columns/data-table-column-resizable.directive.d.ts +0 -22
- package/data-table-2/lib/columns/data-table-column.d.ts +0 -22
- package/data-table-2/lib/columns/data-text-column.component.d.ts +0 -18
- package/data-table-2/lib/columns/row-command-column.component.d.ts +0 -40
- package/data-table-2/lib/columns/row-index-column.component.d.ts +0 -18
- package/data-table-2/lib/columns/row-select-column.component.d.ts +0 -14
- package/data-table-2/lib/data-table-2.component.d.ts +0 -61
- package/data-table-2/lib/data-table-2.module.d.ts +0 -24
- package/esm2022/data-table/lib/data-table.component.mjs +0 -290
- package/esm2022/data-table-2/acorex-components-data-table-2.mjs +0 -5
- package/esm2022/data-table-2/index.mjs +0 -9
- package/esm2022/data-table-2/lib/columns/data-table-column-resizable.directive.mjs +0 -59
- package/esm2022/data-table-2/lib/columns/data-table-column.mjs +0 -42
- package/esm2022/data-table-2/lib/columns/data-text-column.component.mjs +0 -81
- package/esm2022/data-table-2/lib/columns/row-command-column.component.mjs +0 -231
- package/esm2022/data-table-2/lib/columns/row-index-column.component.mjs +0 -71
- package/esm2022/data-table-2/lib/columns/row-select-column.component.mjs +0 -61
- package/esm2022/data-table-2/lib/data-table-2.component.mjs +0 -211
- package/esm2022/data-table-2/lib/data-table-2.module.mjs +0 -94
- package/fesm2022/acorex-components-data-table-2.mjs +0 -822
- package/fesm2022/acorex-components-data-table-2.mjs.map +0 -1
@@ -43,6 +43,7 @@ export interface AXDataSourceChangedEvent<T = unknown> {
|
|
43
43
|
}
|
44
44
|
export declare class AXDataSource<T = unknown> {
|
45
45
|
config: AXDataSourceConfig<T>;
|
46
|
+
useCache: boolean;
|
46
47
|
private _totalCount;
|
47
48
|
get totalCount(): number;
|
48
49
|
get totalPages(): number;
|
@@ -63,6 +64,7 @@ export declare class AXDataSource<T = unknown> {
|
|
63
64
|
private load;
|
64
65
|
private setLoadingState;
|
65
66
|
setPage(page: number): void;
|
67
|
+
setPageSize(pageSize: number): void;
|
66
68
|
filter(value: AXDataSourceFilterOption): void;
|
67
69
|
sort(...value: AXDataSourceSortOption[]): void;
|
68
70
|
clearFilter(): void;
|
package/data-table/index.d.ts
CHANGED
@@ -1,8 +1,9 @@
|
|
1
1
|
export * from './lib/columns/data-table-column';
|
2
|
+
export * from './lib/columns/data-table-column-resizable.directive';
|
2
3
|
export * from './lib/columns/data-text-column.component';
|
3
4
|
export * from './lib/columns/row-command-column.component';
|
4
5
|
export * from './lib/columns/row-index-column.component';
|
5
6
|
export * from './lib/columns/row-select-column.component';
|
6
|
-
export * from './lib/columns/data-table-column-resizable.directive';
|
7
|
-
export * from './lib/data-table.component';
|
8
7
|
export * from './lib/data-table.module';
|
8
|
+
export * from './lib/data-table/data-table.component';
|
9
|
+
export * from './lib/infinite-scroll-data-table/infinite-scroll-data-table.component';
|
@@ -0,0 +1,25 @@
|
|
1
|
+
import { AXDataSource, AXEvent, MXBaseComponent } from '@acorex/components/common';
|
2
|
+
import { EventEmitter } from '@angular/core';
|
3
|
+
import * as i0 from "@angular/core";
|
4
|
+
export interface AXDataTableScrollIndexChanged extends AXEvent {
|
5
|
+
index: number;
|
6
|
+
}
|
7
|
+
export interface AXDataTableRowClick extends AXEvent {
|
8
|
+
data?: any;
|
9
|
+
}
|
10
|
+
export interface AXColumnsOrderChangedEvent extends AXEvent {
|
11
|
+
data?: any;
|
12
|
+
}
|
13
|
+
export interface AXDataTableRowDbClick extends AXDataTableRowClick {
|
14
|
+
}
|
15
|
+
export declare abstract class AXBaseDataTable extends MXBaseComponent {
|
16
|
+
dataSource: AXDataSource<unknown>;
|
17
|
+
selectedRowsChange: EventEmitter<unknown[]>;
|
18
|
+
private _selectedRows;
|
19
|
+
get selectedRows(): unknown[];
|
20
|
+
set selectedRows(v: unknown[]);
|
21
|
+
selectRows(...rows: unknown[]): void;
|
22
|
+
unSelectRows(...rows: unknown[]): void;
|
23
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<AXBaseDataTable, never>;
|
24
|
+
static ɵprov: i0.ɵɵInjectableDeclaration<AXBaseDataTable>;
|
25
|
+
}
|
@@ -1,7 +1,7 @@
|
|
1
1
|
import { AXButtonItemComponent, AXButtonItemListItem } from '@acorex/components/button';
|
2
2
|
import { AXButtonClickEvent, AXItemClickEvent } from '@acorex/components/common';
|
3
3
|
import { ChangeDetectorRef, EventEmitter, TemplateRef } from '@angular/core';
|
4
|
-
import {
|
4
|
+
import { AXBaseDataTable } from '../base-data-table.class';
|
5
5
|
import { AXDataTableColumnComponent } from './data-table-column';
|
6
6
|
import * as i0 from "@angular/core";
|
7
7
|
export interface AXRowCommandItem extends AXButtonItemListItem {
|
@@ -9,7 +9,7 @@ export interface AXRowCommandItem extends AXButtonItemListItem {
|
|
9
9
|
export interface AXRowCommandItemClickEvent extends AXButtonClickEvent {
|
10
10
|
}
|
11
11
|
export declare abstract class AXBaseRowCommandColumnComponent extends AXDataTableColumnComponent {
|
12
|
-
protected grid:
|
12
|
+
protected grid: AXBaseDataTable;
|
13
13
|
protected cdr: ChangeDetectorRef;
|
14
14
|
allowSorting: boolean;
|
15
15
|
get loadingEnabled(): boolean;
|
@@ -0,0 +1,52 @@
|
|
1
|
+
import { AXDataPagerChangedEvent } from '@acorex/components/data-pager';
|
2
|
+
import { CdkDragDrop } from '@angular/cdk/drag-drop';
|
3
|
+
import { AfterViewInit, EventEmitter, OnInit, QueryList, TemplateRef, WritableSignal } from '@angular/core';
|
4
|
+
import { AXBaseDataTable, AXColumnsOrderChangedEvent, AXDataTableRowClick, AXDataTableRowDbClick } from '../base-data-table.class';
|
5
|
+
import { AXDataTableColumnComponent } from '../columns/data-table-column';
|
6
|
+
import * as i0 from "@angular/core";
|
7
|
+
export declare class AXDataTableComponent extends AXBaseDataTable implements OnInit, AfterViewInit {
|
8
|
+
onColumnsOrderChanged: EventEmitter<AXColumnsOrderChangedEvent>;
|
9
|
+
protected displayedRows: WritableSignal<any[]>;
|
10
|
+
protected page: WritableSignal<number>;
|
11
|
+
protected pageSize: WritableSignal<number>;
|
12
|
+
protected columnsList: WritableSignal<any[]>;
|
13
|
+
protected columns: QueryList<AXDataTableColumnComponent>;
|
14
|
+
ngAfterViewInit(): void;
|
15
|
+
protected drop(event: CdkDragDrop<any, any, any>): void;
|
16
|
+
ngOnInit(): void;
|
17
|
+
rowTemplate?: TemplateRef<unknown>;
|
18
|
+
emptyTemplate?: TemplateRef<unknown>;
|
19
|
+
showHeader: boolean;
|
20
|
+
fixedHeader: boolean;
|
21
|
+
itemHeight: number | 'auto';
|
22
|
+
fetchDataMode: 'auto' | 'manual';
|
23
|
+
loading: {
|
24
|
+
enabled: boolean;
|
25
|
+
animation: boolean;
|
26
|
+
loadingTemplate?: TemplateRef<unknown>;
|
27
|
+
};
|
28
|
+
private _focusedRow;
|
29
|
+
get focusedRow(): unknown;
|
30
|
+
set focusedRow(v: unknown);
|
31
|
+
protected isLoading: WritableSignal<boolean>;
|
32
|
+
protected hasItems: boolean;
|
33
|
+
protected totalRows: number;
|
34
|
+
protected currentPage: number;
|
35
|
+
protected totalPages: number;
|
36
|
+
protected startRowIndex: number;
|
37
|
+
private lastIndex;
|
38
|
+
focusedRowChange: EventEmitter<unknown>;
|
39
|
+
onRowClick: EventEmitter<AXDataTableRowClick>;
|
40
|
+
onRowDbClick: EventEmitter<AXDataTableRowDbClick>;
|
41
|
+
private clickSubject;
|
42
|
+
protected handleRowClick(event: MouseEvent, item: unknown): void;
|
43
|
+
private handleRowSingleClick;
|
44
|
+
protected onPageChanged(event: AXDataPagerChangedEvent): void;
|
45
|
+
protected handleRowDoubleClick(e: MouseEvent, item: unknown): void;
|
46
|
+
handleColumnClick(e: MouseEvent, column: AXDataTableColumnComponent): void;
|
47
|
+
protected getSort(column: AXDataTableColumnComponent): string | undefined;
|
48
|
+
refresh(): void;
|
49
|
+
private calculateStickyColumnsPositions;
|
50
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<AXDataTableComponent, never>;
|
51
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<AXDataTableComponent, "ax-data-table", never, { "dataSource": { "alias": "dataSource"; "required": false; }; "rowTemplate": { "alias": "rowTemplate"; "required": false; }; "emptyTemplate": { "alias": "emptyTemplate"; "required": false; }; "showHeader": { "alias": "showHeader"; "required": false; }; "fixedHeader": { "alias": "fixedHeader"; "required": false; }; "itemHeight": { "alias": "itemHeight"; "required": false; }; "fetchDataMode": { "alias": "fetchDataMode"; "required": false; }; "loading": { "alias": "loading"; "required": false; }; "focusedRow": { "alias": "focusedRow"; "required": false; }; }, { "onColumnsOrderChanged": "onColumnsOrderChanged"; "focusedRowChange": "focusedRowChange"; "onRowClick": "onRowClick"; "onRowDbClick": "onRowDbClick"; }, ["columns"], ["ax-header", "ax-footer"], false, never>;
|
52
|
+
}
|
@@ -1,23 +1,26 @@
|
|
1
1
|
import * as i0 from "@angular/core";
|
2
|
-
import * as i1 from "./data-table.component";
|
3
|
-
import * as i2 from "./
|
4
|
-
import * as i3 from "./columns/
|
5
|
-
import * as i4 from "./columns/row-
|
6
|
-
import * as i5 from "./columns/row-
|
7
|
-
import * as i6 from "./columns/
|
8
|
-
import * as i7 from "
|
9
|
-
import * as i8 from "@
|
10
|
-
import * as i9 from "@
|
11
|
-
import * as i10 from "@
|
12
|
-
import * as i11 from "@acorex/
|
13
|
-
import * as i12 from "@acorex/components/
|
14
|
-
import * as i13 from "@acorex/components/
|
15
|
-
import * as i14 from "@acorex/components/
|
16
|
-
import * as i15 from "@acorex/components/
|
17
|
-
import * as i16 from "@acorex/components/
|
18
|
-
import * as i17 from "@acorex/
|
2
|
+
import * as i1 from "./infinite-scroll-data-table/infinite-scroll-data-table.component";
|
3
|
+
import * as i2 from "./data-table/data-table.component";
|
4
|
+
import * as i3 from "./columns/data-text-column.component";
|
5
|
+
import * as i4 from "./columns/row-index-column.component";
|
6
|
+
import * as i5 from "./columns/row-select-column.component";
|
7
|
+
import * as i6 from "./columns/row-command-column.component";
|
8
|
+
import * as i7 from "./columns/data-table-column-resizable.directive";
|
9
|
+
import * as i8 from "@angular/common";
|
10
|
+
import * as i9 from "@acorex/components/common";
|
11
|
+
import * as i10 from "@angular/cdk/scrolling";
|
12
|
+
import * as i11 from "@acorex/core/translation";
|
13
|
+
import * as i12 from "@acorex/components/result";
|
14
|
+
import * as i13 from "@acorex/components/loading";
|
15
|
+
import * as i14 from "@acorex/components/decorators";
|
16
|
+
import * as i15 from "@acorex/components/skeleton";
|
17
|
+
import * as i16 from "@acorex/components/button";
|
18
|
+
import * as i17 from "@acorex/components/dropdown";
|
19
|
+
import * as i18 from "@acorex/core/format";
|
20
|
+
import * as i19 from "@acorex/components/data-pager";
|
21
|
+
import * as i20 from "@angular/cdk/drag-drop";
|
19
22
|
export declare class AXDataTableModule {
|
20
23
|
static ɵfac: i0.ɵɵFactoryDeclaration<AXDataTableModule, never>;
|
21
|
-
static ɵmod: i0.ɵɵNgModuleDeclaration<AXDataTableModule, [typeof i1.
|
24
|
+
static ɵmod: i0.ɵɵNgModuleDeclaration<AXDataTableModule, [typeof i1.AXInfiniteScrollDataTableComponent, typeof i2.AXDataTableComponent, typeof i3.AXDataTableTextColumnComponent, typeof i4.AXRowIndexColumnComponent, typeof i5.AXRowSelectColumnComponent, typeof i6.AXRowCommandColumnComponent, typeof i6.AXRowDropdownCommandColumnComponent, typeof i7.AXDataTableColumnResizableDirective], [typeof i8.CommonModule, typeof i9.AXCommonModule, typeof i10.ScrollingModule, typeof i11.AXTranslationModule, typeof i12.AXResultModule, typeof i13.AXLoadingModule, typeof i14.AXDecoratorModule, typeof i15.AXSkeletonModule, typeof i16.AXButtonModule, typeof i17.AXDropdownModule, typeof i18.AXFormatModule, typeof i9.AXRippleDirective, typeof i19.AXDataPagerModule, typeof i20.CdkDropList, typeof i20.CdkDrag, typeof i20.CdkDragPlaceholder, typeof i20.CdkDragHandle], [typeof i1.AXInfiniteScrollDataTableComponent, typeof i2.AXDataTableComponent, typeof i3.AXDataTableTextColumnComponent, typeof i4.AXRowIndexColumnComponent, typeof i5.AXRowSelectColumnComponent, typeof i6.AXRowCommandColumnComponent, typeof i6.AXRowDropdownCommandColumnComponent, typeof i7.AXDataTableColumnResizableDirective]>;
|
22
25
|
static ɵinj: i0.ɵɵInjectorDeclaration<AXDataTableModule>;
|
23
26
|
}
|
@@ -1,16 +1,9 @@
|
|
1
|
-
import {
|
2
|
-
import { DoCheck, ElementRef, EventEmitter, OnInit, QueryList, TemplateRef } from '@angular/core';
|
3
|
-
import {
|
1
|
+
import { AXListDataSource, AXValueChangedEvent } from '@acorex/components/common';
|
2
|
+
import { DoCheck, ElementRef, EventEmitter, OnInit, QueryList, TemplateRef, WritableSignal } from '@angular/core';
|
3
|
+
import { AXBaseDataTable, AXDataTableRowClick, AXDataTableRowDbClick, AXDataTableScrollIndexChanged } from '../base-data-table.class';
|
4
|
+
import { AXDataTableColumnComponent } from '../columns/data-table-column';
|
4
5
|
import * as i0 from "@angular/core";
|
5
|
-
export
|
6
|
-
index: number;
|
7
|
-
}
|
8
|
-
export interface AXDataTableRowClick extends AXEvent {
|
9
|
-
data?: any;
|
10
|
-
}
|
11
|
-
export interface AXDataTableRowDbClick extends AXDataTableRowClick {
|
12
|
-
}
|
13
|
-
export declare class AXDataTableComponent extends MXBaseComponent implements OnInit, DoCheck {
|
6
|
+
export declare class AXInfiniteScrollDataTableComponent extends AXBaseDataTable implements OnInit, DoCheck {
|
14
7
|
private ngZone;
|
15
8
|
protected columns: QueryList<AXDataTableColumnComponent>;
|
16
9
|
protected startFixedColumn(): AXDataTableColumnComponent[];
|
@@ -26,14 +19,13 @@ export declare class AXDataTableComponent extends MXBaseComponent implements OnI
|
|
26
19
|
emptyTemplate?: TemplateRef<unknown>;
|
27
20
|
showHeader: boolean;
|
28
21
|
fetchDataMode: 'auto' | 'manual';
|
29
|
-
dataSource: AXDataSource<unknown>;
|
30
22
|
loading: {
|
31
23
|
enabled: boolean;
|
32
24
|
animation: boolean;
|
33
25
|
loadingTemplate?: TemplateRef<unknown>;
|
34
26
|
};
|
35
27
|
protected listDataSource: AXListDataSource<unknown>;
|
36
|
-
protected isLoading: boolean
|
28
|
+
protected isLoading: WritableSignal<boolean>;
|
37
29
|
protected hasItems: boolean;
|
38
30
|
protected totalRows: number;
|
39
31
|
protected currentPage: number;
|
@@ -44,12 +36,6 @@ export declare class AXDataTableComponent extends MXBaseComponent implements OnI
|
|
44
36
|
private _focusedRow;
|
45
37
|
get focusedRow(): unknown;
|
46
38
|
set focusedRow(v: unknown);
|
47
|
-
selectedRowsChange: EventEmitter<unknown[]>;
|
48
|
-
private _selectedRows;
|
49
|
-
get selectedRows(): unknown[];
|
50
|
-
set selectedRows(v: unknown[]);
|
51
|
-
selectRows(...rows: unknown[]): void;
|
52
|
-
unSelectRows(...rows: unknown[]): void;
|
53
39
|
itemHeight: number | 'auto';
|
54
40
|
protected width: string;
|
55
41
|
protected height: string;
|
@@ -75,6 +61,6 @@ export declare class AXDataTableComponent extends MXBaseComponent implements OnI
|
|
75
61
|
handleColumnClick(e: MouseEvent, column: AXDataTableColumnComponent): void;
|
76
62
|
protected getSort(column: AXDataTableColumnComponent): string | undefined;
|
77
63
|
protected _handleOnScroll(): void;
|
78
|
-
static ɵfac: i0.ɵɵFactoryDeclaration<
|
79
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<
|
64
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<AXInfiniteScrollDataTableComponent, never>;
|
65
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<AXInfiniteScrollDataTableComponent, "ax-infinite-scroll-data-table", never, { "dataSource": { "alias": "dataSource"; "required": false; }; "rowTemplate": { "alias": "rowTemplate"; "required": false; }; "emptyTemplate": { "alias": "emptyTemplate"; "required": false; }; "showHeader": { "alias": "showHeader"; "required": false; }; "fetchDataMode": { "alias": "fetchDataMode"; "required": false; }; "loading": { "alias": "loading"; "required": false; }; "focusedRow": { "alias": "focusedRow"; "required": false; }; "itemHeight": { "alias": "itemHeight"; "required": false; }; }, { "onPageChanged": "onPageChanged"; "onRowClick": "onRowClick"; "onRowDbClick": "onRowDbClick"; "focusedRowChange": "focusedRowChange"; "onScrolledIndexChanged": "onScrolledIndexChanged"; }, ["columns"], ["ax-header", "ax-footer"], false, never>;
|
80
66
|
}
|
@@ -62,7 +62,7 @@ export class AXButtonComponent extends MXButtonBaseComponent {
|
|
62
62
|
{ provide: AXComponent, useExisting: AXButtonComponent },
|
63
63
|
{ provide: AXButtonItemComponent, useExisting: AXButtonComponent },
|
64
64
|
{ provide: AXFocusableComponent, useExisting: AXButtonComponent },
|
65
|
-
], usesInheritance: true, ngImport: i0, template: "<button [axRipple] [disabled]=\"disabled\" [attr.tabindex]=\"tabIndex\" (focus)=\"emitOnFocusEvent($event)\"\n (blur)=\"emitOnBlurEvent($event)\" (click)=\"_handleClick($event)\" [attr.type]=\"type\">\n <ng-content select=\"ax-prefix, ax-loading, ax-loading-spinner, ax-icon\"> </ng-content>\n <ng-content select=\"ax-content\"> </ng-content>\n\n @if(text){\n <span class=\"ax-button-text\">{{ text }}</span>\n }\n\n <ng-content select=\"ax-suffix\"> </ng-content>\n <ng-content select=\"ax-dropdown-panel\"> </ng-content>\n <ng-content select=\".tab-content\"> </ng-content>\n</button>", styles: ["ax-button{position:relative;display:inline-flex;height:var(--ax-size-default);cursor:pointer;align-items:center;justify-content:center;border-radius:var(--ax-rounded-border-default);font-size:.875rem;line-height:1.25rem;outline:2px solid transparent;outline-offset:2px;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}ax-button.ax-xs{font-size:.75rem;line-height:1rem}ax-button.ax-xs>button{padding-left:.25rem;padding-right:.25rem}ax-button.ax-sm>button{padding-left:.5rem;padding-right:.5rem}ax-button.ax-sm,ax-button.ax-md{font-size:.875rem;line-height:1.25rem}ax-button.ax-lg{font-size:1rem;line-height:1.25rem}ax-button.ax-lg>button{padding-left:1.5rem;padding-right:1.5rem}ax-button.ax-xl{font-size:1.125rem;line-height:1.75rem}ax-button.ax-xl>button{padding-left:2rem;padding-right:2rem}ax-button.ax-xl.ax-button-icon{font-size:1.5rem}ax-button.ax-xs.ax-button-icon,ax-button.ax-sm.ax-button-icon{font-size:1rem}ax-button.ax-button-icon{height:var(--ax-size-default);width:var(--ax-size-default);font-size:1.25rem}ax-button.ax-state-disabled,ax-button.ax-state-loading{opacity:.5}ax-button.ax-state-disabled>button,ax-button.ax-state-loading>button{cursor:not-allowed}ax-button>button{position:relative;display:inline-flex;height:100%;width:100%;align-items:center;justify-content:center;overflow:hidden;border-radius:var(--ax-rounded-border-default);padding-left:1rem;padding-right:1rem;outline-color:transparent}ax-button>button.ax-state-focus:focus,ax-button>button:focus-visible{outline-width:2px;outline-offset:2px;outline-color:#000}ax-button>button .ax-button-text{white-space:nowrap;padding-left:.5rem;padding-right:.5rem;font-weight:500;line-height:1}ax-button ax-button-item.ax-divided{border-bottom-width:1px!important;border-color:rgba(var(--ax-color-border-default))!important}\n"], dependencies: [{ kind: "directive", type: i1.AXRippleDirective, selector: "[axRipple]", inputs: ["axRipple", "axRippleColor"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
|
65
|
+
], usesInheritance: true, ngImport: i0, template: "<button [axRipple] [disabled]=\"disabled\" [attr.tabindex]=\"tabIndex\" (focus)=\"emitOnFocusEvent($event)\"\n (blur)=\"emitOnBlurEvent($event)\" (click)=\"_handleClick($event)\" [attr.type]=\"type\">\n <ng-content select=\"ax-prefix, ax-loading, ax-loading-spinner, ax-icon\"> </ng-content>\n <ng-content select=\"ax-content\"> </ng-content>\n\n @if(text){\n <span class=\"ax-button-text\">{{ text }}</span>\n }\n\n <ng-content select=\"ax-suffix\"> </ng-content>\n <ng-content select=\"ax-dropdown-panel\"> </ng-content>\n <ng-content select=\".tab-content\"> </ng-content>\n</button>", styles: ["ax-button{position:relative;display:inline-flex;height:var(--ax-size-default);cursor:pointer;align-items:center;justify-content:center;border-radius:var(--ax-rounded-border-default);font-size:.875rem;line-height:1.25rem;outline:2px solid transparent;outline-offset:2px;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}ax-button.ax-xs{font-size:.75rem;line-height:1rem}ax-button.ax-xs>button{padding-left:.25rem;padding-right:.25rem}ax-button.ax-sm>button{padding-left:.5rem;padding-right:.5rem}ax-button.ax-sm,ax-button.ax-md{font-size:.875rem;line-height:1.25rem}ax-button.ax-lg{font-size:1rem;line-height:1.25rem}ax-button.ax-lg>button{padding-left:1.5rem;padding-right:1.5rem}ax-button.ax-xl{font-size:1.125rem;line-height:1.75rem}ax-button.ax-xl>button{padding-left:2rem;padding-right:2rem}ax-button.ax-xl.ax-button-icon{font-size:1.5rem}ax-button.ax-xs.ax-button-icon,ax-button.ax-sm.ax-button-icon{font-size:1rem}ax-button.ax-button-icon{height:var(--ax-size-default);width:var(--ax-size-default);font-size:1.25rem}ax-button.ax-state-disabled,ax-button.ax-state-loading{opacity:.5}ax-button.ax-state-disabled>button,ax-button.ax-state-loading>button{cursor:not-allowed}ax-button>button{position:relative;display:inline-flex;height:100%;width:100%;align-items:center;justify-content:center;overflow:hidden;border-radius:var(--ax-rounded-border-default);padding-left:1rem;padding-right:1rem;outline-color:transparent}ax-button>button.ax-state-focus:focus,ax-button>button:focus-visible{outline-width:2px;outline-offset:2px;outline-color:#000;border-radius:inherit}ax-button>button .ax-button-text{white-space:nowrap;padding-left:.5rem;padding-right:.5rem;font-weight:500;line-height:1}ax-button ax-button-item.ax-divided{border-bottom-width:1px!important;border-color:rgba(var(--ax-color-border-default))!important}\n"], dependencies: [{ kind: "directive", type: i1.AXRippleDirective, selector: "[axRipple]", inputs: ["axRipple", "axRippleColor"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
|
66
66
|
}
|
67
67
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.2", ngImport: i0, type: AXButtonComponent, decorators: [{
|
68
68
|
type: Component,
|
@@ -88,7 +88,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.2", ngImpor
|
|
88
88
|
{ provide: AXComponent, useExisting: AXButtonComponent },
|
89
89
|
{ provide: AXButtonItemComponent, useExisting: AXButtonComponent },
|
90
90
|
{ provide: AXFocusableComponent, useExisting: AXButtonComponent },
|
91
|
-
], template: "<button [axRipple] [disabled]=\"disabled\" [attr.tabindex]=\"tabIndex\" (focus)=\"emitOnFocusEvent($event)\"\n (blur)=\"emitOnBlurEvent($event)\" (click)=\"_handleClick($event)\" [attr.type]=\"type\">\n <ng-content select=\"ax-prefix, ax-loading, ax-loading-spinner, ax-icon\"> </ng-content>\n <ng-content select=\"ax-content\"> </ng-content>\n\n @if(text){\n <span class=\"ax-button-text\">{{ text }}</span>\n }\n\n <ng-content select=\"ax-suffix\"> </ng-content>\n <ng-content select=\"ax-dropdown-panel\"> </ng-content>\n <ng-content select=\".tab-content\"> </ng-content>\n</button>", styles: ["ax-button{position:relative;display:inline-flex;height:var(--ax-size-default);cursor:pointer;align-items:center;justify-content:center;border-radius:var(--ax-rounded-border-default);font-size:.875rem;line-height:1.25rem;outline:2px solid transparent;outline-offset:2px;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}ax-button.ax-xs{font-size:.75rem;line-height:1rem}ax-button.ax-xs>button{padding-left:.25rem;padding-right:.25rem}ax-button.ax-sm>button{padding-left:.5rem;padding-right:.5rem}ax-button.ax-sm,ax-button.ax-md{font-size:.875rem;line-height:1.25rem}ax-button.ax-lg{font-size:1rem;line-height:1.25rem}ax-button.ax-lg>button{padding-left:1.5rem;padding-right:1.5rem}ax-button.ax-xl{font-size:1.125rem;line-height:1.75rem}ax-button.ax-xl>button{padding-left:2rem;padding-right:2rem}ax-button.ax-xl.ax-button-icon{font-size:1.5rem}ax-button.ax-xs.ax-button-icon,ax-button.ax-sm.ax-button-icon{font-size:1rem}ax-button.ax-button-icon{height:var(--ax-size-default);width:var(--ax-size-default);font-size:1.25rem}ax-button.ax-state-disabled,ax-button.ax-state-loading{opacity:.5}ax-button.ax-state-disabled>button,ax-button.ax-state-loading>button{cursor:not-allowed}ax-button>button{position:relative;display:inline-flex;height:100%;width:100%;align-items:center;justify-content:center;overflow:hidden;border-radius:var(--ax-rounded-border-default);padding-left:1rem;padding-right:1rem;outline-color:transparent}ax-button>button.ax-state-focus:focus,ax-button>button:focus-visible{outline-width:2px;outline-offset:2px;outline-color:#000}ax-button>button .ax-button-text{white-space:nowrap;padding-left:.5rem;padding-right:.5rem;font-weight:500;line-height:1}ax-button ax-button-item.ax-divided{border-bottom-width:1px!important;border-color:rgba(var(--ax-color-border-default))!important}\n"] }]
|
91
|
+
], template: "<button [axRipple] [disabled]=\"disabled\" [attr.tabindex]=\"tabIndex\" (focus)=\"emitOnFocusEvent($event)\"\n (blur)=\"emitOnBlurEvent($event)\" (click)=\"_handleClick($event)\" [attr.type]=\"type\">\n <ng-content select=\"ax-prefix, ax-loading, ax-loading-spinner, ax-icon\"> </ng-content>\n <ng-content select=\"ax-content\"> </ng-content>\n\n @if(text){\n <span class=\"ax-button-text\">{{ text }}</span>\n }\n\n <ng-content select=\"ax-suffix\"> </ng-content>\n <ng-content select=\"ax-dropdown-panel\"> </ng-content>\n <ng-content select=\".tab-content\"> </ng-content>\n</button>", styles: ["ax-button{position:relative;display:inline-flex;height:var(--ax-size-default);cursor:pointer;align-items:center;justify-content:center;border-radius:var(--ax-rounded-border-default);font-size:.875rem;line-height:1.25rem;outline:2px solid transparent;outline-offset:2px;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}ax-button.ax-xs{font-size:.75rem;line-height:1rem}ax-button.ax-xs>button{padding-left:.25rem;padding-right:.25rem}ax-button.ax-sm>button{padding-left:.5rem;padding-right:.5rem}ax-button.ax-sm,ax-button.ax-md{font-size:.875rem;line-height:1.25rem}ax-button.ax-lg{font-size:1rem;line-height:1.25rem}ax-button.ax-lg>button{padding-left:1.5rem;padding-right:1.5rem}ax-button.ax-xl{font-size:1.125rem;line-height:1.75rem}ax-button.ax-xl>button{padding-left:2rem;padding-right:2rem}ax-button.ax-xl.ax-button-icon{font-size:1.5rem}ax-button.ax-xs.ax-button-icon,ax-button.ax-sm.ax-button-icon{font-size:1rem}ax-button.ax-button-icon{height:var(--ax-size-default);width:var(--ax-size-default);font-size:1.25rem}ax-button.ax-state-disabled,ax-button.ax-state-loading{opacity:.5}ax-button.ax-state-disabled>button,ax-button.ax-state-loading>button{cursor:not-allowed}ax-button>button{position:relative;display:inline-flex;height:100%;width:100%;align-items:center;justify-content:center;overflow:hidden;border-radius:var(--ax-rounded-border-default);padding-left:1rem;padding-right:1rem;outline-color:transparent}ax-button>button.ax-state-focus:focus,ax-button>button:focus-visible{outline-width:2px;outline-offset:2px;outline-color:#000;border-radius:inherit}ax-button>button .ax-button-text{white-space:nowrap;padding-left:.5rem;padding-right:.5rem;font-weight:500;line-height:1}ax-button ax-button-item.ax-divided{border-bottom-width:1px!important;border-color:rgba(var(--ax-color-border-default))!important}\n"] }]
|
92
92
|
}], propDecorators: { type: [{
|
93
93
|
type: Input
|
94
94
|
}], __hostClass: [{
|
@@ -23,6 +23,7 @@ export class AXDataSource {
|
|
23
23
|
return this._isLoading;
|
24
24
|
}
|
25
25
|
constructor(config) {
|
26
|
+
this.useCache = true;
|
26
27
|
this._totalCount = 0;
|
27
28
|
this._items = [];
|
28
29
|
this.fetchedPages = new Set();
|
@@ -38,11 +39,12 @@ export class AXDataSource {
|
|
38
39
|
}
|
39
40
|
load() {
|
40
41
|
const page = this._page;
|
41
|
-
if (this.fetchedPages.has(page)) {
|
42
|
+
if (this.fetchedPages.has(page) && this.useCache) {
|
42
43
|
return;
|
43
44
|
}
|
44
45
|
this.setLoadingState(true);
|
45
46
|
this.fetchedPages.add(page);
|
47
|
+
this._query.take = this.config.pageSize;
|
46
48
|
this._query.skip = page * this.config.pageSize;
|
47
49
|
this.config
|
48
50
|
.load({ ...this._query })
|
@@ -76,6 +78,10 @@ export class AXDataSource {
|
|
76
78
|
this.load();
|
77
79
|
}
|
78
80
|
}
|
81
|
+
setPageSize(pageSize) {
|
82
|
+
this.config.pageSize = pageSize;
|
83
|
+
this.load();
|
84
|
+
}
|
79
85
|
filter(value) {
|
80
86
|
this._query.filter = value;
|
81
87
|
}
|
@@ -124,4 +130,4 @@ export function convertArrayToDataSource(items, options = { key: 'id', pageSize:
|
|
124
130
|
};
|
125
131
|
return new AXDataSource(config);
|
126
132
|
}
|
127
|
-
//# 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 AXFilterLogic = 'and' | 'or';\nexport type AXSortOrder = 'asc' | 'desc';\n\nexport type AXDataSourceFilterOption = {\n  field: string;\n  value?: unknown;\n  operator: AXDataSourceOperator;\n  logic?: AXFilterLogic;\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  public get totalCount(): number {\n    return this._totalCount;\n  }\n\n  public get totalPages(): number {\n    return Math.floor(this.totalCount / this.config.pageSize);\n  }\n\n  public get pageSize(): number {\n    return 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 = { skip: 0, take: 0, sort: [] };\n\n  public get query(): AXDataSourceQuery {\n    return this._query;\n  }\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.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 = [];\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((c) => (!this.config.key && c == key) || (c && this.config.key && c[this.config.key] == key));\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: 100 },\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"]}
|
133
|
+
//# 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 AXFilterLogic = 'and' | 'or';\nexport type AXSortOrder = 'asc' | 'desc';\n\nexport type AXDataSourceFilterOption = {\n  field: string;\n  value?: unknown;\n  operator: AXDataSourceOperator;\n  logic?: AXFilterLogic;\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  useCache = true;\n\n  private _totalCount = 0;\n  public get totalCount(): number {\n    return this._totalCount;\n  }\n\n  public get totalPages(): number {\n    return Math.floor(this.totalCount / this.config.pageSize);\n  }\n\n  public get pageSize(): number {\n    return 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 = { skip: 0, take: 0, sort: [] };\n\n  public get query(): AXDataSourceQuery {\n    return this._query;\n  }\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.take = this.config.pageSize;\n  }\n\n  private load() {\n    const page = this._page;\n    if (this.fetchedPages.has(page) && this.useCache) {\n      return;\n    }\n    this.setLoadingState(true);\n    this.fetchedPages.add(page);\n    this._query.take = this.config.pageSize;\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  public setPageSize(pageSize: number) {\n    this.config.pageSize = pageSize;\n    this.load();\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 = [];\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((c) => (!this.config.key && c == key) || (c && this.config.key && c[this.config.key] == key));\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: 100 },\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"]}
|
@@ -177,7 +177,7 @@ export class MXSelectionValueComponent extends MXValueComponent {
|
|
177
177
|
}
|
178
178
|
getDisplayText(item) {
|
179
179
|
const normalizeItem = this.normalizeItem(item);
|
180
|
-
return normalizeItem[this.textField] ||
|
180
|
+
return normalizeItem[this.textField] || normalizeItem[this.valueField];
|
181
181
|
}
|
182
182
|
getValue(item) {
|
183
183
|
const normalizeItem = this.normalizeItem(item);
|
@@ -193,4 +193,4 @@ export class MXSelectionValueComponent extends MXValueComponent {
|
|
193
193
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.2", ngImport: i0, type: MXSelectionValueComponent, decorators: [{
|
194
194
|
type: Injectable
|
195
195
|
}] });
|
196
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"selection-base.component.class.js","sourceRoot":"","sources":["../../../../../../../libs/components/common/src/lib/components/selection-base.component.class.ts"],"names":[],"mappings":"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","sourcesContent":["import { coerceBooleanProperty } from '@angular/cdk/coercion';\nimport { Injectable, InjectionToken, inject } from '@angular/core';\nimport { MXValueComponent } from './value-component.class';\n\n@Injectable()\nexport class MXSelectionBridgeService {\n  public selectedItems: unknown[] = [];\n  public cacheList: { [key: string | number]: unknown } = {};\n}\n\nexport const AX_SELECTION_DATA_TOKEN = new InjectionToken<MXSelectionBridgeService>('AX_SELECTION_DATA_TOKEN');\n\n@Injectable()\nexport abstract class MXSelectionValueComponent<T = unknown> extends MXValueComponent<unknown> {\n  private dataService = inject(AX_SELECTION_DATA_TOKEN);\n\n  disabledCallback: (e: { item: T; index: number }) => boolean;\n\n  private _valueField = 'id';\n  public get valueField(): string {\n    return this._valueField;\n  }\n  public set valueField(v: string) {\n    this.setOption({\n      name: 'valueField',\n      value: v,\n    });\n  }\n\n  private _textField = 'text';\n  public get textField(): string {\n    return this._textField;\n  }\n  public set textField(v: string) {\n    this.setOption({\n      name: 'textField',\n      value: v,\n    });\n  }\n\n  private _disabledField = 'disabled';\n  public get disabledField(): string {\n    return this._disabledField;\n  }\n  public set disabledField(v: string) {\n    this.setOption({\n      name: 'disabledField',\n      value: v,\n    });\n  }\n\n  private _multiple = false;\n  public get multiple(): boolean {\n    return this._multiple;\n  }\n  public set multiple(v: boolean) {\n    this.setOption({\n      name: 'multiple',\n      value: v,\n      afterCallback: () => {\n        this.clear(false);\n      },\n    });\n  }\n\n  get selectedItems(): unknown[] {\n    return this.dataService.selectedItems || [];\n  }\n\n  override internalSetValue(value: unknown) {\n    const isArray = Array.isArray(value);\n    if (value == null || (isArray && value.length == 0)) {\n      return this.multiple ? [] : null;\n    }\n    const normalizedItems = isArray ? this.normalizeItemsList(value, true) : this.normalizeItemsList([value], true);\n\n    if (normalizedItems.length == 0) {\n      return this.multiple ? [] : null;\n    }\n    const result = this.multiple ? normalizedItems.map((c) => c[this.valueField]) : normalizedItems[0][this.valueField];\n    return result;\n  }\n\n  override emitOnValueChangedEvent(oldValue?: unknown, newValue?: unknown) {\n    this._normalizeSelectedItems();\n    super.emitOnValueChangedEvent(oldValue, newValue);\n  }\n\n  abstract getItemByKey(key: unknown): unknown | Promise<unknown>;\n\n  protected normalizeItemsList(items: unknown[], findBykey = false): unknown[] {\n    if (items == null) return [];\n    return items.filter((c) => c != null).map((i) => this.normalizeItem(i, findBykey));\n  }\n\n  private normalizeItem(item: unknown, findBykey = false): unknown {\n    const complex = typeof item == 'object';\n    const key = complex ? item[this.valueField] : `${item}`;\n    const cacheKey = `k-${key}`;\n    const hasText = !complex || item[this.textField] != null;\n    //\n    if (this.dataService.cacheList[cacheKey] && this.dataService.cacheList[cacheKey][this.textField])\n      return this.dataService.cacheList[cacheKey];\n    //\n    const obj: unknown = {};\n    if (complex && hasText) {\n      Object.assign(obj, item);\n    } else {\n      const existsItem = findBykey ? this.getItemByKey(key) : null;\n      if (existsItem && existsItem instanceof Promise) {\n        obj[this.valueField] = key;\n        obj['isLoading'] = true;\n        //\n        existsItem\n          .then((r) => {\n            if (typeof r === 'object') {\n              obj[this.valueField] = r[this.valueField];\n              obj[this.textField] = r[this.textField];\n            } else {\n              obj[this.valueField] = r || key;\n            }\n          })\n          .finally(() => {\n            obj['isLoading'] = false;\n            this.dataService.cacheList[cacheKey] = obj;\n            this.cdr.markForCheck();\n          });\n      } else if (existsItem) {\n        obj[this.valueField] = complex ? existsItem[this.valueField] : existsItem;\n      } else {\n        obj[this.valueField] = complex ? item[this.valueField] : item;\n      }\n    }\n    this.dataService.cacheList[cacheKey] = obj;\n    return obj;\n  }\n\n  private _normalizeSelectedItems() {\n    const values = Array.isArray(this.value) ? this.value : this.value != null ? [this.value] : [];\n    this.dataService.selectedItems = values.map((v) => this.normalizeItem(v));\n  }\n\n  public unselectItems(...items: T[]) {\n    if (!items || items.length === 0) {\n      this.commitValue([], true);\n      return;\n    }\n    const normalizeItems = Array.isArray(items) ? this.normalizeItemsList(items) : [this.normalizeItem(items)];\n    const newSelectedItems = this.selectedItems.filter((i) => !normalizeItems.some((n) => n[this.valueField] == i[this.valueField]));\n    this.commitValue(newSelectedItems, true);\n  }\n\n  public selectItems(...items: T[]) {\n    if (items && items.length) {\n      let newSelectedItems = Array.isArray(this.value) ? this.value : [this.value];\n      const normalizeItems = Array.isArray(items) ? this.normalizeItemsList(items) : [this.normalizeItem(items)];\n      if (this.multiple) {\n        newSelectedItems = [...newSelectedItems, ...normalizeItems];\n      } else {\n        newSelectedItems = normalizeItems;\n      }\n      this.commitValue(newSelectedItems, true);\n    }\n  }\n\n  public toggleSelect(...items: T[]) {\n    items?.forEach((item) => {\n      if (this.multiple) {\n        this.isItemSelected(item) ? this.unselectItems(item) : this.selectItems(item);\n      } else {\n        this.selectItems(item);\n      }\n    });\n  }\n\n  public isItemSelected(item: T): boolean {\n    return this.selectedItems.some((c) => c[this.valueField] === this.normalizeItem(item)[this.valueField]);\n  }\n\n  public isItemDisabled(item: T): boolean {\n    return (\n      this.disabled ||\n      coerceBooleanProperty(item[this.disabledField]) === true ||\n      (this.disabledCallback ? this.disabledCallback({ item, index: -1 }) : false)\n    );\n  }\n\n  protected getDisplayText(item: T) {\n    const normalizeItem = this.normalizeItem(item) as any;\n    return normalizeItem[this.textField] || 'Loading...';\n  }\n\n  protected getValue(item: T) {\n    const normalizeItem = this.normalizeItem(item) as any;\n    return normalizeItem[this.valueField];\n  }\n\n  protected clearSelectionCache() {\n    this.dataService.cacheList = {};\n    this.dataService.selectedItems = [];\n  }\n}\n"]}
|
196
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"selection-base.component.class.js","sourceRoot":"","sources":["../../../../../../../libs/components/common/src/lib/components/selection-base.component.class.ts"],"names":[],"mappings":"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","sourcesContent":["import { coerceBooleanProperty } from '@angular/cdk/coercion';\nimport { Injectable, InjectionToken, inject } from '@angular/core';\nimport { MXValueComponent } from './value-component.class';\n\n@Injectable()\nexport class MXSelectionBridgeService {\n  public selectedItems: unknown[] = [];\n  public cacheList: { [key: string | number]: unknown } = {};\n}\n\nexport const AX_SELECTION_DATA_TOKEN = new InjectionToken<MXSelectionBridgeService>('AX_SELECTION_DATA_TOKEN');\n\n@Injectable()\nexport abstract class MXSelectionValueComponent<T = unknown> extends MXValueComponent<unknown> {\n  private dataService = inject(AX_SELECTION_DATA_TOKEN);\n\n  disabledCallback: (e: { item: T; index: number }) => boolean;\n\n  private _valueField = 'id';\n  public get valueField(): string {\n    return this._valueField;\n  }\n  public set valueField(v: string) {\n    this.setOption({\n      name: 'valueField',\n      value: v,\n    });\n  }\n\n  private _textField = 'text';\n  public get textField(): string {\n    return this._textField;\n  }\n  public set textField(v: string) {\n    this.setOption({\n      name: 'textField',\n      value: v,\n    });\n  }\n\n  private _disabledField = 'disabled';\n  public get disabledField(): string {\n    return this._disabledField;\n  }\n  public set disabledField(v: string) {\n    this.setOption({\n      name: 'disabledField',\n      value: v,\n    });\n  }\n\n  private _multiple = false;\n  public get multiple(): boolean {\n    return this._multiple;\n  }\n  public set multiple(v: boolean) {\n    this.setOption({\n      name: 'multiple',\n      value: v,\n      afterCallback: () => {\n        this.clear(false);\n      },\n    });\n  }\n\n  get selectedItems(): unknown[] {\n    return this.dataService.selectedItems || [];\n  }\n\n  override internalSetValue(value: unknown) {\n    const isArray = Array.isArray(value);\n    if (value == null || (isArray && value.length == 0)) {\n      return this.multiple ? [] : null;\n    }\n    const normalizedItems = isArray ? this.normalizeItemsList(value, true) : this.normalizeItemsList([value], true);\n\n    if (normalizedItems.length == 0) {\n      return this.multiple ? [] : null;\n    }\n    const result = this.multiple ? normalizedItems.map((c) => c[this.valueField]) : normalizedItems[0][this.valueField];\n    return result;\n  }\n\n  override emitOnValueChangedEvent(oldValue?: unknown, newValue?: unknown) {\n    this._normalizeSelectedItems();\n    super.emitOnValueChangedEvent(oldValue, newValue);\n  }\n\n  abstract getItemByKey(key: unknown): unknown | Promise<unknown>;\n\n  protected normalizeItemsList(items: unknown[], findBykey = false): unknown[] {\n    if (items == null) return [];\n    return items.filter((c) => c != null).map((i) => this.normalizeItem(i, findBykey));\n  }\n\n  private normalizeItem(item: unknown, findBykey = false): unknown {\n    const complex = typeof item == 'object';\n    const key = complex ? item[this.valueField] : `${item}`;\n    const cacheKey = `k-${key}`;\n    const hasText = !complex || item[this.textField] != null;\n    //\n    if (this.dataService.cacheList[cacheKey] && this.dataService.cacheList[cacheKey][this.textField])\n      return this.dataService.cacheList[cacheKey];\n    //\n    const obj: unknown = {};\n    if (complex && hasText) {\n      Object.assign(obj, item);\n    } else {\n      const existsItem = findBykey ? this.getItemByKey(key) : null;\n      if (existsItem && existsItem instanceof Promise) {\n        obj[this.valueField] = key;\n        obj['isLoading'] = true;\n        //\n        existsItem\n          .then((r) => {\n            if (typeof r === 'object') {\n              obj[this.valueField] = r[this.valueField];\n              obj[this.textField] = r[this.textField];\n            } else {\n              obj[this.valueField] = r || key;\n            }\n          })\n          .finally(() => {\n            obj['isLoading'] = false;\n            this.dataService.cacheList[cacheKey] = obj;\n            this.cdr.markForCheck();\n          });\n      } else if (existsItem) {\n        obj[this.valueField] = complex ? existsItem[this.valueField] : existsItem;\n      } else {\n        obj[this.valueField] = complex ? item[this.valueField] : item;\n      }\n    }\n    this.dataService.cacheList[cacheKey] = obj;\n    return obj;\n  }\n\n  private _normalizeSelectedItems() {\n    const values = Array.isArray(this.value) ? this.value : this.value != null ? [this.value] : [];\n    this.dataService.selectedItems = values.map((v) => this.normalizeItem(v));\n  }\n\n  public unselectItems(...items: T[]) {\n    if (!items || items.length === 0) {\n      this.commitValue([], true);\n      return;\n    }\n    const normalizeItems = Array.isArray(items) ? this.normalizeItemsList(items) : [this.normalizeItem(items)];\n    const newSelectedItems = this.selectedItems.filter((i) => !normalizeItems.some((n) => n[this.valueField] == i[this.valueField]));\n    this.commitValue(newSelectedItems, true);\n  }\n\n  public selectItems(...items: T[]) {\n    if (items && items.length) {\n      let newSelectedItems = Array.isArray(this.value) ? this.value : [this.value];\n      const normalizeItems = Array.isArray(items) ? this.normalizeItemsList(items) : [this.normalizeItem(items)];\n      if (this.multiple) {\n        newSelectedItems = [...newSelectedItems, ...normalizeItems];\n      } else {\n        newSelectedItems = normalizeItems;\n      }\n      this.commitValue(newSelectedItems, true);\n    }\n  }\n\n  public toggleSelect(...items: T[]) {\n    items?.forEach((item) => {\n      if (this.multiple) {\n        this.isItemSelected(item) ? this.unselectItems(item) : this.selectItems(item);\n      } else {\n        this.selectItems(item);\n      }\n    });\n  }\n\n  public isItemSelected(item: T): boolean {\n    return this.selectedItems.some((c) => c[this.valueField] === this.normalizeItem(item)[this.valueField]);\n  }\n\n  public isItemDisabled(item: T): boolean {\n    return (\n      this.disabled ||\n      coerceBooleanProperty(item[this.disabledField]) === true ||\n      (this.disabledCallback ? this.disabledCallback({ item, index: -1 }) : false)\n    );\n  }\n\n  protected getDisplayText(item: T) {\n    const normalizeItem = this.normalizeItem(item) as any;\n    return normalizeItem[this.textField] || normalizeItem[this.valueField];\n  }\n\n  protected getValue(item: T) {\n    const normalizeItem = this.normalizeItem(item) as any;\n    return normalizeItem[this.valueField];\n  }\n\n  protected clearSelectionCache() {\n    this.dataService.cacheList = {};\n    this.dataService.selectedItems = [];\n  }\n}\n"]}
|
@@ -2,7 +2,7 @@ import { AXPagedComponent, MXValueComponent } from '@acorex/components/common';
|
|
2
2
|
import { ChangeDetectionStrategy, Component, EventEmitter, Inject, Input, Optional, Output, ViewEncapsulation, forwardRef, } from '@angular/core';
|
3
3
|
import { isNumber } from 'lodash-es';
|
4
4
|
import { NG_VALUE_ACCESSOR } from '@angular/forms';
|
5
|
-
import { AXDataPagerParentComponent
|
5
|
+
import { AXDataPagerParentComponent } from './data-pager-base.component';
|
6
6
|
import * as i0 from "@angular/core";
|
7
7
|
import * as i1 from "@acorex/components/decorators";
|
8
8
|
import * as i2 from "./data-pager-next-buttons.components";
|
@@ -79,7 +79,7 @@ export class AXDataPagerComponent extends MXValueComponent {
|
|
79
79
|
this._emitChangedEvent();
|
80
80
|
}
|
81
81
|
internalValueChanged(value) {
|
82
|
-
this._emitChangedEvent();
|
82
|
+
this._emitChangedEvent(true);
|
83
83
|
}
|
84
84
|
internalGetValue(value) {
|
85
85
|
if (!isNumber(value) || !value || this.totalPages == 0)
|
@@ -101,11 +101,12 @@ export class AXDataPagerComponent extends MXValueComponent {
|
|
101
101
|
};
|
102
102
|
return result;
|
103
103
|
}
|
104
|
-
_emitChangedEvent() {
|
104
|
+
_emitChangedEvent(u = false) {
|
105
105
|
this.totalPages = Math.ceil(this._total / this.size);
|
106
106
|
//
|
107
107
|
this.onChanged.emit(Object.assign({
|
108
108
|
component: this,
|
109
|
+
isUserInteraction: u,
|
109
110
|
htmlElement: this.getHostElement(),
|
110
111
|
}, this.displayInfo));
|
111
112
|
if (this.totalPages > 0)
|
@@ -127,7 +128,7 @@ export class AXDataPagerComponent extends MXValueComponent {
|
|
127
128
|
}
|
128
129
|
goToPage(page) {
|
129
130
|
if (page != this.value) {
|
130
|
-
this.commitValue(page);
|
131
|
+
this.commitValue(page, true);
|
131
132
|
}
|
132
133
|
}
|
133
134
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.2", ngImport: i0, type: AXDataPagerComponent, deps: [{ token: AXPagedComponent, optional: true }], target: i0.ɵɵFactoryTarget.Component }); }
|
@@ -142,12 +143,7 @@ export class AXDataPagerComponent extends MXValueComponent {
|
|
142
143
|
}
|
143
144
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.2", ngImport: i0, type: AXDataPagerComponent, decorators: [{
|
144
145
|
type: Component,
|
145
|
-
args: [{ selector: 'ax-data-pager', inputs: ['value', 'name', 'disabled', 'readonly'], outputs: [
|
146
|
-
'valueChange',
|
147
|
-
'onValueChanged',
|
148
|
-
'disabledChange',
|
149
|
-
'readonlyChange',
|
150
|
-
], changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, providers: [
|
146
|
+
args: [{ selector: 'ax-data-pager', inputs: ['value', 'name', 'disabled', 'readonly'], outputs: ['valueChange', 'onValueChanged', 'disabledChange', 'readonlyChange'], changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, providers: [
|
151
147
|
{ provide: AXDataPagerParentComponent, useExisting: AXDataPagerComponent },
|
152
148
|
{
|
153
149
|
provide: NG_VALUE_ACCESSOR,
|
@@ -171,4 +167,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.2", ngImpor
|
|
171
167
|
}], onChanged: [{
|
172
168
|
type: Output
|
173
169
|
}] } });
|
174
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-pager.component.js","sourceRoot":"","sources":["../../../../../../libs/components/data-pager/src/lib/data-pager.component.ts","../../../../../../libs/components/data-pager/src/lib/data-pager.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AXPagedComponent, MXValueComponent } from '@acorex/components/common';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  EventEmitter,\n  Inject,\n  Input,\n  Optional,\n  Output,\n  ViewEncapsulation,\n  forwardRef,\n} from '@angular/core';\nimport { isNumber } from 'lodash-es';\n\nimport { NG_VALUE_ACCESSOR } from '@angular/forms';\nimport {\n  AXDataPagerChangedEvent,\n  AXDataPagerData,\n  AXDataPagerParentComponent,\n} from './data-pager-base.component';\n\n@Component({\n  selector: 'ax-data-pager',\n  templateUrl: './data-pager.component.html',\n  styleUrls: ['./data-pager.component.scss'],\n  inputs: ['value', 'name', 'disabled', 'readonly'],\n  outputs: [\n    'valueChange',\n    'onValueChanged',\n    'disabledChange',\n    'readonlyChange',\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  providers: [\n    { provide: AXDataPagerParentComponent, useExisting: AXDataPagerComponent },\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => AXDataPagerComponent),\n      multi: true,\n    },\n  ],\n})\nexport class AXDataPagerComponent extends MXValueComponent<number> {\n  private _size = 10;\n  @Input()\n  public get size(): number {\n    return this._size;\n  }\n  public set size(v: number) {\n    if (v != this._size) {\n      this._size = v;\n      if (this._parent) {\n        this._parent.pageSize = v;\n      }\n      const newPage = Math.ceil(this.displayInfo.range.from / this._size) || 1;\n      this.commitValue(newPage);\n      this._emitChangedEvent();\n    }\n  }\n\n  private _total = 0;\n  @Input()\n  public get total(): number {\n    return this._total;\n  }\n  public set total(v: number) {\n    const t = v && v > 0 ? v : 0;\n    if (t != this._total) {\n      this._total = t;\n      this._emitChangedEvent();\n    }\n  }\n\n  private _totalPages = 0;\n\n  public get totalPages(): number {\n    return this._totalPages;\n  }\n\n  private set totalPages(value: number) {\n    this._totalPages = value;\n  }\n\n  @Output()\n  public displayModeChange: EventEmitter<string> = new EventEmitter<string>();\n\n  private _displayMode = 'full';\n  @Input()\n  public get displayMode(): string {\n    return this._displayMode;\n  }\n  public set displayMode(v: string) {\n    this.setOption({\n      name: 'displayMode',\n      value: v,\n      afterCallback: () => {\n        this._emitChangedEvent();\n      },\n    });\n  }\n\n  @Output()\n  onChanged: EventEmitter<AXDataPagerChangedEvent> =\n    new EventEmitter<AXDataPagerChangedEvent>();\n\n  constructor(\n    @Optional()\n    @Inject(AXPagedComponent)\n    private _parent: AXPagedComponent\n  ) {\n    super();\n    //\n    if (this._parent) {\n      this._parent.onPageChanged.subscribe((c) => {\n        this.size = this._parent.pageSize;\n        this.total = this._parent.totalCount;\n        this.value = c.value;\n      });\n      this.size = this._parent.pageSize;\n      this.total = this._parent.totalCount;\n    }\n  }\n\n  ngAfterViewInit() {\n    this._emitChangedEvent();\n  }\n\n  protected override internalValueChanged(value: any): void {\n    this._emitChangedEvent();\n  }\n\n  protected override internalGetValue(value: any): number {\n    if (!isNumber(value) || !value || this.totalPages == 0) return 1;\n    return value > this.totalPages ? this.totalPages : value;\n  }\n\n  public get displayInfo(): AXDataPagerData {\n    const skip = Math.max(0, (this.value - 1) * this.size);\n    const result = {\n      page: this.value,\n      totalItems: this.total,\n      totalPages: this.totalPages,\n      range: {\n        from: skip + 1,\n        to: Math.min(this.value * this.size, this.total),\n      },\n      skip,\n      take: this.size,\n    };\n    return result;\n  }\n\n  private _emitChangedEvent(): void {\n    this.totalPages = Math.ceil(this._total / this.size);\n    //\n    this.onChanged.emit(\n      Object.assign(\n        {\n          component: this,\n          htmlElement: this.getHostElement(),\n        },\n        this.displayInfo\n      )\n    );\n    if (this.totalPages > 0) this._parent?.goToPage(this.value);\n    //\n    this.cdr.markForCheck();\n  }\n\n  goNextPage(): void {\n    this.goToPage(Math.min(this.value + 1, this.totalPages));\n  }\n\n  goLastPage(): void {\n    this.goToPage(this.totalPages);\n  }\n\n  goFirstPage(): void {\n    this.goToPage(1);\n  }\n\n  goPrevPage(): void {\n    this.goToPage(Math.max(this.value - 1, 1));\n  }\n\n  goToPage(page: number): void {\n    if (page != this.value) {\n      this.commitValue(page);\n    }\n  }\n}\n","@switch(displayMode){\n@case('full'){\n<ax-prefix>\n    <ax-data-pager-numeric-selector>\n    </ax-data-pager-numeric-selector>\n    <ax-data-pager-page-sizes>\n    </ax-data-pager-page-sizes>\n</ax-prefix>\n<ax-suffix>\n    <ax-data-pager-info>\n    </ax-data-pager-info>\n</ax-suffix>\n}\n@case('compact'){\n<ax-prefix>\n    <ax-data-pager-prev-buttons>\n    </ax-data-pager-prev-buttons>\n    <ax-data-pager-input-selector>\n    </ax-data-pager-input-selector>\n    <ax-data-pager-next-buttons>\n    </ax-data-pager-next-buttons>\n</ax-prefix>\n<ax-suffix>\n    <ax-data-pager-info>\n    </ax-data-pager-info>\n</ax-suffix>\n}\n@default{\n<ng-content select=\"ax-prefix\"></ng-content>\n<ng-content select=\"ax-suffix\"></ng-content>\n}\n}"]}
|
170
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-pager.component.js","sourceRoot":"","sources":["../../../../../../libs/components/data-pager/src/lib/data-pager.component.ts","../../../../../../libs/components/data-pager/src/lib/data-pager.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AXPagedComponent, MXValueComponent } from '@acorex/components/common';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  EventEmitter,\n  Inject,\n  Input,\n  Optional,\n  Output,\n  ViewEncapsulation,\n  forwardRef,\n} from '@angular/core';\nimport { isNumber } from 'lodash-es';\n\nimport { NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { AXDataPagerChangedEvent, AXDataPagerData, AXDataPagerParentComponent } from './data-pager-base.component';\n\n@Component({\n  selector: 'ax-data-pager',\n  templateUrl: './data-pager.component.html',\n  styleUrls: ['./data-pager.component.scss'],\n  inputs: ['value', 'name', 'disabled', 'readonly'],\n  outputs: ['valueChange', 'onValueChanged', 'disabledChange', 'readonlyChange'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  providers: [\n    { provide: AXDataPagerParentComponent, useExisting: AXDataPagerComponent },\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => AXDataPagerComponent),\n      multi: true,\n    },\n  ],\n})\nexport class AXDataPagerComponent extends MXValueComponent<number> {\n  private _size = 10;\n  @Input()\n  public get size(): number {\n    return this._size;\n  }\n  public set size(v: number) {\n    if (v != this._size) {\n      this._size = v;\n      if (this._parent) {\n        this._parent.pageSize = v;\n      }\n      const newPage = Math.ceil(this.displayInfo.range.from / this._size) || 1;\n      this.commitValue(newPage);\n      this._emitChangedEvent();\n    }\n  }\n\n  private _total = 0;\n  @Input()\n  public get total(): number {\n    return this._total;\n  }\n  public set total(v: number) {\n    const t = v && v > 0 ? v : 0;\n    if (t != this._total) {\n      this._total = t;\n      this._emitChangedEvent();\n    }\n  }\n\n  private _totalPages = 0;\n\n  public get totalPages(): number {\n    return this._totalPages;\n  }\n\n  private set totalPages(value: number) {\n    this._totalPages = value;\n  }\n\n  @Output()\n  public displayModeChange: EventEmitter<string> = new EventEmitter<string>();\n\n  private _displayMode = 'full';\n  @Input()\n  public get displayMode(): string {\n    return this._displayMode;\n  }\n  public set displayMode(v: string) {\n    this.setOption({\n      name: 'displayMode',\n      value: v,\n      afterCallback: () => {\n        this._emitChangedEvent();\n      },\n    });\n  }\n\n  @Output()\n  onChanged: EventEmitter<AXDataPagerChangedEvent> = new EventEmitter<AXDataPagerChangedEvent>();\n\n  constructor(\n    @Optional()\n    @Inject(AXPagedComponent)\n    private _parent: AXPagedComponent,\n  ) {\n    super();\n    //\n    if (this._parent) {\n      this._parent.onPageChanged.subscribe((c) => {\n        this.size = this._parent.pageSize;\n        this.total = this._parent.totalCount;\n        this.value = c.value;\n      });\n      this.size = this._parent.pageSize;\n      this.total = this._parent.totalCount;\n    }\n  }\n\n  ngAfterViewInit() {\n    this._emitChangedEvent();\n  }\n\n  protected override internalValueChanged(value: any): void {\n    this._emitChangedEvent(true);\n  }\n\n  protected override internalGetValue(value: any): number {\n    if (!isNumber(value) || !value || this.totalPages == 0) return 1;\n    return value > this.totalPages ? this.totalPages : value;\n  }\n\n  public get displayInfo(): AXDataPagerData {\n    const skip = Math.max(0, (this.value - 1) * this.size);\n    const result = {\n      page: this.value,\n      totalItems: this.total,\n      totalPages: this.totalPages,\n      range: {\n        from: skip + 1,\n        to: Math.min(this.value * this.size, this.total),\n      },\n      skip,\n      take: this.size,\n    };\n    return result;\n  }\n\n  private _emitChangedEvent(u: boolean = false): void {\n    this.totalPages = Math.ceil(this._total / this.size);\n    //\n    this.onChanged.emit(\n      Object.assign(\n        {\n          component: this,\n          isUserInteraction: u,\n          htmlElement: this.getHostElement(),\n        },\n        this.displayInfo,\n      ),\n    );\n    if (this.totalPages > 0) this._parent?.goToPage(this.value);\n    //\n    this.cdr.markForCheck();\n  }\n\n  goNextPage(): void {\n    this.goToPage(Math.min(this.value + 1, this.totalPages));\n  }\n\n  goLastPage(): void {\n    this.goToPage(this.totalPages);\n  }\n\n  goFirstPage(): void {\n    this.goToPage(1);\n  }\n\n  goPrevPage(): void {\n    this.goToPage(Math.max(this.value - 1, 1));\n  }\n\n  goToPage(page: number): void {\n    if (page != this.value) {\n      this.commitValue(page, true);\n    }\n  }\n}\n","@switch(displayMode){\n@case('full'){\n<ax-prefix>\n    <ax-data-pager-numeric-selector>\n    </ax-data-pager-numeric-selector>\n    <ax-data-pager-page-sizes>\n    </ax-data-pager-page-sizes>\n</ax-prefix>\n<ax-suffix>\n    <ax-data-pager-info>\n    </ax-data-pager-info>\n</ax-suffix>\n}\n@case('compact'){\n<ax-prefix>\n    <ax-data-pager-prev-buttons>\n    </ax-data-pager-prev-buttons>\n    <ax-data-pager-input-selector>\n    </ax-data-pager-input-selector>\n    <ax-data-pager-next-buttons>\n    </ax-data-pager-next-buttons>\n</ax-prefix>\n<ax-suffix>\n    <ax-data-pager-info>\n    </ax-data-pager-info>\n</ax-suffix>\n}\n@default{\n<ng-content select=\"ax-prefix\"></ng-content>\n<ng-content select=\"ax-suffix\"></ng-content>\n}\n}"]}
|