@smartbit4all/ng-client 4.2.62 → 4.2.64

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.
@@ -1,23 +1,28 @@
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';
4
5
  import * as i0 from "@angular/core";
5
6
  import * as i1 from "./menu.service";
6
- import * as i2 from "@angular/common";
7
- import * as i3 from "../../../../smart-icon/smart-icon/smart-icon.component";
8
- import * as i4 from "../../ui-action-button/ui-action-button.component";
9
- import * as i5 from "../../../utility/componentLibrary";
7
+ import * as i2 from "@angular/cdk/overlay";
8
+ import * as i3 from "@angular/common";
9
+ import * as i4 from "../../../../smart-icon/smart-icon/smart-icon.component";
10
+ import * as i5 from "../../ui-action-button/ui-action-button.component";
11
+ import * as i6 from "../../../utility/componentLibrary";
10
12
  export class MenuComponent {
11
- constructor(menuService, compLib) {
13
+ constructor(menuService, overlay, viewContainerRef, overlayPositionBuilder, compLib) {
12
14
  this.menuService = menuService;
15
+ this.overlay = overlay;
16
+ this.viewContainerRef = viewContainerRef;
17
+ this.overlayPositionBuilder = overlayPositionBuilder;
13
18
  this.compLib = compLib;
14
- this.subActions = [];
19
+ this.overlayRef = null;
15
20
  this.isSubmenu = false;
16
21
  this.actionClick = new EventEmitter();
22
+ this.submenuOpened = new EventEmitter();
17
23
  this.destroy$ = new Subject();
18
- this.visible = false;
19
24
  this.submenuOpenMap = new Map();
20
- this.alignLeft = false;
25
+ this.subActions = [];
21
26
  this.compLib = compLib ?? ComponentLibrary.PRIMENG;
22
27
  if (this.compLib === ComponentLibrary.PRIMENG) {
23
28
  this.icon = 'chevron-right';
@@ -31,10 +36,15 @@ export class MenuComponent {
31
36
  .getCloseSignal()
32
37
  .pipe(takeUntil(this.destroy$))
33
38
  .subscribe(() => {
34
- this.visible = false;
35
- this.submenuComponents?.forEach((submenu) => (submenu.visible = false));
39
+ this.closeMenu();
36
40
  });
37
41
  }
42
+ ngOnChanges(changes) {
43
+ if (changes['triggerAction']) {
44
+ const trigger = changes['triggerAction'].currentValue;
45
+ this.subActions = trigger?.subActions ?? [];
46
+ }
47
+ }
38
48
  ngOnDestroy() {
39
49
  this.destroy$.next();
40
50
  this.destroy$.complete();
@@ -49,68 +59,119 @@ export class MenuComponent {
49
59
  event.stopPropagation();
50
60
  }
51
61
  onDocumentClick(event) {
52
- this.visible = false;
53
- this.submenuComponents.forEach((submenu) => (submenu.visible = false));
54
- }
55
- toggleMenu() {
56
- if (!this.isSubmenu) {
57
- this.menuService.closeAllMenus();
62
+ if (this.overlayRef) {
63
+ this.overlayRef.dispose();
64
+ this.overlayRef = null;
65
+ return;
58
66
  }
59
- this.visible = !this.visible;
60
- this.adjustAlignment();
61
67
  }
62
- openSubmenu(action) {
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
+ }
63
77
  this.submenuComponents.forEach((submenu) => {
64
- submenu.visible = false;
78
+ submenu.closeMenu();
65
79
  });
66
- let submenuComp = this.getSubmenuComponentForAction(action);
67
- if (submenuComp && !submenuComp.visible) {
68
- submenuComp.toggleMenu();
80
+ }
81
+ openMenu(event) {
82
+ if (this.isOpen) {
83
+ return;
69
84
  }
85
+ else {
86
+ }
87
+ if (this.isSubmenu) {
88
+ console.log('emit submenu');
89
+ this.submenuOpened.emit(this.triggerAction);
90
+ }
91
+ else {
92
+ this.menuService.closeAllMenus();
93
+ }
94
+ 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
+ }
122
+ let positionStrategy = this.overlayPositionBuilder
123
+ .flexibleConnectedTo(triggerElement)
124
+ .withFlexibleDimensions(false)
125
+ .withPush(false)
126
+ .withPositions(positions);
127
+ this.overlayRef = this.overlay.create({
128
+ positionStrategy,
129
+ scrollStrategy: this.overlay.scrollStrategies.reposition(),
130
+ hasBackdrop: false,
131
+ });
132
+ let portal = new TemplatePortal(this.menuTemplate, this.viewContainerRef);
133
+ this.overlayRef.attach(portal);
70
134
  }
71
- getSubmenuComponentForAction(action) {
72
- let submenuActions = this.subActions.filter((a) => a.subActions && a.subActions.length > 0);
73
- let index = submenuActions.findIndex((a) => a.code === action.code);
74
- if (index === -1)
75
- return undefined;
76
- return this.submenuComponents.toArray()[index];
135
+ toggleMenu(event) {
136
+ if (this.isOpen) {
137
+ this.openMenu(event);
138
+ }
139
+ else {
140
+ this.closeMenu();
141
+ }
77
142
  }
78
- adjustAlignment(retries = 10) {
79
- if (!this.menuRef?.nativeElement) {
80
- if (retries > 0) {
81
- setTimeout(() => this.adjustAlignment(retries - 1), 10);
143
+ onSubmenuOpened(openedAction) {
144
+ this.submenuComponents.forEach((submenu) => {
145
+ if (submenu.triggerAction.code !== openedAction.code && submenu.overlayRef) {
146
+ submenu.closeMenu();
82
147
  }
83
- return;
84
- }
85
- const rect = this.menuRef.nativeElement.getBoundingClientRect();
86
- const overflowRight = rect.right > window.innerWidth;
87
- this.alignLeft = overflowRight;
148
+ });
88
149
  }
89
- 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 }); }
90
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.11", type: MenuComponent, selector: "ui-tiered-menu", inputs: { subActions: "subActions", triggerAction: "triggerAction", isSubmenu: "isSubmenu" }, outputs: { actionClick: "actionClick" }, host: { listeners: { "click": "onMenuClick($event)", "document:click": "onDocumentClick($event)" } }, viewQueries: [{ propertyName: "menuRef", first: true, predicate: ["menuContainer"], descendants: true }, { propertyName: "submenuComponents", predicate: ["submenu"], descendants: true }], ngImport: i0, template: "@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", styles: [":host{position:relative;display:inline-block}.ui-tiered-menu{position:absolute;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}.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}.ui-tiered-menu ::ng-deep button:hover{background-color:#f1f5f9}.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{position:absolute;top:0;left:100%;margin-left:2px;z-index:1000;background:#fff;border:1px solid #ccc;box-shadow:2px 2px 8px #0003;visibility:visible}smart-icon{align-content:center}.ui-tiered-menu.align-left{position:absolute;top:0;left:auto;right:100%}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i3.SmartIconComponent, selector: "smart-icon", inputs: ["icon", "color"] }, { kind: "component", type: i4.UiActionButtonComponent, selector: "ui-action-button", inputs: ["disabled", "descriptor", "code", "addedCssClass"], outputs: ["actionClick", "actionDoubleClick"] }, { kind: "component", type: MenuComponent, selector: "ui-tiered-menu", inputs: ["subActions", "triggerAction", "isSubmenu"], outputs: ["actionClick"] }] }); }
150
+ 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)=\"openMenu($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}.submenu:hover,.ui-tiered-menu ::ng-deep button:hover{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"] }] }); }
91
152
  }
92
153
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: MenuComponent, decorators: [{
93
154
  type: Component,
94
- args: [{ selector: 'ui-tiered-menu', template: "@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", styles: [":host{position:relative;display:inline-block}.ui-tiered-menu{position:absolute;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}.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}.ui-tiered-menu ::ng-deep button:hover{background-color:#f1f5f9}.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{position:absolute;top:0;left:100%;margin-left:2px;z-index:1000;background:#fff;border:1px solid #ccc;box-shadow:2px 2px 8px #0003;visibility:visible}smart-icon{align-content:center}.ui-tiered-menu.align-left{position:absolute;top:0;left:auto;right:100%}\n"] }]
95
- }], ctorParameters: () => [{ type: i1.UiMenuService }, { type: i5.ComponentLibrary, decorators: [{
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)=\"openMenu($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}.submenu:hover,.ui-tiered-menu ::ng-deep button:hover{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
+ }], ctorParameters: () => [{ type: i1.UiMenuService }, { type: i2.Overlay }, { type: i0.ViewContainerRef }, { type: i2.OverlayPositionBuilder }, { type: i6.ComponentLibrary, decorators: [{
96
157
  type: Inject,
97
158
  args: [COMPONENT_LIBRARY]
98
159
  }, {
99
160
  type: Optional
100
- }] }], propDecorators: { menuRef: [{
101
- type: ViewChild,
102
- args: ['menuContainer', { static: false }]
103
- }], submenuComponents: [{
161
+ }] }], propDecorators: { submenuComponents: [{
104
162
  type: ViewChildren,
105
163
  args: ['submenu']
106
- }], subActions: [{
107
- type: Input
164
+ }], menuTemplate: [{
165
+ type: ViewChild,
166
+ args: ['menuTemplate']
108
167
  }], triggerAction: [{
109
168
  type: Input
110
169
  }], isSubmenu: [{
111
170
  type: Input
112
171
  }], actionClick: [{
113
172
  type: Output
173
+ }], submenuOpened: [{
174
+ type: Output
114
175
  }], onMenuClick: [{
115
176
  type: HostListener,
116
177
  args: ['click', ['$event']]
@@ -118,4 +179,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
118
179
  type: HostListener,
119
180
  args: ['document:click', ['$event']]
120
181
  }] } });
121
- //# 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    if (!this.isSubmenu) {\r\n      this.menuService.closeAllMenus();\r\n    }\r\n    this.visible = !this.visible;\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"]}
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"]}
@@ -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":"AAAA,OAAO,EAEL,SAAS,EAET,YAAY,EACZ,MAAM,EACN,KAAK,EAGL,QAAQ,EACR,MAAM,GAGP,MAAM,eAAe,CAAC;AAEvB,OAAO,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AAC/B,OAAO,EAAE,iBAAiB,EAAE,gBAAgB,EAAE,MAAM,gCAAgC,CAAC;AACrF,OAAO,EAAE,kBAAkB,EAAE,MAAM,oCAAoC,CAAC;AACxE,OAAO,EAAE,YAAY,EAAE,MAAM,8BAA8B,CAAC;;;;;;;;;AAQ5D,MAAM,OAAO,uBAAuB;IA2BlC,YACS,cAAiC,EACD,OAA0B;QAD1D,mBAAc,GAAd,cAAc,CAAmB;QA3BlC,cAAS,GAAkB,IAAI,OAAO,EAAE,CAAC;QAOvC,gBAAW,GAAG,IAAI,YAAY,EAKpC,CAAC;QACK,sBAAiB,GAAG,IAAI,YAAY,EAI1C,CAAC;QAEL,qBAAgB,GAAG,gBAAgB,CAAC;QAIpC,wBAAmB,GAAY,IAAI,CAAC;QACpC,eAAU,GAAY,KAAK,CAAC;QAM1B,IAAI,CAAC,OAAO,GAAG,OAAO,IAAI,gBAAgB,CAAC,OAAO,CAAC;IACrD,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE,CAAC;YACrB,MAAM,IAAI,KAAK,CACb,+EAA+E,CAChF,CAAC;QACJ,CAAC;IACH,CAAC;IAED,WAAW,CAAC,OAAsB;QAChC,IAAI,OAAO,CAAC,YAAY,CAAC,IAAI,IAAI,CAAC,UAAU,EAAE,CAAC;YAC7C,IAAI,CAAC,eAAe,GAAG;gBACrB,UAAU,EAAE,IAAI,CAAC,UAAU;gBAC3B,QAAQ,EAAE;oBACR,UAAU,EAAE,IAAI,CAAC,UAAU;oBAC3B,IAAI,EAAE,IAAI,CAAC,IAAI;oBACf,QAAQ,EAAE,IAAI,CAAC,QAAQ,IAAI,KAAK;iBACjC;aACe,CAAC;QACrB,CAAC;IACH,CAAC;IAED,WAAW;QACT,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,CAAC;QACtB,IAAI,CAAC,SAAS,CAAC,QAAQ,EAAE,CAAC;IAC5B,CAAC;IAED,KAAK,CAAC,eAAe,CAAC,KAAiB,EAAE,KAAoB;QAC3D,KAAK,CAAC,eAAe,EAAE,CAAC;QACxB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC;YACpB,KAAK;YACL,IAAI,EAAE,KAAK,CAAC,QAAQ,CAAC,IAAI;YACzB,UAAU,EAAE,KAAK,CAAC,UAAW;SAC9B,CAAC,CAAC;IACL,CAAC;IAED,qBAAqB,CAAC,KAAU;QAC9B,KAAK,CAAC,eAAe,EAAE,CAAC;QACxB,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC;YAC1B,KAAK;YACL,IAAI,EAAE,IAAI,CAAC,IAAI;YACf,UAAU,EAAE,IAAI,CAAC,UAAU;SAC5B,CAAC,CAAC;IACL,CAAC;IAED,YAAY;QACV,OAAO,YAAY,CAAC;IACtB,CAAC;IAED,UAAU;QACR,OAAO,CACL,IAAI,CAAC,UAAU,EAAE,IAAI,KAAK,kBAAkB,CAAC,IAAI;YACjD,IAAI,CAAC,UAAU,EAAE,IAAI,KAAK,kBAAkB,CAAC,QAAQ;YACrD,IAAI,CAAC,UAAU,EAAE,IAAI,KAAK,kBAAkB,CAAC,GAAG,CACjD,CAAC;IACJ,CAAC;IAED,WAAW;QACT,IAAI,IAAI,CAAC,UAAU,CAAC,KAAK,EAAE,CAAC;YAC1B,OAAO,WAAW,GAAG,IAAI,CAAC,UAAU,EAAE,KAAK,CAAC;QAC9C,CAAC;QACD,OAAO,EAAE,CAAC;IACZ,CAAC;IAED,OAAO;QACL,IAAI,IAAI,CAAC,OAAO,KAAK,gBAAgB,CAAC,OAAO,EAAE,CAAC;YAC9C,QAAQ,IAAI,CAAC,UAAU,CAAC,IAAI,EAAE,CAAC;gBAC7B,KAAK,kBAAkB,CAAC,MAAM;oBAC5B,OAAO;wBACL,eAAe,EAAE,IAAI;wBACrB,kBAAkB,EAAE,IAAI;qBACzB,CAAC;gBACJ,KAAK,kBAAkB,CAAC,IAAI;oBAC1B,OAAO,EAAE,iBAAiB,EAAE,IAAI,EAAE,kBAAkB,EAAE,IAAI,EAAE,CAAC;gBAC/D,KAAK,kBAAkB,CAAC,MAAM;oBAC5B,OAAO,EAAE,iBAAiB,EAAE,IAAI,EAAE,kBAAkB,EAAE,IAAI,EAAE,CAAC;gBAC/D,KAAK,kBAAkB,CAAC,OAAO;oBAC7B,OAAO,EAAE,mBAAmB,EAAE,IAAI,EAAE,kBAAkB,EAAE,IAAI,EAAE,CAAC;gBACjE,KAAK,kBAAkB,CAAC,QAAQ;oBAC9B,OAAO,EAAE,kBAAkB,EAAE,IAAI,EAAE,eAAe,EAAE,IAAI,EAAE,iBAAiB,EAAE,IAAI,EAAE,CAAC;gBACtF;oBACE,OAAO;wBACL,eAAe,EAAE,IAAI;wBACrB,iBAAiB,EAAE,IAAI;wBACvB,kBAAkB,EAAE,IAAI;wBACxB,mBAAmB,EAAE,IAAI;qBAC1B,CAAC;YACN,CAAC;QACH,CAAC;aAAM,CAAC;YACN,QAAQ,IAAI,CAAC,UAAU,CAAC,IAAI,EAAE,CAAC;gBAC7B,KAAK,kBAAkB,CAAC,MAAM;oBAC5B,OAAO,gBAAgB,CAAC;gBAC1B,KAAK,kBAAkB,CAAC,IAAI;oBAC1B,OAAO,qBAAqB,CAAC;gBAC/B,KAAK,kBAAkB,CAAC,MAAM;oBAC5B,OAAO,uBAAuB,CAAC;gBACjC,KAAK,kBAAkB,CAAC,OAAO;oBAC7B,OAAO,wBAAwB,CAAC;gBAClC,KAAK,kBAAkB,CAAC,IAAI;oBAC1B,OAAO,qBAAqB,CAAC;gBAC/B,KAAK,kBAAkB,CAAC,QAAQ;oBAC9B,OAAO,kBAAkB,CAAC;gBAC5B,KAAK,kBAAkB,CAAC,GAAG;oBACzB,OAAO,aAAa,CAAC;gBACvB;oBACE,OAAO,YAAY,CAAC;YACxB,CAAC;QACH,CAAC;IACH,CAAC;+GA7IU,uBAAuB,mDA6BxB,iBAAiB;mGA7BhB,uBAAuB,wQC1BpC,q9FAoFA;;4FD1Da,uBAAuB;kBALnC,SAAS;+BACE,kBAAkB;;0BAiCzB,MAAM;2BAAC,iBAAiB;;0BAAG,QAAQ;yCA1B7B,QAAQ;sBAAhB,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,aAAa;sBAArB,KAAK;gBAEI,WAAW;sBAApB,MAAM;gBAMG,iBAAiB;sBAA1B,MAAM","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: ["subActions", "triggerAction", "isSubmenu"], outputs: ["actionClick"] }] }); }
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,