contextMenuContent.component.js 33 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406
  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 { ActiveDescendantKeyManager } from '@angular/cdk/a11y';
  7. import { OverlayRef } from '@angular/cdk/overlay';
  8. import { ChangeDetectorRef, Component, ElementRef, EventEmitter, HostListener, Inject, Input, Optional, Output, QueryList, ViewChild, ViewChildren } from '@angular/core';
  9. import { Subscription } from 'rxjs';
  10. import { CONTEXT_MENU_OPTIONS } from './contextMenu.tokens';
  11. /**
  12. * @record
  13. */
  14. export function ILinkConfig() { }
  15. if (false) {
  16. /** @type {?} */
  17. ILinkConfig.prototype.click;
  18. /** @type {?|undefined} */
  19. ILinkConfig.prototype.enabled;
  20. /** @type {?} */
  21. ILinkConfig.prototype.html;
  22. }
  23. /** @type {?} */
  24. var ARROW_LEFT_KEYCODE = 37;
  25. var ContextMenuContentComponent = /** @class */ (function () {
  26. function ContextMenuContentComponent(changeDetector, elementRef, options) {
  27. this.changeDetector = changeDetector;
  28. this.elementRef = elementRef;
  29. this.options = options;
  30. this.menuItems = [];
  31. this.isLeaf = false;
  32. this.execute = new EventEmitter();
  33. this.openSubMenu = new EventEmitter();
  34. this.closeLeafMenu = new EventEmitter();
  35. this.closeAllMenus = new EventEmitter();
  36. this.autoFocus = false;
  37. this.useBootstrap4 = false;
  38. this.subscription = new Subscription();
  39. if (options) {
  40. this.autoFocus = options.autoFocus;
  41. this.useBootstrap4 = options.useBootstrap4;
  42. }
  43. }
  44. /**
  45. * @return {?}
  46. */
  47. ContextMenuContentComponent.prototype.ngOnInit = /**
  48. * @return {?}
  49. */
  50. function () {
  51. var _this = this;
  52. this.menuItems.forEach((/**
  53. * @param {?} menuItem
  54. * @return {?}
  55. */
  56. function (menuItem) {
  57. menuItem.currentItem = _this.item;
  58. _this.subscription.add(menuItem.execute.subscribe((/**
  59. * @param {?} event
  60. * @return {?}
  61. */
  62. function (event) {
  63. return _this.execute.emit(tslib_1.__assign({}, event, { menuItem: menuItem }));
  64. })));
  65. }));
  66. /** @type {?} */
  67. var queryList = new QueryList();
  68. queryList.reset(this.menuItems);
  69. this._keyManager = new ActiveDescendantKeyManager(queryList).withWrap();
  70. };
  71. /**
  72. * @return {?}
  73. */
  74. ContextMenuContentComponent.prototype.ngAfterViewInit = /**
  75. * @return {?}
  76. */
  77. function () {
  78. var _this = this;
  79. if (this.autoFocus) {
  80. setTimeout((/**
  81. * @return {?}
  82. */
  83. function () { return _this.focus(); }));
  84. }
  85. this.overlay.updatePosition();
  86. };
  87. /**
  88. * @return {?}
  89. */
  90. ContextMenuContentComponent.prototype.ngOnDestroy = /**
  91. * @return {?}
  92. */
  93. function () {
  94. this.subscription.unsubscribe();
  95. };
  96. /**
  97. * @return {?}
  98. */
  99. ContextMenuContentComponent.prototype.focus = /**
  100. * @return {?}
  101. */
  102. function () {
  103. if (this.autoFocus) {
  104. this.menuElement.nativeElement.focus();
  105. }
  106. };
  107. /**
  108. * @param {?} $event
  109. * @return {?}
  110. */
  111. ContextMenuContentComponent.prototype.stopEvent = /**
  112. * @param {?} $event
  113. * @return {?}
  114. */
  115. function ($event) {
  116. $event.stopPropagation();
  117. };
  118. /**
  119. * @param {?} menuItem
  120. * @return {?}
  121. */
  122. ContextMenuContentComponent.prototype.isMenuItemEnabled = /**
  123. * @param {?} menuItem
  124. * @return {?}
  125. */
  126. function (menuItem) {
  127. return this.evaluateIfFunction(menuItem && menuItem.enabled);
  128. };
  129. /**
  130. * @param {?} menuItem
  131. * @return {?}
  132. */
  133. ContextMenuContentComponent.prototype.isMenuItemVisible = /**
  134. * @param {?} menuItem
  135. * @return {?}
  136. */
  137. function (menuItem) {
  138. return this.evaluateIfFunction(menuItem && menuItem.visible);
  139. };
  140. /**
  141. * @param {?} value
  142. * @return {?}
  143. */
  144. ContextMenuContentComponent.prototype.evaluateIfFunction = /**
  145. * @param {?} value
  146. * @return {?}
  147. */
  148. function (value) {
  149. if (value instanceof Function) {
  150. return value(this.item);
  151. }
  152. return value;
  153. };
  154. /**
  155. * @param {?} link
  156. * @return {?}
  157. */
  158. ContextMenuContentComponent.prototype.isDisabled = /**
  159. * @param {?} link
  160. * @return {?}
  161. */
  162. function (link) {
  163. return link.enabled && !link.enabled(this.item);
  164. };
  165. /**
  166. * @param {?} event
  167. * @return {?}
  168. */
  169. ContextMenuContentComponent.prototype.onKeyEvent = /**
  170. * @param {?} event
  171. * @return {?}
  172. */
  173. function (event) {
  174. if (!this.isLeaf) {
  175. return;
  176. }
  177. this._keyManager.onKeydown(event);
  178. };
  179. /**
  180. * @param {?=} event
  181. * @return {?}
  182. */
  183. ContextMenuContentComponent.prototype.keyboardOpenSubMenu = /**
  184. * @param {?=} event
  185. * @return {?}
  186. */
  187. function (event) {
  188. if (!this.isLeaf) {
  189. return;
  190. }
  191. this.cancelEvent(event);
  192. /** @type {?} */
  193. var menuItem = this.menuItems[this._keyManager.activeItemIndex];
  194. if (menuItem) {
  195. this.onOpenSubMenu(menuItem);
  196. }
  197. };
  198. /**
  199. * @param {?=} event
  200. * @return {?}
  201. */
  202. ContextMenuContentComponent.prototype.keyboardMenuItemSelect = /**
  203. * @param {?=} event
  204. * @return {?}
  205. */
  206. function (event) {
  207. if (!this.isLeaf) {
  208. return;
  209. }
  210. this.cancelEvent(event);
  211. /** @type {?} */
  212. var menuItem = this.menuItems[this._keyManager.activeItemIndex];
  213. if (menuItem) {
  214. this.onMenuItemSelect(menuItem, event);
  215. }
  216. };
  217. /**
  218. * @param {?} event
  219. * @return {?}
  220. */
  221. ContextMenuContentComponent.prototype.onCloseLeafMenu = /**
  222. * @param {?} event
  223. * @return {?}
  224. */
  225. function (event) {
  226. if (!this.isLeaf) {
  227. return;
  228. }
  229. this.cancelEvent(event);
  230. this.closeLeafMenu.emit({
  231. exceptRootMenu: event.keyCode === ARROW_LEFT_KEYCODE,
  232. event: event
  233. });
  234. };
  235. /**
  236. * @param {?} event
  237. * @return {?}
  238. */
  239. ContextMenuContentComponent.prototype.closeMenu = /**
  240. * @param {?} event
  241. * @return {?}
  242. */
  243. function (event) {
  244. if (event.type === 'click' && event.button === 2) {
  245. return;
  246. }
  247. this.closeAllMenus.emit({ event: event });
  248. };
  249. /**
  250. * @param {?} menuItem
  251. * @param {?=} event
  252. * @return {?}
  253. */
  254. ContextMenuContentComponent.prototype.onOpenSubMenu = /**
  255. * @param {?} menuItem
  256. * @param {?=} event
  257. * @return {?}
  258. */
  259. function (menuItem, event) {
  260. /** @type {?} */
  261. var anchorElementRef = this.menuItemElements.toArray()[this._keyManager.activeItemIndex];
  262. /** @type {?} */
  263. var anchorElement = anchorElementRef && anchorElementRef.nativeElement;
  264. this.openSubMenu.emit({
  265. anchorElement: anchorElement,
  266. contextMenu: menuItem.subMenu,
  267. event: event,
  268. item: this.item,
  269. parentContextMenu: this
  270. });
  271. };
  272. /**
  273. * @param {?} menuItem
  274. * @param {?} event
  275. * @return {?}
  276. */
  277. ContextMenuContentComponent.prototype.onMenuItemSelect = /**
  278. * @param {?} menuItem
  279. * @param {?} event
  280. * @return {?}
  281. */
  282. function (menuItem, event) {
  283. event.preventDefault();
  284. event.stopPropagation();
  285. this.onOpenSubMenu(menuItem, event);
  286. if (!menuItem.subMenu) {
  287. menuItem.triggerExecute(this.item, event);
  288. }
  289. };
  290. /**
  291. * @private
  292. * @param {?} event
  293. * @return {?}
  294. */
  295. ContextMenuContentComponent.prototype.cancelEvent = /**
  296. * @private
  297. * @param {?} event
  298. * @return {?}
  299. */
  300. function (event) {
  301. if (!event) {
  302. return;
  303. }
  304. /** @type {?} */
  305. var target = event.target;
  306. if (['INPUT', 'TEXTAREA', 'SELECT'].indexOf(target.tagName) > -1 ||
  307. target.isContentEditable) {
  308. return;
  309. }
  310. event.preventDefault();
  311. event.stopPropagation();
  312. };
  313. ContextMenuContentComponent.decorators = [
  314. { type: Component, args: [{
  315. selector: 'context-menu-content',
  316. template: "\n <div\n class=\"dropdown open show ngx-contextmenu\"\n [ngClass]=\"menuClass\"\n tabindex=\"0\"\n >\n <ul\n #menu\n class=\"dropdown-menu show\"\n style=\"position: static; float: none;\"\n tabindex=\"0\"\n >\n <li\n #li\n *ngFor=\"let menuItem of menuItems; let i = index\"\n [class.disabled]=\"!isMenuItemEnabled(menuItem)\"\n [class.divider]=\"menuItem.divider\"\n [class.dropdown-divider]=\"useBootstrap4 && menuItem.divider\"\n [class.active]=\"menuItem.isActive && isMenuItemEnabled(menuItem)\"\n [attr.role]=\"menuItem.divider ? 'separator' : undefined\"\n >\n <a\n *ngIf=\"!menuItem.divider && !menuItem.passive\"\n href\n [class.dropdown-item]=\"useBootstrap4\"\n [class.active]=\"menuItem.isActive && isMenuItemEnabled(menuItem)\"\n [class.disabled]=\"useBootstrap4 && !isMenuItemEnabled(menuItem)\"\n [class.hasSubMenu]=\"!!menuItem.subMenu\"\n (click)=\"onMenuItemSelect(menuItem, $event)\"\n (mouseenter)=\"onOpenSubMenu(menuItem, $event)\"\n >\n <ng-template\n [ngTemplateOutlet]=\"menuItem.template\"\n [ngTemplateOutletContext]=\"{ $implicit: item }\"\n ></ng-template>\n </a>\n\n <span\n (click)=\"stopEvent($event)\"\n (contextmenu)=\"stopEvent($event)\"\n class=\"passive\"\n *ngIf=\"!menuItem.divider && menuItem.passive\"\n [class.dropdown-item]=\"useBootstrap4\"\n [class.disabled]=\"useBootstrap4 && !isMenuItemEnabled(menuItem)\"\n >\n <ng-template\n [ngTemplateOutlet]=\"menuItem.template\"\n [ngTemplateOutletContext]=\"{ $implicit: item }\"\n ></ng-template>\n </span>\n </li>\n </ul>\n </div>\n ",
  317. styles: ["\n .passive {\n display: block;\n padding: 3px 20px;\n clear: both;\n font-weight: normal;\n line-height: @line-height-base;\n white-space: nowrap;\n }\n .hasSubMenu:before {\n content: '\u25B6';\n float: right;\n }\n "]
  318. }] }
  319. ];
  320. /** @nocollapse */
  321. ContextMenuContentComponent.ctorParameters = function () { return [
  322. { type: ChangeDetectorRef },
  323. { type: ElementRef },
  324. { type: undefined, decorators: [{ type: Optional }, { type: Inject, args: [CONTEXT_MENU_OPTIONS,] }] }
  325. ]; };
  326. ContextMenuContentComponent.propDecorators = {
  327. menuItems: [{ type: Input }],
  328. item: [{ type: Input }],
  329. event: [{ type: Input }],
  330. parentContextMenu: [{ type: Input }],
  331. menuClass: [{ type: Input }],
  332. overlay: [{ type: Input }],
  333. isLeaf: [{ type: Input }],
  334. execute: [{ type: Output }],
  335. openSubMenu: [{ type: Output }],
  336. closeLeafMenu: [{ type: Output }],
  337. closeAllMenus: [{ type: Output }],
  338. menuElement: [{ type: ViewChild, args: ['menu', { static: true },] }],
  339. menuItemElements: [{ type: ViewChildren, args: ['li',] }],
  340. onKeyEvent: [{ type: HostListener, args: ['window:keydown.ArrowDown', ['$event'],] }, { type: HostListener, args: ['window:keydown.ArrowUp', ['$event'],] }],
  341. keyboardOpenSubMenu: [{ type: HostListener, args: ['window:keydown.ArrowRight', ['$event'],] }],
  342. keyboardMenuItemSelect: [{ type: HostListener, args: ['window:keydown.Enter', ['$event'],] }, { type: HostListener, args: ['window:keydown.Space', ['$event'],] }],
  343. onCloseLeafMenu: [{ type: HostListener, args: ['window:keydown.Escape', ['$event'],] }, { type: HostListener, args: ['window:keydown.ArrowLeft', ['$event'],] }],
  344. closeMenu: [{ type: HostListener, args: ['document:click', ['$event'],] }, { type: HostListener, args: ['document:contextmenu', ['$event'],] }]
  345. };
  346. return ContextMenuContentComponent;
  347. }());
  348. export { ContextMenuContentComponent };
  349. if (false) {
  350. /** @type {?} */
  351. ContextMenuContentComponent.prototype.menuItems;
  352. /** @type {?} */
  353. ContextMenuContentComponent.prototype.item;
  354. /** @type {?} */
  355. ContextMenuContentComponent.prototype.event;
  356. /** @type {?} */
  357. ContextMenuContentComponent.prototype.parentContextMenu;
  358. /** @type {?} */
  359. ContextMenuContentComponent.prototype.menuClass;
  360. /** @type {?} */
  361. ContextMenuContentComponent.prototype.overlay;
  362. /** @type {?} */
  363. ContextMenuContentComponent.prototype.isLeaf;
  364. /** @type {?} */
  365. ContextMenuContentComponent.prototype.execute;
  366. /** @type {?} */
  367. ContextMenuContentComponent.prototype.openSubMenu;
  368. /** @type {?} */
  369. ContextMenuContentComponent.prototype.closeLeafMenu;
  370. /** @type {?} */
  371. ContextMenuContentComponent.prototype.closeAllMenus;
  372. /** @type {?} */
  373. ContextMenuContentComponent.prototype.menuElement;
  374. /** @type {?} */
  375. ContextMenuContentComponent.prototype.menuItemElements;
  376. /** @type {?} */
  377. ContextMenuContentComponent.prototype.autoFocus;
  378. /** @type {?} */
  379. ContextMenuContentComponent.prototype.useBootstrap4;
  380. /**
  381. * @type {?}
  382. * @private
  383. */
  384. ContextMenuContentComponent.prototype._keyManager;
  385. /**
  386. * @type {?}
  387. * @private
  388. */
  389. ContextMenuContentComponent.prototype.subscription;
  390. /**
  391. * @type {?}
  392. * @private
  393. */
  394. ContextMenuContentComponent.prototype.changeDetector;
  395. /**
  396. * @type {?}
  397. * @private
  398. */
  399. ContextMenuContentComponent.prototype.elementRef;
  400. /**
  401. * @type {?}
  402. * @private
  403. */
  404. ContextMenuContentComponent.prototype.options;
  405. }
  406. //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"contextMenuContent.component.js","sourceRoot":"ng://ngx-contextmenu/","sources":["lib/contextMenuContent.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ActiveDescendantKeyManager } from '@angular/cdk/a11y';\nimport { OverlayRef } from '@angular/cdk/overlay';\nimport {\n  AfterViewInit,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  EventEmitter,\n  HostListener,\n  Inject,\n  Input,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n  QueryList,\n  ViewChild,\n  ViewChildren\n} from '@angular/core';\nimport { Subscription } from 'rxjs';\nimport { ContextMenuItemDirective } from './contextMenu.item.directive';\nimport { IContextMenuOptions } from './contextMenu.options';\nimport {\n  CloseLeafMenuEvent,\n  IContextMenuClickEvent\n} from './contextMenu.service';\nimport { CONTEXT_MENU_OPTIONS } from './contextMenu.tokens';\n\nexport interface ILinkConfig {\n  click: (item: any, $event?: MouseEvent) => void;\n  enabled?: (item: any) => boolean;\n  html: (item: any) => string;\n}\n\nconst ARROW_LEFT_KEYCODE = 37;\n\n@Component({\n  selector: 'context-menu-content',\n  styles: [\n    `\n      .passive {\n        display: block;\n        padding: 3px 20px;\n        clear: both;\n        font-weight: normal;\n        line-height: @line-height-base;\n        white-space: nowrap;\n      }\n      .hasSubMenu:before {\n        content: '\\u25B6';\n        float: right;\n      }\n    `\n  ],\n  template: `\n    <div\n      class=\"dropdown open show ngx-contextmenu\"\n      [ngClass]=\"menuClass\"\n      tabindex=\"0\"\n    >\n      <ul\n        #menu\n        class=\"dropdown-menu show\"\n        style=\"position: static; float: none;\"\n        tabindex=\"0\"\n      >\n        <li\n          #li\n          *ngFor=\"let menuItem of menuItems; let i = index\"\n          [class.disabled]=\"!isMenuItemEnabled(menuItem)\"\n          [class.divider]=\"menuItem.divider\"\n          [class.dropdown-divider]=\"useBootstrap4 && menuItem.divider\"\n          [class.active]=\"menuItem.isActive && isMenuItemEnabled(menuItem)\"\n          [attr.role]=\"menuItem.divider ? 'separator' : undefined\"\n        >\n          <a\n            *ngIf=\"!menuItem.divider && !menuItem.passive\"\n            href\n            [class.dropdown-item]=\"useBootstrap4\"\n            [class.active]=\"menuItem.isActive && isMenuItemEnabled(menuItem)\"\n            [class.disabled]=\"useBootstrap4 && !isMenuItemEnabled(menuItem)\"\n            [class.hasSubMenu]=\"!!menuItem.subMenu\"\n            (click)=\"onMenuItemSelect(menuItem, $event)\"\n            (mouseenter)=\"onOpenSubMenu(menuItem, $event)\"\n          >\n            <ng-template\n              [ngTemplateOutlet]=\"menuItem.template\"\n              [ngTemplateOutletContext]=\"{ $implicit: item }\"\n            ></ng-template>\n          </a>\n\n          <span\n            (click)=\"stopEvent($event)\"\n            (contextmenu)=\"stopEvent($event)\"\n            class=\"passive\"\n            *ngIf=\"!menuItem.divider && menuItem.passive\"\n            [class.dropdown-item]=\"useBootstrap4\"\n            [class.disabled]=\"useBootstrap4 && !isMenuItemEnabled(menuItem)\"\n          >\n            <ng-template\n              [ngTemplateOutlet]=\"menuItem.template\"\n              [ngTemplateOutletContext]=\"{ $implicit: item }\"\n            ></ng-template>\n          </span>\n        </li>\n      </ul>\n    </div>\n  `\n})\nexport class ContextMenuContentComponent\n  implements OnInit, OnDestroy, AfterViewInit {\n  @Input() public menuItems: ContextMenuItemDirective[] = [];\n  @Input() public item: any;\n  @Input() public event: MouseEvent | KeyboardEvent;\n  @Input() public parentContextMenu: ContextMenuContentComponent;\n  @Input() public menuClass: string;\n  @Input() public overlay: OverlayRef;\n  @Input() public isLeaf = false;\n  @Output() public execute: EventEmitter<{\n    event: MouseEvent | KeyboardEvent;\n    item: any;\n    menuItem: ContextMenuItemDirective;\n  }> = new EventEmitter();\n  @Output() public openSubMenu: EventEmitter<\n    IContextMenuClickEvent\n  > = new EventEmitter();\n  @Output() public closeLeafMenu: EventEmitter<\n    CloseLeafMenuEvent\n  > = new EventEmitter();\n  @Output() public closeAllMenus: EventEmitter<{\n    event: MouseEvent;\n  }> = new EventEmitter();\n  @ViewChild('menu', { static: true }) public menuElement: ElementRef;\n  @ViewChildren('li') public menuItemElements: QueryList<ElementRef>;\n\n  public autoFocus = false;\n  public useBootstrap4 = false;\n  private _keyManager: ActiveDescendantKeyManager<ContextMenuItemDirective>;\n  private subscription: Subscription = new Subscription();\n  constructor(\n    private changeDetector: ChangeDetectorRef,\n    private elementRef: ElementRef,\n    @Optional()\n    @Inject(CONTEXT_MENU_OPTIONS)\n    private options: IContextMenuOptions\n  ) {\n    if (options) {\n      this.autoFocus = options.autoFocus;\n      this.useBootstrap4 = options.useBootstrap4;\n    }\n  }\n\n  ngOnInit(): void {\n    this.menuItems.forEach(menuItem => {\n      menuItem.currentItem = this.item;\n      this.subscription.add(\n        menuItem.execute.subscribe(event =>\n          this.execute.emit({ ...event, menuItem })\n        )\n      );\n    });\n    const queryList = new QueryList<ContextMenuItemDirective>();\n    queryList.reset(this.menuItems);\n    this._keyManager = new ActiveDescendantKeyManager<ContextMenuItemDirective>(\n      queryList\n    ).withWrap();\n  }\n\n  ngAfterViewInit() {\n    if (this.autoFocus) {\n      setTimeout(() => this.focus());\n    }\n    this.overlay.updatePosition();\n  }\n\n  ngOnDestroy() {\n    this.subscription.unsubscribe();\n  }\n\n  focus(): void {\n    if (this.autoFocus) {\n      this.menuElement.nativeElement.focus();\n    }\n  }\n\n  stopEvent($event: MouseEvent) {\n    $event.stopPropagation();\n  }\n\n  public isMenuItemEnabled(menuItem: ContextMenuItemDirective): boolean {\n    return this.evaluateIfFunction(menuItem && menuItem.enabled);\n  }\n\n  public isMenuItemVisible(menuItem: ContextMenuItemDirective): boolean {\n    return this.evaluateIfFunction(menuItem && menuItem.visible);\n  }\n\n  public evaluateIfFunction(value: any): any {\n    if (value instanceof Function) {\n      return value(this.item);\n    }\n    return value;\n  }\n\n  public isDisabled(link: ILinkConfig): boolean {\n    return link.enabled && !link.enabled(this.item);\n  }\n\n  @HostListener('window:keydown.ArrowDown', ['$event'])\n  @HostListener('window:keydown.ArrowUp', ['$event'])\n  public onKeyEvent(event: KeyboardEvent): void {\n    if (!this.isLeaf) {\n      return;\n    }\n    this._keyManager.onKeydown(event);\n  }\n\n  @HostListener('window:keydown.ArrowRight', ['$event'])\n  public keyboardOpenSubMenu(event?: KeyboardEvent): void {\n    if (!this.isLeaf) {\n      return;\n    }\n    this.cancelEvent(event);\n    const menuItem = this.menuItems[this._keyManager.activeItemIndex];\n    if (menuItem) {\n      this.onOpenSubMenu(menuItem);\n    }\n  }\n\n  @HostListener('window:keydown.Enter', ['$event'])\n  @HostListener('window:keydown.Space', ['$event'])\n  public keyboardMenuItemSelect(event?: KeyboardEvent): void {\n    if (!this.isLeaf) {\n      return;\n    }\n    this.cancelEvent(event);\n    const menuItem = this.menuItems[this._keyManager.activeItemIndex];\n    if (menuItem) {\n      this.onMenuItemSelect(menuItem, event);\n    }\n  }\n\n  @HostListener('window:keydown.Escape', ['$event'])\n  @HostListener('window:keydown.ArrowLeft', ['$event'])\n  public onCloseLeafMenu(event: KeyboardEvent): void {\n    if (!this.isLeaf) {\n      return;\n    }\n    this.cancelEvent(event);\n    this.closeLeafMenu.emit({\n      exceptRootMenu: event.keyCode === ARROW_LEFT_KEYCODE,\n      event\n    });\n  }\n\n  @HostListener('document:click', ['$event'])\n  @HostListener('document:contextmenu', ['$event'])\n  public closeMenu(event: MouseEvent): void {\n    if (event.type === 'click' && event.button === 2) {\n      return;\n    }\n    this.closeAllMenus.emit({ event });\n  }\n\n  public onOpenSubMenu(\n    menuItem: ContextMenuItemDirective,\n    event?: MouseEvent | KeyboardEvent\n  ): void {\n    const anchorElementRef = this.menuItemElements.toArray()[\n      this._keyManager.activeItemIndex\n    ];\n    const anchorElement = anchorElementRef && anchorElementRef.nativeElement;\n    this.openSubMenu.emit({\n      anchorElement,\n      contextMenu: menuItem.subMenu,\n      event,\n      item: this.item,\n      parentContextMenu: this\n    });\n  }\n\n  public onMenuItemSelect(\n    menuItem: ContextMenuItemDirective,\n    event: MouseEvent | KeyboardEvent\n  ): void {\n    event.preventDefault();\n    event.stopPropagation();\n    this.onOpenSubMenu(menuItem, event);\n    if (!menuItem.subMenu) {\n      menuItem.triggerExecute(this.item, event);\n    }\n  }\n\n  private cancelEvent(event): void {\n    if (!event) {\n      return;\n    }\n\n    const target: HTMLElement = event.target;\n    if (\n      ['INPUT', 'TEXTAREA', 'SELECT'].indexOf(target.tagName) > -1 ||\n      target.isContentEditable\n    ) {\n      return;\n    }\n\n    event.preventDefault();\n    event.stopPropagation();\n  }\n}\n"]}