@acorex/components 18.10.16 → 18.11.1
Sign up to get free protection for your applications and to get access to all the features.
- package/action-sheet/lib/action-sheet.class.d.ts +8 -0
- package/common/index.d.ts +1 -0
- package/common/lib/types/base/component.types.d.ts +8 -0
- package/common/lib/types/base/events.types.d.ts +21 -0
- package/common/lib/types/base/index.d.ts +2 -0
- package/esm2022/action-sheet/lib/action-sheet.class.mjs +1 -1
- package/esm2022/action-sheet/lib/action-sheet.component.mjs +3 -3
- package/esm2022/common/index.mjs +2 -1
- package/esm2022/common/lib/classes/events.class.mjs +1 -1
- package/esm2022/common/lib/components/base-component.class.mjs +1 -1
- package/esm2022/common/lib/types/base/component.types.mjs +27 -0
- package/esm2022/common/lib/types/base/events.types.mjs +19 -0
- package/esm2022/common/lib/types/base/index.mjs +3 -0
- package/esm2022/menu/index.mjs +4 -4
- package/esm2022/menu/lib/context-menu.component.mjs +232 -0
- package/esm2022/menu/lib/menu-item.component.mjs +310 -0
- package/esm2022/menu/lib/menu.component.mjs +27 -33
- 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 +14 -0
- package/fesm2022/acorex-components-action-sheet.mjs +2 -2
- package/fesm2022/acorex-components-action-sheet.mjs.map +1 -1
- package/fesm2022/acorex-components-common.mjs +47 -3
- package/fesm2022/acorex-components-common.mjs.map +1 -1
- package/fesm2022/acorex-components-menu.mjs +536 -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 +52 -0
- package/menu/lib/menu-item.component.d.ts +60 -0
- package/menu/lib/menu.component.d.ts +10 -11
- 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 +38 -0
- package/package.json +43 -43
- 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
@@ -0,0 +1,310 @@
|
|
1
|
+
import { NXComponent } from '@acorex/components/common';
|
2
|
+
import { afterNextRender, ChangeDetectionStrategy, Component, computed, HostBinding, HostListener, inject, input, output, Renderer2, signal, ViewEncapsulation, } from '@angular/core';
|
3
|
+
import { AXMenuService } from './menu.service';
|
4
|
+
import { AXMenuItemComponentBase, AXRootMenu } from './menu.types';
|
5
|
+
import { AXHtmlUtil, AXUnsubscriber } from '@acorex/core/utils';
|
6
|
+
import * as i0 from "@angular/core";
|
7
|
+
/**
|
8
|
+
* Represents a menu item component used within an `ax-menu`.
|
9
|
+
* @category Components
|
10
|
+
*/
|
11
|
+
export class AXMenuItemComponent extends NXComponent {
|
12
|
+
constructor() {
|
13
|
+
super();
|
14
|
+
this.isOpen = signal(false);
|
15
|
+
this.hasSubItems = signal(false);
|
16
|
+
this.isFirstLevel = signal(false);
|
17
|
+
this.root = inject(AXRootMenu);
|
18
|
+
this.service = inject(AXMenuService);
|
19
|
+
this.scrollableParents = [];
|
20
|
+
this.unsuscriber = inject(AXUnsubscriber);
|
21
|
+
this.renderer = inject(Renderer2);
|
22
|
+
this.arrowIcon = computed(() => {
|
23
|
+
const isRtl = AXHtmlUtil.isRtl(this.nativeElement);
|
24
|
+
return this.root.orientation() == 'horizontal' && this.isFirstLevel() ?
|
25
|
+
"ax-icon-chevron-down" :
|
26
|
+
isRtl ? "ax-icon-chevron-left" : "ax-icon-chevron-right";
|
27
|
+
});
|
28
|
+
this.onClick = output();
|
29
|
+
this.name = input();
|
30
|
+
this.data = input();
|
31
|
+
this.disabled = input();
|
32
|
+
this.color = input();
|
33
|
+
//
|
34
|
+
afterNextRender(() => {
|
35
|
+
this.detectSubItems();
|
36
|
+
this.observeMutations();
|
37
|
+
this.bindScrollEvents();
|
38
|
+
});
|
39
|
+
//
|
40
|
+
this.service.closeAll$
|
41
|
+
.pipe(this.unsuscriber.takeUntilDestroy)
|
42
|
+
.subscribe(() => this.close());
|
43
|
+
this.service.open$
|
44
|
+
.pipe(this.unsuscriber.takeUntilDestroy)
|
45
|
+
.subscribe((item) => {
|
46
|
+
if (this === item) {
|
47
|
+
this.isOpen.set(true);
|
48
|
+
this.calculatePosition();
|
49
|
+
}
|
50
|
+
});
|
51
|
+
//
|
52
|
+
this.service.close$
|
53
|
+
.pipe(this.unsuscriber.takeUntilDestroy)
|
54
|
+
.subscribe(item => {
|
55
|
+
if (this == item) {
|
56
|
+
this.isOpen.set(false);
|
57
|
+
}
|
58
|
+
});
|
59
|
+
//
|
60
|
+
this.service.closeExcept$
|
61
|
+
.pipe(this.unsuscriber.takeUntilDestroy)
|
62
|
+
.subscribe((item) => {
|
63
|
+
this.closeExcept(item);
|
64
|
+
});
|
65
|
+
}
|
66
|
+
closeExcept(item) {
|
67
|
+
const list = [item];
|
68
|
+
//
|
69
|
+
let parent = item.parent;
|
70
|
+
while (parent != null) {
|
71
|
+
list.push(parent);
|
72
|
+
parent = parent.parent;
|
73
|
+
}
|
74
|
+
//
|
75
|
+
if (!list.includes(this)) {
|
76
|
+
this.close();
|
77
|
+
}
|
78
|
+
}
|
79
|
+
observeMutations() {
|
80
|
+
this.mutationObserver = new MutationObserver(() => {
|
81
|
+
this.detectSubItems();
|
82
|
+
});
|
83
|
+
// Start observing changes in child elements
|
84
|
+
this.mutationObserver.observe(this.nativeElement, {
|
85
|
+
childList: true,
|
86
|
+
subtree: true,
|
87
|
+
});
|
88
|
+
}
|
89
|
+
getText() {
|
90
|
+
return this.nativeElement.querySelector('ax-text')?.innerText;
|
91
|
+
}
|
92
|
+
/**
|
93
|
+
* Manually detect all `ax-menu-item` elements and check if this menu item has sub-items.
|
94
|
+
*/
|
95
|
+
detectSubItems() {
|
96
|
+
//
|
97
|
+
const parentEl = this.nativeElement.parentElement?.parentElement;
|
98
|
+
this.parent = parentEl?.tagName == "AX-MENU-ITEM" ? parentEl?.["__axContext__"] : null;
|
99
|
+
//
|
100
|
+
const tag = this.nativeElement.parentElement?.tagName;
|
101
|
+
this.isFirstLevel.set(tag == "AX-MENU" || tag == "AX-CONTEXT-MENU");
|
102
|
+
const subItems = this.nativeElement.querySelectorAll('ax-menu-item');
|
103
|
+
if (subItems.length > 0) {
|
104
|
+
this.hasSubItems.set(true);
|
105
|
+
}
|
106
|
+
else {
|
107
|
+
this.hasSubItems.set(false);
|
108
|
+
}
|
109
|
+
}
|
110
|
+
open() {
|
111
|
+
this.service.closeExcept$.next(this);
|
112
|
+
if (!this.disabled() && this.hasSubItems()) {
|
113
|
+
this.service.open$.next(this);
|
114
|
+
}
|
115
|
+
}
|
116
|
+
close() {
|
117
|
+
this.service.close$.next(this);
|
118
|
+
}
|
119
|
+
/**
|
120
|
+
* Calculate the position of the submenu to avoid it going out of the viewport.
|
121
|
+
*/
|
122
|
+
calculatePosition() {
|
123
|
+
const submenu = this.nativeElement.querySelector('.ax-menu-items');
|
124
|
+
if (!submenu)
|
125
|
+
return;
|
126
|
+
const submenuRect = submenu.getBoundingClientRect();
|
127
|
+
const itemRect = this.nativeElement.getBoundingClientRect();
|
128
|
+
const windowWidth = window.innerWidth;
|
129
|
+
const windowHeight = window.innerHeight;
|
130
|
+
const isRtl = AXHtmlUtil.isRtl(this.nativeElement);
|
131
|
+
let top = null;
|
132
|
+
let left = null;
|
133
|
+
// For first-level menu items
|
134
|
+
if (this.isFirstLevel() && this.root.orientation() === 'horizontal') {
|
135
|
+
top = itemRect.bottom + submenuRect.height > windowHeight
|
136
|
+
? itemRect.top - submenuRect.height // Open upwards
|
137
|
+
: itemRect.bottom; // Open downwards
|
138
|
+
if (isRtl) {
|
139
|
+
// RTL: Align to the right of the parent item
|
140
|
+
left = itemRect.right - submenuRect.width < 0
|
141
|
+
? itemRect.left // Align to the left if not enough space on the right
|
142
|
+
: itemRect.right - submenuRect.width; // Open to the left in RTL
|
143
|
+
}
|
144
|
+
else {
|
145
|
+
// LTR: Align to the left of the parent item
|
146
|
+
left = itemRect.left + submenuRect.width > windowWidth
|
147
|
+
? itemRect.right - submenuRect.width // Align to the right edge in LTR
|
148
|
+
: itemRect.left; // Open to the left
|
149
|
+
}
|
150
|
+
}
|
151
|
+
else {
|
152
|
+
// For nested submenus
|
153
|
+
if (isRtl) {
|
154
|
+
// RTL: Nested submenu opens to the left
|
155
|
+
left = itemRect.left - submenuRect.width < 0
|
156
|
+
? itemRect.right // Align to the right if not enough space on the left
|
157
|
+
: itemRect.left - submenuRect.width; // Open to the left in RTL
|
158
|
+
}
|
159
|
+
else {
|
160
|
+
// LTR: Nested submenu opens to the right
|
161
|
+
left = itemRect.right + submenuRect.width > windowWidth
|
162
|
+
? itemRect.left - submenuRect.width // Open to the left if not enough space
|
163
|
+
: itemRect.right; // Open to the right in LTR
|
164
|
+
}
|
165
|
+
// Adjust top position (align vertically with parent)
|
166
|
+
top = itemRect.top + submenuRect.height > windowHeight
|
167
|
+
? itemRect.top - (itemRect.bottom + submenuRect.height - windowHeight) // Adjust upwards
|
168
|
+
: itemRect.top; // Align with the parent item
|
169
|
+
}
|
170
|
+
// Apply calculated styles for RTL/LTR
|
171
|
+
this.renderer.setStyle(submenu, 'left', `${left}px`);
|
172
|
+
this.renderer.setStyle(submenu, 'top', `${top}px`);
|
173
|
+
this.renderer.setStyle(submenu, 'position', 'fixed'); // Fixed position relative to the viewport
|
174
|
+
}
|
175
|
+
handleClick(e) {
|
176
|
+
e.stopPropagation();
|
177
|
+
if (this.disabled())
|
178
|
+
return;
|
179
|
+
//
|
180
|
+
const event = {
|
181
|
+
sender: this,
|
182
|
+
nativeEvent: e,
|
183
|
+
canceled: false,
|
184
|
+
item: {
|
185
|
+
name: this.name(),
|
186
|
+
text: this.getText(),
|
187
|
+
data: this.data()
|
188
|
+
}
|
189
|
+
};
|
190
|
+
//
|
191
|
+
this.onClick.emit(event);
|
192
|
+
this.root.onItemClick.emit({ ...event, ...{ sender: this.root } });
|
193
|
+
//
|
194
|
+
if (this.hasSubItems() && !event.canceled) {
|
195
|
+
this.open();
|
196
|
+
}
|
197
|
+
else if (!event.canceled) {
|
198
|
+
this.service.closeAll$.next();
|
199
|
+
this.service.closeAllContextMenu$.next({ sender: this.root });
|
200
|
+
}
|
201
|
+
}
|
202
|
+
handleMouseEnter(event) {
|
203
|
+
event.stopPropagation();
|
204
|
+
// Cancel the close delay if the mouse re-enters the element
|
205
|
+
if (this.mouseLeaveTimeout) {
|
206
|
+
clearTimeout(this.mouseLeaveTimeout);
|
207
|
+
this.mouseLeaveTimeout = null; // Reset the timeout
|
208
|
+
}
|
209
|
+
if (!this.isFirstLevel() || this.root.openOn() == 'hover') {
|
210
|
+
this.open();
|
211
|
+
}
|
212
|
+
}
|
213
|
+
handleMouseLeave(event) {
|
214
|
+
event.stopPropagation();
|
215
|
+
if (this.hasSubItems() && this.root.closeOn() === 'leave') {
|
216
|
+
// Clear any previous timeout to avoid multiple triggers
|
217
|
+
if (this.mouseLeaveTimeout) {
|
218
|
+
clearTimeout(this.mouseLeaveTimeout);
|
219
|
+
}
|
220
|
+
// Set a delay before closing the submenu
|
221
|
+
this.mouseLeaveTimeout = setTimeout(() => {
|
222
|
+
this.close();
|
223
|
+
}, 500); // Adjust the delay (500ms in this case) as per your requirement
|
224
|
+
}
|
225
|
+
}
|
226
|
+
onWindowEvent() {
|
227
|
+
this.service.closeAll$.next(); // Close all menus on scroll or resize
|
228
|
+
}
|
229
|
+
/**
|
230
|
+
* Close all menus if clicking outside the root menu and all sub-items.
|
231
|
+
*/
|
232
|
+
onClickOutside(event) {
|
233
|
+
const hostElement = this.root.nativeElement;
|
234
|
+
if (!hostElement.contains(event.target)) {
|
235
|
+
this.service.closeAll$.next(); // Close all menus if click is outside the root and sub-items
|
236
|
+
}
|
237
|
+
}
|
238
|
+
ngOnDestroy() {
|
239
|
+
this.removeScrollEvents();
|
240
|
+
}
|
241
|
+
bindScrollEvents() {
|
242
|
+
this.scrollableParents = AXHtmlUtil.getScrollableParents(this.nativeElement);
|
243
|
+
this.scrollableParents.forEach((parent) => {
|
244
|
+
parent.addEventListener('scroll', this.onContainerScroll.bind(this));
|
245
|
+
});
|
246
|
+
}
|
247
|
+
// Remove scroll event listeners
|
248
|
+
removeScrollEvents() {
|
249
|
+
this.scrollableParents.forEach((parent) => {
|
250
|
+
parent.removeEventListener('scroll', this.onContainerScroll.bind(this));
|
251
|
+
});
|
252
|
+
}
|
253
|
+
/**
|
254
|
+
* Handler for scroll events (window or scrollable parent containers)
|
255
|
+
*/
|
256
|
+
onContainerScroll() {
|
257
|
+
this.service.closeAll$.next(); // Close all menus on scroll
|
258
|
+
}
|
259
|
+
/** @ignore */
|
260
|
+
get __hostClass() {
|
261
|
+
const list = ['ax-el-interactive', 'ax-action-item'];
|
262
|
+
if (this.disabled()) {
|
263
|
+
list.push('ax-state-disabled');
|
264
|
+
}
|
265
|
+
if (this.color()) {
|
266
|
+
list.push(`ax-el-${this.color()}-blank`);
|
267
|
+
}
|
268
|
+
return list;
|
269
|
+
}
|
270
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: AXMenuItemComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
271
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.0", type: AXMenuItemComponent, selector: "ax-menu-item", inputs: { name: { classPropertyName: "name", publicName: "name", isSignal: true, isRequired: false, transformFunction: null }, data: { classPropertyName: "data", publicName: "data", isSignal: true, isRequired: false, transformFunction: null }, disabled: { classPropertyName: "disabled", publicName: "disabled", isSignal: true, isRequired: false, transformFunction: null }, color: { classPropertyName: "color", publicName: "color", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { onClick: "onClick" }, host: { listeners: { "click": "handleClick($event)", "mouseenter": "handleMouseEnter($event)", "mouseleave": "handleMouseLeave($event)", "window:scroll": "onWindowEvent($event)", "window:resize": "onWindowEvent($event)", "document:click": "onClickOutside($event)" }, properties: { "class": "this.__hostClass" } }, providers: [
|
272
|
+
{
|
273
|
+
provide: AXMenuItemComponentBase,
|
274
|
+
useExisting: AXMenuItemComponent
|
275
|
+
},
|
276
|
+
AXUnsubscriber
|
277
|
+
], usesInheritance: true, ngImport: i0, template: "<div class=\"ax-action-item-prefix\">\n <ng-content select=\"ax-prefix\"></ng-content>\n <ng-content select=\"ax-text\"></ng-content>\n</div>\n<div class=\"ax-action-item-suffix\">\n <ng-content select=\"ax-suffix\"></ng-content>\n @if (hasSubItems()) {\n <i class=\"ax-icon ax-icon-solid {{ arrowIcon() }} ax-menu-item-child-icon\"></i>\n }\n</div>\n<div class=\"ax-menu-items ax-action-list ax-action-list-vertical\" [class.ax-state-open]=\"isOpen()\">\n <ng-content select=\"ax-menu-item,ax-title,ng-container\"></ng-content>\n</div>", changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
|
278
|
+
}
|
279
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: AXMenuItemComponent, decorators: [{
|
280
|
+
type: Component,
|
281
|
+
args: [{ selector: 'ax-menu-item', encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, providers: [
|
282
|
+
{
|
283
|
+
provide: AXMenuItemComponentBase,
|
284
|
+
useExisting: AXMenuItemComponent
|
285
|
+
},
|
286
|
+
AXUnsubscriber
|
287
|
+
], template: "<div class=\"ax-action-item-prefix\">\n <ng-content select=\"ax-prefix\"></ng-content>\n <ng-content select=\"ax-text\"></ng-content>\n</div>\n<div class=\"ax-action-item-suffix\">\n <ng-content select=\"ax-suffix\"></ng-content>\n @if (hasSubItems()) {\n <i class=\"ax-icon ax-icon-solid {{ arrowIcon() }} ax-menu-item-child-icon\"></i>\n }\n</div>\n<div class=\"ax-menu-items ax-action-list ax-action-list-vertical\" [class.ax-state-open]=\"isOpen()\">\n <ng-content select=\"ax-menu-item,ax-title,ng-container\"></ng-content>\n</div>" }]
|
288
|
+
}], ctorParameters: () => [], propDecorators: { handleClick: [{
|
289
|
+
type: HostListener,
|
290
|
+
args: ["click", ['$event']]
|
291
|
+
}], handleMouseEnter: [{
|
292
|
+
type: HostListener,
|
293
|
+
args: ["mouseenter", ['$event']]
|
294
|
+
}], handleMouseLeave: [{
|
295
|
+
type: HostListener,
|
296
|
+
args: ["mouseleave", ['$event']]
|
297
|
+
}], onWindowEvent: [{
|
298
|
+
type: HostListener,
|
299
|
+
args: ['window:scroll', ['$event']]
|
300
|
+
}, {
|
301
|
+
type: HostListener,
|
302
|
+
args: ['window:resize', ['$event']]
|
303
|
+
}], onClickOutside: [{
|
304
|
+
type: HostListener,
|
305
|
+
args: ['document:click', ['$event']]
|
306
|
+
}], __hostClass: [{
|
307
|
+
type: HostBinding,
|
308
|
+
args: ['class']
|
309
|
+
}] } });
|
310
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"menu-item.component.js","sourceRoot":"","sources":["../../../../../../libs/components/menu/src/lib/menu-item.component.ts","../../../../../../libs/components/menu/src/lib/menu-item.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AXStyleColorType, NXComponent } from '@acorex/components/common';\nimport {\n  afterNextRender,\n  ChangeDetectionStrategy,\n  Component,\n  computed,\n  HostBinding,\n  HostListener,\n  inject,\n  input,\n  output,\n  Renderer2,\n  signal,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { AXMenuService } from './menu.service';\nimport { AXMenuItemClickBaseEvent, AXMenuItemComponentBase, AXRootMenu } from './menu.types';\nimport { AXHtmlUtil, AXUnsubscriber } from '@acorex/core/utils';\n\nexport type AXMenuItemClickEvent = AXMenuItemClickBaseEvent<AXMenuItemComponent>;\n\n/**\n * Represents a menu item component used within an `ax-menu`.\n * @category Components\n */\n@Component({\n  selector: 'ax-menu-item',\n  templateUrl: './menu-item.component.html',\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    {\n      provide: AXMenuItemComponentBase,\n      useExisting: AXMenuItemComponent\n    },\n    AXUnsubscriber\n  ],\n})\nexport class AXMenuItemComponent extends NXComponent {\n\n  protected isOpen = signal(false);\n  protected hasSubItems = signal(false);\n  protected isFirstLevel = signal(false);\n  private mutationObserver!: MutationObserver;\n\n  protected root = inject(AXRootMenu);\n  protected parent?: AXMenuItemComponent | null;\n\n  private service = inject(AXMenuService);\n  private scrollableParents: HTMLElement[] = [];\n\n  private unsuscriber = inject(AXUnsubscriber);\n  private renderer = inject(Renderer2)\n\n\n  protected arrowIcon = computed(() => {\n    const isRtl = AXHtmlUtil.isRtl(this.nativeElement);\n    return this.root.orientation() == 'horizontal' && this.isFirstLevel() ?\n      \"ax-icon-chevron-down\" :\n      isRtl ? \"ax-icon-chevron-left\" : \"ax-icon-chevron-right\";\n  })\n\n\n  onClick = output<AXMenuItemClickEvent>();\n\n  name = input<string>();\n  data = input<any>();\n  disabled = input<boolean>();\n  color = input<AXStyleColorType>();\n\n\n\n  constructor() {\n    super();\n    //\n    afterNextRender(() => {\n      this.detectSubItems();\n      this.observeMutations();\n      this.bindScrollEvents();\n    });\n    //\n    this.service.closeAll$\n      .pipe(this.unsuscriber.takeUntilDestroy)\n      .subscribe(() => this.close());\n\n    this.service.open$\n      .pipe(this.unsuscriber.takeUntilDestroy)\n      .subscribe((item) => {\n        if ((this as any) === item) {\n          this.isOpen.set(true);\n          this.calculatePosition();\n        }\n      });\n    //\n    this.service.close$\n      .pipe(this.unsuscriber.takeUntilDestroy)\n      .subscribe(item => {\n        if ((this as any) == item) {\n          this.isOpen.set(false);\n        }\n      });\n    //\n    this.service.closeExcept$\n      .pipe(this.unsuscriber.takeUntilDestroy)\n      .subscribe((item) => {\n        this.closeExcept(item as AXMenuItemComponent);\n      });\n  }\n\n\n  private closeExcept(item: AXMenuItemComponent) {\n    const list: AXMenuItemComponent[] = [item]\n    //\n    let parent = item.parent;\n    while (parent != null) {\n      list.push(parent);\n      parent = parent.parent;\n    }\n    //\n    if (!list.includes(this)) {\n      this.close();\n    }\n  }\n\n\n  private observeMutations() {\n    this.mutationObserver = new MutationObserver(() => {\n      this.detectSubItems();\n    });\n\n    // Start observing changes in child elements\n    this.mutationObserver.observe(this.nativeElement, {\n      childList: true,\n      subtree: true,\n    });\n  }\n\n\n  private getText(): string {\n    return this.nativeElement.querySelector<HTMLDivElement>('ax-text')?.innerText;\n  }\n\n\n  /**\n    * Manually detect all `ax-menu-item` elements and check if this menu item has sub-items.\n    */\n  private detectSubItems() {\n    //\n    const parentEl = this.nativeElement.parentElement?.parentElement;\n    this.parent = parentEl?.tagName == \"AX-MENU-ITEM\" ? parentEl?.[\"__axContext__\"] as AXMenuItemComponent : null;\n    //\n    const tag = this.nativeElement.parentElement?.tagName;\n    this.isFirstLevel.set(tag == \"AX-MENU\" || tag == \"AX-CONTEXT-MENU\");\n    const subItems = this.nativeElement.querySelectorAll('ax-menu-item');\n    if (subItems.length > 0) {\n      this.hasSubItems.set(true);\n    } else {\n      this.hasSubItems.set(false);\n    }\n  }\n\n\n  open() {\n    this.service.closeExcept$.next(this);\n    if (!this.disabled() && this.hasSubItems()) {\n      this.service.open$.next(this);\n    }\n  }\n\n  close() {\n    this.service.close$.next(this);\n  }\n\n\n  /**\n * Calculate the position of the submenu to avoid it going out of the viewport.\n */\n  private calculatePosition() {\n    const submenu = this.nativeElement.querySelector('.ax-menu-items');\n    if (!submenu) return;\n\n    const submenuRect = submenu.getBoundingClientRect();\n    const itemRect = this.nativeElement.getBoundingClientRect();\n    const windowWidth = window.innerWidth;\n    const windowHeight = window.innerHeight;\n\n    const isRtl = AXHtmlUtil.isRtl(this.nativeElement);\n\n    let top: number | null = null;\n    let left: number | null = null;\n\n    // For first-level menu items\n    if (this.isFirstLevel() && this.root.orientation() === 'horizontal') {\n      top = itemRect.bottom + submenuRect.height > windowHeight\n        ? itemRect.top - submenuRect.height // Open upwards\n        : itemRect.bottom; // Open downwards\n\n      if (isRtl) {\n        // RTL: Align to the right of the parent item\n        left = itemRect.right - submenuRect.width < 0\n          ? itemRect.left // Align to the left if not enough space on the right\n          : itemRect.right - submenuRect.width; // Open to the left in RTL\n      } else {\n        // LTR: Align to the left of the parent item\n        left = itemRect.left + submenuRect.width > windowWidth\n          ? itemRect.right - submenuRect.width // Align to the right edge in LTR\n          : itemRect.left; // Open to the left\n      }\n    } else {\n      // For nested submenus\n      if (isRtl) {\n        // RTL: Nested submenu opens to the left\n        left = itemRect.left - submenuRect.width < 0\n          ? itemRect.right // Align to the right if not enough space on the left\n          : itemRect.left - submenuRect.width; // Open to the left in RTL\n      } else {\n        // LTR: Nested submenu opens to the right\n        left = itemRect.right + submenuRect.width > windowWidth\n          ? itemRect.left - submenuRect.width // Open to the left if not enough space\n          : itemRect.right; // Open to the right in LTR\n      }\n\n      // Adjust top position (align vertically with parent)\n      top = itemRect.top + submenuRect.height > windowHeight\n        ? itemRect.top - (itemRect.bottom + submenuRect.height - windowHeight) // Adjust upwards\n        : itemRect.top; // Align with the parent item\n    }\n\n    // Apply calculated styles for RTL/LTR\n    this.renderer.setStyle(submenu, 'left', `${left}px`);\n    this.renderer.setStyle(submenu, 'top', `${top}px`);\n    this.renderer.setStyle(submenu, 'position', 'fixed'); // Fixed position relative to the viewport\n  }\n\n\n\n  @HostListener(\"click\", ['$event'])\n  private handleClick(e: MouseEvent) {\n    e.stopPropagation();\n    if (this.disabled()) return;\n    //\n    const event = {\n      sender: this,\n      nativeEvent: e,\n      canceled: false,\n      item: {\n        name: this.name(),\n        text: this.getText(),\n        data: this.data()\n      }\n    } as AXMenuItemClickEvent;\n    //\n    this.onClick.emit(event);\n    this.root.onItemClick.emit({ ...event, ...{ sender: this.root as any } });\n    //\n    if (this.hasSubItems() && !event.canceled) {\n      this.open();\n    }\n    else if (!event.canceled) {\n      this.service.closeAll$.next();\n      this.service.closeAllContextMenu$.next({ sender: this.root });\n    }\n  }\n\n  @HostListener(\"mouseenter\", ['$event'])\n  private handleMouseEnter(event: MouseEvent) {\n    event.stopPropagation();\n    // Cancel the close delay if the mouse re-enters the element\n    if (this.mouseLeaveTimeout) {\n      clearTimeout(this.mouseLeaveTimeout);\n      this.mouseLeaveTimeout = null; // Reset the timeout\n    }\n    if (!this.isFirstLevel() || this.root.openOn() == 'hover') {\n      this.open();\n    }\n  }\n\n  private mouseLeaveTimeout: any;\n\n  @HostListener(\"mouseleave\", ['$event'])\n  private handleMouseLeave(event: MouseEvent) {\n    event.stopPropagation();\n\n    if (this.hasSubItems() && this.root.closeOn() === 'leave') {\n      // Clear any previous timeout to avoid multiple triggers\n      if (this.mouseLeaveTimeout) {\n        clearTimeout(this.mouseLeaveTimeout);\n      }\n\n      // Set a delay before closing the submenu\n      this.mouseLeaveTimeout = setTimeout(() => {\n        this.close();\n      }, 500); // Adjust the delay (500ms in this case) as per your requirement\n    }\n  }\n\n  @HostListener('window:scroll', ['$event'])\n  @HostListener('window:resize', ['$event'])\n  private onWindowEvent() {\n    this.service.closeAll$.next(); // Close all menus on scroll or resize\n  }\n\n  /**\n   * Close all menus if clicking outside the root menu and all sub-items.\n   */\n  @HostListener('document:click', ['$event'])\n  private onClickOutside(event: MouseEvent) {\n    const hostElement = this.root.nativeElement;\n    if (!hostElement.contains(event.target as Node)) {\n      this.service.closeAll$.next() // Close all menus if click is outside the root and sub-items\n    }\n  }\n\n\n  ngOnDestroy() {\n    this.removeScrollEvents();\n  }\n\n  private bindScrollEvents() {\n    this.scrollableParents = AXHtmlUtil.getScrollableParents(this.nativeElement);\n\n    this.scrollableParents.forEach((parent) => {\n      parent.addEventListener('scroll', this.onContainerScroll.bind(this));\n    });\n  }\n\n  // Remove scroll event listeners \n  private removeScrollEvents() {\n    this.scrollableParents.forEach((parent) => {\n      parent.removeEventListener('scroll', this.onContainerScroll.bind(this));\n    });\n  }\n\n  /**\n   * Handler for scroll events (window or scrollable parent containers)\n   */\n  private onContainerScroll() {\n    this.service.closeAll$.next(); // Close all menus on scroll\n  }\n\n\n\n  /** @ignore */\n  @HostBinding('class')\n  get __hostClass(): string[] {\n    const list: string[] = ['ax-el-interactive', 'ax-action-item'];\n    if (this.disabled()) {\n      list.push('ax-state-disabled');\n    }\n    if (this.color()) {\n      list.push(`ax-el-${this.color()}-blank`);\n    }\n    return list\n  }\n\n}\n","<div class=\"ax-action-item-prefix\">\n  <ng-content select=\"ax-prefix\"></ng-content>\n  <ng-content select=\"ax-text\"></ng-content>\n</div>\n<div class=\"ax-action-item-suffix\">\n  <ng-content select=\"ax-suffix\"></ng-content>\n  @if (hasSubItems()) {\n    <i class=\"ax-icon ax-icon-solid {{ arrowIcon() }} ax-menu-item-child-icon\"></i>\n  }\n</div>\n<div class=\"ax-menu-items ax-action-list ax-action-list-vertical\" [class.ax-state-open]=\"isOpen()\">\n  <ng-content select=\"ax-menu-item,ax-title,ng-container\"></ng-content>\n</div>"]}
|
@@ -1,58 +1,52 @@
|
|
1
|
-
import {
|
2
|
-
import {
|
3
|
-
import { AXRootMenu } from './class/root-menu.class';
|
4
|
-
import { AXMenuItemComponent } from './menu-item/menu-item.component';
|
1
|
+
import { NXComponent } from '@acorex/components/common';
|
2
|
+
import { ChangeDetectionStrategy, Component, HostBinding, inject, input, output, ViewEncapsulation, } from '@angular/core';
|
5
3
|
import { AXMenuService } from './menu.service';
|
4
|
+
import { AXRootMenu } from './menu.types';
|
6
5
|
import * as i0 from "@angular/core";
|
6
|
+
import * as i1 from "@angular/common";
|
7
|
+
import * as i2 from "@acorex/components/decorators";
|
8
|
+
import * as i3 from "./menu-item.component";
|
7
9
|
/**
|
8
10
|
* Represents a menu component that displays menu items.
|
9
11
|
* @category Components
|
10
12
|
*/
|
11
|
-
export class AXMenuComponent extends
|
13
|
+
export class AXMenuComponent extends NXComponent {
|
12
14
|
constructor() {
|
13
15
|
super(...arguments);
|
14
16
|
this.orientation = input('horizontal');
|
15
|
-
this.openOn = input('
|
17
|
+
this.openOn = input('hover');
|
18
|
+
this.closeOn = input('leave');
|
16
19
|
this.service = inject(AXMenuService);
|
17
|
-
|
18
|
-
|
19
|
-
ngAfterViewInit() {
|
20
|
-
this.children.forEach((c) => {
|
21
|
-
c.isRoot = true;
|
22
|
-
c.parent = this;
|
23
|
-
});
|
20
|
+
this.onItemClick = output();
|
21
|
+
this.items = input([]);
|
24
22
|
}
|
25
23
|
/** @ignore */
|
26
24
|
get __hostClass() {
|
27
|
-
return `ax-
|
25
|
+
return `ax-action-list-${this.orientation()} ax-action-list`;
|
26
|
+
}
|
27
|
+
close() {
|
28
|
+
this.service.closeAll$.next();
|
28
29
|
}
|
29
30
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: AXMenuComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
|
30
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.
|
31
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.0", type: AXMenuComponent, selector: "ax-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 }, items: { classPropertyName: "items", publicName: "items", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { onItemClick: "onItemClick" }, host: { properties: { "class": "this.__hostClass" } }, providers: [
|
32
|
+
AXMenuService,
|
31
33
|
{
|
32
34
|
provide: AXRootMenu,
|
33
|
-
useExisting: AXMenuComponent
|
34
|
-
}
|
35
|
-
{
|
36
|
-
provide: AXMenuService,
|
37
|
-
},
|
38
|
-
], queries: [{ propertyName: "children", predicate: AXMenuItemComponent }], usesInheritance: true, ngImport: i0, template: ` <ng-content select="ax-menu-item,ng-container"></ng-content>`, isInline: true, styles: ["ax-menu{width:100%;font-size:.875rem;line-height:1.25rem;color:inherit;position:relative}ax-menu.ax-orientation-horizontal{display:flex}ax-menu.ax-orientation-horizontal ax-menu-item:not(ax-menu.ax-orientation-horizontal ax-menu-item:last-child){margin-inline-end:1rem}ax-menu.ax-orientation-vertical{display:flex;flex-direction:column}ax-menu.ax-orientation-vertical ax-menu-item{justify-content:space-between}ax-menu.ax-orientation-vertical ax-menu-item:not(ax-menu.ax-orientation-vertical ax-menu-item:last-child){margin-bottom:1rem}ax-menu ax-menu-item:hover:not(ax-menu ax-menu-item:hover.ax-state-disabled){color:rgba(var(--ax-color-primary-500))}ax-menu-item{position:relative;display:flex;align-items:center;gap:.5rem;font-size:.875rem;line-height:1.25rem;font-weight:500;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s;justify-content:space-between;color:rgba(var(--ax-color-text-default))}ax-menu-item .ax-menu-item-text{white-space:nowrap}ax-menu-item:not(ax-menu-item.ax-state-disabled){cursor:pointer}ax-menu-item .ax-menu-item-start-side{display:flex;align-items:center;gap:.5rem}ax-menu-item.ax-state-disabled{cursor:not-allowed;opacity:.5}ax-menu-item.ax-state-selected{color:rgba(var(--ax-color-primary-500))}ax-menu-item .ax-menu-item-child-icon{width:fit-content;line-height:1;font-size:10px}ax-menu-item ax-popover{position:absolute}.ax-menu-item-children{padding-top:.5rem;padding-bottom:.5rem}.ax-menu-item-children:not(.ax-menu-item-children:empty){display:flex;min-width:12rem;flex-direction:column;border-radius:var(--ax-rounded-border-default);border-width:1px;border-color:rgba(var(--ax-color-border-default));background-color:rgba(var(--ax-color-surface))}.ax-menu-item-children:not(.ax-menu-item-children:empty) ax-menu-item{padding:.5rem 1rem;font-size:.875rem;line-height:1.25rem}.ax-menu-item-children:not(.ax-menu-item-children:empty) ax-menu-item:hover:not(.ax-menu-item-children:not(.ax-menu-item-children:empty) ax-menu-item:hover.ax-state-disabled){background-color:rgba(var(--ax-color-on-surface))}.ax-menu-item-children:not(.ax-menu-item-children:empty) ax-menu-item:hover:not(.ax-menu-item-children:not(.ax-menu-item-children:empty) ax-menu-item:hover.ax-state-disabled) ax-prefix,.ax-menu-item-children:not(.ax-menu-item-children:empty) ax-menu-item:hover:not(.ax-menu-item-children:not(.ax-menu-item-children:empty) ax-menu-item:hover.ax-state-disabled) ax-suffix{opacity:1}.ax-menu-item-children:not(.ax-menu-item-children:empty) ax-menu-item ax-prefix,.ax-menu-item-children:not(.ax-menu-item-children:empty) ax-menu-item ax-suffix{opacity:.75}.ax-menu-item-children:not(.ax-menu-item-children:empty) ax-menu-item .ax-menu-item-text{flex:1 1 0%}html[dir=rtl] .ax-parent-horizontal .ax-menu-item-child-icon{transform:rotate(-90deg)}html[dir=rtl] .ax-parent-horizontal .ax-menu-item-child-icon:before{-moz-transform:scale(1,-1);-webkit-transform:scale(1,-1);-o-transform:scale(1,-1);-ms-transform:scale(1,-1);transform:scaleY(-1)}.ax-parent-horizontal .ax-menu-item-child-icon{transform:rotate(-90deg)}\n"], encapsulation: i0.ViewEncapsulation.None }); }
|
35
|
+
useExisting: AXMenuComponent
|
36
|
+
}
|
37
|
+
], 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.items\" [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-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-action-list-horizontal{padding-inline:1rem}ax-menu.ax-action-list-horizontal{min-width:12rem;gap:.875rem}ax-menu.ax-action-list-horizontal>ax-menu-item{font-weight:500}ax-menu.ax-action-list-horizontal>ax-menu-item>.ax-action-item-prefix{padding-inline-start:0!important}ax-menu.ax-action-list-horizontal>ax-menu-item>.ax-action-item-suffix:not(ax-menu.ax-action-list-horizontal>ax-menu-item>.ax-action-item-suffix:empty){padding-inline-end:0!important;margin-inline-start:0!important}ax-menu.ax-action-list-horizontal>ax-menu-item:hover{background-color:transparent!important}ax-menu.ax-action-list-horizontal>ax-menu-item:hover>.ax-action-item-prefix{color:rgba(var(--ax-color-primary-500))}ax-menu.ax-action-list-horizontal>ax-menu-item:hover>.ax-action-item-suffix{color:rgba(var(--ax-color-primary-500))}ax-menu.ax-action-list-vertical{width:max-content;min-width:12rem}ax-menu.ax-action-list-vertical>ax-menu-item{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 }); }
|
39
38
|
}
|
40
39
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: AXMenuComponent, decorators: [{
|
41
40
|
type: Component,
|
42
|
-
args: [{ selector: 'ax-menu',
|
41
|
+
args: [{ selector: 'ax-menu', encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, providers: [
|
42
|
+
AXMenuService,
|
43
43
|
{
|
44
44
|
provide: AXRootMenu,
|
45
|
-
useExisting: AXMenuComponent
|
46
|
-
}
|
47
|
-
|
48
|
-
|
49
|
-
},
|
50
|
-
], styles: ["ax-menu{width:100%;font-size:.875rem;line-height:1.25rem;color:inherit;position:relative}ax-menu.ax-orientation-horizontal{display:flex}ax-menu.ax-orientation-horizontal ax-menu-item:not(ax-menu.ax-orientation-horizontal ax-menu-item:last-child){margin-inline-end:1rem}ax-menu.ax-orientation-vertical{display:flex;flex-direction:column}ax-menu.ax-orientation-vertical ax-menu-item{justify-content:space-between}ax-menu.ax-orientation-vertical ax-menu-item:not(ax-menu.ax-orientation-vertical ax-menu-item:last-child){margin-bottom:1rem}ax-menu ax-menu-item:hover:not(ax-menu ax-menu-item:hover.ax-state-disabled){color:rgba(var(--ax-color-primary-500))}ax-menu-item{position:relative;display:flex;align-items:center;gap:.5rem;font-size:.875rem;line-height:1.25rem;font-weight:500;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s;justify-content:space-between;color:rgba(var(--ax-color-text-default))}ax-menu-item .ax-menu-item-text{white-space:nowrap}ax-menu-item:not(ax-menu-item.ax-state-disabled){cursor:pointer}ax-menu-item .ax-menu-item-start-side{display:flex;align-items:center;gap:.5rem}ax-menu-item.ax-state-disabled{cursor:not-allowed;opacity:.5}ax-menu-item.ax-state-selected{color:rgba(var(--ax-color-primary-500))}ax-menu-item .ax-menu-item-child-icon{width:fit-content;line-height:1;font-size:10px}ax-menu-item ax-popover{position:absolute}.ax-menu-item-children{padding-top:.5rem;padding-bottom:.5rem}.ax-menu-item-children:not(.ax-menu-item-children:empty){display:flex;min-width:12rem;flex-direction:column;border-radius:var(--ax-rounded-border-default);border-width:1px;border-color:rgba(var(--ax-color-border-default));background-color:rgba(var(--ax-color-surface))}.ax-menu-item-children:not(.ax-menu-item-children:empty) ax-menu-item{padding:.5rem 1rem;font-size:.875rem;line-height:1.25rem}.ax-menu-item-children:not(.ax-menu-item-children:empty) ax-menu-item:hover:not(.ax-menu-item-children:not(.ax-menu-item-children:empty) ax-menu-item:hover.ax-state-disabled){background-color:rgba(var(--ax-color-on-surface))}.ax-menu-item-children:not(.ax-menu-item-children:empty) ax-menu-item:hover:not(.ax-menu-item-children:not(.ax-menu-item-children:empty) ax-menu-item:hover.ax-state-disabled) ax-prefix,.ax-menu-item-children:not(.ax-menu-item-children:empty) ax-menu-item:hover:not(.ax-menu-item-children:not(.ax-menu-item-children:empty) ax-menu-item:hover.ax-state-disabled) ax-suffix{opacity:1}.ax-menu-item-children:not(.ax-menu-item-children:empty) ax-menu-item ax-prefix,.ax-menu-item-children:not(.ax-menu-item-children:empty) ax-menu-item ax-suffix{opacity:.75}.ax-menu-item-children:not(.ax-menu-item-children:empty) ax-menu-item .ax-menu-item-text{flex:1 1 0%}html[dir=rtl] .ax-parent-horizontal .ax-menu-item-child-icon{transform:rotate(-90deg)}html[dir=rtl] .ax-parent-horizontal .ax-menu-item-child-icon:before{-moz-transform:scale(1,-1);-webkit-transform:scale(1,-1);-o-transform:scale(1,-1);-ms-transform:scale(1,-1);transform:scaleY(-1)}.ax-parent-horizontal .ax-menu-item-child-icon{transform:rotate(-90deg)}\n"] }]
|
51
|
-
}], propDecorators: { children: [{
|
52
|
-
type: ContentChildren,
|
53
|
-
args: [AXMenuItemComponent]
|
54
|
-
}], __hostClass: [{
|
45
|
+
useExisting: AXMenuComponent
|
46
|
+
}
|
47
|
+
], 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.items\" [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-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-action-list-horizontal{padding-inline:1rem}ax-menu.ax-action-list-horizontal{min-width:12rem;gap:.875rem}ax-menu.ax-action-list-horizontal>ax-menu-item{font-weight:500}ax-menu.ax-action-list-horizontal>ax-menu-item>.ax-action-item-prefix{padding-inline-start:0!important}ax-menu.ax-action-list-horizontal>ax-menu-item>.ax-action-item-suffix:not(ax-menu.ax-action-list-horizontal>ax-menu-item>.ax-action-item-suffix:empty){padding-inline-end:0!important;margin-inline-start:0!important}ax-menu.ax-action-list-horizontal>ax-menu-item:hover{background-color:transparent!important}ax-menu.ax-action-list-horizontal>ax-menu-item:hover>.ax-action-item-prefix{color:rgba(var(--ax-color-primary-500))}ax-menu.ax-action-list-horizontal>ax-menu-item:hover>.ax-action-item-suffix{color:rgba(var(--ax-color-primary-500))}ax-menu.ax-action-list-vertical{width:max-content;min-width:12rem}ax-menu.ax-action-list-vertical>ax-menu-item{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"] }]
|
48
|
+
}], propDecorators: { __hostClass: [{
|
55
49
|
type: HostBinding,
|
56
50
|
args: ['class']
|
57
51
|
}] } });
|
58
|
-
//# sourceMappingURL=data:application/json;base64,
|
52
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWVudS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvbWVudS9zcmMvbGliL21lbnUuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL21lbnUvc3JjL2xpYi9tZW51LmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBaUIsV0FBVyxFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFDdkUsT0FBTyxFQUNMLHVCQUF1QixFQUN2QixTQUFTLEVBQ1QsV0FBVyxFQUNYLE1BQU0sRUFDTixLQUFLLEVBQ0wsTUFBTSxFQUNOLGlCQUFpQixHQUNsQixNQUFNLGVBQWUsQ0FBQztBQUN2QixPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDL0MsT0FBTyxFQUErRSxVQUFVLEVBQUUsTUFBTSxjQUFjLENBQUM7Ozs7O0FBSXZIOzs7R0FHRztBQWVILE1BQU0sT0FBTyxlQUFnQixTQUFRLFdBQVc7SUFkaEQ7O1FBZUUsZ0JBQVcsR0FBRyxLQUFLLENBQWdCLFlBQVksQ0FBQyxDQUFDO1FBRWpELFdBQU0sR0FBRyxLQUFLLENBQW9CLE9BQU8sQ0FBQyxDQUFDO1FBRTNDLFlBQU8sR0FBRyxLQUFLLENBQXFCLE9BQU8sQ0FBQyxDQUFDO1FBRTdDLFlBQU8sR0FBRyxNQUFNLENBQUMsYUFBYSxDQUFDLENBQUM7UUFFaEMsZ0JBQVcsR0FBRyxNQUFNLEVBQXlCLENBQUM7UUFFOUMsVUFBSyxHQUFHLEtBQUssQ0FBZSxFQUFFLENBQUMsQ0FBQztLQVlqQztJQVZDLGNBQWM7SUFDZCxJQUNJLFdBQVc7UUFDYixPQUFPLGtCQUFrQixJQUFJLENBQUMsV0FBVyxFQUFFLGlCQUFpQixDQUFDO0lBQy9ELENBQUM7SUFHTSxLQUFLO1FBQ1YsSUFBSSxDQUFDLE9BQU8sQ0FBQyxTQUFTLENBQUMsSUFBSSxFQUFFLENBQUM7SUFDaEMsQ0FBQzs4R0F0QlUsZUFBZTtrR0FBZixlQUFlLHlvQkFSZjtZQUNULGFBQWE7WUFDYjtnQkFDRSxPQUFPLEVBQUUsVUFBVTtnQkFDbkIsV0FBVyxFQUFFLGVBQWU7YUFDN0I7U0FDRixpREMvQkgseW5DQW1DYzs7MkZERkQsZUFBZTtrQkFkM0IsU0FBUzsrQkFDRSxTQUFTLGlCQUdKLGlCQUFpQixDQUFDLElBQUksbUJBQ3BCLHVCQUF1QixDQUFDLE1BQU0sYUFDcEM7d0JBQ1QsYUFBYTt3QkFDYjs0QkFDRSxPQUFPLEVBQUUsVUFBVTs0QkFDbkIsV0FBVyxpQkFBaUI7eUJBQzdCO3FCQUNGOzhCQWlCRyxXQUFXO3NCQURkLFdBQVc7dUJBQUMsT0FBTyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEFYT3JpZW50YXRpb24sIE5YQ29tcG9uZW50IH0gZnJvbSAnQGFjb3JleC9jb21wb25lbnRzL2NvbW1vbic7XG5pbXBvcnQge1xuICBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSxcbiAgQ29tcG9uZW50LFxuICBIb3N0QmluZGluZyxcbiAgaW5qZWN0LFxuICBpbnB1dCxcbiAgb3V0cHV0LFxuICBWaWV3RW5jYXBzdWxhdGlvbixcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBBWE1lbnVTZXJ2aWNlIH0gZnJvbSAnLi9tZW51LnNlcnZpY2UnO1xuaW1wb3J0IHsgQVhNZW51Q2xvc2VUcmlnZ2VyLCBBWE1lbnVJdGVtLCBBWE1lbnVJdGVtQ2xpY2tCYXNlRXZlbnQsIEFYTWVudU9wZW5UcmlnZ2VyLCBBWFJvb3RNZW51IH0gZnJvbSAnLi9tZW51LnR5cGVzJztcblxuZXhwb3J0IHR5cGUgQVhNZW51SXRlbXNDbGlja0V2ZW50ID0gQVhNZW51SXRlbUNsaWNrQmFzZUV2ZW50PEFYTWVudUNvbXBvbmVudD47XG5cbi8qKlxuICogUmVwcmVzZW50cyBhIG1lbnUgY29tcG9uZW50IHRoYXQgZGlzcGxheXMgbWVudSBpdGVtcy5cbiAqIEBjYXRlZ29yeSBDb21wb25lbnRzXG4gKi9cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2F4LW1lbnUnLFxuICB0ZW1wbGF0ZVVybDogJy4vbWVudS5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuL21lbnUuY29tcG9uZW50LnNjc3MnXSxcbiAgZW5jYXBzdWxhdGlvbjogVmlld0VuY2Fwc3VsYXRpb24uTm9uZSxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG4gIHByb3ZpZGVyczogW1xuICAgIEFYTWVudVNlcnZpY2UsXG4gICAge1xuICAgICAgcHJvdmlkZTogQVhSb290TWVudSxcbiAgICAgIHVzZUV4aXN0aW5nOiBBWE1lbnVDb21wb25lbnRcbiAgICB9XG4gIF1cbn0pXG5leHBvcnQgY2xhc3MgQVhNZW51Q29tcG9uZW50IGV4dGVuZHMgTlhDb21wb25lbnQge1xuICBvcmllbnRhdGlvbiA9IGlucHV0PEFYT3JpZW50YXRpb24+KCdob3Jpem9udGFsJyk7XG5cbiAgb3Blbk9uID0gaW5wdXQ8QVhNZW51T3BlblRyaWdnZXI+KCdob3ZlcicpO1xuXG4gIGNsb3NlT24gPSBpbnB1dDxBWE1lbnVDbG9zZVRyaWdnZXI+KCdsZWF2ZScpO1xuXG4gIHNlcnZpY2UgPSBpbmplY3QoQVhNZW51U2VydmljZSk7XG5cbiAgb25JdGVtQ2xpY2sgPSBvdXRwdXQ8QVhNZW51SXRlbXNDbGlja0V2ZW50PigpO1xuXG4gIGl0ZW1zID0gaW5wdXQ8QVhNZW51SXRlbVtdPihbXSk7XG5cbiAgLyoqIEBpZ25vcmUgKi9cbiAgQEhvc3RCaW5kaW5nKCdjbGFzcycpXG4gIGdldCBfX2hvc3RDbGFzcygpOiBzdHJpbmcge1xuICAgIHJldHVybiBgYXgtYWN0aW9uLWxpc3QtJHt0aGlzLm9yaWVudGF0aW9uKCl9IGF4LWFjdGlvbi1saXN0YDtcbiAgfVxuXG5cbiAgcHVibGljIGNsb3NlKCkge1xuICAgIHRoaXMuc2VydmljZS5jbG9zZUFsbCQubmV4dCgpO1xuICB9XG59XG4iLCI8bmctY29udGVudCBzZWxlY3Q9XCJheC1tZW51LWl0ZW0sYXgtdGl0bGUsbmctY29udGFpbmVyXCI+PC9uZy1jb250ZW50PlxuXG48bmctY29udGFpbmVyICpuZ0Zvcj1cImxldCBub2RlIG9mIGl0ZW1zKClcIiBbbmdUZW1wbGF0ZU91dGxldF09XCJSZWN1cnNpb25cIlxuICAgIFtuZ1RlbXBsYXRlT3V0bGV0Q29udGV4dF09XCJ7ICRpbXBsaWNpdDogbm9kZSB9XCI+XG48L25nLWNvbnRhaW5lcj5cbjxuZy10ZW1wbGF0ZSAjUmVjdXJzaW9uIGxldC1pdGVtPlxuICAgIEBpZihpdGVtLmdyb3VwPy50aXRsZSlcbiAgICB7XG4gICAgPGF4LXRpdGxlPnt7aXRlbS5ncm91cD8udGl0bGV9fTwvYXgtdGl0bGU+XG4gICAgfVxuICAgIDxheC1tZW51LWl0ZW0gW25hbWVdPVwiaXRlbS5uYW1lXCIgW2RhdGFdPVwiaXRlbS5kYXRhXCIgW2Rpc2FibGVkXT1cIml0ZW0uZGlzYWJsZWRcIiBbY29sb3JdPVwiaXRlbS5jb2xvclwiPlxuICAgICAgICA8YXgtcHJlZml4PlxuICAgICAgICAgICAgQGlmKGl0ZW0uaWNvbilcbiAgICAgICAgICAgIHtcbiAgICAgICAgICAgIDxheC1pY29uIFtpY29uXT1cIml0ZW0uaWNvblwiPlxuICAgICAgICAgICAgPC9heC1pY29uPlxuICAgICAgICAgICAgfVxuICAgICAgICA8L2F4LXByZWZpeD5cbiAgICAgICAgQGlmKGl0ZW0udGV4dClcbiAgICAgICAge1xuICAgICAgICA8YXgtdGV4dD57eyBpdGVtLnRleHQgfX08L2F4LXRleHQ+XG4gICAgICAgIH1cbiAgICAgICAgQGlmKGl0ZW0uc3VmZml4KVxuICAgICAgICB7XG4gICAgICAgIDxheC1zdWZmaXg+XG4gICAgICAgICAgICA8YXgtdGV4dD57eyBpdGVtLnN1ZmZpeC50ZXh0IH19PC9heC10ZXh0PlxuICAgICAgICA8L2F4LXN1ZmZpeD5cbiAgICAgICAgfVxuICAgICAgICA8bmctY29udGFpbmVyICpuZ0Zvcj1cImxldCBjaGlsZCBvZiBpdGVtLml0ZW1zXCIgW25nVGVtcGxhdGVPdXRsZXRdPVwiUmVjdXJzaW9uXCJcbiAgICAgICAgICAgIFtuZ1RlbXBsYXRlT3V0bGV0Q29udGV4dF09XCJ7ICRpbXBsaWNpdDogY2hpbGQgfVwiPjwvbmctY29udGFpbmVyPlxuICAgIDwvYXgtbWVudS1pdGVtPlxuICAgIEBpZihpdGVtLmJyZWFrKVxuICAgIHtcbiAgICA8YXgtZGl2aWRlcj48L2F4LWRpdmlkZXI+XG4gICAgfVxuPC9uZy10ZW1wbGF0ZT4iXX0=
|
@@ -1,4 +1,3 @@
|
|
1
|
-
import { AXButtonModule } from '@acorex/components/button';
|
2
1
|
import { AXDecoratorModule } from '@acorex/components/decorators';
|
3
2
|
import { AXLoadingModule } from '@acorex/components/loading';
|
4
3
|
import { AXPopoverModule } from '@acorex/components/popover';
|
@@ -6,23 +5,24 @@ import { AXTranslationModule } from '@acorex/core/translation';
|
|
6
5
|
import { OverlayModule } from '@angular/cdk/overlay';
|
7
6
|
import { CommonModule } from '@angular/common';
|
8
7
|
import { NgModule } from '@angular/core';
|
9
|
-
import { AXMenuItemComponent } from './menu-item/menu-item.component';
|
10
8
|
import { AXMenuComponent } from './menu.component';
|
9
|
+
import { AXContextMenuComponent } from './context-menu.component';
|
10
|
+
import { AXMenuItemComponent } from './menu-item.component';
|
11
11
|
import * as i0 from "@angular/core";
|
12
|
-
const COMPONENT = [AXMenuItemComponent, AXMenuComponent];
|
12
|
+
const COMPONENT = [AXMenuItemComponent, AXMenuComponent, AXContextMenuComponent];
|
13
13
|
const MODULES = [AXDecoratorModule, AXLoadingModule, AXTranslationModule, OverlayModule, AXPopoverModule];
|
14
14
|
export class AXMenuModule {
|
15
15
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: AXMenuModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
16
|
-
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.2.0", ngImport: i0, type: AXMenuModule, declarations: [AXMenuItemComponent, AXMenuComponent], imports: [CommonModule, AXDecoratorModule, AXLoadingModule, AXTranslationModule, OverlayModule, AXPopoverModule
|
17
|
-
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: AXMenuModule, imports: [CommonModule, MODULES
|
16
|
+
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.2.0", ngImport: i0, type: AXMenuModule, declarations: [AXMenuItemComponent, AXMenuComponent, AXContextMenuComponent], imports: [CommonModule, AXDecoratorModule, AXLoadingModule, AXTranslationModule, OverlayModule, AXPopoverModule], exports: [AXMenuItemComponent, AXMenuComponent, AXContextMenuComponent] }); }
|
17
|
+
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: AXMenuModule, imports: [CommonModule, MODULES] }); }
|
18
18
|
}
|
19
19
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: AXMenuModule, decorators: [{
|
20
20
|
type: NgModule,
|
21
21
|
args: [{
|
22
22
|
declarations: [...COMPONENT],
|
23
|
-
imports: [CommonModule, ...MODULES
|
23
|
+
imports: [CommonModule, ...MODULES],
|
24
24
|
exports: [...COMPONENT],
|
25
25
|
providers: [],
|
26
26
|
}]
|
27
27
|
}] });
|
28
|
-
//# sourceMappingURL=data:application/json;base64,
|
28
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWVudS5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvbWVudS9zcmMvbGliL21lbnUubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLCtCQUErQixDQUFDO0FBQ2xFLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQztBQUM3RCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sNEJBQTRCLENBQUM7QUFDN0QsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDL0QsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBQ3JELE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRXpDLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQztBQUNuRCxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUNsRSxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQzs7QUFFNUQsTUFBTSxTQUFTLEdBQUcsQ0FBQyxtQkFBbUIsRUFBRSxlQUFlLEVBQUUsc0JBQXNCLENBQUMsQ0FBQztBQUNqRixNQUFNLE9BQU8sR0FBRyxDQUFDLGlCQUFpQixFQUFFLGVBQWUsRUFBRSxtQkFBbUIsRUFBRSxhQUFhLEVBQUUsZUFBZSxDQUFDLENBQUM7QUFRMUcsTUFBTSxPQUFPLFlBQVk7OEdBQVosWUFBWTsrR0FBWixZQUFZLGlCQVROLG1CQUFtQixFQUFFLGVBQWUsRUFBRSxzQkFBc0IsYUFLbkUsWUFBWSxFQUpQLGlCQUFpQixFQUFFLGVBQWUsRUFBRSxtQkFBbUIsRUFBRSxhQUFhLEVBQUUsZUFBZSxhQURyRixtQkFBbUIsRUFBRSxlQUFlLEVBQUUsc0JBQXNCOytHQVNsRSxZQUFZLFlBSmIsWUFBWSxFQUFLLE9BQU87OzJGQUl2QixZQUFZO2tCQU54QixRQUFRO21CQUFDO29CQUNSLFlBQVksRUFBRSxDQUFDLEdBQUcsU0FBUyxDQUFDO29CQUM1QixPQUFPLEVBQUUsQ0FBQyxZQUFZLEVBQUUsR0FBRyxPQUFPLENBQUM7b0JBQ25DLE9BQU8sRUFBRSxDQUFDLEdBQUcsU0FBUyxDQUFDO29CQUN2QixTQUFTLEVBQUUsRUFBRTtpQkFDZCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEFYRGVjb3JhdG9yTW9kdWxlIH0gZnJvbSAnQGFjb3JleC9jb21wb25lbnRzL2RlY29yYXRvcnMnO1xuaW1wb3J0IHsgQVhMb2FkaW5nTW9kdWxlIH0gZnJvbSAnQGFjb3JleC9jb21wb25lbnRzL2xvYWRpbmcnO1xuaW1wb3J0IHsgQVhQb3BvdmVyTW9kdWxlIH0gZnJvbSAnQGFjb3JleC9jb21wb25lbnRzL3BvcG92ZXInO1xuaW1wb3J0IHsgQVhUcmFuc2xhdGlvbk1vZHVsZSB9IGZyb20gJ0BhY29yZXgvY29yZS90cmFuc2xhdGlvbic7XG5pbXBvcnQgeyBPdmVybGF5TW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY2RrL292ZXJsYXknO1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB7IEFYTWVudUNvbXBvbmVudCB9IGZyb20gJy4vbWVudS5jb21wb25lbnQnO1xuaW1wb3J0IHsgQVhDb250ZXh0TWVudUNvbXBvbmVudCB9IGZyb20gJy4vY29udGV4dC1tZW51LmNvbXBvbmVudCc7XG5pbXBvcnQgeyBBWE1lbnVJdGVtQ29tcG9uZW50IH0gZnJvbSAnLi9tZW51LWl0ZW0uY29tcG9uZW50JztcblxuY29uc3QgQ09NUE9ORU5UID0gW0FYTWVudUl0ZW1Db21wb25lbnQsIEFYTWVudUNvbXBvbmVudCwgQVhDb250ZXh0TWVudUNvbXBvbmVudF07XG5jb25zdCBNT0RVTEVTID0gW0FYRGVjb3JhdG9yTW9kdWxlLCBBWExvYWRpbmdNb2R1bGUsIEFYVHJhbnNsYXRpb25Nb2R1bGUsIE92ZXJsYXlNb2R1bGUsIEFYUG9wb3Zlck1vZHVsZV07XG5cbkBOZ01vZHVsZSh7XG4gIGRlY2xhcmF0aW9uczogWy4uLkNPTVBPTkVOVF0sXG4gIGltcG9ydHM6IFtDb21tb25Nb2R1bGUsIC4uLk1PRFVMRVNdLFxuICBleHBvcnRzOiBbLi4uQ09NUE9ORU5UXSxcbiAgcHJvdmlkZXJzOiBbXSxcbn0pXG5leHBvcnQgY2xhc3MgQVhNZW51TW9kdWxlIHsgfVxuIl19
|
@@ -1,17 +1,19 @@
|
|
1
1
|
import { Injectable } from '@angular/core';
|
2
|
-
import {
|
2
|
+
import { Subject } from 'rxjs';
|
3
3
|
import * as i0 from "@angular/core";
|
4
4
|
export class AXMenuService {
|
5
5
|
constructor() {
|
6
|
-
this.
|
6
|
+
this.closeAll$ = new Subject();
|
7
|
+
this.open$ = new Subject();
|
8
|
+
this.close$ = new Subject();
|
9
|
+
this.closeExcept$ = new Subject();
|
10
|
+
this.openContextMenu$ = new Subject();
|
11
|
+
this.closeAllContextMenu$ = new Subject();
|
7
12
|
}
|
8
13
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: AXMenuService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
9
|
-
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: AXMenuService
|
14
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: AXMenuService }); }
|
10
15
|
}
|
11
16
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: AXMenuService, decorators: [{
|
12
|
-
type: Injectable
|
13
|
-
args: [{
|
14
|
-
providedIn: 'root',
|
15
|
-
}]
|
17
|
+
type: Injectable
|
16
18
|
}] });
|
17
|
-
//# sourceMappingURL=data:application/json;base64,
|
19
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWVudS5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL21lbnUvc3JjL2xpYi9tZW51LnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMzQyxPQUFPLEVBQUUsT0FBTyxFQUFFLE1BQU0sTUFBTSxDQUFDOztBQUsvQixNQUFNLE9BQU8sYUFBYTtJQUQxQjtRQUVTLGNBQVMsR0FBa0IsSUFBSSxPQUFPLEVBQUUsQ0FBQztRQUN6QyxVQUFLLEdBQXFDLElBQUksT0FBTyxFQUFFLENBQUM7UUFDeEQsV0FBTSxHQUFxQyxJQUFJLE9BQU8sRUFBRSxDQUFDO1FBQ3pELGlCQUFZLEdBQUcsSUFBSSxPQUFPLEVBQTJCLENBQUM7UUFFdEQscUJBQWdCLEdBQUcsSUFBSSxPQUFPLEVBQTBDLENBQUM7UUFDekUseUJBQW9CLEdBQUcsSUFBSSxPQUFPLEVBQTBCLENBQUM7S0FDckU7OEdBUlksYUFBYTtrSEFBYixhQUFhOzsyRkFBYixhQUFhO2tCQUR6QixVQUFVIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgU3ViamVjdCB9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHsgQVhNZW51SXRlbUNvbXBvbmVudEJhc2UsIEFYUm9vdE1lbnUgfSBmcm9tICcuL21lbnUudHlwZXMnO1xuaW1wb3J0IHsgQVhQb2ludCB9IGZyb20gJ0BhY29yZXgvY29yZS91dGlscyc7XG5cbkBJbmplY3RhYmxlKClcbmV4cG9ydCBjbGFzcyBBWE1lbnVTZXJ2aWNlIHtcbiAgcHVibGljIGNsb3NlQWxsJDogU3ViamVjdDx2b2lkPiA9IG5ldyBTdWJqZWN0KCk7XG4gIHB1YmxpYyBvcGVuJDogU3ViamVjdDxBWE1lbnVJdGVtQ29tcG9uZW50QmFzZT4gPSBuZXcgU3ViamVjdCgpO1xuICBwdWJsaWMgY2xvc2UkOiBTdWJqZWN0PEFYTWVudUl0ZW1Db21wb25lbnRCYXNlPiA9IG5ldyBTdWJqZWN0KCk7XG4gIHB1YmxpYyBjbG9zZUV4Y2VwdCQgPSBuZXcgU3ViamVjdDxBWE1lbnVJdGVtQ29tcG9uZW50QmFzZT4oKTtcblxuICBwdWJsaWMgb3BlbkNvbnRleHRNZW51JCA9IG5ldyBTdWJqZWN0PHsgc2VuZGVyOiBBWFJvb3RNZW51LCBwb2ludDogQVhQb2ludCB9PigpO1xuICBwdWJsaWMgY2xvc2VBbGxDb250ZXh0TWVudSQgPSBuZXcgU3ViamVjdDx7IHNlbmRlcjogQVhSb290TWVudSB9PigpO1xufVxuIl19
|
@@ -0,0 +1,14 @@
|
|
1
|
+
import { NXClickEvent } from '@acorex/components/common';
|
2
|
+
export class AXRootMenu {
|
3
|
+
}
|
4
|
+
export class AXMenuItemComponentBase {
|
5
|
+
}
|
6
|
+
export class AXMenuItem {
|
7
|
+
}
|
8
|
+
export class AXMenuItemClickBaseEvent extends NXClickEvent {
|
9
|
+
constructor() {
|
10
|
+
super(...arguments);
|
11
|
+
this.canceled = false;
|
12
|
+
}
|
13
|
+
}
|
14
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWVudS50eXBlcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9tZW51L3NyYy9saWIvbWVudS50eXBlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQW1DLFlBQVksRUFBZSxNQUFNLDJCQUEyQixDQUFDO0FBT3ZHLE1BQU0sT0FBZ0IsVUFBVTtDQU0vQjtBQUVELE1BQU0sT0FBZ0IsdUJBQXVCO0NBQzVDO0FBR0QsTUFBTSxPQUFnQixVQUFVO0NBZ0IvQjtBQUdELE1BQU0sT0FBTyx3QkFBOEQsU0FBUSxZQUFlO0lBQWxHOztRQU1FLGFBQVEsR0FBRyxLQUFLLENBQUM7SUFDbkIsQ0FBQztDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQVhPcmllbnRhdGlvbiwgQVhTdHlsZUNvbG9yVHlwZSwgTlhDbGlja0V2ZW50LCBOWENvbXBvbmVudCB9IGZyb20gJ0BhY29yZXgvY29tcG9uZW50cy9jb21tb24nO1xuaW1wb3J0IHsgT3V0cHV0RW1pdHRlclJlZiwgV3JpdGFibGVTaWduYWwgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuZXhwb3J0IHR5cGUgQVhNZW51T3BlblRyaWdnZXIgPSAnY2xpY2snIHwgJ2hvdmVyJztcbmV4cG9ydCB0eXBlIEFYTWVudUNsb3NlVHJpZ2dlciA9ICdjbGljaycgfCAnbGVhdmUnO1xuXG5cbmV4cG9ydCBhYnN0cmFjdCBjbGFzcyBBWFJvb3RNZW51IHtcbiAgb3JpZW50YXRpb246IFdyaXRhYmxlU2lnbmFsPEFYT3JpZW50YXRpb24+O1xuICBvcGVuT246IFdyaXRhYmxlU2lnbmFsPEFYTWVudU9wZW5UcmlnZ2VyPjtcbiAgY2xvc2VPbjogV3JpdGFibGVTaWduYWw8QVhNZW51Q2xvc2VUcmlnZ2VyPjtcbiAgb25JdGVtQ2xpY2s6IE91dHB1dEVtaXR0ZXJSZWY8QVhNZW51SXRlbUNsaWNrQmFzZUV2ZW50PjtcbiAgbmF0aXZlRWxlbWVudDogSFRNTERpdkVsZW1lbnQ7XG59XG5cbmV4cG9ydCBhYnN0cmFjdCBjbGFzcyBBWE1lbnVJdGVtQ29tcG9uZW50QmFzZSB7XG59XG5cblxuZXhwb3J0IGFic3RyYWN0IGNsYXNzIEFYTWVudUl0ZW0ge1xuICBjb2xvcj86IEFYU3R5bGVDb2xvclR5cGVcbiAgbmFtZT86IHN0cmluZztcbiAgdGV4dDogc3RyaW5nO1xuICBkYXRhPzogYW55XG4gIGljb24/OiBzdHJpbmc7XG4gIGRpc2FibGVkPzogYm9vbGVhbjtcbiAgaXRlbXM/OiBBWE1lbnVJdGVtW107XG4gIHN1ZmZpeD86IHtcbiAgICB0ZXh0OiBzdHJpbmdcbiAgfTtcbiAgYnJlYWs/OiBib29sZWFuXG4gIGdyb3VwPzoge1xuICAgIG5hbWU/OiBzdHJpbmdcbiAgICB0aXRsZT86IHN0cmluZ1xuICB9XG59XG5cblxuZXhwb3J0IGNsYXNzIEFYTWVudUl0ZW1DbGlja0Jhc2VFdmVudDxUIGV4dGVuZHMgTlhDb21wb25lbnQgPSBOWENvbXBvbmVudD4gZXh0ZW5kcyBOWENsaWNrRXZlbnQ8VD4ge1xuICBpdGVtOiB7XG4gICAgbmFtZT86IHN0cmluZztcbiAgICB0ZXh0OiBzdHJpbmc7XG4gICAgZGF0YT86IGFueVxuICB9O1xuICBjYW5jZWxlZCA9IGZhbHNlO1xufVxuIl19
|