UNPKG

com.phloxui

Version:

PhloxUI Ng2+ Framework

401 lines (400 loc) 29.4 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes} checked by tsc */ import * as tslib_1 from "tslib"; import { Component, ElementRef, Input, Output, EventEmitter } from '@angular/core'; import { MenuModel } from './model/models'; import { AbstractHasData } from './AbstractHasData'; import { Option } from '../decorator/Option.decorator'; import { I18N } from '../decorator/I18N.decorator'; import { NeedFocusService } from '../service/NeedFocusService.service'; const /** @type {?} */ TYPE_NAME = "phx-context-menu-btn"; const /** @type {?} */ TYPE_PARENT = "parent"; const /** @type {?} */ TYPE_CHILDREN = "children"; const /** @type {?} */ TYPE_DISTANCE = "distance"; export class ContextMenuButton extends AbstractHasData { /** * @param {?} elementRef * @param {?} needFocusService */ constructor(elementRef, needFocusService) { super(elementRef); this.needFocusService = needFocusService; this.autoFocus = true; } /** * @return {?} */ ngOnInit() { this.init(); } /** * @return {?} */ ngOnDestroy() { if (this.contextMenu != null && typeof this.contextMenu !== 'undefined') { this.contextMenu.setContext(null); } } /** * @return {?} */ init() { if (this.contextMenu != null && typeof this.contextMenu !== 'undefined') { this.contextMenu.setContext(this); } if (this.menuFactory !== null && typeof this.menuFactory !== 'undefined') { this.menuModel = this.menuFactory.createMenuModel(this); } } /** * @return {?} */ recreateMenuModel() { this.menuModel = this.menuFactory.createMenuModel(this); } /** * @param {?} $event * @return {?} */ onMoreButtonClick($event) { if (this.contextMenu !== null && typeof this.contextMenu !== 'undefined') { if (this.contextMenu.isShow()) { setTimeout(() => { this.hideMenu(); }, 50); } else { let /** @type {?} */ anchorEl = this.elementRef.nativeElement; if (this.anchorComponent !== null && this.anchorComponent !== undefined) { anchorEl = this.anchorComponent.elementRef.nativeElement; } else if (this.anchorSelector !== null && typeof this.anchorSelector === 'string') { let /** @type {?} */ selector = $(this.anchorSelector); if (selector.length > 0) { anchorEl = selector[0]; } } let /** @type {?} */ offsetTop = 0; let /** @type {?} */ offsetLeft = 0; if (this.menuOffsetTop !== null && typeof this.menuOffsetTop === 'number') { offsetTop = this.menuOffsetTop; } if (this.menuOffsetLeft !== null && typeof this.menuOffsetLeft === 'number') { offsetLeft = this.menuOffsetLeft; } let /** @type {?} */ top = $(anchorEl).offset().top + $(anchorEl).height() + offsetTop; let /** @type {?} */ leftEllipsisButton = $(this.elementRef.nativeElement).offset().left + offsetLeft; let /** @type {?} */ widthEllipsisButton = $(this.elementRef.nativeElement).outerWidth(); let /** @type {?} */ setLeft = leftEllipsisButton + widthEllipsisButton; this.contextMenu.showAt(top, setLeft); } } } /** * @return {?} */ getContextMenu() { return this.contextMenu; } /** * @param {?} menu * @return {?} */ setContextMenu(menu) { this.contextMenu = menu; } /** * @return {?} */ getMenuModelFactory() { return this.menuFactory; } /** * @param {?} menuFactory * @return {?} */ setMenuModelFactory(menuFactory) { this.menuFactory = menuFactory; } /** * @return {?} */ getMenuModel() { return this.menuModel; } /** * @return {?} */ isSelfDataDirty() { return false; } /** * @param {?} data * @return {?} */ selfSaveData(data) { } /** * @return {?} */ selfResetData() { } /** * @return {?} */ doPreload() { return new Promise((resolve, reject) => { resolve(null); }); } /** * @return {?} */ doLoaded() { } /** * @return {?} */ isIconURLEmpty() { if (this.iconURL == null || this.iconURL === undefined) { return true; } return false; } /** * @return {?} */ getIconURL() { return this.iconURL; } /** * @return {?} */ getStyleClasses() { return this.styleClasses; } /** * @return {?} */ hideMenu() { if (this.contextMenu != null && typeof this.contextMenu !== 'undefined') { this.contextMenu.hide(); } } /** * @return {?} */ isShowMenu() { return this.contextMenu.isShow(); } /** * @return {?} */ isAutoFocus() { return this.autoFocus; } /** * @param {?} event * @return {?} */ onFocus(event) { } /** * @param {?} event * @return {?} */ onLostFocus(event) { this.hideMenu(); } /** * @param {?} $event * @return {?} */ _doFocus($event) { // do something when focus } /** * @param {?} $event * @return {?} */ _doLostFocus($event) { if (this.needFocusService !== null) { this.needFocusService.resetFocusingComponent(this); } } } ContextMenuButton.TYPE_NAME = TYPE_NAME; ContextMenuButton.decorators = [ { type: Component, args: [{ moduleId: module.id, selector: TYPE_NAME, template: `<div class="phx-context-menu-btn" [ngClass]="getStyleClasses()" (click)="onMoreButtonClick($event)"> <div class="icon-img" *ngIf="!isIconURLEmpty()"> <img src="{{getIconURL()}}"> </div> <button type="button" class="fake" (focusin)="_doFocus($event)" (blur)="_doLostFocus($event)"></button> </div> <phx-context-menu [model]="getMenuModel()" [context]="this" class="vertical" [autoFocus]="isAutoFocus()"></phx-context-menu> ` },] }, ]; /** @nocollapse */ ContextMenuButton.ctorParameters = () => [ { type: ElementRef, }, { type: NeedFocusService, }, ]; ContextMenuButton.propDecorators = { "dataParent": [{ type: Input },], "ignoreParentData": [{ type: Input },], "data": [{ type: Input },], "ignoreParentDisabled": [{ type: Input },], "delegateHistory": [{ type: Input },], "onDisabled": [{ type: Input },], "onEnabled": [{ type: Input },], "loadingEnabled": [{ type: Input },], "i18nKey": [{ type: Input },], "bypass": [{ type: Input, args: ['i18nBypass',] },], "options": [{ type: Input },], "disabled": [{ type: Input },], "menuFactory": [{ type: Input },], "iconURL": [{ type: Input }, { type: Output },], "styleClasses": [{ type: Input }, { type: Output },], "anchorComponent": [{ type: Input },], "anchorSelector": [{ type: Input },], "menuOffsetTop": [{ type: Input },], "menuOffsetLeft": [{ type: Input },], "loadEvent": [{ type: Output, args: ['phxLoad',] },], }; tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", Object) ], ContextMenuButton.prototype, "dataParent", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", Boolean) ], ContextMenuButton.prototype, "ignoreParentData", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", Object) ], ContextMenuButton.prototype, "data", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", Boolean) ], ContextMenuButton.prototype, "ignoreParentDisabled", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", Boolean) ], ContextMenuButton.prototype, "delegateHistory", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", Function) ], ContextMenuButton.prototype, "onDisabled", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", Function) ], ContextMenuButton.prototype, "onEnabled", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", Boolean) ], ContextMenuButton.prototype, "loadingEnabled", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", String) ], ContextMenuButton.prototype, "i18nKey", void 0); tslib_1.__decorate([ Option('i18nBypass'), tslib_1.__metadata("design:type", Boolean) ], ContextMenuButton.prototype, "bypass", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", Boolean) ], ContextMenuButton.prototype, "disabled", void 0); tslib_1.__decorate([ I18N(), Option(), tslib_1.__metadata("design:type", Object) ], ContextMenuButton.prototype, "menuFactory", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", Object) ], ContextMenuButton.prototype, "anchorComponent", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", String) ], ContextMenuButton.prototype, "anchorSelector", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", String) ], ContextMenuButton.prototype, "menuOffsetTop", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", String) ], ContextMenuButton.prototype, "menuOffsetLeft", void 0); tslib_1.__decorate([ Option('load'), tslib_1.__metadata("design:type", EventEmitter) ], ContextMenuButton.prototype, "loadEvent", void 0); tslib_1.__decorate([ I18N(), tslib_1.__metadata("design:type", MenuModel) ], ContextMenuButton.prototype, "menuModel", void 0); function ContextMenuButton_tsickle_Closure_declarations() { /** @type {!Array<{type: !Function, args: (undefined|!Array<?>)}>} */ ContextMenuButton.decorators; /** * @nocollapse * @type {function(): !Array<(null|{type: ?, decorators: (undefined|!Array<{type: !Function, args: (undefined|!Array<?>)}>)})>} */ ContextMenuButton.ctorParameters; /** @type {!Object<string,!Array<{type: !Function, args: (undefined|!Array<?>)}>>} */ ContextMenuButton.propDecorators; /** @type {?} */ ContextMenuButton.TYPE_NAME; /** @type {?} */ ContextMenuButton.prototype.dataParent; /** @type {?} */ ContextMenuButton.prototype.ignoreParentData; /** @type {?} */ ContextMenuButton.prototype.data; /** @type {?} */ ContextMenuButton.prototype.ignoreParentDisabled; /** @type {?} */ ContextMenuButton.prototype.delegateHistory; /** @type {?} */ ContextMenuButton.prototype.onDisabled; /** @type {?} */ ContextMenuButton.prototype.onEnabled; /** @type {?} */ ContextMenuButton.prototype.loadingEnabled; /** @type {?} */ ContextMenuButton.prototype.i18nKey; /** @type {?} */ ContextMenuButton.prototype.bypass; /** @type {?} */ ContextMenuButton.prototype.options; /** @type {?} */ ContextMenuButton.prototype.disabled; /** @type {?} */ ContextMenuButton.prototype.menuFactory; /** @type {?} */ ContextMenuButton.prototype.iconURL; /** @type {?} */ ContextMenuButton.prototype.styleClasses; /** @type {?} */ ContextMenuButton.prototype.anchorComponent; /** @type {?} */ ContextMenuButton.prototype.anchorSelector; /** @type {?} */ ContextMenuButton.prototype.menuOffsetTop; /** @type {?} */ ContextMenuButton.prototype.menuOffsetLeft; /** @type {?} */ ContextMenuButton.prototype.loadEvent; /** @type {?} */ ContextMenuButton.prototype.menuModel; /** @type {?} */ ContextMenuButton.prototype.contextMenu; /** @type {?} */ ContextMenuButton.prototype.needFocusService; /** @type {?} */ ContextMenuButton.prototype.autoFocus; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ContextMenuButton.component.js","sourceRoot":"ng://com.phloxui/","sources":["lib/component/ContextMenuButton.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, ElementRef, Input, Output, OnDestroy, EventEmitter } from '@angular/core';\r\nimport { MenuModel } from './model/models';\r\nimport { ContextMenu } from './ContextMenu.component';\r\nimport { IContext } from './IContext';\r\nimport { IHasData } from './IHasData';\r\nimport { INeedFocus } from './INeedFocus';\r\nimport { IMenuModelFactory } from './IMenuModelFactory';\r\nimport { AbstractHasData } from './AbstractHasData';\r\nimport { Option } from '../decorator/Option.decorator';\r\nimport { I18N } from '../decorator/I18N.decorator';\r\nimport { NeedFocusService } from '../service/NeedFocusService.service';\r\n\r\ndeclare var $: any;\r\n\r\nconst TYPE_NAME: string = \"phx-context-menu-btn\";\r\n\r\nconst TYPE_PARENT = \"parent\";\r\nconst TYPE_CHILDREN = \"children\";\r\nconst TYPE_DISTANCE = \"distance\";\r\n\r\n@Component({\r\n  moduleId: module.id,\r\n  selector: TYPE_NAME,\r\n  template: `<div class=\"phx-context-menu-btn\" [ngClass]=\"getStyleClasses()\" (click)=\"onMoreButtonClick($event)\">\r\n  <div class=\"icon-img\" *ngIf=\"!isIconURLEmpty()\">\r\n    <img src=\"{{getIconURL()}}\">\r\n  </div>\r\n  <button type=\"button\" class=\"fake\" (focusin)=\"_doFocus($event)\" (blur)=\"_doLostFocus($event)\"></button>\r\n</div>\r\n<phx-context-menu [model]=\"getMenuModel()\" [context]=\"this\" class=\"vertical\" [autoFocus]=\"isAutoFocus()\"></phx-context-menu>\r\n`\r\n})\r\nexport class ContextMenuButton extends AbstractHasData implements OnInit, IContext, OnDestroy, INeedFocus {\r\n\r\n  public static readonly TYPE_NAME: string = TYPE_NAME;\r\n\r\n  // Re-declare field to declare ng @Input.\r\n  // --- from AbstractHasData\r\n  @Input()\r\n  @Option()\r\n  protected dataParent: IHasData;\r\n  @Input()\r\n  @Option()\r\n  protected ignoreParentData: boolean;\r\n  @Input()\r\n  @Option()\r\n  protected data: any;\r\n  @Input()\r\n  @Option()\r\n  protected ignoreParentDisabled: boolean;\r\n  @Input()\r\n  @Option()\r\n  protected delegateHistory: boolean;\r\n  @Input()\r\n  @Option()\r\n  protected onDisabled: Function;\r\n  @Input()\r\n  @Option()\r\n  protected onEnabled: Function;\r\n  @Input()\r\n  @Option()\r\n  protected loadingEnabled: boolean;\r\n  @Input()\r\n  @Option()\r\n  protected i18nKey: string;\r\n  @Input('i18nBypass')\r\n  @Option('i18nBypass')\r\n  protected bypass: boolean;\r\n  @Input()\r\n  protected options: any;\r\n  @Input()\r\n  @Option()\r\n  protected disabled: boolean;\r\n\r\n  // --- from Self\r\n  @Input()\r\n  @I18N()\r\n  @Option()\r\n  protected menuFactory: IMenuModelFactory;\r\n\r\n  @Input()\r\n  @Output()\r\n  private iconURL: string;\r\n  @Input()\r\n  @Output()\r\n  private styleClasses: string[];\r\n  @Input()\r\n  @Option()\r\n  private anchorComponent: any;\r\n  @Input()\r\n  @Option()\r\n  private anchorSelector: string;\r\n  @Input()\r\n  @Option()\r\n  private menuOffsetTop: string;\r\n  @Input()\r\n  @Option()\r\n  private menuOffsetLeft: string;\r\n\r\n  // Re-declare field to declare ng @Output.\r\n  // --- from AbstractHasData\r\n  @Output('phxLoad')\r\n  @Option('load')\r\n  protected loadEvent: EventEmitter<any>;\r\n\r\n  // --- from Self\r\n\r\n  @I18N()\r\n  protected menuModel: MenuModel;\r\n  protected contextMenu: ContextMenu;\r\n  protected needFocusService: NeedFocusService;\r\n  protected autoFocus: boolean;\r\n\r\n  constructor(elementRef: ElementRef, needFocusService: NeedFocusService) {\r\n    super(elementRef);\r\n\r\n    this.needFocusService = needFocusService;\r\n    this.autoFocus = true;\r\n  }\r\n\r\n  public ngOnInit(): void {\r\n    this.init();\r\n  }\r\n\r\n  public ngOnDestroy() {\r\n    if (this.contextMenu != null && typeof this.contextMenu !== 'undefined') {\r\n      this.contextMenu.setContext(null);\r\n    }\r\n  }\r\n\r\n  public init(): void {\r\n    if (this.contextMenu != null && typeof this.contextMenu !== 'undefined') {\r\n      this.contextMenu.setContext(this);\r\n    }\r\n\r\n    if (this.menuFactory !== null && typeof this.menuFactory !== 'undefined') {\r\n      this.menuModel = this.menuFactory.createMenuModel(this);\r\n    }\r\n  }\r\n\r\n  public recreateMenuModel(): void {\r\n    this.menuModel = this.menuFactory.createMenuModel(this);\r\n  }\r\n\r\n  public onMoreButtonClick($event: Event) {\r\n    if (this.contextMenu !== null && typeof this.contextMenu !== 'undefined') {\r\n      if (this.contextMenu.isShow()) {\r\n        setTimeout(()=>{\r\n          this.hideMenu();\r\n        }, 50);\r\n      } else {\r\n        let anchorEl: any = this.elementRef.nativeElement;\r\n\r\n        if (this.anchorComponent !== null && this.anchorComponent !== undefined) {\r\n          anchorEl = this.anchorComponent.elementRef.nativeElement;\r\n        } else if (this.anchorSelector !== null && typeof this.anchorSelector === 'string') {\r\n          let selector: any = $(this.anchorSelector);\r\n\r\n          if (selector.length > 0) {\r\n            anchorEl = selector[0];\r\n          }\r\n        }\r\n\r\n        let offsetTop: number = 0;\r\n        let offsetLeft: number = 0;\r\n\r\n        if (this.menuOffsetTop !== null && typeof this.menuOffsetTop === 'number') {\r\n          offsetTop = this.menuOffsetTop;\r\n        }\r\n        if (this.menuOffsetLeft !== null && typeof this.menuOffsetLeft === 'number') {\r\n          offsetLeft = this.menuOffsetLeft;\r\n        }\r\n\r\n        let top = $(anchorEl).offset().top + $(anchorEl).height() + offsetTop;  \r\n        let leftEllipsisButton = $(this.elementRef.nativeElement).offset().left + offsetLeft;\r\n        let widthEllipsisButton = $(this.elementRef.nativeElement).outerWidth();\r\n        let setLeft = leftEllipsisButton + widthEllipsisButton;  \r\n        this.contextMenu.showAt(top, setLeft);\r\n      }\r\n    }\r\n  }\r\n\r\n  public getContextMenu(): ContextMenu {\r\n    return this.contextMenu;\r\n  }\r\n\r\n  public setContextMenu(menu: ContextMenu): void {\r\n    this.contextMenu = menu;\r\n  }\r\n\r\n  public getMenuModelFactory(): IMenuModelFactory {\r\n    return this.menuFactory;\r\n  }\r\n\r\n  public setMenuModelFactory(menuFactory: IMenuModelFactory): void {\r\n    this.menuFactory = menuFactory;\r\n  }\r\n\r\n  public getMenuModel(): MenuModel {\r\n    return this.menuModel;\r\n  }\r\n\r\n  public isSelfDataDirty(): boolean {\r\n    return false;\r\n  }\r\n\r\n  public selfSaveData(data: any): void {\r\n\r\n  }\r\n\r\n  public selfResetData(): void {\r\n\r\n  }\r\n\r\n  public doPreload(): Promise<any> {     return new Promise((resolve, reject) => {       resolve(null);     });   }  public doLoaded(): void {\r\n\r\n  }\r\n\r\n  public isIconURLEmpty(): boolean {\r\n    if (this.iconURL == null || this.iconURL === undefined) {\r\n      return true;\r\n    }\r\n\r\n    return false;\r\n  }\r\n\r\n  public getIconURL(): string {\r\n    return this.iconURL;\r\n  }\r\n\r\n  public getStyleClasses(): string[] {\r\n    return this.styleClasses;\r\n  }\r\n\r\n  public hideMenu(): void {\r\n    if (this.contextMenu != null && typeof this.contextMenu !== 'undefined') {\r\n      this.contextMenu.hide();\r\n    }\r\n  }\r\n\r\n  public isShowMenu(): boolean {\r\n    return this.contextMenu.isShow();\r\n  }\r\n\r\n  public isAutoFocus(): boolean {\r\n    return this.autoFocus;\r\n  }\r\n\r\n  public onFocus(event: any): void {\r\n  }\r\n\r\n  public onLostFocus(event: any): void {\r\n    this.hideMenu();\r\n  }\r\n\r\n  public _doFocus($event: Event): void {\r\n    // do something when focus\r\n  }\r\n\r\n  public _doLostFocus($event: Event): void {\r\n    if (this.needFocusService !== null) {\r\n        this.needFocusService.resetFocusingComponent(this);\r\n    }\r\n  }\r\n}\r\n"]}