@acorex/components 5.1.1 → 5.1.2
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/esm2020/lib/base/mixin/base-menu-mixin.class.mjs +135 -0
- package/esm2020/lib/base/mixin/mixin.class.mjs +4 -3
- package/esm2020/lib/calendar/calendar.component.mjs +9 -3
- package/esm2020/lib/datepicker/datepicker.component.mjs +6 -6
- package/esm2020/lib/menu/menu.component.mjs +39 -27
- package/esm2020/lib/menu/menu.module.mjs +6 -4
- package/esm2020/lib/tabs/tab-item.component.mjs +7 -4
- package/esm2020/lib/tabs/tabs.component.mjs +4 -3
- package/fesm2015/acorex-components.mjs +193 -43
- package/fesm2015/acorex-components.mjs.map +1 -1
- package/fesm2020/acorex-components.mjs +191 -41
- package/fesm2020/acorex-components.mjs.map +1 -1
- package/lib/base/mixin/base-menu-mixin.class.d.ts +51 -0
- package/lib/base/mixin/datalist-component.class.d.ts +8 -8
- package/lib/base/mixin/interactive-mixin.class.d.ts +2 -2
- package/lib/base/mixin/mixin.class.d.ts +72 -26
- package/lib/base/mixin/value-mixin.class.d.ts +8 -8
- package/lib/button/button-item.component.d.ts +2 -2
- package/lib/datepicker/datepicker.component.d.ts +11 -10
- package/lib/menu/menu.component.d.ts +9 -12
- package/lib/menu/menu.module.d.ts +3 -1
- package/lib/tabs/tab-item.component.d.ts +1 -1
- package/lib/tabs/tabs.component.d.ts +1 -0
- package/package.json +1 -1
|
@@ -1,36 +1,52 @@
|
|
|
1
|
-
import { Component, ViewEncapsulation, ChangeDetectionStrategy,
|
|
2
|
-
import {
|
|
1
|
+
import { Component, ViewEncapsulation, ChangeDetectionStrategy, } from '@angular/core';
|
|
2
|
+
import { AXBaseMenuMixin } from '../base';
|
|
3
|
+
import { BASEMENU_INPUTS } from '../base/mixin/base-menu-mixin.class';
|
|
4
|
+
import { INTERACTIVE_INPUTS, INTERACTIVE_OUTPUT, } from '../base/mixin/interactive-mixin.class';
|
|
3
5
|
import * as i0 from "@angular/core";
|
|
4
6
|
import * as i1 from "../icon/icon.component";
|
|
5
|
-
import * as i2 from "
|
|
7
|
+
import * as i2 from "../loading/loading.component";
|
|
8
|
+
import * as i3 from "@angular/common";
|
|
9
|
+
import * as i4 from "@acorex/core";
|
|
6
10
|
/**
|
|
7
11
|
* The Button is a component which detects user interaction and triggers a corresponding event
|
|
8
12
|
*
|
|
9
13
|
* @category Components
|
|
10
14
|
*/
|
|
11
|
-
export class AXMenuComponent extends
|
|
12
|
-
/**
|
|
13
|
-
* @ignore
|
|
14
|
-
*/
|
|
15
|
+
export class AXMenuComponent extends AXBaseMenuMixin {
|
|
15
16
|
constructor(elementRef, cdr) {
|
|
16
17
|
super(elementRef, cdr);
|
|
17
18
|
this.elementRef = elementRef;
|
|
18
19
|
this.cdr = cdr;
|
|
19
|
-
|
|
20
|
-
|
|
20
|
+
}
|
|
21
|
+
onInit() {
|
|
22
|
+
super.onInit();
|
|
23
|
+
this._fetchData();
|
|
24
|
+
}
|
|
25
|
+
ngAfterViewInit() {
|
|
26
|
+
super.onViewInit();
|
|
21
27
|
}
|
|
22
28
|
onMenuClick(e, item) {
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
29
|
+
if (!item[this.disableField]) {
|
|
30
|
+
this.notActive(this.displayItems);
|
|
31
|
+
if (item.children?.length > 0 || item[this.hasChildField]) {
|
|
32
|
+
if (item.children?.length > 0 && item[this.hasChildField]) {
|
|
33
|
+
item.children = [];
|
|
34
|
+
}
|
|
35
|
+
if (item.children?.length > 0) {
|
|
36
|
+
this.closeChild(item.children);
|
|
37
|
+
}
|
|
38
|
+
item.isOpen = !item.isOpen;
|
|
39
|
+
}
|
|
40
|
+
item.isActive = !item.isActive;
|
|
41
|
+
this.onMenuItemClick.emit({
|
|
42
|
+
component: this,
|
|
43
|
+
item: item,
|
|
44
|
+
nativeEvent: e,
|
|
45
|
+
});
|
|
46
|
+
if (item.isOpen && item[this.hasChildField]) {
|
|
47
|
+
this._fetchData(item.id);
|
|
48
|
+
}
|
|
26
49
|
}
|
|
27
|
-
item.isActive = !item.isActive;
|
|
28
|
-
item.isOpen = !item.isOpen;
|
|
29
|
-
this.onMenuItemClick.emit({
|
|
30
|
-
component: this,
|
|
31
|
-
item: item,
|
|
32
|
-
nativeEvent: e,
|
|
33
|
-
});
|
|
34
50
|
e.stopPropagation();
|
|
35
51
|
e.preventDefault();
|
|
36
52
|
}
|
|
@@ -52,13 +68,9 @@ export class AXMenuComponent extends AXBaseComponentMixin {
|
|
|
52
68
|
}
|
|
53
69
|
}
|
|
54
70
|
AXMenuComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: AXMenuComponent, deps: [{ token: i0.ElementRef }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
55
|
-
AXMenuComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.2", type: AXMenuComponent, selector: "ax-menu", inputs: { items: "items" }, outputs: {
|
|
71
|
+
AXMenuComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.2", type: AXMenuComponent, selector: "ax-menu", inputs: { disabled: "disabled", tabIndex: "tabIndex", textField: "textField", valueField: "valueField", items: "items", id: "id", parentId: "parentId", icon: "icon", tooltip: "tooltip", isOpen: "isOpen", isActive: "isActive", visible: "visible", disableField: "disableField", hasChildField: "hasChildField", openMode: "openMode" }, outputs: { onBlur: "onBlur", onFocus: "onFocus" }, host: { classAttribute: "ax-menu" }, usesInheritance: true, ngImport: i0, template: "<ul>\r\n <ng-container *ngTemplateOutlet=\"recursiveListTmpl; context:{ list: displayItems }\"></ng-container>\r\n</ul>\r\n\r\n<ng-template #recursiveListTmpl let-list=\"list\">\r\n <ng-container *ngFor=\"let item of list; trackBy: _trackLoaded\">\r\n <li [class.ax-state-disabled]=\"item[disableField]\" *ngIf=\"item.visible !=false\" (click)=\"onMenuClick($event,item)\">\r\n <a [ngClass]=\"{'active': item.isActive}\">\r\n <div class=\"ax-menu-start-side\">\r\n <ax-icon [class]=\"item.icon || item[icon]\" *ngIf=\"item.icon || item[icon]\"></ax-icon>\r\n <span>{{_getItemDisplayTextTemplte(item)}}</span>\r\n </div>\r\n <div class=\"ax-menu-end-side\">\r\n <ax-icon [ngClass]=\"{'active-icon': item.isOpen}\"\r\n *ngIf=\"item?.children?.length > 0 && !isLoading || item[hasChildField] && !isLoading\" class=\"ax-ic-chevron\">\r\n </ax-icon>\r\n </div>\r\n\r\n <ax-loading *ngIf=\"isLoading && item.isActive && item.isOpen\">\r\n </ax-loading>\r\n </a>\r\n <ul [class.ax-state-disabled]=\"item[disableField]\" *ngIf=\"item?.children?.length > 0 && item.isOpen\">\r\n <ng-container *ngTemplateOutlet=\"recursiveListTmpl; context:{ list: item.children }\"></ng-container>\r\n </ul>\r\n </li>\r\n </ng-container>\r\n</ng-template>\r\n<ng-container *ngIf=\"isLoading\">\r\n <ng-template>\r\n <div class=\"ax-flex ax-items-center ax-justify-center ax-p-4\">\r\n <ax-loading text=\"{{ 'layout.loading.text' | trans }}\"></ax-loading>\r\n </div>\r\n </ng-template>\r\n</ng-container>", components: [{ type: i1.AXIconComponent, selector: "ax-icon", inputs: ["icon"] }, { type: i2.AXLoadingComponent, selector: "ax-loading", inputs: ["visible", "type", "text"], outputs: ["visibleChange"] }], directives: [{ type: i3.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }], pipes: { "trans": i4.AXTranslatorPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
|
|
56
72
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: AXMenuComponent, decorators: [{
|
|
57
73
|
type: Component,
|
|
58
|
-
args: [{ selector: 'ax-menu', changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, host: { class:
|
|
59
|
-
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.ChangeDetectorRef }]; }
|
|
60
|
-
|
|
61
|
-
}], onMenuItemClick: [{
|
|
62
|
-
type: Output
|
|
63
|
-
}] } });
|
|
64
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWVudS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hY29yZXgvY29tcG9uZW50cy9zcmMvbGliL21lbnUvbWVudS5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hY29yZXgvY29tcG9uZW50cy9zcmMvbGliL21lbnUvbWVudS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0wsU0FBUyxFQUNULGlCQUFpQixFQUNqQix1QkFBdUIsRUFHdkIsS0FBSyxFQUNMLE1BQU0sRUFDTixZQUFZLEdBQ2IsTUFBTSxlQUFlLENBQUE7QUFDdEIsT0FBTyxFQUFFLG9CQUFvQixFQUE2QixNQUFNLFNBQVMsQ0FBQTs7OztBQW1CekU7Ozs7R0FJRztBQVFILE1BQU0sT0FBTyxlQUFnQixTQUFRLG9CQUFvQjtJQUNwRDs7S0FFQztJQUNKLFlBQW9CLFVBQXNCLEVBQVUsR0FBc0I7UUFDeEUsS0FBSyxDQUFDLFVBQVUsRUFBRSxHQUFHLENBQUMsQ0FBQTtRQURKLGVBQVUsR0FBVixVQUFVLENBQVk7UUFBVSxRQUFHLEdBQUgsR0FBRyxDQUFtQjtRQVExRSxvQkFBZSxHQUVYLElBQUksWUFBWSxFQUFpQyxDQUFBO1FBUm5ELGVBQWU7SUFDakIsQ0FBQztJQVNELFdBQVcsQ0FBQyxDQUFhLEVBQUUsSUFBaUI7UUFDMUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDM0IsSUFBSSxJQUFJLENBQUMsUUFBUSxFQUFFLE1BQU0sR0FBRyxDQUFDLEVBQUU7WUFDN0IsSUFBSSxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLENBQUE7U0FDL0I7UUFFRCxJQUFJLENBQUMsUUFBUSxHQUFHLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQTtRQUM5QixJQUFJLENBQUMsTUFBTSxHQUFHLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQTtRQUMxQixJQUFJLENBQUMsZUFBZSxDQUFDLElBQUksQ0FBQztZQUN4QixTQUFTLEVBQUUsSUFBSTtZQUNmLElBQUksRUFBRSxJQUFJO1lBQ1YsV0FBVyxFQUFFLENBQUM7U0FDZixDQUFDLENBQUE7UUFDRixDQUFDLENBQUMsZUFBZSxFQUFFLENBQUM7UUFDcEIsQ0FBQyxDQUFDLGNBQWMsRUFBRSxDQUFBO0lBQ3BCLENBQUM7SUFFRCxTQUFTLENBQUMsS0FBb0I7UUFDNUIsS0FBSyxDQUFDLE9BQU8sQ0FBQyxDQUFDLE9BQW9CLEVBQUUsRUFBRTtZQUNyQyxPQUFPLENBQUMsUUFBUSxHQUFHLEtBQUssQ0FBQTtZQUN4QixJQUFJLE9BQU8sQ0FBQyxRQUFRLEVBQUUsTUFBTSxHQUFHLENBQUMsRUFBRTtnQkFDaEMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxPQUFPLENBQUMsUUFBUSxDQUFDLENBQUM7YUFDbEM7UUFDSCxDQUFDLENBQUMsQ0FBQztJQUNMLENBQUM7SUFFRCxVQUFVLENBQUMsS0FBb0I7UUFDN0IsS0FBSyxDQUFDLE9BQU8sQ0FBQyxDQUFDLE9BQW9CLEVBQUUsRUFBRTtZQUNyQyxPQUFPLENBQUMsTUFBTSxHQUFHLEtBQUssQ0FBQTtZQUN0QixJQUFJLE9BQU8sQ0FBQyxRQUFRLEVBQUUsTUFBTSxHQUFHLENBQUMsRUFBRTtnQkFDaEMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxPQUFPLENBQUMsUUFBUSxDQUFDLENBQUM7YUFDbkM7UUFDSCxDQUFDLENBQUMsQ0FBQztJQUVMLENBQUM7OzRHQWxEVSxlQUFlO2dHQUFmLGVBQWUsd0xDekM1Qix1M0JBbUJjOzJGRHNCRCxlQUFlO2tCQVAzQixTQUFTOytCQUNFLFNBQVMsbUJBRUYsdUJBQXVCLENBQUMsTUFBTSxpQkFDaEMsaUJBQWlCLENBQUMsSUFBSSxRQUMvQixFQUFFLEtBQUssRUFBRSxTQUFTLEVBQUU7aUlBV2pCLEtBQUs7c0JBQWIsS0FBSztnQkFHTixlQUFlO3NCQURkLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xyXG4gIENvbXBvbmVudCxcclxuICBWaWV3RW5jYXBzdWxhdGlvbixcclxuICBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSxcclxuICBFbGVtZW50UmVmLFxyXG4gIENoYW5nZURldGVjdG9yUmVmLFxyXG4gIElucHV0LFxyXG4gIE91dHB1dCxcclxuICBFdmVudEVtaXR0ZXIsXHJcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSdcclxuaW1wb3J0IHsgQVhCYXNlQ29tcG9uZW50TWl4aW4sIEFYRXZlbnQsIEFYSXRlbUNsaWNrRXZlbnQgfSBmcm9tICcuLi9iYXNlJ1xyXG5cclxuZXhwb3J0IGludGVyZmFjZSBBWE1lbnVJdGVtcyB7XHJcbiAgaWQ/OiBzdHJpbmdcclxuICBuYW1lPzogc3RyaW5nXHJcbiAgdGV4dD86IHN0cmluZ1xyXG4gIHRvb2x0aXA/OiBzdHJpbmdcclxuICBwYXJlbnRJZD86IHN0cmluZ1xyXG4gIGljb24/OiBzdHJpbmdcclxuICB2aXNpYmxlPzogYm9vbGVhblxyXG4gIGRpc2FibGU/OiBib29sZWFuXHJcbiAgc2VsZWN0ZWQ/OiBib29sZWFuXHJcbiAgZGF0YT86IGFueVxyXG4gIHN0eWxlPzogc3RyaW5nXHJcbiAgY2hpbGRyZW4/OiBBWE1lbnVJdGVtc1tdXHJcbiAgaXNPcGVuPzogYm9vbGVhblxyXG4gIGlzQWN0aXZlPzogYm9vbGVhblxyXG4gIG9uQ2xpY2s/OiAoZT86IGFueSkgPT4gdm9pZFxyXG59XHJcbi8qKlxyXG4gKiBUaGUgQnV0dG9uIGlzIGEgY29tcG9uZW50IHdoaWNoIGRldGVjdHMgdXNlciBpbnRlcmFjdGlvbiBhbmQgdHJpZ2dlcnMgYSBjb3JyZXNwb25kaW5nIGV2ZW50XHJcbiAqXHJcbiAqIEBjYXRlZ29yeSBDb21wb25lbnRzXHJcbiAqL1xyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ2F4LW1lbnUnLFxyXG4gIHRlbXBsYXRlVXJsOiAnLi9tZW51LmNvbXBvbmVudC5odG1sJyxcclxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcclxuICBlbmNhcHN1bGF0aW9uOiBWaWV3RW5jYXBzdWxhdGlvbi5Ob25lLFxyXG4gIGhvc3Q6IHsgY2xhc3M6IFwiYXgtbWVudVwiIH1cclxufSlcclxuZXhwb3J0IGNsYXNzIEFYTWVudUNvbXBvbmVudCBleHRlbmRzIEFYQmFzZUNvbXBvbmVudE1peGluIHtcclxuICAgICAvKipcclxuICAgICogIEBpZ25vcmVcclxuICAgICovXHJcbiAgY29uc3RydWN0b3IocHJpdmF0ZSBlbGVtZW50UmVmOiBFbGVtZW50UmVmLCBwcml2YXRlIGNkcjogQ2hhbmdlRGV0ZWN0b3JSZWYpIHtcclxuICAgIHN1cGVyKGVsZW1lbnRSZWYsIGNkcilcclxuICAgIC8vVE9ETzogYXgtbWVudVxyXG4gIH1cclxuXHJcbiAgQElucHV0KCkgaXRlbXM6IEFYTWVudUl0ZW1zW11cclxuXHJcbiAgQE91dHB1dCgpXHJcbiAgb25NZW51SXRlbUNsaWNrOiBFdmVudEVtaXR0ZXI8XHJcbiAgICBBWEl0ZW1DbGlja0V2ZW50PEFYTWVudUl0ZW1zPlxyXG4gID4gPSBuZXcgRXZlbnRFbWl0dGVyPEFYSXRlbUNsaWNrRXZlbnQ8QVhNZW51SXRlbXM+PigpXHJcblxyXG4gIG9uTWVudUNsaWNrKGU6IE1vdXNlRXZlbnQsIGl0ZW06IEFYTWVudUl0ZW1zKSB7XHJcbiAgICB0aGlzLm5vdEFjdGl2ZSh0aGlzLml0ZW1zKTtcclxuICAgIGlmIChpdGVtLmNoaWxkcmVuPy5sZW5ndGggPiAwKSB7XHJcbiAgICAgIHRoaXMuY2xvc2VDaGlsZChpdGVtLmNoaWxkcmVuKVxyXG4gICAgfVxyXG5cclxuICAgIGl0ZW0uaXNBY3RpdmUgPSAhaXRlbS5pc0FjdGl2ZVxyXG4gICAgaXRlbS5pc09wZW4gPSAhaXRlbS5pc09wZW5cclxuICAgIHRoaXMub25NZW51SXRlbUNsaWNrLmVtaXQoe1xyXG4gICAgICBjb21wb25lbnQ6IHRoaXMsXHJcbiAgICAgIGl0ZW06IGl0ZW0sXHJcbiAgICAgIG5hdGl2ZUV2ZW50OiBlLFxyXG4gICAgfSlcclxuICAgIGUuc3RvcFByb3BhZ2F0aW9uKCk7XHJcbiAgICBlLnByZXZlbnREZWZhdWx0KClcclxuICB9XHJcblxyXG4gIG5vdEFjdGl2ZShpdGVtczogQVhNZW51SXRlbXNbXSkge1xyXG4gICAgaXRlbXMuZm9yRWFjaCgoZWxlbWVudDogQVhNZW51SXRlbXMpID0+IHtcclxuICAgICAgZWxlbWVudC5pc0FjdGl2ZSA9IGZhbHNlXHJcbiAgICAgIGlmIChlbGVtZW50LmNoaWxkcmVuPy5sZW5ndGggPiAwKSB7XHJcbiAgICAgICAgdGhpcy5ub3RBY3RpdmUoZWxlbWVudC5jaGlsZHJlbik7XHJcbiAgICAgIH1cclxuICAgIH0pO1xyXG4gIH1cclxuXHJcbiAgY2xvc2VDaGlsZChpdGVtczogQVhNZW51SXRlbXNbXSkge1xyXG4gICAgaXRlbXMuZm9yRWFjaCgoZWxlbWVudDogQVhNZW51SXRlbXMpID0+IHtcclxuICAgICAgZWxlbWVudC5pc09wZW4gPSBmYWxzZVxyXG4gICAgICBpZiAoZWxlbWVudC5jaGlsZHJlbj8ubGVuZ3RoID4gMCkge1xyXG4gICAgICAgIHRoaXMuY2xvc2VDaGlsZChlbGVtZW50LmNoaWxkcmVuKTtcclxuICAgICAgfVxyXG4gICAgfSk7XHJcblxyXG4gIH1cclxuXHJcbn1cclxuXHJcbiIsIjx1bD5cclxuICA8bmctY29udGFpbmVyICpuZ1RlbXBsYXRlT3V0bGV0PVwicmVjdXJzaXZlTGlzdFRtcGw7IGNvbnRleHQ6eyBsaXN0OiBpdGVtcyB9XCI+PC9uZy1jb250YWluZXI+XHJcbjwvdWw+XHJcblxyXG48bmctdGVtcGxhdGUgI3JlY3Vyc2l2ZUxpc3RUbXBsIGxldC1saXN0PVwibGlzdFwiPlxyXG4gIDxuZy1jb250YWluZXIgKm5nRm9yPVwibGV0IGl0ZW0gb2YgbGlzdFwiPlxyXG4gICAgPGxpICpuZ0lmPVwiaXRlbS52aXNpYmxlICE9ZmFsc2VcIiAoY2xpY2spPVwib25NZW51Q2xpY2soJGV2ZW50LGl0ZW0pXCI+XHJcbiAgICAgIDxhIFtuZ0NsYXNzXT1cInsnYWN0aXZlJzogaXRlbS5pc0FjdGl2ZX1cIj5cclxuICAgICAgICA8c3Bhbj57e2l0ZW0udGV4dH19PC9zcGFuPlxyXG4gICAgICAgIDxheC1pY29uIFtuZ0NsYXNzXT1cInsnYWN0aXZlLWljb24nOiBpdGVtLmlzT3Blbn1cIiAqbmdJZj1cIml0ZW0/LmNoaWxkcmVuPy5sZW5ndGggPiAwXCIgY2xhc3M9XCJheC1pYy1jaGV2cm9uXCI+XHJcbiAgICAgICAgPC9heC1pY29uPlxyXG4gICAgICAgIDxheC1pY29uICpuZ0lmPVwiaXRlbS5pY29uXCIgY2xhc3M9XCJ7e2l0ZW0uaWNvbn19XCI+XHJcbiAgICAgICAgPC9heC1pY29uPlxyXG4gICAgICA8L2E+XHJcbiAgICAgIDx1bCAqbmdJZj1cIml0ZW0/LmNoaWxkcmVuPy5sZW5ndGggPiAwICYmIGl0ZW0uaXNPcGVuXCI+XHJcbiAgICAgICAgPG5nLWNvbnRhaW5lciAqbmdUZW1wbGF0ZU91dGxldD1cInJlY3Vyc2l2ZUxpc3RUbXBsOyBjb250ZXh0OnsgbGlzdDogaXRlbS5jaGlsZHJlbiB9XCI+PC9uZy1jb250YWluZXI+XHJcbiAgICAgIDwvdWw+XHJcbiAgICA8L2xpPlxyXG4gIDwvbmctY29udGFpbmVyPlxyXG48L25nLXRlbXBsYXRlPiJdfQ==
|
|
74
|
+
args: [{ selector: 'ax-menu', inputs: [...INTERACTIVE_INPUTS, ...BASEMENU_INPUTS], outputs: [...INTERACTIVE_OUTPUT], changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, host: { class: 'ax-menu' }, template: "<ul>\r\n <ng-container *ngTemplateOutlet=\"recursiveListTmpl; context:{ list: displayItems }\"></ng-container>\r\n</ul>\r\n\r\n<ng-template #recursiveListTmpl let-list=\"list\">\r\n <ng-container *ngFor=\"let item of list; trackBy: _trackLoaded\">\r\n <li [class.ax-state-disabled]=\"item[disableField]\" *ngIf=\"item.visible !=false\" (click)=\"onMenuClick($event,item)\">\r\n <a [ngClass]=\"{'active': item.isActive}\">\r\n <div class=\"ax-menu-start-side\">\r\n <ax-icon [class]=\"item.icon || item[icon]\" *ngIf=\"item.icon || item[icon]\"></ax-icon>\r\n <span>{{_getItemDisplayTextTemplte(item)}}</span>\r\n </div>\r\n <div class=\"ax-menu-end-side\">\r\n <ax-icon [ngClass]=\"{'active-icon': item.isOpen}\"\r\n *ngIf=\"item?.children?.length > 0 && !isLoading || item[hasChildField] && !isLoading\" class=\"ax-ic-chevron\">\r\n </ax-icon>\r\n </div>\r\n\r\n <ax-loading *ngIf=\"isLoading && item.isActive && item.isOpen\">\r\n </ax-loading>\r\n </a>\r\n <ul [class.ax-state-disabled]=\"item[disableField]\" *ngIf=\"item?.children?.length > 0 && item.isOpen\">\r\n <ng-container *ngTemplateOutlet=\"recursiveListTmpl; context:{ list: item.children }\"></ng-container>\r\n </ul>\r\n </li>\r\n </ng-container>\r\n</ng-template>\r\n<ng-container *ngIf=\"isLoading\">\r\n <ng-template>\r\n <div class=\"ax-flex ax-items-center ax-justify-center ax-p-4\">\r\n <ax-loading text=\"{{ 'layout.loading.text' | trans }}\"></ax-loading>\r\n </div>\r\n </ng-template>\r\n</ng-container>" }]
|
|
75
|
+
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.ChangeDetectorRef }]; } });
|
|
76
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"menu.component.js","sourceRoot":"","sources":["../../../../../../projects/acorex/components/src/lib/menu/menu.component.ts","../../../../../../projects/acorex/components/src/lib/menu/menu.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  OnInit,\r\n} from '@angular/core';\r\nimport { AXBaseMenuMixin } from '../base';\r\nimport { BASEMENU_INPUTS } from '../base/mixin/base-menu-mixin.class';\r\nimport {\r\n  INTERACTIVE_INPUTS,\r\n  INTERACTIVE_OUTPUT,\r\n} from '../base/mixin/interactive-mixin.class';\r\n\r\nexport interface AXMenuItems {\r\n  id?: string;\r\n  name?: string;\r\n  text?: string;\r\n  tooltip?: string;\r\n  parentId?: string;\r\n  icon?: string;\r\n  visible?: boolean;\r\n  disable?: boolean;\r\n  selected?: boolean;\r\n  data?: any;\r\n  style?: string;\r\n  children?: AXMenuItems[];\r\n  isOpen?: boolean;\r\n  isActive?: boolean;\r\n  onClick?: (e?: any) => void;\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-menu',\r\n  templateUrl: './menu.component.html',\r\n  inputs: [...INTERACTIVE_INPUTS, ...BASEMENU_INPUTS],\r\n  outputs: [...INTERACTIVE_OUTPUT],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  encapsulation: ViewEncapsulation.None,\r\n  host: { class: 'ax-menu' },\r\n})\r\nexport class AXMenuComponent extends AXBaseMenuMixin implements OnInit {\r\n  constructor(private elementRef: ElementRef, private cdr: ChangeDetectorRef) {\r\n    super(elementRef, cdr);\r\n  }\r\n\r\n  onInit(): void {\r\n    super.onInit();\r\n    this._fetchData();\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    super.onViewInit();\r\n  }\r\n\r\n  onMenuClick(e: MouseEvent, item: any) {\r\n    if (!item[this.disableField]) {\r\n      this.notActive(this.displayItems);\r\n      if (item.children?.length > 0 || item[this.hasChildField]) {\r\n        if (item.children?.length > 0 && item[this.hasChildField]) {\r\n          item.children = [];\r\n        }\r\n        if (item.children?.length > 0) {\r\n          this.closeChild(item.children);\r\n        }\r\n        item.isOpen = !item.isOpen;\r\n      }\r\n      item.isActive = !item.isActive;\r\n      this.onMenuItemClick.emit({\r\n        component: this,\r\n        item: item,\r\n        nativeEvent: e,\r\n      });\r\n      if (item.isOpen && item[this.hasChildField]) {\r\n        this._fetchData(item.id);\r\n      }\r\n    }\r\n    e.stopPropagation();\r\n    e.preventDefault();\r\n  }\r\n\r\n  notActive(items: any[]) {\r\n    items.forEach((element: any) => {\r\n      element.isActive = false;\r\n      if (element.children?.length > 0) {\r\n        this.notActive(element.children);\r\n      }\r\n    });\r\n  }\r\n\r\n  closeChild(items: any[]) {\r\n    items.forEach((element: any) => {\r\n      element.isOpen = false;\r\n      if (element.children?.length > 0) {\r\n        this.closeChild(element.children);\r\n      }\r\n    });\r\n  }\r\n}\r\n","<ul>\r\n  <ng-container *ngTemplateOutlet=\"recursiveListTmpl; context:{ list: displayItems }\"></ng-container>\r\n</ul>\r\n\r\n<ng-template #recursiveListTmpl let-list=\"list\">\r\n  <ng-container *ngFor=\"let item of list;  trackBy: _trackLoaded\">\r\n    <li [class.ax-state-disabled]=\"item[disableField]\" *ngIf=\"item.visible !=false\" (click)=\"onMenuClick($event,item)\">\r\n      <a [ngClass]=\"{'active': item.isActive}\">\r\n        <div class=\"ax-menu-start-side\">\r\n          <ax-icon [class]=\"item.icon || item[icon]\" *ngIf=\"item.icon || item[icon]\"></ax-icon>\r\n          <span>{{_getItemDisplayTextTemplte(item)}}</span>\r\n        </div>\r\n        <div class=\"ax-menu-end-side\">\r\n          <ax-icon [ngClass]=\"{'active-icon': item.isOpen}\"\r\n            *ngIf=\"item?.children?.length > 0 && !isLoading || item[hasChildField] && !isLoading\" class=\"ax-ic-chevron\">\r\n          </ax-icon>\r\n        </div>\r\n\r\n        <ax-loading *ngIf=\"isLoading && item.isActive && item.isOpen\">\r\n        </ax-loading>\r\n      </a>\r\n      <ul [class.ax-state-disabled]=\"item[disableField]\" *ngIf=\"item?.children?.length > 0 && item.isOpen\">\r\n        <ng-container *ngTemplateOutlet=\"recursiveListTmpl; context:{ list: item.children }\"></ng-container>\r\n      </ul>\r\n    </li>\r\n  </ng-container>\r\n</ng-template>\r\n<ng-container *ngIf=\"isLoading\">\r\n  <ng-template>\r\n    <div class=\"ax-flex ax-items-center ax-justify-center ax-p-4\">\r\n      <ax-loading text=\"{{ 'layout.loading.text' | trans }}\"></ax-loading>\r\n    </div>\r\n  </ng-template>\r\n</ng-container>"]}
|
|
@@ -2,21 +2,23 @@ import { NgModule } from '@angular/core';
|
|
|
2
2
|
import { CommonModule } from '@angular/common';
|
|
3
3
|
import { AXMenuComponent } from './menu.component';
|
|
4
4
|
import { AXIconModule } from '../icon';
|
|
5
|
+
import { AXLoadingModule } from '../loading';
|
|
6
|
+
import { AXTranslationModule } from '@acorex/core';
|
|
5
7
|
import * as i0 from "@angular/core";
|
|
6
8
|
const COMPONENT = [AXMenuComponent];
|
|
7
9
|
const MODULES = [CommonModule];
|
|
8
10
|
export class AXMenuModule {
|
|
9
11
|
}
|
|
10
12
|
AXMenuModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: AXMenuModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
11
|
-
AXMenuModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: AXMenuModule, declarations: [AXMenuComponent], imports: [CommonModule, AXIconModule], exports: [AXMenuComponent] });
|
|
12
|
-
AXMenuModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: AXMenuModule, providers: [], imports: [[...MODULES, AXIconModule]] });
|
|
13
|
+
AXMenuModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: AXMenuModule, declarations: [AXMenuComponent], imports: [CommonModule, AXIconModule, AXLoadingModule, AXTranslationModule], exports: [AXMenuComponent] });
|
|
14
|
+
AXMenuModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: AXMenuModule, providers: [], imports: [[...MODULES, AXIconModule, AXLoadingModule, AXTranslationModule]] });
|
|
13
15
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: AXMenuModule, decorators: [{
|
|
14
16
|
type: NgModule,
|
|
15
17
|
args: [{
|
|
16
18
|
declarations: [...COMPONENT],
|
|
17
|
-
imports: [...MODULES, AXIconModule],
|
|
19
|
+
imports: [...MODULES, AXIconModule, AXLoadingModule, AXTranslationModule],
|
|
18
20
|
exports: [...COMPONENT],
|
|
19
21
|
providers: [],
|
|
20
22
|
}]
|
|
21
23
|
}] });
|
|
22
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
24
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWVudS5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hY29yZXgvY29tcG9uZW50cy9zcmMvbGliL21lbnUvbWVudS5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLGtCQUFrQixDQUFDO0FBQ25ELE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxTQUFTLENBQUM7QUFDdkMsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLFlBQVksQ0FBQztBQUM3QyxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxjQUFjLENBQUM7O0FBRW5ELE1BQU0sU0FBUyxHQUFHLENBQUMsZUFBZSxDQUFDLENBQUM7QUFDcEMsTUFBTSxPQUFPLEdBQUcsQ0FBQyxZQUFZLENBQUMsQ0FBQztBQVEvQixNQUFNLE9BQU8sWUFBWTs7eUdBQVosWUFBWTswR0FBWixZQUFZLGlCQVROLGVBQWUsYUFDakIsWUFBWSxFQUlILFlBQVksRUFBRSxlQUFlLEVBQUMsbUJBQW1CLGFBTHhELGVBQWU7MEdBU3JCLFlBQVksYUFGVixFQUFFLFlBRkosQ0FBQyxHQUFHLE9BQU8sRUFBRSxZQUFZLEVBQUUsZUFBZSxFQUFDLG1CQUFtQixDQUFDOzJGQUkvRCxZQUFZO2tCQU54QixRQUFRO21CQUFDO29CQUNOLFlBQVksRUFBRSxDQUFDLEdBQUcsU0FBUyxDQUFDO29CQUM1QixPQUFPLEVBQUUsQ0FBQyxHQUFHLE9BQU8sRUFBRSxZQUFZLEVBQUUsZUFBZSxFQUFDLG1CQUFtQixDQUFDO29CQUN4RSxPQUFPLEVBQUUsQ0FBQyxHQUFHLFNBQVMsQ0FBQztvQkFDdkIsU0FBUyxFQUFFLEVBQUU7aUJBQ2hCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcclxuaW1wb3J0IHsgQVhNZW51Q29tcG9uZW50IH0gZnJvbSAnLi9tZW51LmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IEFYSWNvbk1vZHVsZSB9IGZyb20gJy4uL2ljb24nO1xyXG5pbXBvcnQgeyBBWExvYWRpbmdNb2R1bGUgfSBmcm9tICcuLi9sb2FkaW5nJztcclxuaW1wb3J0IHsgQVhUcmFuc2xhdGlvbk1vZHVsZSB9IGZyb20gJ0BhY29yZXgvY29yZSc7XHJcblxyXG5jb25zdCBDT01QT05FTlQgPSBbQVhNZW51Q29tcG9uZW50XTtcclxuY29uc3QgTU9EVUxFUyA9IFtDb21tb25Nb2R1bGVdO1xyXG5cclxuQE5nTW9kdWxlKHtcclxuICAgIGRlY2xhcmF0aW9uczogWy4uLkNPTVBPTkVOVF0sXHJcbiAgICBpbXBvcnRzOiBbLi4uTU9EVUxFUywgQVhJY29uTW9kdWxlLCBBWExvYWRpbmdNb2R1bGUsQVhUcmFuc2xhdGlvbk1vZHVsZV0sXHJcbiAgICBleHBvcnRzOiBbLi4uQ09NUE9ORU5UXSxcclxuICAgIHByb3ZpZGVyczogW10sXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBBWE1lbnVNb2R1bGUgeyB9XHJcbiJdfQ==
|
|
@@ -5,8 +5,8 @@ import * as i0 from "@angular/core";
|
|
|
5
5
|
import * as i1 from "@angular/common";
|
|
6
6
|
export const AXBaseTabItemMixin = _ClickableComponenetMixin(AXBaseComponent);
|
|
7
7
|
export class AXTabItemComponent extends AXBaseTabItemMixin {
|
|
8
|
-
constructor(
|
|
9
|
-
super(
|
|
8
|
+
constructor(_elementRef, _cdr) {
|
|
9
|
+
super(_elementRef, _cdr);
|
|
10
10
|
this.activeChange = new EventEmitter();
|
|
11
11
|
this._active = false;
|
|
12
12
|
this.disabledChange = new EventEmitter();
|
|
@@ -18,7 +18,10 @@ export class AXTabItemComponent extends AXBaseTabItemMixin {
|
|
|
18
18
|
set active(value) {
|
|
19
19
|
this._setOption({
|
|
20
20
|
name: 'active',
|
|
21
|
-
value
|
|
21
|
+
value,
|
|
22
|
+
afterCallback: () => {
|
|
23
|
+
this._cdr.markForCheck();
|
|
24
|
+
}
|
|
22
25
|
});
|
|
23
26
|
}
|
|
24
27
|
get disabled() {
|
|
@@ -115,4 +118,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImpor
|
|
|
115
118
|
type: HostListener,
|
|
116
119
|
args: ['click', ['$event']]
|
|
117
120
|
}] } });
|
|
118
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
121
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFiLWl0ZW0uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYWNvcmV4L2NvbXBvbmVudHMvc3JjL2xpYi90YWJzL3RhYi1pdGVtLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0gsU0FBUyxFQUNULGlCQUFpQixFQUNqQix1QkFBdUIsRUFHdkIsS0FBSyxFQUNMLFNBQVMsRUFFVCxNQUFNLEVBQ04sWUFBWSxFQUNaLFlBQVksRUFDWixZQUFZLEdBQ2YsTUFBTSxlQUFlLENBQUM7QUFDdkIsT0FBTyxFQUFFLGVBQWUsRUFBNEIsTUFBTSxTQUFTLENBQUM7QUFDcEUsT0FBTyxFQUFFLHlCQUF5QixFQUFFLE1BQU0scUNBQXFDLENBQUM7OztBQUdoRixNQUFNLENBQUMsTUFBTSxrQkFBa0IsR0FBRyx5QkFBeUIsQ0FBQyxlQUFlLENBQUMsQ0FBQTtBQXlCNUUsTUFBTSxPQUFPLGtCQUFtQixTQUFRLGtCQUFrQjtJQUV0RCxZQUFZLFdBQXVCLEVBQUUsSUFBdUI7UUFDeEQsS0FBSyxDQUFDLFdBQVcsRUFBRSxJQUFJLENBQUMsQ0FBQztRQW1CN0IsaUJBQVksR0FBMEIsSUFBSSxZQUFZLEVBQVcsQ0FBQztRQUUxRCxZQUFPLEdBQVksS0FBSyxDQUFDO1FBaUJqQyxtQkFBYyxHQUEwQixJQUFJLFlBQVksRUFBVyxDQUFDO1FBQzVELGNBQVMsR0FBWSxLQUFLLENBQUM7SUF0Q25DLENBQUM7SUFxQkQsSUFDVyxNQUFNO1FBQ2IsT0FBTyxJQUFJLENBQUMsT0FBTyxDQUFDO0lBQ3hCLENBQUM7SUFDRCxJQUFXLE1BQU0sQ0FBQyxLQUFjO1FBQzVCLElBQUksQ0FBQyxVQUFVLENBQUM7WUFDWixJQUFJLEVBQUUsUUFBUTtZQUNkLEtBQUs7WUFDTCxhQUFhLEVBQUMsR0FBRSxFQUFFO2dCQUNkLElBQUksQ0FBQyxJQUFJLENBQUMsWUFBWSxFQUFFLENBQUM7WUFDN0IsQ0FBQztTQUNKLENBQUMsQ0FBQztJQUNQLENBQUM7SUFNRCxJQUNXLFFBQVE7UUFDZixPQUFPLElBQUksQ0FBQyxTQUFTLENBQUM7SUFDMUIsQ0FBQztJQUNELElBQVcsUUFBUSxDQUFDLEtBQWM7UUFDOUIsSUFBSSxDQUFDLFVBQVUsQ0FBQztZQUNaLElBQUksRUFBRSxVQUFVO1lBQ2hCLEtBQUs7U0FDUixDQUFDLENBQUM7SUFDUCxDQUFDO0lBSU8sV0FBVyxDQUFDLENBQWE7UUFDN0IsSUFBSSxDQUFDLElBQUksQ0FBQyxRQUFRLEVBQUU7WUFDaEIsSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUM7Z0JBQ2QsU0FBUyxFQUFFLElBQUk7Z0JBQ2YsV0FBVyxFQUFFLElBQUksQ0FBQyxlQUFlLEVBQUU7Z0JBQ25DLFdBQVcsRUFBRSxDQUFDO2FBQ2pCLENBQUMsQ0FBQTtTQUNMO0lBQ0wsQ0FBQztJQUdELGdCQUFnQixDQUFDLE1BQWdDO1FBQzdDLE1BQU0sWUFBWSxHQUFHLElBQUksQ0FBQyxlQUFlLEVBQUUsQ0FBQyxTQUFTLENBQUM7UUFDdEQsSUFBSSxNQUFNLENBQUMsSUFBSSxJQUFJLFVBQVUsRUFBRTtZQUMzQixNQUFNLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQyxZQUFZLENBQUMsR0FBRyxDQUFDLG1CQUFtQixDQUFDLENBQUMsQ0FBQyxDQUFDLFlBQVksQ0FBQyxNQUFNLENBQUMsbUJBQW1CLENBQUMsQ0FBQTtTQUNyRztRQUNELElBQUksTUFBTSxDQUFDLElBQUksSUFBSSxRQUFRLEVBQUU7WUFDekIsTUFBTSxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUMsWUFBWSxDQUFDLEdBQUcsQ0FBQyxpQkFBaUIsQ0FBQyxDQUFDLENBQUMsQ0FBQyxZQUFZLENBQUMsTUFBTSxDQUFDLGlCQUFpQixDQUFDLENBQUE7U0FDakc7SUFDTCxDQUFDOzsrR0EzRVEsa0JBQWtCO21HQUFsQixrQkFBa0IsdWZBckJqQjs7Ozs7Ozs7Ozs7Ozs7Ozs7S0FpQlQ7MkZBSVEsa0JBQWtCO2tCQXZCOUIsU0FBUzttQkFBQztvQkFDUCxRQUFRLEVBQUUsYUFBYTtvQkFDdkIsUUFBUSxFQUFFOzs7Ozs7Ozs7Ozs7Ozs7OztLQWlCVDtvQkFDRCxlQUFlLEVBQUUsdUJBQXVCLENBQUMsTUFBTTtvQkFDL0MsYUFBYSxFQUFFLGlCQUFpQixDQUFDLElBQUk7aUJBQ3hDO2lJQVFHLElBQUk7c0JBREgsS0FBSztnQkFLTixHQUFHO3NCQURGLEtBQUs7Z0JBSU4sUUFBUTtzQkFEUCxTQUFTO3VCQUFDLFNBQVM7Z0JBS3BCLGNBQWM7c0JBRGIsWUFBWTt1QkFBQyxRQUFRLEVBQUUsRUFBRSxNQUFNLEVBQUUsSUFBSSxFQUFFO2dCQUt4QyxZQUFZO3NCQURYLE1BQU07Z0JBS0ksTUFBTTtzQkFEaEIsS0FBSztnQkFnQk4sY0FBYztzQkFEYixNQUFNO2dCQUlJLFFBQVE7c0JBRGxCLEtBQUs7Z0JBYUUsV0FBVztzQkFEbEIsWUFBWTt1QkFBQyxPQUFPLEVBQUUsQ0FBQyxRQUFRLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xyXG4gICAgQ29tcG9uZW50LFxyXG4gICAgVmlld0VuY2Fwc3VsYXRpb24sXHJcbiAgICBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSxcclxuICAgIEVsZW1lbnRSZWYsXHJcbiAgICBDaGFuZ2VEZXRlY3RvclJlZixcclxuICAgIElucHV0LFxyXG4gICAgVmlld0NoaWxkLFxyXG4gICAgVGVtcGxhdGVSZWYsXHJcbiAgICBPdXRwdXQsXHJcbiAgICBFdmVudEVtaXR0ZXIsXHJcbiAgICBIb3N0TGlzdGVuZXIsXHJcbiAgICBDb250ZW50Q2hpbGQsXHJcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IEFYQmFzZUNvbXBvbmVudCwgQVhDb21wb25lbnRPcHRpb25DaGFuZ2VkIH0gZnJvbSAnLi4vYmFzZSc7XHJcbmltcG9ydCB7IF9DbGlja2FibGVDb21wb25lbmV0TWl4aW4gfSBmcm9tICcuLi9iYXNlL21peGluL2NsaWNrYWJsZS1taXhpbi5jbGFzcyc7XHJcblxyXG5cclxuZXhwb3J0IGNvbnN0IEFYQmFzZVRhYkl0ZW1NaXhpbiA9IF9DbGlja2FibGVDb21wb25lbmV0TWl4aW4oQVhCYXNlQ29tcG9uZW50KVxyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgICBzZWxlY3RvcjogJ2F4LXRhYi1pdGVtJyxcclxuICAgIHRlbXBsYXRlOiBgXHJcbiAgICAgICAgPG5nLWNvbnRhaW5lciAqbmdJZj1cImhlYWRlclRlbXBsYXRlO2Vsc2UgaGVhZGVyXCI+XHJcbiAgICAgICAgICAgICA8bmctY29udGFpbmVyIFtuZ1RlbXBsYXRlT3V0bGV0XT1cImhlYWRlclRlbXBsYXRlXCIgW25nVGVtcGxhdGVPdXRsZXRDb250ZXh0XT1cInsgJGltcGxpY2l0OiB7dGV4dCxrZXksYWN0aXZlLGRpc2FibGVkfSB9XCI+PC9uZy1jb250YWluZXI+XHJcbiAgICAgICAgPC9uZy1jb250YWluZXI+XHJcbiAgICAgICAgPCEtLSA8bmctY29udGFpbmVyICpuZ0lmPVwiaGVhZGVyVGVtcGxhdGU7ZWxzZSBoZWFkZXJcIj5cclxuICAgICAgICAgICAgPG5nLWNvbnRlbnQgc2VsZWN0PVwiYXgtaGVhZGVyXCI+XHJcbiAgICAgICAgICAgIDwvbmctY29udGVudD5cclxuICAgICAgICA8L25nLWNvbnRhaW5lcj4gLS0+XHJcbiAgICAgICAgPG5nLXRlbXBsYXRlICNoZWFkZXI+XHJcbiAgICAgICAgICAgIDxuZy1jb250ZW50IHNlbGVjdD1cImF4LXByZWZpeFwiPjwvbmctY29udGVudD5cclxuICAgICAgICAgICAgPHNwYW4+e3t0ZXh0fX08L3NwYW4+XHJcbiAgICAgICAgICAgIDxuZy1jb250ZW50IHNlbGVjdD1cImF4LXN1ZmZpeFwiPjwvbmctY29udGVudD5cclxuICAgICAgICA8L25nLXRlbXBsYXRlPlxyXG4gICAgICAgIDxuZy10ZW1wbGF0ZSAjY29udGVudD5cclxuICAgICAgICAgICAgPG5nLWNvbnRlbnQgc2VsZWN0PVwiYXgtY29udGVudFwiPlxyXG4gICAgICAgICAgICA8L25nLWNvbnRlbnQ+XHJcbiAgICAgICAgPC9uZy10ZW1wbGF0ZT5cclxuICAgIGAsXHJcbiAgICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcclxuICAgIGVuY2Fwc3VsYXRpb246IFZpZXdFbmNhcHN1bGF0aW9uLk5vbmUsXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBBWFRhYkl0ZW1Db21wb25lbnQgZXh0ZW5kcyBBWEJhc2VUYWJJdGVtTWl4aW4ge1xyXG5cclxuICAgIGNvbnN0cnVjdG9yKF9lbGVtZW50UmVmOiBFbGVtZW50UmVmLCBfY2RyOiBDaGFuZ2VEZXRlY3RvclJlZikge1xyXG4gICAgICAgIHN1cGVyKF9lbGVtZW50UmVmLCBfY2RyKTtcclxuICAgIH1cclxuXHJcbiAgICBASW5wdXQoKVxyXG4gICAgdGV4dDogc3RyaW5nO1xyXG5cclxuXHJcbiAgICBASW5wdXQoKVxyXG4gICAga2V5OiBzdHJpbmc7XHJcblxyXG4gICAgQFZpZXdDaGlsZCgnY29udGVudCcpXHJcbiAgICB0ZW1wbGF0ZTogVGVtcGxhdGVSZWY8YW55PjtcclxuXHJcblxyXG4gICAgQENvbnRlbnRDaGlsZCgnaGVhZGVyJywgeyBzdGF0aWM6IHRydWUgfSlcclxuICAgIGhlYWRlclRlbXBsYXRlOiBUZW1wbGF0ZVJlZjxhbnk+O1xyXG5cclxuXHJcbiAgICBAT3V0cHV0KClcclxuICAgIGFjdGl2ZUNoYW5nZTogRXZlbnRFbWl0dGVyPGJvb2xlYW4+ID0gbmV3IEV2ZW50RW1pdHRlcjxib29sZWFuPigpO1xyXG5cclxuICAgIHByaXZhdGUgX2FjdGl2ZTogYm9vbGVhbiA9IGZhbHNlO1xyXG4gICAgQElucHV0KClcclxuICAgIHB1YmxpYyBnZXQgYWN0aXZlKCk6IGJvb2xlYW4ge1xyXG4gICAgICAgIHJldHVybiB0aGlzLl9hY3RpdmU7XHJcbiAgICB9XHJcbiAgICBwdWJsaWMgc2V0IGFjdGl2ZSh2YWx1ZTogYm9vbGVhbikge1xyXG4gICAgICAgIHRoaXMuX3NldE9wdGlvbih7XHJcbiAgICAgICAgICAgIG5hbWU6ICdhY3RpdmUnLFxyXG4gICAgICAgICAgICB2YWx1ZSxcclxuICAgICAgICAgICAgYWZ0ZXJDYWxsYmFjazooKT0+e1xyXG4gICAgICAgICAgICAgICAgdGhpcy5fY2RyLm1hcmtGb3JDaGVjaygpO1xyXG4gICAgICAgICAgICB9XHJcbiAgICAgICAgfSk7XHJcbiAgICB9XHJcblxyXG5cclxuICAgIEBPdXRwdXQoKVxyXG4gICAgZGlzYWJsZWRDaGFuZ2U6IEV2ZW50RW1pdHRlcjxib29sZWFuPiA9IG5ldyBFdmVudEVtaXR0ZXI8Ym9vbGVhbj4oKTtcclxuICAgIHByaXZhdGUgX2Rpc2FibGVkOiBib29sZWFuID0gZmFsc2U7XHJcbiAgICBASW5wdXQoKVxyXG4gICAgcHVibGljIGdldCBkaXNhYmxlZCgpOiBib29sZWFuIHtcclxuICAgICAgICByZXR1cm4gdGhpcy5fZGlzYWJsZWQ7XHJcbiAgICB9XHJcbiAgICBwdWJsaWMgc2V0IGRpc2FibGVkKHZhbHVlOiBib29sZWFuKSB7XHJcbiAgICAgICAgdGhpcy5fc2V0T3B0aW9uKHtcclxuICAgICAgICAgICAgbmFtZTogJ2Rpc2FibGVkJyxcclxuICAgICAgICAgICAgdmFsdWVcclxuICAgICAgICB9KTtcclxuICAgIH1cclxuXHJcblxyXG4gICAgQEhvc3RMaXN0ZW5lcignY2xpY2snLCBbJyRldmVudCddKVxyXG4gICAgcHJpdmF0ZSBfX2hvc3RDbGljayhlOiBNb3VzZUV2ZW50KSB7XHJcbiAgICAgICAgaWYgKCF0aGlzLmRpc2FibGVkKSB7XHJcbiAgICAgICAgICAgIHRoaXMub25DbGljay5lbWl0KHtcclxuICAgICAgICAgICAgICAgIGNvbXBvbmVudDogdGhpcyxcclxuICAgICAgICAgICAgICAgIGh0bWxFbGVtZW50OiB0aGlzLl9nZXRIb3N0RWxlbWVudCgpLFxyXG4gICAgICAgICAgICAgICAgbmF0aXZlRXZlbnQ6IGVcclxuICAgICAgICAgICAgfSlcclxuICAgICAgICB9XHJcbiAgICB9XHJcblxyXG5cclxuICAgIF9vbk9wdGlvbkNoYW5nZWQob3B0aW9uOiBBWENvbXBvbmVudE9wdGlvbkNoYW5nZWQpOiB2b2lkIHtcclxuICAgICAgICBjb25zdCBjbGFzc0xpc3RSZWYgPSB0aGlzLl9nZXRIb3N0RWxlbWVudCgpLmNsYXNzTGlzdDtcclxuICAgICAgICBpZiAob3B0aW9uLm5hbWUgPT0gJ2Rpc2FibGVkJykge1xyXG4gICAgICAgICAgICBvcHRpb24ubmV3VmFsdWUgPyBjbGFzc0xpc3RSZWYuYWRkKCdheC1zdGF0ZS1kaXNhYmxlZCcpIDogY2xhc3NMaXN0UmVmLnJlbW92ZSgnYXgtc3RhdGUtZGlzYWJsZWQnKVxyXG4gICAgICAgIH1cclxuICAgICAgICBpZiAob3B0aW9uLm5hbWUgPT0gJ2FjdGl2ZScpIHtcclxuICAgICAgICAgICAgb3B0aW9uLm5ld1ZhbHVlID8gY2xhc3NMaXN0UmVmLmFkZCgnYXgtc3RhdGUtYWN0aXZlJykgOiBjbGFzc0xpc3RSZWYucmVtb3ZlKCdheC1zdGF0ZS1hY3RpdmUnKVxyXG4gICAgICAgIH1cclxuICAgIH1cclxufVxyXG4iXX0=
|
|
@@ -14,10 +14,10 @@ export class AXTabsComponent extends AXBaseComponent {
|
|
|
14
14
|
return this._contentTabs.toArray();
|
|
15
15
|
}
|
|
16
16
|
get selectedIndex() {
|
|
17
|
-
return this.items.
|
|
17
|
+
return this.items.indexOf(this._selectedItem);
|
|
18
18
|
}
|
|
19
19
|
get selectedItem() {
|
|
20
|
-
return this.
|
|
20
|
+
return this._selectedItem;
|
|
21
21
|
}
|
|
22
22
|
onRenderCssClass() {
|
|
23
23
|
const classList = Array.from(this._getHostElement().classList);
|
|
@@ -43,6 +43,7 @@ export class AXTabsComponent extends AXBaseComponent {
|
|
|
43
43
|
//
|
|
44
44
|
if (!tab || this.selectedItem == tabItem)
|
|
45
45
|
return;
|
|
46
|
+
this._selectedItem = tabItem;
|
|
46
47
|
//
|
|
47
48
|
this.items.forEach(c => c.active = false);
|
|
48
49
|
tabItem.active = true;
|
|
@@ -91,4 +92,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImpor
|
|
|
91
92
|
}], onActiveTabChanged: [{
|
|
92
93
|
type: Output
|
|
93
94
|
}] } });
|
|
94
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
95
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tabs.component.js","sourceRoot":"","sources":["../../../../../../projects/acorex/components/src/lib/tabs/tabs.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, ViewEncapsulation, ChangeDetectionStrategy, ElementRef, ChangeDetectorRef, ContentChildren, QueryList, Input, HostBinding, ViewChild, TemplateRef, ViewContainerRef, Renderer2, ComponentFactory, Inject, Injector, Output, EventEmitter } from '@angular/core';\r\nimport { AXTabStripChangedEvent } from './tabs.class';\r\nimport { AXBaseComponent } from '../base';\r\nimport { AXTabItemComponent } from './tab-item.component';\r\nimport { AXTabContentDirective } from './tab-content.directive';\r\n\r\n@Component({\r\n    selector: 'ax-tabs',\r\n    template: `\r\n        <div class=\"ax-items-wrapper\">\r\n            <ng-content select=\"ax-tab-item\">\r\n            </ng-content>\r\n        </div>\r\n    `,\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n    encapsulation: ViewEncapsulation.None,\r\n})\r\nexport class AXTabsComponent extends AXBaseComponent {\r\n\r\n    @ContentChildren(AXTabItemComponent)\r\n    private _contentTabs: QueryList<AXTabItemComponent>;\r\n\r\n    @Input()\r\n    fitParent: boolean = false;\r\n\r\n    @Input()\r\n    minWidth: boolean = false;\r\n\r\n\r\n    @Input()\r\n    content: AXTabContentDirective;\r\n\r\n    constructor(\r\n        elementRef: ElementRef,\r\n        cdr: ChangeDetectorRef\r\n    ) {\r\n        super(elementRef, cdr);\r\n    }\r\n\r\n\r\n    private _isUserInteraction: boolean = false;\r\n\r\n\r\n    get items(): AXTabItemComponent[] {\r\n        return this._contentTabs.toArray();\r\n    }\r\n\r\n\r\n    private _selectedItem:AXTabItemComponent;\r\n\r\n    get selectedIndex(): number {\r\n        return this.items.indexOf(this._selectedItem);\r\n    }\r\n\r\n\r\n    get selectedItem(): AXTabItemComponent {\r\n        return this._selectedItem;\r\n    }\r\n\r\n\r\n    @Output()\r\n    onActiveTabChanged: EventEmitter<AXTabStripChangedEvent> = new EventEmitter<AXTabStripChangedEvent>();\r\n\r\n    onRenderCssClass() {\r\n        const classList = Array.from(this._getHostElement().classList);\r\n        if (!classList.some(c => ['ax-vertical', 'ax-horizontal'].includes(c))) {\r\n            this._getHostElement().classList.add('ax-horizontal');\r\n        }\r\n        if (!classList.some(c => c.startsWith('ax-look-'))) {\r\n            this._getHostElement().classList.add('ax-look-default');\r\n        }\r\n    }\r\n\r\n    onViewInit() {\r\n        const selected = this.items.find(c => c.active) || this.items[0];\r\n     \r\n        this.select(selected);\r\n        this.items.forEach(c => {\r\n            c.onClick.subscribe(t => {\r\n                this._isUserInteraction = t.nativeEvent?.isTrusted;\r\n                this.select(c);\r\n            })\r\n        });\r\n    }\r\n\r\n    select(tab: number | AXTabItemComponent) {\r\n        let tabItem: AXTabItemComponent = typeof tab == 'number' ? this.items[tab] : tab;\r\n        //\r\n        if (!tab || this.selectedItem == tabItem) return;\r\n        this._selectedItem = tabItem;\r\n        //\r\n        this.items.forEach(c => c.active = false);\r\n        tabItem.active = true;\r\n        if (this.content) {\r\n            this.content.portal = tabItem.template;\r\n        }\r\n        this._cdr.markForCheck();\r\n        this.onActiveTabChanged.emit({\r\n            component: this,\r\n            isUserInteraction: this._isUserInteraction,\r\n            tab: tabItem,\r\n            index: this.selectedIndex\r\n        })\r\n        this._isUserInteraction = false;\r\n    }\r\n}\r\n"]}
|