@acorex/components 6.0.5 → 6.0.10
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/alert/src/alert.component.d.ts +1 -1
- package/badge/src/badge.component.d.ts +1 -1
- package/breadcrumbs/src/breadcrumbs-item.component.d.ts +4 -4
- package/button/src/button-group.component.d.ts +4 -4
- package/button/src/button-item.component.d.ts +4 -4
- package/color-picker/src/color-picker.component.d.ts +14 -14
- package/data-table/src/data-table.component.d.ts +3 -1
- package/date-picker/src/datepicker.component.d.ts +11 -11
- package/esm2020/color-palette/src/color-palette-picker.component.mjs +1 -1
- package/esm2020/context-menu/src/context-menu.component.mjs +17 -15
- package/esm2020/data-table/src/data-table.component.mjs +11 -4
- package/esm2020/form/src/form.component.mjs +8 -3
- package/esm2020/image-uploader/acorex-components-image-uploader.mjs +5 -0
- package/esm2020/image-uploader/public-api.mjs +3 -0
- package/esm2020/image-uploader/src/image-uploader.component.mjs +16 -0
- package/esm2020/image-uploader/src/image-uploader.module.mjs +19 -0
- package/esm2020/menu/src/menu.component.mjs +5 -3
- package/esm2020/mixin/src/datalist-component.class.mjs +1 -1
- package/esm2020/popover/src/popover.component.mjs +2 -2
- package/esm2020/range-slider/src/range-slider.component.mjs +8 -5
- package/fesm2015/acorex-components-color-palette.mjs +1 -1
- package/fesm2015/acorex-components-color-palette.mjs.map +1 -1
- package/fesm2015/acorex-components-context-menu.mjs +16 -14
- package/fesm2015/acorex-components-context-menu.mjs.map +1 -1
- package/fesm2015/acorex-components-data-table.mjs +10 -3
- package/fesm2015/acorex-components-data-table.mjs.map +1 -1
- package/fesm2015/acorex-components-form.mjs +7 -2
- package/fesm2015/acorex-components-form.mjs.map +1 -1
- package/fesm2015/acorex-components-image-uploader.mjs +39 -0
- package/fesm2015/acorex-components-image-uploader.mjs.map +1 -0
- package/fesm2015/acorex-components-menu.mjs +4 -2
- package/fesm2015/acorex-components-menu.mjs.map +1 -1
- package/fesm2015/acorex-components-mixin.mjs.map +1 -1
- package/fesm2015/acorex-components-popover.mjs +1 -1
- package/fesm2015/acorex-components-popover.mjs.map +1 -1
- package/fesm2015/acorex-components-range-slider.mjs +5 -2
- package/fesm2015/acorex-components-range-slider.mjs.map +1 -1
- package/fesm2020/acorex-components-color-palette.mjs +1 -1
- package/fesm2020/acorex-components-color-palette.mjs.map +1 -1
- package/fesm2020/acorex-components-context-menu.mjs +16 -14
- package/fesm2020/acorex-components-context-menu.mjs.map +1 -1
- package/fesm2020/acorex-components-data-table.mjs +10 -3
- package/fesm2020/acorex-components-data-table.mjs.map +1 -1
- package/fesm2020/acorex-components-form.mjs +7 -2
- package/fesm2020/acorex-components-form.mjs.map +1 -1
- package/fesm2020/acorex-components-image-uploader.mjs +39 -0
- package/fesm2020/acorex-components-image-uploader.mjs.map +1 -0
- package/fesm2020/acorex-components-menu.mjs +4 -2
- package/fesm2020/acorex-components-menu.mjs.map +1 -1
- package/fesm2020/acorex-components-mixin.mjs.map +1 -1
- package/fesm2020/acorex-components-popover.mjs +1 -1
- package/fesm2020/acorex-components-popover.mjs.map +1 -1
- package/fesm2020/acorex-components-range-slider.mjs +5 -2
- package/fesm2020/acorex-components-range-slider.mjs.map +1 -1
- package/form/src/form.component.d.ts +2 -1
- package/image-uploader/index.d.ts +5 -0
- package/image-uploader/public-api.d.ts +2 -0
- package/image-uploader/src/image-uploader.component.d.ts +9 -0
- package/image-uploader/src/image-uploader.module.d.ts +8 -0
- package/mixin/src/base-components.class.d.ts +1 -1
- package/mixin/src/base-menu-mixin.class.d.ts +4 -4
- package/mixin/src/button-mixin.class.d.ts +1 -1
- package/mixin/src/clickable-mixin.class.d.ts +1 -1
- package/mixin/src/color-look-mixing.class.d.ts +1 -1
- package/mixin/src/datalist-component.class.d.ts +9 -9
- package/mixin/src/dropdown-mixin.class.d.ts +1 -1
- package/mixin/src/interactive-mixin.class.d.ts +3 -3
- package/mixin/src/loading-mixin.class.d.ts +1 -1
- package/mixin/src/mixin.class.d.ts +42 -42
- package/mixin/src/page-component.class.d.ts +1 -1
- package/mixin/src/selection-component.class.d.ts +1 -1
- package/mixin/src/sizable-mixin.class.d.ts +1 -1
- package/mixin/src/textbox-mixin.class.d.ts +3 -3
- package/mixin/src/value-mixin.class.d.ts +7 -7
- package/package.json +9 -1
- package/range-slider/src/range-slider.component.d.ts +2 -1
- package/tabs/src/tab-item.component.d.ts +1 -1
|
@@ -11,7 +11,7 @@ export declare const AXBaseAlertMixin: (new (...args: any[]) => {
|
|
|
11
11
|
look: import("@acorex/components/common").AXStyleLookType;
|
|
12
12
|
id: string;
|
|
13
13
|
rtl: boolean;
|
|
14
|
-
"__#
|
|
14
|
+
"__#33097@#elementRef": ElementRef<any>;
|
|
15
15
|
_cdr: ChangeDetectorRef;
|
|
16
16
|
_isInited: boolean;
|
|
17
17
|
_isRendered: boolean;
|
|
@@ -10,7 +10,7 @@ export declare const AXBaseBadgeMixin: (new (...args: any[]) => {
|
|
|
10
10
|
look: import("@acorex/components/common").AXStyleLookType;
|
|
11
11
|
id: string;
|
|
12
12
|
rtl: boolean;
|
|
13
|
-
"__#
|
|
13
|
+
"__#33097@#elementRef": ElementRef<any>;
|
|
14
14
|
_cdr: ChangeDetectorRef;
|
|
15
15
|
_isInited: boolean;
|
|
16
16
|
_isRendered: boolean;
|
|
@@ -3,9 +3,9 @@ import { ChangeDetectorRef, ElementRef } from '@angular/core';
|
|
|
3
3
|
import { AXBreadCrumbsComponent } from './breadcrumbs.component';
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
5
|
export declare const AXBaseItemBreadCrumbMixin: (abstract new (...args: any[]) => {
|
|
6
|
-
"__#
|
|
6
|
+
"__#33100@#disabled": boolean;
|
|
7
7
|
disabled: boolean;
|
|
8
|
-
"__#
|
|
8
|
+
"__#33100@#tabIndex": number;
|
|
9
9
|
tabIndex: number;
|
|
10
10
|
onFocus: import("@angular/core").EventEmitter<import("@acorex/components/common").AXFocusEvent>;
|
|
11
11
|
_emitOnFocusEvent(e: FocusEvent): void;
|
|
@@ -15,7 +15,7 @@ export declare const AXBaseItemBreadCrumbMixin: (abstract new (...args: any[]) =
|
|
|
15
15
|
hasFocus(): boolean;
|
|
16
16
|
id: string;
|
|
17
17
|
rtl: boolean;
|
|
18
|
-
"__#
|
|
18
|
+
"__#33097@#elementRef": ElementRef<any>;
|
|
19
19
|
_cdr: ChangeDetectorRef;
|
|
20
20
|
_isInited: boolean;
|
|
21
21
|
_isRendered: boolean;
|
|
@@ -38,7 +38,7 @@ export declare const AXBaseItemBreadCrumbMixin: (abstract new (...args: any[]) =
|
|
|
38
38
|
_emitOnClickEvent(e: MouseEvent): void;
|
|
39
39
|
id: string;
|
|
40
40
|
rtl: boolean;
|
|
41
|
-
"__#
|
|
41
|
+
"__#33097@#elementRef": ElementRef<any>;
|
|
42
42
|
/**
|
|
43
43
|
* @ignore
|
|
44
44
|
*/
|
|
@@ -4,9 +4,9 @@ import { AXClickEvent, AXItemClickEvent, AXSelectionMode, AXSelectionValueChange
|
|
|
4
4
|
import { AXBaseComponent } from '@acorex/components/mixin';
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
6
6
|
export declare const AXBaseButtonGroupMixin: (abstract new (...args: any[]) => {
|
|
7
|
-
"__#
|
|
7
|
+
"__#33100@#disabled": boolean;
|
|
8
8
|
disabled: boolean;
|
|
9
|
-
"__#
|
|
9
|
+
"__#33100@#tabIndex": number;
|
|
10
10
|
tabIndex: number;
|
|
11
11
|
onFocus: EventEmitter<import("@acorex/components/common").AXFocusEvent>;
|
|
12
12
|
_emitOnFocusEvent(e: FocusEvent): void;
|
|
@@ -16,7 +16,7 @@ export declare const AXBaseButtonGroupMixin: (abstract new (...args: any[]) => {
|
|
|
16
16
|
hasFocus(): boolean;
|
|
17
17
|
id: string;
|
|
18
18
|
rtl: boolean;
|
|
19
|
-
"__#
|
|
19
|
+
"__#33097@#elementRef": ElementRef<any>;
|
|
20
20
|
_cdr: ChangeDetectorRef;
|
|
21
21
|
_isInited: boolean;
|
|
22
22
|
_isRendered: boolean;
|
|
@@ -43,7 +43,7 @@ export declare const AXBaseButtonGroupMixin: (abstract new (...args: any[]) => {
|
|
|
43
43
|
look: import("@acorex/components/common").AXStyleLookType;
|
|
44
44
|
id: string;
|
|
45
45
|
rtl: boolean;
|
|
46
|
-
"__#
|
|
46
|
+
"__#33097@#elementRef": ElementRef<any>;
|
|
47
47
|
_cdr: ChangeDetectorRef;
|
|
48
48
|
_isInited: boolean;
|
|
49
49
|
_isRendered: boolean;
|
|
@@ -3,9 +3,9 @@ import { AXStyleColorType } from '@acorex/components/common';
|
|
|
3
3
|
import { AXBaseComponent } from '@acorex/components/mixin';
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
5
|
export declare const AXBaseItemButtonMixin: (abstract new (...args: any[]) => {
|
|
6
|
-
"__#
|
|
6
|
+
"__#33100@#disabled": boolean;
|
|
7
7
|
disabled: boolean;
|
|
8
|
-
"__#
|
|
8
|
+
"__#33100@#tabIndex": number;
|
|
9
9
|
tabIndex: number;
|
|
10
10
|
onFocus: import("@angular/core").EventEmitter<import("@acorex/components/common").AXFocusEvent>;
|
|
11
11
|
_emitOnFocusEvent(e: FocusEvent): void;
|
|
@@ -15,7 +15,7 @@ export declare const AXBaseItemButtonMixin: (abstract new (...args: any[]) => {
|
|
|
15
15
|
hasFocus(): boolean;
|
|
16
16
|
id: string;
|
|
17
17
|
rtl: boolean;
|
|
18
|
-
"__#
|
|
18
|
+
"__#33097@#elementRef": ElementRef<any>;
|
|
19
19
|
_cdr: ChangeDetectorRef;
|
|
20
20
|
_isInited: boolean;
|
|
21
21
|
_isRendered: boolean;
|
|
@@ -38,7 +38,7 @@ export declare const AXBaseItemButtonMixin: (abstract new (...args: any[]) => {
|
|
|
38
38
|
_emitOnClickEvent(e: MouseEvent): void;
|
|
39
39
|
id: string;
|
|
40
40
|
rtl: boolean;
|
|
41
|
-
"__#
|
|
41
|
+
"__#33097@#elementRef": ElementRef<any>;
|
|
42
42
|
_cdr: ChangeDetectorRef;
|
|
43
43
|
_isInited: boolean;
|
|
44
44
|
_isRendered: boolean;
|
|
@@ -6,9 +6,9 @@ import { AXPopoverComponent } from '@acorex/components/popover';
|
|
|
6
6
|
import { AXBaseComponent } from '@acorex/components/mixin';
|
|
7
7
|
import * as i0 from "@angular/core";
|
|
8
8
|
export declare const AXBaseColorPickerMixin: (abstract new (...args: any[]) => {
|
|
9
|
-
"__#
|
|
9
|
+
"__#33100@#disabled": boolean;
|
|
10
10
|
disabled: boolean;
|
|
11
|
-
"__#
|
|
11
|
+
"__#33100@#tabIndex": number;
|
|
12
12
|
tabIndex: number;
|
|
13
13
|
onFocus: import("@angular/core").EventEmitter<import("@acorex/components/common").AXFocusEvent>;
|
|
14
14
|
_emitOnFocusEvent(e: FocusEvent): void;
|
|
@@ -18,7 +18,7 @@ export declare const AXBaseColorPickerMixin: (abstract new (...args: any[]) => {
|
|
|
18
18
|
hasFocus(): boolean;
|
|
19
19
|
id: string;
|
|
20
20
|
rtl: boolean;
|
|
21
|
-
"__#
|
|
21
|
+
"__#33097@#elementRef": ElementRef<any>;
|
|
22
22
|
_cdr: ChangeDetectorRef;
|
|
23
23
|
_isInited: boolean;
|
|
24
24
|
_isRendered: boolean;
|
|
@@ -52,7 +52,7 @@ export declare const AXBaseColorPickerMixin: (abstract new (...args: any[]) => {
|
|
|
52
52
|
readonly isOpen: boolean;
|
|
53
53
|
id: string;
|
|
54
54
|
rtl: boolean;
|
|
55
|
-
"__#
|
|
55
|
+
"__#33097@#elementRef": ElementRef<any>;
|
|
56
56
|
_cdr: ChangeDetectorRef;
|
|
57
57
|
_isInited: boolean;
|
|
58
58
|
_isRendered: boolean;
|
|
@@ -71,17 +71,17 @@ export declare const AXBaseColorPickerMixin: (abstract new (...args: any[]) => {
|
|
|
71
71
|
}) & (new (...args: any[]) => {
|
|
72
72
|
onValueChanged: import("@angular/core").EventEmitter<AXValueChangedEvent<any>>;
|
|
73
73
|
valueChange: import("@angular/core").EventEmitter<any>;
|
|
74
|
-
"__#
|
|
74
|
+
"__#33102@#readonly": boolean;
|
|
75
75
|
readonly: boolean;
|
|
76
|
-
"__#
|
|
76
|
+
"__#33102@#allowNull": boolean;
|
|
77
77
|
allowNull: boolean;
|
|
78
|
-
"__#
|
|
78
|
+
"__#33102@#name": string;
|
|
79
79
|
name: string;
|
|
80
|
-
"__#
|
|
80
|
+
"__#33102@#isUserInteraction": boolean;
|
|
81
81
|
readonly isUserInteraction: boolean;
|
|
82
|
-
"__#
|
|
82
|
+
"__#33102@#value": any;
|
|
83
83
|
value: any;
|
|
84
|
-
"__#
|
|
84
|
+
"__#33102@#state": "error" | "clear" | "success";
|
|
85
85
|
readonly state: "error" | "clear" | "success";
|
|
86
86
|
_emitOnValueChangedEvent(oldValue?: any, newValue?: any): void;
|
|
87
87
|
_internalSetValue(value: any): any;
|
|
@@ -97,7 +97,7 @@ export declare const AXBaseColorPickerMixin: (abstract new (...args: any[]) => {
|
|
|
97
97
|
_setState(state: "error" | "clear" | "success", ...args: any[]): void;
|
|
98
98
|
id: string;
|
|
99
99
|
rtl: boolean;
|
|
100
|
-
"__#
|
|
100
|
+
"__#33097@#elementRef": ElementRef<any>;
|
|
101
101
|
_cdr: ChangeDetectorRef;
|
|
102
102
|
_isInited: boolean;
|
|
103
103
|
_isRendered: boolean;
|
|
@@ -119,8 +119,8 @@ export declare const AXBaseColorPickerMixin: (abstract new (...args: any[]) => {
|
|
|
119
119
|
maxLength: number;
|
|
120
120
|
autoComplete: string;
|
|
121
121
|
debounceTime: number;
|
|
122
|
-
"__#
|
|
123
|
-
"__#
|
|
122
|
+
"__#33101@#valueSubscription": import("rxjs").Subscription;
|
|
123
|
+
"__#33101@#valueSubject": import("rxjs").Subject<unknown>;
|
|
124
124
|
onKeyDown: import("@angular/core").EventEmitter<import("@acorex/components/common").AXHtmlEvent<KeyboardEvent>>;
|
|
125
125
|
onKeyUp: import("@angular/core").EventEmitter<import("@acorex/components/common").AXHtmlEvent<KeyboardEvent>>;
|
|
126
126
|
onKeyPress: import("@angular/core").EventEmitter<import("@acorex/components/common").AXHtmlEvent<KeyboardEvent>>;
|
|
@@ -133,7 +133,7 @@ export declare const AXBaseColorPickerMixin: (abstract new (...args: any[]) => {
|
|
|
133
133
|
onDestroy(): void;
|
|
134
134
|
id: string;
|
|
135
135
|
rtl: boolean;
|
|
136
|
-
"__#
|
|
136
|
+
"__#33097@#elementRef": ElementRef<any>;
|
|
137
137
|
_cdr: ChangeDetectorRef;
|
|
138
138
|
_isInited: boolean;
|
|
139
139
|
_isRendered: boolean;
|
|
@@ -7,6 +7,8 @@ export declare class AXDataTableComponent extends AXBaseComponentMixin implement
|
|
|
7
7
|
_columns: QueryList<AXDataColumnComponent>;
|
|
8
8
|
onPageChanged: EventEmitter<AXValueChangedEvent<number>>;
|
|
9
9
|
rowTemplate?: TemplateRef<any>;
|
|
10
|
+
emptyTemplate?: TemplateRef<any>;
|
|
11
|
+
showHeader: boolean;
|
|
10
12
|
private _pageSize;
|
|
11
13
|
get pageSize(): number;
|
|
12
14
|
set pageSize(v: number);
|
|
@@ -31,5 +33,5 @@ export declare class AXDataTableComponent extends AXBaseComponentMixin implement
|
|
|
31
33
|
refresh(): void;
|
|
32
34
|
goToPage(page: number): void;
|
|
33
35
|
static ɵfac: i0.ɵɵFactoryDeclaration<AXDataTableComponent, never>;
|
|
34
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<AXDataTableComponent, "ax-data-table", never, { "rowTemplate": "rowTemplate"; "pageSize": "pageSize"; "fetchDataMode": "fetchDataMode"; "items": "items"; }, { "onPageChanged": "onPageChanged"; }, ["_columns"], ["ax-header", "ax-footer"], false>;
|
|
36
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<AXDataTableComponent, "ax-data-table", never, { "rowTemplate": "rowTemplate"; "emptyTemplate": "emptyTemplate"; "showHeader": "showHeader"; "pageSize": "pageSize"; "fetchDataMode": "fetchDataMode"; "items": "items"; }, { "onPageChanged": "onPageChanged"; }, ["_columns"], ["ax-header", "ax-footer"], false>;
|
|
35
37
|
}
|
|
@@ -6,9 +6,9 @@ import { AXPopoverComponent } from '@acorex/components/popover';
|
|
|
6
6
|
import { AXComponentOptionChanged } from '@acorex/components/mixin';
|
|
7
7
|
import * as i0 from "@angular/core";
|
|
8
8
|
export declare const AXBaseDatePickerMixin: (abstract new (...args: any[]) => {
|
|
9
|
-
"__#
|
|
9
|
+
"__#33100@#disabled": boolean;
|
|
10
10
|
disabled: boolean;
|
|
11
|
-
"__#
|
|
11
|
+
"__#33100@#tabIndex": number;
|
|
12
12
|
tabIndex: number;
|
|
13
13
|
onFocus: EventEmitter<import("@acorex/components/common").AXFocusEvent>;
|
|
14
14
|
_emitOnFocusEvent(e: FocusEvent): void;
|
|
@@ -18,7 +18,7 @@ export declare const AXBaseDatePickerMixin: (abstract new (...args: any[]) => {
|
|
|
18
18
|
hasFocus(): boolean;
|
|
19
19
|
id: string;
|
|
20
20
|
rtl: boolean;
|
|
21
|
-
"__#
|
|
21
|
+
"__#33097@#elementRef": ElementRef<any>;
|
|
22
22
|
_cdr: ChangeDetectorRef;
|
|
23
23
|
_isInited: boolean;
|
|
24
24
|
_isRendered: boolean;
|
|
@@ -52,7 +52,7 @@ export declare const AXBaseDatePickerMixin: (abstract new (...args: any[]) => {
|
|
|
52
52
|
readonly isOpen: boolean;
|
|
53
53
|
id: string;
|
|
54
54
|
rtl: boolean;
|
|
55
|
-
"__#
|
|
55
|
+
"__#33097@#elementRef": ElementRef<any>;
|
|
56
56
|
_cdr: ChangeDetectorRef;
|
|
57
57
|
_isInited: boolean;
|
|
58
58
|
_isRendered: boolean;
|
|
@@ -71,17 +71,17 @@ export declare const AXBaseDatePickerMixin: (abstract new (...args: any[]) => {
|
|
|
71
71
|
}) & (new (...args: any[]) => {
|
|
72
72
|
onValueChanged: EventEmitter<import("@acorex/components/common").AXValueChangedEvent<any>>;
|
|
73
73
|
valueChange: EventEmitter<any>;
|
|
74
|
-
"__#
|
|
74
|
+
"__#33102@#readonly": boolean;
|
|
75
75
|
readonly: boolean;
|
|
76
|
-
"__#
|
|
76
|
+
"__#33102@#allowNull": boolean;
|
|
77
77
|
allowNull: boolean;
|
|
78
|
-
"__#
|
|
78
|
+
"__#33102@#name": string;
|
|
79
79
|
name: string;
|
|
80
|
-
"__#
|
|
80
|
+
"__#33102@#isUserInteraction": boolean;
|
|
81
81
|
readonly isUserInteraction: boolean;
|
|
82
|
-
"__#
|
|
82
|
+
"__#33102@#value": any;
|
|
83
83
|
value: any;
|
|
84
|
-
"__#
|
|
84
|
+
"__#33102@#state": "error" | "clear" | "success";
|
|
85
85
|
readonly state: "error" | "clear" | "success";
|
|
86
86
|
_emitOnValueChangedEvent(oldValue?: any, newValue?: any): void;
|
|
87
87
|
_internalSetValue(value: any): any;
|
|
@@ -97,7 +97,7 @@ export declare const AXBaseDatePickerMixin: (abstract new (...args: any[]) => {
|
|
|
97
97
|
_setState(state: "error" | "clear" | "success", ...args: any[]): void;
|
|
98
98
|
id: string;
|
|
99
99
|
rtl: boolean;
|
|
100
|
-
"__#
|
|
100
|
+
"__#33097@#elementRef": ElementRef<any>;
|
|
101
101
|
_cdr: ChangeDetectorRef;
|
|
102
102
|
_isInited: boolean;
|
|
103
103
|
_isRendered: boolean;
|
|
@@ -79,7 +79,7 @@ AXColorPalettePickerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "1
|
|
|
79
79
|
provide: AXColorPaletteChildComponent,
|
|
80
80
|
useExisting: AXColorPalettePickerComponent,
|
|
81
81
|
},
|
|
82
|
-
], usesInheritance: true, ngImport: i0, template: "<div class=\"ax-color-picker-overlay\" [style.background-color]=\"_bgColor\">\r\n <div class=\"ax-color-picker-overlay-color\"></div>\r\n <div class=\"ax-color-picker-overlay-gradient\"></div>\r\n <div class=\"ax-color-picker-pointer\"></div>\r\n</div>\r\n<ax-range-slider class=\"ax-color-picker-gradient\" [minValue]=\"0\" [maxValue]=\"99\" [step]=\"1\" [value]=\"_gradient\" \r\n (onValueChanged)=\"_handleGradientChanged($event)\">\r\n</ax-range-slider>\r\n<ax-range-slider class=\"ax-color-picker-transparent\" [minValue]=\"0\" [maxValue]=\"1\" [step]=\"0.01\" [value]=\"_rgba.a\"\r\n (onValueChanged)=\"_handleAlphaChanged($event)\">\r\n</ax-range-slider>", dependencies: [{ kind: "component", type: i1.AXRangeSliderComponent, selector: "ax-range-slider", inputs: ["readonly", "allowNull", "value", "name", "checked", "minValue", "maxValue", "step", "color"], outputs: ["valueChange", "onValueChanged", "colorChange"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
|
|
82
|
+
], usesInheritance: true, ngImport: i0, template: "<div class=\"ax-color-picker-overlay\" [style.background-color]=\"_bgColor\">\r\n <div class=\"ax-color-picker-overlay-color\"></div>\r\n <div class=\"ax-color-picker-overlay-gradient\"></div>\r\n <div class=\"ax-color-picker-pointer\"></div>\r\n</div>\r\n<ax-range-slider class=\"ax-color-picker-gradient\" [minValue]=\"0\" [maxValue]=\"99\" [step]=\"1\" [value]=\"_gradient\" \r\n (onValueChanged)=\"_handleGradientChanged($event)\">\r\n</ax-range-slider>\r\n<ax-range-slider class=\"ax-color-picker-transparent\" [minValue]=\"0\" [maxValue]=\"1\" [step]=\"0.01\" [value]=\"_rgba.a\"\r\n (onValueChanged)=\"_handleAlphaChanged($event)\">\r\n</ax-range-slider>", dependencies: [{ kind: "component", type: i1.AXRangeSliderComponent, selector: "ax-range-slider", inputs: ["readonly", "allowNull", "value", "name", "checked", "minValue", "maxValue", "step", "color", "oriantaion"], outputs: ["valueChange", "onValueChanged", "colorChange"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
|
|
83
83
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: AXColorPalettePickerComponent, decorators: [{
|
|
84
84
|
type: Component,
|
|
85
85
|
args: [{ selector: 'ax-color-palette-picker', host: { class: 'ax-color-palette-picker' }, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, providers: [
|
|
@@ -40,20 +40,22 @@ export class AXContextMenuComponent extends AXBaseMenuMixin {
|
|
|
40
40
|
ngAfterViewInit() {
|
|
41
41
|
super.onViewInit();
|
|
42
42
|
this._templatePortal = new TemplatePortal(this._contextTemplate ? this._contextTemplate : this._menuTmp, this._viewContainerRef);
|
|
43
|
-
this._target
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
43
|
+
if (this._target) {
|
|
44
|
+
this._target.addEventListener('contextmenu', (e) => {
|
|
45
|
+
e.preventDefault();
|
|
46
|
+
const position = {
|
|
47
|
+
getBoundingClientRect: () => ({
|
|
48
|
+
bottom: e.clientY,
|
|
49
|
+
height: 0,
|
|
50
|
+
left: e.clientX,
|
|
51
|
+
right: e.clientX,
|
|
52
|
+
top: e.clientY,
|
|
53
|
+
width: 0,
|
|
54
|
+
}),
|
|
55
|
+
};
|
|
56
|
+
this._openAsOverlay(new ElementRef(position));
|
|
57
|
+
});
|
|
58
|
+
}
|
|
57
59
|
}
|
|
58
60
|
_openAsOverlay(position) {
|
|
59
61
|
this._overlayRef = this._overlay.create({
|
|
@@ -254,4 +256,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.2", ngImpor
|
|
|
254
256
|
}], target: [{
|
|
255
257
|
type: Input
|
|
256
258
|
}] } });
|
|
257
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"context-menu.component.js","sourceRoot":"","sources":["../../../../../../projects/acorex/components/context-menu/src/context-menu.component.ts","../../../../../../projects/acorex/components/context-menu/src/context-menu.component.html"],"names":[],"mappings":"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","sourcesContent":["import { OverlayRef, Overlay } from '@angular/cdk/overlay';\r\n\r\nimport {\r\n  Component,\r\n  ChangeDetectionStrategy,\r\n  ViewEncapsulation,\r\n  OnInit,\r\n  TemplateRef,\r\n  ElementRef,\r\n  ChangeDetectorRef,\r\n  ViewContainerRef,\r\n  ViewChild,\r\n  Input,\r\n} from '@angular/core';\r\nimport { AXBaseComponent, AXBaseMenuMixin } from '@acorex/components/mixin';\r\nimport { TemplatePortal } from '@angular/cdk/portal';\r\nimport { AXPlatform } from '@acorex/core/platform';\r\n\r\n/**\r\n * The Button is a component which detects user interaction and triggers a corresponding event\r\n *\r\n * @category Components\r\n */\r\n@Component({\r\n  selector: 'ax-context-menu',\r\n  templateUrl: './context-menu.component.html',\r\n  inputs: [\r\n    'disabled',\r\n    'textField',\r\n    'valueField',\r\n    'items',\r\n    'parentId',\r\n    'iconField',\r\n    'isOpen',\r\n    'isActive',\r\n    'visibleField',\r\n    'disableField',\r\n    'hasChildField',\r\n    'dividerField',\r\n    'openMode',\r\n    'orientation',\r\n  ],\r\n  outputs: ['onBlur', 'onFocus', 'onMenuItemClick'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  encapsulation: ViewEncapsulation.None,\r\n})\r\nexport class AXContextMenuComponent extends AXBaseMenuMixin implements OnInit {\r\n  @ViewChild('contextTemplate')\r\n  _contextTemplate: TemplateRef<any>;\r\n\r\n  get contextTemplate(): TemplateRef<any> {\r\n    return this._contextTemplate;\r\n  }\r\n\r\n  @ViewChild('menuTmp', { static: true })\r\n  _menuTmp: TemplateRef<any>;\r\n\r\n  private _overlayRef: OverlayRef;\r\n\r\n  private _templatePortal: TemplatePortal;\r\n\r\n  private _target: HTMLElement;\r\n\r\n  @Input()\r\n  public get target(): HTMLElement {\r\n    return this._target;\r\n  }\r\n\r\n  public set target(v: HTMLElement | ElementRef | AXBaseComponent) {\r\n    if (v instanceof HTMLElement) this._target = v;\r\n    else if (v instanceof ElementRef) this._target = v.nativeElement;\r\n    else if (v instanceof AXBaseComponent) this._target = v._getInnerElement();\r\n  }\r\n\r\n  constructor(\r\n    private _elementRef: ElementRef,\r\n    private cdr: ChangeDetectorRef,\r\n    private _overlay: Overlay,\r\n    private _viewContainerRef: ViewContainerRef,\r\n    private _platform: AXPlatform\r\n  ) {\r\n    super(_elementRef, cdr);\r\n  }\r\n\r\n  onInit(): void {\r\n    super.onInit();\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    super.onViewInit();\r\n\r\n    this._templatePortal = new TemplatePortal(\r\n      this._contextTemplate ? this._contextTemplate : this._menuTmp,\r\n      this._viewContainerRef\r\n    );\r\n\r\n    this._target.addEventListener('contextmenu', (e) => {\r\n      e.preventDefault();\r\n      const position = {\r\n        getBoundingClientRect: () => ({\r\n          bottom: e.clientY,\r\n          height: 0,\r\n          left: e.clientX,\r\n          right: e.clientX,\r\n          top: e.clientY,\r\n          width: 0,\r\n        }),\r\n      };\r\n      this._openAsOverlay(new ElementRef(position));\r\n    });\r\n  }\r\n\r\n  private _openAsOverlay(position): void {\r\n    this._overlayRef = this._overlay.create({\r\n      positionStrategy: this._overlay\r\n        .position()\r\n        .flexibleConnectedTo(position)\r\n        .withPositions([\r\n          {\r\n            originX: 'end',\r\n            originY: 'top',\r\n            overlayX: 'start',\r\n            overlayY: 'top',\r\n          },\r\n          {\r\n            originX: 'end',\r\n            originY: 'center',\r\n            overlayX: 'start',\r\n            overlayY: 'top',\r\n          },\r\n          {\r\n            originX: 'end',\r\n            originY: 'bottom',\r\n            overlayX: 'start',\r\n            overlayY: 'top',\r\n          },\r\n          {\r\n            originX: 'end',\r\n            originY: 'top',\r\n            overlayX: 'center',\r\n            overlayY: 'top',\r\n          },\r\n          {\r\n            originX: 'end',\r\n            originY: 'top',\r\n            overlayX: 'end',\r\n            overlayY: 'top',\r\n          },\r\n          {\r\n            originX: 'end',\r\n            originY: 'top',\r\n            overlayX: 'end',\r\n            overlayY: 'center',\r\n          },\r\n          {\r\n            originX: 'end',\r\n            originY: 'top',\r\n            overlayX: 'end',\r\n            overlayY: 'bottom',\r\n          },\r\n          {\r\n            originX: 'start',\r\n            originY: 'top',\r\n            overlayX: 'start',\r\n            overlayY: 'top',\r\n          },\r\n          {\r\n            originX: 'start',\r\n            originY: 'center',\r\n            overlayX: 'start',\r\n            overlayY: 'top',\r\n          },\r\n          {\r\n            originX: 'start',\r\n            originY: 'bottom',\r\n            overlayX: 'start',\r\n            overlayY: 'top',\r\n          },\r\n          {\r\n            originX: 'start',\r\n            originY: 'top',\r\n            overlayX: 'center',\r\n            overlayY: 'top',\r\n          },\r\n          {\r\n            originX: 'start',\r\n            originY: 'top',\r\n            overlayX: 'end',\r\n            overlayY: 'top',\r\n          },\r\n          {\r\n            originX: 'start',\r\n            originY: 'top',\r\n            overlayX: 'end',\r\n            overlayY: 'center',\r\n          },\r\n          {\r\n            originX: 'start',\r\n            originY: 'top',\r\n            overlayX: 'end',\r\n            overlayY: 'bottom',\r\n          },\r\n          {\r\n            originX: 'center',\r\n            originY: 'top',\r\n            overlayX: 'start',\r\n            overlayY: 'top',\r\n          },\r\n          {\r\n            originX: 'center',\r\n            originY: 'center',\r\n            overlayX: 'start',\r\n            overlayY: 'top',\r\n          },\r\n          {\r\n            originX: 'center',\r\n            originY: 'bottom',\r\n            overlayX: 'start',\r\n            overlayY: 'top',\r\n          },\r\n          {\r\n            originX: 'center',\r\n            originY: 'top',\r\n            overlayX: 'center',\r\n            overlayY: 'top',\r\n          },\r\n          {\r\n            originX: 'center',\r\n            originY: 'top',\r\n            overlayX: 'end',\r\n            overlayY: 'top',\r\n          },\r\n          {\r\n            originX: 'center',\r\n            originY: 'top',\r\n            overlayX: 'end',\r\n            overlayY: 'center',\r\n          },\r\n          {\r\n            originX: 'center',\r\n            originY: 'top',\r\n            overlayX: 'end',\r\n            overlayY: 'bottom',\r\n          },\r\n        ])\r\n        .withPush(false),\r\n      disposeOnNavigation: true,\r\n      panelClass: ['ax-animate-fadeIn', 'ax-animate-faster', 'ax-overlay-menu'],\r\n      maxHeight: 'unset',\r\n      hasBackdrop: false,\r\n      backdropClass: ['cdk-overlay-transparent-backdrop'],\r\n    });\r\n    this._overlayRef.attach(this._templatePortal);\r\n    this._overlayRef.outsidePointerEvents().subscribe(() => {\r\n      if (this._overlayRef && this.openMode === 'click') {\r\n        this.close();\r\n      }\r\n    });\r\n\r\n    this._platform.scroll.subscribe(() => {\r\n      if (this._overlayRef) {\r\n        this.close();\r\n      }\r\n    });\r\n\r\n    this._platform.resize.subscribe(() => {\r\n      if (this._overlayRef) {\r\n        this.close();\r\n      }\r\n    });\r\n  }\r\n\r\n  private close() {\r\n    this._overlayRef.detach();\r\n    this.displayItems.forEach((element) => {\r\n      element.isOpen = false;\r\n      element.isActive = false;\r\n    });\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  /***********defultTmp***********/\r\n  onContextMenuClick(e) {\r\n    this.onMenuItemClick.emit(e);\r\n  }\r\n}\r\n","<ng-template #contextTemplateRef>\r\n    <ng-container *ngIf=\"contextTemplate  else menuTmp\">\r\n        <div class=\"ax-context-menu\">\r\n            <ng-container *ngTemplateOutlet=\"contextTemplate\">\r\n            </ng-container>\r\n        </div>\r\n    </ng-container>\r\n</ng-template>\r\n\r\n\r\n<ng-template #menuTmp>\r\n    <ax-menu class=\"ax-context-menu\" orientation=\"vertical\" openMode=\"hover\" [items]='items'\r\n        [disableField]=\"disableField\" [hasChildField]=\"hasChildField\" [textField]=\"textField\" [iconField]=\"iconField\"\r\n        [valueField]=\"valueField\" [dividerField]=\"dividerField\" (onMenuItemClick)='onContextMenuClick($event)'>\r\n    </ax-menu>\r\n</ng-template>"]}
|
|
259
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"context-menu.component.js","sourceRoot":"","sources":["../../../../../../projects/acorex/components/context-menu/src/context-menu.component.ts","../../../../../../projects/acorex/components/context-menu/src/context-menu.component.html"],"names":[],"mappings":"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","sourcesContent":["import { OverlayRef, Overlay } from '@angular/cdk/overlay';\r\n\r\nimport {\r\n  Component,\r\n  ChangeDetectionStrategy,\r\n  ViewEncapsulation,\r\n  OnInit,\r\n  TemplateRef,\r\n  ElementRef,\r\n  ChangeDetectorRef,\r\n  ViewContainerRef,\r\n  ViewChild,\r\n  Input,\r\n} from '@angular/core';\r\nimport { AXBaseComponent, AXBaseMenuMixin } from '@acorex/components/mixin';\r\nimport { TemplatePortal } from '@angular/cdk/portal';\r\nimport { AXPlatform } from '@acorex/core/platform';\r\n\r\n/**\r\n * The Button is a component which detects user interaction and triggers a corresponding event\r\n *\r\n * @category Components\r\n */\r\n@Component({\r\n  selector: 'ax-context-menu',\r\n  templateUrl: './context-menu.component.html',\r\n  inputs: [\r\n    'disabled',\r\n    'textField',\r\n    'valueField',\r\n    'items',\r\n    'parentId',\r\n    'iconField',\r\n    'isOpen',\r\n    'isActive',\r\n    'visibleField',\r\n    'disableField',\r\n    'hasChildField',\r\n    'dividerField',\r\n    'openMode',\r\n    'orientation',\r\n  ],\r\n  outputs: ['onBlur', 'onFocus', 'onMenuItemClick'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  encapsulation: ViewEncapsulation.None,\r\n})\r\nexport class AXContextMenuComponent extends AXBaseMenuMixin implements OnInit {\r\n  @ViewChild('contextTemplate')\r\n  _contextTemplate: TemplateRef<any>;\r\n\r\n  get contextTemplate(): TemplateRef<any> {\r\n    return this._contextTemplate;\r\n  }\r\n\r\n  @ViewChild('menuTmp', { static: true })\r\n  _menuTmp: TemplateRef<any>;\r\n\r\n  private _overlayRef: OverlayRef;\r\n\r\n  private _templatePortal: TemplatePortal;\r\n\r\n  private _target: HTMLElement;\r\n\r\n  @Input()\r\n  public get target(): HTMLElement {\r\n    return this._target;\r\n  }\r\n\r\n  public set target(v: HTMLElement | ElementRef | AXBaseComponent) {\r\n    if (v instanceof HTMLElement) this._target = v;\r\n    else if (v instanceof ElementRef) this._target = v.nativeElement;\r\n    else if (v instanceof AXBaseComponent) this._target = v._getInnerElement();\r\n  }\r\n\r\n  constructor(\r\n    private _elementRef: ElementRef,\r\n    private cdr: ChangeDetectorRef,\r\n    private _overlay: Overlay,\r\n    private _viewContainerRef: ViewContainerRef,\r\n    private _platform: AXPlatform\r\n  ) {\r\n    super(_elementRef, cdr);\r\n  }\r\n\r\n  onInit(): void {\r\n    super.onInit();\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    super.onViewInit();\r\n\r\n    this._templatePortal = new TemplatePortal(\r\n      this._contextTemplate ? this._contextTemplate : this._menuTmp,\r\n      this._viewContainerRef\r\n    );\r\n\r\n    if (this._target) {\r\n      this._target.addEventListener('contextmenu', (e) => {\r\n        e.preventDefault();\r\n        const position = {\r\n          getBoundingClientRect: () => ({\r\n            bottom: e.clientY,\r\n            height: 0,\r\n            left: e.clientX,\r\n            right: e.clientX,\r\n            top: e.clientY,\r\n            width: 0,\r\n          }),\r\n        };\r\n        this._openAsOverlay(new ElementRef(position));\r\n      });\r\n    }\r\n  }\r\n\r\n  private _openAsOverlay(position): void {\r\n    this._overlayRef = this._overlay.create({\r\n      positionStrategy: this._overlay\r\n        .position()\r\n        .flexibleConnectedTo(position)\r\n        .withPositions([\r\n          {\r\n            originX: 'end',\r\n            originY: 'top',\r\n            overlayX: 'start',\r\n            overlayY: 'top',\r\n          },\r\n          {\r\n            originX: 'end',\r\n            originY: 'center',\r\n            overlayX: 'start',\r\n            overlayY: 'top',\r\n          },\r\n          {\r\n            originX: 'end',\r\n            originY: 'bottom',\r\n            overlayX: 'start',\r\n            overlayY: 'top',\r\n          },\r\n          {\r\n            originX: 'end',\r\n            originY: 'top',\r\n            overlayX: 'center',\r\n            overlayY: 'top',\r\n          },\r\n          {\r\n            originX: 'end',\r\n            originY: 'top',\r\n            overlayX: 'end',\r\n            overlayY: 'top',\r\n          },\r\n          {\r\n            originX: 'end',\r\n            originY: 'top',\r\n            overlayX: 'end',\r\n            overlayY: 'center',\r\n          },\r\n          {\r\n            originX: 'end',\r\n            originY: 'top',\r\n            overlayX: 'end',\r\n            overlayY: 'bottom',\r\n          },\r\n          {\r\n            originX: 'start',\r\n            originY: 'top',\r\n            overlayX: 'start',\r\n            overlayY: 'top',\r\n          },\r\n          {\r\n            originX: 'start',\r\n            originY: 'center',\r\n            overlayX: 'start',\r\n            overlayY: 'top',\r\n          },\r\n          {\r\n            originX: 'start',\r\n            originY: 'bottom',\r\n            overlayX: 'start',\r\n            overlayY: 'top',\r\n          },\r\n          {\r\n            originX: 'start',\r\n            originY: 'top',\r\n            overlayX: 'center',\r\n            overlayY: 'top',\r\n          },\r\n          {\r\n            originX: 'start',\r\n            originY: 'top',\r\n            overlayX: 'end',\r\n            overlayY: 'top',\r\n          },\r\n          {\r\n            originX: 'start',\r\n            originY: 'top',\r\n            overlayX: 'end',\r\n            overlayY: 'center',\r\n          },\r\n          {\r\n            originX: 'start',\r\n            originY: 'top',\r\n            overlayX: 'end',\r\n            overlayY: 'bottom',\r\n          },\r\n          {\r\n            originX: 'center',\r\n            originY: 'top',\r\n            overlayX: 'start',\r\n            overlayY: 'top',\r\n          },\r\n          {\r\n            originX: 'center',\r\n            originY: 'center',\r\n            overlayX: 'start',\r\n            overlayY: 'top',\r\n          },\r\n          {\r\n            originX: 'center',\r\n            originY: 'bottom',\r\n            overlayX: 'start',\r\n            overlayY: 'top',\r\n          },\r\n          {\r\n            originX: 'center',\r\n            originY: 'top',\r\n            overlayX: 'center',\r\n            overlayY: 'top',\r\n          },\r\n          {\r\n            originX: 'center',\r\n            originY: 'top',\r\n            overlayX: 'end',\r\n            overlayY: 'top',\r\n          },\r\n          {\r\n            originX: 'center',\r\n            originY: 'top',\r\n            overlayX: 'end',\r\n            overlayY: 'center',\r\n          },\r\n          {\r\n            originX: 'center',\r\n            originY: 'top',\r\n            overlayX: 'end',\r\n            overlayY: 'bottom',\r\n          },\r\n        ])\r\n        .withPush(false),\r\n      disposeOnNavigation: true,\r\n      panelClass: ['ax-animate-fadeIn', 'ax-animate-faster', 'ax-overlay-menu'],\r\n      maxHeight: 'unset',\r\n      hasBackdrop: false,\r\n      backdropClass: ['cdk-overlay-transparent-backdrop'],\r\n    });\r\n    this._overlayRef.attach(this._templatePortal);\r\n    this._overlayRef.outsidePointerEvents().subscribe(() => {\r\n      if (this._overlayRef && this.openMode === 'click') {\r\n        this.close();\r\n      }\r\n    });\r\n\r\n    this._platform.scroll.subscribe(() => {\r\n      if (this._overlayRef) {\r\n        this.close();\r\n      }\r\n    });\r\n\r\n    this._platform.resize.subscribe(() => {\r\n      if (this._overlayRef) {\r\n        this.close();\r\n      }\r\n    });\r\n  }\r\n\r\n  private close() {\r\n    this._overlayRef.detach();\r\n    this.displayItems.forEach((element) => {\r\n      element.isOpen = false;\r\n      element.isActive = false;\r\n    });\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  /***********defultTmp***********/\r\n  onContextMenuClick(e) {\r\n    this.onMenuItemClick.emit(e);\r\n  }\r\n}\r\n","<ng-template #contextTemplateRef>\r\n    <ng-container *ngIf=\"contextTemplate  else menuTmp\">\r\n        <div class=\"ax-context-menu\">\r\n            <ng-container *ngTemplateOutlet=\"contextTemplate\">\r\n            </ng-container>\r\n        </div>\r\n    </ng-container>\r\n</ng-template>\r\n\r\n\r\n<ng-template #menuTmp>\r\n    <ax-menu class=\"ax-context-menu\" orientation=\"vertical\" openMode=\"hover\" [items]='items'\r\n        [disableField]=\"disableField\" [hasChildField]=\"hasChildField\" [textField]=\"textField\" [iconField]=\"iconField\"\r\n        [valueField]=\"valueField\" [dividerField]=\"dividerField\" (onMenuItemClick)='onContextMenuClick($event)'>\r\n    </ax-menu>\r\n</ng-template>"]}
|
|
@@ -12,6 +12,7 @@ export class AXDataTableComponent extends AXBaseComponentMixin {
|
|
|
12
12
|
super(elementRef, cdr);
|
|
13
13
|
this._columns = {};
|
|
14
14
|
this.onPageChanged = new EventEmitter();
|
|
15
|
+
this.showHeader = true;
|
|
15
16
|
this._pageSize = 20;
|
|
16
17
|
this.fetchDataMode = 'auto';
|
|
17
18
|
this._currentPage = 1;
|
|
@@ -101,18 +102,20 @@ export class AXDataTableComponent extends AXBaseComponentMixin {
|
|
|
101
102
|
}
|
|
102
103
|
}
|
|
103
104
|
refresh() {
|
|
105
|
+
this._totalItems = 0;
|
|
106
|
+
this._loadedItems = [];
|
|
104
107
|
this._fetchData();
|
|
105
108
|
}
|
|
106
109
|
goToPage(page) {
|
|
107
110
|
this._currentPage = page;
|
|
108
|
-
this.
|
|
111
|
+
this._fetchData();
|
|
109
112
|
}
|
|
110
113
|
}
|
|
111
114
|
AXDataTableComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: AXDataTableComponent, deps: [{ token: i0.ElementRef }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
112
|
-
AXDataTableComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.2", type: AXDataTableComponent, selector: "ax-data-table", inputs: { rowTemplate: "rowTemplate", pageSize: "pageSize", fetchDataMode: "fetchDataMode", items: "items" }, outputs: { onPageChanged: "onPageChanged" }, host: { classAttribute: "ax-data-table" }, providers: [{ provide: AXPagedComponent, useExisting: AXDataTableComponent }], queries: [{ propertyName: "_columns", predicate: AXDataColumnComponent }], usesInheritance: true, ngImport: i0, template: "<ng-content select=\"ax-header\">\r\n</ng-content>\r\n<div class=\"ax-wrapper\">\r\n
|
|
115
|
+
AXDataTableComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.2", type: AXDataTableComponent, selector: "ax-data-table", inputs: { rowTemplate: "rowTemplate", emptyTemplate: "emptyTemplate", showHeader: "showHeader", pageSize: "pageSize", fetchDataMode: "fetchDataMode", items: "items" }, outputs: { onPageChanged: "onPageChanged" }, host: { classAttribute: "ax-data-table" }, providers: [{ provide: AXPagedComponent, useExisting: AXDataTableComponent }], queries: [{ propertyName: "_columns", predicate: AXDataColumnComponent }], usesInheritance: true, ngImport: i0, template: "<ng-content select=\"ax-header\">\r\n</ng-content>\r\n<div class=\"ax-wrapper\">\r\n<table class=\"ax-table ax-table-bordered\" tabindex=\"0\" [axIsLoading]=\"_isLoading\">\r\n <thead *ngIf=\"showHeader\">\r\n <tr>\r\n <th *ngFor=\"let c of _columns\">\r\n <ng-template [ngIf]=\"c.headerTemplate\" [ngIfElse]=\"captionTpl\">\r\n <ng-container *ngTemplateOutlet=\"c.headerTemplate\"></ng-container>\r\n </ng-template>\r\n <ng-template #captionTpl>\r\n {{c.caption}}\r\n </ng-template>\r\n </th>\r\n </tr>\r\n </thead>\r\n <tbody>\r\n <ng-container *ngIf=\"displayItems.length; else emptyTpl\">\r\n <ng-container *ngFor=\"let d of displayItems;let rIndex=index\">\r\n <ng-template [ngIf]=\"rowTemplate\" [ngIfElse]=\"rowTpl\">\r\n <ng-container *ngTemplateOutlet=\"rowTemplate;context: { $implicit: {data:d,rowIndex:rIndex} }\">\r\n </ng-container>\r\n </ng-template>\r\n <ng-template #rowTpl>\r\n <tr>\r\n <ng-container *ngFor=\"let c of _columns\">\r\n <ng-template [ngIf]=\"c.cellTemplate\" [ngIfElse]=\"cellTpl\">\r\n <ng-container *ngTemplateOutlet=\"c.cellTemplate;context: { $implicit: {data:d,rowIndex:rIndex} }\">\r\n </ng-container>\r\n </ng-template>\r\n <ng-template #cellTpl>\r\n <td [attr.data-label]=\"c.caption\" tabindex=\"0\">\r\n {{d[c.valueField]}}\r\n </td>\r\n </ng-template>\r\n </ng-container>\r\n </tr>\r\n </ng-template>\r\n </ng-container>\r\n </ng-container>\r\n <ng-template #emptyTpl>\r\n <tr>\r\n <td [attr.colspan]=\"_columns.length\">\r\n <ng-template [ngIf]=\"emptyTemplate\" [ngIfElse]=\"defaultEmptyTemplate\">\r\n <ng-container *ngTemplateOutlet=\"emptyTemplate\"></ng-container>\r\n </ng-template>\r\n <ng-template #defaultEmptyTemplate>\r\n <ax-result type=\"empty\" caption=\" {{'common.no-result-found' | trans }}\"></ax-result>\r\n </ng-template>\r\n </td>\r\n </tr>\r\n </ng-template>\r\n </tbody>\r\n </table>\r\n</div>\r\n<ng-content select=\"ax-footer\">\r\n</ng-content>", dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i2.AXResultComponent, selector: "ax-result", inputs: ["type", "caption", "description"] }, { kind: "directive", type: i3.AXLoadingDirective, selector: "[axIsLoading]", inputs: ["axIsLoading"] }, { kind: "pipe", type: i4.AXTranslatorPipe, name: "trans" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
|
|
113
116
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: AXDataTableComponent, decorators: [{
|
|
114
117
|
type: Component,
|
|
115
|
-
args: [{ selector: 'ax-data-table', host: { class: 'ax-data-table' }, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, providers: [{ provide: AXPagedComponent, useExisting: AXDataTableComponent }], template: "<ng-content select=\"ax-header\">\r\n</ng-content>\r\n<div class=\"ax-wrapper\">\r\n
|
|
118
|
+
args: [{ selector: 'ax-data-table', host: { class: 'ax-data-table' }, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, providers: [{ provide: AXPagedComponent, useExisting: AXDataTableComponent }], template: "<ng-content select=\"ax-header\">\r\n</ng-content>\r\n<div class=\"ax-wrapper\">\r\n<table class=\"ax-table ax-table-bordered\" tabindex=\"0\" [axIsLoading]=\"_isLoading\">\r\n <thead *ngIf=\"showHeader\">\r\n <tr>\r\n <th *ngFor=\"let c of _columns\">\r\n <ng-template [ngIf]=\"c.headerTemplate\" [ngIfElse]=\"captionTpl\">\r\n <ng-container *ngTemplateOutlet=\"c.headerTemplate\"></ng-container>\r\n </ng-template>\r\n <ng-template #captionTpl>\r\n {{c.caption}}\r\n </ng-template>\r\n </th>\r\n </tr>\r\n </thead>\r\n <tbody>\r\n <ng-container *ngIf=\"displayItems.length; else emptyTpl\">\r\n <ng-container *ngFor=\"let d of displayItems;let rIndex=index\">\r\n <ng-template [ngIf]=\"rowTemplate\" [ngIfElse]=\"rowTpl\">\r\n <ng-container *ngTemplateOutlet=\"rowTemplate;context: { $implicit: {data:d,rowIndex:rIndex} }\">\r\n </ng-container>\r\n </ng-template>\r\n <ng-template #rowTpl>\r\n <tr>\r\n <ng-container *ngFor=\"let c of _columns\">\r\n <ng-template [ngIf]=\"c.cellTemplate\" [ngIfElse]=\"cellTpl\">\r\n <ng-container *ngTemplateOutlet=\"c.cellTemplate;context: { $implicit: {data:d,rowIndex:rIndex} }\">\r\n </ng-container>\r\n </ng-template>\r\n <ng-template #cellTpl>\r\n <td [attr.data-label]=\"c.caption\" tabindex=\"0\">\r\n {{d[c.valueField]}}\r\n </td>\r\n </ng-template>\r\n </ng-container>\r\n </tr>\r\n </ng-template>\r\n </ng-container>\r\n </ng-container>\r\n <ng-template #emptyTpl>\r\n <tr>\r\n <td [attr.colspan]=\"_columns.length\">\r\n <ng-template [ngIf]=\"emptyTemplate\" [ngIfElse]=\"defaultEmptyTemplate\">\r\n <ng-container *ngTemplateOutlet=\"emptyTemplate\"></ng-container>\r\n </ng-template>\r\n <ng-template #defaultEmptyTemplate>\r\n <ax-result type=\"empty\" caption=\" {{'common.no-result-found' | trans }}\"></ax-result>\r\n </ng-template>\r\n </td>\r\n </tr>\r\n </ng-template>\r\n </tbody>\r\n </table>\r\n</div>\r\n<ng-content select=\"ax-footer\">\r\n</ng-content>" }]
|
|
116
119
|
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { _columns: [{
|
|
117
120
|
type: ContentChildren,
|
|
118
121
|
args: [AXDataColumnComponent]
|
|
@@ -120,6 +123,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.2", ngImpor
|
|
|
120
123
|
type: Output
|
|
121
124
|
}], rowTemplate: [{
|
|
122
125
|
type: Input
|
|
126
|
+
}], emptyTemplate: [{
|
|
127
|
+
type: Input
|
|
128
|
+
}], showHeader: [{
|
|
129
|
+
type: Input
|
|
123
130
|
}], pageSize: [{
|
|
124
131
|
type: Input
|
|
125
132
|
}], fetchDataMode: [{
|
|
@@ -127,4 +134,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.2", ngImpor
|
|
|
127
134
|
}], items: [{
|
|
128
135
|
type: Input
|
|
129
136
|
}] } });
|
|
130
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-table.component.js","sourceRoot":"","sources":["../../../../../../projects/acorex/components/data-table/src/data-table.component.ts","../../../../../../projects/acorex/components/data-table/src/data-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  ViewEncapsulation,\r\n  ChangeDetectionStrategy,\r\n  ElementRef,\r\n  ChangeDetectorRef,\r\n  Input,\r\n  ContentChildren,\r\n  QueryList,\r\n  TemplateRef,\r\n  EventEmitter,\r\n  Output,\r\n} from '@angular/core';\r\nimport {\r\n  AXPagedComponent,\r\n  AXPagedComponentInterface,\r\n  AXValueChangedEvent,\r\n} from '@acorex/components/common';\r\n\r\nimport { AXDataColumnComponent } from './data-column.directive';\r\nimport { AXBaseComponentMixin, AXDataListFetchDataCallback, AXDataListItems } from '@acorex/components/mixin';\r\n\r\n\r\n@Component({\r\n  selector: 'ax-data-table',\r\n  templateUrl: './data-table.component.html',\r\n  host: { class: 'ax-data-table' },\r\n  encapsulation: ViewEncapsulation.None,\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  providers: [{ provide: AXPagedComponent, useExisting: AXDataTableComponent }],\r\n})\r\nexport class AXDataTableComponent\r\n  extends AXBaseComponentMixin\r\n  implements AXPagedComponentInterface\r\n{\r\n  @ContentChildren(AXDataColumnComponent)\r\n  _columns: QueryList<AXDataColumnComponent> = {} as QueryList<AXDataColumnComponent>;\r\n\r\n  @Output()\r\n  onPageChanged: EventEmitter<AXValueChangedEvent<number>> = new EventEmitter<\r\n    AXValueChangedEvent<number>\r\n  >();\r\n\r\n  @Input()\r\n  rowTemplate?: TemplateRef<any>;\r\n\r\n  private _pageSize: number = 20;\r\n  @Input()\r\n  public get pageSize(): number {\r\n    return this._pageSize;\r\n  }\r\n  public set pageSize(v: number) {\r\n    this._pageSize = v;\r\n  }\r\n\r\n  @Input()\r\n  fetchDataMode: 'auto' | 'manual' = 'auto';\r\n\r\n  private _currentPage: number = 1;\r\n  _isLoading: boolean = false;\r\n  private _loadedItems: any[] = [];\r\n  private _totalItems: number = 0;\r\n\r\n  private _isLazy: boolean = false;\r\n\r\n  get totalCount(): number {\r\n    return this._totalItems;\r\n  }\r\n\r\n  get isLazy(): boolean {\r\n    return this._isLazy;\r\n  }\r\n\r\n  get loadedCount(): number {\r\n    return this._loadedItems?.length || 0;\r\n  }\r\n\r\n  private _items: AXDataListItems = [];\r\n\r\n  @Input()\r\n  get items(): AXDataListItems {\r\n    return this._items;\r\n  }\r\n  set items(v: AXDataListItems) {\r\n    if (Array.isArray(v)) {\r\n      this._items = v;\r\n    } else if (typeof v === 'function') {\r\n      this._isLazy = true;\r\n      this._items = v;\r\n    } else {\r\n      this._items = [];\r\n    }\r\n  }\r\n\r\n  get displayItems(): any[] {\r\n    if (Array.isArray(this.items)) {\r\n      return (this._items || []) as any[];\r\n    } else if (typeof this._items == 'function') {\r\n      return this._loadedItems || [];\r\n    }\r\n    return [];\r\n  }\r\n\r\n  constructor(elementRef: ElementRef, cdr: ChangeDetectorRef) {\r\n    super(elementRef, cdr);\r\n  }\r\n\r\n  onViewInit(): void {\r\n    if (this.fetchDataMode == 'auto') this._fetchData();\r\n  }\r\n\r\n  _fetchData(opts?: { searchQuery?: string }) {\r\n    const skip = (this._currentPage - 1) * this.pageSize,\r\n      take = this.pageSize;\r\n    if (\r\n      (this.loadedCount >= this.totalCount && this.totalCount != 0) ||\r\n      this._isLoading ||\r\n      !this._isLazy ||\r\n      skip > this.totalCount\r\n    ) {\r\n      return;\r\n    }\r\n    if (this._items) {\r\n      this._isLoading = true;\r\n      this._cdr.markForCheck();\r\n      const fetchFn = this._items as AXDataListFetchDataCallback;\r\n      fetchFn({ skip, take, searchQuery: opts?.searchQuery })\r\n        .then((c) => {\r\n          if (Array.isArray(c)) {\r\n            this._loadedItems = c;\r\n            this._totalItems = c.length;\r\n          } else {\r\n            this._totalItems = c.total || c.items?.length || 0;\r\n            //this._loadedItems = [...new Set(this._loadedItems.concat(c.items))];\r\n            this._loadedItems = [...new Set(c.items)];\r\n          }\r\n        })\r\n        .finally(() => {\r\n          this._isLoading = false;\r\n          this.onPageChanged.next({\r\n            component: this,\r\n            isUserInteraction: false,\r\n            name: 'page',\r\n            value: this._currentPage,\r\n          });\r\n          this._cdr.markForCheck();\r\n        });\r\n    }\r\n  }\r\n\r\n  refresh() {\r\n    this._fetchData();\r\n  }\r\n\r\n  goToPage(page: number) {\r\n    this._currentPage = page;\r\n    this.refresh();\r\n  }\r\n}\r\n","<ng-content select=\"ax-header\">\r\n</ng-content>\r\n<div class=\"ax-wrapper\">\r\n  <table class=\"ax-table ax-table-bordered\" tabindex=\"0\" [axIsLoading]=\"_isLoading\">\r\n    <thead>\r\n     \r\n      <tr>\r\n        <th *ngFor=\"let c of _columns\">\r\n          <ng-template [ngIf]=\"c.headerTemplate\" [ngIfElse]=\"captionTpl\">\r\n            <ng-container *ngTemplateOutlet=\"c.headerTemplate\"></ng-container>\r\n          </ng-template>\r\n          <ng-template #captionTpl>\r\n            {{c.caption}}\r\n          </ng-template>\r\n        </th>\r\n      </tr>\r\n    </thead>\r\n    <tbody>\r\n      <ng-container *ngIf=\"displayItems.length; else emptyTpl\">\r\n        <ng-container *ngFor=\"let d of displayItems;let rIndex=index\">\r\n          <ng-template [ngIf]=\"rowTemplate\" [ngIfElse]=\"rowTpl\">\r\n            <ng-container *ngTemplateOutlet=\"rowTemplate;context: { $implicit: {data:d,rowIndex:rIndex} }\">\r\n            </ng-container>\r\n          </ng-template>\r\n          <ng-template #rowTpl>\r\n            <tr>\r\n              <ng-container *ngFor=\"let c of _columns\">\r\n                <ng-template [ngIf]=\"c.cellTemplate\" [ngIfElse]=\"cellTpl\">\r\n                  <ng-container *ngTemplateOutlet=\"c.cellTemplate;context: { $implicit: {data:d,rowIndex:rIndex} }\">\r\n                  </ng-container>\r\n                </ng-template>\r\n                <ng-template #cellTpl>\r\n                  <td [attr.data-label]=\"c.caption\" tabindex=\"0\">\r\n                    {{d[c.valueField]}}\r\n                  </td>\r\n                </ng-template>\r\n              </ng-container>\r\n            </tr>\r\n          </ng-template>\r\n        </ng-container>\r\n      </ng-container>\r\n      <ng-template #emptyTpl>\r\n        <tr>\r\n          <td [attr.colspan]=\"_columns.length\">\r\n            <ax-result type=\"empty\" caption=\" {{'common.no-result-found' | trans }}\"></ax-result>\r\n          </td>\r\n        </tr>\r\n      </ng-template>\r\n    </tbody>\r\n  </table>\r\n</div>\r\n<ng-content select=\"ax-footer\">\r\n</ng-content>\r\n\r\n<!-- <br>\r\n<table class=\"ax-table ax-table-responsive  ax-table-alternate\">\r\n    <thead>\r\n      <col>\r\n      <colgroup span=\"2\"></colgroup>\r\n      <colgroup span=\"2\"></colgroup>\r\n      <tr>\r\n        <th rowspan=\"2\">Index</th>\r\n        <th colspan=\"2\" scope=\"colgroup\">Mars</th>\r\n        <th colspan=\"2\" scope=\"colgroup\">Venus</th>\r\n      </tr>\r\n      <tr>\r\n        <th scope=\"col\">Produced</th>\r\n        <th scope=\"col\">Sold</th>\r\n        <th scope=\"col\">Produced</th>\r\n        <th scope=\"col\">Sold</th>\r\n      </tr>\r\n    </thead>\r\n    <tbody>\r\n      <tr>\r\n        <td >Teddy Bears</td>\r\n        <td>50,000</td>\r\n        <td>30,000</td>\r\n        <td>100,000</td>\r\n        <td>80,000</td>\r\n      </tr>\r\n      <tr>\r\n        <td >Board Games</td>\r\n        <td>10,000</td>\r\n        <td>5,000</td>\r\n        <td>12,000</td>\r\n        <td>9,000</td>\r\n      </tr>\r\n    </tbody>\r\n  </table> -->"]}
|
|
137
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-table.component.js","sourceRoot":"","sources":["../../../../../../projects/acorex/components/data-table/src/data-table.component.ts","../../../../../../projects/acorex/components/data-table/src/data-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  ViewEncapsulation,\r\n  ChangeDetectionStrategy,\r\n  ElementRef,\r\n  ChangeDetectorRef,\r\n  Input,\r\n  ContentChildren,\r\n  QueryList,\r\n  TemplateRef,\r\n  EventEmitter,\r\n  Output,\r\n} from '@angular/core';\r\nimport {\r\n  AXPagedComponent,\r\n  AXPagedComponentInterface,\r\n  AXValueChangedEvent,\r\n} from '@acorex/components/common';\r\n\r\nimport { AXDataColumnComponent } from './data-column.directive';\r\nimport { AXBaseComponentMixin, AXDataListFetchDataCallback, AXDataListItems } from '@acorex/components/mixin';\r\n\r\n\r\n@Component({\r\n  selector: 'ax-data-table',\r\n  templateUrl: './data-table.component.html',\r\n  host: { class: 'ax-data-table' },\r\n  encapsulation: ViewEncapsulation.None,\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  providers: [{ provide: AXPagedComponent, useExisting: AXDataTableComponent }],\r\n})\r\nexport class AXDataTableComponent extends AXBaseComponentMixin implements AXPagedComponentInterface {\r\n  @ContentChildren(AXDataColumnComponent)\r\n  _columns: QueryList<AXDataColumnComponent> = {} as QueryList<AXDataColumnComponent>;\r\n\r\n  @Output()\r\n  onPageChanged: EventEmitter<AXValueChangedEvent<number>> = new EventEmitter<AXValueChangedEvent<number>>();\r\n\r\n  @Input()\r\n  rowTemplate?: TemplateRef<any>;\r\n\r\n  @Input()\r\n  emptyTemplate?: TemplateRef<any>;\r\n\r\n  @Input()\r\n  showHeader: boolean = true;\r\n\r\n  private _pageSize: number = 20;\r\n  @Input()\r\n  public get pageSize(): number {\r\n    return this._pageSize;\r\n  }\r\n  public set pageSize(v: number) {\r\n    this._pageSize = v;\r\n  }\r\n\r\n  @Input()\r\n  fetchDataMode: 'auto' | 'manual' = 'auto';\r\n\r\n  private _currentPage: number = 1;\r\n  _isLoading: boolean = false;\r\n  private _loadedItems: any[] = [];\r\n  private _totalItems: number = 0;\r\n\r\n  private _isLazy: boolean = false;\r\n\r\n  get totalCount(): number {\r\n    return this._totalItems;\r\n  }\r\n\r\n  get isLazy(): boolean {\r\n    return this._isLazy;\r\n  }\r\n\r\n  get loadedCount(): number {\r\n    return this._loadedItems?.length || 0;\r\n  }\r\n\r\n  private _items: AXDataListItems = [];\r\n\r\n  @Input()\r\n  get items(): AXDataListItems {\r\n    return this._items;\r\n  }\r\n  set items(v: AXDataListItems) {\r\n    if (Array.isArray(v)) {\r\n      this._items = v;\r\n    } else if (typeof v === 'function') {\r\n      this._isLazy = true;\r\n      this._items = v;\r\n    } else {\r\n      this._items = [];\r\n    }\r\n  }\r\n\r\n  get displayItems(): any[] {\r\n    if (Array.isArray(this.items)) {\r\n      return (this._items || []) as any[];\r\n    } else if (typeof this._items == 'function') {\r\n      return this._loadedItems || [];\r\n    }\r\n    return [];\r\n  }\r\n\r\n  constructor(elementRef: ElementRef, cdr: ChangeDetectorRef) {\r\n    super(elementRef, cdr);\r\n  }\r\n\r\n  onViewInit(): void {\r\n    if (this.fetchDataMode == 'auto') this._fetchData();\r\n  }\r\n\r\n  _fetchData(opts?: { searchQuery?: string }) {\r\n    const skip = (this._currentPage - 1) * this.pageSize, take = this.pageSize;\r\n    if (\r\n      (this.loadedCount >= this.totalCount && this.totalCount != 0) ||\r\n      this._isLoading ||\r\n      !this._isLazy ||\r\n      skip > this.totalCount\r\n    ) {\r\n      return;\r\n    }\r\n    if (this._items) {\r\n      this._isLoading = true;\r\n      this._cdr.markForCheck();\r\n      const fetchFn = this._items as AXDataListFetchDataCallback;\r\n      fetchFn({ skip, take, searchQuery: opts?.searchQuery })\r\n        .then((c) => {\r\n          if (Array.isArray(c)) {\r\n            this._loadedItems = c;\r\n            this._totalItems = c.length;\r\n          } else {\r\n            this._totalItems = c.total || c.items?.length || 0;\r\n            //this._loadedItems = [...new Set(this._loadedItems.concat(c.items))];\r\n            this._loadedItems = [...new Set(c.items)];\r\n          }\r\n        })\r\n        .finally(() => {\r\n          this._isLoading = false;\r\n          this.onPageChanged.next({\r\n            component: this,\r\n            isUserInteraction: false,\r\n            name: 'page',\r\n            value: this._currentPage,\r\n          });\r\n          this._cdr.markForCheck();\r\n        });\r\n    }\r\n  }\r\n\r\n  refresh() {\r\n    this._totalItems = 0;\r\n    this._loadedItems = [];\r\n    this._fetchData();\r\n  }\r\n\r\n  goToPage(page: number) {\r\n    this._currentPage = page;\r\n    this._fetchData();\r\n  }\r\n\r\n}\r\n","<ng-content select=\"ax-header\">\r\n</ng-content>\r\n<div class=\"ax-wrapper\">\r\n<table class=\"ax-table ax-table-bordered\" tabindex=\"0\" [axIsLoading]=\"_isLoading\">\r\n    <thead *ngIf=\"showHeader\">\r\n      <tr>\r\n        <th *ngFor=\"let c of _columns\">\r\n          <ng-template [ngIf]=\"c.headerTemplate\" [ngIfElse]=\"captionTpl\">\r\n            <ng-container *ngTemplateOutlet=\"c.headerTemplate\"></ng-container>\r\n          </ng-template>\r\n          <ng-template #captionTpl>\r\n            {{c.caption}}\r\n          </ng-template>\r\n        </th>\r\n      </tr>\r\n    </thead>\r\n    <tbody>\r\n      <ng-container *ngIf=\"displayItems.length; else emptyTpl\">\r\n        <ng-container *ngFor=\"let d of displayItems;let rIndex=index\">\r\n          <ng-template [ngIf]=\"rowTemplate\" [ngIfElse]=\"rowTpl\">\r\n            <ng-container *ngTemplateOutlet=\"rowTemplate;context: { $implicit: {data:d,rowIndex:rIndex} }\">\r\n            </ng-container>\r\n          </ng-template>\r\n          <ng-template #rowTpl>\r\n            <tr>\r\n              <ng-container *ngFor=\"let c of _columns\">\r\n                <ng-template [ngIf]=\"c.cellTemplate\" [ngIfElse]=\"cellTpl\">\r\n                  <ng-container *ngTemplateOutlet=\"c.cellTemplate;context: { $implicit: {data:d,rowIndex:rIndex} }\">\r\n                  </ng-container>\r\n                </ng-template>\r\n                <ng-template #cellTpl>\r\n                  <td [attr.data-label]=\"c.caption\" tabindex=\"0\">\r\n                    {{d[c.valueField]}}\r\n                  </td>\r\n                </ng-template>\r\n              </ng-container>\r\n            </tr>\r\n          </ng-template>\r\n        </ng-container>\r\n      </ng-container>\r\n      <ng-template #emptyTpl>\r\n        <tr>\r\n          <td [attr.colspan]=\"_columns.length\">\r\n            <ng-template [ngIf]=\"emptyTemplate\" [ngIfElse]=\"defaultEmptyTemplate\">\r\n              <ng-container *ngTemplateOutlet=\"emptyTemplate\"></ng-container>\r\n            </ng-template>\r\n            <ng-template #defaultEmptyTemplate>\r\n              <ax-result type=\"empty\" caption=\" {{'common.no-result-found' | trans }}\"></ax-result>\r\n            </ng-template>\r\n          </td>\r\n        </tr>\r\n      </ng-template>\r\n    </tbody>\r\n  </table>\r\n</div>\r\n<ng-content select=\"ax-footer\">\r\n</ng-content>"]}
|