@seniorsistemas/angular-components 17.7.2 → 17.7.4

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.
Files changed (61) hide show
  1. package/bundles/seniorsistemas-angular-components.umd.js +350 -235
  2. package/bundles/seniorsistemas-angular-components.umd.js.map +1 -1
  3. package/bundles/seniorsistemas-angular-components.umd.min.js +1 -1
  4. package/bundles/seniorsistemas-angular-components.umd.min.js.map +1 -1
  5. package/components/tiered-menu/components/tiered-menu/tiered-menu.component.d.ts +8 -4
  6. package/components/tiered-menu/components/tiered-menu-item/tiered-menu-item.component.d.ts +2 -1
  7. package/components/tiered-menu/components/tiered-menu-nested/tiered-menu-nested.component.d.ts +7 -4
  8. package/components/tiered-menu/models/tiered-menu-item-data.d.ts +2 -0
  9. package/components/tiered-menu/models/tiered-menu-item-internal-data.d.ts +2 -6
  10. package/components/tiered-menu/{tiered-menu.event.service.d.ts → services/tiered-menu.event.service.d.ts} +1 -8
  11. package/components/tiered-menu/services/tiered-menu.global.service.d.ts +4 -0
  12. package/components/tiered-menu/{tiered-menu.service.d.ts → services/tiered-menu.service.d.ts} +5 -3
  13. package/components/tiered-menu/tiered-menu.directive.d.ts +16 -14
  14. package/components/timeline/components/horizontal-timeline/horizontal-timeline.component.d.ts +1 -0
  15. package/components/timeline/components/timeline-icon-item/timeline-icon-item.component.d.ts +1 -0
  16. package/components/timeline/components/vertical-timeline/components/vertical-items/vertical-items.component.d.ts +1 -0
  17. package/components/timeline/components/vertical-timeline/vertical-timeline.component.d.ts +1 -0
  18. package/components/timeline/timeline.component.d.ts +1 -0
  19. package/esm2015/components/tiered-menu/components/tiered-menu/tiered-menu.component.js +110 -51
  20. package/esm2015/components/tiered-menu/components/tiered-menu-item/tiered-menu-item.component.js +16 -8
  21. package/esm2015/components/tiered-menu/components/tiered-menu-nested/tiered-menu-nested.component.js +53 -9
  22. package/esm2015/components/tiered-menu/models/tiered-menu-item-data.js +1 -1
  23. package/esm2015/components/tiered-menu/models/tiered-menu-item-internal-data.js +1 -1
  24. package/esm2015/components/tiered-menu/services/tiered-menu.event.service.js +18 -0
  25. package/esm2015/components/tiered-menu/services/tiered-menu.global.service.js +9 -0
  26. package/esm2015/components/tiered-menu/services/tiered-menu.service.js +51 -0
  27. package/esm2015/components/tiered-menu/tiered-menu.directive.js +103 -109
  28. package/esm2015/components/tiered-menu/tiered-menu.module.js +8 -12
  29. package/esm2015/components/timeline/components/horizontal-timeline/horizontal-timeline.component.js +6 -3
  30. package/esm2015/components/timeline/components/timeline-icon-item/timeline-icon-item.component.js +6 -3
  31. package/esm2015/components/timeline/components/vertical-timeline/components/vertical-items/vertical-items.component.js +5 -2
  32. package/esm2015/components/timeline/components/vertical-timeline/vertical-timeline.component.js +5 -2
  33. package/esm2015/components/timeline/timeline.component.js +6 -2
  34. package/esm2015/seniorsistemas-angular-components.js +18 -17
  35. package/esm5/components/tiered-menu/components/tiered-menu/tiered-menu.component.js +110 -51
  36. package/esm5/components/tiered-menu/components/tiered-menu-item/tiered-menu-item.component.js +16 -8
  37. package/esm5/components/tiered-menu/components/tiered-menu-nested/tiered-menu-nested.component.js +53 -9
  38. package/esm5/components/tiered-menu/models/tiered-menu-item-data.js +1 -1
  39. package/esm5/components/tiered-menu/models/tiered-menu-item-internal-data.js +1 -1
  40. package/esm5/components/tiered-menu/services/tiered-menu.event.service.js +19 -0
  41. package/esm5/components/tiered-menu/services/tiered-menu.global.service.js +12 -0
  42. package/esm5/components/tiered-menu/services/tiered-menu.service.js +54 -0
  43. package/esm5/components/tiered-menu/tiered-menu.directive.js +103 -110
  44. package/esm5/components/tiered-menu/tiered-menu.module.js +8 -12
  45. package/esm5/components/timeline/components/horizontal-timeline/horizontal-timeline.component.js +6 -3
  46. package/esm5/components/timeline/components/timeline-icon-item/timeline-icon-item.component.js +6 -3
  47. package/esm5/components/timeline/components/vertical-timeline/components/vertical-items/vertical-items.component.js +5 -2
  48. package/esm5/components/timeline/components/vertical-timeline/vertical-timeline.component.js +5 -2
  49. package/esm5/components/timeline/timeline.component.js +6 -2
  50. package/esm5/seniorsistemas-angular-components.js +18 -17
  51. package/fesm2015/seniorsistemas-angular-components.js +332 -218
  52. package/fesm2015/seniorsistemas-angular-components.js.map +1 -1
  53. package/fesm5/seniorsistemas-angular-components.js +336 -222
  54. package/fesm5/seniorsistemas-angular-components.js.map +1 -1
  55. package/package.json +1 -1
  56. package/seniorsistemas-angular-components.d.ts +17 -16
  57. package/seniorsistemas-angular-components.metadata.json +1 -1
  58. package/esm2015/components/tiered-menu/tiered-menu.event.service.js +0 -39
  59. package/esm2015/components/tiered-menu/tiered-menu.service.js +0 -39
  60. package/esm5/components/tiered-menu/tiered-menu.event.service.js +0 -40
  61. package/esm5/components/tiered-menu/tiered-menu.service.js +0 -44
@@ -1,11 +1,12 @@
1
- import { ApplicationRef, ComponentFactoryResolver, EventEmitter, Injector, OnDestroy, OnInit } from "@angular/core";
1
+ import { ApplicationRef, ChangeDetectorRef, ComponentFactoryResolver, EventEmitter, Injector, OnDestroy, OnInit } from "@angular/core";
2
2
  import { TieredMenuItemInternalData } from "../../models/tiered-menu-item-internal-data";
3
- import { TieredMenuEventService } from "../../tiered-menu.event.service";
4
- import { TieredMenuService } from "../../tiered-menu.service";
3
+ import { TieredMenuEventService } from "../../services/tiered-menu.event.service";
4
+ import { TieredMenuService } from "../../services/tiered-menu.service";
5
5
  export declare class TieredMenuComponent implements OnInit, OnDestroy {
6
6
  private readonly _appRef;
7
7
  private readonly _componentFactoryResolver;
8
8
  private readonly _injector;
9
+ private readonly _changeDetectorRef;
9
10
  readonly tieredMenuService: TieredMenuService;
10
11
  private readonly _tieredMenuEventService;
11
12
  items: TieredMenuItemInternalData[];
@@ -16,7 +17,10 @@ export declare class TieredMenuComponent implements OnInit, OnDestroy {
16
17
  private _menuDivElement?;
17
18
  private _unsubscribe$;
18
19
  destroyRequest: EventEmitter<boolean>;
19
- constructor(_appRef: ApplicationRef, _componentFactoryResolver: ComponentFactoryResolver, _injector: Injector, tieredMenuService: TieredMenuService, _tieredMenuEventService: TieredMenuEventService);
20
+ constructor(_appRef: ApplicationRef, _componentFactoryResolver: ComponentFactoryResolver, _injector: Injector, _changeDetectorRef: ChangeDetectorRef, tieredMenuService: TieredMenuService, _tieredMenuEventService: TieredMenuEventService);
21
+ onResize(): void;
22
+ onDocumentClick(event: MouseEvent): void;
23
+ onKeydownHandler(event: KeyboardEvent): void;
20
24
  ngOnInit(): void;
21
25
  ngOnDestroy(): void;
22
26
  private _incrementCurItem;
@@ -1,9 +1,10 @@
1
- import { TieredMenuEventService } from "../../tiered-menu.event.service";
1
+ import { TieredMenuEventService } from "../../services/tiered-menu.event.service";
2
2
  import { TieredMenuItemInternalData } from "../../models";
3
3
  export declare class TieredMenuItemComponent {
4
4
  private readonly _tieredMenuEventService;
5
5
  item: TieredMenuItemInternalData;
6
6
  focused: boolean;
7
+ highlight: boolean;
7
8
  triggerEvent: "click" | "hover";
8
9
  closeOnClick: boolean;
9
10
  private _showTimeout?;
@@ -1,15 +1,18 @@
1
1
  import { OnDestroy, OnInit } from "@angular/core";
2
2
  import { TieredMenuItemInternalData } from "../../models/tiered-menu-item-internal-data";
3
- import { TieredMenuEventService } from "../../tiered-menu.event.service";
4
- import { TieredMenuService } from "../../tiered-menu.service";
3
+ import { TieredMenuEventService } from "../../services/tiered-menu.event.service";
4
+ import { TieredMenuService } from "../../services/tiered-menu.service";
5
5
  export declare class TieredMenuNestedComponent implements OnInit, OnDestroy {
6
6
  readonly tieredMenuService: TieredMenuService;
7
7
  private readonly _tieredMenuEventService;
8
8
  items: TieredMenuItemInternalData[];
9
9
  top: number;
10
- maxHeight: number;
11
- private _unsubscribe$;
10
+ left: number;
12
11
  private _lastOpenItem;
12
+ private _unsubscribe$;
13
+ onResize(): void;
14
+ onDocumentClick(event: MouseEvent): void;
15
+ onKeydownHandler(event: KeyboardEvent): void;
13
16
  constructor(tieredMenuService: TieredMenuService, _tieredMenuEventService: TieredMenuEventService);
14
17
  ngOnInit(): void;
15
18
  ngOnDestroy(): void;
@@ -4,4 +4,6 @@ export interface TieredMenuItemData {
4
4
  command?: VoidFunction;
5
5
  submenu?: TieredMenuItemData[];
6
6
  divider?: boolean;
7
+ disabled?: boolean;
8
+ visible?: boolean;
7
9
  }
@@ -1,10 +1,6 @@
1
- export interface TieredMenuItemInternalData {
1
+ import { TieredMenuItemData } from "./tiered-menu-item-data";
2
+ export interface TieredMenuItemInternalData extends TieredMenuItemData {
2
3
  id?: string;
3
- label?: string;
4
- iconClass?: string;
5
4
  isOpen?: boolean;
6
- command?: VoidFunction;
7
- submenu?: TieredMenuItemInternalData[];
8
- divider?: boolean;
9
5
  parent?: TieredMenuItemInternalData;
10
6
  }
@@ -1,5 +1,5 @@
1
1
  import { EventEmitter } from '@angular/core';
2
- import { TieredMenuItemInternalData } from './models/tiered-menu-item-internal-data';
2
+ import { TieredMenuItemInternalData } from '../models/tiered-menu-item-internal-data';
3
3
  export declare class TieredMenuEventService {
4
4
  incrementCurrentItemEvent: EventEmitter<any>;
5
5
  decrementCurrentItemEvent: EventEmitter<any>;
@@ -8,11 +8,4 @@ export declare class TieredMenuEventService {
8
8
  openItemMenuEvent: EventEmitter<TieredMenuItemInternalData>;
9
9
  closeItemMenuEvent: EventEmitter<TieredMenuItemInternalData>;
10
10
  createMenuEvent: EventEmitter<TieredMenuItemInternalData>;
11
- emitIncrementCurrentItemEvent(): void;
12
- emitDecrementCurrentItemEvent(): void;
13
- emitCloseAllMenusEvent(): void;
14
- emitSelectItemEvent(item: TieredMenuItemInternalData): void;
15
- emitOpenItemMenuEvent(item: TieredMenuItemInternalData): void;
16
- emitCloseItemMenuEvent(item: TieredMenuItemInternalData): void;
17
- emitCreateMenuEvent(item: TieredMenuItemInternalData): void;
18
11
  }
@@ -0,0 +1,4 @@
1
+ import { TieredMenuDirective } from "../tiered-menu.directive";
2
+ export declare class TieredMenuGlobalService {
3
+ lastInstance: TieredMenuDirective;
4
+ }
@@ -1,10 +1,12 @@
1
- import { TieredMenuItemData } from "./models/tiered-menu-item-data";
2
- import { TieredMenuItemInternalData } from "./models/tiered-menu-item-internal-data";
1
+ import { TieredMenuItemData } from "../models/tiered-menu-item-data";
2
+ import { TieredMenuItemInternalData } from "../models/tiered-menu-item-internal-data";
3
3
  export declare class TieredMenuService {
4
4
  currentItem: TieredMenuItemInternalData;
5
5
  currentItems: TieredMenuItemInternalData[];
6
6
  items: TieredMenuItemInternalData[];
7
7
  normalizeData(items: TieredMenuItemData[], parent?: TieredMenuItemInternalData): TieredMenuItemInternalData[];
8
8
  markAllItemsAsClosed(items: TieredMenuItemInternalData[]): TieredMenuItemInternalData[];
9
- searchTheHierarchy(item1: TieredMenuItemInternalData, item2: TieredMenuItemInternalData): boolean;
9
+ searchTheHierarchy(itemA: TieredMenuItemInternalData, itemB: TieredMenuItemInternalData): boolean;
10
+ cloneItems(items: TieredMenuItemInternalData[]): TieredMenuItemInternalData[];
11
+ private _generateId;
10
12
  }
@@ -1,32 +1,31 @@
1
- import { AfterViewInit, ApplicationRef, ComponentFactoryResolver, ElementRef, Injector, OnDestroy, OnInit } from "@angular/core";
1
+ import { ApplicationRef, ChangeDetectorRef, ComponentFactoryResolver, DoCheck, ElementRef, Injector, OnDestroy, OnInit } from "@angular/core";
2
2
  import { TieredMenuItemData } from "./models/tiered-menu-item-data";
3
- import { TieredMenuEventService } from "./tiered-menu.event.service";
4
- import { TieredMenuService } from "./tiered-menu.service";
5
- export declare class TieredMenuDirective implements OnInit, AfterViewInit, OnDestroy {
3
+ import { TieredMenuEventService } from "./services/tiered-menu.event.service";
4
+ import { TieredMenuGlobalService } from "./services/tiered-menu.global.service";
5
+ import { TieredMenuService } from "./services/tiered-menu.service";
6
+ export declare class TieredMenuDirective implements OnInit, DoCheck, OnDestroy {
6
7
  private readonly _elementRef;
7
8
  private readonly _appRef;
8
9
  private readonly _componentFactoryResolver;
9
10
  private readonly _injector;
10
11
  private readonly _tieredMenuEventService;
11
12
  private readonly _tieredMenuService;
13
+ private readonly _tieredMenuGlobalService;
14
+ private readonly _changeDetectorRef;
15
+ items: TieredMenuItemData[];
16
+ triggerEvent: "click" | "hover";
12
17
  private _componentRef;
13
18
  private _showTimeout?;
14
- private _menuDivElement?;
15
19
  private _isNested;
16
20
  private _isOpen;
17
21
  private _unsubscribe$;
18
22
  private _lastActiveElement;
19
- constructor(_elementRef: ElementRef, _appRef: ApplicationRef, _componentFactoryResolver: ComponentFactoryResolver, _injector: Injector, _tieredMenuEventService: TieredMenuEventService, _tieredMenuService: TieredMenuService);
20
- items: TieredMenuItemData[];
21
- alwaysOpen: boolean;
22
- triggerEvent: "click" | "hover";
23
+ private previousItems;
24
+ onClick(event: MouseEvent): void;
25
+ constructor(_elementRef: ElementRef, _appRef: ApplicationRef, _componentFactoryResolver: ComponentFactoryResolver, _injector: Injector, _tieredMenuEventService: TieredMenuEventService, _tieredMenuService: TieredMenuService, _tieredMenuGlobalService: TieredMenuGlobalService, _changeDetectorRef: ChangeDetectorRef);
23
26
  ngOnInit(): void;
24
- ngAfterViewInit(): void;
27
+ ngDoCheck(): void;
25
28
  ngOnDestroy(): void;
26
- onResize(): void;
27
- onKeydownHandler(event: KeyboardEvent): void;
28
- onClick(event: MouseEvent): void;
29
- onDocumentClick(event: MouseEvent): void;
30
29
  private _createMenu;
31
30
  private _createTieredMenu;
32
31
  private _createNestedMenu;
@@ -34,4 +33,7 @@ export declare class TieredMenuDirective implements OnInit, AfterViewInit, OnDes
34
33
  private _setMenuPosition;
35
34
  private _setMenuComponentProperties;
36
35
  private _subscribeEvents;
36
+ private _compareItems;
37
+ private _rebuildMenu;
38
+ private _updateServiceItems;
37
39
  }
@@ -2,4 +2,5 @@ import { TimelineItem } from "../../models/timeline-item";
2
2
  export declare class HorizontalTimelineComponent {
3
3
  items: TimelineItem[];
4
4
  activeIndex: number;
5
+ highlightActiveItem: boolean;
5
6
  }
@@ -2,5 +2,6 @@ import { TimelineItem } from "../../models";
2
2
  export declare class TimelineIconItemComponent {
3
3
  item: TimelineItem;
4
4
  isActive: boolean;
5
+ highlightActive: boolean;
5
6
  isComplete: boolean;
6
7
  }
@@ -3,5 +3,6 @@ export declare class VerticalItemsComponent {
3
3
  items: TimelineItem[];
4
4
  isLast: boolean;
5
5
  isActive: boolean;
6
+ highlightActive: boolean;
6
7
  isCompleted: boolean;
7
8
  }
@@ -11,6 +11,7 @@ export declare class VerticalTimelineComponent {
11
11
  lastItem: TimelineItem[];
12
12
  set activeIndex(index: number);
13
13
  get activeIndex(): number;
14
+ highlightActiveItem: boolean;
14
15
  items: TimelineItem[];
15
16
  counterLabel: string;
16
17
  collapsable: boolean;
@@ -8,6 +8,7 @@ export declare class TimelineComponent implements OnInit {
8
8
  get items(): TimelineItem[];
9
9
  set items(items: TimelineItem[]);
10
10
  activeIndex: number;
11
+ highlightActiveItem: boolean;
11
12
  direction: typeof HORIZONTAL | typeof VERTICAL;
12
13
  collapsable: boolean;
13
14
  counterLabel: string;
@@ -1,15 +1,16 @@
1
1
  var TieredMenuComponent_1;
2
2
  import { __decorate } from "tslib";
3
- import { ApplicationRef, Component, ComponentFactoryResolver, ComponentRef, EmbeddedViewRef, EventEmitter, Injector, OnDestroy, OnInit, Output, } from "@angular/core";
3
+ import { ApplicationRef, ChangeDetectorRef, Component, ComponentFactoryResolver, ComponentRef, EmbeddedViewRef, EventEmitter, HostListener, Injector, OnDestroy, OnInit, Output, } from "@angular/core";
4
4
  import { Subject } from "rxjs";
5
5
  import { takeUntil } from "rxjs/operators";
6
- import { TieredMenuEventService } from "../../tiered-menu.event.service";
7
- import { TieredMenuService } from "../../tiered-menu.service";
6
+ import { TieredMenuEventService } from "../../services/tiered-menu.event.service";
7
+ import { TieredMenuService } from "../../services/tiered-menu.service";
8
8
  let TieredMenuComponent = TieredMenuComponent_1 = class TieredMenuComponent {
9
- constructor(_appRef, _componentFactoryResolver, _injector, tieredMenuService, _tieredMenuEventService) {
9
+ constructor(_appRef, _componentFactoryResolver, _injector, _changeDetectorRef, tieredMenuService, _tieredMenuEventService) {
10
10
  this._appRef = _appRef;
11
11
  this._componentFactoryResolver = _componentFactoryResolver;
12
12
  this._injector = _injector;
13
+ this._changeDetectorRef = _changeDetectorRef;
13
14
  this.tieredMenuService = tieredMenuService;
14
15
  this._tieredMenuEventService = _tieredMenuEventService;
15
16
  this.top = 0;
@@ -19,6 +20,54 @@ let TieredMenuComponent = TieredMenuComponent_1 = class TieredMenuComponent {
19
20
  this._unsubscribe$ = new Subject();
20
21
  this.destroyRequest = new EventEmitter();
21
22
  }
23
+ onResize() {
24
+ this._tieredMenuEventService.closeAllMenusEvent.emit();
25
+ }
26
+ onDocumentClick(event) {
27
+ // Closing menu when clicked outside.
28
+ const target = event.target;
29
+ const clickedInside = target.closest("s-tiered-menu-item") || target.closest("s-tiered-menu-divider");
30
+ if (!clickedInside) {
31
+ this._tieredMenuEventService.closeAllMenusEvent.emit();
32
+ }
33
+ }
34
+ onKeydownHandler(event) {
35
+ switch (event.key) {
36
+ case "Escape":
37
+ this._tieredMenuEventService.closeAllMenusEvent.emit();
38
+ break;
39
+ case " ":
40
+ case "Enter":
41
+ if (!this.tieredMenuService.currentItem.disabled) {
42
+ this._tieredMenuEventService.selectItemEvent.emit(this.tieredMenuService.currentItem);
43
+ }
44
+ break;
45
+ case "ArrowLeft":
46
+ if (this.items.includes(this.tieredMenuService.currentItem)) {
47
+ this._tieredMenuEventService.closeItemMenuEvent.emit(this.tieredMenuService.currentItem);
48
+ this._changeDetectorRef.detectChanges();
49
+ }
50
+ break;
51
+ case "ArrowRight":
52
+ if (!this.tieredMenuService.currentItem.disabled && this.items.includes(this.tieredMenuService.currentItem)) {
53
+ this._tieredMenuEventService.openItemMenuEvent.emit(this.tieredMenuService.currentItem);
54
+ event.stopImmediatePropagation();
55
+ }
56
+ break;
57
+ case "ArrowUp":
58
+ if (!this.tieredMenuService.currentItem || this.items.includes(this.tieredMenuService.currentItem)) {
59
+ this._tieredMenuEventService.decrementCurrentItemEvent.emit();
60
+ event.stopImmediatePropagation();
61
+ }
62
+ break;
63
+ case "ArrowDown":
64
+ if (!this.tieredMenuService.currentItem || this.items.includes(this.tieredMenuService.currentItem)) {
65
+ this._tieredMenuEventService.incrementCurrentItemEvent.emit();
66
+ event.stopImmediatePropagation();
67
+ }
68
+ break;
69
+ }
70
+ }
22
71
  ngOnInit() {
23
72
  this.tieredMenuService.currentItems = this.items;
24
73
  this._subscribeEvents();
@@ -77,8 +126,7 @@ let TieredMenuComponent = TieredMenuComponent_1 = class TieredMenuComponent {
77
126
  // Setting the menu items.
78
127
  this._componentRef.instance.items = items;
79
128
  // Subscribe menu events.
80
- this._componentRef.instance.destroyRequest
81
- .subscribe((propagate) => {
129
+ this._componentRef.instance.destroyRequest.subscribe((propagate) => {
82
130
  this._destroy(propagate);
83
131
  });
84
132
  this._menuDivElement = domElem.querySelector(".menu");
@@ -97,14 +145,23 @@ let TieredMenuComponent = TieredMenuComponent_1 = class TieredMenuComponent {
97
145
  }
98
146
  }
99
147
  _setMenuPosition(position) {
100
- var _a;
148
+ var _a, _b;
149
+ const ITEM_HEIGHT = 37;
150
+ const DIVIDER_HEIGHT = 5;
151
+ const PADDING = 8;
101
152
  if (this._componentRef !== null) {
102
153
  const { top, right, bottom, left } = position;
154
+ const itemsCount = (_a = this._componentRef.instance.items) === null || _a === void 0 ? void 0 : _a.reduce((count, item) => {
155
+ return !item.divider ? count + 1 : count;
156
+ }, 0);
157
+ const dividersCount = (_b = this._componentRef.instance.items) === null || _b === void 0 ? void 0 : _b.reduce((count, item) => {
158
+ return item.divider ? count + 1 : count;
159
+ }, 0);
103
160
  // I need to calculate the height of the component because the internal elements have not been created yet.
104
- const menuHeight = ((_a = this.items) === null || _a === void 0 ? void 0 : _a.length) * 40;
161
+ const menuHeight = itemsCount * ITEM_HEIGHT + dividersCount * DIVIDER_HEIGHT + PADDING + 8;
105
162
  const menuWidth = this._menuDivElement.getBoundingClientRect().width;
106
- const rightFreeSpace = document.body.clientWidth - right;
107
- const bottomFreeSpace = document.body.clientHeight - bottom;
163
+ const rightFreeSpace = window.innerWidth - right;
164
+ const bottomFreeSpace = window.innerHeight - bottom;
108
165
  if (rightFreeSpace > menuWidth) {
109
166
  this._componentRef.instance.left = right;
110
167
  }
@@ -112,84 +169,76 @@ let TieredMenuComponent = TieredMenuComponent_1 = class TieredMenuComponent {
112
169
  this._componentRef.instance.left = left - menuWidth;
113
170
  }
114
171
  if (bottomFreeSpace <= menuHeight) {
115
- this._componentRef.instance.top = top - menuHeight;
172
+ this._componentRef.instance.top = Math.max(window.innerHeight - menuHeight, window.scrollY);
116
173
  }
117
174
  else {
118
- this._componentRef.instance.top = top;
175
+ this._componentRef.instance.top = window.scrollY + top;
119
176
  }
120
177
  }
121
178
  }
122
179
  _subscribeEvents() {
123
180
  // Increment current item event.
124
- this._tieredMenuEventService.incrementCurrentItemEvent
125
- .pipe(takeUntil(this._unsubscribe$))
126
- .subscribe(() => {
181
+ this._tieredMenuEventService.incrementCurrentItemEvent.pipe(takeUntil(this._unsubscribe$)).subscribe(() => {
127
182
  this._incrementCurItem();
128
183
  });
129
184
  // Decrement current item event.
130
- this._tieredMenuEventService.decrementCurrentItemEvent
131
- .pipe(takeUntil(this._unsubscribe$))
132
- .subscribe(() => {
185
+ this._tieredMenuEventService.decrementCurrentItemEvent.pipe(takeUntil(this._unsubscribe$)).subscribe(() => {
133
186
  this._decrementCurItem();
134
187
  });
135
188
  // Select item event.
136
- this._tieredMenuEventService.selectItemEvent
137
- .pipe(takeUntil(this._unsubscribe$))
138
- .subscribe((item) => {
189
+ this._tieredMenuEventService.selectItemEvent.pipe(takeUntil(this._unsubscribe$)).subscribe((item) => {
139
190
  if (item.submenu) {
140
- this._tieredMenuEventService.emitOpenItemMenuEvent(item);
191
+ this._tieredMenuEventService.openItemMenuEvent.emit(item);
141
192
  }
142
193
  else if (item.command) {
143
- this._tieredMenuEventService.emitCloseAllMenusEvent();
194
+ this._tieredMenuEventService.closeAllMenusEvent.emit();
144
195
  item.command();
145
196
  }
146
197
  });
147
198
  // Close all menus event.
148
- this._tieredMenuEventService.closeAllMenusEvent
149
- .pipe(takeUntil(this._unsubscribe$))
150
- .subscribe(() => {
199
+ this._tieredMenuEventService.closeAllMenusEvent.pipe(takeUntil(this._unsubscribe$)).subscribe(() => {
151
200
  this._destroy();
152
201
  this.tieredMenuService.currentItem = null;
153
202
  this.tieredMenuService.currentItems = this.tieredMenuService.items;
203
+ this.tieredMenuService.markAllItemsAsClosed(this.tieredMenuService.items);
154
204
  });
155
205
  // Open item menu event.
156
- this._tieredMenuEventService.openItemMenuEvent
157
- .pipe(takeUntil(this._unsubscribe$))
158
- .subscribe((item) => {
159
- item.isOpen = false;
206
+ this._tieredMenuEventService.openItemMenuEvent.pipe(takeUntil(this._unsubscribe$)).subscribe((item) => {
160
207
  if (this.tieredMenuService.currentItem) {
161
208
  if (this.tieredMenuService.currentItem.parent === item) {
162
209
  return;
163
210
  }
164
211
  if (!this.tieredMenuService.searchTheHierarchy(this.tieredMenuService.currentItem.parent, item)) {
165
- let itemAux = this.tieredMenuService.currentItem;
166
- while (itemAux.parent !== item.parent) {
167
- this._tieredMenuEventService.emitCloseItemMenuEvent(itemAux);
168
- itemAux = itemAux.parent;
212
+ let current = this.tieredMenuService.currentItem;
213
+ current.isOpen = false;
214
+ while ((current === null || current === void 0 ? void 0 : current.parent) !== item.parent) {
215
+ this._tieredMenuEventService.closeItemMenuEvent.emit(current);
216
+ this._changeDetectorRef.detectChanges();
217
+ current = current.parent;
169
218
  }
170
- }
171
- }
172
- if (item.submenu) {
173
- if (!item.isOpen) {
174
- const { top, right, left, bottom } = document
175
- .querySelector(`#${item.id}`)
176
- .getBoundingClientRect();
177
- const position = { top, right, left, bottom };
178
- if (this.items.includes(item)) {
179
- this._createMenu(item.submenu, position);
180
- this.tieredMenuService.currentItems = item.submenu;
181
- this.tieredMenuService.currentItem = item.submenu[0];
219
+ if (current) {
220
+ current.isOpen = false;
182
221
  }
183
222
  }
184
223
  }
224
+ if (item.submenu && !item.isOpen && this.items.includes(item)) {
225
+ const { top, right, left, bottom } = document.querySelector(`#${item.id}`).getBoundingClientRect();
226
+ const position = { top, right, left, bottom };
227
+ this._createMenu(item.submenu, position);
228
+ this.tieredMenuService.currentItems = item.submenu;
229
+ this.tieredMenuService.currentItem = item.submenu[0];
230
+ item.isOpen = true;
231
+ }
185
232
  });
186
233
  // Close item menu event.
187
234
  this._tieredMenuEventService.closeItemMenuEvent
188
235
  .pipe(takeUntil(this._unsubscribe$))
189
236
  .subscribe((item) => {
190
237
  var _a, _b;
191
- if (this.items.includes(item)) {
192
- item.isOpen = false;
238
+ if (this.items.some((i) => i.id === item.id)) {
239
+ if (item.parent) {
240
+ item.parent.isOpen = false;
241
+ }
193
242
  this.tieredMenuService.currentItems = ((_b = (_a = item === null || item === void 0 ? void 0 : item.parent) === null || _a === void 0 ? void 0 : _a.parent) === null || _b === void 0 ? void 0 : _b.submenu) || this.tieredMenuService.items;
194
243
  this.tieredMenuService.currentItem = item.parent;
195
244
  this.destroyRequest.emit(false);
@@ -201,18 +250,28 @@ TieredMenuComponent.ctorParameters = () => [
201
250
  { type: ApplicationRef },
202
251
  { type: ComponentFactoryResolver },
203
252
  { type: Injector },
253
+ { type: ChangeDetectorRef },
204
254
  { type: TieredMenuService },
205
255
  { type: TieredMenuEventService }
206
256
  ];
207
257
  __decorate([
208
258
  Output()
209
259
  ], TieredMenuComponent.prototype, "destroyRequest", void 0);
260
+ __decorate([
261
+ HostListener("window:resize")
262
+ ], TieredMenuComponent.prototype, "onResize", null);
263
+ __decorate([
264
+ HostListener("document:click", ["$event"])
265
+ ], TieredMenuComponent.prototype, "onDocumentClick", null);
266
+ __decorate([
267
+ HostListener("document:keydown", ["$event"])
268
+ ], TieredMenuComponent.prototype, "onKeydownHandler", null);
210
269
  TieredMenuComponent = TieredMenuComponent_1 = __decorate([
211
270
  Component({
212
271
  selector: "s-tiered-menu",
213
- template: "<div class=\"menu\" [ngStyle]=\"{\n 'left': left + 'px',\n 'top': top + 'px'\n }\">\n\n <div *ngFor=\"let item of items\">\n <s-tiered-menu-item\n *ngIf=\"!item.divider\"\n [item]=\"item\"\n [focused]=\"item === tieredMenuService.currentItem\"\n triggerEvent=\"hover\"\n [closeOnClick]=\"false\">\n </s-tiered-menu-item>\n <s-tiered-menu-divider *ngIf=\"item.divider\"></s-tiered-menu-divider>\n </div>\n</div>",
214
- styles: [".menu{background-color:#fff;border:1px solid #ccc;border-radius:6px;box-shadow:0 2px 12px 0 rgba(0,0,0,.1);display:-ms-inline-flexbox;display:inline-flex;-ms-flex-direction:column;flex-direction:column;min-width:176px;padding:4px 0;position:fixed;z-index:9999}"]
272
+ template: "<div\n class=\"menu\"\n [ngStyle]=\"{\n 'left': left + 'px',\n 'top': top + 'px'\n }\">\n\n <div *ngFor=\"let item of items\">\n <s-tiered-menu-item\n *ngIf=\"!item.divider\"\n [item]=\"item\"\n [focused]=\"item === tieredMenuService.currentItem\"\n [highlight]=\"item.isOpen\"\n triggerEvent=\"hover\"\n [closeOnClick]=\"false\">\n </s-tiered-menu-item>\n <s-tiered-menu-divider *ngIf=\"item.divider\"></s-tiered-menu-divider>\n </div>\n</div>",
273
+ styles: [".menu{background-color:#fff;border:1px solid #ccc;border-radius:6px;box-shadow:0 2px 12px 0 rgba(0,0,0,.1);display:-ms-inline-flexbox;display:inline-flex;-ms-flex-direction:column;flex-direction:column;max-height:100vh;min-width:176px;padding:4px 0;overflow-y:auto;position:absolute;z-index:9999}"]
215
274
  })
216
275
  ], TieredMenuComponent);
217
276
  export { TieredMenuComponent };
218
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tiered-menu.component.js","sourceRoot":"ng://@seniorsistemas/angular-components/","sources":["components/tiered-menu/components/tiered-menu/tiered-menu.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    ApplicationRef,\n    Component,\n    ComponentFactoryResolver,\n    ComponentRef,\n    EmbeddedViewRef,\n    EventEmitter,\n    Injector,\n    OnDestroy,\n    OnInit,\n    Output,\n} from \"@angular/core\";\n\nimport { Subject } from \"rxjs\";\n\nimport { takeUntil } from \"rxjs/operators\";\nimport { TieredMenuItemInternalData } from \"../../models/tiered-menu-item-internal-data\";\nimport { TieredMenuEventService } from \"../../tiered-menu.event.service\";\nimport { TieredMenuService } from \"../../tiered-menu.service\";\n\n@Component({\n    selector: \"s-tiered-menu\",\n    templateUrl: \"./tiered-menu.component.html\",\n    styleUrls: [\"./tiered-menu.component.scss\"],\n})\nexport class TieredMenuComponent implements OnInit, OnDestroy {\n    public items: TieredMenuItemInternalData[];\n    public top = 0;\n    public left = 0;\n    public menuTriggerEvent: \"click\" | \"hover\" = \"hover\";\n\n    private _componentRef: ComponentRef<any> = null;\n    private _menuDivElement?: HTMLElement;\n    private _unsubscribe$ = new Subject<void>();\n\n    @Output()\n    public destroyRequest = new EventEmitter<boolean>();\n\n    constructor(\n        private readonly _appRef: ApplicationRef,\n        private readonly _componentFactoryResolver: ComponentFactoryResolver,\n        private readonly _injector: Injector,\n        public readonly tieredMenuService: TieredMenuService,\n        private readonly _tieredMenuEventService: TieredMenuEventService,\n    ) { }\n\n    public ngOnInit(): void {\n        this.tieredMenuService.currentItems = this.items;\n        this._subscribeEvents();\n    }\n\n    public ngOnDestroy(): void {\n        this._unsubscribe$.next();\n        this._unsubscribe$.complete();\n    }\n\n    private _incrementCurItem(): void {\n        if (!this.tieredMenuService.currentItem) {\n            this.tieredMenuService.currentItem = this.tieredMenuService.currentItems[0];\n            return;\n        } else if (!this.items.includes(this.tieredMenuService.currentItem)) {\n            // Checking if it is the current menu.\n            return;\n        }\n\n        const currentIndex = this.tieredMenuService.currentItems.indexOf(this.tieredMenuService.currentItem) + 1;\n\n        if (currentIndex < this.tieredMenuService.currentItems.length) {\n            this.tieredMenuService.currentItem = this.tieredMenuService.currentItems[currentIndex];\n        } else {\n            this.tieredMenuService.currentItem = this.tieredMenuService.currentItems[0];\n        }\n\n        if (this.tieredMenuService.currentItem.divider) {\n            this._incrementCurItem();\n        }\n    }\n\n    private _decrementCurItem(): void {\n        if (!this.tieredMenuService.currentItem) {\n            this.tieredMenuService.currentItem = this.tieredMenuService.currentItems[0];\n            return;\n            // Checking if it is the current menu.\n        } else if (!this.items.includes(this.tieredMenuService.currentItem)) {\n            return;\n        }\n\n        const curIndex = this.tieredMenuService.currentItems.indexOf(this.tieredMenuService.currentItem) - 1;\n\n        if (curIndex >= 0) {\n            this.tieredMenuService.currentItem = this.tieredMenuService.currentItems[curIndex];\n        } else {\n            this.tieredMenuService.currentItem = this.tieredMenuService.currentItems[this.tieredMenuService.currentItems.length - 1];\n        }\n\n        if (this.tieredMenuService.currentItem.divider) {\n            this._decrementCurItem();\n        }\n    }\n\n    private _createMenu(items: TieredMenuItemInternalData[], position: any): void {\n        if (!this._componentRef && items) {\n            const componentFactory = this._componentFactoryResolver.resolveComponentFactory(TieredMenuComponent);\n            this._componentRef = componentFactory.create(this._injector);\n            this._appRef.attachView(this._componentRef.hostView);\n            const domElem = (this._componentRef.hostView as EmbeddedViewRef<any>).rootNodes[0] as HTMLElement;\n            document.body.appendChild(domElem);\n\n            // Setting the menu items.\n            this._componentRef.instance.items = items;\n\n            // Subscribe menu events.\n            this._componentRef.instance.destroyRequest\n                .subscribe((propagate: boolean) => {\n                    this._destroy(propagate);\n                });\n\n            this._menuDivElement = domElem.querySelector(\".menu\");\n            this._setMenuPosition(position);\n        }\n    }\n\n    private _destroy(propagate = true): void {\n        if (this._componentRef !== null) {\n            this._appRef.detachView(this._componentRef.hostView);\n            this._componentRef.destroy();\n            this._componentRef = null;\n            this._menuDivElement = null;\n        }\n\n        if (propagate) {\n            this.destroyRequest.emit();\n        }\n    }\n\n    private _setMenuPosition(position: { top: number, right: number, bottom: number, left: number }): void {\n        if (this._componentRef !== null) {\n            const { top, right, bottom, left } = position;\n            // I need to calculate the height of the component because the internal elements have not been created yet.\n            const menuHeight = (this.items?.length) * 40;\n            const menuWidth = this._menuDivElement.getBoundingClientRect().width;\n\n            const rightFreeSpace = document.body.clientWidth - right;\n            const bottomFreeSpace = document.body.clientHeight - bottom;\n\n            if (rightFreeSpace > menuWidth) {\n                this._componentRef.instance.left = right;\n            } else {\n                this._componentRef.instance.left = left - menuWidth;\n            }\n\n            if (bottomFreeSpace <= menuHeight) {\n                this._componentRef.instance.top = top - menuHeight;\n            } else {\n                this._componentRef.instance.top = top;\n            }\n        }\n    }\n\n    private _subscribeEvents(): void {\n        // Increment current item event.\n        this._tieredMenuEventService.incrementCurrentItemEvent\n            .pipe(takeUntil(this._unsubscribe$))\n            .subscribe(() => {\n                this._incrementCurItem();\n            });\n        // Decrement current item event.\n        this._tieredMenuEventService.decrementCurrentItemEvent\n            .pipe(takeUntil(this._unsubscribe$))\n            .subscribe(() => {\n                this._decrementCurItem();\n            });\n        // Select item event.\n        this._tieredMenuEventService.selectItemEvent\n            .pipe(takeUntil(this._unsubscribe$))\n            .subscribe((item: TieredMenuItemInternalData) => {\n                if (item.submenu) {\n                    this._tieredMenuEventService.emitOpenItemMenuEvent(item);\n                } else if (item.command) {\n                    this._tieredMenuEventService.emitCloseAllMenusEvent();\n                    item.command();\n                }\n            });\n        // Close all menus event.\n        this._tieredMenuEventService.closeAllMenusEvent\n            .pipe(takeUntil(this._unsubscribe$))\n            .subscribe(() => {\n                this._destroy();\n                this.tieredMenuService.currentItem = null;\n                this.tieredMenuService.currentItems = this.tieredMenuService.items;\n            });\n        // Open item menu event.\n        this._tieredMenuEventService.openItemMenuEvent\n            .pipe(takeUntil(this._unsubscribe$))\n            .subscribe((item: TieredMenuItemInternalData) => {\n                item.isOpen = false;\n\n                if (this.tieredMenuService.currentItem) {\n                    if (this.tieredMenuService.currentItem.parent === item) {\n                        return;\n                    }\n                    if (\n                        !this.tieredMenuService.searchTheHierarchy(\n                            this.tieredMenuService.currentItem.parent,\n                            item\n                        )\n                    ) {\n                        let itemAux = this.tieredMenuService.currentItem;\n                        while (itemAux.parent !== item.parent) {\n                            this._tieredMenuEventService.emitCloseItemMenuEvent(\n                                itemAux\n                            );\n                            itemAux = itemAux.parent;\n                        }\n                    }\n                }\n\n                if (item.submenu) {\n                    if (!item.isOpen) {\n                        const { top, right, left, bottom } = document\n                            .querySelector(`#${item.id}`)\n                            .getBoundingClientRect();\n                        const position = { top, right, left, bottom };\n                        if (this.items.includes(item)) {\n                            this._createMenu(item.submenu, position);\n                            this.tieredMenuService.currentItems = item.submenu;\n                            this.tieredMenuService.currentItem = item.submenu[0];\n                        }\n                    }\n                }\n            });\n        // Close item menu event.\n        this._tieredMenuEventService.closeItemMenuEvent\n            .pipe(takeUntil(this._unsubscribe$))\n            .subscribe((item: TieredMenuItemInternalData) => {\n                if (this.items.includes(item)) {\n                    item.isOpen = false;\n                    this.tieredMenuService.currentItems = item?.parent?.parent?.submenu || this.tieredMenuService.items;\n                    this.tieredMenuService.currentItem = item.parent;\n                    this.destroyRequest.emit(false);\n                }\n            });\n    }\n}\n"]}
277
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tiered-menu.component.js","sourceRoot":"ng://@seniorsistemas/angular-components/","sources":["components/tiered-menu/components/tiered-menu/tiered-menu.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    ApplicationRef,\n    ChangeDetectorRef,\n    Component,\n    ComponentFactoryResolver,\n    ComponentRef,\n    EmbeddedViewRef,\n    EventEmitter,\n    HostListener,\n    Injector,\n    OnDestroy,\n    OnInit,\n    Output,\n} from \"@angular/core\";\n\nimport { Subject } from \"rxjs\";\n\nimport { takeUntil } from \"rxjs/operators\";\nimport { TieredMenuItemInternalData } from \"../../models/tiered-menu-item-internal-data\";\nimport { TieredMenuEventService } from \"../../services/tiered-menu.event.service\";\nimport { TieredMenuService } from \"../../services/tiered-menu.service\";\n\n@Component({\n    selector: \"s-tiered-menu\",\n    templateUrl: \"./tiered-menu.component.html\",\n    styleUrls: [\"./tiered-menu.component.scss\"],\n})\nexport class TieredMenuComponent implements OnInit, OnDestroy {\n    public items: TieredMenuItemInternalData[];\n    public top = 0;\n    public left = 0;\n    public menuTriggerEvent: \"click\" | \"hover\" = \"hover\";\n\n    private _componentRef: ComponentRef<TieredMenuComponent> = null;\n    private _menuDivElement?: HTMLElement;\n    private _unsubscribe$ = new Subject<void>();\n\n    @Output()\n    public destroyRequest = new EventEmitter<boolean>();\n\n    constructor(\n        private readonly _appRef: ApplicationRef,\n        private readonly _componentFactoryResolver: ComponentFactoryResolver,\n        private readonly _injector: Injector,\n        private readonly _changeDetectorRef: ChangeDetectorRef,\n        public readonly tieredMenuService: TieredMenuService,\n        private readonly _tieredMenuEventService: TieredMenuEventService\n    ) {}\n\n    @HostListener(\"window:resize\")\n    public onResize(): void {\n        this._tieredMenuEventService.closeAllMenusEvent.emit();\n    }\n\n    @HostListener(\"document:click\", [\"$event\"])\n    public onDocumentClick(event: MouseEvent): void {\n        // Closing menu when clicked outside.\n        const target = event.target as Element;\n        const clickedInside = target.closest(\"s-tiered-menu-item\") || target.closest(\"s-tiered-menu-divider\");\n        if (!clickedInside) {\n            this._tieredMenuEventService.closeAllMenusEvent.emit();\n        }\n    }\n\n    @HostListener(\"document:keydown\", [\"$event\"])\n    public onKeydownHandler(event: KeyboardEvent) {\n        switch (event.key) {\n            case \"Escape\":\n                this._tieredMenuEventService.closeAllMenusEvent.emit();\n                break;\n            case \" \":\n            case \"Enter\":\n                if (!this.tieredMenuService.currentItem.disabled) {\n                    this._tieredMenuEventService.selectItemEvent.emit(this.tieredMenuService.currentItem);\n                }\n                break;\n            case \"ArrowLeft\":\n                if (this.items.includes(this.tieredMenuService.currentItem)) {\n                    this._tieredMenuEventService.closeItemMenuEvent.emit(this.tieredMenuService.currentItem);\n                    this._changeDetectorRef.detectChanges();\n                }\n                break;\n            case \"ArrowRight\":\n                if (!this.tieredMenuService.currentItem.disabled && this.items.includes(this.tieredMenuService.currentItem)) {\n                    this._tieredMenuEventService.openItemMenuEvent.emit(this.tieredMenuService.currentItem);\n                    event.stopImmediatePropagation();\n                }\n                break;\n            case \"ArrowUp\":\n                if (!this.tieredMenuService.currentItem || this.items.includes(this.tieredMenuService.currentItem)) {\n                    this._tieredMenuEventService.decrementCurrentItemEvent.emit();\n                    event.stopImmediatePropagation();\n                }\n                break;\n            case \"ArrowDown\":\n                if (!this.tieredMenuService.currentItem || this.items.includes(this.tieredMenuService.currentItem)) {\n                    this._tieredMenuEventService.incrementCurrentItemEvent.emit();\n                    event.stopImmediatePropagation();\n                }\n                break;\n        }\n    }\n\n    public ngOnInit(): void {\n        this.tieredMenuService.currentItems = this.items;\n        this._subscribeEvents();\n    }\n\n    public ngOnDestroy(): void {\n        this._unsubscribe$.next();\n        this._unsubscribe$.complete();\n    }\n\n    private _incrementCurItem(): void {\n        if (!this.tieredMenuService.currentItem) {\n            this.tieredMenuService.currentItem = this.tieredMenuService.currentItems[0];\n            return;\n        } else if (!this.items.includes(this.tieredMenuService.currentItem)) {\n            // Checking if it is the current menu.\n            return;\n        }\n\n        const currentIndex = this.tieredMenuService.currentItems.indexOf(this.tieredMenuService.currentItem) + 1;\n\n        if (currentIndex < this.tieredMenuService.currentItems.length) {\n            this.tieredMenuService.currentItem = this.tieredMenuService.currentItems[currentIndex];\n        } else {\n            this.tieredMenuService.currentItem = this.tieredMenuService.currentItems[0];\n        }\n\n        if (this.tieredMenuService.currentItem.divider) {\n            this._incrementCurItem();\n        }\n    }\n\n    private _decrementCurItem(): void {\n        if (!this.tieredMenuService.currentItem) {\n            this.tieredMenuService.currentItem = this.tieredMenuService.currentItems[0];\n            return;\n            // Checking if it is the current menu.\n        } else if (!this.items.includes(this.tieredMenuService.currentItem)) {\n            return;\n        }\n\n        const curIndex = this.tieredMenuService.currentItems.indexOf(this.tieredMenuService.currentItem) - 1;\n\n        if (curIndex >= 0) {\n            this.tieredMenuService.currentItem = this.tieredMenuService.currentItems[curIndex];\n        } else {\n            this.tieredMenuService.currentItem = this.tieredMenuService.currentItems[this.tieredMenuService.currentItems.length - 1];\n        }\n\n        if (this.tieredMenuService.currentItem.divider) {\n            this._decrementCurItem();\n        }\n    }\n\n    private _createMenu(items: TieredMenuItemInternalData[], position: any): void {\n        if (!this._componentRef && items) {\n            const componentFactory = this._componentFactoryResolver.resolveComponentFactory(TieredMenuComponent);\n            this._componentRef = componentFactory.create(this._injector);\n            this._appRef.attachView(this._componentRef.hostView);\n            const domElem = (this._componentRef.hostView as EmbeddedViewRef<any>).rootNodes[0] as HTMLElement;\n            document.body.appendChild(domElem);\n\n            // Setting the menu items.\n            this._componentRef.instance.items = items;\n\n            // Subscribe menu events.\n            this._componentRef.instance.destroyRequest.subscribe((propagate: boolean) => {\n                this._destroy(propagate);\n            });\n\n            this._menuDivElement = domElem.querySelector(\".menu\");\n            this._setMenuPosition(position);\n        }\n    }\n\n    private _destroy(propagate = true): void {\n        if (this._componentRef !== null) {\n            this._appRef.detachView(this._componentRef.hostView);\n            this._componentRef.destroy();\n            this._componentRef = null;\n            this._menuDivElement = null;\n        }\n\n        if (propagate) {\n            this.destroyRequest.emit();\n        }\n    }\n\n    private _setMenuPosition(position: any): void {\n        const ITEM_HEIGHT = 37;\n        const DIVIDER_HEIGHT = 5;\n        const PADDING = 8;\n\n        if (this._componentRef !== null) {\n            const { top, right, bottom, left } = position;\n\n            const itemsCount = this._componentRef.instance.items?.reduce((count: number, item: TieredMenuItemInternalData) => {\n                return !item.divider ? count + 1 : count;\n            }, 0);\n\n            const dividersCount = this._componentRef.instance.items?.reduce((count: number, item: TieredMenuItemInternalData) => {\n                return item.divider ? count + 1 : count;\n            }, 0);\n\n            // I need to calculate the height of the component because the internal elements have not been created yet.\n            const menuHeight = itemsCount * ITEM_HEIGHT + dividersCount * DIVIDER_HEIGHT + PADDING + 8;\n            const menuWidth = this._menuDivElement.getBoundingClientRect().width;\n\n            const rightFreeSpace = window.innerWidth - right;\n            const bottomFreeSpace = window.innerHeight - bottom;\n\n            if (rightFreeSpace > menuWidth) {\n                this._componentRef.instance.left = right;\n            } else {\n                this._componentRef.instance.left = left - menuWidth;\n            }\n\n            if (bottomFreeSpace <= menuHeight) {\n                this._componentRef.instance.top = Math.max(window.innerHeight - menuHeight, window.scrollY);\n            } else {\n                this._componentRef.instance.top = window.scrollY + top;\n            }\n        }\n    }\n\n    private _subscribeEvents(): void {\n        // Increment current item event.\n        this._tieredMenuEventService.incrementCurrentItemEvent.pipe(takeUntil(this._unsubscribe$)).subscribe(() => {\n            this._incrementCurItem();\n        });\n        // Decrement current item event.\n        this._tieredMenuEventService.decrementCurrentItemEvent.pipe(takeUntil(this._unsubscribe$)).subscribe(() => {\n            this._decrementCurItem();\n        });\n        // Select item event.\n        this._tieredMenuEventService.selectItemEvent.pipe(takeUntil(this._unsubscribe$)).subscribe((item: TieredMenuItemInternalData) => {\n            if (item.submenu) {\n                this._tieredMenuEventService.openItemMenuEvent.emit(item);\n            } else if (item.command) {\n                this._tieredMenuEventService.closeAllMenusEvent.emit();\n                item.command();\n            }\n        });\n        // Close all menus event.\n        this._tieredMenuEventService.closeAllMenusEvent.pipe(takeUntil(this._unsubscribe$)).subscribe(() => {\n            this._destroy();\n            this.tieredMenuService.currentItem = null;\n            this.tieredMenuService.currentItems = this.tieredMenuService.items;\n            this.tieredMenuService.markAllItemsAsClosed(this.tieredMenuService.items);\n        });\n\n        // Open item menu event.\n        this._tieredMenuEventService.openItemMenuEvent.pipe(takeUntil(this._unsubscribe$)).subscribe((item: TieredMenuItemInternalData) => {\n            if (this.tieredMenuService.currentItem) {\n                if (this.tieredMenuService.currentItem.parent === item) {\n                    return;\n                }\n\n                if (!this.tieredMenuService.searchTheHierarchy(this.tieredMenuService.currentItem.parent, item)) {\n                    let current = this.tieredMenuService.currentItem;\n\n                    current.isOpen = false;\n\n                    while (current?.parent !== item.parent) {\n                        this._tieredMenuEventService.closeItemMenuEvent.emit(current);\n                        this._changeDetectorRef.detectChanges();\n\n                        current = current.parent;\n                    }\n\n                    if (current) {\n                        current.isOpen = false;\n                    }\n                }\n            }\n\n            if (item.submenu && !item.isOpen && this.items.includes(item)) {\n                const { top, right, left, bottom } = document.querySelector(`#${item.id}`).getBoundingClientRect();\n                const position = { top, right, left, bottom };\n\n                this._createMenu(item.submenu, position);\n                this.tieredMenuService.currentItems = item.submenu;\n                this.tieredMenuService.currentItem = item.submenu[0];\n                item.isOpen = true;\n            }\n        });\n\n        // Close item menu event.\n        this._tieredMenuEventService.closeItemMenuEvent\n            .pipe(takeUntil(this._unsubscribe$))\n            .subscribe((item: TieredMenuItemInternalData) => {\n                if (this.items.some((i) => i.id === item.id)) {\n                    if (item.parent) {\n                        item.parent.isOpen = false;\n                    }\n                    this.tieredMenuService.currentItems = item?.parent?.parent?.submenu || this.tieredMenuService.items;\n                    this.tieredMenuService.currentItem = item.parent;\n                    this.destroyRequest.emit(false);\n                }\n            });\n    }\n}\n"]}