| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406 |
- /**
- * @fileoverview added by tsickle
- * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
- */
- import * as tslib_1 from "tslib";
- import { ActiveDescendantKeyManager } from '@angular/cdk/a11y';
- import { OverlayRef } from '@angular/cdk/overlay';
- import { ChangeDetectorRef, Component, ElementRef, EventEmitter, HostListener, Inject, Input, Optional, Output, QueryList, ViewChild, ViewChildren } from '@angular/core';
- import { Subscription } from 'rxjs';
- import { CONTEXT_MENU_OPTIONS } from './contextMenu.tokens';
- /**
- * @record
- */
- export function ILinkConfig() { }
- if (false) {
- /** @type {?} */
- ILinkConfig.prototype.click;
- /** @type {?|undefined} */
- ILinkConfig.prototype.enabled;
- /** @type {?} */
- ILinkConfig.prototype.html;
- }
- /** @type {?} */
- var ARROW_LEFT_KEYCODE = 37;
- var ContextMenuContentComponent = /** @class */ (function () {
- function ContextMenuContentComponent(changeDetector, elementRef, options) {
- this.changeDetector = changeDetector;
- this.elementRef = elementRef;
- this.options = options;
- this.menuItems = [];
- this.isLeaf = false;
- this.execute = new EventEmitter();
- this.openSubMenu = new EventEmitter();
- this.closeLeafMenu = new EventEmitter();
- this.closeAllMenus = new EventEmitter();
- this.autoFocus = false;
- this.useBootstrap4 = false;
- this.subscription = new Subscription();
- if (options) {
- this.autoFocus = options.autoFocus;
- this.useBootstrap4 = options.useBootstrap4;
- }
- }
- /**
- * @return {?}
- */
- ContextMenuContentComponent.prototype.ngOnInit = /**
- * @return {?}
- */
- function () {
- var _this = this;
- this.menuItems.forEach((/**
- * @param {?} menuItem
- * @return {?}
- */
- function (menuItem) {
- menuItem.currentItem = _this.item;
- _this.subscription.add(menuItem.execute.subscribe((/**
- * @param {?} event
- * @return {?}
- */
- function (event) {
- return _this.execute.emit(tslib_1.__assign({}, event, { menuItem: menuItem }));
- })));
- }));
- /** @type {?} */
- var queryList = new QueryList();
- queryList.reset(this.menuItems);
- this._keyManager = new ActiveDescendantKeyManager(queryList).withWrap();
- };
- /**
- * @return {?}
- */
- ContextMenuContentComponent.prototype.ngAfterViewInit = /**
- * @return {?}
- */
- function () {
- var _this = this;
- if (this.autoFocus) {
- setTimeout((/**
- * @return {?}
- */
- function () { return _this.focus(); }));
- }
- this.overlay.updatePosition();
- };
- /**
- * @return {?}
- */
- ContextMenuContentComponent.prototype.ngOnDestroy = /**
- * @return {?}
- */
- function () {
- this.subscription.unsubscribe();
- };
- /**
- * @return {?}
- */
- ContextMenuContentComponent.prototype.focus = /**
- * @return {?}
- */
- function () {
- if (this.autoFocus) {
- this.menuElement.nativeElement.focus();
- }
- };
- /**
- * @param {?} $event
- * @return {?}
- */
- ContextMenuContentComponent.prototype.stopEvent = /**
- * @param {?} $event
- * @return {?}
- */
- function ($event) {
- $event.stopPropagation();
- };
- /**
- * @param {?} menuItem
- * @return {?}
- */
- ContextMenuContentComponent.prototype.isMenuItemEnabled = /**
- * @param {?} menuItem
- * @return {?}
- */
- function (menuItem) {
- return this.evaluateIfFunction(menuItem && menuItem.enabled);
- };
- /**
- * @param {?} menuItem
- * @return {?}
- */
- ContextMenuContentComponent.prototype.isMenuItemVisible = /**
- * @param {?} menuItem
- * @return {?}
- */
- function (menuItem) {
- return this.evaluateIfFunction(menuItem && menuItem.visible);
- };
- /**
- * @param {?} value
- * @return {?}
- */
- ContextMenuContentComponent.prototype.evaluateIfFunction = /**
- * @param {?} value
- * @return {?}
- */
- function (value) {
- if (value instanceof Function) {
- return value(this.item);
- }
- return value;
- };
- /**
- * @param {?} link
- * @return {?}
- */
- ContextMenuContentComponent.prototype.isDisabled = /**
- * @param {?} link
- * @return {?}
- */
- function (link) {
- return link.enabled && !link.enabled(this.item);
- };
- /**
- * @param {?} event
- * @return {?}
- */
- ContextMenuContentComponent.prototype.onKeyEvent = /**
- * @param {?} event
- * @return {?}
- */
- function (event) {
- if (!this.isLeaf) {
- return;
- }
- this._keyManager.onKeydown(event);
- };
- /**
- * @param {?=} event
- * @return {?}
- */
- ContextMenuContentComponent.prototype.keyboardOpenSubMenu = /**
- * @param {?=} event
- * @return {?}
- */
- function (event) {
- if (!this.isLeaf) {
- return;
- }
- this.cancelEvent(event);
- /** @type {?} */
- var menuItem = this.menuItems[this._keyManager.activeItemIndex];
- if (menuItem) {
- this.onOpenSubMenu(menuItem);
- }
- };
- /**
- * @param {?=} event
- * @return {?}
- */
- ContextMenuContentComponent.prototype.keyboardMenuItemSelect = /**
- * @param {?=} event
- * @return {?}
- */
- function (event) {
- if (!this.isLeaf) {
- return;
- }
- this.cancelEvent(event);
- /** @type {?} */
- var menuItem = this.menuItems[this._keyManager.activeItemIndex];
- if (menuItem) {
- this.onMenuItemSelect(menuItem, event);
- }
- };
- /**
- * @param {?} event
- * @return {?}
- */
- ContextMenuContentComponent.prototype.onCloseLeafMenu = /**
- * @param {?} event
- * @return {?}
- */
- function (event) {
- if (!this.isLeaf) {
- return;
- }
- this.cancelEvent(event);
- this.closeLeafMenu.emit({
- exceptRootMenu: event.keyCode === ARROW_LEFT_KEYCODE,
- event: event
- });
- };
- /**
- * @param {?} event
- * @return {?}
- */
- ContextMenuContentComponent.prototype.closeMenu = /**
- * @param {?} event
- * @return {?}
- */
- function (event) {
- if (event.type === 'click' && event.button === 2) {
- return;
- }
- this.closeAllMenus.emit({ event: event });
- };
- /**
- * @param {?} menuItem
- * @param {?=} event
- * @return {?}
- */
- ContextMenuContentComponent.prototype.onOpenSubMenu = /**
- * @param {?} menuItem
- * @param {?=} event
- * @return {?}
- */
- function (menuItem, event) {
- /** @type {?} */
- var anchorElementRef = this.menuItemElements.toArray()[this._keyManager.activeItemIndex];
- /** @type {?} */
- var anchorElement = anchorElementRef && anchorElementRef.nativeElement;
- this.openSubMenu.emit({
- anchorElement: anchorElement,
- contextMenu: menuItem.subMenu,
- event: event,
- item: this.item,
- parentContextMenu: this
- });
- };
- /**
- * @param {?} menuItem
- * @param {?} event
- * @return {?}
- */
- ContextMenuContentComponent.prototype.onMenuItemSelect = /**
- * @param {?} menuItem
- * @param {?} event
- * @return {?}
- */
- function (menuItem, event) {
- event.preventDefault();
- event.stopPropagation();
- this.onOpenSubMenu(menuItem, event);
- if (!menuItem.subMenu) {
- menuItem.triggerExecute(this.item, event);
- }
- };
- /**
- * @private
- * @param {?} event
- * @return {?}
- */
- ContextMenuContentComponent.prototype.cancelEvent = /**
- * @private
- * @param {?} event
- * @return {?}
- */
- function (event) {
- if (!event) {
- return;
- }
- /** @type {?} */
- var target = event.target;
- if (['INPUT', 'TEXTAREA', 'SELECT'].indexOf(target.tagName) > -1 ||
- target.isContentEditable) {
- return;
- }
- event.preventDefault();
- event.stopPropagation();
- };
- ContextMenuContentComponent.decorators = [
- { type: Component, args: [{
- selector: 'context-menu-content',
- 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 ",
- 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 "]
- }] }
- ];
- /** @nocollapse */
- ContextMenuContentComponent.ctorParameters = function () { return [
- { type: ChangeDetectorRef },
- { type: ElementRef },
- { type: undefined, decorators: [{ type: Optional }, { type: Inject, args: [CONTEXT_MENU_OPTIONS,] }] }
- ]; };
- ContextMenuContentComponent.propDecorators = {
- menuItems: [{ type: Input }],
- item: [{ type: Input }],
- event: [{ type: Input }],
- parentContextMenu: [{ type: Input }],
- menuClass: [{ type: Input }],
- overlay: [{ type: Input }],
- isLeaf: [{ type: Input }],
- execute: [{ type: Output }],
- openSubMenu: [{ type: Output }],
- closeLeafMenu: [{ type: Output }],
- closeAllMenus: [{ type: Output }],
- menuElement: [{ type: ViewChild, args: ['menu', { static: true },] }],
- menuItemElements: [{ type: ViewChildren, args: ['li',] }],
- onKeyEvent: [{ type: HostListener, args: ['window:keydown.ArrowDown', ['$event'],] }, { type: HostListener, args: ['window:keydown.ArrowUp', ['$event'],] }],
- keyboardOpenSubMenu: [{ type: HostListener, args: ['window:keydown.ArrowRight', ['$event'],] }],
- keyboardMenuItemSelect: [{ type: HostListener, args: ['window:keydown.Enter', ['$event'],] }, { type: HostListener, args: ['window:keydown.Space', ['$event'],] }],
- onCloseLeafMenu: [{ type: HostListener, args: ['window:keydown.Escape', ['$event'],] }, { type: HostListener, args: ['window:keydown.ArrowLeft', ['$event'],] }],
- closeMenu: [{ type: HostListener, args: ['document:click', ['$event'],] }, { type: HostListener, args: ['document:contextmenu', ['$event'],] }]
- };
- return ContextMenuContentComponent;
- }());
- export { ContextMenuContentComponent };
- if (false) {
- /** @type {?} */
- ContextMenuContentComponent.prototype.menuItems;
- /** @type {?} */
- ContextMenuContentComponent.prototype.item;
- /** @type {?} */
- ContextMenuContentComponent.prototype.event;
- /** @type {?} */
- ContextMenuContentComponent.prototype.parentContextMenu;
- /** @type {?} */
- ContextMenuContentComponent.prototype.menuClass;
- /** @type {?} */
- ContextMenuContentComponent.prototype.overlay;
- /** @type {?} */
- ContextMenuContentComponent.prototype.isLeaf;
- /** @type {?} */
- ContextMenuContentComponent.prototype.execute;
- /** @type {?} */
- ContextMenuContentComponent.prototype.openSubMenu;
- /** @type {?} */
- ContextMenuContentComponent.prototype.closeLeafMenu;
- /** @type {?} */
- ContextMenuContentComponent.prototype.closeAllMenus;
- /** @type {?} */
- ContextMenuContentComponent.prototype.menuElement;
- /** @type {?} */
- ContextMenuContentComponent.prototype.menuItemElements;
- /** @type {?} */
- ContextMenuContentComponent.prototype.autoFocus;
- /** @type {?} */
- ContextMenuContentComponent.prototype.useBootstrap4;
- /**
- * @type {?}
- * @private
- */
- ContextMenuContentComponent.prototype._keyManager;
- /**
- * @type {?}
- * @private
- */
- ContextMenuContentComponent.prototype.subscription;
- /**
- * @type {?}
- * @private
- */
- ContextMenuContentComponent.prototype.changeDetector;
- /**
- * @type {?}
- * @private
- */
- ContextMenuContentComponent.prototype.elementRef;
- /**
- * @type {?}
- * @private
- */
- ContextMenuContentComponent.prototype.options;
- }
- //# 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"]}
|