@acorex/components 6.0.7 → 6.0.11
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/button/src/button-item.component.d.ts +1 -1
- package/data-table/src/data-table.component.d.ts +3 -1
- package/dropdown/src/dropdown-panel.component.d.ts +6 -4
- package/esm2020/button/src/button-item.component.mjs +3 -2
- package/esm2020/context-menu/src/context-menu.component.mjs +17 -15
- package/esm2020/data-pager/src/data-pager-pagesize-dropdown.component.mjs +1 -1
- package/esm2020/data-table/src/data-table.component.mjs +11 -4
- package/esm2020/dropdown/src/dropdown-panel.component.mjs +13 -5
- 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/fesm2015/acorex-components-button.mjs +2 -1
- package/fesm2015/acorex-components-button.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-pager.mjs +1 -1
- package/fesm2015/acorex-components-data-pager.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-dropdown.mjs +13 -4
- package/fesm2015/acorex-components-dropdown.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/fesm2020/acorex-components-button.mjs +2 -1
- package/fesm2020/acorex-components-button.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-pager.mjs +1 -1
- package/fesm2020/acorex-components-data-pager.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-dropdown.mjs +12 -4
- package/fesm2020/acorex-components-dropdown.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/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/package.json +9 -1
|
@@ -72,5 +72,5 @@ export declare class AXButtonItemComponent extends AXBaseItemButtonMixin {
|
|
|
72
72
|
private __hostClick;
|
|
73
73
|
private get __hostClass();
|
|
74
74
|
static ɵfac: i0.ɵɵFactoryDeclaration<AXButtonItemComponent, never>;
|
|
75
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<AXButtonItemComponent, "ax-button-item", never, { "text": "text"; "tooltip": "tooltip"; "selected": "selected"; "seperated": "seperated"; "name": "name"; "data": "data"; "color": "color"; }, {}, never, ["ax-prefix", "ax-icon", "ax-suffix"], false>;
|
|
75
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<AXButtonItemComponent, "ax-button-item", never, { "text": "text"; "tooltip": "tooltip"; "selected": "selected"; "seperated": "seperated"; "name": "name"; "data": "data"; "color": "color"; }, { "onClick": "onClick"; }, never, ["ax-prefix", "ax-icon", "ax-suffix"], false>;
|
|
76
76
|
}
|
|
@@ -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,14 +6,16 @@ import { AXPopoverComponent } from '@acorex/components/popover';
|
|
|
6
6
|
import { AXBaseDropdownMixin } from '@acorex/components/mixin';
|
|
7
7
|
import * as i0 from "@angular/core";
|
|
8
8
|
export declare class AXDropdownPanelComponent extends AXBaseDropdownMixin {
|
|
9
|
-
_parent
|
|
10
|
-
constructor(elementRef: ElementRef, cdr: ChangeDetectorRef, _parent
|
|
9
|
+
_parent?: AXButtonComponent;
|
|
10
|
+
constructor(elementRef: ElementRef, cdr: ChangeDetectorRef, _parent?: AXButtonComponent);
|
|
11
11
|
_contentButtons: QueryList<AXButtonItemComponent>;
|
|
12
12
|
onItemClick: EventEmitter<AXButtonClickEvent>;
|
|
13
13
|
popover: AXPopoverComponent;
|
|
14
14
|
_needBorder: boolean;
|
|
15
15
|
_subs: Subscription[];
|
|
16
|
-
_target
|
|
16
|
+
private _target;
|
|
17
|
+
get target(): HTMLElement;
|
|
18
|
+
set target(v: HTMLElement);
|
|
17
19
|
ngAfterContentInit(): void;
|
|
18
20
|
private _initContents;
|
|
19
21
|
private _bindEvents;
|
|
@@ -23,5 +25,5 @@ export declare class AXDropdownPanelComponent extends AXBaseDropdownMixin {
|
|
|
23
25
|
_emitOnItemClickEvent(e: AXClickEvent, item: AXButtonItemComponent): void;
|
|
24
26
|
private _handleOnItemClick;
|
|
25
27
|
static ɵfac: i0.ɵɵFactoryDeclaration<AXDropdownPanelComponent, [null, null, { optional: true; }]>;
|
|
26
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<AXDropdownPanelComponent, "ax-dropdown-panel", never, { "isOpen": "isOpen"; "fitParent": "fitParent"; "dropdownWidth": "dropdownWidth"; "position": "position"; }, { "onOpened": "onOpened"; "onClosed": "onClosed"; "onItemClick": "onItemClick"; }, ["_contentButtons"], ["[panel],ax-button-item"], false>;
|
|
28
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<AXDropdownPanelComponent, "ax-dropdown-panel", never, { "isOpen": "isOpen"; "fitParent": "fitParent"; "dropdownWidth": "dropdownWidth"; "position": "position"; "target": "target"; }, { "onOpened": "onOpened"; "onClosed": "onClosed"; "onItemClick": "onItemClick"; }, ["_contentButtons"], ["[panel],ax-button-item"], false>;
|
|
27
29
|
}
|
|
@@ -32,7 +32,7 @@ export class AXButtonItemComponent extends AXBaseItemButtonMixin {
|
|
|
32
32
|
}
|
|
33
33
|
}
|
|
34
34
|
AXButtonItemComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: AXButtonItemComponent, deps: [{ token: i0.ElementRef }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
35
|
-
AXButtonItemComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.2", type: AXButtonItemComponent, selector: "ax-button-item", inputs: { text: "text", tooltip: "tooltip", selected: "selected", seperated: "seperated", name: "name", data: "data", color: "color" }, host: { listeners: { "click": "__hostClick($event)" }, properties: { "class": "this.__hostClass" }, classAttribute: "ax-button-item" }, usesInheritance: true, ngImport: i0, template: `
|
|
35
|
+
AXButtonItemComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.2", type: AXButtonItemComponent, selector: "ax-button-item", inputs: { text: "text", tooltip: "tooltip", selected: "selected", seperated: "seperated", name: "name", data: "data", color: "color" }, outputs: { onClick: "onClick" }, host: { listeners: { "click": "__hostClick($event)" }, properties: { "class": "this.__hostClass" }, classAttribute: "ax-button-item" }, usesInheritance: true, ngImport: i0, template: `
|
|
36
36
|
<ng-content select="ax-prefix"> </ng-content>
|
|
37
37
|
<ng-content select="ax-icon"> </ng-content>
|
|
38
38
|
<span *ngIf="text">{{ text }}</span>
|
|
@@ -51,6 +51,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.2", ngImpor
|
|
|
51
51
|
host: { class: 'ax-button-item' },
|
|
52
52
|
encapsulation: ViewEncapsulation.None,
|
|
53
53
|
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
54
|
+
outputs: ['onClick'],
|
|
54
55
|
}]
|
|
55
56
|
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { text: [{
|
|
56
57
|
type: Input
|
|
@@ -73,4 +74,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.2", ngImpor
|
|
|
73
74
|
type: HostBinding,
|
|
74
75
|
args: ['class']
|
|
75
76
|
}] } });
|
|
76
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
77
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnV0dG9uLWl0ZW0uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYWNvcmV4L2NvbXBvbmVudHMvYnV0dG9uL3NyYy9idXR0b24taXRlbS5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUNMLHVCQUF1QixFQUV2QixTQUFTLEVBRVQsV0FBVyxFQUNYLFlBQVksRUFDWixLQUFLLEVBQ0wsaUJBQWlCLEdBQ2xCLE1BQU0sZUFBZSxDQUFDO0FBRXZCLE9BQU8sRUFBRSwyQkFBMkIsRUFBRSx5QkFBeUIsRUFBRSxlQUFlLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQzs7O0FBR25ILE1BQU0sQ0FBQyxNQUFNLHFCQUFxQixHQUFHLDJCQUEyQixDQUM5RCx5QkFBeUIsQ0FBQyxlQUFlLENBQUMsQ0FDM0MsQ0FBQztBQWVGLE1BQU0sT0FBTyxxQkFBc0IsU0FBUSxxQkFBcUI7SUFDOUQ7O09BRUc7SUFDSCxZQUFZLFVBQXNCLEVBQUUsR0FBc0I7UUFDeEQsS0FBSyxDQUFDLFVBQVUsRUFBRSxHQUFHLENBQUMsQ0FBQztRQUl6QixTQUFJLEdBQVcsRUFBRSxDQUFDO1FBR2xCLFlBQU8sR0FBVyxFQUFFLENBQUM7UUFHckIsYUFBUSxHQUFZLEtBQUssQ0FBQztRQUcxQixjQUFTLEdBQVksS0FBSyxDQUFDO1FBUzNCLFVBQUssR0FBcUIsT0FBTyxDQUFDO0lBckJsQyxDQUFDO0lBd0JPLFdBQVcsQ0FBQyxDQUFhO1FBQy9CLElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUM1QixDQUFDO0lBRUQsSUFDWSxXQUFXO1FBQ3JCLE1BQU0sVUFBVSxHQUFRO1lBQ3RCLGdCQUFnQixFQUFFLENBQUMsSUFBSSxDQUFDLElBQUk7WUFDNUIsbUJBQW1CLEVBQUUsSUFBSSxDQUFDLFFBQVE7WUFDbEMsbUJBQW1CLEVBQUUsSUFBSSxDQUFDLFFBQVE7U0FDbkMsQ0FBQztRQUNGLFVBQVUsQ0FBQyxNQUFNLElBQUksQ0FBQyxLQUFLLElBQUksU0FBUyxVQUFVLENBQUMsR0FBRyxJQUFJLENBQUM7UUFDM0QsT0FBTyxNQUFNLENBQUMsT0FBTyxDQUFDLFVBQVUsQ0FBQzthQUM5QixNQUFNLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQzthQUNuQixHQUFHLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQzthQUNoQixJQUFJLENBQUMsR0FBRyxDQUFDLENBQUM7SUFDZixDQUFDOztrSEE5Q1UscUJBQXFCO3NHQUFyQixxQkFBcUIsOFhBWHRCOzs7OztHQUtUOzJGQU1VLHFCQUFxQjtrQkFiakMsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsZ0JBQWdCO29CQUMxQixRQUFRLEVBQUU7Ozs7O0dBS1Q7b0JBQ0QsSUFBSSxFQUFFLEVBQUUsS0FBSyxFQUFFLGdCQUFnQixFQUFFO29CQUNqQyxhQUFhLEVBQUUsaUJBQWlCLENBQUMsSUFBSTtvQkFDckMsZUFBZSxFQUFFLHVCQUF1QixDQUFDLE1BQU07b0JBQy9DLE9BQU8sRUFBRSxDQUFDLFNBQVMsQ0FBQztpQkFDckI7aUlBVUMsSUFBSTtzQkFESCxLQUFLO2dCQUlOLE9BQU87c0JBRE4sS0FBSztnQkFJTixRQUFRO3NCQURQLEtBQUs7Z0JBSU4sU0FBUztzQkFEUixLQUFLO2dCQUlOLElBQUk7c0JBREgsS0FBSztnQkFJTixJQUFJO3NCQURILEtBQUs7Z0JBSU4sS0FBSztzQkFESixLQUFLO2dCQUlFLFdBQVc7c0JBRGxCLFlBQVk7dUJBQUMsT0FBTyxFQUFFLENBQUMsUUFBUSxDQUFDO2dCQU1yQixXQUFXO3NCQUR0QixXQUFXO3VCQUFDLE9BQU8iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xyXG4gIENoYW5nZURldGVjdGlvblN0cmF0ZWd5LFxyXG4gIENoYW5nZURldGVjdG9yUmVmLFxyXG4gIENvbXBvbmVudCxcclxuICBFbGVtZW50UmVmLFxyXG4gIEhvc3RCaW5kaW5nLFxyXG4gIEhvc3RMaXN0ZW5lcixcclxuICBJbnB1dCxcclxuICBWaWV3RW5jYXBzdWxhdGlvbixcclxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgQVhTdHlsZUNvbG9yVHlwZSB9IGZyb20gJ0BhY29yZXgvY29tcG9uZW50cy9jb21tb24nO1xyXG5pbXBvcnQgeyBfSW50ZXJhY3RpdmVDb21wb25lbmV0TWl4aW4sIF9DbGlja2FibGVDb21wb25lbmV0TWl4aW4sIEFYQmFzZUNvbXBvbmVudCB9IGZyb20gJ0BhY29yZXgvY29tcG9uZW50cy9taXhpbic7XHJcblxyXG5cclxuZXhwb3J0IGNvbnN0IEFYQmFzZUl0ZW1CdXR0b25NaXhpbiA9IF9JbnRlcmFjdGl2ZUNvbXBvbmVuZXRNaXhpbihcclxuICBfQ2xpY2thYmxlQ29tcG9uZW5ldE1peGluKEFYQmFzZUNvbXBvbmVudClcclxuKTtcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAnYXgtYnV0dG9uLWl0ZW0nLFxyXG4gIHRlbXBsYXRlOiBgXHJcbiAgICA8bmctY29udGVudCBzZWxlY3Q9XCJheC1wcmVmaXhcIj4gPC9uZy1jb250ZW50PlxyXG4gICAgPG5nLWNvbnRlbnQgc2VsZWN0PVwiYXgtaWNvblwiPiA8L25nLWNvbnRlbnQ+XHJcbiAgICA8c3BhbiAqbmdJZj1cInRleHRcIj57eyB0ZXh0IH19PC9zcGFuPlxyXG4gICAgPG5nLWNvbnRlbnQgc2VsZWN0PVwiYXgtc3VmZml4XCI+IDwvbmctY29udGVudD5cclxuICBgLFxyXG4gIGhvc3Q6IHsgY2xhc3M6ICdheC1idXR0b24taXRlbScgfSxcclxuICBlbmNhcHN1bGF0aW9uOiBWaWV3RW5jYXBzdWxhdGlvbi5Ob25lLFxyXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxyXG4gIG91dHB1dHM6IFsnb25DbGljayddLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgQVhCdXR0b25JdGVtQ29tcG9uZW50IGV4dGVuZHMgQVhCYXNlSXRlbUJ1dHRvbk1peGluIHtcclxuICAvKipcclxuICAgKiAgQGlnbm9yZVxyXG4gICAqL1xyXG4gIGNvbnN0cnVjdG9yKGVsZW1lbnRSZWY6IEVsZW1lbnRSZWYsIGNkcjogQ2hhbmdlRGV0ZWN0b3JSZWYpIHtcclxuICAgIHN1cGVyKGVsZW1lbnRSZWYsIGNkcik7XHJcbiAgfVxyXG5cclxuICBASW5wdXQoKVxyXG4gIHRleHQ6IHN0cmluZyA9ICcnO1xyXG5cclxuICBASW5wdXQoKVxyXG4gIHRvb2x0aXA6IHN0cmluZyA9ICcnO1xyXG5cclxuICBASW5wdXQoKVxyXG4gIHNlbGVjdGVkOiBib29sZWFuID0gZmFsc2U7XHJcblxyXG4gIEBJbnB1dCgpXHJcbiAgc2VwZXJhdGVkOiBib29sZWFuID0gZmFsc2U7XHJcblxyXG4gIEBJbnB1dCgpXHJcbiAgbmFtZTogc3RyaW5nO1xyXG5cclxuICBASW5wdXQoKVxyXG4gIGRhdGE6IGFueTtcclxuXHJcbiAgQElucHV0KClcclxuICBjb2xvcjogQVhTdHlsZUNvbG9yVHlwZSA9ICdsaWdodCc7XHJcblxyXG4gIEBIb3N0TGlzdGVuZXIoJ2NsaWNrJywgWyckZXZlbnQnXSlcclxuICBwcml2YXRlIF9faG9zdENsaWNrKGU6IE1vdXNlRXZlbnQpIHtcclxuICAgIHRoaXMuX2VtaXRPbkNsaWNrRXZlbnQoZSk7XHJcbiAgfVxyXG5cclxuICBASG9zdEJpbmRpbmcoJ2NsYXNzJylcclxuICBwcml2YXRlIGdldCBfX2hvc3RDbGFzcygpOiBzdHJpbmcge1xyXG4gICAgY29uc3QgY3NzQ2xhc3NlczogYW55ID0ge1xyXG4gICAgICAnYXgtYnV0dG9uLWljb24nOiAhdGhpcy50ZXh0LFxyXG4gICAgICAnYXgtc3RhdGUtZGlzYWJsZWQnOiB0aGlzLmRpc2FibGVkLFxyXG4gICAgICAnYXgtc3RhdGUtc2VsZWN0ZWQnOiB0aGlzLnNlbGVjdGVkLFxyXG4gICAgfTtcclxuICAgIGNzc0NsYXNzZXNbYGF4LSR7dGhpcy5jb2xvciB8fCAncHJpbWFyeSd9LWRlZmF1bHRgXSA9IHRydWU7XHJcbiAgICByZXR1cm4gT2JqZWN0LmVudHJpZXMoY3NzQ2xhc3NlcylcclxuICAgICAgLmZpbHRlcigoYykgPT4gY1sxXSlcclxuICAgICAgLm1hcCgoYykgPT4gY1swXSlcclxuICAgICAgLmpvaW4oJyAnKTtcclxuICB9XHJcbn1cclxuIl19
|
|
@@ -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>"]}
|
|
@@ -54,7 +54,7 @@ AXDataPagerPageSizesComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "1
|
|
|
54
54
|
</ax-suffix>
|
|
55
55
|
</ax-button>
|
|
56
56
|
<!-- <span >items per page</span> -->
|
|
57
|
-
`, isInline: true, dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "component", type: i2.AXButtonComponent, selector: "ax-button", inputs: ["disabled", "size", "tabIndex", "color", "look", "text", "toggleable", "selected"], outputs: ["onBlur", "onFocus", "onClick", "selectedChange", "toggleableChange", "lookChange", "colorChange"] }, { kind: "component", type: i2.AXButtonItemComponent, selector: "ax-button-item", inputs: ["text", "tooltip", "selected", "seperated", "name", "data", "color"] }, { kind: "component", type: i3.AXDropdownPanelComponent, selector: "ax-dropdown-panel", inputs: ["isOpen", "fitParent", "dropdownWidth", "position"], outputs: ["onOpened", "onClosed", "onItemClick"] }, { kind: "component", type: i4.AXDecoratorSuffixComponent, selector: "ax-suffix" }, { kind: "component", type: i4.AXDecoratorIconComponent, selector: "ax-icon", inputs: ["icon"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
|
|
57
|
+
`, isInline: true, dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "component", type: i2.AXButtonComponent, selector: "ax-button", inputs: ["disabled", "size", "tabIndex", "color", "look", "text", "toggleable", "selected"], outputs: ["onBlur", "onFocus", "onClick", "selectedChange", "toggleableChange", "lookChange", "colorChange"] }, { kind: "component", type: i2.AXButtonItemComponent, selector: "ax-button-item", inputs: ["text", "tooltip", "selected", "seperated", "name", "data", "color"], outputs: ["onClick"] }, { kind: "component", type: i3.AXDropdownPanelComponent, selector: "ax-dropdown-panel", inputs: ["isOpen", "fitParent", "dropdownWidth", "position", "target"], outputs: ["onOpened", "onClosed", "onItemClick"] }, { kind: "component", type: i4.AXDecoratorSuffixComponent, selector: "ax-suffix" }, { kind: "component", type: i4.AXDecoratorIconComponent, selector: "ax-icon", inputs: ["icon"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
|
|
58
58
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: AXDataPagerPageSizesComponent, decorators: [{
|
|
59
59
|
type: Component,
|
|
60
60
|
args: [{
|
|
@@ -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>"]}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Component, ViewEncapsulation, ChangeDetectionStrategy, ContentChildren, EventEmitter, Output, ViewChild, Optional, } from '@angular/core';
|
|
1
|
+
import { Component, ViewEncapsulation, ChangeDetectionStrategy, ContentChildren, EventEmitter, Output, ViewChild, Optional, Input, } from '@angular/core';
|
|
2
2
|
import { AXButtonItemComponent, } from '@acorex/components/button';
|
|
3
3
|
import { AXPopoverComponent } from '@acorex/components/popover';
|
|
4
4
|
import { AXBaseDropdownMixin } from '@acorex/components/mixin';
|
|
@@ -12,7 +12,13 @@ export class AXDropdownPanelComponent extends AXBaseDropdownMixin {
|
|
|
12
12
|
this.onItemClick = new EventEmitter();
|
|
13
13
|
this._needBorder = false;
|
|
14
14
|
this._subs = [];
|
|
15
|
-
this._target = this._parent
|
|
15
|
+
this._target = this._parent?._getHostElement();
|
|
16
|
+
}
|
|
17
|
+
get target() {
|
|
18
|
+
return this._target;
|
|
19
|
+
}
|
|
20
|
+
set target(v) {
|
|
21
|
+
this._target = v;
|
|
16
22
|
}
|
|
17
23
|
ngAfterContentInit() {
|
|
18
24
|
this._initContents();
|
|
@@ -64,10 +70,10 @@ export class AXDropdownPanelComponent extends AXBaseDropdownMixin {
|
|
|
64
70
|
}
|
|
65
71
|
}
|
|
66
72
|
AXDropdownPanelComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: AXDropdownPanelComponent, deps: [{ token: i0.ElementRef }, { token: i0.ChangeDetectorRef }, { token: i1.AXButtonComponent, optional: true }], target: i0.ɵɵFactoryTarget.Component });
|
|
67
|
-
AXDropdownPanelComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.2", type: AXDropdownPanelComponent, selector: "ax-dropdown-panel", inputs: { isOpen: "isOpen", fitParent: "fitParent", dropdownWidth: "dropdownWidth", position: "position" }, outputs: { onOpened: "onOpened", onClosed: "onClosed", onItemClick: "onItemClick" }, host: { classAttribute: "ax-dropdown-panel" }, queries: [{ propertyName: "_contentButtons", predicate: AXButtonItemComponent }], viewQueries: [{ propertyName: "popover", first: true, predicate: AXPopoverComponent, descendants: true, static: true }], usesInheritance: true, ngImport: i0, template: "<ax-popover [target]=\"
|
|
73
|
+
AXDropdownPanelComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.2", type: AXDropdownPanelComponent, selector: "ax-dropdown-panel", inputs: { isOpen: "isOpen", fitParent: "fitParent", dropdownWidth: "dropdownWidth", position: "position", target: "target" }, outputs: { onOpened: "onOpened", onClosed: "onClosed", onItemClick: "onItemClick" }, host: { classAttribute: "ax-dropdown-panel" }, queries: [{ propertyName: "_contentButtons", predicate: AXButtonItemComponent }], viewQueries: [{ propertyName: "popover", first: true, predicate: AXPopoverComponent, descendants: true, static: true }], usesInheritance: true, ngImport: i0, template: "<ax-popover [target]=\"target\" [position]=\"position\" [openTrigger]=\"'toggle'\" [closeTrigger]=\"'clickout'\" [adaptivityEnabled]=\"false\">\r\n <div class=\"ax-overlay-pane\" [class.ax-dropdown-list]=\"_needBorder\" >\r\n <ng-content select=\"[panel],ax-button-item\">\r\n </ng-content>\r\n </div>\r\n</ax-popover>", dependencies: [{ kind: "component", type: i2.AXPopoverComponent, selector: "ax-popover", inputs: ["target", "position", "openTrigger", "closeTrigger", "hasBackdrop", "backdropClass", "adaptivityEnabled"], outputs: ["onOpened", "onClosed"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
|
|
68
74
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: AXDropdownPanelComponent, decorators: [{
|
|
69
75
|
type: Component,
|
|
70
|
-
args: [{ selector: 'ax-dropdown-panel', inputs: ['isOpen', 'fitParent', 'dropdownWidth', 'position'], outputs: ['onOpened', 'onClosed'], host: { class: 'ax-dropdown-panel' }, changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, template: "<ax-popover [target]=\"
|
|
76
|
+
args: [{ selector: 'ax-dropdown-panel', inputs: ['isOpen', 'fitParent', 'dropdownWidth', 'position'], outputs: ['onOpened', 'onClosed'], host: { class: 'ax-dropdown-panel' }, changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, template: "<ax-popover [target]=\"target\" [position]=\"position\" [openTrigger]=\"'toggle'\" [closeTrigger]=\"'clickout'\" [adaptivityEnabled]=\"false\">\r\n <div class=\"ax-overlay-pane\" [class.ax-dropdown-list]=\"_needBorder\" >\r\n <ng-content select=\"[panel],ax-button-item\">\r\n </ng-content>\r\n </div>\r\n</ax-popover>" }]
|
|
71
77
|
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.ChangeDetectorRef }, { type: i1.AXButtonComponent, decorators: [{
|
|
72
78
|
type: Optional
|
|
73
79
|
}] }]; }, propDecorators: { _contentButtons: [{
|
|
@@ -78,5 +84,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.2", ngImpor
|
|
|
78
84
|
}], popover: [{
|
|
79
85
|
type: ViewChild,
|
|
80
86
|
args: [AXPopoverComponent, { static: true }]
|
|
87
|
+
}], target: [{
|
|
88
|
+
type: Input
|
|
81
89
|
}] } });
|
|
82
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
90
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dropdown-panel.component.js","sourceRoot":"","sources":["../../../../../../projects/acorex/components/dropdown/src/dropdown-panel.component.ts","../../../../../../projects/acorex/components/dropdown/src/dropdown-panel.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  ContentChildren,\r\n  QueryList,\r\n  EventEmitter,\r\n  Output,\r\n  ViewChild,\r\n  Optional,\r\n  Input,\r\n} from '@angular/core';\r\nimport { Subscription } from 'rxjs';\r\n\r\nimport { AXButtonClickEvent, AXClickEvent } from '@acorex/components/common';\r\nimport {\r\n  AXButtonComponent,\r\n  AXButtonItemComponent,\r\n} from '@acorex/components/button';\r\nimport { AXPopoverComponent } from '@acorex/components/popover';\r\nimport { AXBaseDropdownMixin } from '@acorex/components/mixin';\r\n\r\n\r\n@Component({\r\n  selector: 'ax-dropdown-panel',\r\n  templateUrl: './dropdown-panel.component.html',\r\n  inputs: ['isOpen', 'fitParent', 'dropdownWidth', 'position'],\r\n  outputs: ['onOpened', 'onClosed'],\r\n  host: { class: 'ax-dropdown-panel' },\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  encapsulation: ViewEncapsulation.None,\r\n})\r\nexport class AXDropdownPanelComponent extends AXBaseDropdownMixin {\r\n  constructor(\r\n    elementRef: ElementRef,\r\n    cdr: ChangeDetectorRef,\r\n    @Optional()\r\n    public _parent?: AXButtonComponent\r\n  ) {\r\n    super(elementRef, cdr);\r\n    this._target = this._parent?._getHostElement();\r\n  }\r\n\r\n  @ContentChildren(AXButtonItemComponent)\r\n  _contentButtons: QueryList<AXButtonItemComponent>;\r\n\r\n  @Output()\r\n  onItemClick: EventEmitter<AXButtonClickEvent> = new EventEmitter<AXButtonClickEvent>();\r\n\r\n  @ViewChild(AXPopoverComponent, { static: true })\r\n  popover: AXPopoverComponent;\r\n\r\n  _needBorder: boolean = false;\r\n  _subs: Subscription[] = [];\r\n\r\n\r\n  private _target: HTMLElement;\r\n  @Input()\r\n  public get target(): HTMLElement {\r\n    return this._target;\r\n  }\r\n  public set target(v: HTMLElement) {\r\n    this._target = v;\r\n  }\r\n\r\n\r\n\r\n  ngAfterContentInit() {\r\n    this._initContents();\r\n    this._contentButtons.changes.subscribe(() => {\r\n      this._initContents();\r\n    });\r\n  }\r\n\r\n  private _initContents() {\r\n    this._needBorder = this._contentButtons.length > 0;\r\n    this._bindEvents();\r\n    this._bindProps();\r\n    this._cdr.markForCheck();\r\n  }\r\n\r\n  private _bindEvents() {\r\n    this._contentButtons?.forEach((b) => {\r\n      if (!b.onClick.length)\r\n        b.onClick.subscribe((c) => {\r\n          this._handleOnItemClick(c);\r\n        });\r\n    });\r\n  }\r\n\r\n  private _bindProps() {\r\n    this._contentButtons?.forEach((b) => {\r\n      //b.look = this.look ?? this.look;\r\n      b.disabled = b.disabled ?? this.disabled;\r\n      //b.toggleable = false;\r\n    });\r\n  }\r\n\r\n  onOptionChanged(options) {\r\n    this._bindProps();\r\n  }\r\n\r\n  onDestroy(): void {\r\n    this._subs.forEach((s) => {\r\n      s?.unsubscribe();\r\n    });\r\n  }\r\n\r\n  _emitOnItemClickEvent(e: AXClickEvent, item: AXButtonItemComponent): void {\r\n    this.onItemClick.emit({\r\n      component: this,\r\n      htmlElement: this._getHostElement(),\r\n      nativeEvent: e.nativeEvent,\r\n      name: item.name,\r\n      data: item.data,\r\n    });\r\n  }\r\n\r\n  private _handleOnItemClick(e: AXClickEvent) {\r\n    this.close();\r\n    this._emitOnItemClickEvent(e, e.component);\r\n  }\r\n}\r\n","<ax-popover [target]=\"target\" [position]=\"position\" [openTrigger]=\"'toggle'\" [closeTrigger]=\"'clickout'\" [adaptivityEnabled]=\"false\">\r\n    <div class=\"ax-overlay-pane\" [class.ax-dropdown-list]=\"_needBorder\" >\r\n        <ng-content select=\"[panel],ax-button-item\">\r\n        </ng-content>\r\n    </div>\r\n</ax-popover>"]}
|
|
@@ -23,6 +23,7 @@ export class AXFormComponent extends AXBaseComponentMixin {
|
|
|
23
23
|
this.onValidate = new EventEmitter();
|
|
24
24
|
this.updateOnChange = new EventEmitter();
|
|
25
25
|
this._updateOn = 'blur';
|
|
26
|
+
this.validateInitValues = false;
|
|
26
27
|
this._subs = [];
|
|
27
28
|
}
|
|
28
29
|
get updateOn() {
|
|
@@ -41,7 +42,9 @@ export class AXFormComponent extends AXBaseComponentMixin {
|
|
|
41
42
|
return Array.from(this._getHostElement().querySelectorAll('[ax-form-input="true"]')).map((c) => c.__axContext__);
|
|
42
43
|
}
|
|
43
44
|
onViewInit() {
|
|
44
|
-
this.
|
|
45
|
+
if (this.validateInitValues) {
|
|
46
|
+
this._validateInitValues();
|
|
47
|
+
}
|
|
45
48
|
this._bindEvents();
|
|
46
49
|
const config = { attributes: false, childList: true, subtree: true };
|
|
47
50
|
const callback = (mutationList, observer) => {
|
|
@@ -127,7 +130,7 @@ export class AXFormComponent extends AXBaseComponentMixin {
|
|
|
127
130
|
}
|
|
128
131
|
}
|
|
129
132
|
AXFormComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: AXFormComponent, deps: [{ token: i0.ElementRef }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
130
|
-
AXFormComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.2", type: AXFormComponent, selector: "ax-form", inputs: { updateOn: "updateOn" }, outputs: { onValidate: "onValidate", updateOnChange: "updateOnChange" }, usesInheritance: true, ngImport: i0, template: '<form ><ng-content></ng-content></form>', isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
|
|
133
|
+
AXFormComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.2", type: AXFormComponent, selector: "ax-form", inputs: { updateOn: "updateOn", validateInitValues: "validateInitValues" }, outputs: { onValidate: "onValidate", updateOnChange: "updateOnChange" }, usesInheritance: true, ngImport: i0, template: '<form ><ng-content></ng-content></form>', isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
|
|
131
134
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: AXFormComponent, decorators: [{
|
|
132
135
|
type: Component,
|
|
133
136
|
args: [{
|
|
@@ -142,5 +145,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.2", ngImpor
|
|
|
142
145
|
type: Output
|
|
143
146
|
}], updateOn: [{
|
|
144
147
|
type: Input
|
|
148
|
+
}], validateInitValues: [{
|
|
149
|
+
type: Input
|
|
145
150
|
}] } });
|
|
146
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form.component.js","sourceRoot":"","sources":["../../../../../../projects/acorex/components/form/src/form.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAqB,SAAS,EAAc,YAAY,EAAE,KAAK,EAAE,MAAM,EAAE,iBAAiB,EAAE,MAAM,eAAe,CAAC;AAClJ,OAAO,EAAE,OAAO,EAAE,MAAM,2BAA2B,CAAC;AAEpD,OAAO,EAAE,oBAAoB,EAAE,MAAM,0BAA0B,CAAC;;AAGhE;;;EAGE;AACF,MAAM,OAAO,qBAAsB,SAAQ,OAAO;CAEjD;AASD;;;;GAIG;AAOH,MAAM,OAAO,eAAgB,SAAQ,oBAAoB;IAgCrD;;MAEE;IACF,YACI,UAAsB,EACd,GAAsB;QAE9B,KAAK,CAAC,UAAU,EAAE,GAAG,CAAC,CAAC;QAFf,QAAG,GAAH,GAAG,CAAmB;QAjClC,eAAU,GAAwC,IAAI,YAAY,EAAyB,CAAC;QAI5F,mBAAc,GAAiC,IAAI,YAAY,EAAkB,CAAC;QAE1E,cAAS,GAAmB,MAAM,CAAC;QAkBnC,UAAK,GAAmB,EAAE,CAAC;IAYnC,CAAC;IA7BD,IACW,QAAQ;QACf,OAAO,IAAI,CAAC,SAAS,CAAC;IAC1B,CAAC;IACD,IAAW,QAAQ,CAAC,CAAiB;QACjC,IAAI,CAAC,UAAU,CAAC;YACZ,IAAI,EAAE,UAAU;YAChB,KAAK,EAAE,CAAC;YACR,aAAa,EAAE,CAAC,QAAS,EAAE,QAAS,EAAE,EAAE;gBACpC,IAAI,CAAC,WAAW,EAAE,CAAC;YACvB,CAAC;SACJ,CAAC,CAAA;IACN,CAAC;IAmBO,eAAe;QACnB,OAAO,KAAK,CAAC,IAAI,CACb,IAAI,CAAC,eAAe,EAAE,CAAC,gBAAgB,CAAC,wBAAwB,CAAC,CACpE,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAE,CAAS,CAAC,aAAa,CAAC,CAAC;IAC3C,CAAC;IAED,UAAU;QACN,IAAI,CAAC,mBAAmB,EAAE,CAAC;QAC3B,IAAI,CAAC,WAAW,EAAE,CAAC;QAEnB,MAAM,MAAM,GAAG,EAAE,UAAU,EAAE,KAAK,EAAE,SAAS,EAAE,IAAI,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC;QACrE,MAAM,QAAQ,GAAG,CAAC,YAAY,EAAE,QAAQ,EAAE,EAAE;YACxC,IAAI,CAAC,WAAW,EAAE,CAAC;QACvB,CAAC,CAAC;QAEF,8DAA8D;QAC9D,IAAI,CAAC,SAAS,GAAG,IAAI,gBAAgB,CAAC,QAAQ,CAAC,CAAC;QAChD,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,IAAI,CAAC,eAAe,EAAE,EAAE,MAAM,CAAC,CAAC;IAC3D,CAAC;IAEO,WAAW;QACf,IAAI,CAAC,UAAU,EAAE,CAAC;QAClB,MAAM,OAAO,GAAG,IAAI,CAAC,eAAe,EAAE,CAAA;QACtC,EAAE;QACF,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE;YAChB,IAAI,IAAI,CAAC,QAAQ,IAAI,QAAQ,EAAE;gBAC3B,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,cAAc,EAAE,SAAS,CAAC,CAAC,CAAC,EAAE;oBAC5C,CAAC,CAAC,QAAQ,EAAE,CAAC;gBACjB,CAAC,CAAC,CAAC,CAAC;aACP;iBACI,IAAI,IAAI,CAAC,QAAQ,IAAI,MAAM,EAAE;gBAC9B,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,MAAM,EAAE,SAAS,CAAC,CAAC,CAAC,EAAE;oBACpC,CAAC,CAAC,QAAQ,EAAE,CAAC;gBACjB,CAAC,CAAC,CAAC,CAAC;aACP;QACL,CAAC,CAAC,CAAA;IACN,CAAC;IAEO,UAAU;QACd,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC,CAAA;QACxC,IAAI,CAAC,KAAK,GAAG,EAAE,CAAC;IACpB,CAAC;IAEO,mBAAmB;QACvB,IAAI,CAAC,eAAe,EAAE;aACjB,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC;aACvB,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,EAAE,CAAC,CAAC;IACpC,CAAC;IAID,QAAQ,CAAC,GAAG,IAAc;QACtB,MAAM,OAAO,GAAG,IAAI,CAAC,eAAe,EAAE,CAAC;QACvC,IAAI,OAAO,CAAC,MAAM,KAAK,CAAC,EAAE;YACtB,IAAI,CAAC,oBAAoB,CAAC,EAAE,MAAM,EAAE,IAAI,EAAE,CAAC,CAAC;YAC5C,OAAO,OAAO,CAAC,OAAO,CAAC,EAAE,MAAM,EAAE,IAAI,EAAE,CAAC,CAAC;SAC5C;QACD,EAAE;QACF,OAAO,IAAI,OAAO,CAAyB,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;YAC3D,OAAO,CAAC,GAAG,CAAC,OAAO;iBACd,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,IAAI,IAAI,IAAI,IAAI,IAAI,CAAC,MAAM,IAAI,CAAC,CAAC,IAAI,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;iBACxE,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,QAAQ,EAAE,CAAC,CAAC;iBACzB,IAAI,CAAC,CAAC,KAAU,EAAE,EAAE;gBACjB,MAAM,MAAM,GAAG,KAAK,CAAC,MAAM,CAAC,CAAC,CAAM,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC;gBACnD,IAAI,MAAM,CAAC,MAAM,EAAE;oBACf,IAAI,CAAC,oBAAoB,CAAC;wBACtB,MAAM,EAAE,KAAK;wBACb,KAAK,EAAE,MAAM;qBAChB,CAAC,CAAC;oBACH,OAAO,CAAC;wBACJ,MAAM,EAAE,KAAK;wBACb,KAAK,EAAE,MAAM;qBAChB,CAAC,CAAC;iBACN;qBACI;oBACD,IAAI,CAAC,oBAAoB,CAAC,EAAE,MAAM,EAAE,IAAI,EAAE,CAAC,CAAC;oBAC5C,OAAO,CAAC,EAAE,MAAM,EAAE,IAAI,EAAE,CAAC,CAAC;iBAC7B;YACL,CAAC,CAAC,CAAC;QACX,CAAC,CAAC,CAAC;IACP,CAAC;IAEO,oBAAoB,CAAC,CAAyB;QAClD,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC;YACjB,SAAS,EAAE,IAAI;YACf,MAAM,EAAE,CAAC;YACT,WAAW,EAAE,IAAI,CAAC,eAAe,EAAE;SACtC,CAAC,CAAA;IACN,CAAC;IAED,KAAK;QACD,MAAM,OAAO,GAAG,IAAI,CAAC,eAAe,EAAE,CAAC;QACvC,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE;YAChB,CAAC,CAAC,KAAK,EAAE,CAAC;QACd,CAAC,CAAC,CAAC;IACP,CAAC;IAED,SAAS;QACL,IAAI,CAAC,SAAS,CAAC,UAAU,EAAE,CAAC;QAC5B,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;QACtB,IAAI,CAAC,UAAU,EAAE,CAAC;IACtB,CAAC;;4GA/IQ,eAAe;gGAAf,eAAe,iLAJd,0CAA0C;2FAI3C,eAAe;kBAN3B,SAAS;mBAAC;oBACP,QAAQ,EAAE,SAAS;oBACnB,QAAQ,EAAE,0CAA0C;oBACpD,aAAa,EAAE,iBAAiB,CAAC,IAAI;oBACrC,eAAe,EAAE,uBAAuB,CAAC,MAAM;iBAClD;iIAKG,UAAU;sBADT,MAAM;gBAKP,cAAc;sBADb,MAAM;gBAKI,QAAQ;sBADlB,KAAK","sourcesContent":["import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, EventEmitter, Input, Output, ViewEncapsulation } from '@angular/core';\r\nimport { AXEvent } from '@acorex/components/common';\r\nimport { AXFormValidationResult } from './validation.class';\r\nimport { AXBaseComponentMixin } from '@acorex/components/mixin';\r\nimport { Subscription } from 'rxjs';\r\n\r\n/**\r\n*  Contains native event\r\n* @category Events\r\n*/\r\nexport class AXFormValidationEvent extends AXEvent {\r\n    result: AXFormValidationResult;\r\n}\r\n\r\n/**\r\n*  Contains native event\r\n* @category Events\r\n*/\r\nexport type AXFormUpdateOn = 'change' | 'blur' | 'manual';\r\n\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-form',\r\n    template: '<form  ><ng-content></ng-content></form>',\r\n    encapsulation: ViewEncapsulation.None,\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class AXFormComponent extends AXBaseComponentMixin {\r\n\r\n\r\n    @Output()\r\n    onValidate: EventEmitter<AXFormValidationEvent> = new EventEmitter<AXFormValidationEvent>();\r\n\r\n\r\n    @Output()\r\n    updateOnChange: EventEmitter<AXFormUpdateOn> = new EventEmitter<AXFormUpdateOn>();\r\n\r\n    private _updateOn: AXFormUpdateOn = 'blur';\r\n    @Input()\r\n    public get updateOn(): AXFormUpdateOn {\r\n        return this._updateOn;\r\n    }\r\n    public set updateOn(v: AXFormUpdateOn) {\r\n        this._setOption({\r\n            name: 'updateOn',\r\n            value: v,\r\n            afterCallback: (oldValue?, newValue?) => {\r\n                this._bindEvents();\r\n            },\r\n        })\r\n    }\r\n\r\n\r\n\r\n    private _observer: MutationObserver;\r\n    private _subs: Subscription[] = [];\r\n\r\n\r\n\r\n    /**\r\n    *  @ignore\r\n    */\r\n    constructor(\r\n        elementRef: ElementRef,\r\n        private cdr: ChangeDetectorRef\r\n    ) {\r\n        super(elementRef, cdr);\r\n    }\r\n\r\n    private _getComponenets() {\r\n        return Array.from(\r\n            this._getHostElement().querySelectorAll('[ax-form-input=\"true\"]')\r\n        ).map((c) => (c as any).__axContext__);\r\n    }\r\n\r\n    onViewInit(): void {\r\n        this._validateInitValues();\r\n        this._bindEvents();\r\n\r\n        const config = { attributes: false, childList: true, subtree: true };\r\n        const callback = (mutationList, observer) => {\r\n            this._bindEvents();\r\n        };\r\n\r\n        // Create an observer instance linked to the callback function\r\n        this._observer = new MutationObserver(callback);\r\n        this._observer.observe(this._getHostElement(), config);\r\n    }\r\n\r\n    private _bindEvents() {\r\n        this._clearSubs();\r\n        const widgets = this._getComponenets()\r\n        //\r\n        widgets.forEach(w => {\r\n            if (this.updateOn == 'change') {\r\n                this._subs.push(w.onValueChanged?.subscribe(v => {\r\n                    w.validate();\r\n                }));\r\n            }\r\n            else if (this.updateOn == 'blur') {\r\n                this._subs.push(w.onBlur?.subscribe(v => {\r\n                    w.validate();\r\n                }));\r\n            }\r\n        })\r\n    }\r\n\r\n    private _clearSubs() {\r\n        this._subs.forEach(c => c.unsubscribe())\r\n        this._subs = [];\r\n    }\r\n\r\n    private _validateInitValues() {\r\n        this._getComponenets()\r\n            .filter(c => c['value'])\r\n            .forEach(c => c.validate());\r\n    }\r\n\r\n\r\n\r\n    validate(...args: string[]): Promise<AXFormValidationResult> {\r\n        const widgets = this._getComponenets();\r\n        if (widgets.length === 0) {\r\n            this._emitOnValidateEvent({ result: true });\r\n            return Promise.resolve({ result: true });\r\n        }\r\n        //\r\n        return new Promise<AXFormValidationResult>((resolve, reject) => {\r\n            Promise.all(widgets\r\n                .filter(c => (args == null || args.length == 0) || args.includes(c.name))\r\n                .map((c) => c.validate()))\r\n                .then((rules: any) => {\r\n                    const failed = rules.filter((c: any) => !c.result);\r\n                    if (failed.length) {\r\n                        this._emitOnValidateEvent({\r\n                            result: false,\r\n                            items: failed\r\n                        });\r\n                        resolve({\r\n                            result: false,\r\n                            items: failed\r\n                        });\r\n                    }\r\n                    else {\r\n                        this._emitOnValidateEvent({ result: true });\r\n                        resolve({ result: true });\r\n                    }\r\n                });\r\n        });\r\n    }\r\n\r\n    private _emitOnValidateEvent(e: AXFormValidationResult) {\r\n        this.onValidate.emit({\r\n            component: this,\r\n            result: e,\r\n            htmlElement: this._getHostElement(),\r\n        })\r\n    }\r\n\r\n    clear() {\r\n        const widgets = this._getComponenets();\r\n        widgets.forEach(w => {\r\n            w.clear();\r\n        });\r\n    }\r\n\r\n    onDestroy(): void {\r\n        this._observer.disconnect();\r\n        this._observer = null;\r\n        this._clearSubs();\r\n    }\r\n}"]}
|
|
151
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form.component.js","sourceRoot":"","sources":["../../../../../../projects/acorex/components/form/src/form.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, EventEmitter, Input, Output, ViewEncapsulation } from '@angular/core';\r\nimport { AXEvent } from '@acorex/components/common';\r\nimport { AXFormValidationResult } from './validation.class';\r\nimport { AXBaseComponentMixin } from '@acorex/components/mixin';\r\nimport { Subscription } from 'rxjs';\r\n\r\n/**\r\n*  Contains native event\r\n* @category Events\r\n*/\r\nexport class AXFormValidationEvent extends AXEvent {\r\n    result: AXFormValidationResult;\r\n}\r\n\r\n/**\r\n*  Contains native event\r\n* @category Events\r\n*/\r\nexport type AXFormUpdateOn = 'change' | 'blur' | 'manual';\r\n\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-form',\r\n    template: '<form  ><ng-content></ng-content></form>',\r\n    encapsulation: ViewEncapsulation.None,\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class AXFormComponent extends AXBaseComponentMixin {\r\n\r\n\r\n    @Output()\r\n    onValidate: EventEmitter<AXFormValidationEvent> = new EventEmitter<AXFormValidationEvent>();\r\n\r\n\r\n    @Output()\r\n    updateOnChange: EventEmitter<AXFormUpdateOn> = new EventEmitter<AXFormUpdateOn>();\r\n\r\n    private _updateOn: AXFormUpdateOn = 'blur';\r\n    @Input()\r\n    public get updateOn(): AXFormUpdateOn {\r\n        return this._updateOn;\r\n    }\r\n    public set updateOn(v: AXFormUpdateOn) {\r\n        this._setOption({\r\n            name: 'updateOn',\r\n            value: v,\r\n            afterCallback: (oldValue?, newValue?) => {\r\n                this._bindEvents();\r\n            },\r\n        })\r\n    }\r\n\r\n    @Input()\r\n    validateInitValues: boolean = false;\r\n\r\n\r\n    private _observer: MutationObserver;\r\n    private _subs: Subscription[] = [];\r\n\r\n\r\n\r\n    /**\r\n    *  @ignore\r\n    */\r\n    constructor(\r\n        elementRef: ElementRef,\r\n        private cdr: ChangeDetectorRef\r\n    ) {\r\n        super(elementRef, cdr);\r\n    }\r\n\r\n    private _getComponenets() {\r\n        return Array.from(\r\n            this._getHostElement().querySelectorAll('[ax-form-input=\"true\"]')\r\n        ).map((c) => (c as any).__axContext__);\r\n    }\r\n\r\n    onViewInit(): void {\r\n        if (this.validateInitValues) {\r\n            this._validateInitValues();\r\n        }\r\n        this._bindEvents();\r\n\r\n        const config = { attributes: false, childList: true, subtree: true };\r\n        const callback = (mutationList, observer) => {\r\n            this._bindEvents();\r\n        };\r\n\r\n        // Create an observer instance linked to the callback function\r\n        this._observer = new MutationObserver(callback);\r\n        this._observer.observe(this._getHostElement(), config);\r\n    }\r\n\r\n    private _bindEvents() {\r\n        this._clearSubs();\r\n        const widgets = this._getComponenets()\r\n        //\r\n        widgets.forEach(w => {\r\n            if (this.updateOn == 'change') {\r\n                this._subs.push(w.onValueChanged?.subscribe(v => {\r\n                    w.validate();\r\n                }));\r\n            }\r\n            else if (this.updateOn == 'blur') {\r\n                this._subs.push(w.onBlur?.subscribe(v => {\r\n                    w.validate();\r\n                }));\r\n            }\r\n        })\r\n    }\r\n\r\n    private _clearSubs() {\r\n        this._subs.forEach(c => c.unsubscribe())\r\n        this._subs = [];\r\n    }\r\n\r\n    private _validateInitValues() {\r\n        this._getComponenets()\r\n            .filter(c => c['value'])\r\n            .forEach(c => c.validate());\r\n    }\r\n\r\n\r\n\r\n    validate(...args: string[]): Promise<AXFormValidationResult> {\r\n        const widgets = this._getComponenets();\r\n        if (widgets.length === 0) {\r\n            this._emitOnValidateEvent({ result: true });\r\n            return Promise.resolve({ result: true });\r\n        }\r\n        //\r\n        return new Promise<AXFormValidationResult>((resolve, reject) => {\r\n            Promise.all(widgets\r\n                .filter(c => (args == null || args.length == 0) || args.includes(c.name))\r\n                .map((c) => c.validate()))\r\n                .then((rules: any) => {\r\n                    const failed = rules.filter((c: any) => !c.result);\r\n                    if (failed.length) {\r\n                        this._emitOnValidateEvent({\r\n                            result: false,\r\n                            items: failed\r\n                        });\r\n                        resolve({\r\n                            result: false,\r\n                            items: failed\r\n                        });\r\n                    }\r\n                    else {\r\n                        this._emitOnValidateEvent({ result: true });\r\n                        resolve({ result: true });\r\n                    }\r\n                });\r\n        });\r\n    }\r\n\r\n    private _emitOnValidateEvent(e: AXFormValidationResult) {\r\n        this.onValidate.emit({\r\n            component: this,\r\n            result: e,\r\n            htmlElement: this._getHostElement(),\r\n        })\r\n    }\r\n\r\n    clear() {\r\n        const widgets = this._getComponenets();\r\n        widgets.forEach(w => {\r\n            w.clear();\r\n        });\r\n    }\r\n\r\n    onDestroy(): void {\r\n        this._observer.disconnect();\r\n        this._observer = null;\r\n        this._clearSubs();\r\n    }\r\n}"]}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Generated bundle index. Do not edit.
|
|
3
|
+
*/
|
|
4
|
+
export * from './public-api';
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWNvcmV4LWNvbXBvbmVudHMtaW1hZ2UtdXBsb2FkZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hY29yZXgvY29tcG9uZW50cy9pbWFnZS11cGxvYWRlci9hY29yZXgtY29tcG9uZW50cy1pbWFnZS11cGxvYWRlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsY0FBYyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBHZW5lcmF0ZWQgYnVuZGxlIGluZGV4LiBEbyBub3QgZWRpdC5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL3B1YmxpYy1hcGknO1xuIl19
|