UNPKG

com.phloxui

Version:

PhloxUI Ng2+ Framework

380 lines (379 loc) 29.1 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes} checked by tsc */ import * as tslib_1 from "tslib"; import { Component, ElementRef, Input } from '@angular/core'; import { MenuModel } from './model/MenuModel'; import { AbstractMenu } from './AbstractMenu'; import { NeedFocusService } from '../service/NeedFocusService.service'; import { Option } from '../decorator/Option.decorator'; import { I18N } from '../decorator/I18N.decorator'; var /** @type {?} */ TYPE_NAME = "phx-context-menu"; var ContextMenu = /** @class */ (function (_super) { tslib_1.__extends(ContextMenu, _super); function ContextMenu(elementRef, needFocusService) { var _this = _super.call(this, needFocusService) || this; _this.elementRef = elementRef; _this._show = false; _this.autoFocus = true; return _this; } /** * @return {?} */ ContextMenu.prototype.ngOnInit = /** * @return {?} */ function () { this.init(); if (this.autoFocus === null || typeof this.autoFocus === 'undefined') { this.autoFocus = true; } }; /** * @return {?} */ ContextMenu.prototype.init = /** * @return {?} */ function () { if (this.context != null) { this.context.setContextMenu(this); } if (this.nativeElement === undefined) { // remove dom and save them in RAM this.nativeElement = $(this.elementRef.nativeElement).detach(); } this.showMenu(this._show); }; /** * @param {?} isShow * @param {?=} widthSet * @return {?} */ ContextMenu.prototype.showMenu = /** * @param {?} isShow * @param {?=} widthSet * @return {?} */ function (isShow, widthSet) { var _this = this; this._show = isShow; if (this.nativeElement === undefined) { // remove dom and save them in RAM this.nativeElement = $(this.elementRef.nativeElement).detach(); } if (this._show) { if (this.context != null && this.context.getMenuModelFactory() != null) { this.model = this.context.getMenuModelFactory().createMenuModel(this.context); } if (this.needFocusService != null) { if (this.autoFocus) { this.needFocusService.setFocusingComponent(this); } } $(this.elementRef.nativeElement).addClass('show'); setTimeout(function () { $(_this.elementRef.nativeElement).css('opacity', 1); // append dom $("body").append(_this.nativeElement); if (typeof widthSet !== "number") { var /** @type {?} */ left = $(_this.elementRef.nativeElement).offset().left; var /** @type {?} */ width = $(_this.elementRef.nativeElement).width(); $(_this.nativeElement).css('left', (left - width) + "px"); } }, 1); } else { $(this.elementRef.nativeElement).removeClass('show'); $(this.elementRef.nativeElement).css('opacity', 0); if (this.needFocusService != null) { if (this.autoFocus && this.needFocusService.getFocusingComponent() === this) { this.needFocusService.resetFocusingComponent(); } } } }; /** * @param {?} positionX * @param {?} positionY * @param {?=} width * @return {?} */ ContextMenu.prototype.showAt = /** * @param {?} positionX * @param {?} positionY * @param {?=} width * @return {?} */ function (positionX, positionY, width) { if (positionX == null && positionY == null) { return; } if (positionX == null) { positionX = 0; } if (positionY == null) { positionY = 0; } if (this.nativeElement === undefined) { // remove dom and save them in RAM this.nativeElement = $(this.elementRef.nativeElement).detach(); } $(this.nativeElement).css('top', positionX + "px"); $(this.nativeElement).css('left', positionY + "px"); if (width !== null && width !== undefined) { $(this.nativeElement).css('width', width); } this.showMenu(true, width); }; /** * @return {?} */ ContextMenu.prototype.hide = /** * @return {?} */ function () { this.showMenu(false); }; /** * @param {?} $event * @return {?} */ ContextMenu.prototype.onItemClick = /** * @param {?} $event * @return {?} */ function ($event) { if (this.autoFocus) { if (this.needFocusService !== null && this.needFocusService !== undefined) { this.needFocusService.setFocusingComponent(this); } } }; /** * @return {?} */ ContextMenu.prototype.isShow = /** * @return {?} */ function () { return this._show; }; /** * @return {?} */ ContextMenu.prototype.doRenderMenu = /** * @return {?} */ function () { // all item was cleared and items should be set here }; /** * @param {?} dataParent * @return {?} */ ContextMenu.prototype.setDataParent = /** * @param {?} dataParent * @return {?} */ function (dataParent) { this.dataParent = dataParent; }; /** * @return {?} */ ContextMenu.prototype.getDataParent = /** * @return {?} */ function () { return this.dataParent; }; /** * @return {?} */ ContextMenu.prototype.getContext = /** * @return {?} */ function () { return this.context; }; /** * @param {?} context * @return {?} */ ContextMenu.prototype.setContext = /** * @param {?} context * @return {?} */ function (context) { this.context = context; }; /** * @param {?} event * @return {?} */ ContextMenu.prototype.onFocus = /** * @param {?} event * @return {?} */ function (event) { var _this = this; if (this.focusTimeout !== undefined && this.focusTimeout !== null) { clearTimeout(this.focusTimeout); } this.focusTimeout = setTimeout(function () { $(_this.elementRef.nativeElement).find(".fake").focus(); }, 20); }; /** * @param {?} event * @return {?} */ ContextMenu.prototype.onLostFocus = /** * @param {?} event * @return {?} */ function (event) { var _this = this; if (this.lostFocusTimeout !== undefined && this.lostFocusTimeout !== null) { clearTimeout(this.lostFocusTimeout); } this.lostFocusTimeout = setTimeout(function () { _this.showMenu(false); $(_this.elementRef.nativeElement).find(".fake").blur(); }, 400); }; /** * @param {?} autoFocus * @return {?} */ ContextMenu.prototype.setAutoFocus = /** * @param {?} autoFocus * @return {?} */ function (autoFocus) { this.autoFocus = autoFocus; }; /** * @return {?} */ ContextMenu.prototype.isAutoFocus = /** * @return {?} */ function () { return this.autoFocus; }; /** * @param {?} $event * @return {?} */ ContextMenu.prototype._doFocus = /** * @param {?} $event * @return {?} */ function ($event) { // do something when focus if (this.needFocusService !== null && this.needFocusService !== undefined) { this.needFocusService.setFocusingComponent(this); } }; /** * @param {?} $event * @return {?} */ ContextMenu.prototype._doLostFocus = /** * @param {?} $event * @return {?} */ function ($event) { if (this.needFocusService !== null && this.needFocusService.getFocusingComponent() === this) { this.needFocusService.resetFocusingComponent(); } }; ContextMenu.TYPE_NAME = TYPE_NAME; ContextMenu.decorators = [ { type: Component, args: [{ moduleId: module.id, selector: TYPE_NAME, template: "<div class=\"phx-context-menu\">\n\t<ul *ngIf=\"getModel() != null\">\n\t\t<li *ngFor=\"let item of getModel().items; let i = index\" [class.disable]=\"!item.enable\" (click)=\"onItemClick($event)\"><phx-component-wrapper\n\t\t\t\t[type]=\"item.type\" [handler]=\"getMenuItemHandler()\" [model]=\"item\"\n\t\t\t\t[class.disable]=\"!item.enable\"></phx-component-wrapper></li>\n\t</ul>\n\t<button type=\"button\" class=\"fake\" (focusin)=\"_doFocus($event)\" (blur)=\"_doLostFocus($event)\"></button>\n</div>\n" },] }, ]; /** @nocollapse */ ContextMenu.ctorParameters = function () { return [ { type: ElementRef, }, { type: NeedFocusService, }, ]; }; ContextMenu.propDecorators = { "model": [{ type: Input },], "items": [{ type: Input },], "dataParent": [{ type: Input },], "context": [{ type: Input },], "autoFocus": [{ type: Input },], }; tslib_1.__decorate([ Option(), I18N(), tslib_1.__metadata("design:type", MenuModel) ], ContextMenu.prototype, "model", void 0); tslib_1.__decorate([ Option(), I18N(), tslib_1.__metadata("design:type", Array) ], ContextMenu.prototype, "items", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", Object) ], ContextMenu.prototype, "dataParent", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", Object) ], ContextMenu.prototype, "context", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", Boolean) ], ContextMenu.prototype, "autoFocus", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", Function) ], ContextMenu.prototype, "menuItemHandler", void 0); return ContextMenu; }(AbstractMenu)); export { ContextMenu }; function ContextMenu_tsickle_Closure_declarations() { /** @type {!Array<{type: !Function, args: (undefined|!Array<?>)}>} */ ContextMenu.decorators; /** * @nocollapse * @type {function(): !Array<(null|{type: ?, decorators: (undefined|!Array<{type: !Function, args: (undefined|!Array<?>)}>)})>} */ ContextMenu.ctorParameters; /** @type {!Object<string,!Array<{type: !Function, args: (undefined|!Array<?>)}>>} */ ContextMenu.propDecorators; /** @type {?} */ ContextMenu.TYPE_NAME; /** @type {?} */ ContextMenu.prototype.model; /** @type {?} */ ContextMenu.prototype.items; /** @type {?} */ ContextMenu.prototype.dataParent; /** @type {?} */ ContextMenu.prototype.context; /** @type {?} */ ContextMenu.prototype.autoFocus; /** @type {?} */ ContextMenu.prototype.menuItemHandler; /** @type {?} */ ContextMenu.prototype.elementRef; /** @type {?} */ ContextMenu.prototype._show; /** @type {?} */ ContextMenu.prototype.nativeElement; /** @type {?} */ ContextMenu.prototype.focusTimeout; /** @type {?} */ ContextMenu.prototype.lostFocusTimeout; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ContextMenu.component.js","sourceRoot":"ng://com.phloxui/","sources":["lib/component/ContextMenu.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, ElementRef, Input, HostListener } from '@angular/core';\nimport { MenuModel } from './model/MenuModel';\nimport { MenuItemModel } from './model/MenuItemModel';\nimport { AbstractMenu } from './AbstractMenu';\nimport { IHasContext } from './IHasContext';\nimport { IContext } from './IContext';\nimport { INeedFocus } from './INeedFocus';\nimport { IHasDataParent } from './IHasDataParent';\nimport { IHasData } from './IHasData';\nimport { NeedFocusService } from '../service/NeedFocusService.service';\nimport { AbstractMenuItem } from './AbstractMenuItem';\nimport { Option } from '../decorator/Option.decorator';\nimport { I18N } from '../decorator/I18N.decorator';\n\ndeclare var $: any;\n\nconst TYPE_NAME: string = \"phx-context-menu\";\n\n@Component({\n  moduleId: module.id,\n  selector: TYPE_NAME,\n  template: `<div class=\"phx-context-menu\">\n\t<ul *ngIf=\"getModel() != null\">\n\t\t<li *ngFor=\"let item of getModel().items; let i = index\" [class.disable]=\"!item.enable\" (click)=\"onItemClick($event)\"><phx-component-wrapper\n\t\t\t\t[type]=\"item.type\" [handler]=\"getMenuItemHandler()\" [model]=\"item\"\n\t\t\t\t[class.disable]=\"!item.enable\"></phx-component-wrapper></li>\n\t</ul>\n\t<button type=\"button\" class=\"fake\" (focusin)=\"_doFocus($event)\" (blur)=\"_doLostFocus($event)\"></button>\n</div>\n`\n})\nexport class ContextMenu extends AbstractMenu implements OnInit, IHasContext, INeedFocus, IHasDataParent {\n\n  public static readonly TYPE_NAME: string = TYPE_NAME;\n\n  // Re-declare field to declare ng @Input.\n  // --- from AbstractMenu\n  @Input()\n  @Option()\n  @I18N()\n  protected model: MenuModel;\n  @Input()\n  @Option()\n  @I18N()\n  protected items: AbstractMenuItem[];\n  // --- self\n  @Input()\n  @Option()\n  protected dataParent: IHasData;\n  @Input()\n  @Option()\n  private context: IContext;\n  @Input()\n  @Option()\n  private autoFocus: boolean;\n\n  // Re-declare field to declare ng @Output.\n  // Re-declare field to declare\n  // --- from AbstractMenu\n  @Option()\n  protected menuItemHandler: Function;\n\n  // --- self\n  protected elementRef: ElementRef;\n  private _show: boolean;\n  private nativeElement: any;\n  private focusTimeout: any;\n  private lostFocusTimeout: any;\n\n  constructor(elementRef: ElementRef, needFocusService: NeedFocusService) {\n    super(needFocusService);\n    this.elementRef = elementRef;\n    this._show = false;\n    this.autoFocus = true;\n  }\n\n  public ngOnInit(): void {\n    this.init();\n\n    if (this.autoFocus === null || typeof this.autoFocus === 'undefined') {\n      this.autoFocus = true;\n    }\n\n  }\n\n  private init(): void {\n    if (this.context != null) {\n      this.context.setContextMenu(this);\n    }\n\n    if (this.nativeElement === undefined) {\n      // remove dom and save them in RAM\n      this.nativeElement = $(this.elementRef.nativeElement).detach();\n    }\n\n    this.showMenu(this._show);\n  }\n\n  private showMenu(isShow: boolean, widthSet?: number): void {\n    this._show = isShow;\n\n    if (this.nativeElement === undefined) {\n      // remove dom and save them in RAM\n      this.nativeElement = $(this.elementRef.nativeElement).detach();\n    }\n\n    if (this._show) {\n      if (this.context != null && this.context.getMenuModelFactory() != null) {\n        this.model = this.context.getMenuModelFactory().createMenuModel(this.context);\n      }\n\n      if (this.needFocusService != null) {\n        if (this.autoFocus) {\n          this.needFocusService.setFocusingComponent(this);\n        }\n      }\n\n      $(this.elementRef.nativeElement).addClass('show');\n      setTimeout(() => {\n        $(this.elementRef.nativeElement).css('opacity', 1);\n        // append dom\n        $(\"body\").append(this.nativeElement);\n        if (typeof widthSet !== \"number\") {\n          let left = $(this.elementRef.nativeElement).offset().left;\n          let width = $(this.elementRef.nativeElement).width();\n          $(this.nativeElement).css('left', (left - width) + \"px\");\n        }\n      }, 1);\n    } else {\n      $(this.elementRef.nativeElement).removeClass('show');\n      $(this.elementRef.nativeElement).css('opacity', 0);\n\n      if (this.needFocusService != null) {\n        if (this.autoFocus && this.needFocusService.getFocusingComponent() === this) {\n          this.needFocusService.resetFocusingComponent();\n        }\n      }\n    }\n  }\n\n  public showAt(positionX: number, positionY: number, width?: number): void {\n    if (positionX == null && positionY == null) {\n      return;\n    }\n    if (positionX == null) {\n      positionX = 0;\n    }\n    if (positionY == null) {\n      positionY = 0;\n    }\n\n    if (this.nativeElement === undefined) {\n      // remove dom and save them in RAM\n      this.nativeElement = $(this.elementRef.nativeElement).detach();\n    }\n\n    $(this.nativeElement).css('top', positionX + \"px\");\n    $(this.nativeElement).css('left', positionY + \"px\");\n\n    if (width !== null && width !== undefined) {\n      $(this.nativeElement).css('width', width);\n    }\n\n    this.showMenu(true, width);\n  }\n\n  public hide(): void {\n    this.showMenu(false);\n  }\n\n  public onItemClick($event: Event): void {\n    if (this.autoFocus) {\n      if (this.needFocusService !== null && this.needFocusService !== undefined) {\n        this.needFocusService.setFocusingComponent(this);\n      }\n    }\n  }\n\n  public isShow(): boolean {\n    return this._show;\n  }\n\n  public doRenderMenu(): void {\n    // all item was cleared and items should be set here\n  }\n\n  public setDataParent(dataParent: IHasData) {\n    this.dataParent = dataParent;\n  }\n\n  public getDataParent(): IHasData {\n    return this.dataParent;\n  }\n\n  public getContext(): IContext {\n    return this.context;\n  }\n\n  public setContext(context: IContext): void {\n    this.context = context;\n  }\n\n  public onFocus(event: any): void {\n    if (this.focusTimeout !== undefined && this.focusTimeout !== null) {\n      clearTimeout(this.focusTimeout);\n    }\n\n    this.focusTimeout = setTimeout(() => {\n      $(this.elementRef.nativeElement).find(\".fake\").focus();\n    }, 20);\n  }\n\n  public onLostFocus(event: any): void {\n    if (this.lostFocusTimeout !== undefined && this.lostFocusTimeout !== null) {\n      clearTimeout(this.lostFocusTimeout);\n    }\n\n    this.lostFocusTimeout = setTimeout(() => {\n      this.showMenu(false);\n      $(this.elementRef.nativeElement).find(\".fake\").blur();\n    }, 400);\n  }\n\n  public setAutoFocus(autoFocus: boolean): void {\n    this.autoFocus = autoFocus;\n  }\n\n  public isAutoFocus(): boolean {\n    return this.autoFocus;\n  }\n\n  public _doFocus($event: Event): void {\n    // do something when focus\n    if (this.needFocusService !== null && this.needFocusService !== undefined) {\n      this.needFocusService.setFocusingComponent(this);\n    }\n  }\n\n  public _doLostFocus($event: Event): void {\n    if (this.needFocusService !== null && this.needFocusService.getFocusingComponent() === this) {\n      this.needFocusService.resetFocusingComponent();\n    }\n  }\n}\n"]}