UNPKG

@true-directive/grid

Version:

Angular Data Grid from Yopsilon.

118 lines 13 kB
import * as tslib_1 from "tslib"; /** * Copyright (c) 2018-2019 Aleksey Melnikov, True Directive Company. * @link https://truedirective.com/ * @license MIT */ import { Component, Input, Output, EventEmitter, ContentChildren, QueryList, ViewChild } from '@angular/core'; import { MenuItemComponent } from './menu-item.component'; var MenuComponent = /** @class */ (function () { function MenuComponent() { this.closed = new EventEmitter(); this.show = new EventEmitter(); this.position = 'RELATIVE'; this._parentMenu = null; } MenuComponent.prototype.popupClosed = function (e) { this.closeSubMenus(null); this.closed.emit(); }; MenuComponent.prototype.popupShow = function (e) { this.show.emit(); }; Object.defineProperty(MenuComponent.prototype, "visible", { get: function () { return this.popup.visible; }, enumerable: true, configurable: true }); MenuComponent.prototype.showByXY = function (x, y) { this.popup.showByXY(x, y); }; MenuComponent.prototype.showByTarget = function (target, direction, parentMenu) { if (target === void 0) { target = null; } if (direction === void 0) { direction = ''; } if (parentMenu === void 0) { parentMenu = null; } this._parentMenu = parentMenu; this.popup.showByTarget(target, direction); }; MenuComponent.prototype.togglePopup = function (target, direction, parentMenu) { if (target === void 0) { target = null; } if (direction === void 0) { direction = ''; } if (parentMenu === void 0) { parentMenu = null; } if (!this.visible) { this._parentMenu = parentMenu; this.popup.showByTarget(target, direction); } else this.popup.closePopup(target, direction); }; MenuComponent.prototype.closeSubMenus = function (sender) { this.items.forEach(function (item) { if (item !== sender) item.closeSubMenu(); }); }; MenuComponent.prototype.closePopup = function (withParent) { if (withParent === void 0) { withParent = true; } if (this._parentMenu !== null && withParent) this._parentMenu.closePopup(true); this.popup.closePopup(); }; MenuComponent.prototype.addSubscription = function (s) { if (!this._subscription) { this._subscription = s; } else { this._subscription.add(s); } }; MenuComponent.prototype.ngAfterContentInit = function () { var _this = this; if (this._subscription) { this._subscription.unsubscribe(); } this.items.forEach(function (item) { item.parentMenu = _this; var sbme = item.onMouseEnter.subscribe(function (e) { return _this.closeSubMenus(e); }); _this.addSubscription(sbme); var sbc = item.onClick.subscribe(function (e) { return _this.closePopup(true); }); _this.addSubscription(sbc); }); }; MenuComponent.prototype.ngOnDestroy = function () { if (this._subscription) { this._subscription.unsubscribe(); } }; tslib_1.__decorate([ ViewChild('popup', { static: true }), tslib_1.__metadata("design:type", Object) ], MenuComponent.prototype, "popup", void 0); tslib_1.__decorate([ Output('closed'), tslib_1.__metadata("design:type", EventEmitter) ], MenuComponent.prototype, "closed", void 0); tslib_1.__decorate([ Output('show'), tslib_1.__metadata("design:type", EventEmitter) ], MenuComponent.prototype, "show", void 0); tslib_1.__decorate([ Input(), tslib_1.__metadata("design:type", String) ], MenuComponent.prototype, "position", void 0); tslib_1.__decorate([ ContentChildren(MenuItemComponent), tslib_1.__metadata("design:type", QueryList) ], MenuComponent.prototype, "items", void 0); MenuComponent = tslib_1.__decorate([ Component({ selector: 'true-menu', template: "\n <true-popup #popup\n [position]=\"position\"\n (closed)=\"popupClosed($event)\"\n (show)=\"popupShow($event)\">\n <div class=\"true-menu\">\n <ng-content></ng-content>\n </div>\n </true-popup>\n " }) ], MenuComponent); return MenuComponent; }()); export { MenuComponent }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"menu.component.js","sourceRoot":"ng://@true-directive/grid/","sources":["src/controls/menu.component.ts"],"names":[],"mappings":"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","sourcesContent":["/**\r\n * Copyright (c) 2018-2019 Aleksey Melnikov, True Directive Company.\r\n * @link https://truedirective.com/\r\n * @license MIT\r\n*/\r\nimport { Component, Input, Output, EventEmitter, HostBinding, ContentChildren, QueryList,\r\n         AfterContentInit,\r\n         ViewChildren, ViewChild, OnDestroy } from '@angular/core';\r\nimport { Subscription } from 'rxjs';\r\n\r\nimport { MenuItemComponent } from './menu-item.component';\r\n\r\n@Component({\r\n  selector: 'true-menu',\r\n  template: `\r\n    <true-popup #popup\r\n      [position]=\"position\"\r\n      (closed)=\"popupClosed($event)\"\r\n      (show)=\"popupShow($event)\">\r\n      <div class=\"true-menu\">\r\n        <ng-content></ng-content>\r\n      </div>\r\n    </true-popup>\r\n  `})\r\nexport class MenuComponent implements OnDestroy, AfterContentInit {\r\n\r\n  @ViewChild('popup', {static: true})\r\n  popup: any;\r\n\r\n  @Output('closed')\r\n  closed: EventEmitter<any> = new EventEmitter<any>();\r\n\r\n  @Output('show')\r\n  show: EventEmitter<any> = new EventEmitter<any>();\r\n\r\n  @Input()\r\n  position: string = 'RELATIVE';\r\n\r\n  @ContentChildren(MenuItemComponent) items: QueryList<MenuItemComponent>;\r\n\r\n  _parentMenu: MenuComponent = null;\r\n\r\n  popupClosed(e: any) {\r\n    this.closeSubMenus(null);\r\n    this.closed.emit();\r\n  }\r\n\r\n  popupShow(e: any) {\r\n    this.show.emit();\r\n  }\r\n\r\n  get visible(): boolean {\r\n    return this.popup.visible;\r\n  }\r\n\r\n  public showByXY(x: number, y: number) {\r\n    this.popup.showByXY(x, y);\r\n  }\r\n\r\n  public showByTarget(target: any = null, direction: string = '', parentMenu: MenuComponent = null) {\r\n    this._parentMenu = parentMenu;\r\n    this.popup.showByTarget(target, direction);\r\n  }\r\n\r\n  public togglePopup(target: any = null, direction: string = '', parentMenu: MenuComponent = null) {\r\n    if (!this.visible) {\r\n      this._parentMenu = parentMenu;\r\n      this.popup.showByTarget(target, direction);\r\n    } else\r\n      this.popup.closePopup(target, direction);\r\n  }\r\n\r\n  public closeSubMenus(sender: any) {\r\n    this.items.forEach(item => {\r\n      if (item !== sender)\r\n        item.closeSubMenu();\r\n    });\r\n  }\r\n\r\n  public closePopup(withParent: boolean = true) {\r\n    if (this._parentMenu !== null && withParent)\r\n      this._parentMenu.closePopup(true);\r\n    this.popup.closePopup();\r\n  }\r\n\r\n  _subscription: Subscription;\r\n\r\n  private addSubscription(s: Subscription) {\r\n    if (!this._subscription) {\r\n      this._subscription = s;\r\n    } else {\r\n      this._subscription.add(s);\r\n    }\r\n  }\r\n\r\n  ngAfterContentInit() {\r\n    if (this._subscription) {\r\n      this._subscription.unsubscribe();\r\n    }\r\n\r\n    this.items.forEach(item => {\r\n      item.parentMenu = this;\r\n      const sbme = item.onMouseEnter.subscribe(e => this.closeSubMenus(e));\r\n      this.addSubscription(sbme);\r\n      const sbc = item.onClick.subscribe(e => this.closePopup(true));\r\n      this.addSubscription(sbc);\r\n    });\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    if (this._subscription) {\r\n      this._subscription.unsubscribe();\r\n    }\r\n  }\r\n}\r\n"]}