@smartbit4all/ng-client 4.2.64 → 4.2.65
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/view-context/smart-ui-action/components/menu/menu.component.mjs +9 -38
- package/esm2022/lib/view-context/smart-ui-action/components/menu/menu.constants.mjs +72 -0
- package/fesm2022/smartbit4all-ng-client.mjs +79 -37
- package/fesm2022/smartbit4all-ng-client.mjs.map +1 -1
- package/lib/view-context/smart-ui-action/components/menu/menu.constants.d.ts +3 -0
- package/package.json +1 -1
- package/smartbit4all-ng-client-4.2.65.tgz +0 -0
- package/smartbit4all-ng-client-4.2.64.tgz +0 -0
|
@@ -2,6 +2,7 @@ import { Component, EventEmitter, HostListener, Inject, Input, Optional, Output,
|
|
|
2
2
|
import { Subject, takeUntil } from 'rxjs';
|
|
3
3
|
import { COMPONENT_LIBRARY, ComponentLibrary } from '../../../utility/componentLibrary';
|
|
4
4
|
import { TemplatePortal } from '@angular/cdk/portal';
|
|
5
|
+
import { SUBMENU_POSITIONS, ROOT_MENU_POSITIONS } from './menu.constants';
|
|
5
6
|
import * as i0 from "@angular/core";
|
|
6
7
|
import * as i1 from "./menu.service";
|
|
7
8
|
import * as i2 from "@angular/cdk/overlay";
|
|
@@ -59,10 +60,9 @@ export class MenuComponent {
|
|
|
59
60
|
event.stopPropagation();
|
|
60
61
|
}
|
|
61
62
|
onDocumentClick(event) {
|
|
63
|
+
this.menuService.closeAllMenus();
|
|
62
64
|
if (this.overlayRef) {
|
|
63
|
-
this.
|
|
64
|
-
this.overlayRef = null;
|
|
65
|
-
return;
|
|
65
|
+
this.closeMenu();
|
|
66
66
|
}
|
|
67
67
|
}
|
|
68
68
|
get isOpen() {
|
|
@@ -82,47 +82,18 @@ export class MenuComponent {
|
|
|
82
82
|
if (this.isOpen) {
|
|
83
83
|
return;
|
|
84
84
|
}
|
|
85
|
-
else {
|
|
86
|
-
}
|
|
87
85
|
if (this.isSubmenu) {
|
|
88
|
-
console.log('emit submenu');
|
|
89
86
|
this.submenuOpened.emit(this.triggerAction);
|
|
90
87
|
}
|
|
91
88
|
else {
|
|
92
89
|
this.menuService.closeAllMenus();
|
|
93
90
|
}
|
|
94
91
|
let triggerElement = event.currentTarget;
|
|
95
|
-
const positions =
|
|
96
|
-
if (this.isSubmenu) {
|
|
97
|
-
positions.push({
|
|
98
|
-
originX: 'end',
|
|
99
|
-
originY: 'top',
|
|
100
|
-
overlayX: 'start',
|
|
101
|
-
overlayY: 'top',
|
|
102
|
-
}, {
|
|
103
|
-
originX: 'start',
|
|
104
|
-
originY: 'top',
|
|
105
|
-
overlayX: 'end',
|
|
106
|
-
overlayY: 'top',
|
|
107
|
-
});
|
|
108
|
-
}
|
|
109
|
-
else {
|
|
110
|
-
positions.push({
|
|
111
|
-
originX: 'start',
|
|
112
|
-
originY: 'bottom',
|
|
113
|
-
overlayX: 'start',
|
|
114
|
-
overlayY: 'top',
|
|
115
|
-
}, {
|
|
116
|
-
originX: 'end',
|
|
117
|
-
originY: 'bottom',
|
|
118
|
-
overlayX: 'end',
|
|
119
|
-
overlayY: 'top',
|
|
120
|
-
});
|
|
121
|
-
}
|
|
92
|
+
const positions = this.isSubmenu ? SUBMENU_POSITIONS : ROOT_MENU_POSITIONS;
|
|
122
93
|
let positionStrategy = this.overlayPositionBuilder
|
|
123
94
|
.flexibleConnectedTo(triggerElement)
|
|
124
95
|
.withFlexibleDimensions(false)
|
|
125
|
-
.withPush(
|
|
96
|
+
.withPush(true)
|
|
126
97
|
.withPositions(positions);
|
|
127
98
|
this.overlayRef = this.overlay.create({
|
|
128
99
|
positionStrategy,
|
|
@@ -133,7 +104,7 @@ export class MenuComponent {
|
|
|
133
104
|
this.overlayRef.attach(portal);
|
|
134
105
|
}
|
|
135
106
|
toggleMenu(event) {
|
|
136
|
-
if (this.isOpen) {
|
|
107
|
+
if (!this.isOpen) {
|
|
137
108
|
this.openMenu(event);
|
|
138
109
|
}
|
|
139
110
|
else {
|
|
@@ -148,11 +119,11 @@ export class MenuComponent {
|
|
|
148
119
|
});
|
|
149
120
|
}
|
|
150
121
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: MenuComponent, deps: [{ token: i1.UiMenuService }, { token: i2.Overlay }, { token: i0.ViewContainerRef }, { token: i2.OverlayPositionBuilder }, { token: COMPONENT_LIBRARY, optional: true }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
151
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.11", type: MenuComponent, selector: "ui-tiered-menu", inputs: { triggerAction: "triggerAction", isSubmenu: "isSubmenu" }, outputs: { actionClick: "actionClick", submenuOpened: "submenuOpened" }, host: { listeners: { "click": "onMenuClick($event)", "document:click": "onDocumentClick($event)" } }, viewQueries: [{ propertyName: "menuTemplate", first: true, predicate: ["menuTemplate"], descendants: true }, { propertyName: "submenuComponents", predicate: ["submenu"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "@if (isSubmenu) {\r\n<div class=\"submenu\" (mouseenter)=\"openMenu($event)\">\r\n <ng-container *ngTemplateOutlet=\"triggerTempalte\"></ng-container>\r\n <smart-icon [icon]=\"icon\" color=\"black\"></smart-icon>\r\n</div>\r\n}@else {\r\n<ng-container *ngTemplateOutlet=\"triggerTempalte\"></ng-container>\r\n}\r\n\r\n<ng-template #menuTemplate>\r\n <ul class=\"ui-tiered-menu\">\r\n <li *ngFor=\"let action of subActions\" [class.disabled]=\"action.disabled\">\r\n @if (action.subActions && action.subActions.length > 0) {\r\n\r\n <ui-tiered-menu\r\n #submenu\r\n [triggerAction]=\"action\"\r\n [isSubmenu]=\"true\"\r\n [subActions]=\"action.subActions!\"\r\n (actionClick)=\"actionClick.emit($event)\"\r\n (submenuOpened)=\"onSubmenuOpened(action)\"\r\n ></ui-tiered-menu>\r\n\r\n } @else {\r\n <ui-action-button\r\n [descriptor]=\"action.descriptor!\"\r\n [disabled]=\"!!action.disabled\"\r\n (actionClick)=\"!action.subActions?.length && onActionClick(action)\"\r\n ></ui-action-button>\r\n }\r\n </li>\r\n </ul>\r\n</ng-template>\r\n\r\n<ng-template #triggerTempalte>\r\n <ui-action-button\r\n [descriptor]=\"triggerAction.descriptor!\"\r\n [disabled]=\"!!triggerAction.disabled\"\r\n (actionClick)=\"
|
|
122
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.11", type: MenuComponent, selector: "ui-tiered-menu", inputs: { triggerAction: "triggerAction", isSubmenu: "isSubmenu" }, outputs: { actionClick: "actionClick", submenuOpened: "submenuOpened" }, host: { listeners: { "click": "onMenuClick($event)", "document:click": "onDocumentClick($event)" } }, viewQueries: [{ propertyName: "menuTemplate", first: true, predicate: ["menuTemplate"], descendants: true }, { propertyName: "submenuComponents", predicate: ["submenu"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "@if (isSubmenu) {\r\n<div class=\"submenu hoverEffect\" [class.activeSubmenu]=\"isOpen\" (mouseenter)=\"openMenu($event)\">\r\n <ng-container *ngTemplateOutlet=\"triggerTempalte\"></ng-container>\r\n <smart-icon [icon]=\"icon\" color=\"black\"></smart-icon>\r\n</div>\r\n}@else {\r\n<ng-container *ngTemplateOutlet=\"triggerTempalte\"></ng-container>\r\n}\r\n\r\n<ng-template #menuTemplate>\r\n <ul class=\"ui-tiered-menu\">\r\n <li *ngFor=\"let action of subActions\" class=\"hoverEffect\" [class.disabled]=\"action.disabled\">\r\n @if (action.subActions && action.subActions.length > 0) {\r\n\r\n <ui-tiered-menu\r\n #submenu\r\n [triggerAction]=\"action\"\r\n [isSubmenu]=\"true\"\r\n [subActions]=\"action.subActions!\"\r\n (actionClick)=\"actionClick.emit($event)\"\r\n (submenuOpened)=\"onSubmenuOpened(action)\"\r\n ></ui-tiered-menu>\r\n\r\n } @else {\r\n <ui-action-button\r\n [descriptor]=\"action.descriptor!\"\r\n [disabled]=\"!!action.disabled\"\r\n (actionClick)=\"!action.subActions?.length && onActionClick(action)\"\r\n ></ui-action-button>\r\n }\r\n </li>\r\n </ul>\r\n</ng-template>\r\n\r\n<ng-template #triggerTempalte>\r\n <ui-action-button\r\n [descriptor]=\"triggerAction.descriptor!\"\r\n [disabled]=\"!!triggerAction.disabled\"\r\n (actionClick)=\"toggleMenu($event.event)\"\r\n [class.submenuTrigger]=\"isSubmenu\"\r\n >\r\n </ui-action-button>\r\n</ng-template>\r\n", styles: [":host{display:inline-block;position:relative}ul,.ui-tiered-menu{top:100%;left:0;list-style:none;padding-left:0;margin:0;background:#fff;width:fit-content;box-shadow:2px 2px 8px #0003;z-index:1000;border-radius:5px;padding:.1rem}.submenuTrigger,.ui-tiered-menu ::ng-deep button{background-color:#fff;box-shadow:unset;border:unset;border-radius:unset;color:#000;width:100%;justify-content:flex-start}.hoverEffect:hover,.hoverEffect ::ng-deep button:hover{background-color:#f1f5f9}.hoverEffect.activeSubmenu,.hoverEffect.activeSubmenu ::ng-deep button{background-color:#f1f5f9}.ui-tiered-menu ::ng-deep ui-action-button,.ui-tiered-menu ::ng-deep ui-badge{width:100%}.ui-tiered-menu>li{position:relative}.submenu{display:flex;flex-direction:row;justify-content:space-between;align-items:center}.submenu ::ng-deep ui-action-button{flex:1}.disabled{color:#aaa;cursor:not-allowed}.ui-tiered-menu ui-tiered-menu{width:100%}smart-icon{align-content:center}\n"], dependencies: [{ kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i4.SmartIconComponent, selector: "smart-icon", inputs: ["icon", "color"] }, { kind: "component", type: i5.UiActionButtonComponent, selector: "ui-action-button", inputs: ["disabled", "descriptor", "code", "addedCssClass"], outputs: ["actionClick", "actionDoubleClick"] }, { kind: "component", type: MenuComponent, selector: "ui-tiered-menu", inputs: ["triggerAction", "isSubmenu"], outputs: ["actionClick", "submenuOpened"] }] }); }
|
|
152
123
|
}
|
|
153
124
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: MenuComponent, decorators: [{
|
|
154
125
|
type: Component,
|
|
155
|
-
args: [{ selector: 'ui-tiered-menu', template: "@if (isSubmenu) {\r\n<div class=\"submenu\" (mouseenter)=\"openMenu($event)\">\r\n <ng-container *ngTemplateOutlet=\"triggerTempalte\"></ng-container>\r\n <smart-icon [icon]=\"icon\" color=\"black\"></smart-icon>\r\n</div>\r\n}@else {\r\n<ng-container *ngTemplateOutlet=\"triggerTempalte\"></ng-container>\r\n}\r\n\r\n<ng-template #menuTemplate>\r\n <ul class=\"ui-tiered-menu\">\r\n <li *ngFor=\"let action of subActions\" [class.disabled]=\"action.disabled\">\r\n @if (action.subActions && action.subActions.length > 0) {\r\n\r\n <ui-tiered-menu\r\n #submenu\r\n [triggerAction]=\"action\"\r\n [isSubmenu]=\"true\"\r\n [subActions]=\"action.subActions!\"\r\n (actionClick)=\"actionClick.emit($event)\"\r\n (submenuOpened)=\"onSubmenuOpened(action)\"\r\n ></ui-tiered-menu>\r\n\r\n } @else {\r\n <ui-action-button\r\n [descriptor]=\"action.descriptor!\"\r\n [disabled]=\"!!action.disabled\"\r\n (actionClick)=\"!action.subActions?.length && onActionClick(action)\"\r\n ></ui-action-button>\r\n }\r\n </li>\r\n </ul>\r\n</ng-template>\r\n\r\n<ng-template #triggerTempalte>\r\n <ui-action-button\r\n [descriptor]=\"triggerAction.descriptor!\"\r\n [disabled]=\"!!triggerAction.disabled\"\r\n (actionClick)=\"
|
|
126
|
+
args: [{ selector: 'ui-tiered-menu', template: "@if (isSubmenu) {\r\n<div class=\"submenu hoverEffect\" [class.activeSubmenu]=\"isOpen\" (mouseenter)=\"openMenu($event)\">\r\n <ng-container *ngTemplateOutlet=\"triggerTempalte\"></ng-container>\r\n <smart-icon [icon]=\"icon\" color=\"black\"></smart-icon>\r\n</div>\r\n}@else {\r\n<ng-container *ngTemplateOutlet=\"triggerTempalte\"></ng-container>\r\n}\r\n\r\n<ng-template #menuTemplate>\r\n <ul class=\"ui-tiered-menu\">\r\n <li *ngFor=\"let action of subActions\" class=\"hoverEffect\" [class.disabled]=\"action.disabled\">\r\n @if (action.subActions && action.subActions.length > 0) {\r\n\r\n <ui-tiered-menu\r\n #submenu\r\n [triggerAction]=\"action\"\r\n [isSubmenu]=\"true\"\r\n [subActions]=\"action.subActions!\"\r\n (actionClick)=\"actionClick.emit($event)\"\r\n (submenuOpened)=\"onSubmenuOpened(action)\"\r\n ></ui-tiered-menu>\r\n\r\n } @else {\r\n <ui-action-button\r\n [descriptor]=\"action.descriptor!\"\r\n [disabled]=\"!!action.disabled\"\r\n (actionClick)=\"!action.subActions?.length && onActionClick(action)\"\r\n ></ui-action-button>\r\n }\r\n </li>\r\n </ul>\r\n</ng-template>\r\n\r\n<ng-template #triggerTempalte>\r\n <ui-action-button\r\n [descriptor]=\"triggerAction.descriptor!\"\r\n [disabled]=\"!!triggerAction.disabled\"\r\n (actionClick)=\"toggleMenu($event.event)\"\r\n [class.submenuTrigger]=\"isSubmenu\"\r\n >\r\n </ui-action-button>\r\n</ng-template>\r\n", styles: [":host{display:inline-block;position:relative}ul,.ui-tiered-menu{top:100%;left:0;list-style:none;padding-left:0;margin:0;background:#fff;width:fit-content;box-shadow:2px 2px 8px #0003;z-index:1000;border-radius:5px;padding:.1rem}.submenuTrigger,.ui-tiered-menu ::ng-deep button{background-color:#fff;box-shadow:unset;border:unset;border-radius:unset;color:#000;width:100%;justify-content:flex-start}.hoverEffect:hover,.hoverEffect ::ng-deep button:hover{background-color:#f1f5f9}.hoverEffect.activeSubmenu,.hoverEffect.activeSubmenu ::ng-deep button{background-color:#f1f5f9}.ui-tiered-menu ::ng-deep ui-action-button,.ui-tiered-menu ::ng-deep ui-badge{width:100%}.ui-tiered-menu>li{position:relative}.submenu{display:flex;flex-direction:row;justify-content:space-between;align-items:center}.submenu ::ng-deep ui-action-button{flex:1}.disabled{color:#aaa;cursor:not-allowed}.ui-tiered-menu ui-tiered-menu{width:100%}smart-icon{align-content:center}\n"] }]
|
|
156
127
|
}], ctorParameters: () => [{ type: i1.UiMenuService }, { type: i2.Overlay }, { type: i0.ViewContainerRef }, { type: i2.OverlayPositionBuilder }, { type: i6.ComponentLibrary, decorators: [{
|
|
157
128
|
type: Inject,
|
|
158
129
|
args: [COMPONENT_LIBRARY]
|
|
@@ -179,4 +150,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
|
|
|
179
150
|
type: HostListener,
|
|
180
151
|
args: ['document:click', ['$event']]
|
|
181
152
|
}] } });
|
|
182
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"menu.component.js","sourceRoot":"","sources":["../../../../../../../../projects/smart-ng-client/src/lib/view-context/smart-ui-action/components/menu/menu.component.ts","../../../../../../../../projects/smart-ng-client/src/lib/view-context/smart-ui-action/components/menu/menu.component.html"],"names":[],"mappings":"AAAA,OAAO,EACL,SAAS,EAET,YAAY,EACZ,YAAY,EACZ,MAAM,EACN,KAAK,EACL,QAAQ,EACR,MAAM,EAIN,SAAS,EACT,YAAY,GAEb,MAAM,eAAe,CAAC;AAEvB,OAAO,EAAE,OAAO,EAAE,SAAS,EAAE,MAAM,MAAM,CAAC;AAE1C,OAAO,EAAE,iBAAiB,EAAE,gBAAgB,EAAE,MAAM,mCAAmC,CAAC;AAOxF,OAAO,EAAE,cAAc,EAAE,MAAM,qBAAqB,CAAC;;;;;;;;AAOrD,MAAM,OAAO,aAAa;IAiBxB,YACU,WAA0B,EAC1B,OAAgB,EAChB,gBAAkC,EAClC,sBAA8C,EACR,OAA0B;QAJhE,gBAAW,GAAX,WAAW,CAAe;QAC1B,YAAO,GAAP,OAAO,CAAS;QAChB,qBAAgB,GAAhB,gBAAgB,CAAkB;QAClC,2BAAsB,GAAtB,sBAAsB,CAAwB;QACR,YAAO,GAAP,OAAO,CAAmB;QAlB1E,eAAU,GAAsB,IAAI,CAAC;QAG5B,cAAS,GAAY,KAAK,CAAC;QAE1B,gBAAW,GAAG,IAAI,YAAY,EAAY,CAAC;QAC3C,kBAAa,GAAG,IAAI,YAAY,EAAY,CAAC;QAE/C,aAAQ,GAAG,IAAI,OAAO,EAAQ,CAAC;QAEvC,mBAAc,GAAG,IAAI,GAAG,EAAqB,CAAC;QAC9C,eAAU,GAAe,EAAE,CAAC;QAS1B,IAAI,CAAC,OAAO,GAAG,OAAO,IAAI,gBAAgB,CAAC,OAAO,CAAC;QAEnD,IAAI,IAAI,CAAC,OAAO,KAAK,gBAAgB,CAAC,OAAO,EAAE,CAAC;YAC9C,IAAI,CAAC,IAAI,GAAG,eAAe,CAAC;QAC9B,CAAC;aAAM,IAAI,IAAI,CAAC,OAAO,KAAK,gBAAgB,CAAC,QAAQ,EAAE,CAAC;YACtD,IAAI,CAAC,IAAI,GAAG,eAAe,CAAC;QAC9B,CAAC;IACH,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,WAAW;aACb,cAAc,EAAE;aAChB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;aAC9B,SAAS,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,SAAS,EAAE,CAAC;QACnB,CAAC,CAAC,CAAC;IACP,CAAC;IAED,WAAW,CAAC,OAAsB;QAChC,IAAI,OAAO,CAAC,eAAe,CAAC,EAAE,CAAC;YAC7B,MAAM,OAAO,GAAG,OAAO,CAAC,eAAe,CAAC,CAAC,YAAwB,CAAC;YAClE,IAAI,CAAC,UAAU,GAAG,OAAO,EAAE,UAAU,IAAI,EAAE,CAAC;QAC9C,CAAC;IACH,CAAC;IACD,WAAW;QACT,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;QACrB,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC;IAC3B,CAAC;IAED,aAAa,CAAC,MAAgB;QAC5B,IAAI,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAC;YACrB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;YAC9B,IAAI,CAAC,WAAW,CAAC,aAAa,EAAE,CAAC;QACnC,CAAC;IACH,CAAC;IAGD,WAAW,CAAC,KAAY;QACtB,KAAK,CAAC,eAAe,EAAE,CAAC;IAC1B,CAAC;IAGD,eAAe,CAAC,KAAY;QAC1B,IAAI,IAAI,CAAC,UAAU,EAAE,CAAC;YACpB,IAAI,CAAC,UAAU,CAAC,OAAO,EAAE,CAAC;YAC1B,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;YACvB,OAAO;QACT,CAAC;IACH,CAAC;IAED,IAAI,MAAM;QACR,OAAO,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC;IAC3B,CAAC;IAED,SAAS;QACP,IAAI,IAAI,CAAC,UAAU,EAAE,CAAC;YACpB,IAAI,CAAC,UAAU,CAAC,OAAO,EAAE,CAAC;YAC1B,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;YACvB,OAAO;QACT,CAAC;QAED,IAAI,CAAC,iBAAiB,CAAC,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE;YACzC,OAAO,CAAC,SAAS,EAAE,CAAC;QACtB,CAAC,CAAC,CAAC;IACL,CAAC;IACD,QAAQ,CAAC,KAAiB;QACxB,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC;YAChB,OAAO;QACT,CAAC;aAAM,CAAC;QACR,CAAC;QAED,IAAI,IAAI,CAAC,SAAS,EAAE,CAAC;YACnB,OAAO,CAAC,GAAG,CAAC,cAAc,CAAC,CAAC;YAC5B,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;QAC9C,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,WAAW,CAAC,aAAa,EAAE,CAAC;QACnC,CAAC;QAED,IAAI,cAAc,GAAG,KAAK,CAAC,aAA4B,CAAC;QACxD,MAAM,SAAS,GAAwB,EAAE,CAAC;QAE1C,IAAI,IAAI,CAAC,SAAS,EAAE,CAAC;YACnB,SAAS,CAAC,IAAI,CACZ;gBACE,OAAO,EAAE,KAAK;gBACd,OAAO,EAAE,KAAK;gBACd,QAAQ,EAAE,OAAO;gBACjB,QAAQ,EAAE,KAAK;aAChB,EACD;gBACE,OAAO,EAAE,OAAO;gBAChB,OAAO,EAAE,KAAK;gBACd,QAAQ,EAAE,KAAK;gBACf,QAAQ,EAAE,KAAK;aAChB,CACF,CAAC;QACJ,CAAC;aAAM,CAAC;YACN,SAAS,CAAC,IAAI,CACZ;gBACE,OAAO,EAAE,OAAO;gBAChB,OAAO,EAAE,QAAQ;gBACjB,QAAQ,EAAE,OAAO;gBACjB,QAAQ,EAAE,KAAK;aAChB,EACD;gBACE,OAAO,EAAE,KAAK;gBACd,OAAO,EAAE,QAAQ;gBACjB,QAAQ,EAAE,KAAK;gBACf,QAAQ,EAAE,KAAK;aAChB,CACF,CAAC;QACJ,CAAC;QAED,IAAI,gBAAgB,GAAG,IAAI,CAAC,sBAAsB;aAC/C,mBAAmB,CAAC,cAAc,CAAC;aACnC,sBAAsB,CAAC,KAAK,CAAC;aAC7B,QAAQ,CAAC,KAAK,CAAC;aACf,aAAa,CAAC,SAAS,CAAC,CAAC;QAE5B,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC;YACpC,gBAAgB;YAChB,cAAc,EAAE,IAAI,CAAC,OAAO,CAAC,gBAAgB,CAAC,UAAU,EAAE;YAC1D,WAAW,EAAE,KAAK;SACnB,CAAC,CAAC;QAEH,IAAI,MAAM,GAAG,IAAI,cAAc,CAAC,IAAI,CAAC,YAAY,EAAE,IAAI,CAAC,gBAAgB,CAAC,CAAC;QAC1E,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;IACjC,CAAC;IAED,UAAU,CAAC,KAAiB;QAC1B,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC;YAChB,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;QACvB,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,SAAS,EAAE,CAAC;QACnB,CAAC;IACH,CAAC;IAED,eAAe,CAAC,YAAsB;QACpC,IAAI,CAAC,iBAAiB,CAAC,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE;YACzC,IAAI,OAAO,CAAC,aAAa,CAAC,IAAI,KAAK,YAAY,CAAC,IAAI,IAAI,OAAO,CAAC,UAAU,EAAE,CAAC;gBAC3E,OAAO,CAAC,SAAS,EAAE,CAAC;YACtB,CAAC;QACH,CAAC,CAAC,CAAC;IACL,CAAC;+GAvKU,aAAa,4IAsBd,iBAAiB;mGAtBhB,aAAa,8fCjC1B,w6CA2CA,49CDVa,aAAa;;4FAAb,aAAa;kBALzB,SAAS;+BACE,gBAAgB;;0BA0BvB,MAAM;2BAAC,iBAAiB;;0BAAG,QAAQ;yCArBb,iBAAiB;sBAAzC,YAAY;uBAAC,SAAS;gBAEI,YAAY;sBAAtC,SAAS;uBAAC,cAAc;gBAGhB,aAAa;sBAArB,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBAEI,WAAW;sBAApB,MAAM;gBACG,aAAa;sBAAtB,MAAM;gBAmDP,WAAW;sBADV,YAAY;uBAAC,OAAO,EAAE,CAAC,QAAQ,CAAC;gBAMjC,eAAe;sBADd,YAAY;uBAAC,gBAAgB,EAAE,CAAC,QAAQ,CAAC","sourcesContent":["import {\r\n  Component,\r\n  ElementRef,\r\n  EventEmitter,\r\n  HostListener,\r\n  Inject,\r\n  Input,\r\n  Optional,\r\n  Output,\r\n  QueryList,\r\n  SimpleChanges,\r\n  TemplateRef,\r\n  ViewChild,\r\n  ViewChildren,\r\n  ViewContainerRef,\r\n} from '@angular/core';\r\nimport { UiAction } from '../../../api';\r\nimport { Subject, takeUntil } from 'rxjs';\r\nimport { UiMenuService } from './menu.service';\r\nimport { COMPONENT_LIBRARY, ComponentLibrary } from '../../../utility/componentLibrary';\r\nimport {\r\n  ConnectedPosition,\r\n  Overlay,\r\n  OverlayPositionBuilder,\r\n  OverlayRef,\r\n} from '@angular/cdk/overlay';\r\nimport { TemplatePortal } from '@angular/cdk/portal';\r\n\r\n@Component({\r\n  selector: 'ui-tiered-menu',\r\n  templateUrl: './menu.component.html',\r\n  styleUrl: './menu.component.css',\r\n})\r\nexport class MenuComponent {\r\n  @ViewChildren('submenu') submenuComponents!: QueryList<MenuComponent>;\r\n\r\n  @ViewChild('menuTemplate') menuTemplate!: TemplateRef<any>;\r\n  overlayRef: OverlayRef | null = null;\r\n\r\n  @Input() triggerAction!: UiAction;\r\n  @Input() isSubmenu: boolean = false;\r\n\r\n  @Output() actionClick = new EventEmitter<UiAction>();\r\n  @Output() submenuOpened = new EventEmitter<UiAction>();\r\n\r\n  private destroy$ = new Subject<void>();\r\n  icon!: string;\r\n  submenuOpenMap = new Map<UiAction, boolean>();\r\n  subActions: UiAction[] = [];\r\n\r\n  constructor(\r\n    private menuService: UiMenuService,\r\n    private overlay: Overlay,\r\n    private viewContainerRef: ViewContainerRef,\r\n    private overlayPositionBuilder: OverlayPositionBuilder,\r\n    @Inject(COMPONENT_LIBRARY) @Optional() public compLib?: ComponentLibrary\r\n  ) {\r\n    this.compLib = compLib ?? ComponentLibrary.PRIMENG;\r\n\r\n    if (this.compLib === ComponentLibrary.PRIMENG) {\r\n      this.icon = 'chevron-right';\r\n    } else if (this.compLib === ComponentLibrary.MATERIAL) {\r\n      this.icon = 'chevron_right';\r\n    }\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this.menuService\r\n      .getCloseSignal()\r\n      .pipe(takeUntil(this.destroy$))\r\n      .subscribe(() => {\r\n        this.closeMenu();\r\n      });\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges) {\r\n    if (changes['triggerAction']) {\r\n      const trigger = changes['triggerAction'].currentValue as UiAction;\r\n      this.subActions = trigger?.subActions ?? [];\r\n    }\r\n  }\r\n  ngOnDestroy(): void {\r\n    this.destroy$.next();\r\n    this.destroy$.complete();\r\n  }\r\n\r\n  onActionClick(action: UiAction) {\r\n    if (!action.disabled) {\r\n      this.actionClick.emit(action);\r\n      this.menuService.closeAllMenus();\r\n    }\r\n  }\r\n\r\n  @HostListener('click', ['$event'])\r\n  onMenuClick(event: Event) {\r\n    event.stopPropagation();\r\n  }\r\n\r\n  @HostListener('document:click', ['$event'])\r\n  onDocumentClick(event: Event) {\r\n    if (this.overlayRef) {\r\n      this.overlayRef.dispose();\r\n      this.overlayRef = null;\r\n      return;\r\n    }\r\n  }\r\n\r\n  get isOpen(): boolean {\r\n    return !!this.overlayRef;\r\n  }\r\n\r\n  closeMenu() {\r\n    if (this.overlayRef) {\r\n      this.overlayRef.dispose();\r\n      this.overlayRef = null;\r\n      return;\r\n    }\r\n\r\n    this.submenuComponents.forEach((submenu) => {\r\n      submenu.closeMenu();\r\n    });\r\n  }\r\n  openMenu(event: MouseEvent) {\r\n    if (this.isOpen) {\r\n      return;\r\n    } else {\r\n    }\r\n\r\n    if (this.isSubmenu) {\r\n      console.log('emit submenu');\r\n      this.submenuOpened.emit(this.triggerAction);\r\n    } else {\r\n      this.menuService.closeAllMenus();\r\n    }\r\n\r\n    let triggerElement = event.currentTarget as HTMLElement;\r\n    const positions: ConnectedPosition[] = [];\r\n\r\n    if (this.isSubmenu) {\r\n      positions.push(\r\n        {\r\n          originX: 'end',\r\n          originY: 'top',\r\n          overlayX: 'start',\r\n          overlayY: 'top',\r\n        },\r\n        {\r\n          originX: 'start',\r\n          originY: 'top',\r\n          overlayX: 'end',\r\n          overlayY: 'top',\r\n        }\r\n      );\r\n    } else {\r\n      positions.push(\r\n        {\r\n          originX: 'start',\r\n          originY: 'bottom',\r\n          overlayX: 'start',\r\n          overlayY: 'top',\r\n        },\r\n        {\r\n          originX: 'end',\r\n          originY: 'bottom',\r\n          overlayX: 'end',\r\n          overlayY: 'top',\r\n        }\r\n      );\r\n    }\r\n\r\n    let positionStrategy = this.overlayPositionBuilder\r\n      .flexibleConnectedTo(triggerElement)\r\n      .withFlexibleDimensions(false)\r\n      .withPush(false)\r\n      .withPositions(positions);\r\n\r\n    this.overlayRef = this.overlay.create({\r\n      positionStrategy,\r\n      scrollStrategy: this.overlay.scrollStrategies.reposition(),\r\n      hasBackdrop: false,\r\n    });\r\n\r\n    let portal = new TemplatePortal(this.menuTemplate, this.viewContainerRef);\r\n    this.overlayRef.attach(portal);\r\n  }\r\n\r\n  toggleMenu(event: MouseEvent) {\r\n    if (this.isOpen) {\r\n      this.openMenu(event);\r\n    } else {\r\n      this.closeMenu();\r\n    }\r\n  }\r\n\r\n  onSubmenuOpened(openedAction: UiAction) {\r\n    this.submenuComponents.forEach((submenu) => {\r\n      if (submenu.triggerAction.code !== openedAction.code && submenu.overlayRef) {\r\n        submenu.closeMenu();\r\n      }\r\n    });\r\n  }\r\n}\r\n","@if (isSubmenu) {\r\n<div class=\"submenu\" (mouseenter)=\"openMenu($event)\">\r\n  <ng-container *ngTemplateOutlet=\"triggerTempalte\"></ng-container>\r\n  <smart-icon [icon]=\"icon\" color=\"black\"></smart-icon>\r\n</div>\r\n}@else {\r\n<ng-container *ngTemplateOutlet=\"triggerTempalte\"></ng-container>\r\n}\r\n\r\n<ng-template #menuTemplate>\r\n  <ul class=\"ui-tiered-menu\">\r\n    <li *ngFor=\"let action of subActions\" [class.disabled]=\"action.disabled\">\r\n      @if (action.subActions && action.subActions.length > 0) {\r\n\r\n      <ui-tiered-menu\r\n        #submenu\r\n        [triggerAction]=\"action\"\r\n        [isSubmenu]=\"true\"\r\n        [subActions]=\"action.subActions!\"\r\n        (actionClick)=\"actionClick.emit($event)\"\r\n        (submenuOpened)=\"onSubmenuOpened(action)\"\r\n      ></ui-tiered-menu>\r\n\r\n      } @else {\r\n      <ui-action-button\r\n        [descriptor]=\"action.descriptor!\"\r\n        [disabled]=\"!!action.disabled\"\r\n        (actionClick)=\"!action.subActions?.length && onActionClick(action)\"\r\n      ></ui-action-button>\r\n      }\r\n    </li>\r\n  </ul>\r\n</ng-template>\r\n\r\n<ng-template #triggerTempalte>\r\n  <ui-action-button\r\n    [descriptor]=\"triggerAction.descriptor!\"\r\n    [disabled]=\"!!triggerAction.disabled\"\r\n    (actionClick)=\"openMenu($event.event)\"\r\n    [class.submenuTrigger]=\"isSubmenu\"\r\n  >\r\n  </ui-action-button>\r\n</ng-template>\r\n"]}
|
|
153
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"menu.component.js","sourceRoot":"","sources":["../../../../../../../../projects/smart-ng-client/src/lib/view-context/smart-ui-action/components/menu/menu.component.ts","../../../../../../../../projects/smart-ng-client/src/lib/view-context/smart-ui-action/components/menu/menu.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  ElementRef,\r\n  EventEmitter,\r\n  HostListener,\r\n  Inject,\r\n  Input,\r\n  Optional,\r\n  Output,\r\n  QueryList,\r\n  SimpleChanges,\r\n  TemplateRef,\r\n  ViewChild,\r\n  ViewChildren,\r\n  ViewContainerRef,\r\n} from '@angular/core';\r\nimport { UiAction } from '../../../api';\r\nimport { Subject, takeUntil } from 'rxjs';\r\nimport { UiMenuService } from './menu.service';\r\nimport { COMPONENT_LIBRARY, ComponentLibrary } from '../../../utility/componentLibrary';\r\nimport {\r\n  ConnectedPosition,\r\n  Overlay,\r\n  OverlayPositionBuilder,\r\n  OverlayRef,\r\n} from '@angular/cdk/overlay';\r\nimport { TemplatePortal } from '@angular/cdk/portal';\r\nimport { SUBMENU_POSITIONS, ROOT_MENU_POSITIONS } from './menu.constants';\r\n\r\n@Component({\r\n  selector: 'ui-tiered-menu',\r\n  templateUrl: './menu.component.html',\r\n  styleUrl: './menu.component.css',\r\n})\r\nexport class MenuComponent {\r\n  @ViewChildren('submenu') submenuComponents!: QueryList<MenuComponent>;\r\n\r\n  @ViewChild('menuTemplate') menuTemplate!: TemplateRef<any>;\r\n  overlayRef: OverlayRef | null = null;\r\n\r\n  @Input() triggerAction!: UiAction;\r\n  @Input() isSubmenu: boolean = false;\r\n\r\n  @Output() actionClick = new EventEmitter<UiAction>();\r\n  @Output() submenuOpened = new EventEmitter<UiAction>();\r\n\r\n  private destroy$ = new Subject<void>();\r\n  icon!: string;\r\n  submenuOpenMap = new Map<UiAction, boolean>();\r\n  subActions: UiAction[] = [];\r\n\r\n  constructor(\r\n    private menuService: UiMenuService,\r\n    private overlay: Overlay,\r\n    private viewContainerRef: ViewContainerRef,\r\n    private overlayPositionBuilder: OverlayPositionBuilder,\r\n    @Inject(COMPONENT_LIBRARY) @Optional() public compLib?: ComponentLibrary\r\n  ) {\r\n    this.compLib = compLib ?? ComponentLibrary.PRIMENG;\r\n\r\n    if (this.compLib === ComponentLibrary.PRIMENG) {\r\n      this.icon = 'chevron-right';\r\n    } else if (this.compLib === ComponentLibrary.MATERIAL) {\r\n      this.icon = 'chevron_right';\r\n    }\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this.menuService\r\n      .getCloseSignal()\r\n      .pipe(takeUntil(this.destroy$))\r\n      .subscribe(() => {\r\n        this.closeMenu();\r\n      });\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges) {\r\n    if (changes['triggerAction']) {\r\n      const trigger = changes['triggerAction'].currentValue as UiAction;\r\n      this.subActions = trigger?.subActions ?? [];\r\n    }\r\n  }\r\n  ngOnDestroy(): void {\r\n    this.destroy$.next();\r\n    this.destroy$.complete();\r\n  }\r\n\r\n  onActionClick(action: UiAction) {\r\n    if (!action.disabled) {\r\n      this.actionClick.emit(action);\r\n      this.menuService.closeAllMenus();\r\n    }\r\n  }\r\n\r\n  @HostListener('click', ['$event'])\r\n  onMenuClick(event: Event) {\r\n    event.stopPropagation();\r\n  }\r\n\r\n  @HostListener('document:click', ['$event'])\r\n  onDocumentClick(event: Event) {\r\n    this.menuService.closeAllMenus();\r\n    if (this.overlayRef) {\r\n      this.closeMenu();\r\n    }\r\n  }\r\n\r\n  get isOpen(): boolean {\r\n    return !!this.overlayRef;\r\n  }\r\n\r\n  closeMenu() {\r\n    if (this.overlayRef) {\r\n      this.overlayRef.dispose();\r\n      this.overlayRef = null;\r\n      return;\r\n    }\r\n\r\n    this.submenuComponents.forEach((submenu) => {\r\n      submenu.closeMenu();\r\n    });\r\n  }\r\n  openMenu(event: MouseEvent) {\r\n    if (this.isOpen) {\r\n      return;\r\n    }\r\n\r\n    if (this.isSubmenu) {\r\n      this.submenuOpened.emit(this.triggerAction);\r\n    } else {\r\n      this.menuService.closeAllMenus();\r\n    }\r\n\r\n    let triggerElement = event.currentTarget as HTMLElement;\r\n    const positions: ConnectedPosition[] = this.isSubmenu ? SUBMENU_POSITIONS : ROOT_MENU_POSITIONS;\r\n\r\n    let positionStrategy = this.overlayPositionBuilder\r\n      .flexibleConnectedTo(triggerElement)\r\n      .withFlexibleDimensions(false)\r\n      .withPush(true)\r\n      .withPositions(positions);\r\n\r\n    this.overlayRef = this.overlay.create({\r\n      positionStrategy,\r\n      scrollStrategy: this.overlay.scrollStrategies.reposition(),\r\n      hasBackdrop: false,\r\n    });\r\n\r\n    let portal = new TemplatePortal(this.menuTemplate, this.viewContainerRef);\r\n    this.overlayRef.attach(portal);\r\n  }\r\n\r\n  toggleMenu(event: MouseEvent) {\r\n    if (!this.isOpen) {\r\n      this.openMenu(event);\r\n    } else {\r\n      this.closeMenu();\r\n    }\r\n  }\r\n\r\n  onSubmenuOpened(openedAction: UiAction) {\r\n    this.submenuComponents.forEach((submenu) => {\r\n      if (submenu.triggerAction.code !== openedAction.code && submenu.overlayRef) {\r\n        submenu.closeMenu();\r\n      }\r\n    });\r\n  }\r\n}\r\n","@if (isSubmenu) {\r\n<div class=\"submenu hoverEffect\" [class.activeSubmenu]=\"isOpen\" (mouseenter)=\"openMenu($event)\">\r\n  <ng-container *ngTemplateOutlet=\"triggerTempalte\"></ng-container>\r\n  <smart-icon [icon]=\"icon\" color=\"black\"></smart-icon>\r\n</div>\r\n}@else {\r\n<ng-container *ngTemplateOutlet=\"triggerTempalte\"></ng-container>\r\n}\r\n\r\n<ng-template #menuTemplate>\r\n  <ul class=\"ui-tiered-menu\">\r\n    <li *ngFor=\"let action of subActions\" class=\"hoverEffect\" [class.disabled]=\"action.disabled\">\r\n      @if (action.subActions && action.subActions.length > 0) {\r\n\r\n      <ui-tiered-menu\r\n        #submenu\r\n        [triggerAction]=\"action\"\r\n        [isSubmenu]=\"true\"\r\n        [subActions]=\"action.subActions!\"\r\n        (actionClick)=\"actionClick.emit($event)\"\r\n        (submenuOpened)=\"onSubmenuOpened(action)\"\r\n      ></ui-tiered-menu>\r\n\r\n      } @else {\r\n      <ui-action-button\r\n        [descriptor]=\"action.descriptor!\"\r\n        [disabled]=\"!!action.disabled\"\r\n        (actionClick)=\"!action.subActions?.length && onActionClick(action)\"\r\n      ></ui-action-button>\r\n      }\r\n    </li>\r\n  </ul>\r\n</ng-template>\r\n\r\n<ng-template #triggerTempalte>\r\n  <ui-action-button\r\n    [descriptor]=\"triggerAction.descriptor!\"\r\n    [disabled]=\"!!triggerAction.disabled\"\r\n    (actionClick)=\"toggleMenu($event.event)\"\r\n    [class.submenuTrigger]=\"isSubmenu\"\r\n  >\r\n  </ui-action-button>\r\n</ng-template>\r\n"]}
|
|
@@ -0,0 +1,72 @@
|
|
|
1
|
+
export const SUBMENU_POSITIONS = [
|
|
2
|
+
// Top-left of trigger → aligns top-left of overlay
|
|
3
|
+
// {
|
|
4
|
+
// originX: 'start',
|
|
5
|
+
// originY: 'top',
|
|
6
|
+
// overlayX: 'start',
|
|
7
|
+
// overlayY: 'top',
|
|
8
|
+
// },
|
|
9
|
+
// // Bottom-left of trigger → aligns bottom-left of overlay
|
|
10
|
+
// {
|
|
11
|
+
// originX: 'start',
|
|
12
|
+
// originY: 'bottom',
|
|
13
|
+
// overlayX: 'start',
|
|
14
|
+
// overlayY: 'bottom',
|
|
15
|
+
// },
|
|
16
|
+
// // Top-right of trigger → aligns top-right of overlay
|
|
17
|
+
// {
|
|
18
|
+
// originX: 'end',
|
|
19
|
+
// originY: 'top',
|
|
20
|
+
// overlayX: 'end',
|
|
21
|
+
// overlayY: 'top',
|
|
22
|
+
// },
|
|
23
|
+
// // Bottom-right of trigger → aligns bottom-right of overlay
|
|
24
|
+
// {
|
|
25
|
+
// originX: 'end',
|
|
26
|
+
// originY: 'bottom',
|
|
27
|
+
// overlayX: 'end',
|
|
28
|
+
// overlayY: 'bottom',
|
|
29
|
+
// },
|
|
30
|
+
{
|
|
31
|
+
originX: 'end',
|
|
32
|
+
originY: 'top',
|
|
33
|
+
overlayX: 'start',
|
|
34
|
+
overlayY: 'top',
|
|
35
|
+
},
|
|
36
|
+
{
|
|
37
|
+
originX: 'start',
|
|
38
|
+
originY: 'top',
|
|
39
|
+
overlayX: 'end',
|
|
40
|
+
overlayY: 'top',
|
|
41
|
+
},
|
|
42
|
+
];
|
|
43
|
+
export const ROOT_MENU_POSITIONS = [
|
|
44
|
+
// Below-right of trigger
|
|
45
|
+
{
|
|
46
|
+
originX: 'end',
|
|
47
|
+
originY: 'bottom',
|
|
48
|
+
overlayX: 'end',
|
|
49
|
+
overlayY: 'top',
|
|
50
|
+
}, // Below-left of trigger
|
|
51
|
+
{
|
|
52
|
+
originX: 'start',
|
|
53
|
+
originY: 'bottom',
|
|
54
|
+
overlayX: 'start',
|
|
55
|
+
overlayY: 'top',
|
|
56
|
+
},
|
|
57
|
+
// Above-left of trigger
|
|
58
|
+
{
|
|
59
|
+
originX: 'start',
|
|
60
|
+
originY: 'top',
|
|
61
|
+
overlayX: 'start',
|
|
62
|
+
overlayY: 'bottom',
|
|
63
|
+
},
|
|
64
|
+
// Above-right of trigger
|
|
65
|
+
{
|
|
66
|
+
originX: 'end',
|
|
67
|
+
originY: 'top',
|
|
68
|
+
overlayX: 'end',
|
|
69
|
+
overlayY: 'bottom',
|
|
70
|
+
},
|
|
71
|
+
];
|
|
72
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWVudS5jb25zdGFudHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9zbWFydC1uZy1jbGllbnQvc3JjL2xpYi92aWV3LWNvbnRleHQvc21hcnQtdWktYWN0aW9uL2NvbXBvbmVudHMvbWVudS9tZW51LmNvbnN0YW50cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFFQSxNQUFNLENBQUMsTUFBTSxpQkFBaUIsR0FBd0I7SUFDcEQsbURBQW1EO0lBQ25ELE1BQU07SUFDTix3QkFBd0I7SUFDeEIsc0JBQXNCO0lBQ3RCLHlCQUF5QjtJQUN6Qix1QkFBdUI7SUFDdkIsT0FBTztJQUNQLDhEQUE4RDtJQUM5RCxNQUFNO0lBQ04sd0JBQXdCO0lBQ3hCLHlCQUF5QjtJQUN6Qix5QkFBeUI7SUFDekIsMEJBQTBCO0lBQzFCLE9BQU87SUFDUCwwREFBMEQ7SUFDMUQsTUFBTTtJQUNOLHNCQUFzQjtJQUN0QixzQkFBc0I7SUFDdEIsdUJBQXVCO0lBQ3ZCLHVCQUF1QjtJQUN2QixPQUFPO0lBQ1AsZ0VBQWdFO0lBQ2hFLE1BQU07SUFDTixzQkFBc0I7SUFDdEIseUJBQXlCO0lBQ3pCLHVCQUF1QjtJQUN2QiwwQkFBMEI7SUFDMUIsT0FBTztJQUNQO1FBQ0UsT0FBTyxFQUFFLEtBQUs7UUFDZCxPQUFPLEVBQUUsS0FBSztRQUNkLFFBQVEsRUFBRSxPQUFPO1FBQ2pCLFFBQVEsRUFBRSxLQUFLO0tBQ2hCO0lBQ0Q7UUFDRSxPQUFPLEVBQUUsT0FBTztRQUNoQixPQUFPLEVBQUUsS0FBSztRQUNkLFFBQVEsRUFBRSxLQUFLO1FBQ2YsUUFBUSxFQUFFLEtBQUs7S0FDaEI7Q0FDRixDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0sbUJBQW1CLEdBQXdCO0lBQ3RELHlCQUF5QjtJQUN6QjtRQUNFLE9BQU8sRUFBRSxLQUFLO1FBQ2QsT0FBTyxFQUFFLFFBQVE7UUFDakIsUUFBUSxFQUFFLEtBQUs7UUFDZixRQUFRLEVBQUUsS0FBSztLQUNoQixFQUFFLHdCQUF3QjtJQUMzQjtRQUNFLE9BQU8sRUFBRSxPQUFPO1FBQ2hCLE9BQU8sRUFBRSxRQUFRO1FBQ2pCLFFBQVEsRUFBRSxPQUFPO1FBQ2pCLFFBQVEsRUFBRSxLQUFLO0tBQ2hCO0lBRUQsd0JBQXdCO0lBQ3hCO1FBQ0UsT0FBTyxFQUFFLE9BQU87UUFDaEIsT0FBTyxFQUFFLEtBQUs7UUFDZCxRQUFRLEVBQUUsT0FBTztRQUNqQixRQUFRLEVBQUUsUUFBUTtLQUNuQjtJQUNELHlCQUF5QjtJQUN6QjtRQUNFLE9BQU8sRUFBRSxLQUFLO1FBQ2QsT0FBTyxFQUFFLEtBQUs7UUFDZCxRQUFRLEVBQUUsS0FBSztRQUNmLFFBQVEsRUFBRSxRQUFRO0tBQ25CO0NBQ0YsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbm5lY3RlZFBvc2l0aW9uIH0gZnJvbSAnQGFuZ3VsYXIvY2RrL292ZXJsYXknO1xyXG5cclxuZXhwb3J0IGNvbnN0IFNVQk1FTlVfUE9TSVRJT05TOiBDb25uZWN0ZWRQb3NpdGlvbltdID0gW1xyXG4gIC8vIFRvcC1sZWZ0IG9mIHRyaWdnZXIg4oaSIGFsaWducyB0b3AtbGVmdCBvZiBvdmVybGF5XHJcbiAgLy8gICB7XHJcbiAgLy8gICAgIG9yaWdpblg6ICdzdGFydCcsXHJcbiAgLy8gICAgIG9yaWdpblk6ICd0b3AnLFxyXG4gIC8vICAgICBvdmVybGF5WDogJ3N0YXJ0JyxcclxuICAvLyAgICAgb3ZlcmxheVk6ICd0b3AnLFxyXG4gIC8vICAgfSxcclxuICAvLyAgIC8vIEJvdHRvbS1sZWZ0IG9mIHRyaWdnZXIg4oaSIGFsaWducyBib3R0b20tbGVmdCBvZiBvdmVybGF5XHJcbiAgLy8gICB7XHJcbiAgLy8gICAgIG9yaWdpblg6ICdzdGFydCcsXHJcbiAgLy8gICAgIG9yaWdpblk6ICdib3R0b20nLFxyXG4gIC8vICAgICBvdmVybGF5WDogJ3N0YXJ0JyxcclxuICAvLyAgICAgb3ZlcmxheVk6ICdib3R0b20nLFxyXG4gIC8vICAgfSxcclxuICAvLyAgIC8vIFRvcC1yaWdodCBvZiB0cmlnZ2VyIOKGkiBhbGlnbnMgdG9wLXJpZ2h0IG9mIG92ZXJsYXlcclxuICAvLyAgIHtcclxuICAvLyAgICAgb3JpZ2luWDogJ2VuZCcsXHJcbiAgLy8gICAgIG9yaWdpblk6ICd0b3AnLFxyXG4gIC8vICAgICBvdmVybGF5WDogJ2VuZCcsXHJcbiAgLy8gICAgIG92ZXJsYXlZOiAndG9wJyxcclxuICAvLyAgIH0sXHJcbiAgLy8gICAvLyBCb3R0b20tcmlnaHQgb2YgdHJpZ2dlciDihpIgYWxpZ25zIGJvdHRvbS1yaWdodCBvZiBvdmVybGF5XHJcbiAgLy8gICB7XHJcbiAgLy8gICAgIG9yaWdpblg6ICdlbmQnLFxyXG4gIC8vICAgICBvcmlnaW5ZOiAnYm90dG9tJyxcclxuICAvLyAgICAgb3ZlcmxheVg6ICdlbmQnLFxyXG4gIC8vICAgICBvdmVybGF5WTogJ2JvdHRvbScsXHJcbiAgLy8gICB9LFxyXG4gIHtcclxuICAgIG9yaWdpblg6ICdlbmQnLFxyXG4gICAgb3JpZ2luWTogJ3RvcCcsXHJcbiAgICBvdmVybGF5WDogJ3N0YXJ0JyxcclxuICAgIG92ZXJsYXlZOiAndG9wJyxcclxuICB9LFxyXG4gIHtcclxuICAgIG9yaWdpblg6ICdzdGFydCcsXHJcbiAgICBvcmlnaW5ZOiAndG9wJyxcclxuICAgIG92ZXJsYXlYOiAnZW5kJyxcclxuICAgIG92ZXJsYXlZOiAndG9wJyxcclxuICB9LFxyXG5dO1xyXG5cclxuZXhwb3J0IGNvbnN0IFJPT1RfTUVOVV9QT1NJVElPTlM6IENvbm5lY3RlZFBvc2l0aW9uW10gPSBbXHJcbiAgLy8gQmVsb3ctcmlnaHQgb2YgdHJpZ2dlclxyXG4gIHtcclxuICAgIG9yaWdpblg6ICdlbmQnLFxyXG4gICAgb3JpZ2luWTogJ2JvdHRvbScsXHJcbiAgICBvdmVybGF5WDogJ2VuZCcsXHJcbiAgICBvdmVybGF5WTogJ3RvcCcsXHJcbiAgfSwgLy8gQmVsb3ctbGVmdCBvZiB0cmlnZ2VyXHJcbiAge1xyXG4gICAgb3JpZ2luWDogJ3N0YXJ0JyxcclxuICAgIG9yaWdpblk6ICdib3R0b20nLFxyXG4gICAgb3ZlcmxheVg6ICdzdGFydCcsXHJcbiAgICBvdmVybGF5WTogJ3RvcCcsXHJcbiAgfSxcclxuXHJcbiAgLy8gQWJvdmUtbGVmdCBvZiB0cmlnZ2VyXHJcbiAge1xyXG4gICAgb3JpZ2luWDogJ3N0YXJ0JyxcclxuICAgIG9yaWdpblk6ICd0b3AnLFxyXG4gICAgb3ZlcmxheVg6ICdzdGFydCcsXHJcbiAgICBvdmVybGF5WTogJ2JvdHRvbScsXHJcbiAgfSxcclxuICAvLyBBYm92ZS1yaWdodCBvZiB0cmlnZ2VyXHJcbiAge1xyXG4gICAgb3JpZ2luWDogJ2VuZCcsXHJcbiAgICBvcmlnaW5ZOiAndG9wJyxcclxuICAgIG92ZXJsYXlYOiAnZW5kJyxcclxuICAgIG92ZXJsYXlZOiAnYm90dG9tJyxcclxuICB9LFxyXG5dO1xyXG4iXX0=
|
|
@@ -5781,6 +5781,78 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
|
|
|
5781
5781
|
args: ['fileUploadDialogService']
|
|
5782
5782
|
}] }, { type: i1$4.MatSnackBar }] });
|
|
5783
5783
|
|
|
5784
|
+
const SUBMENU_POSITIONS = [
|
|
5785
|
+
// Top-left of trigger → aligns top-left of overlay
|
|
5786
|
+
// {
|
|
5787
|
+
// originX: 'start',
|
|
5788
|
+
// originY: 'top',
|
|
5789
|
+
// overlayX: 'start',
|
|
5790
|
+
// overlayY: 'top',
|
|
5791
|
+
// },
|
|
5792
|
+
// // Bottom-left of trigger → aligns bottom-left of overlay
|
|
5793
|
+
// {
|
|
5794
|
+
// originX: 'start',
|
|
5795
|
+
// originY: 'bottom',
|
|
5796
|
+
// overlayX: 'start',
|
|
5797
|
+
// overlayY: 'bottom',
|
|
5798
|
+
// },
|
|
5799
|
+
// // Top-right of trigger → aligns top-right of overlay
|
|
5800
|
+
// {
|
|
5801
|
+
// originX: 'end',
|
|
5802
|
+
// originY: 'top',
|
|
5803
|
+
// overlayX: 'end',
|
|
5804
|
+
// overlayY: 'top',
|
|
5805
|
+
// },
|
|
5806
|
+
// // Bottom-right of trigger → aligns bottom-right of overlay
|
|
5807
|
+
// {
|
|
5808
|
+
// originX: 'end',
|
|
5809
|
+
// originY: 'bottom',
|
|
5810
|
+
// overlayX: 'end',
|
|
5811
|
+
// overlayY: 'bottom',
|
|
5812
|
+
// },
|
|
5813
|
+
{
|
|
5814
|
+
originX: 'end',
|
|
5815
|
+
originY: 'top',
|
|
5816
|
+
overlayX: 'start',
|
|
5817
|
+
overlayY: 'top',
|
|
5818
|
+
},
|
|
5819
|
+
{
|
|
5820
|
+
originX: 'start',
|
|
5821
|
+
originY: 'top',
|
|
5822
|
+
overlayX: 'end',
|
|
5823
|
+
overlayY: 'top',
|
|
5824
|
+
},
|
|
5825
|
+
];
|
|
5826
|
+
const ROOT_MENU_POSITIONS = [
|
|
5827
|
+
// Below-right of trigger
|
|
5828
|
+
{
|
|
5829
|
+
originX: 'end',
|
|
5830
|
+
originY: 'bottom',
|
|
5831
|
+
overlayX: 'end',
|
|
5832
|
+
overlayY: 'top',
|
|
5833
|
+
}, // Below-left of trigger
|
|
5834
|
+
{
|
|
5835
|
+
originX: 'start',
|
|
5836
|
+
originY: 'bottom',
|
|
5837
|
+
overlayX: 'start',
|
|
5838
|
+
overlayY: 'top',
|
|
5839
|
+
},
|
|
5840
|
+
// Above-left of trigger
|
|
5841
|
+
{
|
|
5842
|
+
originX: 'start',
|
|
5843
|
+
originY: 'top',
|
|
5844
|
+
overlayX: 'start',
|
|
5845
|
+
overlayY: 'bottom',
|
|
5846
|
+
},
|
|
5847
|
+
// Above-right of trigger
|
|
5848
|
+
{
|
|
5849
|
+
originX: 'end',
|
|
5850
|
+
originY: 'top',
|
|
5851
|
+
overlayX: 'end',
|
|
5852
|
+
overlayY: 'bottom',
|
|
5853
|
+
},
|
|
5854
|
+
];
|
|
5855
|
+
|
|
5784
5856
|
class UiMenuService {
|
|
5785
5857
|
constructor() {
|
|
5786
5858
|
this.closeMenus$ = new Subject();
|
|
@@ -5849,10 +5921,9 @@ class MenuComponent {
|
|
|
5849
5921
|
event.stopPropagation();
|
|
5850
5922
|
}
|
|
5851
5923
|
onDocumentClick(event) {
|
|
5924
|
+
this.menuService.closeAllMenus();
|
|
5852
5925
|
if (this.overlayRef) {
|
|
5853
|
-
this.
|
|
5854
|
-
this.overlayRef = null;
|
|
5855
|
-
return;
|
|
5926
|
+
this.closeMenu();
|
|
5856
5927
|
}
|
|
5857
5928
|
}
|
|
5858
5929
|
get isOpen() {
|
|
@@ -5872,47 +5943,18 @@ class MenuComponent {
|
|
|
5872
5943
|
if (this.isOpen) {
|
|
5873
5944
|
return;
|
|
5874
5945
|
}
|
|
5875
|
-
else {
|
|
5876
|
-
}
|
|
5877
5946
|
if (this.isSubmenu) {
|
|
5878
|
-
console.log('emit submenu');
|
|
5879
5947
|
this.submenuOpened.emit(this.triggerAction);
|
|
5880
5948
|
}
|
|
5881
5949
|
else {
|
|
5882
5950
|
this.menuService.closeAllMenus();
|
|
5883
5951
|
}
|
|
5884
5952
|
let triggerElement = event.currentTarget;
|
|
5885
|
-
const positions =
|
|
5886
|
-
if (this.isSubmenu) {
|
|
5887
|
-
positions.push({
|
|
5888
|
-
originX: 'end',
|
|
5889
|
-
originY: 'top',
|
|
5890
|
-
overlayX: 'start',
|
|
5891
|
-
overlayY: 'top',
|
|
5892
|
-
}, {
|
|
5893
|
-
originX: 'start',
|
|
5894
|
-
originY: 'top',
|
|
5895
|
-
overlayX: 'end',
|
|
5896
|
-
overlayY: 'top',
|
|
5897
|
-
});
|
|
5898
|
-
}
|
|
5899
|
-
else {
|
|
5900
|
-
positions.push({
|
|
5901
|
-
originX: 'start',
|
|
5902
|
-
originY: 'bottom',
|
|
5903
|
-
overlayX: 'start',
|
|
5904
|
-
overlayY: 'top',
|
|
5905
|
-
}, {
|
|
5906
|
-
originX: 'end',
|
|
5907
|
-
originY: 'bottom',
|
|
5908
|
-
overlayX: 'end',
|
|
5909
|
-
overlayY: 'top',
|
|
5910
|
-
});
|
|
5911
|
-
}
|
|
5953
|
+
const positions = this.isSubmenu ? SUBMENU_POSITIONS : ROOT_MENU_POSITIONS;
|
|
5912
5954
|
let positionStrategy = this.overlayPositionBuilder
|
|
5913
5955
|
.flexibleConnectedTo(triggerElement)
|
|
5914
5956
|
.withFlexibleDimensions(false)
|
|
5915
|
-
.withPush(
|
|
5957
|
+
.withPush(true)
|
|
5916
5958
|
.withPositions(positions);
|
|
5917
5959
|
this.overlayRef = this.overlay.create({
|
|
5918
5960
|
positionStrategy,
|
|
@@ -5923,7 +5965,7 @@ class MenuComponent {
|
|
|
5923
5965
|
this.overlayRef.attach(portal);
|
|
5924
5966
|
}
|
|
5925
5967
|
toggleMenu(event) {
|
|
5926
|
-
if (this.isOpen) {
|
|
5968
|
+
if (!this.isOpen) {
|
|
5927
5969
|
this.openMenu(event);
|
|
5928
5970
|
}
|
|
5929
5971
|
else {
|
|
@@ -5938,11 +5980,11 @@ class MenuComponent {
|
|
|
5938
5980
|
});
|
|
5939
5981
|
}
|
|
5940
5982
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: MenuComponent, deps: [{ token: UiMenuService }, { token: i2$2.Overlay }, { token: i0.ViewContainerRef }, { token: i2$2.OverlayPositionBuilder }, { token: COMPONENT_LIBRARY, optional: true }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
5941
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.11", type: MenuComponent, selector: "ui-tiered-menu", inputs: { triggerAction: "triggerAction", isSubmenu: "isSubmenu" }, outputs: { actionClick: "actionClick", submenuOpened: "submenuOpened" }, host: { listeners: { "click": "onMenuClick($event)", "document:click": "onDocumentClick($event)" } }, viewQueries: [{ propertyName: "menuTemplate", first: true, predicate: ["menuTemplate"], descendants: true }, { propertyName: "submenuComponents", predicate: ["submenu"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "@if (isSubmenu) {\r\n<div class=\"submenu\" (mouseenter)=\"openMenu($event)\">\r\n <ng-container *ngTemplateOutlet=\"triggerTempalte\"></ng-container>\r\n <smart-icon [icon]=\"icon\" color=\"black\"></smart-icon>\r\n</div>\r\n}@else {\r\n<ng-container *ngTemplateOutlet=\"triggerTempalte\"></ng-container>\r\n}\r\n\r\n<ng-template #menuTemplate>\r\n <ul class=\"ui-tiered-menu\">\r\n <li *ngFor=\"let action of subActions\" [class.disabled]=\"action.disabled\">\r\n @if (action.subActions && action.subActions.length > 0) {\r\n\r\n <ui-tiered-menu\r\n #submenu\r\n [triggerAction]=\"action\"\r\n [isSubmenu]=\"true\"\r\n [subActions]=\"action.subActions!\"\r\n (actionClick)=\"actionClick.emit($event)\"\r\n (submenuOpened)=\"onSubmenuOpened(action)\"\r\n ></ui-tiered-menu>\r\n\r\n } @else {\r\n <ui-action-button\r\n [descriptor]=\"action.descriptor!\"\r\n [disabled]=\"!!action.disabled\"\r\n (actionClick)=\"!action.subActions?.length && onActionClick(action)\"\r\n ></ui-action-button>\r\n }\r\n </li>\r\n </ul>\r\n</ng-template>\r\n\r\n<ng-template #triggerTempalte>\r\n <ui-action-button\r\n [descriptor]=\"triggerAction.descriptor!\"\r\n [disabled]=\"!!triggerAction.disabled\"\r\n (actionClick)=\"
|
|
5983
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.11", type: MenuComponent, selector: "ui-tiered-menu", inputs: { triggerAction: "triggerAction", isSubmenu: "isSubmenu" }, outputs: { actionClick: "actionClick", submenuOpened: "submenuOpened" }, host: { listeners: { "click": "onMenuClick($event)", "document:click": "onDocumentClick($event)" } }, viewQueries: [{ propertyName: "menuTemplate", first: true, predicate: ["menuTemplate"], descendants: true }, { propertyName: "submenuComponents", predicate: ["submenu"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "@if (isSubmenu) {\r\n<div class=\"submenu hoverEffect\" [class.activeSubmenu]=\"isOpen\" (mouseenter)=\"openMenu($event)\">\r\n <ng-container *ngTemplateOutlet=\"triggerTempalte\"></ng-container>\r\n <smart-icon [icon]=\"icon\" color=\"black\"></smart-icon>\r\n</div>\r\n}@else {\r\n<ng-container *ngTemplateOutlet=\"triggerTempalte\"></ng-container>\r\n}\r\n\r\n<ng-template #menuTemplate>\r\n <ul class=\"ui-tiered-menu\">\r\n <li *ngFor=\"let action of subActions\" class=\"hoverEffect\" [class.disabled]=\"action.disabled\">\r\n @if (action.subActions && action.subActions.length > 0) {\r\n\r\n <ui-tiered-menu\r\n #submenu\r\n [triggerAction]=\"action\"\r\n [isSubmenu]=\"true\"\r\n [subActions]=\"action.subActions!\"\r\n (actionClick)=\"actionClick.emit($event)\"\r\n (submenuOpened)=\"onSubmenuOpened(action)\"\r\n ></ui-tiered-menu>\r\n\r\n } @else {\r\n <ui-action-button\r\n [descriptor]=\"action.descriptor!\"\r\n [disabled]=\"!!action.disabled\"\r\n (actionClick)=\"!action.subActions?.length && onActionClick(action)\"\r\n ></ui-action-button>\r\n }\r\n </li>\r\n </ul>\r\n</ng-template>\r\n\r\n<ng-template #triggerTempalte>\r\n <ui-action-button\r\n [descriptor]=\"triggerAction.descriptor!\"\r\n [disabled]=\"!!triggerAction.disabled\"\r\n (actionClick)=\"toggleMenu($event.event)\"\r\n [class.submenuTrigger]=\"isSubmenu\"\r\n >\r\n </ui-action-button>\r\n</ng-template>\r\n", styles: [":host{display:inline-block;position:relative}ul,.ui-tiered-menu{top:100%;left:0;list-style:none;padding-left:0;margin:0;background:#fff;width:fit-content;box-shadow:2px 2px 8px #0003;z-index:1000;border-radius:5px;padding:.1rem}.submenuTrigger,.ui-tiered-menu ::ng-deep button{background-color:#fff;box-shadow:unset;border:unset;border-radius:unset;color:#000;width:100%;justify-content:flex-start}.hoverEffect:hover,.hoverEffect ::ng-deep button:hover{background-color:#f1f5f9}.hoverEffect.activeSubmenu,.hoverEffect.activeSubmenu ::ng-deep button{background-color:#f1f5f9}.ui-tiered-menu ::ng-deep ui-action-button,.ui-tiered-menu ::ng-deep ui-badge{width:100%}.ui-tiered-menu>li{position:relative}.submenu{display:flex;flex-direction:row;justify-content:space-between;align-items:center}.submenu ::ng-deep ui-action-button{flex:1}.disabled{color:#aaa;cursor:not-allowed}.ui-tiered-menu ui-tiered-menu{width:100%}smart-icon{align-content:center}\n"], dependencies: [{ kind: "directive", type: i1$1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1$1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: SmartIconComponent, selector: "smart-icon", inputs: ["icon", "color"] }, { kind: "component", type: UiActionButtonComponent, selector: "ui-action-button", inputs: ["disabled", "descriptor", "code", "addedCssClass"], outputs: ["actionClick", "actionDoubleClick"] }, { kind: "component", type: MenuComponent, selector: "ui-tiered-menu", inputs: ["triggerAction", "isSubmenu"], outputs: ["actionClick", "submenuOpened"] }] }); }
|
|
5942
5984
|
}
|
|
5943
5985
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: MenuComponent, decorators: [{
|
|
5944
5986
|
type: Component,
|
|
5945
|
-
args: [{ selector: 'ui-tiered-menu', template: "@if (isSubmenu) {\r\n<div class=\"submenu\" (mouseenter)=\"openMenu($event)\">\r\n <ng-container *ngTemplateOutlet=\"triggerTempalte\"></ng-container>\r\n <smart-icon [icon]=\"icon\" color=\"black\"></smart-icon>\r\n</div>\r\n}@else {\r\n<ng-container *ngTemplateOutlet=\"triggerTempalte\"></ng-container>\r\n}\r\n\r\n<ng-template #menuTemplate>\r\n <ul class=\"ui-tiered-menu\">\r\n <li *ngFor=\"let action of subActions\" [class.disabled]=\"action.disabled\">\r\n @if (action.subActions && action.subActions.length > 0) {\r\n\r\n <ui-tiered-menu\r\n #submenu\r\n [triggerAction]=\"action\"\r\n [isSubmenu]=\"true\"\r\n [subActions]=\"action.subActions!\"\r\n (actionClick)=\"actionClick.emit($event)\"\r\n (submenuOpened)=\"onSubmenuOpened(action)\"\r\n ></ui-tiered-menu>\r\n\r\n } @else {\r\n <ui-action-button\r\n [descriptor]=\"action.descriptor!\"\r\n [disabled]=\"!!action.disabled\"\r\n (actionClick)=\"!action.subActions?.length && onActionClick(action)\"\r\n ></ui-action-button>\r\n }\r\n </li>\r\n </ul>\r\n</ng-template>\r\n\r\n<ng-template #triggerTempalte>\r\n <ui-action-button\r\n [descriptor]=\"triggerAction.descriptor!\"\r\n [disabled]=\"!!triggerAction.disabled\"\r\n (actionClick)=\"
|
|
5987
|
+
args: [{ selector: 'ui-tiered-menu', template: "@if (isSubmenu) {\r\n<div class=\"submenu hoverEffect\" [class.activeSubmenu]=\"isOpen\" (mouseenter)=\"openMenu($event)\">\r\n <ng-container *ngTemplateOutlet=\"triggerTempalte\"></ng-container>\r\n <smart-icon [icon]=\"icon\" color=\"black\"></smart-icon>\r\n</div>\r\n}@else {\r\n<ng-container *ngTemplateOutlet=\"triggerTempalte\"></ng-container>\r\n}\r\n\r\n<ng-template #menuTemplate>\r\n <ul class=\"ui-tiered-menu\">\r\n <li *ngFor=\"let action of subActions\" class=\"hoverEffect\" [class.disabled]=\"action.disabled\">\r\n @if (action.subActions && action.subActions.length > 0) {\r\n\r\n <ui-tiered-menu\r\n #submenu\r\n [triggerAction]=\"action\"\r\n [isSubmenu]=\"true\"\r\n [subActions]=\"action.subActions!\"\r\n (actionClick)=\"actionClick.emit($event)\"\r\n (submenuOpened)=\"onSubmenuOpened(action)\"\r\n ></ui-tiered-menu>\r\n\r\n } @else {\r\n <ui-action-button\r\n [descriptor]=\"action.descriptor!\"\r\n [disabled]=\"!!action.disabled\"\r\n (actionClick)=\"!action.subActions?.length && onActionClick(action)\"\r\n ></ui-action-button>\r\n }\r\n </li>\r\n </ul>\r\n</ng-template>\r\n\r\n<ng-template #triggerTempalte>\r\n <ui-action-button\r\n [descriptor]=\"triggerAction.descriptor!\"\r\n [disabled]=\"!!triggerAction.disabled\"\r\n (actionClick)=\"toggleMenu($event.event)\"\r\n [class.submenuTrigger]=\"isSubmenu\"\r\n >\r\n </ui-action-button>\r\n</ng-template>\r\n", styles: [":host{display:inline-block;position:relative}ul,.ui-tiered-menu{top:100%;left:0;list-style:none;padding-left:0;margin:0;background:#fff;width:fit-content;box-shadow:2px 2px 8px #0003;z-index:1000;border-radius:5px;padding:.1rem}.submenuTrigger,.ui-tiered-menu ::ng-deep button{background-color:#fff;box-shadow:unset;border:unset;border-radius:unset;color:#000;width:100%;justify-content:flex-start}.hoverEffect:hover,.hoverEffect ::ng-deep button:hover{background-color:#f1f5f9}.hoverEffect.activeSubmenu,.hoverEffect.activeSubmenu ::ng-deep button{background-color:#f1f5f9}.ui-tiered-menu ::ng-deep ui-action-button,.ui-tiered-menu ::ng-deep ui-badge{width:100%}.ui-tiered-menu>li{position:relative}.submenu{display:flex;flex-direction:row;justify-content:space-between;align-items:center}.submenu ::ng-deep ui-action-button{flex:1}.disabled{color:#aaa;cursor:not-allowed}.ui-tiered-menu ui-tiered-menu{width:100%}smart-icon{align-content:center}\n"] }]
|
|
5946
5988
|
}], ctorParameters: () => [{ type: UiMenuService }, { type: i2$2.Overlay }, { type: i0.ViewContainerRef }, { type: i2$2.OverlayPositionBuilder }, { type: ComponentLibrary, decorators: [{
|
|
5947
5989
|
type: Inject,
|
|
5948
5990
|
args: [COMPONENT_LIBRARY]
|