@acorex/components 7.24.4 → 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 +12 -35
- 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/drawer/lib/drawer.component.mjs +2 -2
- package/esm2022/menu/lib/menu-item/menu-item.component.mjs +3 -3
- package/esm2022/menu/lib/menu.component.mjs +2 -2
- package/esm2022/otp/lib/otp.component.mjs +2 -2
- package/esm2022/phone-box/lib/phone-box.component.mjs +25 -42
- package/esm2022/phone-box/lib/phone-box.module.mjs +20 -3
- 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 +18 -35
- 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-drawer.mjs +2 -2
- package/fesm2022/acorex-components-drawer.mjs.map +1 -1
- package/fesm2022/acorex-components-menu.mjs +4 -4
- package/fesm2022/acorex-components-menu.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 +45 -44
- 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 +7 -13
- package/phone-box/lib/phone-box.component.d.ts +4 -13
- package/phone-box/lib/phone-box.module.d.ts +2 -1
- 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"]}
|
@@ -70,15 +70,11 @@ export class MXSelectionValueComponent extends MXValueComponent {
|
|
70
70
|
if (value == null || (isArray && value.length == 0)) {
|
71
71
|
return this.multiple ? [] : null;
|
72
72
|
}
|
73
|
-
const normalizedItems = isArray
|
74
|
-
? this.normalizeItemsList(value, true)
|
75
|
-
: this.normalizeItemsList([value], true);
|
73
|
+
const normalizedItems = isArray ? this.normalizeItemsList(value, true) : this.normalizeItemsList([value], true);
|
76
74
|
if (normalizedItems.length == 0) {
|
77
75
|
return this.multiple ? [] : null;
|
78
76
|
}
|
79
|
-
const result = this.multiple
|
80
|
-
? normalizedItems.map((c) => c[this.valueField])
|
81
|
-
: normalizedItems[0][this.valueField];
|
77
|
+
const result = this.multiple ? normalizedItems.map((c) => c[this.valueField]) : normalizedItems[0][this.valueField];
|
82
78
|
return result;
|
83
79
|
}
|
84
80
|
emitOnValueChangedEvent(oldValue, newValue) {
|
@@ -88,9 +84,7 @@ export class MXSelectionValueComponent extends MXValueComponent {
|
|
88
84
|
normalizeItemsList(items, findBykey = false) {
|
89
85
|
if (items == null)
|
90
86
|
return [];
|
91
|
-
return items
|
92
|
-
.filter((c) => c != null)
|
93
|
-
.map((i) => this.normalizeItem(i, findBykey));
|
87
|
+
return items.filter((c) => c != null).map((i) => this.normalizeItem(i, findBykey));
|
94
88
|
}
|
95
89
|
normalizeItem(item, findBykey = false) {
|
96
90
|
const complex = typeof item == 'object';
|
@@ -98,8 +92,7 @@ export class MXSelectionValueComponent extends MXValueComponent {
|
|
98
92
|
const cacheKey = `k-${key}`;
|
99
93
|
const hasText = !complex || item[this.textField] != null;
|
100
94
|
//
|
101
|
-
if (this.dataService.cacheList[cacheKey] &&
|
102
|
-
this.dataService.cacheList[cacheKey][this.textField])
|
95
|
+
if (this.dataService.cacheList[cacheKey] && this.dataService.cacheList[cacheKey][this.textField])
|
103
96
|
return this.dataService.cacheList[cacheKey];
|
104
97
|
//
|
105
98
|
const obj = {};
|
@@ -129,9 +122,7 @@ export class MXSelectionValueComponent extends MXValueComponent {
|
|
129
122
|
});
|
130
123
|
}
|
131
124
|
else if (existsItem) {
|
132
|
-
obj[this.valueField] = complex
|
133
|
-
? existsItem[this.valueField]
|
134
|
-
: existsItem;
|
125
|
+
obj[this.valueField] = complex ? existsItem[this.valueField] : existsItem;
|
135
126
|
}
|
136
127
|
else {
|
137
128
|
obj[this.valueField] = complex ? item[this.valueField] : item;
|
@@ -141,11 +132,7 @@ export class MXSelectionValueComponent extends MXValueComponent {
|
|
141
132
|
return obj;
|
142
133
|
}
|
143
134
|
_normalizeSelectedItems() {
|
144
|
-
const values = Array.isArray(this.value)
|
145
|
-
? this.value
|
146
|
-
: this.value != null
|
147
|
-
? [this.value]
|
148
|
-
: [];
|
135
|
+
const values = Array.isArray(this.value) ? this.value : this.value != null ? [this.value] : [];
|
149
136
|
this.dataService.selectedItems = values.map((v) => this.normalizeItem(v));
|
150
137
|
}
|
151
138
|
unselectItems(...items) {
|
@@ -153,20 +140,14 @@ export class MXSelectionValueComponent extends MXValueComponent {
|
|
153
140
|
this.commitValue([], true);
|
154
141
|
return;
|
155
142
|
}
|
156
|
-
const normalizeItems = Array.isArray(items)
|
157
|
-
? this.normalizeItemsList(items)
|
158
|
-
: [this.normalizeItem(items)];
|
143
|
+
const normalizeItems = Array.isArray(items) ? this.normalizeItemsList(items) : [this.normalizeItem(items)];
|
159
144
|
const newSelectedItems = this.selectedItems.filter((i) => !normalizeItems.some((n) => n[this.valueField] == i[this.valueField]));
|
160
145
|
this.commitValue(newSelectedItems, true);
|
161
146
|
}
|
162
147
|
selectItems(...items) {
|
163
148
|
if (items && items.length) {
|
164
|
-
let newSelectedItems = Array.isArray(this.value)
|
165
|
-
|
166
|
-
: [this.value];
|
167
|
-
const normalizeItems = Array.isArray(items)
|
168
|
-
? this.normalizeItemsList(items)
|
169
|
-
: [this.normalizeItem(items)];
|
149
|
+
let newSelectedItems = Array.isArray(this.value) ? this.value : [this.value];
|
150
|
+
const normalizeItems = Array.isArray(items) ? this.normalizeItemsList(items) : [this.normalizeItem(items)];
|
170
151
|
if (this.multiple) {
|
171
152
|
newSelectedItems = [...newSelectedItems, ...normalizeItems];
|
172
153
|
}
|
@@ -179,9 +160,7 @@ export class MXSelectionValueComponent extends MXValueComponent {
|
|
179
160
|
toggleSelect(...items) {
|
180
161
|
items?.forEach((item) => {
|
181
162
|
if (this.multiple) {
|
182
|
-
this.isItemSelected(item)
|
183
|
-
? this.unselectItems(item)
|
184
|
-
: this.selectItems(item);
|
163
|
+
this.isItemSelected(item) ? this.unselectItems(item) : this.selectItems(item);
|
185
164
|
}
|
186
165
|
else {
|
187
166
|
this.selectItems(item);
|
@@ -194,9 +173,7 @@ export class MXSelectionValueComponent extends MXValueComponent {
|
|
194
173
|
isItemDisabled(item) {
|
195
174
|
return (this.disabled ||
|
196
175
|
coerceBooleanProperty(item[this.disabledField]) === true ||
|
197
|
-
(this.disabledCallback
|
198
|
-
? this.disabledCallback({ item, index: -1 })
|
199
|
-
: false));
|
176
|
+
(this.disabledCallback ? this.disabledCallback({ item, index: -1 }) : false));
|
200
177
|
}
|
201
178
|
getDisplayText(item) {
|
202
179
|
const normalizeItem = this.normalizeItem(item);
|
@@ -216,4 +193,4 @@ export class MXSelectionValueComponent extends MXValueComponent {
|
|
216
193
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.2", ngImport: i0, type: MXSelectionValueComponent, decorators: [{
|
217
194
|
type: Injectable
|
218
195
|
}] });
|
219
|
-
//# 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 =\n  new InjectionToken<MXSelectionBridgeService>('AX_SELECTION_DATA_TOKEN');\n\n@Injectable()\nexport abstract class MXSelectionValueComponent<\n  T = unknown\n> 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\n      ? this.normalizeItemsList(value, true)\n      : this.normalizeItemsList([value], true);\n\n    if (normalizedItems.length == 0) {\n      return this.multiple ? [] : null;\n    }\n    const result = this.multiple\n      ? normalizedItems.map((c) => c[this.valueField])\n      : 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\n      .filter((c) => c != null)\n      .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 (\n      this.dataService.cacheList[cacheKey] &&\n      this.dataService.cacheList[cacheKey][this.textField]\n    )\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\n          ? existsItem[this.valueField]\n          : 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)\n      ? this.value\n      : this.value != null\n      ? [this.value]\n      : [];\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)\n      ? this.normalizeItemsList(items)\n      : [this.normalizeItem(items)];\n    const newSelectedItems = this.selectedItems.filter(\n      (i) =>\n        !normalizeItems.some((n) => n[this.valueField] == i[this.valueField])\n    );\n    this.commitValue(newSelectedItems, true);\n  }\n\n  public selectItems(...items: T[]) {\n    if (items && items.length) {\n      let newSelectedItems = Array.isArray(this.value)\n        ? this.value\n        : [this.value];\n      const normalizeItems = Array.isArray(items)\n        ? this.normalizeItemsList(items)\n        : [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)\n          ? this.unselectItems(item)\n          : this.selectItems(item);\n      } else {\n        this.selectItems(item);\n      }\n    });\n  }\n\n  public isItemSelected(item: T): boolean {\n    return this.selectedItems.some(\n      (c) => c[this.valueField] === this.normalizeItem(item)[this.valueField]\n    );\n  }\n\n  public isItemDisabled(item: T): boolean {\n    return (\n      this.disabled ||\n      coerceBooleanProperty(item[this.disabledField]) === true ||\n      (this.disabledCallback\n        ? this.disabledCallback({ item, index: -1 })\n        : 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"]}
|
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"]}
|