@true-directive/grid
Version:
Angular Data Grid from Yopsilon.
118 lines • 13 kB
JavaScript
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":";AAAA;;;;EAIE;AACF,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,MAAM,EAAE,YAAY,EAAe,eAAe,EAAE,SAAS,EAEjE,SAAS,EAAa,MAAM,eAAe,CAAC;AAGnE,OAAO,EAAE,iBAAiB,EAAE,MAAM,uBAAuB,CAAC;AAc1D;IAZA;QAkBE,WAAM,GAAsB,IAAI,YAAY,EAAO,CAAC;QAGpD,SAAI,GAAsB,IAAI,YAAY,EAAO,CAAC;QAGlD,aAAQ,GAAW,UAAU,CAAC;QAI9B,gBAAW,GAAkB,IAAI,CAAC;IA0EpC,CAAC;IAxEC,mCAAW,GAAX,UAAY,CAAM;QAChB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;QACzB,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC;IACrB,CAAC;IAED,iCAAS,GAAT,UAAU,CAAM;QACd,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC;IACnB,CAAC;IAED,sBAAI,kCAAO;aAAX;YACE,OAAO,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC;QAC5B,CAAC;;;OAAA;IAEM,gCAAQ,GAAf,UAAgB,CAAS,EAAE,CAAS;QAClC,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;IAC5B,CAAC;IAEM,oCAAY,GAAnB,UAAoB,MAAkB,EAAE,SAAsB,EAAE,UAAgC;QAA5E,uBAAA,EAAA,aAAkB;QAAE,0BAAA,EAAA,cAAsB;QAAE,2BAAA,EAAA,iBAAgC;QAC9F,IAAI,CAAC,WAAW,GAAG,UAAU,CAAC;QAC9B,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,MAAM,EAAE,SAAS,CAAC,CAAC;IAC7C,CAAC;IAEM,mCAAW,GAAlB,UAAmB,MAAkB,EAAE,SAAsB,EAAE,UAAgC;QAA5E,uBAAA,EAAA,aAAkB;QAAE,0BAAA,EAAA,cAAsB;QAAE,2BAAA,EAAA,iBAAgC;QAC7F,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE;YACjB,IAAI,CAAC,WAAW,GAAG,UAAU,CAAC;YAC9B,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,MAAM,EAAE,SAAS,CAAC,CAAC;SAC5C;;YACC,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,MAAM,EAAE,SAAS,CAAC,CAAC;IAC7C,CAAC;IAEM,qCAAa,GAApB,UAAqB,MAAW;QAC9B,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,UAAA,IAAI;YACrB,IAAI,IAAI,KAAK,MAAM;gBACjB,IAAI,CAAC,YAAY,EAAE,CAAC;QACxB,CAAC,CAAC,CAAC;IACL,CAAC;IAEM,kCAAU,GAAjB,UAAkB,UAA0B;QAA1B,2BAAA,EAAA,iBAA0B;QAC1C,IAAI,IAAI,CAAC,WAAW,KAAK,IAAI,IAAI,UAAU;YACzC,IAAI,CAAC,WAAW,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;QACpC,IAAI,CAAC,KAAK,CAAC,UAAU,EAAE,CAAC;IAC1B,CAAC;IAIO,uCAAe,GAAvB,UAAwB,CAAe;QACrC,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE;YACvB,IAAI,CAAC,aAAa,GAAG,CAAC,CAAC;SACxB;aAAM;YACL,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;SAC3B;IACH,CAAC;IAED,0CAAkB,GAAlB;QAAA,iBAYC;QAXC,IAAI,IAAI,CAAC,aAAa,EAAE;YACtB,IAAI,CAAC,aAAa,CAAC,WAAW,EAAE,CAAC;SAClC;QAED,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,UAAA,IAAI;YACrB,IAAI,CAAC,UAAU,GAAG,KAAI,CAAC;YACvB,IAAM,IAAI,GAAG,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC,UAAA,CAAC,IAAI,OAAA,KAAI,CAAC,aAAa,CAAC,CAAC,CAAC,EAArB,CAAqB,CAAC,CAAC;YACrE,KAAI,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC;YAC3B,IAAM,GAAG,GAAG,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,UAAA,CAAC,IAAI,OAAA,KAAI,CAAC,UAAU,CAAC,IAAI,CAAC,EAArB,CAAqB,CAAC,CAAC;YAC/D,KAAI,CAAC,eAAe,CAAC,GAAG,CAAC,CAAC;QAC5B,CAAC,CAAC,CAAC;IACL,CAAC;IAED,mCAAW,GAAX;QACE,IAAI,IAAI,CAAC,aAAa,EAAE;YACtB,IAAI,CAAC,aAAa,CAAC,WAAW,EAAE,CAAC;SAClC;IACH,CAAC;IAtFD;QADC,SAAS,CAAC,OAAO,EAAE,EAAC,MAAM,EAAE,IAAI,EAAC,CAAC;;gDACxB;IAGX;QADC,MAAM,CAAC,QAAQ,CAAC;0CACT,YAAY;iDAAgC;IAGpD;QADC,MAAM,CAAC,MAAM,CAAC;0CACT,YAAY;+CAAgC;IAGlD;QADC,KAAK,EAAE;;mDACsB;IAEM;QAAnC,eAAe,CAAC,iBAAiB,CAAC;0CAAQ,SAAS;gDAAoB;IAd7D,aAAa;QAZzB,SAAS,CAAC;YACT,QAAQ,EAAE,WAAW;YACrB,QAAQ,EAAE,+OAST;SAAC,CAAC;OACQ,aAAa,CA0FzB;IAAD,oBAAC;CAAA,AA1FD,IA0FC;SA1FY,aAAa","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"]}