contextMenu.component.js 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221
  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 { ChangeDetectorRef, Component, ContentChildren, ElementRef, EventEmitter, Inject, Input, Optional, Output, QueryList, ViewChild, ViewEncapsulation, } from '@angular/core';
  7. import { Subscription } from 'rxjs';
  8. import { first } from 'rxjs/operators';
  9. import { ContextMenuItemDirective } from './contextMenu.item.directive';
  10. import { ContextMenuService } from './contextMenu.service';
  11. import { CONTEXT_MENU_OPTIONS } from './contextMenu.tokens';
  12. /**
  13. * @record
  14. */
  15. export function ILinkConfig() { }
  16. if (false) {
  17. /** @type {?} */
  18. ILinkConfig.prototype.click;
  19. /** @type {?|undefined} */
  20. ILinkConfig.prototype.enabled;
  21. /** @type {?} */
  22. ILinkConfig.prototype.html;
  23. }
  24. /**
  25. * @record
  26. */
  27. export function MouseLocation() { }
  28. if (false) {
  29. /** @type {?|undefined} */
  30. MouseLocation.prototype.left;
  31. /** @type {?|undefined} */
  32. MouseLocation.prototype.marginLeft;
  33. /** @type {?|undefined} */
  34. MouseLocation.prototype.marginTop;
  35. /** @type {?|undefined} */
  36. MouseLocation.prototype.top;
  37. }
  38. var ContextMenuComponent = /** @class */ (function () {
  39. function ContextMenuComponent(_contextMenuService, changeDetector, elementRef, options) {
  40. var _this = this;
  41. this._contextMenuService = _contextMenuService;
  42. this.changeDetector = changeDetector;
  43. this.elementRef = elementRef;
  44. this.options = options;
  45. this.menuClass = "";
  46. this.autoFocus = false;
  47. this.useBootstrap4 = false;
  48. this.disabled = false;
  49. this.close = new EventEmitter();
  50. this.open = new EventEmitter();
  51. this.visibleMenuItems = [];
  52. this.links = [];
  53. this.subscription = new Subscription();
  54. if (options) {
  55. this.autoFocus = options.autoFocus;
  56. this.useBootstrap4 = options.useBootstrap4;
  57. }
  58. this.subscription.add(_contextMenuService.show.subscribe((/**
  59. * @param {?} menuEvent
  60. * @return {?}
  61. */
  62. function (menuEvent) {
  63. _this.onMenuEvent(menuEvent);
  64. })));
  65. }
  66. /**
  67. * @return {?}
  68. */
  69. ContextMenuComponent.prototype.ngOnDestroy = /**
  70. * @return {?}
  71. */
  72. function () {
  73. this.subscription.unsubscribe();
  74. };
  75. /**
  76. * @param {?} menuEvent
  77. * @return {?}
  78. */
  79. ContextMenuComponent.prototype.onMenuEvent = /**
  80. * @param {?} menuEvent
  81. * @return {?}
  82. */
  83. function (menuEvent) {
  84. var _this = this;
  85. if (this.disabled) {
  86. return;
  87. }
  88. var contextMenu = menuEvent.contextMenu, event = menuEvent.event, item = menuEvent.item;
  89. if (contextMenu && contextMenu !== this) {
  90. return;
  91. }
  92. this.event = event;
  93. this.item = item;
  94. this.setVisibleMenuItems();
  95. this._contextMenuService.openContextMenu(tslib_1.__assign({}, menuEvent, { menuItems: this.visibleMenuItems, menuClass: this.menuClass }));
  96. this._contextMenuService.close.asObservable().pipe(first()).subscribe((/**
  97. * @param {?} closeEvent
  98. * @return {?}
  99. */
  100. function (closeEvent) { return _this.close.emit(closeEvent); }));
  101. this.open.next(menuEvent);
  102. };
  103. /**
  104. * @param {?} menuItem
  105. * @return {?}
  106. */
  107. ContextMenuComponent.prototype.isMenuItemVisible = /**
  108. * @param {?} menuItem
  109. * @return {?}
  110. */
  111. function (menuItem) {
  112. return this.evaluateIfFunction(menuItem.visible);
  113. };
  114. /**
  115. * @return {?}
  116. */
  117. ContextMenuComponent.prototype.setVisibleMenuItems = /**
  118. * @return {?}
  119. */
  120. function () {
  121. var _this = this;
  122. this.visibleMenuItems = this.menuItems.filter((/**
  123. * @param {?} menuItem
  124. * @return {?}
  125. */
  126. function (menuItem) { return _this.isMenuItemVisible(menuItem); }));
  127. };
  128. /**
  129. * @param {?} value
  130. * @return {?}
  131. */
  132. ContextMenuComponent.prototype.evaluateIfFunction = /**
  133. * @param {?} value
  134. * @return {?}
  135. */
  136. function (value) {
  137. if (value instanceof Function) {
  138. return value(this.item);
  139. }
  140. return value;
  141. };
  142. ContextMenuComponent.decorators = [
  143. { type: Component, args: [{
  144. encapsulation: ViewEncapsulation.None,
  145. selector: 'context-menu',
  146. template: " ",
  147. styles: ["\n .cdk-overlay-container {\n position: fixed;\n z-index: 1000;\n pointer-events: none;\n top: 0;\n left: 0;\n width: 100%;\n height: 100%;\n }\n .ngx-contextmenu.cdk-overlay-pane {\n position: absolute;\n pointer-events: auto;\n box-sizing: border-box;\n }\n "]
  148. }] }
  149. ];
  150. /** @nocollapse */
  151. ContextMenuComponent.ctorParameters = function () { return [
  152. { type: ContextMenuService },
  153. { type: ChangeDetectorRef },
  154. { type: ElementRef },
  155. { type: undefined, decorators: [{ type: Optional }, { type: Inject, args: [CONTEXT_MENU_OPTIONS,] }] }
  156. ]; };
  157. ContextMenuComponent.propDecorators = {
  158. menuClass: [{ type: Input }],
  159. autoFocus: [{ type: Input }],
  160. useBootstrap4: [{ type: Input }],
  161. disabled: [{ type: Input }],
  162. close: [{ type: Output }],
  163. open: [{ type: Output }],
  164. menuItems: [{ type: ContentChildren, args: [ContextMenuItemDirective,] }],
  165. menuElement: [{ type: ViewChild, args: ['menu', { static: false },] }]
  166. };
  167. return ContextMenuComponent;
  168. }());
  169. export { ContextMenuComponent };
  170. if (false) {
  171. /** @type {?} */
  172. ContextMenuComponent.prototype.menuClass;
  173. /** @type {?} */
  174. ContextMenuComponent.prototype.autoFocus;
  175. /** @type {?} */
  176. ContextMenuComponent.prototype.useBootstrap4;
  177. /** @type {?} */
  178. ContextMenuComponent.prototype.disabled;
  179. /** @type {?} */
  180. ContextMenuComponent.prototype.close;
  181. /** @type {?} */
  182. ContextMenuComponent.prototype.open;
  183. /** @type {?} */
  184. ContextMenuComponent.prototype.menuItems;
  185. /** @type {?} */
  186. ContextMenuComponent.prototype.menuElement;
  187. /** @type {?} */
  188. ContextMenuComponent.prototype.visibleMenuItems;
  189. /** @type {?} */
  190. ContextMenuComponent.prototype.links;
  191. /** @type {?} */
  192. ContextMenuComponent.prototype.item;
  193. /** @type {?} */
  194. ContextMenuComponent.prototype.event;
  195. /**
  196. * @type {?}
  197. * @private
  198. */
  199. ContextMenuComponent.prototype.subscription;
  200. /**
  201. * @type {?}
  202. * @private
  203. */
  204. ContextMenuComponent.prototype._contextMenuService;
  205. /**
  206. * @type {?}
  207. * @private
  208. */
  209. ContextMenuComponent.prototype.changeDetector;
  210. /**
  211. * @type {?}
  212. * @private
  213. */
  214. ContextMenuComponent.prototype.elementRef;
  215. /**
  216. * @type {?}
  217. * @private
  218. */
  219. ContextMenuComponent.prototype.options;
  220. }
  221. //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"contextMenu.component.js","sourceRoot":"ng://ngx-contextmenu/","sources":["lib/contextMenu.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectorRef,\n    Component,\n    ContentChildren,\n    ElementRef,\n    EventEmitter,\n    HostListener,\n    Inject,\n    Input,\n    OnDestroy,\n    Optional,\n    Output,\n    QueryList,\n    ViewChild,\n    ViewEncapsulation,\n} from '@angular/core';\nimport { Subscription } from 'rxjs';\nimport { first } from 'rxjs/operators';\n\nimport { ContextMenuItemDirective } from './contextMenu.item.directive';\nimport { IContextMenuOptions } from './contextMenu.options';\nimport { ContextMenuService, IContextMenuClickEvent, CloseContextMenuEvent } 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}\nexport interface MouseLocation {\n  left?: string;\n  marginLeft?: string;\n  marginTop?: string;\n  top?: string;\n}\n\n@Component({\n  encapsulation: ViewEncapsulation.None,\n  selector: 'context-menu',\n  styles: [`\n    .cdk-overlay-container {\n      position: fixed;\n      z-index: 1000;\n      pointer-events: none;\n      top: 0;\n      left: 0;\n      width: 100%;\n      height: 100%;\n    }\n    .ngx-contextmenu.cdk-overlay-pane {\n      position: absolute;\n      pointer-events: auto;\n      box-sizing: border-box;\n    }\n  `],\n  template: ` `,\n})\nexport class ContextMenuComponent implements OnDestroy {\n  @Input() public menuClass = \"\";\n  @Input() public autoFocus = false;\n  @Input() public useBootstrap4 = false;\n  @Input() public disabled = false;\n  @Output() public close: EventEmitter<CloseContextMenuEvent> = new EventEmitter();\n  @Output() public open: EventEmitter<IContextMenuClickEvent> = new EventEmitter();\n  @ContentChildren(ContextMenuItemDirective) public menuItems: QueryList<ContextMenuItemDirective>;\n  @ViewChild('menu', { static: false }) public menuElement: ElementRef;\n  public visibleMenuItems: ContextMenuItemDirective[] = [];\n\n  public links: ILinkConfig[] = [];\n  public item: any;\n  public event: MouseEvent | KeyboardEvent;\n  private subscription: Subscription = new Subscription();\n\n  constructor(\n    private _contextMenuService: ContextMenuService,\n    private changeDetector: ChangeDetectorRef,\n    private elementRef: ElementRef,\n    @Optional()\n    @Inject(CONTEXT_MENU_OPTIONS) private options: IContextMenuOptions,\n  ) {\n    if (options) {\n      this.autoFocus = options.autoFocus;\n      this.useBootstrap4 = options.useBootstrap4;\n    }\n    this.subscription.add(_contextMenuService.show.subscribe(menuEvent => {\n      this.onMenuEvent(menuEvent);\n    }));\n  }\n\n  public ngOnDestroy(): void {\n    this.subscription.unsubscribe();\n  }\n\n  public onMenuEvent(menuEvent: IContextMenuClickEvent): void {\n    if (this.disabled) {\n      return;\n    }\n    const { contextMenu, event, item } = menuEvent;\n    if (contextMenu && contextMenu !== this) {\n      return;\n    }\n    this.event = event;\n    this.item = item;\n    this.setVisibleMenuItems();\n    this._contextMenuService.openContextMenu({ ...menuEvent, menuItems: this.visibleMenuItems, menuClass: this.menuClass });\n    this._contextMenuService.close.asObservable().pipe(first()).subscribe(closeEvent => this.close.emit(closeEvent));\n    this.open.next(menuEvent);\n  }\n\n  public isMenuItemVisible(menuItem: ContextMenuItemDirective): boolean {\n    return this.evaluateIfFunction(menuItem.visible);\n  }\n\n  public setVisibleMenuItems(): void {\n    this.visibleMenuItems = this.menuItems.filter(menuItem => this.isMenuItemVisible(menuItem));\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"]}