UNPKG

com.phloxui

Version:

PhloxUI Ng2+ Framework

318 lines (317 loc) 27 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'; const /** @type {?} */ TYPE_NAME = "phx-context-menu"; export class ContextMenu extends AbstractMenu { /** * @param {?} elementRef * @param {?} needFocusService */ constructor(elementRef, needFocusService) { super(needFocusService); this.elementRef = elementRef; this._show = false; this.autoFocus = true; } /** * @return {?} */ ngOnInit() { this.init(); if (this.autoFocus === null || typeof this.autoFocus === 'undefined') { this.autoFocus = true; } } /** * @return {?} */ init() { 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 {?} */ showMenu(isShow, widthSet) { 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(() => { $(this.elementRef.nativeElement).css('opacity', 1); // append dom $("body").append(this.nativeElement); if (typeof widthSet !== "number") { let /** @type {?} */ left = $(this.elementRef.nativeElement).offset().left; let /** @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 {?} */ showAt(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 {?} */ hide() { this.showMenu(false); } /** * @param {?} $event * @return {?} */ onItemClick($event) { if (this.autoFocus) { if (this.needFocusService !== null && this.needFocusService !== undefined) { this.needFocusService.setFocusingComponent(this); } } } /** * @return {?} */ isShow() { return this._show; } /** * @return {?} */ doRenderMenu() { // all item was cleared and items should be set here } /** * @param {?} dataParent * @return {?} */ setDataParent(dataParent) { this.dataParent = dataParent; } /** * @return {?} */ getDataParent() { return this.dataParent; } /** * @return {?} */ getContext() { return this.context; } /** * @param {?} context * @return {?} */ setContext(context) { this.context = context; } /** * @param {?} event * @return {?} */ onFocus(event) { if (this.focusTimeout !== undefined && this.focusTimeout !== null) { clearTimeout(this.focusTimeout); } this.focusTimeout = setTimeout(() => { $(this.elementRef.nativeElement).find(".fake").focus(); }, 20); } /** * @param {?} event * @return {?} */ onLostFocus(event) { if (this.lostFocusTimeout !== undefined && this.lostFocusTimeout !== null) { clearTimeout(this.lostFocusTimeout); } this.lostFocusTimeout = setTimeout(() => { this.showMenu(false); $(this.elementRef.nativeElement).find(".fake").blur(); }, 400); } /** * @param {?} autoFocus * @return {?} */ setAutoFocus(autoFocus) { this.autoFocus = autoFocus; } /** * @return {?} */ isAutoFocus() { return this.autoFocus; } /** * @param {?} $event * @return {?} */ _doFocus($event) { // do something when focus if (this.needFocusService !== null && this.needFocusService !== undefined) { this.needFocusService.setFocusingComponent(this); } } /** * @param {?} $event * @return {?} */ _doLostFocus($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"> <ul *ngIf="getModel() != null"> <li *ngFor="let item of getModel().items; let i = index" [class.disable]="!item.enable" (click)="onItemClick($event)"><phx-component-wrapper [type]="item.type" [handler]="getMenuItemHandler()" [model]="item" [class.disable]="!item.enable"></phx-component-wrapper></li> </ul> <button type="button" class="fake" (focusin)="_doFocus($event)" (blur)="_doLostFocus($event)"></button> </div> ` },] }, ]; /** @nocollapse */ ContextMenu.ctorParameters = () => [ { 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); 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"]}