@acorex/components 18.10.16 → 18.11.0
Sign up to get free protection for your applications and to get access to all the features.
- package/esm2022/common/lib/classes/events.class.mjs +1 -1
- package/esm2022/menu/index.mjs +4 -4
- package/esm2022/menu/lib/context-menu.component.mjs +181 -0
- package/esm2022/menu/lib/menu-item.component.mjs +311 -0
- package/esm2022/menu/lib/menu.component.mjs +24 -30
- package/esm2022/menu/lib/menu.module.mjs +7 -7
- package/esm2022/menu/lib/menu.service.mjs +10 -8
- package/esm2022/menu/lib/menu.types.mjs +22 -0
- package/fesm2022/acorex-components-common.mjs.map +1 -1
- package/fesm2022/acorex-components-menu.mjs +494 -161
- package/fesm2022/acorex-components-menu.mjs.map +1 -1
- package/menu/index.d.ts +3 -3
- package/menu/lib/context-menu.component.d.ts +41 -0
- package/menu/lib/menu-item.component.d.ts +60 -0
- package/menu/lib/menu.component.d.ts +8 -10
- package/menu/lib/menu.module.d.ts +9 -9
- package/menu/lib/menu.service.d.ts +14 -3
- package/menu/lib/menu.types.d.ts +43 -0
- package/package.json +31 -31
- package/esm2022/menu/lib/class/popover.class.mjs +0 -2
- package/esm2022/menu/lib/class/root-menu.class.mjs +0 -8
- package/esm2022/menu/lib/menu-item/menu-item.component.mjs +0 -160
- package/menu/lib/class/popover.class.d.ts +0 -2
- package/menu/lib/class/root-menu.class.d.ts +0 -7
- package/menu/lib/menu-item/menu-item.component.d.ts +0 -81
@@ -76,4 +76,4 @@ export class AXSelectionValueChangedEvent extends AXValueChangedEvent {
|
|
76
76
|
*/
|
77
77
|
export class AXRangeChangedEvent extends AXEvent {
|
78
78
|
}
|
79
|
-
//# sourceMappingURL=data:application/json;base64,
|
79
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXZlbnRzLmNsYXNzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL2NvbW1vbi9zcmMvbGliL2NsYXNzZXMvZXZlbnRzLmNsYXNzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7R0FHRztBQUNILE1BQU0sT0FBTyxPQUFPO0lBQXBCO1FBVUUsc0JBQWlCLEdBQWEsS0FBSyxDQUFDO0lBQ3RDLENBQUM7Q0FBQTtBQUVEOzs7R0FHRztBQUNILE1BQU0sT0FBTyxXQUFxQyxTQUFRLE9BQU87Q0FFaEU7QUFFRDs7O0dBR0c7QUFDSCxNQUFNLE9BQU8sbUJBQTZCLFNBQVEsT0FBTztDQUl4RDtBQUVEOzs7R0FHRztBQUNILE1BQU0sT0FBTyxvQkFBOEIsU0FBUSxPQUFPO0NBSXpEO0FBRUQ7OztHQUdHO0FBQ0gsTUFBTSxPQUFPLFlBQWEsU0FBUSxXQUF1QjtJQUF6RDs7UUFDRTs7V0FFRztRQUNILFNBQUksR0FBUyxJQUFJLENBQUM7UUFFVCxnQkFBVyxHQUFTLElBQUksQ0FBQztJQUNwQyxDQUFDO0NBQUE7QUFFRDs7O0dBR0c7QUFDSCxNQUFNLE9BQU8sa0JBQW1CLFNBQVEsWUFBWTtDQUVuRDtBQUVEOzs7R0FHRztBQUNILE1BQU0sT0FBTyxnQkFBMEIsU0FBUSxZQUFZO0NBRzFEO0FBRUQ7OztHQUdHO0FBQ0gsTUFBTSxPQUFPLFlBQWEsU0FBUSxXQUF1QjtDQUFJO0FBRTdEOzs7R0FHRztBQUNILE1BQU0sT0FBTyw0QkFBNkIsU0FBUSxtQkFBZ0M7SUFBbEY7O1FBQ1csVUFBSyxHQUFTLElBQUksQ0FBQztRQUNuQixhQUFRLEdBQVMsSUFBSSxDQUFDO1FBQy9CLGlCQUFZLEdBQVcsRUFBRSxDQUFDO1FBQzFCLGtCQUFhLEdBQVcsRUFBRSxDQUFDO0lBQzdCLENBQUM7Q0FBQTtBQUVEOzs7R0FHRztBQUNILE1BQU0sT0FBTyxtQkFBdUIsU0FBUSxPQUFPO0NBU2xEIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiAgQ29udGFpbnMgbmF0aXZlIGV2ZW50XG4gKiBAY2F0ZWdvcnkgRXZlbnRzXG4gKi9cbmV4cG9ydCBjbGFzcyBBWEV2ZW50IHtcbiAgLyoqXG4gICAqICBUaGUgc2VuZGVyIGNvbXBvbmVudFxuICAgKi9cbiAgY29tcG9uZW50OiBhbnk7XG4gIC8qKlxuICAgKiAgVGhlIHJvb3QgbmF0aXZlIGVsZW1lbnRcbiAgICovXG4gIGh0bWxFbGVtZW50PzogSFRNTEVsZW1lbnQ7XG5cbiAgaXNVc2VySW50ZXJhY3Rpb24/OiBib29sZWFuID0gZmFsc2U7XG59XG5cbi8qKlxuICogIENvbnRhaW5zIG5hdGl2ZSBldmVudFxuICogQGNhdGVnb3J5IEV2ZW50c1xuICovXG5leHBvcnQgY2xhc3MgQVhIdG1sRXZlbnQ8RSBleHRlbmRzIEV2ZW50ID0gRXZlbnQ+IGV4dGVuZHMgQVhFdmVudCB7XG4gIG5hdGl2ZUV2ZW50PzogRTtcbn1cblxuLyoqXG4gKiAgQ29udGFpbnMgbmF0aXZlIGV2ZW50XG4gKiBAY2F0ZWdvcnkgRXZlbnRzXG4gKi9cbmV4cG9ydCBjbGFzcyBBWFZhbHVlQ2hhbmdlZEV2ZW50PFQgPSBhbnk+IGV4dGVuZHMgQVhFdmVudCB7XG4gIG5hbWU/OiBzdHJpbmc7XG4gIHZhbHVlPzogVDtcbiAgb2xkVmFsdWU/OiBUO1xufVxuXG4vKipcbiAqICBDb250YWlucyBuYXRpdmUgZXZlbnRcbiAqIEBjYXRlZ29yeSBFdmVudHNcbiAqL1xuZXhwb3J0IGNsYXNzIEFYT3B0aW9uQ2hhbmdlZEV2ZW50PFQgPSBhbnk+IGV4dGVuZHMgQVhFdmVudCB7XG4gIG5hbWU/OiBzdHJpbmc7XG4gIG5ld1ZhbHVlPzogVDtcbiAgb2xkVmFsdWU/OiBUO1xufVxuXG4vKipcbiAqICBGaXJlcyBlYWNoIHRpbWUgdGhlIHVzZXIgY2xpY2sgdGhlIGVsZW1lbnQuXG4gKiBAY2F0ZWdvcnkgRXZlbnRzXG4gKi9cbmV4cG9ydCBjbGFzcyBBWENsaWNrRXZlbnQgZXh0ZW5kcyBBWEh0bWxFdmVudDxNb3VzZUV2ZW50PiB7XG4gIC8qKlxuICAgKiAgdXNlcyBmb3IgZXh0cmEgZGF0YVxuICAgKi9cbiAgZGF0YT86IGFueSA9IG51bGw7XG5cbiAgb3ZlcnJpZGUgbmF0aXZlRXZlbnQ/OiBhbnkgPSBudWxsO1xufVxuXG4vKipcbiAqICBGaXJlcyBlYWNoIHRpbWUgdGhlIHVzZXIgY2xpY2sgdGhlIGVsZW1lbnQuXG4gKiBAY2F0ZWdvcnkgRXZlbnRzXG4gKi9cbmV4cG9ydCBjbGFzcyBBWEJ1dHRvbkNsaWNrRXZlbnQgZXh0ZW5kcyBBWENsaWNrRXZlbnQge1xuICBuYW1lOiBzdHJpbmc7XG59XG5cbi8qKlxuICogIEZpcmVzIGVhY2ggdGltZSB0aGUgdXNlciBjbGljayB0aGUgZWxlbWVudC5cbiAqIEBjYXRlZ29yeSBFdmVudHNcbiAqL1xuZXhwb3J0IGNsYXNzIEFYSXRlbUNsaWNrRXZlbnQ8VCA9IGFueT4gZXh0ZW5kcyBBWENsaWNrRXZlbnQge1xuICBuYW1lPzogc3RyaW5nO1xuICBpdGVtOiBUO1xufVxuXG4vKipcbiAqICBGaXJlcyBlYWNoIHRpbWUgdGhlIGNvbXBvbmVudCBnZXRzIGZvY3VzZWQuXG4gKiBAY2F0ZWdvcnkgRXZlbnRzXG4gKi9cbmV4cG9ydCBjbGFzcyBBWEZvY3VzRXZlbnQgZXh0ZW5kcyBBWEh0bWxFdmVudDxGb2N1c0V2ZW50PiB7IH1cblxuLyoqXG4gKiAgRmlyZXMgZWFjaCB0aW1lIGFuIGl0ZW0gb3IgbXVsdGlwbGUgaXRlbXMgc2VsZWN0ZWQgYnkgdGhlIHVzZXIgb3IgdmFsdWUuXG4gKiBAY2F0ZWdvcnkgRXZlbnRzXG4gKi9cbmV4cG9ydCBjbGFzcyBBWFNlbGVjdGlvblZhbHVlQ2hhbmdlZEV2ZW50IGV4dGVuZHMgQVhWYWx1ZUNoYW5nZWRFdmVudDxhbnkgfCBhbnlbXT4ge1xuICBvdmVycmlkZSB2YWx1ZT86IGFueSA9IG51bGw7XG4gIG92ZXJyaWRlIG9sZFZhbHVlPzogYW55ID0gbnVsbDtcbiAgc2VsZWN0ZWRLZXlzPzogYW55W10gPSBbXTtcbiAgc2VsZWN0ZWRJdGVtcz86IGFueVtdID0gW107XG59XG5cbi8qKlxuICogIENvbnRhaW5zIHJhbmdlIHN0YXJ0ICYgZW5kIHZhbHVlc1xuICogQGNhdGVnb3J5IEV2ZW50c1xuICovXG5leHBvcnQgY2xhc3MgQVhSYW5nZUNoYW5nZWRFdmVudDxUPiBleHRlbmRzIEFYRXZlbnQge1xuICAvKipcbiAgICogIFRoZSByYW5nZSBzdGFydCB2YWx1ZVxuICAgKi9cbiAgc3RhcnQ/OiBUO1xuICAvKipcbiAgICogIFRoZSByYW5nZSBlbmQgdmFsdWVcbiAgICovXG4gIGVuZD86IFQ7XG59XG4iXX0=
|
package/esm2022/menu/index.mjs
CHANGED
@@ -1,7 +1,7 @@
|
|
1
|
-
export * from './lib/
|
2
|
-
export * from './lib/
|
3
|
-
export * from './lib/
|
1
|
+
export * from './lib/menu.types';
|
2
|
+
export * from './lib/menu-item.component';
|
3
|
+
export * from './lib/context-menu.component';
|
4
4
|
export * from './lib/menu.component';
|
5
5
|
export * from './lib/menu.module';
|
6
6
|
export * from './lib/menu.service';
|
7
|
-
//# sourceMappingURL=data:application/json;base64,
|
7
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvbWVudS9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxrQkFBa0IsQ0FBQztBQUNqQyxjQUFjLDJCQUEyQixDQUFDO0FBQzFDLGNBQWMsOEJBQThCLENBQUM7QUFDN0MsY0FBYyxzQkFBc0IsQ0FBQztBQUNyQyxjQUFjLG1CQUFtQixDQUFDO0FBQ2xDLGNBQWMsb0JBQW9CLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2xpYi9tZW51LnR5cGVzJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL21lbnUtaXRlbS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29udGV4dC1tZW51LmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9tZW51LmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9tZW51Lm1vZHVsZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9tZW51LnNlcnZpY2UnO1xuIl19
|
@@ -0,0 +1,181 @@
|
|
1
|
+
import { MXBaseComponent } from '@acorex/components/common';
|
2
|
+
import { afterNextRender, ChangeDetectionStrategy, Component, HostBinding, HostListener, inject, input, output, Renderer2, signal, ViewEncapsulation, } from '@angular/core';
|
3
|
+
import { AXRootMenu } from './menu.types';
|
4
|
+
import { AXMenuService } from './menu.service';
|
5
|
+
import { AXHtmlUtil } from '@acorex/core/utils';
|
6
|
+
import { cloneDeep } from 'lodash-es';
|
7
|
+
import * as i0 from "@angular/core";
|
8
|
+
import * as i1 from "@angular/common";
|
9
|
+
import * as i2 from "@acorex/components/decorators";
|
10
|
+
import * as i3 from "./menu-item.component";
|
11
|
+
/**
|
12
|
+
* Represents a menu component that displays context menu.
|
13
|
+
* @category Components
|
14
|
+
*/
|
15
|
+
export class AXContextMenuComponent extends MXBaseComponent {
|
16
|
+
// Constructor (Dependency Injection)
|
17
|
+
/** @ignore */
|
18
|
+
constructor(renderer) {
|
19
|
+
super();
|
20
|
+
this.renderer = renderer;
|
21
|
+
// Inputs and Outputs
|
22
|
+
this.orientation = input('vertical');
|
23
|
+
this.openOn = input('hover');
|
24
|
+
this.closeOn = input('click');
|
25
|
+
this.orginalItems = input([], { alias: "items" });
|
26
|
+
this.target = input();
|
27
|
+
this.onItemClick = output();
|
28
|
+
this.onOpening = output();
|
29
|
+
// Injected Services
|
30
|
+
this.service = inject(AXMenuService);
|
31
|
+
// Private Properties
|
32
|
+
this.scrollableParents = [];
|
33
|
+
this.items = signal([]);
|
34
|
+
afterNextRender(() => {
|
35
|
+
if (this.target()) {
|
36
|
+
this.target().addEventListener('contextmenu', this.handleContextMenu.bind(this));
|
37
|
+
}
|
38
|
+
this.bindScrollEvents();
|
39
|
+
});
|
40
|
+
this.service.closeAllContextMenu$.subscribe(() => {
|
41
|
+
this.service.closeAll$.next();
|
42
|
+
this.close();
|
43
|
+
});
|
44
|
+
this.service.openContextMenu$.subscribe((e) => {
|
45
|
+
if (e.sender == this) {
|
46
|
+
this.internalShowAt(e.point);
|
47
|
+
}
|
48
|
+
});
|
49
|
+
}
|
50
|
+
// Lifecycle Hooks
|
51
|
+
ngOnDestroy() {
|
52
|
+
this.removeScrollEvents();
|
53
|
+
}
|
54
|
+
// Public Methods
|
55
|
+
showAt(point) {
|
56
|
+
const sender = this;
|
57
|
+
this.service.closeAllContextMenu$.next({ sender });
|
58
|
+
this.service.openContextMenu$.next({ sender, point });
|
59
|
+
}
|
60
|
+
close() {
|
61
|
+
const elementRef = this.getHostElement();
|
62
|
+
elementRef.classList.remove('ax-state-open');
|
63
|
+
}
|
64
|
+
// Private Methods (Internal Logic)
|
65
|
+
/** @ignore */
|
66
|
+
handleContextMenu(e) {
|
67
|
+
e.preventDefault();
|
68
|
+
e.stopPropagation();
|
69
|
+
//
|
70
|
+
const event = {
|
71
|
+
component: this,
|
72
|
+
htmlElement: this.getHostElement(),
|
73
|
+
nativeEvent: e,
|
74
|
+
canceled: false,
|
75
|
+
items: cloneDeep(this.orginalItems()),
|
76
|
+
};
|
77
|
+
this.onOpening.emit(event);
|
78
|
+
this.items.set(event.items);
|
79
|
+
//
|
80
|
+
if (!event.canceled) {
|
81
|
+
this.showAt({ x: e.clientX, y: e.clientY });
|
82
|
+
}
|
83
|
+
}
|
84
|
+
internalShowAt(point) {
|
85
|
+
const elementRef = this.getHostElement();
|
86
|
+
elementRef.classList.add('ax-state-open');
|
87
|
+
const itemRect = elementRef.getBoundingClientRect();
|
88
|
+
const windowWidth = window.innerWidth;
|
89
|
+
const windowHeight = window.innerHeight;
|
90
|
+
// Detect RTL (Right-To-Left) mode
|
91
|
+
const isRtl = AXHtmlUtil.isRtl(this.getHostElement());
|
92
|
+
let left;
|
93
|
+
if (isRtl) {
|
94
|
+
left = point.x - itemRect.width;
|
95
|
+
if (left < 0) {
|
96
|
+
left = point.x;
|
97
|
+
}
|
98
|
+
}
|
99
|
+
else {
|
100
|
+
left = point.x;
|
101
|
+
if (left + itemRect.width > windowWidth) {
|
102
|
+
left = point.x - itemRect.width;
|
103
|
+
}
|
104
|
+
}
|
105
|
+
const bottom = point.y + itemRect.height;
|
106
|
+
let top;
|
107
|
+
if (bottom > windowHeight) {
|
108
|
+
top = point.y - itemRect.height;
|
109
|
+
if (top < 0) {
|
110
|
+
top = 0;
|
111
|
+
}
|
112
|
+
}
|
113
|
+
else {
|
114
|
+
top = point.y;
|
115
|
+
}
|
116
|
+
this.renderer.setStyle(elementRef, 'left', `${left}px`);
|
117
|
+
this.renderer.setStyle(elementRef, 'top', `${top}px`);
|
118
|
+
this.renderer.setStyle(elementRef, 'position', 'fixed');
|
119
|
+
}
|
120
|
+
bindScrollEvents() {
|
121
|
+
this.scrollableParents = AXHtmlUtil.getScrollableParents(this.getHostElement());
|
122
|
+
this.scrollableParents.forEach((parent) => {
|
123
|
+
parent.addEventListener('scroll', this.onContainerScroll.bind(this));
|
124
|
+
});
|
125
|
+
}
|
126
|
+
removeScrollEvents() {
|
127
|
+
this.scrollableParents.forEach((parent) => {
|
128
|
+
parent.removeEventListener('scroll', this.onContainerScroll.bind(this));
|
129
|
+
});
|
130
|
+
}
|
131
|
+
onContainerScroll() {
|
132
|
+
this.service.closeAllContextMenu$.next({ sender: this });
|
133
|
+
}
|
134
|
+
// Host Listeners (UI Interaction Handling)
|
135
|
+
/** @ignore */
|
136
|
+
onClickOutside(event) {
|
137
|
+
const hostElement = this.getHostElement();
|
138
|
+
if (!hostElement.contains(event.target)) {
|
139
|
+
const sender = this;
|
140
|
+
this.service.closeAllContextMenu$.next({ sender });
|
141
|
+
}
|
142
|
+
}
|
143
|
+
onContextMenuOutside(event) {
|
144
|
+
if (!this.target().contains(event.target)) {
|
145
|
+
const sender = this;
|
146
|
+
this.service.closeAllContextMenu$.next({ sender });
|
147
|
+
}
|
148
|
+
}
|
149
|
+
/** @ignore */
|
150
|
+
get __hostClass() {
|
151
|
+
return ['ax-menu-container', `ax-orientation-${this.orientation()}`];
|
152
|
+
}
|
153
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: AXContextMenuComponent, deps: [{ token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Component }); }
|
154
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.0", type: AXContextMenuComponent, selector: "ax-context-menu", inputs: { orientation: { classPropertyName: "orientation", publicName: "orientation", isSignal: true, isRequired: false, transformFunction: null }, openOn: { classPropertyName: "openOn", publicName: "openOn", isSignal: true, isRequired: false, transformFunction: null }, closeOn: { classPropertyName: "closeOn", publicName: "closeOn", isSignal: true, isRequired: false, transformFunction: null }, orginalItems: { classPropertyName: "orginalItems", publicName: "items", isSignal: true, isRequired: false, transformFunction: null }, target: { classPropertyName: "target", publicName: "target", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { onItemClick: "onItemClick", onOpening: "onOpening" }, host: { listeners: { "document:click": "onClickOutside($event)", "document:contextmenu": "onContextMenuOutside($event)" }, properties: { "class": "this.__hostClass" } }, providers: [
|
155
|
+
AXMenuService,
|
156
|
+
{
|
157
|
+
provide: AXRootMenu,
|
158
|
+
useExisting: AXContextMenuComponent
|
159
|
+
}
|
160
|
+
], usesInheritance: true, ngImport: i0, template: "<ng-content select=\"ax-menu-item,ax-title,ng-container\"></ng-content>\n\n<ng-container *ngFor=\"let node of items()\" [ngTemplateOutlet]=\"Recursion\"\n [ngTemplateOutletContext]=\"{ $implicit: node }\">\n</ng-container>\n<ng-template #Recursion let-item>\n @if(item.group?.title)\n {\n <ax-title>{{item.group?.title}}</ax-title>\n }\n <ax-menu-item [name]=\"item.name\" [data]=\"item.data\" [disabled]=\"item.disabled\" [color]=\"item.color\">\n <ax-prefix>\n @if(item.icon)\n {\n <ax-icon [icon]=\"item.icon\">\n </ax-icon>\n }\n </ax-prefix>\n @if(item.text)\n {\n <ax-text>{{ item.text }}</ax-text>\n }\n @if(item.suffix)\n {\n <ax-suffix>\n <ax-text>{{ item.suffix.text }}</ax-text>\n </ax-suffix>\n }\n <ng-container *ngFor=\"let child of item.children\" [ngTemplateOutlet]=\"Recursion\"\n [ngTemplateOutletContext]=\"{ $implicit: child }\"></ng-container>\n </ax-menu-item>\n @if(item.break)\n {\n <ax-divider></ax-divider>\n }\n</ng-template>", styles: ["ax-context-menu,ax-menu{width:100%;color:inherit;display:flex;width:max-content}ax-context-menu.ax-orientation-horizontal,ax-menu.ax-orientation-horizontal{flex-direction:row!important}ax-context-menu.ax-orientation-vertical,ax-menu.ax-orientation-vertical{flex-direction:column!important}ax-context-menu ax-title,ax-menu ax-title{display:block;padding-inline:1rem;padding-block:.25rem;font-size:.75rem;line-height:1rem;font-weight:bolder;text-transform:uppercase;opacity:.5}ax-context-menu ax-divider,ax-menu ax-divider{margin-top:.25rem;margin-bottom:.25rem;height:.5px;width:100%;background-color:rgba(var(--ax-color-border-default))}ax-context-menu ax-menu-item,ax-menu ax-menu-item{display:flex;align-items:center;font-size:.875rem;line-height:1.25rem;justify-content:space-between;color:rgba(var(--ax-color-text-default));height:2.25rem;cursor:pointer}ax-context-menu ax-menu-item>.ax-menu-item-prefix,ax-menu ax-menu-item>.ax-menu-item-prefix{display:flex;gap:.5rem}ax-context-menu ax-menu-item.ax-state-disabled,ax-menu ax-menu-item.ax-state-disabled{cursor:not-allowed;opacity:.5}ax-context-menu ax-menu-item ax-suffix ax-text,ax-menu ax-menu-item ax-suffix ax-text{color:rgba(var(--ax-color-text-default))!important;opacity:.5!important;font-weight:200!important;padding-inline-start:2rem}ax-context-menu.ax-menu-container,ax-context-menu .ax-menu-items,ax-menu.ax-menu-container,ax-menu .ax-menu-items{padding-block:.5rem;display:flex;opacity:0;visibility:hidden;transition:opacity .3s;width:max-content;min-width:12rem;height:max-content;position:fixed;flex-direction:column;border-radius:0;border-width:1px;border-color:rgba(var(--ax-color-border-default));background-color:rgba(var(--ax-color-surface));--ax-shadow: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--ax-shadow-colored: 0 4px 6px -1px var(--ax-shadow-color), 0 2px 4px -2px var(--ax-shadow-color);box-shadow:var(--ax-ring-offset-shadow, 0 0 rgba(0, 0, 0, 0)),var(--ax-ring-shadow, 0 0 rgba(0, 0, 0, 0)),var(--ax-shadow);border-radius:var(--ax-rounded-border-default);z-index:9999}ax-context-menu.ax-menu-container.ax-state-open,ax-context-menu .ax-menu-items.ax-state-open,ax-menu.ax-menu-container.ax-state-open,ax-menu .ax-menu-items.ax-state-open{opacity:1;visibility:visible}ax-context-menu.ax-menu-container ax-menu-item,ax-context-menu .ax-menu-items ax-menu-item,ax-menu.ax-menu-container ax-menu-item,ax-menu .ax-menu-items ax-menu-item{padding-inline:1rem;padding-block:.5rem}ax-context-menu.ax-menu-container ax-menu-item ax-prefix,ax-context-menu .ax-menu-items ax-menu-item ax-prefix,ax-menu.ax-menu-container ax-menu-item ax-prefix,ax-menu .ax-menu-items ax-menu-item ax-prefix{width:1rem}ax-context-menu.ax-menu-container ax-menu-item:hover:not(ax-context-menu.ax-menu-container ax-menu-item:hover.ax-state-disabled,ax-context-menu .ax-menu-items ax-menu-item:hover.ax-state-disabled,ax-menu.ax-menu-container ax-menu-item:hover.ax-state-disabled,ax-menu .ax-menu-items ax-menu-item:hover.ax-state-disabled),ax-context-menu .ax-menu-items ax-menu-item:hover:not(ax-context-menu.ax-menu-container ax-menu-item:hover.ax-state-disabled,ax-context-menu .ax-menu-items ax-menu-item:hover.ax-state-disabled,ax-menu.ax-menu-container ax-menu-item:hover.ax-state-disabled,ax-menu .ax-menu-items ax-menu-item:hover.ax-state-disabled),ax-menu.ax-menu-container ax-menu-item:hover:not(ax-context-menu.ax-menu-container ax-menu-item:hover.ax-state-disabled,ax-context-menu .ax-menu-items ax-menu-item:hover.ax-state-disabled,ax-menu.ax-menu-container ax-menu-item:hover.ax-state-disabled,ax-menu .ax-menu-items ax-menu-item:hover.ax-state-disabled),ax-menu .ax-menu-items ax-menu-item:hover:not(ax-context-menu.ax-menu-container ax-menu-item:hover.ax-state-disabled,ax-context-menu .ax-menu-items ax-menu-item:hover.ax-state-disabled,ax-menu.ax-menu-container ax-menu-item:hover.ax-state-disabled,ax-menu .ax-menu-items ax-menu-item:hover.ax-state-disabled){background-color:rgba(var(--ax-color-on-surface))}ax-context-menu.ax-menu-container ax-menu-item:hover:not(ax-context-menu.ax-menu-container ax-menu-item:hover.ax-state-disabled,ax-context-menu .ax-menu-items ax-menu-item:hover.ax-state-disabled,ax-menu.ax-menu-container ax-menu-item:hover.ax-state-disabled,ax-menu .ax-menu-items ax-menu-item:hover.ax-state-disabled) ax-prefix,ax-context-menu.ax-menu-container ax-menu-item:hover:not(ax-context-menu.ax-menu-container ax-menu-item:hover.ax-state-disabled,ax-context-menu .ax-menu-items ax-menu-item:hover.ax-state-disabled,ax-menu.ax-menu-container ax-menu-item:hover.ax-state-disabled,ax-menu .ax-menu-items ax-menu-item:hover.ax-state-disabled) ax-suffix,ax-context-menu .ax-menu-items ax-menu-item:hover:not(ax-context-menu.ax-menu-container ax-menu-item:hover.ax-state-disabled,ax-context-menu .ax-menu-items ax-menu-item:hover.ax-state-disabled,ax-menu.ax-menu-container ax-menu-item:hover.ax-state-disabled,ax-menu .ax-menu-items ax-menu-item:hover.ax-state-disabled) ax-prefix,ax-context-menu .ax-menu-items ax-menu-item:hover:not(ax-context-menu.ax-menu-container ax-menu-item:hover.ax-state-disabled,ax-context-menu .ax-menu-items ax-menu-item:hover.ax-state-disabled,ax-menu.ax-menu-container ax-menu-item:hover.ax-state-disabled,ax-menu .ax-menu-items ax-menu-item:hover.ax-state-disabled) ax-suffix,ax-menu.ax-menu-container ax-menu-item:hover:not(ax-context-menu.ax-menu-container ax-menu-item:hover.ax-state-disabled,ax-context-menu .ax-menu-items ax-menu-item:hover.ax-state-disabled,ax-menu.ax-menu-container ax-menu-item:hover.ax-state-disabled,ax-menu .ax-menu-items ax-menu-item:hover.ax-state-disabled) ax-prefix,ax-menu.ax-menu-container ax-menu-item:hover:not(ax-context-menu.ax-menu-container ax-menu-item:hover.ax-state-disabled,ax-context-menu .ax-menu-items ax-menu-item:hover.ax-state-disabled,ax-menu.ax-menu-container ax-menu-item:hover.ax-state-disabled,ax-menu .ax-menu-items ax-menu-item:hover.ax-state-disabled) ax-suffix,ax-menu .ax-menu-items ax-menu-item:hover:not(ax-context-menu.ax-menu-container ax-menu-item:hover.ax-state-disabled,ax-context-menu .ax-menu-items ax-menu-item:hover.ax-state-disabled,ax-menu.ax-menu-container ax-menu-item:hover.ax-state-disabled,ax-menu .ax-menu-items ax-menu-item:hover.ax-state-disabled) ax-prefix,ax-menu .ax-menu-items ax-menu-item:hover:not(ax-context-menu.ax-menu-container ax-menu-item:hover.ax-state-disabled,ax-context-menu .ax-menu-items ax-menu-item:hover.ax-state-disabled,ax-menu.ax-menu-container ax-menu-item:hover.ax-state-disabled,ax-menu .ax-menu-items ax-menu-item:hover.ax-state-disabled) ax-suffix{opacity:1}ax-context-menu.ax-orientation-horizontal{padding-inline:1rem}ax-menu.ax-orientation-horizontal{min-width:12rem;gap:.875rem}ax-menu.ax-orientation-horizontal>ax-menu-item{font-weight:500}ax-menu.ax-orientation-vertical{width:max-content;min-width:12rem}ax-menu.ax-orientation-vertical>ax-menu-item{padding-inline:1rem;font-weight:500}ax-menu>ax-menu-item{padding-block:.5rem}ax-menu>ax-menu-item:hover:not(ax-menu>ax-menu-item:hover.ax-state-disabled)>ax-icon,ax-menu>ax-menu-item:hover:not(ax-menu>ax-menu-item:hover.ax-state-disabled)>ax-text{color:rgba(var(--ax-color-primary-500))}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i2.AXDecoratorIconComponent, selector: "ax-icon", inputs: ["icon"] }, { kind: "component", type: i2.AXDecoratorGenericComponent, selector: "ax-footer, ax-header, ax-content, ax-divider, ax-form-hint, ax-prefix, ax-suffix, ax-text, ax-title, ax-sub-title, ax-placeholder, ax-overlay" }, { kind: "component", type: i3.AXMenuItemComponent, selector: "ax-menu-item", inputs: ["name", "data", "disabled", "color"], outputs: ["onClick"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
|
161
|
+
}
|
162
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: AXContextMenuComponent, decorators: [{
|
163
|
+
type: Component,
|
164
|
+
args: [{ selector: 'ax-context-menu', changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, providers: [
|
165
|
+
AXMenuService,
|
166
|
+
{
|
167
|
+
provide: AXRootMenu,
|
168
|
+
useExisting: AXContextMenuComponent
|
169
|
+
}
|
170
|
+
], template: "<ng-content select=\"ax-menu-item,ax-title,ng-container\"></ng-content>\n\n<ng-container *ngFor=\"let node of items()\" [ngTemplateOutlet]=\"Recursion\"\n [ngTemplateOutletContext]=\"{ $implicit: node }\">\n</ng-container>\n<ng-template #Recursion let-item>\n @if(item.group?.title)\n {\n <ax-title>{{item.group?.title}}</ax-title>\n }\n <ax-menu-item [name]=\"item.name\" [data]=\"item.data\" [disabled]=\"item.disabled\" [color]=\"item.color\">\n <ax-prefix>\n @if(item.icon)\n {\n <ax-icon [icon]=\"item.icon\">\n </ax-icon>\n }\n </ax-prefix>\n @if(item.text)\n {\n <ax-text>{{ item.text }}</ax-text>\n }\n @if(item.suffix)\n {\n <ax-suffix>\n <ax-text>{{ item.suffix.text }}</ax-text>\n </ax-suffix>\n }\n <ng-container *ngFor=\"let child of item.children\" [ngTemplateOutlet]=\"Recursion\"\n [ngTemplateOutletContext]=\"{ $implicit: child }\"></ng-container>\n </ax-menu-item>\n @if(item.break)\n {\n <ax-divider></ax-divider>\n }\n</ng-template>", styles: ["ax-context-menu,ax-menu{width:100%;color:inherit;display:flex;width:max-content}ax-context-menu.ax-orientation-horizontal,ax-menu.ax-orientation-horizontal{flex-direction:row!important}ax-context-menu.ax-orientation-vertical,ax-menu.ax-orientation-vertical{flex-direction:column!important}ax-context-menu ax-title,ax-menu ax-title{display:block;padding-inline:1rem;padding-block:.25rem;font-size:.75rem;line-height:1rem;font-weight:bolder;text-transform:uppercase;opacity:.5}ax-context-menu ax-divider,ax-menu ax-divider{margin-top:.25rem;margin-bottom:.25rem;height:.5px;width:100%;background-color:rgba(var(--ax-color-border-default))}ax-context-menu ax-menu-item,ax-menu ax-menu-item{display:flex;align-items:center;font-size:.875rem;line-height:1.25rem;justify-content:space-between;color:rgba(var(--ax-color-text-default));height:2.25rem;cursor:pointer}ax-context-menu ax-menu-item>.ax-menu-item-prefix,ax-menu ax-menu-item>.ax-menu-item-prefix{display:flex;gap:.5rem}ax-context-menu ax-menu-item.ax-state-disabled,ax-menu ax-menu-item.ax-state-disabled{cursor:not-allowed;opacity:.5}ax-context-menu ax-menu-item ax-suffix ax-text,ax-menu ax-menu-item ax-suffix ax-text{color:rgba(var(--ax-color-text-default))!important;opacity:.5!important;font-weight:200!important;padding-inline-start:2rem}ax-context-menu.ax-menu-container,ax-context-menu .ax-menu-items,ax-menu.ax-menu-container,ax-menu .ax-menu-items{padding-block:.5rem;display:flex;opacity:0;visibility:hidden;transition:opacity .3s;width:max-content;min-width:12rem;height:max-content;position:fixed;flex-direction:column;border-radius:0;border-width:1px;border-color:rgba(var(--ax-color-border-default));background-color:rgba(var(--ax-color-surface));--ax-shadow: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--ax-shadow-colored: 0 4px 6px -1px var(--ax-shadow-color), 0 2px 4px -2px var(--ax-shadow-color);box-shadow:var(--ax-ring-offset-shadow, 0 0 rgba(0, 0, 0, 0)),var(--ax-ring-shadow, 0 0 rgba(0, 0, 0, 0)),var(--ax-shadow);border-radius:var(--ax-rounded-border-default);z-index:9999}ax-context-menu.ax-menu-container.ax-state-open,ax-context-menu .ax-menu-items.ax-state-open,ax-menu.ax-menu-container.ax-state-open,ax-menu .ax-menu-items.ax-state-open{opacity:1;visibility:visible}ax-context-menu.ax-menu-container ax-menu-item,ax-context-menu .ax-menu-items ax-menu-item,ax-menu.ax-menu-container ax-menu-item,ax-menu .ax-menu-items ax-menu-item{padding-inline:1rem;padding-block:.5rem}ax-context-menu.ax-menu-container ax-menu-item ax-prefix,ax-context-menu .ax-menu-items ax-menu-item ax-prefix,ax-menu.ax-menu-container ax-menu-item ax-prefix,ax-menu .ax-menu-items ax-menu-item ax-prefix{width:1rem}ax-context-menu.ax-menu-container ax-menu-item:hover:not(ax-context-menu.ax-menu-container ax-menu-item:hover.ax-state-disabled,ax-context-menu .ax-menu-items ax-menu-item:hover.ax-state-disabled,ax-menu.ax-menu-container ax-menu-item:hover.ax-state-disabled,ax-menu .ax-menu-items ax-menu-item:hover.ax-state-disabled),ax-context-menu .ax-menu-items ax-menu-item:hover:not(ax-context-menu.ax-menu-container ax-menu-item:hover.ax-state-disabled,ax-context-menu .ax-menu-items ax-menu-item:hover.ax-state-disabled,ax-menu.ax-menu-container ax-menu-item:hover.ax-state-disabled,ax-menu .ax-menu-items ax-menu-item:hover.ax-state-disabled),ax-menu.ax-menu-container ax-menu-item:hover:not(ax-context-menu.ax-menu-container ax-menu-item:hover.ax-state-disabled,ax-context-menu .ax-menu-items ax-menu-item:hover.ax-state-disabled,ax-menu.ax-menu-container ax-menu-item:hover.ax-state-disabled,ax-menu .ax-menu-items ax-menu-item:hover.ax-state-disabled),ax-menu .ax-menu-items ax-menu-item:hover:not(ax-context-menu.ax-menu-container ax-menu-item:hover.ax-state-disabled,ax-context-menu .ax-menu-items ax-menu-item:hover.ax-state-disabled,ax-menu.ax-menu-container ax-menu-item:hover.ax-state-disabled,ax-menu .ax-menu-items ax-menu-item:hover.ax-state-disabled){background-color:rgba(var(--ax-color-on-surface))}ax-context-menu.ax-menu-container ax-menu-item:hover:not(ax-context-menu.ax-menu-container ax-menu-item:hover.ax-state-disabled,ax-context-menu .ax-menu-items ax-menu-item:hover.ax-state-disabled,ax-menu.ax-menu-container ax-menu-item:hover.ax-state-disabled,ax-menu .ax-menu-items ax-menu-item:hover.ax-state-disabled) ax-prefix,ax-context-menu.ax-menu-container ax-menu-item:hover:not(ax-context-menu.ax-menu-container ax-menu-item:hover.ax-state-disabled,ax-context-menu .ax-menu-items ax-menu-item:hover.ax-state-disabled,ax-menu.ax-menu-container ax-menu-item:hover.ax-state-disabled,ax-menu .ax-menu-items ax-menu-item:hover.ax-state-disabled) ax-suffix,ax-context-menu .ax-menu-items ax-menu-item:hover:not(ax-context-menu.ax-menu-container ax-menu-item:hover.ax-state-disabled,ax-context-menu .ax-menu-items ax-menu-item:hover.ax-state-disabled,ax-menu.ax-menu-container ax-menu-item:hover.ax-state-disabled,ax-menu .ax-menu-items ax-menu-item:hover.ax-state-disabled) ax-prefix,ax-context-menu .ax-menu-items ax-menu-item:hover:not(ax-context-menu.ax-menu-container ax-menu-item:hover.ax-state-disabled,ax-context-menu .ax-menu-items ax-menu-item:hover.ax-state-disabled,ax-menu.ax-menu-container ax-menu-item:hover.ax-state-disabled,ax-menu .ax-menu-items ax-menu-item:hover.ax-state-disabled) ax-suffix,ax-menu.ax-menu-container ax-menu-item:hover:not(ax-context-menu.ax-menu-container ax-menu-item:hover.ax-state-disabled,ax-context-menu .ax-menu-items ax-menu-item:hover.ax-state-disabled,ax-menu.ax-menu-container ax-menu-item:hover.ax-state-disabled,ax-menu .ax-menu-items ax-menu-item:hover.ax-state-disabled) ax-prefix,ax-menu.ax-menu-container ax-menu-item:hover:not(ax-context-menu.ax-menu-container ax-menu-item:hover.ax-state-disabled,ax-context-menu .ax-menu-items ax-menu-item:hover.ax-state-disabled,ax-menu.ax-menu-container ax-menu-item:hover.ax-state-disabled,ax-menu .ax-menu-items ax-menu-item:hover.ax-state-disabled) ax-suffix,ax-menu .ax-menu-items ax-menu-item:hover:not(ax-context-menu.ax-menu-container ax-menu-item:hover.ax-state-disabled,ax-context-menu .ax-menu-items ax-menu-item:hover.ax-state-disabled,ax-menu.ax-menu-container ax-menu-item:hover.ax-state-disabled,ax-menu .ax-menu-items ax-menu-item:hover.ax-state-disabled) ax-prefix,ax-menu .ax-menu-items ax-menu-item:hover:not(ax-context-menu.ax-menu-container ax-menu-item:hover.ax-state-disabled,ax-context-menu .ax-menu-items ax-menu-item:hover.ax-state-disabled,ax-menu.ax-menu-container ax-menu-item:hover.ax-state-disabled,ax-menu .ax-menu-items ax-menu-item:hover.ax-state-disabled) ax-suffix{opacity:1}ax-context-menu.ax-orientation-horizontal{padding-inline:1rem}ax-menu.ax-orientation-horizontal{min-width:12rem;gap:.875rem}ax-menu.ax-orientation-horizontal>ax-menu-item{font-weight:500}ax-menu.ax-orientation-vertical{width:max-content;min-width:12rem}ax-menu.ax-orientation-vertical>ax-menu-item{padding-inline:1rem;font-weight:500}ax-menu>ax-menu-item{padding-block:.5rem}ax-menu>ax-menu-item:hover:not(ax-menu>ax-menu-item:hover.ax-state-disabled)>ax-icon,ax-menu>ax-menu-item:hover:not(ax-menu>ax-menu-item:hover.ax-state-disabled)>ax-text{color:rgba(var(--ax-color-primary-500))}\n"] }]
|
171
|
+
}], ctorParameters: () => [{ type: i0.Renderer2 }], propDecorators: { onClickOutside: [{
|
172
|
+
type: HostListener,
|
173
|
+
args: ['document:click', ['$event']]
|
174
|
+
}], onContextMenuOutside: [{
|
175
|
+
type: HostListener,
|
176
|
+
args: ['document:contextmenu', ['$event']]
|
177
|
+
}], __hostClass: [{
|
178
|
+
type: HostBinding,
|
179
|
+
args: ['class']
|
180
|
+
}] } });
|
181
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"context-menu.component.js","sourceRoot":"","sources":["../../../../../../libs/components/menu/src/lib/context-menu.component.ts","../../../../../../libs/components/menu/src/lib/menu.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAiB,eAAe,EAAE,MAAM,2BAA2B,CAAC;AAC3E,OAAO,EACH,eAAe,EACf,uBAAuB,EACvB,SAAS,EACT,WAAW,EACX,YAAY,EACZ,MAAM,EACN,KAAK,EACL,MAAM,EACN,SAAS,EACT,MAAM,EACN,iBAAiB,GACpB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAsG,UAAU,EAAE,MAAM,cAAc,CAAC;AAC9I,OAAO,EAAE,aAAa,EAAE,MAAM,gBAAgB,CAAC;AAC/C,OAAO,EAAE,UAAU,EAAW,MAAM,oBAAoB,CAAC;AACzD,OAAO,EAAE,SAAS,EAAE,MAAM,WAAW,CAAC;;;;;AAEtC;;;GAGG;AAeH,MAAM,OAAO,sBAAuB,SAAQ,eAAe;IAiBvD,qCAAqC;IAErC,cAAc;IACd,YAAoB,QAAmB;QACnC,KAAK,EAAE,CAAC;QADQ,aAAQ,GAAR,QAAQ,CAAW;QAlBvC,qBAAqB;QAErB,gBAAW,GAAG,KAAK,CAAgB,UAAU,CAAC,CAAC;QAC/C,WAAM,GAAG,KAAK,CAAoB,OAAO,CAAC,CAAC;QAC3C,YAAO,GAAG,KAAK,CAAqB,OAAO,CAAC,CAAC;QAC7C,iBAAY,GAAG,KAAK,CAAe,EAAE,EAAE,EAAE,KAAK,EAAE,OAAO,EAAE,CAAC,CAAC;QAC3D,WAAM,GAAG,KAAK,EAAe,CAAC;QAE9B,gBAAW,GAAG,MAAM,EAAwB,CAAC;QAC7C,cAAS,GAAG,MAAM,EAA6B,CAAC;QAEhD,oBAAoB;QAEpB,YAAO,GAAG,MAAM,CAAC,aAAa,CAAC,CAAC;QA6ChC,qBAAqB;QAEb,sBAAiB,GAAkB,EAAE,CAAC;QAEpC,UAAK,GAAG,MAAM,CAAe,EAAE,CAAC,CAAC;QA1CvC,eAAe,CAAC,GAAG,EAAE;YACjB,IAAI,IAAI,CAAC,MAAM,EAAE,EAAE,CAAC;gBAChB,IAAI,CAAC,MAAM,EAAE,CAAC,gBAAgB,CAAC,aAAa,EAAE,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;YACrF,CAAC;YACD,IAAI,CAAC,gBAAgB,EAAE,CAAC;QAC5B,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,OAAO,CAAC,oBAAoB,CAAC,SAAS,CAAC,GAAG,EAAE;YAC7C,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,IAAI,EAAE,CAAC;YAC9B,IAAI,CAAC,KAAK,EAAE,CAAC;QACjB,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,OAAO,CAAC,gBAAgB,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE;YAC1C,IAAI,CAAC,CAAC,MAAa,IAAI,IAAI,EAAE,CAAC;gBAC1B,IAAI,CAAC,cAAc,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;YACjC,CAAC;QACL,CAAC,CAAC,CAAC;IACP,CAAC;IAED,kBAAkB;IAElB,WAAW;QACP,IAAI,CAAC,kBAAkB,EAAE,CAAC;IAC9B,CAAC;IAED,iBAAiB;IAEV,MAAM,CAAC,KAAc;QACxB,MAAM,MAAM,GAAG,IAAyB,CAAC;QACzC,IAAI,CAAC,OAAO,CAAC,oBAAoB,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,CAAC,CAAC;QACnD,IAAI,CAAC,OAAO,CAAC,gBAAgB,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,CAAC;IAC1D,CAAC;IAEM,KAAK;QACR,MAAM,UAAU,GAAG,IAAI,CAAC,cAAc,EAAE,CAAC;QACzC,UAAU,CAAC,SAAS,CAAC,MAAM,CAAC,eAAe,CAAC,CAAC;IACjD,CAAC;IAQD,mCAAmC;IAEnC,cAAc;IACN,iBAAiB,CAAC,CAAa;QACnC,CAAC,CAAC,cAAc,EAAE,CAAC;QACnB,CAAC,CAAC,eAAe,EAAE,CAAC;QACpB,EAAE;QACF,MAAM,KAAK,GAAG;YACV,SAAS,EAAE,IAAI;YACf,WAAW,EAAE,IAAI,CAAC,cAAc,EAAE;YAClC,WAAW,EAAE,CAAC;YACd,QAAQ,EAAE,KAAK;YACf,KAAK,EAAE,SAAS,CAAC,IAAI,CAAC,YAAY,EAAE,CAAC;SACX,CAAC;QAC/B,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC3B,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;QAC5B,EAAE;QACF,IAAI,CAAC,KAAK,CAAC,QAAQ,EAAE,CAAC;YAClB,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,OAAO,EAAE,CAAC,EAAE,CAAC,CAAC,OAAO,EAAE,CAAC,CAAC;QAChD,CAAC;IACL,CAAC;IAEO,cAAc,CAAC,KAAc;QACjC,MAAM,UAAU,GAAG,IAAI,CAAC,cAAc,EAAE,CAAC;QACzC,UAAU,CAAC,SAAS,CAAC,GAAG,CAAC,eAAe,CAAC,CAAC;QAC1C,MAAM,QAAQ,GAAG,UAAU,CAAC,qBAAqB,EAAE,CAAC;QACpD,MAAM,WAAW,GAAG,MAAM,CAAC,UAAU,CAAC;QACtC,MAAM,YAAY,GAAG,MAAM,CAAC,WAAW,CAAC;QAExC,kCAAkC;QAClC,MAAM,KAAK,GAAG,UAAU,CAAC,KAAK,CAAC,IAAI,CAAC,cAAc,EAAE,CAAC,CAAC;QAEtD,IAAI,IAAY,CAAC;QACjB,IAAI,KAAK,EAAE,CAAC;YACR,IAAI,GAAG,KAAK,CAAC,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC;YAChC,IAAI,IAAI,GAAG,CAAC,EAAE,CAAC;gBACX,IAAI,GAAG,KAAK,CAAC,CAAC,CAAC;YACnB,CAAC;QACL,CAAC;aAAM,CAAC;YACJ,IAAI,GAAG,KAAK,CAAC,CAAC,CAAC;YACf,IAAI,IAAI,GAAG,QAAQ,CAAC,KAAK,GAAG,WAAW,EAAE,CAAC;gBACtC,IAAI,GAAG,KAAK,CAAC,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC;YACpC,CAAC;QACL,CAAC;QAED,MAAM,MAAM,GAAG,KAAK,CAAC,CAAC,GAAG,QAAQ,CAAC,MAAM,CAAC;QACzC,IAAI,GAAW,CAAC;QAEhB,IAAI,MAAM,GAAG,YAAY,EAAE,CAAC;YACxB,GAAG,GAAG,KAAK,CAAC,CAAC,GAAG,QAAQ,CAAC,MAAM,CAAC;YAChC,IAAI,GAAG,GAAG,CAAC,EAAE,CAAC;gBACV,GAAG,GAAG,CAAC,CAAC;YACZ,CAAC;QACL,CAAC;aAAM,CAAC;YACJ,GAAG,GAAG,KAAK,CAAC,CAAC,CAAC;QAClB,CAAC;QAED,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,UAAU,EAAE,MAAM,EAAE,GAAG,IAAI,IAAI,CAAC,CAAC;QACxD,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,UAAU,EAAE,KAAK,EAAE,GAAG,GAAG,IAAI,CAAC,CAAC;QACtD,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,UAAU,EAAE,UAAU,EAAE,OAAO,CAAC,CAAC;IAC5D,CAAC;IAEO,gBAAgB;QACpB,IAAI,CAAC,iBAAiB,GAAG,UAAU,CAAC,oBAAoB,CAAC,IAAI,CAAC,cAAc,EAAE,CAAC,CAAC;QAChF,IAAI,CAAC,iBAAiB,CAAC,OAAO,CAAC,CAAC,MAAM,EAAE,EAAE;YACtC,MAAM,CAAC,gBAAgB,CAAC,QAAQ,EAAE,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;QACzE,CAAC,CAAC,CAAC;IACP,CAAC;IAEO,kBAAkB;QACtB,IAAI,CAAC,iBAAiB,CAAC,OAAO,CAAC,CAAC,MAAM,EAAE,EAAE;YACtC,MAAM,CAAC,mBAAmB,CAAC,QAAQ,EAAE,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;QAC5E,CAAC,CAAC,CAAC;IACP,CAAC;IAEO,iBAAiB;QACrB,IAAI,CAAC,OAAO,CAAC,oBAAoB,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,IAAyB,EAAE,CAAC,CAAC;IAClF,CAAC;IAED,2CAA2C;IAE3C,cAAc;IAEN,cAAc,CAAC,KAAiB;QACpC,MAAM,WAAW,GAAG,IAAI,CAAC,cAAc,EAAE,CAAC;QAC1C,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,KAAK,CAAC,MAAc,CAAC,EAAE,CAAC;YAC9C,MAAM,MAAM,GAAG,IAAyB,CAAC;YACzC,IAAI,CAAC,OAAO,CAAC,oBAAoB,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,CAAC,CAAC;QACvD,CAAC;IACL,CAAC;IAGO,oBAAoB,CAAC,KAAiB;QAC1C,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,QAAQ,CAAC,KAAK,CAAC,MAAc,CAAC,EAAE,CAAC;YAChD,MAAM,MAAM,GAAG,IAAyB,CAAC;YACzC,IAAI,CAAC,OAAO,CAAC,oBAAoB,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,CAAC,CAAC;QACvD,CAAC;IACL,CAAC;IAED,cAAc;IACd,IACI,WAAW;QACX,OAAO,CAAC,mBAAmB,EAAE,kBAAkB,IAAI,CAAC,WAAW,EAAE,EAAE,CAAC,CAAC;IACzE,CAAC;8GAzKQ,sBAAsB;kGAAtB,sBAAsB,q6BARpB;YACP,aAAa;YACb;gBACI,OAAO,EAAE,UAAU;gBACnB,WAAW,EAAE,sBAAsB;aACtC;SACJ,iDCnCL,4nCAmCc;;2FDED,sBAAsB;kBAdlC,SAAS;+BACI,iBAAiB,mBAGV,uBAAuB,CAAC,MAAM,iBAChC,iBAAiB,CAAC,IAAI,aAC1B;wBACP,aAAa;wBACb;4BACI,OAAO,EAAE,UAAU;4BACnB,WAAW,wBAAwB;yBACtC;qBACJ;8EAuJO,cAAc;sBADrB,YAAY;uBAAC,gBAAgB,EAAE,CAAC,QAAQ,CAAC;gBAUlC,oBAAoB;sBAD3B,YAAY;uBAAC,sBAAsB,EAAE,CAAC,QAAQ,CAAC;gBAU5C,WAAW;sBADd,WAAW;uBAAC,OAAO","sourcesContent":["import { AXOrientation, MXBaseComponent } from '@acorex/components/common';\nimport {\n    afterNextRender,\n    ChangeDetectionStrategy,\n    Component,\n    HostBinding,\n    HostListener,\n    inject,\n    input,\n    output,\n    Renderer2,\n    signal,\n    ViewEncapsulation,\n} from '@angular/core';\nimport { AXContextMenuOpeningEvent, AXMenuCloseTrigger, AXMenuItem, AXMenuItemClickEvent, AXMenuOpenTrigger, AXRootMenu } from './menu.types';\nimport { AXMenuService } from './menu.service';\nimport { AXHtmlUtil, AXPoint } from '@acorex/core/utils';\nimport { cloneDeep } from 'lodash-es';\n\n/**\n * Represents a menu component that displays context menu.\n * @category Components\n */\n@Component({\n    selector: 'ax-context-menu',\n    templateUrl: './menu.component.html',\n    styleUrls: ['./menu.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    encapsulation: ViewEncapsulation.None,\n    providers: [\n        AXMenuService,\n        {\n            provide: AXRootMenu,\n            useExisting: AXContextMenuComponent\n        }\n    ]\n})\nexport class AXContextMenuComponent extends MXBaseComponent {\n\n    // Inputs and Outputs\n\n    orientation = input<AXOrientation>('vertical');\n    openOn = input<AXMenuOpenTrigger>('hover');\n    closeOn = input<AXMenuCloseTrigger>('click');\n    orginalItems = input<AXMenuItem[]>([], { alias: \"items\" });\n    target = input<HTMLElement>();\n\n    onItemClick = output<AXMenuItemClickEvent>();\n    onOpening = output<AXContextMenuOpeningEvent>();\n\n    // Injected Services\n\n    service = inject(AXMenuService);\n\n    // Constructor (Dependency Injection)\n\n    /** @ignore */\n    constructor(private renderer: Renderer2) {\n        super();\n        afterNextRender(() => {\n            if (this.target()) {\n                this.target().addEventListener('contextmenu', this.handleContextMenu.bind(this));\n            }\n            this.bindScrollEvents();\n        });\n\n        this.service.closeAllContextMenu$.subscribe(() => {\n            this.service.closeAll$.next();\n            this.close();\n        });\n\n        this.service.openContextMenu$.subscribe((e) => {\n            if (e.sender as any == this) {\n                this.internalShowAt(e.point);\n            }\n        });\n    }\n\n    // Lifecycle Hooks\n\n    ngOnDestroy() {\n        this.removeScrollEvents();\n    }\n\n    // Public Methods\n\n    public showAt(point: AXPoint) {\n        const sender = this as any as AXRootMenu;\n        this.service.closeAllContextMenu$.next({ sender });\n        this.service.openContextMenu$.next({ sender, point });\n    }\n\n    public close() {\n        const elementRef = this.getHostElement();\n        elementRef.classList.remove('ax-state-open');\n    }\n\n    // Private Properties\n\n    private scrollableParents: HTMLElement[] = [];\n\n    protected items = signal<AXMenuItem[]>([]);\n\n    // Private Methods (Internal Logic)\n\n    /** @ignore */\n    private handleContextMenu(e: MouseEvent) {\n        e.preventDefault();\n        e.stopPropagation();\n        //\n        const event = {\n            component: this,\n            htmlElement: this.getHostElement(),\n            nativeEvent: e,\n            canceled: false,\n            items: cloneDeep(this.orginalItems()),\n        } as AXContextMenuOpeningEvent;\n        this.onOpening.emit(event);\n        this.items.set(event.items);\n        //\n        if (!event.canceled) {\n            this.showAt({ x: e.clientX, y: e.clientY });\n        }\n    }\n\n    private internalShowAt(point: AXPoint) {\n        const elementRef = this.getHostElement();\n        elementRef.classList.add('ax-state-open');\n        const itemRect = elementRef.getBoundingClientRect();\n        const windowWidth = window.innerWidth;\n        const windowHeight = window.innerHeight;\n\n        // Detect RTL (Right-To-Left) mode\n        const isRtl = AXHtmlUtil.isRtl(this.getHostElement());\n\n        let left: number;\n        if (isRtl) {\n            left = point.x - itemRect.width;\n            if (left < 0) {\n                left = point.x;\n            }\n        } else {\n            left = point.x;\n            if (left + itemRect.width > windowWidth) {\n                left = point.x - itemRect.width;\n            }\n        }\n\n        const bottom = point.y + itemRect.height;\n        let top: number;\n\n        if (bottom > windowHeight) {\n            top = point.y - itemRect.height;\n            if (top < 0) {\n                top = 0;\n            }\n        } else {\n            top = point.y;\n        }\n\n        this.renderer.setStyle(elementRef, 'left', `${left}px`);\n        this.renderer.setStyle(elementRef, 'top', `${top}px`);\n        this.renderer.setStyle(elementRef, 'position', 'fixed');\n    }\n\n    private bindScrollEvents() {\n        this.scrollableParents = AXHtmlUtil.getScrollableParents(this.getHostElement());\n        this.scrollableParents.forEach((parent) => {\n            parent.addEventListener('scroll', this.onContainerScroll.bind(this));\n        });\n    }\n\n    private removeScrollEvents() {\n        this.scrollableParents.forEach((parent) => {\n            parent.removeEventListener('scroll', this.onContainerScroll.bind(this));\n        });\n    }\n\n    private onContainerScroll() {\n        this.service.closeAllContextMenu$.next({ sender: this as any as AXRootMenu });\n    }\n\n    // Host Listeners (UI Interaction Handling)\n\n    /** @ignore */\n    @HostListener('document:click', ['$event'])\n    private onClickOutside(event: MouseEvent) {\n        const hostElement = this.getHostElement();\n        if (!hostElement.contains(event.target as Node)) {\n            const sender = this as any as AXRootMenu;\n            this.service.closeAllContextMenu$.next({ sender });\n        }\n    }\n\n    @HostListener('document:contextmenu', ['$event'])\n    private onContextMenuOutside(event: MouseEvent) {\n        if (!this.target().contains(event.target as Node)) {\n            const sender = this as any as AXRootMenu;\n            this.service.closeAllContextMenu$.next({ sender });\n        }\n    }\n\n    /** @ignore */\n    @HostBinding('class')\n    get __hostClass(): any {\n        return ['ax-menu-container', `ax-orientation-${this.orientation()}`];\n    }\n}\n","<ng-content select=\"ax-menu-item,ax-title,ng-container\"></ng-content>\n\n<ng-container *ngFor=\"let node of items()\" [ngTemplateOutlet]=\"Recursion\"\n    [ngTemplateOutletContext]=\"{ $implicit: node }\">\n</ng-container>\n<ng-template #Recursion let-item>\n    @if(item.group?.title)\n    {\n    <ax-title>{{item.group?.title}}</ax-title>\n    }\n    <ax-menu-item [name]=\"item.name\" [data]=\"item.data\" [disabled]=\"item.disabled\" [color]=\"item.color\">\n        <ax-prefix>\n            @if(item.icon)\n            {\n            <ax-icon [icon]=\"item.icon\">\n            </ax-icon>\n            }\n        </ax-prefix>\n        @if(item.text)\n        {\n        <ax-text>{{ item.text }}</ax-text>\n        }\n        @if(item.suffix)\n        {\n        <ax-suffix>\n            <ax-text>{{ item.suffix.text }}</ax-text>\n        </ax-suffix>\n        }\n        <ng-container *ngFor=\"let child of item.children\" [ngTemplateOutlet]=\"Recursion\"\n            [ngTemplateOutletContext]=\"{ $implicit: child }\"></ng-container>\n    </ax-menu-item>\n    @if(item.break)\n    {\n    <ax-divider></ax-divider>\n    }\n</ng-template>"]}
|