@smartbit4all/ng-client 4.2.63 → 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 +81 -53
- package/esm2022/lib/view-context/smart-ui-action/components/menu/menu.constants.mjs +72 -0
- package/esm2022/lib/view-context/smart-ui-action/ui-action-button/ui-action-button.component.mjs +2 -1
- package/esm2022/lib/view-context/smart-ui-action/ui-action-toolbar.component.mjs +1 -1
- package/fesm2022/smartbit4all-ng-client.mjs +233 -133
- package/fesm2022/smartbit4all-ng-client.mjs.map +1 -1
- package/lib/view-context/smart-ui-action/components/menu/menu.component.d.ts +18 -12
- package/lib/view-context/smart-ui-action/components/menu/menu.constants.d.ts +3 -0
- package/lib/view-context/smart-ui-action/ui-action-button/ui-action-button.component.d.ts +2 -1
- package/package.json +1 -1
- package/smartbit4all-ng-client-4.2.65.tgz +0 -0
- package/smartbit4all-ng-client-4.2.63.tgz +0 -0
|
@@ -1,23 +1,29 @@
|
|
|
1
1
|
import { Component, EventEmitter, HostListener, Inject, Input, Optional, Output, ViewChild, ViewChildren, } from '@angular/core';
|
|
2
2
|
import { Subject, takeUntil } from 'rxjs';
|
|
3
3
|
import { COMPONENT_LIBRARY, ComponentLibrary } from '../../../utility/componentLibrary';
|
|
4
|
+
import { TemplatePortal } from '@angular/cdk/portal';
|
|
5
|
+
import { SUBMENU_POSITIONS, ROOT_MENU_POSITIONS } from './menu.constants';
|
|
4
6
|
import * as i0 from "@angular/core";
|
|
5
7
|
import * as i1 from "./menu.service";
|
|
6
|
-
import * as i2 from "@angular/
|
|
7
|
-
import * as i3 from "
|
|
8
|
-
import * as i4 from "
|
|
9
|
-
import * as i5 from "
|
|
8
|
+
import * as i2 from "@angular/cdk/overlay";
|
|
9
|
+
import * as i3 from "@angular/common";
|
|
10
|
+
import * as i4 from "../../../../smart-icon/smart-icon/smart-icon.component";
|
|
11
|
+
import * as i5 from "../../ui-action-button/ui-action-button.component";
|
|
12
|
+
import * as i6 from "../../../utility/componentLibrary";
|
|
10
13
|
export class MenuComponent {
|
|
11
|
-
constructor(menuService, compLib) {
|
|
14
|
+
constructor(menuService, overlay, viewContainerRef, overlayPositionBuilder, compLib) {
|
|
12
15
|
this.menuService = menuService;
|
|
16
|
+
this.overlay = overlay;
|
|
17
|
+
this.viewContainerRef = viewContainerRef;
|
|
18
|
+
this.overlayPositionBuilder = overlayPositionBuilder;
|
|
13
19
|
this.compLib = compLib;
|
|
14
|
-
this.
|
|
20
|
+
this.overlayRef = null;
|
|
15
21
|
this.isSubmenu = false;
|
|
16
22
|
this.actionClick = new EventEmitter();
|
|
23
|
+
this.submenuOpened = new EventEmitter();
|
|
17
24
|
this.destroy$ = new Subject();
|
|
18
|
-
this.visible = false;
|
|
19
25
|
this.submenuOpenMap = new Map();
|
|
20
|
-
this.
|
|
26
|
+
this.subActions = [];
|
|
21
27
|
this.compLib = compLib ?? ComponentLibrary.PRIMENG;
|
|
22
28
|
if (this.compLib === ComponentLibrary.PRIMENG) {
|
|
23
29
|
this.icon = 'chevron-right';
|
|
@@ -31,10 +37,15 @@ export class MenuComponent {
|
|
|
31
37
|
.getCloseSignal()
|
|
32
38
|
.pipe(takeUntil(this.destroy$))
|
|
33
39
|
.subscribe(() => {
|
|
34
|
-
this.
|
|
35
|
-
this.submenuComponents?.forEach((submenu) => (submenu.visible = false));
|
|
40
|
+
this.closeMenu();
|
|
36
41
|
});
|
|
37
42
|
}
|
|
43
|
+
ngOnChanges(changes) {
|
|
44
|
+
if (changes['triggerAction']) {
|
|
45
|
+
const trigger = changes['triggerAction'].currentValue;
|
|
46
|
+
this.subActions = trigger?.subActions ?? [];
|
|
47
|
+
}
|
|
48
|
+
}
|
|
38
49
|
ngOnDestroy() {
|
|
39
50
|
this.destroy$.next();
|
|
40
51
|
this.destroy$.complete();
|
|
@@ -49,72 +60,89 @@ export class MenuComponent {
|
|
|
49
60
|
event.stopPropagation();
|
|
50
61
|
}
|
|
51
62
|
onDocumentClick(event) {
|
|
52
|
-
this.
|
|
53
|
-
this.
|
|
54
|
-
|
|
55
|
-
toggleMenu() {
|
|
56
|
-
const wasVisible = this.visible;
|
|
57
|
-
if (!this.isSubmenu) {
|
|
58
|
-
this.menuService.closeAllMenus();
|
|
59
|
-
}
|
|
60
|
-
this.visible = !wasVisible;
|
|
61
|
-
if (!this.visible) {
|
|
62
|
-
this.submenuComponents.forEach((submenu) => (submenu.visible = false));
|
|
63
|
+
this.menuService.closeAllMenus();
|
|
64
|
+
if (this.overlayRef) {
|
|
65
|
+
this.closeMenu();
|
|
63
66
|
}
|
|
64
|
-
this.adjustAlignment();
|
|
65
67
|
}
|
|
66
|
-
|
|
68
|
+
get isOpen() {
|
|
69
|
+
return !!this.overlayRef;
|
|
70
|
+
}
|
|
71
|
+
closeMenu() {
|
|
72
|
+
if (this.overlayRef) {
|
|
73
|
+
this.overlayRef.dispose();
|
|
74
|
+
this.overlayRef = null;
|
|
75
|
+
return;
|
|
76
|
+
}
|
|
67
77
|
this.submenuComponents.forEach((submenu) => {
|
|
68
|
-
submenu.
|
|
78
|
+
submenu.closeMenu();
|
|
69
79
|
});
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
80
|
+
}
|
|
81
|
+
openMenu(event) {
|
|
82
|
+
if (this.isOpen) {
|
|
83
|
+
return;
|
|
84
|
+
}
|
|
85
|
+
if (this.isSubmenu) {
|
|
86
|
+
this.submenuOpened.emit(this.triggerAction);
|
|
73
87
|
}
|
|
88
|
+
else {
|
|
89
|
+
this.menuService.closeAllMenus();
|
|
90
|
+
}
|
|
91
|
+
let triggerElement = event.currentTarget;
|
|
92
|
+
const positions = this.isSubmenu ? SUBMENU_POSITIONS : ROOT_MENU_POSITIONS;
|
|
93
|
+
let positionStrategy = this.overlayPositionBuilder
|
|
94
|
+
.flexibleConnectedTo(triggerElement)
|
|
95
|
+
.withFlexibleDimensions(false)
|
|
96
|
+
.withPush(true)
|
|
97
|
+
.withPositions(positions);
|
|
98
|
+
this.overlayRef = this.overlay.create({
|
|
99
|
+
positionStrategy,
|
|
100
|
+
scrollStrategy: this.overlay.scrollStrategies.reposition(),
|
|
101
|
+
hasBackdrop: false,
|
|
102
|
+
});
|
|
103
|
+
let portal = new TemplatePortal(this.menuTemplate, this.viewContainerRef);
|
|
104
|
+
this.overlayRef.attach(portal);
|
|
74
105
|
}
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
106
|
+
toggleMenu(event) {
|
|
107
|
+
if (!this.isOpen) {
|
|
108
|
+
this.openMenu(event);
|
|
109
|
+
}
|
|
110
|
+
else {
|
|
111
|
+
this.closeMenu();
|
|
112
|
+
}
|
|
81
113
|
}
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
if (
|
|
85
|
-
|
|
114
|
+
onSubmenuOpened(openedAction) {
|
|
115
|
+
this.submenuComponents.forEach((submenu) => {
|
|
116
|
+
if (submenu.triggerAction.code !== openedAction.code && submenu.overlayRef) {
|
|
117
|
+
submenu.closeMenu();
|
|
86
118
|
}
|
|
87
|
-
|
|
88
|
-
}
|
|
89
|
-
const rect = this.menuRef.nativeElement.getBoundingClientRect();
|
|
90
|
-
const overflowRight = rect.right > window.innerWidth;
|
|
91
|
-
this.alignLeft = overflowRight;
|
|
119
|
+
});
|
|
92
120
|
}
|
|
93
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: MenuComponent, deps: [{ token: i1.UiMenuService }, { token: COMPONENT_LIBRARY, optional: true }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
94
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.11", type: MenuComponent, selector: "ui-tiered-menu", inputs: {
|
|
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 }); }
|
|
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"] }] }); }
|
|
95
123
|
}
|
|
96
124
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: MenuComponent, decorators: [{
|
|
97
125
|
type: Component,
|
|
98
|
-
args: [{ selector: 'ui-tiered-menu', template: "@if (
|
|
99
|
-
}], ctorParameters: () => [{ type: i1.UiMenuService }, { type:
|
|
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"] }]
|
|
127
|
+
}], ctorParameters: () => [{ type: i1.UiMenuService }, { type: i2.Overlay }, { type: i0.ViewContainerRef }, { type: i2.OverlayPositionBuilder }, { type: i6.ComponentLibrary, decorators: [{
|
|
100
128
|
type: Inject,
|
|
101
129
|
args: [COMPONENT_LIBRARY]
|
|
102
130
|
}, {
|
|
103
131
|
type: Optional
|
|
104
|
-
}] }], propDecorators: {
|
|
105
|
-
type: ViewChild,
|
|
106
|
-
args: ['menuContainer', { static: false }]
|
|
107
|
-
}], submenuComponents: [{
|
|
132
|
+
}] }], propDecorators: { submenuComponents: [{
|
|
108
133
|
type: ViewChildren,
|
|
109
134
|
args: ['submenu']
|
|
110
|
-
}],
|
|
111
|
-
type:
|
|
135
|
+
}], menuTemplate: [{
|
|
136
|
+
type: ViewChild,
|
|
137
|
+
args: ['menuTemplate']
|
|
112
138
|
}], triggerAction: [{
|
|
113
139
|
type: Input
|
|
114
140
|
}], isSubmenu: [{
|
|
115
141
|
type: Input
|
|
116
142
|
}], actionClick: [{
|
|
117
143
|
type: Output
|
|
144
|
+
}], submenuOpened: [{
|
|
145
|
+
type: Output
|
|
118
146
|
}], onMenuClick: [{
|
|
119
147
|
type: HostListener,
|
|
120
148
|
args: ['click', ['$event']]
|
|
@@ -122,4 +150,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
|
|
|
122
150
|
type: HostListener,
|
|
123
151
|
args: ['document:click', ['$event']]
|
|
124
152
|
}] } });
|
|
125
|
-
//# 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  ViewChild,\r\n  ViewChildren,\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\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  @ViewChild('menuContainer', { static: false }) menuRef!: ElementRef;\r\n  @ViewChildren('submenu') submenuComponents!: QueryList<MenuComponent>;\r\n\r\n  @Input() subActions: UiAction[] = [];\r\n  @Input() triggerAction!: UiAction;\r\n  @Input() isSubmenu: boolean = false;\r\n\r\n  @Output() actionClick = new EventEmitter<UiAction>();\r\n\r\n  private destroy$ = new Subject<void>();\r\n  visible = false;\r\n  icon!: string;\r\n  submenuOpenMap = new Map<UiAction, boolean>();\r\n  alignLeft = false;\r\n\r\n  constructor(\r\n    private menuService: UiMenuService,\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.visible = false;\r\n        this.submenuComponents?.forEach((submenu) => (submenu.visible = false));\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.visible = false;\r\n    this.submenuComponents.forEach((submenu) => (submenu.visible = false));\r\n  }\r\n\r\n  toggleMenu() {\r\n    const wasVisible = this.visible;\r\n\r\n    if (!this.isSubmenu) {\r\n      this.menuService.closeAllMenus();\r\n    }\r\n\r\n    this.visible = !wasVisible;\r\n    if (!this.visible) {\r\n      this.submenuComponents.forEach((submenu) => (submenu.visible = false));\r\n    }\r\n\r\n    this.adjustAlignment();\r\n  }\r\n\r\n  openSubmenu(action: UiAction) {\r\n    this.submenuComponents.forEach((submenu) => {\r\n      submenu.visible = false;\r\n    });\r\n\r\n    let submenuComp = this.getSubmenuComponentForAction(action);\r\n\r\n    if (submenuComp && !submenuComp.visible) {\r\n      submenuComp.toggleMenu();\r\n    }\r\n  }\r\n\r\n  private getSubmenuComponentForAction(action: UiAction): MenuComponent | undefined {\r\n    let submenuActions = this.subActions.filter((a) => a.subActions && a.subActions.length > 0);\r\n    let index = submenuActions.findIndex((a) => a.code === action.code);\r\n    if (index === -1) return undefined;\r\n    return this.submenuComponents.toArray()[index];\r\n  }\r\n\r\n  adjustAlignment(retries: number = 10) {\r\n    if (!this.menuRef?.nativeElement) {\r\n      if (retries > 0) {\r\n        setTimeout(() => this.adjustAlignment(retries - 1), 10);\r\n      }\r\n      return;\r\n    }\r\n\r\n    const rect = this.menuRef.nativeElement.getBoundingClientRect();\r\n    const overflowRight = rect.right > window.innerWidth;\r\n\r\n    this.alignLeft = overflowRight;\r\n  }\r\n}\r\n","@if (triggerAction) {\r\n<ui-action-button\r\n  [descriptor]=\"triggerAction.descriptor!\"\r\n  [disabled]=\"!!triggerAction.disabled\"\r\n  (actionClick)=\"toggleMenu()\"\r\n>\r\n</ui-action-button>\r\n} @if (visible) {\r\n<ul class=\"ui-tiered-menu\" #menuContainer [ngClass]=\"{ 'align-left': alignLeft }\">\r\n  <li *ngFor=\"let action of subActions\" [class.disabled]=\"action.disabled\">\r\n    <ng-template #actionButtonTemplate>\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    </ng-template>\r\n\r\n    @if(action.subActions && action.subActions.length){\r\n\r\n    <div class=\"submenu\" #submenuWrapper (mouseenter)=\"openSubmenu(action)\">\r\n      <ng-container *ngTemplateOutlet=\"actionButtonTemplate\"></ng-container>\r\n      <smart-icon icon=\"chevron-right\" color=\"black\"></smart-icon>\r\n      <ui-tiered-menu\r\n        #submenu\r\n        [isSubmenu]=\"true\"\r\n        [subActions]=\"action.subActions\"\r\n        (actionClick)=\"actionClick.emit($event)\"\r\n      ></ui-tiered-menu>\r\n    </div>\r\n\r\n    }@else {\r\n    <ng-container *ngTemplateOutlet=\"actionButtonTemplate\"></ng-container>\r\n    }\r\n  </li>\r\n</ul>\r\n}\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=
|
package/esm2022/lib/view-context/smart-ui-action/ui-action-button/ui-action-button.component.mjs
CHANGED
|
@@ -46,6 +46,7 @@ export class UiActionButtonComponent {
|
|
|
46
46
|
async onActionClicked(event, model) {
|
|
47
47
|
event.stopPropagation();
|
|
48
48
|
this.actionClick.emit({
|
|
49
|
+
event,
|
|
49
50
|
code: model.uiAction.code,
|
|
50
51
|
descriptor: model.descriptor,
|
|
51
52
|
});
|
|
@@ -142,4 +143,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
|
|
|
142
143
|
}], actionDoubleClick: [{
|
|
143
144
|
type: Output
|
|
144
145
|
}] } });
|
|
145
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ui-action-button.component.js","sourceRoot":"","sources":["../../../../../../../projects/smart-ng-client/src/lib/view-context/smart-ui-action/ui-action-button/ui-action-button.component.ts","../../../../../../../projects/smart-ng-client/src/lib/view-context/smart-ui-action/ui-action-button/ui-action-button.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectorRef,\r\n  Component,\r\n  ElementRef,\r\n  EventEmitter,\r\n  Inject,\r\n  Input,\r\n  OnDestroy,\r\n  OnInit,\r\n  Optional,\r\n  Output,\r\n  SimpleChanges,\r\n  ViewChild,\r\n} from '@angular/core';\r\nimport { UiActionModel } from '../ui-action.model';\r\nimport { Subject } from 'rxjs';\r\nimport { COMPONENT_LIBRARY, ComponentLibrary } from '../../utility/componentLibrary';\r\nimport { UiActionButtonType } from '../../api/model/uiActionButtonType';\r\nimport { IconPosition } from '../../api/model/iconPosition';\r\nimport { UiAction, UiActionDescriptor } from '../../api';\r\n\r\n@Component({\r\n  selector: 'ui-action-button',\r\n  templateUrl: './ui-action-button.component.html',\r\n  styleUrl: './ui-action-button.component.css',\r\n})\r\nexport class UiActionButtonComponent implements OnInit, OnDestroy {\r\n  private _destroy$: Subject<void> = new Subject();\r\n\r\n  @Input() disabled?: boolean;\r\n  @Input() descriptor!: UiActionDescriptor;\r\n  @Input() code?: string;\r\n  @Input() addedCssClass?: string;\r\n\r\n  @Output() actionClick = new EventEmitter<{\r\n    descriptor?: UiActionDescriptor;\r\n    code?: string;\r\n    uiAction?: UiAction;\r\n  }>();\r\n  @Output() actionDoubleClick = new EventEmitter<{\r\n    event: any;\r\n    descriptor?: UiActionDescriptor;\r\n    code?: string;\r\n  }>();\r\n\r\n  componentLibrary = ComponentLibrary;\r\n  compLib: ComponentLibrary;\r\n  mainActionModel!: UiActionModel;\r\n\r\n  pressedButtonActive: boolean = true;\r\n  menuOpened: boolean = false;\r\n\r\n  constructor(\r\n    public changeDetector: ChangeDetectorRef,\r\n    @Inject(COMPONENT_LIBRARY) @Optional() compLib?: ComponentLibrary\r\n  ) {\r\n    this.compLib = compLib ?? ComponentLibrary.PRIMENG;\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    if (!this.descriptor) {\r\n      throw new Error(\r\n        'UiActionButtonComponent: \"descriptor\" input is required but was not provided.'\r\n      );\r\n    }\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (changes['descriptor'] && this.descriptor) {\r\n      this.mainActionModel = {\r\n        descriptor: this.descriptor,\r\n        uiAction: {\r\n          descriptor: this.descriptor,\r\n          code: this.code,\r\n          disabled: this.disabled ?? false,\r\n        },\r\n      } as UiActionModel;\r\n    }\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this._destroy$.next();\r\n    this._destroy$.complete();\r\n  }\r\n\r\n  async onActionClicked(event: any, model: UiActionModel): Promise<void> {\r\n    event.stopPropagation();\r\n    this.actionClick.emit({\r\n      code: model.uiAction.code,\r\n      descriptor: model.descriptor!,\r\n    });\r\n  }\r\n\r\n  onActionDoubleClicked(event: any): void {\r\n    event.stopPropagation();\r\n    this.actionDoubleClick.emit({\r\n      event,\r\n      code: this.code,\r\n      descriptor: this.descriptor,\r\n    });\r\n  }\r\n\r\n  iconPosition(): typeof IconPosition {\r\n    return IconPosition;\r\n  }\r\n\r\n  isOnlyIcon(): boolean {\r\n    return (\r\n      this.descriptor?.type === UiActionButtonType.ICON ||\r\n      this.descriptor?.type === UiActionButtonType.MINI_FAB ||\r\n      this.descriptor?.type === UiActionButtonType.FAB\r\n    );\r\n  }\r\n\r\n  getbtnClass(): string {\r\n    if (this.descriptor.color) {\r\n      return 'p-button-' + this.descriptor?.color;\r\n    }\r\n    return '';\r\n  }\r\n\r\n  getType(): any {\r\n    if (this.compLib === ComponentLibrary.PRIMENG) {\r\n      switch (this.descriptor.type) {\r\n        case UiActionButtonType.NORMAL:\r\n          return {\r\n            'p-button-text': true,\r\n            'p-button-rounded': true,\r\n          };\r\n        case UiActionButtonType.FLAT:\r\n          return { 'p-button-raised': true, 'p-button-rounded': true };\r\n        case UiActionButtonType.RAISED:\r\n          return { 'p-button-raised': true, 'p-button-rounded': true };\r\n        case UiActionButtonType.STROKED:\r\n          return { 'p-button-outlined': true, 'p-button-rounded': true };\r\n        case UiActionButtonType.MINI_FAB:\r\n          return { 'p-button-rounded': true, 'p-button-text': true, 'p-button-raised': true };\r\n        default:\r\n          return {\r\n            'p-button-text': true,\r\n            'p-button-raised': true,\r\n            'p-button-rounded': true,\r\n            'p-button-outlined': true,\r\n          };\r\n      }\r\n    } else {\r\n      switch (this.descriptor.type) {\r\n        case UiActionButtonType.NORMAL:\r\n          return 'mat-mdc-button';\r\n        case UiActionButtonType.FLAT:\r\n          return 'mat-mdc-flat-button';\r\n        case UiActionButtonType.RAISED:\r\n          return 'mat-mdc-raised-button';\r\n        case UiActionButtonType.STROKED:\r\n          return 'mat-mdc-stroked-button';\r\n        case UiActionButtonType.ICON:\r\n          return 'mat-mdc-icon-button';\r\n        case UiActionButtonType.MINI_FAB:\r\n          return 'mat-mdc-mini-fab';\r\n        case UiActionButtonType.FAB:\r\n          return 'mat-mdc-fab';\r\n        default:\r\n          return `mat-button`;\r\n      }\r\n    }\r\n  }\r\n}\r\n","<ng-container *ngTemplateOutlet=\"buttonWithBadge\"></ng-container>\r\n\r\n<ng-template #buttonWithBadge>\r\n  @if (descriptor && descriptor.badge) {\r\n  <ui-badge [descriptor]=\"descriptor.badge\">\r\n    <ng-container *ngTemplateOutlet=\"buttonTemplate\"></ng-container>\r\n  </ui-badge>\r\n  } @else {\r\n  <ng-container *ngTemplateOutlet=\"buttonTemplate\"></ng-container>\r\n  }\r\n</ng-template>\r\n\r\n<ng-template #buttonTemplate>\r\n  @if(compLib === componentLibrary.PRIMENG) {\r\n  <button\r\n    pButton\r\n    pRipple\r\n    [smartTooltip]=\"descriptor.tooltip\"\r\n    [disabled]=\"!!disabled\"\r\n    (click)=\"onActionClicked($event, mainActionModel)\"\r\n    (dblclick)=\"onActionDoubleClicked($event)\"\r\n    [autofocus]=\"false\"\r\n    [ngClass]=\"getType()\"\r\n    class=\"{{ getbtnClass() }} {{ addedCssClass }}\"\r\n    type=\"button\"\r\n  >\r\n    <div *ngIf=\"isOnlyIcon(); then iconOnly; else text\"></div>\r\n    <ng-template #iconOnly>\r\n      <smart-icon\r\n        *ngIf=\"descriptor.icon\"\r\n        [icon]=\"descriptor.icon\"\r\n        [color]=\"descriptor.iconColor ?? descriptor.color\"\r\n      ></smart-icon>\r\n    </ng-template>\r\n    <ng-template #text>\r\n      <smart-icon\r\n        *ngIf=\"descriptor.icon && descriptor.iconPosition === iconPosition().PRE\"\r\n        [icon]=\"descriptor.icon\"\r\n        [color]=\"descriptor.iconColor ?? descriptor.color\"\r\n      ></smart-icon>\r\n      {{ descriptor.title }}\r\n      <smart-icon\r\n        *ngIf=\"descriptor.icon && descriptor.iconPosition === iconPosition().POST\"\r\n        [icon]=\"descriptor.icon\"\r\n        [color]=\"descriptor.iconColor ?? descriptor.color\"\r\n      ></smart-icon>\r\n    </ng-template>\r\n  </button>\r\n  } @else {\r\n  <button\r\n    mat-button\r\n    [smartTooltip]=\"descriptor.tooltip\"\r\n    [color]=\"descriptor.color\"\r\n    [disabled]=\"!!disabled\"\r\n    (click)=\"onActionClicked($event, mainActionModel)\"\r\n    (dblclick)=\"onActionDoubleClicked($event)\"\r\n    [ngClass]=\"getType()\"\r\n    class=\"{{ getbtnClass() }} {{ addedCssClass }}\"\r\n    type=\"button\"\r\n  >\r\n    <div *ngIf=\"isOnlyIcon(); then iconOnly; else text\"></div>\r\n    <ng-template #iconOnly>\r\n      <smart-icon\r\n        *ngIf=\"descriptor.icon\"\r\n        [icon]=\"descriptor.icon\"\r\n        [color]=\"descriptor.iconColor ?? descriptor.color\"\r\n      ></smart-icon>\r\n    </ng-template>\r\n    <ng-template #text>\r\n      <smart-icon\r\n        *ngIf=\"descriptor.icon && descriptor.iconPosition === iconPosition().PRE\"\r\n        [icon]=\"descriptor.icon\"\r\n        [color]=\"descriptor.iconColor ?? descriptor.color\"\r\n      ></smart-icon>\r\n      {{ descriptor.title }}\r\n      <smart-icon\r\n        *ngIf=\"descriptor.icon && descriptor.iconPosition === iconPosition().POST\"\r\n        [icon]=\"descriptor.icon\"\r\n        [color]=\"descriptor.iconColor ?? descriptor.color\"\r\n      ></smart-icon>\r\n    </ng-template>\r\n  </button>\r\n  }\r\n</ng-template>\r\n"]}
|
|
146
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ui-action-button.component.js","sourceRoot":"","sources":["../../../../../../../projects/smart-ng-client/src/lib/view-context/smart-ui-action/ui-action-button/ui-action-button.component.ts","../../../../../../../projects/smart-ng-client/src/lib/view-context/smart-ui-action/ui-action-button/ui-action-button.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectorRef,\r\n  Component,\r\n  ElementRef,\r\n  EventEmitter,\r\n  Inject,\r\n  Input,\r\n  OnDestroy,\r\n  OnInit,\r\n  Optional,\r\n  Output,\r\n  SimpleChanges,\r\n  ViewChild,\r\n} from '@angular/core';\r\nimport { UiActionModel } from '../ui-action.model';\r\nimport { Subject } from 'rxjs';\r\nimport { COMPONENT_LIBRARY, ComponentLibrary } from '../../utility/componentLibrary';\r\nimport { UiActionButtonType } from '../../api/model/uiActionButtonType';\r\nimport { IconPosition } from '../../api/model/iconPosition';\r\nimport { UiAction, UiActionDescriptor } from '../../api';\r\n\r\n@Component({\r\n  selector: 'ui-action-button',\r\n  templateUrl: './ui-action-button.component.html',\r\n  styleUrl: './ui-action-button.component.css',\r\n})\r\nexport class UiActionButtonComponent implements OnInit, OnDestroy {\r\n  private _destroy$: Subject<void> = new Subject();\r\n\r\n  @Input() disabled?: boolean;\r\n  @Input() descriptor!: UiActionDescriptor;\r\n  @Input() code?: string;\r\n  @Input() addedCssClass?: string;\r\n\r\n  @Output() actionClick = new EventEmitter<{\r\n    event: MouseEvent;\r\n    descriptor?: UiActionDescriptor;\r\n    code?: string;\r\n    uiAction?: UiAction;\r\n  }>();\r\n  @Output() actionDoubleClick = new EventEmitter<{\r\n    event: any;\r\n    descriptor?: UiActionDescriptor;\r\n    code?: string;\r\n  }>();\r\n\r\n  componentLibrary = ComponentLibrary;\r\n  compLib: ComponentLibrary;\r\n  mainActionModel!: UiActionModel;\r\n\r\n  pressedButtonActive: boolean = true;\r\n  menuOpened: boolean = false;\r\n\r\n  constructor(\r\n    public changeDetector: ChangeDetectorRef,\r\n    @Inject(COMPONENT_LIBRARY) @Optional() compLib?: ComponentLibrary\r\n  ) {\r\n    this.compLib = compLib ?? ComponentLibrary.PRIMENG;\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    if (!this.descriptor) {\r\n      throw new Error(\r\n        'UiActionButtonComponent: \"descriptor\" input is required but was not provided.'\r\n      );\r\n    }\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (changes['descriptor'] && this.descriptor) {\r\n      this.mainActionModel = {\r\n        descriptor: this.descriptor,\r\n        uiAction: {\r\n          descriptor: this.descriptor,\r\n          code: this.code,\r\n          disabled: this.disabled ?? false,\r\n        },\r\n      } as UiActionModel;\r\n    }\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this._destroy$.next();\r\n    this._destroy$.complete();\r\n  }\r\n\r\n  async onActionClicked(event: MouseEvent, model: UiActionModel): Promise<void> {\r\n    event.stopPropagation();\r\n    this.actionClick.emit({\r\n      event,\r\n      code: model.uiAction.code,\r\n      descriptor: model.descriptor!,\r\n    });\r\n  }\r\n\r\n  onActionDoubleClicked(event: any): void {\r\n    event.stopPropagation();\r\n    this.actionDoubleClick.emit({\r\n      event,\r\n      code: this.code,\r\n      descriptor: this.descriptor,\r\n    });\r\n  }\r\n\r\n  iconPosition(): typeof IconPosition {\r\n    return IconPosition;\r\n  }\r\n\r\n  isOnlyIcon(): boolean {\r\n    return (\r\n      this.descriptor?.type === UiActionButtonType.ICON ||\r\n      this.descriptor?.type === UiActionButtonType.MINI_FAB ||\r\n      this.descriptor?.type === UiActionButtonType.FAB\r\n    );\r\n  }\r\n\r\n  getbtnClass(): string {\r\n    if (this.descriptor.color) {\r\n      return 'p-button-' + this.descriptor?.color;\r\n    }\r\n    return '';\r\n  }\r\n\r\n  getType(): any {\r\n    if (this.compLib === ComponentLibrary.PRIMENG) {\r\n      switch (this.descriptor.type) {\r\n        case UiActionButtonType.NORMAL:\r\n          return {\r\n            'p-button-text': true,\r\n            'p-button-rounded': true,\r\n          };\r\n        case UiActionButtonType.FLAT:\r\n          return { 'p-button-raised': true, 'p-button-rounded': true };\r\n        case UiActionButtonType.RAISED:\r\n          return { 'p-button-raised': true, 'p-button-rounded': true };\r\n        case UiActionButtonType.STROKED:\r\n          return { 'p-button-outlined': true, 'p-button-rounded': true };\r\n        case UiActionButtonType.MINI_FAB:\r\n          return { 'p-button-rounded': true, 'p-button-text': true, 'p-button-raised': true };\r\n        default:\r\n          return {\r\n            'p-button-text': true,\r\n            'p-button-raised': true,\r\n            'p-button-rounded': true,\r\n            'p-button-outlined': true,\r\n          };\r\n      }\r\n    } else {\r\n      switch (this.descriptor.type) {\r\n        case UiActionButtonType.NORMAL:\r\n          return 'mat-mdc-button';\r\n        case UiActionButtonType.FLAT:\r\n          return 'mat-mdc-flat-button';\r\n        case UiActionButtonType.RAISED:\r\n          return 'mat-mdc-raised-button';\r\n        case UiActionButtonType.STROKED:\r\n          return 'mat-mdc-stroked-button';\r\n        case UiActionButtonType.ICON:\r\n          return 'mat-mdc-icon-button';\r\n        case UiActionButtonType.MINI_FAB:\r\n          return 'mat-mdc-mini-fab';\r\n        case UiActionButtonType.FAB:\r\n          return 'mat-mdc-fab';\r\n        default:\r\n          return `mat-button`;\r\n      }\r\n    }\r\n  }\r\n}\r\n","<ng-container *ngTemplateOutlet=\"buttonWithBadge\"></ng-container>\r\n\r\n<ng-template #buttonWithBadge>\r\n  @if (descriptor && descriptor.badge) {\r\n  <ui-badge [descriptor]=\"descriptor.badge\">\r\n    <ng-container *ngTemplateOutlet=\"buttonTemplate\"></ng-container>\r\n  </ui-badge>\r\n  } @else {\r\n  <ng-container *ngTemplateOutlet=\"buttonTemplate\"></ng-container>\r\n  }\r\n</ng-template>\r\n\r\n<ng-template #buttonTemplate>\r\n  @if(compLib === componentLibrary.PRIMENG) {\r\n  <button\r\n    pButton\r\n    pRipple\r\n    [smartTooltip]=\"descriptor.tooltip\"\r\n    [disabled]=\"!!disabled\"\r\n    (click)=\"onActionClicked($event, mainActionModel)\"\r\n    (dblclick)=\"onActionDoubleClicked($event)\"\r\n    [autofocus]=\"false\"\r\n    [ngClass]=\"getType()\"\r\n    class=\"{{ getbtnClass() }} {{ addedCssClass }}\"\r\n    type=\"button\"\r\n  >\r\n    <div *ngIf=\"isOnlyIcon(); then iconOnly; else text\"></div>\r\n    <ng-template #iconOnly>\r\n      <smart-icon\r\n        *ngIf=\"descriptor.icon\"\r\n        [icon]=\"descriptor.icon\"\r\n        [color]=\"descriptor.iconColor ?? descriptor.color\"\r\n      ></smart-icon>\r\n    </ng-template>\r\n    <ng-template #text>\r\n      <smart-icon\r\n        *ngIf=\"descriptor.icon && descriptor.iconPosition === iconPosition().PRE\"\r\n        [icon]=\"descriptor.icon\"\r\n        [color]=\"descriptor.iconColor ?? descriptor.color\"\r\n      ></smart-icon>\r\n      {{ descriptor.title }}\r\n      <smart-icon\r\n        *ngIf=\"descriptor.icon && descriptor.iconPosition === iconPosition().POST\"\r\n        [icon]=\"descriptor.icon\"\r\n        [color]=\"descriptor.iconColor ?? descriptor.color\"\r\n      ></smart-icon>\r\n    </ng-template>\r\n  </button>\r\n  } @else {\r\n  <button\r\n    mat-button\r\n    [smartTooltip]=\"descriptor.tooltip\"\r\n    [color]=\"descriptor.color\"\r\n    [disabled]=\"!!disabled\"\r\n    (click)=\"onActionClicked($event, mainActionModel)\"\r\n    (dblclick)=\"onActionDoubleClicked($event)\"\r\n    [ngClass]=\"getType()\"\r\n    class=\"{{ getbtnClass() }} {{ addedCssClass }}\"\r\n    type=\"button\"\r\n  >\r\n    <div *ngIf=\"isOnlyIcon(); then iconOnly; else text\"></div>\r\n    <ng-template #iconOnly>\r\n      <smart-icon\r\n        *ngIf=\"descriptor.icon\"\r\n        [icon]=\"descriptor.icon\"\r\n        [color]=\"descriptor.iconColor ?? descriptor.color\"\r\n      ></smart-icon>\r\n    </ng-template>\r\n    <ng-template #text>\r\n      <smart-icon\r\n        *ngIf=\"descriptor.icon && descriptor.iconPosition === iconPosition().PRE\"\r\n        [icon]=\"descriptor.icon\"\r\n        [color]=\"descriptor.iconColor ?? descriptor.color\"\r\n      ></smart-icon>\r\n      {{ descriptor.title }}\r\n      <smart-icon\r\n        *ngIf=\"descriptor.icon && descriptor.iconPosition === iconPosition().POST\"\r\n        [icon]=\"descriptor.icon\"\r\n        [color]=\"descriptor.iconColor ?? descriptor.color\"\r\n      ></smart-icon>\r\n    </ng-template>\r\n  </button>\r\n  }\r\n</ng-template>\r\n"]}
|
|
@@ -179,7 +179,7 @@ export class UiActionToolbarComponent {
|
|
|
179
179
|
return delay ? delay : 2000;
|
|
180
180
|
}
|
|
181
181
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: UiActionToolbarComponent, deps: [{ token: i1.UiActionService }, { token: i0.Injector }, { token: i0.ChangeDetectorRef }, { token: COMPONENT_LIBRARY }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
182
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.11", type: UiActionToolbarComponent, selector: "smart-ui-action-toolbar", inputs: { uiActionModels: "uiActionModels", uiActionDescriptorService: "uiActionDescriptorService", id: "id" }, usesOnChanges: true, ngImport: i0, template: "<div class=\"uiActionButtonsContainer\">\r\n <ng-container *ngFor=\"let uiActionModel of uiActionModelsWithDescriptions; trackBy: trackByFn\">\r\n @if(uiActionModel.uiAction.subActions && uiActionModel.uiAction.subActions.length > 0 ){\r\n <ui-tiered-menu\r\n #menu\r\n [triggerAction]=\"uiActionModel.uiAction\"\r\n [subActions]=\"uiActionModel.uiAction.subActions!\"\r\n (actionClick)=\"onActionClicked($event, uiActionModel)\"\r\n ></ui-tiered-menu>\r\n }@else {\r\n <ui-action-button\r\n [descriptor]=\"uiActionModel.descriptor!\"\r\n [disabled]=\"!!uiActionModel.uiAction.disabled\"\r\n [addedCssClass]=\"uiActionModel.cssClass\"\r\n (actionClick)=\"onActionClicked($event, uiActionModel)\"\r\n (actionDoubleClick)=\"onActionDoubleClicked($event, uiActionModel)\"\r\n >\r\n </ui-action-button>\r\n }\r\n </ng-container>\r\n</div>\r\n", styles: [".uiActionButtonsContainer{display:flex;flex-direction:row;gap:1rem;flex-wrap:wrap}.uiActionButtonsContainer ::ng-deep button{display:flex;gap:1rem;align-items:center;justify-content:center}.uiActionButtonsContainer ::ng-deep .buttonWrapper{position:relative;width:fit-content;height:fit-content}\n"], dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "component", type: i3.UiActionButtonComponent, selector: "ui-action-button", inputs: ["disabled", "descriptor", "code", "addedCssClass"], outputs: ["actionClick", "actionDoubleClick"] }, { kind: "component", type: i4.MenuComponent, selector: "ui-tiered-menu", inputs: ["
|
|
182
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.11", type: UiActionToolbarComponent, selector: "smart-ui-action-toolbar", inputs: { uiActionModels: "uiActionModels", uiActionDescriptorService: "uiActionDescriptorService", id: "id" }, usesOnChanges: true, ngImport: i0, template: "<div class=\"uiActionButtonsContainer\">\r\n <ng-container *ngFor=\"let uiActionModel of uiActionModelsWithDescriptions; trackBy: trackByFn\">\r\n @if(uiActionModel.uiAction.subActions && uiActionModel.uiAction.subActions.length > 0 ){\r\n <ui-tiered-menu\r\n #menu\r\n [triggerAction]=\"uiActionModel.uiAction\"\r\n [subActions]=\"uiActionModel.uiAction.subActions!\"\r\n (actionClick)=\"onActionClicked($event, uiActionModel)\"\r\n ></ui-tiered-menu>\r\n }@else {\r\n <ui-action-button\r\n [descriptor]=\"uiActionModel.descriptor!\"\r\n [disabled]=\"!!uiActionModel.uiAction.disabled\"\r\n [addedCssClass]=\"uiActionModel.cssClass\"\r\n (actionClick)=\"onActionClicked($event, uiActionModel)\"\r\n (actionDoubleClick)=\"onActionDoubleClicked($event, uiActionModel)\"\r\n >\r\n </ui-action-button>\r\n }\r\n </ng-container>\r\n</div>\r\n", styles: [".uiActionButtonsContainer{display:flex;flex-direction:row;gap:1rem;flex-wrap:wrap}.uiActionButtonsContainer ::ng-deep button{display:flex;gap:1rem;align-items:center;justify-content:center}.uiActionButtonsContainer ::ng-deep .buttonWrapper{position:relative;width:fit-content;height:fit-content}\n"], dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "component", type: i3.UiActionButtonComponent, selector: "ui-action-button", inputs: ["disabled", "descriptor", "code", "addedCssClass"], outputs: ["actionClick", "actionDoubleClick"] }, { kind: "component", type: i4.MenuComponent, selector: "ui-tiered-menu", inputs: ["triggerAction", "isSubmenu"], outputs: ["actionClick", "submenuOpened"] }] }); }
|
|
183
183
|
}
|
|
184
184
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: UiActionToolbarComponent, decorators: [{
|
|
185
185
|
type: Component,
|