contextMenu.service.js 34 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388
  1. /**
  2. * @fileoverview added by tsickle
  3. * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
  4. */
  5. import * as tslib_1 from "tslib";
  6. import { Overlay, ScrollStrategyOptions } from '@angular/cdk/overlay';
  7. import { ComponentPortal } from '@angular/cdk/portal';
  8. import { Injectable, ElementRef } from '@angular/core';
  9. import { Subject, Subscription } from 'rxjs';
  10. import { ContextMenuContentComponent } from './contextMenuContent.component';
  11. /**
  12. * @record
  13. */
  14. export function IContextMenuClickEvent() { }
  15. if (false) {
  16. /** @type {?|undefined} */
  17. IContextMenuClickEvent.prototype.anchorElement;
  18. /** @type {?|undefined} */
  19. IContextMenuClickEvent.prototype.contextMenu;
  20. /** @type {?|undefined} */
  21. IContextMenuClickEvent.prototype.event;
  22. /** @type {?|undefined} */
  23. IContextMenuClickEvent.prototype.parentContextMenu;
  24. /** @type {?} */
  25. IContextMenuClickEvent.prototype.item;
  26. /** @type {?|undefined} */
  27. IContextMenuClickEvent.prototype.activeMenuItemIndex;
  28. }
  29. /**
  30. * @record
  31. */
  32. export function IContextMenuContext() { }
  33. if (false) {
  34. /** @type {?} */
  35. IContextMenuContext.prototype.menuItems;
  36. /** @type {?} */
  37. IContextMenuContext.prototype.menuClass;
  38. }
  39. /**
  40. * @record
  41. */
  42. export function CloseLeafMenuEvent() { }
  43. if (false) {
  44. /** @type {?|undefined} */
  45. CloseLeafMenuEvent.prototype.exceptRootMenu;
  46. /** @type {?|undefined} */
  47. CloseLeafMenuEvent.prototype.event;
  48. }
  49. /**
  50. * @record
  51. */
  52. export function OverlayRefWithContextMenu() { }
  53. if (false) {
  54. /** @type {?|undefined} */
  55. OverlayRefWithContextMenu.prototype.contextMenu;
  56. }
  57. /**
  58. * @record
  59. */
  60. export function CancelContextMenuEvent() { }
  61. if (false) {
  62. /** @type {?} */
  63. CancelContextMenuEvent.prototype.eventType;
  64. /** @type {?|undefined} */
  65. CancelContextMenuEvent.prototype.event;
  66. }
  67. /**
  68. * @record
  69. */
  70. export function ExecuteContextMenuEvent() { }
  71. if (false) {
  72. /** @type {?} */
  73. ExecuteContextMenuEvent.prototype.eventType;
  74. /** @type {?|undefined} */
  75. ExecuteContextMenuEvent.prototype.event;
  76. /** @type {?} */
  77. ExecuteContextMenuEvent.prototype.item;
  78. /** @type {?} */
  79. ExecuteContextMenuEvent.prototype.menuItem;
  80. }
  81. var ContextMenuService = /** @class */ (function () {
  82. function ContextMenuService(overlay, scrollStrategy) {
  83. this.overlay = overlay;
  84. this.scrollStrategy = scrollStrategy;
  85. this.isDestroyingLeafMenu = false;
  86. this.show = new Subject();
  87. this.triggerClose = new Subject();
  88. this.close = new Subject();
  89. this.overlays = [];
  90. this.fakeElement = {
  91. getBoundingClientRect: (/**
  92. * @return {?}
  93. */
  94. function () { return ({
  95. bottom: 0,
  96. height: 0,
  97. left: 0,
  98. right: 0,
  99. top: 0,
  100. width: 0,
  101. }); })
  102. };
  103. }
  104. /**
  105. * @param {?} context
  106. * @return {?}
  107. */
  108. ContextMenuService.prototype.openContextMenu = /**
  109. * @param {?} context
  110. * @return {?}
  111. */
  112. function (context) {
  113. var anchorElement = context.anchorElement, event = context.event, parentContextMenu = context.parentContextMenu;
  114. if (!parentContextMenu) {
  115. /** @type {?} */
  116. var mouseEvent_1 = (/** @type {?} */ (event));
  117. this.fakeElement.getBoundingClientRect = (/**
  118. * @return {?}
  119. */
  120. function () { return ({
  121. bottom: mouseEvent_1.clientY,
  122. height: 0,
  123. left: mouseEvent_1.clientX,
  124. right: mouseEvent_1.clientX,
  125. top: mouseEvent_1.clientY,
  126. width: 0,
  127. }); });
  128. this.closeAllContextMenus({ eventType: 'cancel', event: event });
  129. /** @type {?} */
  130. var positionStrategy = this.overlay.position().connectedTo(new ElementRef(anchorElement || this.fakeElement), { originX: 'start', originY: 'bottom' }, { overlayX: 'start', overlayY: 'top' })
  131. .withFallbackPosition({ originX: 'start', originY: 'top' }, { overlayX: 'start', overlayY: 'bottom' })
  132. .withFallbackPosition({ originX: 'end', originY: 'top' }, { overlayX: 'start', overlayY: 'top' })
  133. .withFallbackPosition({ originX: 'start', originY: 'top' }, { overlayX: 'end', overlayY: 'top' })
  134. .withFallbackPosition({ originX: 'end', originY: 'center' }, { overlayX: 'start', overlayY: 'center' })
  135. .withFallbackPosition({ originX: 'start', originY: 'center' }, { overlayX: 'end', overlayY: 'center' });
  136. this.overlays = [this.overlay.create({
  137. positionStrategy: positionStrategy,
  138. panelClass: 'ngx-contextmenu',
  139. scrollStrategy: this.scrollStrategy.close(),
  140. })];
  141. this.attachContextMenu(this.overlays[0], context);
  142. }
  143. else {
  144. /** @type {?} */
  145. var positionStrategy = this.overlay.position().connectedTo(new ElementRef(event ? event.target : anchorElement), { originX: 'end', originY: 'top' }, { overlayX: 'start', overlayY: 'top' })
  146. .withFallbackPosition({ originX: 'start', originY: 'top' }, { overlayX: 'end', overlayY: 'top' })
  147. .withFallbackPosition({ originX: 'end', originY: 'bottom' }, { overlayX: 'start', overlayY: 'bottom' })
  148. .withFallbackPosition({ originX: 'start', originY: 'bottom' }, { overlayX: 'end', overlayY: 'bottom' });
  149. /** @type {?} */
  150. var newOverlay = this.overlay.create({
  151. positionStrategy: positionStrategy,
  152. panelClass: 'ngx-contextmenu',
  153. scrollStrategy: this.scrollStrategy.close(),
  154. });
  155. this.destroySubMenus(parentContextMenu);
  156. this.overlays = this.overlays.concat(newOverlay);
  157. this.attachContextMenu(newOverlay, context);
  158. }
  159. };
  160. /**
  161. * @param {?} overlay
  162. * @param {?} context
  163. * @return {?}
  164. */
  165. ContextMenuService.prototype.attachContextMenu = /**
  166. * @param {?} overlay
  167. * @param {?} context
  168. * @return {?}
  169. */
  170. function (overlay, context) {
  171. var _this = this;
  172. var event = context.event, item = context.item, menuItems = context.menuItems, menuClass = context.menuClass;
  173. /** @type {?} */
  174. var contextMenuContent = overlay.attach(new ComponentPortal(ContextMenuContentComponent));
  175. contextMenuContent.instance.event = event;
  176. contextMenuContent.instance.item = item;
  177. contextMenuContent.instance.menuItems = menuItems;
  178. contextMenuContent.instance.overlay = overlay;
  179. contextMenuContent.instance.isLeaf = true;
  180. contextMenuContent.instance.menuClass = menuClass;
  181. ((/** @type {?} */ (overlay))).contextMenu = contextMenuContent.instance;
  182. /** @type {?} */
  183. var subscriptions = new Subscription();
  184. subscriptions.add(contextMenuContent.instance.execute.asObservable()
  185. .subscribe((/**
  186. * @param {?} executeEvent
  187. * @return {?}
  188. */
  189. function (executeEvent) { return _this.closeAllContextMenus(tslib_1.__assign({ eventType: 'execute' }, executeEvent)); })));
  190. subscriptions.add(contextMenuContent.instance.closeAllMenus.asObservable()
  191. .subscribe((/**
  192. * @param {?} closeAllEvent
  193. * @return {?}
  194. */
  195. function (closeAllEvent) { return _this.closeAllContextMenus(tslib_1.__assign({ eventType: 'cancel' }, closeAllEvent)); })));
  196. subscriptions.add(contextMenuContent.instance.closeLeafMenu.asObservable()
  197. .subscribe((/**
  198. * @param {?} closeLeafMenuEvent
  199. * @return {?}
  200. */
  201. function (closeLeafMenuEvent) { return _this.destroyLeafMenu(closeLeafMenuEvent); })));
  202. subscriptions.add(contextMenuContent.instance.openSubMenu.asObservable()
  203. .subscribe((/**
  204. * @param {?} subMenuEvent
  205. * @return {?}
  206. */
  207. function (subMenuEvent) {
  208. _this.destroySubMenus(contextMenuContent.instance);
  209. if (!subMenuEvent.contextMenu) {
  210. contextMenuContent.instance.isLeaf = true;
  211. return;
  212. }
  213. contextMenuContent.instance.isLeaf = false;
  214. _this.show.next(subMenuEvent);
  215. })));
  216. contextMenuContent.onDestroy((/**
  217. * @return {?}
  218. */
  219. function () {
  220. menuItems.forEach((/**
  221. * @param {?} menuItem
  222. * @return {?}
  223. */
  224. function (menuItem) { return menuItem.isActive = false; }));
  225. subscriptions.unsubscribe();
  226. }));
  227. contextMenuContent.changeDetectorRef.detectChanges();
  228. };
  229. /**
  230. * @param {?} closeEvent
  231. * @return {?}
  232. */
  233. ContextMenuService.prototype.closeAllContextMenus = /**
  234. * @param {?} closeEvent
  235. * @return {?}
  236. */
  237. function (closeEvent) {
  238. if (this.overlays) {
  239. this.close.next(closeEvent);
  240. this.overlays.forEach((/**
  241. * @param {?} overlay
  242. * @param {?} index
  243. * @return {?}
  244. */
  245. function (overlay, index) {
  246. overlay.detach();
  247. overlay.dispose();
  248. }));
  249. }
  250. this.overlays = [];
  251. };
  252. /**
  253. * @return {?}
  254. */
  255. ContextMenuService.prototype.getLastAttachedOverlay = /**
  256. * @return {?}
  257. */
  258. function () {
  259. /** @type {?} */
  260. var overlay = this.overlays[this.overlays.length - 1];
  261. while (this.overlays.length > 1 && overlay && !overlay.hasAttached()) {
  262. overlay.detach();
  263. overlay.dispose();
  264. this.overlays = this.overlays.slice(0, -1);
  265. overlay = this.overlays[this.overlays.length - 1];
  266. }
  267. return overlay;
  268. };
  269. /**
  270. * @param {?=} __0
  271. * @return {?}
  272. */
  273. ContextMenuService.prototype.destroyLeafMenu = /**
  274. * @param {?=} __0
  275. * @return {?}
  276. */
  277. function (_a) {
  278. var _this = this;
  279. var _b = _a === void 0 ? {} : _a, exceptRootMenu = _b.exceptRootMenu, event = _b.event;
  280. if (this.isDestroyingLeafMenu) {
  281. return;
  282. }
  283. this.isDestroyingLeafMenu = true;
  284. setTimeout((/**
  285. * @return {?}
  286. */
  287. function () {
  288. /** @type {?} */
  289. var overlay = _this.getLastAttachedOverlay();
  290. if (_this.overlays.length > 1 && overlay) {
  291. overlay.detach();
  292. overlay.dispose();
  293. }
  294. if (!exceptRootMenu && _this.overlays.length > 0 && overlay) {
  295. _this.close.next({ eventType: 'cancel', event: event });
  296. overlay.detach();
  297. overlay.dispose();
  298. }
  299. /** @type {?} */
  300. var newLeaf = _this.getLastAttachedOverlay();
  301. if (newLeaf) {
  302. newLeaf.contextMenu.isLeaf = true;
  303. }
  304. _this.isDestroyingLeafMenu = false;
  305. }));
  306. };
  307. /**
  308. * @param {?} contextMenu
  309. * @return {?}
  310. */
  311. ContextMenuService.prototype.destroySubMenus = /**
  312. * @param {?} contextMenu
  313. * @return {?}
  314. */
  315. function (contextMenu) {
  316. /** @type {?} */
  317. var overlay = contextMenu.overlay;
  318. /** @type {?} */
  319. var index = this.overlays.indexOf(overlay);
  320. this.overlays.slice(index + 1).forEach((/**
  321. * @param {?} subMenuOverlay
  322. * @return {?}
  323. */
  324. function (subMenuOverlay) {
  325. subMenuOverlay.detach();
  326. subMenuOverlay.dispose();
  327. }));
  328. };
  329. /**
  330. * @param {?} contextMenuContent
  331. * @return {?}
  332. */
  333. ContextMenuService.prototype.isLeafMenu = /**
  334. * @param {?} contextMenuContent
  335. * @return {?}
  336. */
  337. function (contextMenuContent) {
  338. /** @type {?} */
  339. var overlay = this.getLastAttachedOverlay();
  340. return contextMenuContent.overlay === overlay;
  341. };
  342. ContextMenuService.decorators = [
  343. { type: Injectable }
  344. ];
  345. /** @nocollapse */
  346. ContextMenuService.ctorParameters = function () { return [
  347. { type: Overlay },
  348. { type: ScrollStrategyOptions }
  349. ]; };
  350. return ContextMenuService;
  351. }());
  352. export { ContextMenuService };
  353. if (false) {
  354. /** @type {?} */
  355. ContextMenuService.prototype.isDestroyingLeafMenu;
  356. /** @type {?} */
  357. ContextMenuService.prototype.show;
  358. /** @type {?} */
  359. ContextMenuService.prototype.triggerClose;
  360. /** @type {?} */
  361. ContextMenuService.prototype.close;
  362. /**
  363. * @type {?}
  364. * @private
  365. */
  366. ContextMenuService.prototype.contextMenuContent;
  367. /**
  368. * @type {?}
  369. * @private
  370. */
  371. ContextMenuService.prototype.overlays;
  372. /**
  373. * @type {?}
  374. * @private
  375. */
  376. ContextMenuService.prototype.fakeElement;
  377. /**
  378. * @type {?}
  379. * @private
  380. */
  381. ContextMenuService.prototype.overlay;
  382. /**
  383. * @type {?}
  384. * @private
  385. */
  386. ContextMenuService.prototype.scrollStrategy;
  387. }
  388. //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"contextMenu.service.js","sourceRoot":"ng://ngx-contextmenu/","sources":["lib/contextMenu.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Overlay, OverlayRef, ScrollStrategyOptions } from '@angular/cdk/overlay';\nimport { ComponentPortal } from '@angular/cdk/portal';\nimport { ComponentRef, Injectable, ElementRef } from '@angular/core';\nimport { Subject, Subscription } from 'rxjs';\n\nimport { ContextMenuComponent } from './contextMenu.component';\nimport { ContextMenuItemDirective } from './contextMenu.item.directive';\nimport { ContextMenuContentComponent } from './contextMenuContent.component';\n\nexport interface IContextMenuClickEvent {\n  anchorElement?: Element | EventTarget;\n  contextMenu?: ContextMenuComponent;\n  event?: MouseEvent | KeyboardEvent;\n  parentContextMenu?: ContextMenuContentComponent;\n  item: any;\n  activeMenuItemIndex?: number;\n}\nexport interface IContextMenuContext extends IContextMenuClickEvent {\n  menuItems: ContextMenuItemDirective[];\n  menuClass: string;\n}\nexport interface CloseLeafMenuEvent {\n  exceptRootMenu?: boolean;\n  event?: MouseEvent | KeyboardEvent;\n}\nexport interface OverlayRefWithContextMenu extends OverlayRef {\n  contextMenu?: ContextMenuContentComponent;\n}\n\nexport interface CancelContextMenuEvent {\n  eventType: 'cancel';\n  event?: MouseEvent | KeyboardEvent;\n}\nexport interface ExecuteContextMenuEvent {\n  eventType: 'execute';\n  event?: MouseEvent | KeyboardEvent;\n  item: any;\n  menuItem: ContextMenuItemDirective;\n}\nexport type CloseContextMenuEvent = ExecuteContextMenuEvent | CancelContextMenuEvent;\n\n@Injectable()\nexport class ContextMenuService {\n  public isDestroyingLeafMenu = false;\n\n  public show: Subject<IContextMenuClickEvent> = new Subject<IContextMenuClickEvent>();\n  public triggerClose: Subject<ContextMenuContentComponent> = new Subject();\n  public close: Subject<CloseContextMenuEvent> = new Subject();\n\n  private contextMenuContent: ComponentRef<ContextMenuContentComponent>;\n  private overlays: OverlayRef[] = [];\n  private fakeElement: any = {\n    getBoundingClientRect: (): ClientRect => ({\n      bottom: 0,\n      height: 0,\n      left: 0,\n      right: 0,\n      top: 0,\n      width: 0,\n    })\n  };\n\n  constructor(\n    private overlay: Overlay,\n    private scrollStrategy: ScrollStrategyOptions,\n  ) { }\n\n  public openContextMenu(context: IContextMenuContext) {\n    const { anchorElement, event, parentContextMenu } = context;\n\n    if (!parentContextMenu) {\n      const mouseEvent = event as MouseEvent;\n      this.fakeElement.getBoundingClientRect = (): ClientRect => ({\n        bottom: mouseEvent.clientY,\n        height: 0,\n        left: mouseEvent.clientX,\n        right: mouseEvent.clientX,\n        top: mouseEvent.clientY,\n        width: 0,\n      });\n      this.closeAllContextMenus({ eventType: 'cancel', event });\n      const positionStrategy = this.overlay.position().connectedTo(\n        new ElementRef(anchorElement || this.fakeElement),\n        { originX: 'start', originY: 'bottom' },\n        { overlayX: 'start', overlayY: 'top' })\n        .withFallbackPosition(\n        { originX: 'start', originY: 'top' },\n        { overlayX: 'start', overlayY: 'bottom' })\n        .withFallbackPosition(\n        { originX: 'end', originY: 'top' },\n        { overlayX: 'start', overlayY: 'top' })\n        .withFallbackPosition(\n        { originX: 'start', originY: 'top' },\n        { overlayX: 'end', overlayY: 'top' })\n        .withFallbackPosition(\n        { originX: 'end', originY: 'center' },\n        { overlayX: 'start', overlayY: 'center' })\n        .withFallbackPosition(\n        { originX: 'start', originY: 'center' },\n        { overlayX: 'end', overlayY: 'center' })\n        ;\n      this.overlays = [this.overlay.create({\n        positionStrategy,\n        panelClass: 'ngx-contextmenu',\n        scrollStrategy: this.scrollStrategy.close(),\n      })];\n      this.attachContextMenu(this.overlays[0], context);\n    } else {\n      const positionStrategy = this.overlay.position().connectedTo(\n        new ElementRef(event ? event.target : anchorElement),\n        { originX: 'end', originY: 'top' },\n        { overlayX: 'start', overlayY: 'top' })\n        .withFallbackPosition(\n        { originX: 'start', originY: 'top' },\n        { overlayX: 'end', overlayY: 'top' })\n        .withFallbackPosition(\n        { originX: 'end', originY: 'bottom' },\n        { overlayX: 'start', overlayY: 'bottom' })\n        .withFallbackPosition(\n        { originX: 'start', originY: 'bottom' },\n        { overlayX: 'end', overlayY: 'bottom' })\n        ;\n      const newOverlay = this.overlay.create({\n        positionStrategy,\n        panelClass: 'ngx-contextmenu',\n        scrollStrategy: this.scrollStrategy.close(),\n      });\n      this.destroySubMenus(parentContextMenu);\n      this.overlays = this.overlays.concat(newOverlay);\n      this.attachContextMenu(newOverlay, context);\n    }\n  }\n\n  public attachContextMenu(overlay: OverlayRef, context: IContextMenuContext): void {\n    const { event, item, menuItems, menuClass } = context;\n\n    const contextMenuContent: ComponentRef<ContextMenuContentComponent> = overlay.attach(new ComponentPortal(ContextMenuContentComponent));\n    contextMenuContent.instance.event = event;\n    contextMenuContent.instance.item = item;\n    contextMenuContent.instance.menuItems = menuItems;\n    contextMenuContent.instance.overlay = overlay;\n    contextMenuContent.instance.isLeaf = true;\n    contextMenuContent.instance.menuClass = menuClass;\n    (<OverlayRefWithContextMenu>overlay).contextMenu = contextMenuContent.instance;\n\n    const subscriptions: Subscription = new Subscription();\n    subscriptions.add(contextMenuContent.instance.execute.asObservable()\n      .subscribe((executeEvent) => this.closeAllContextMenus({ eventType: 'execute', ...executeEvent })));\n    subscriptions.add(contextMenuContent.instance.closeAllMenus.asObservable()\n      .subscribe((closeAllEvent) => this.closeAllContextMenus({ eventType: 'cancel', ...closeAllEvent })));\n    subscriptions.add(contextMenuContent.instance.closeLeafMenu.asObservable()\n      .subscribe(closeLeafMenuEvent => this.destroyLeafMenu(closeLeafMenuEvent)));\n    subscriptions.add(contextMenuContent.instance.openSubMenu.asObservable()\n      .subscribe((subMenuEvent: IContextMenuContext) => {\n        this.destroySubMenus(contextMenuContent.instance);\n        if (!subMenuEvent.contextMenu) {\n          contextMenuContent.instance.isLeaf = true;\n          return;\n        }\n        contextMenuContent.instance.isLeaf = false;\n        this.show.next(subMenuEvent);\n      }));\n    contextMenuContent.onDestroy(() => {\n      menuItems.forEach(menuItem => menuItem.isActive = false);\n      subscriptions.unsubscribe();\n    });\n    contextMenuContent.changeDetectorRef.detectChanges();\n  }\n\n  public closeAllContextMenus(closeEvent: CloseContextMenuEvent): void {\n    if (this.overlays) {\n      this.close.next(closeEvent);\n      this.overlays.forEach((overlay, index) => {\n        overlay.detach();\n        overlay.dispose();\n      });\n    }\n    this.overlays = [];\n  }\n\n  public getLastAttachedOverlay(): OverlayRefWithContextMenu {\n    let overlay: OverlayRef = this.overlays[this.overlays.length - 1];\n    while (this.overlays.length > 1 && overlay && !overlay.hasAttached()) {\n      overlay.detach();\n      overlay.dispose();\n      this.overlays = this.overlays.slice(0, -1);\n      overlay = this.overlays[this.overlays.length - 1];\n    }\n    return overlay;\n  }\n\n  public destroyLeafMenu({ exceptRootMenu, event }: CloseLeafMenuEvent = {}): void {\n    if (this.isDestroyingLeafMenu) {\n      return;\n    }\n    this.isDestroyingLeafMenu = true;\n\n    setTimeout(() => {\n      const overlay = this.getLastAttachedOverlay();\n      if (this.overlays.length > 1 && overlay) {\n        overlay.detach();\n        overlay.dispose();\n      }\n      if (!exceptRootMenu && this.overlays.length > 0 && overlay) {\n        this.close.next({ eventType: 'cancel', event });\n        overlay.detach();\n        overlay.dispose();\n      }\n\n      const newLeaf = this.getLastAttachedOverlay();\n      if (newLeaf) {\n        newLeaf.contextMenu.isLeaf = true;\n      }\n\n      this.isDestroyingLeafMenu = false;\n    });\n  }\n\n  public destroySubMenus(contextMenu: ContextMenuContentComponent): void {\n    const overlay = contextMenu.overlay;\n    const index = this.overlays.indexOf(overlay);\n    this.overlays.slice(index + 1).forEach(subMenuOverlay => {\n      subMenuOverlay.detach();\n      subMenuOverlay.dispose();\n    });\n  }\n\n  public isLeafMenu(contextMenuContent: ContextMenuContentComponent): boolean {\n    const overlay = this.getLastAttachedOverlay();\n    return contextMenuContent.overlay === overlay;\n  }\n}\n"]}