contextMenuContent.component.js 31 KB

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