UNPKG

com.phloxui

Version:

PhloxUI Ng2+ Framework

478 lines (477 loc) 32.2 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'; var /** @type {?} */ TYPE_NAME = "phx-context-menu-btn"; var /** @type {?} */ TYPE_PARENT = "parent"; var /** @type {?} */ TYPE_CHILDREN = "children"; var /** @type {?} */ TYPE_DISTANCE = "distance"; var ContextMenuButton = /** @class */ (function (_super) { tslib_1.__extends(ContextMenuButton, _super); function ContextMenuButton(elementRef, needFocusService) { var _this = _super.call(this, elementRef) || this; _this.needFocusService = needFocusService; _this.autoFocus = true; return _this; } /** * @return {?} */ ContextMenuButton.prototype.ngOnInit = /** * @return {?} */ function () { this.init(); }; /** * @return {?} */ ContextMenuButton.prototype.ngOnDestroy = /** * @return {?} */ function () { if (this.contextMenu != null && typeof this.contextMenu !== 'undefined') { this.contextMenu.setContext(null); } }; /** * @return {?} */ ContextMenuButton.prototype.init = /** * @return {?} */ function () { 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 {?} */ ContextMenuButton.prototype.recreateMenuModel = /** * @return {?} */ function () { this.menuModel = this.menuFactory.createMenuModel(this); }; /** * @param {?} $event * @return {?} */ ContextMenuButton.prototype.onMoreButtonClick = /** * @param {?} $event * @return {?} */ function ($event) { var _this = this; if (this.contextMenu !== null && typeof this.contextMenu !== 'undefined') { if (this.contextMenu.isShow()) { setTimeout(function () { _this.hideMenu(); }, 50); } else { var /** @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') { var /** @type {?} */ selector = $(this.anchorSelector); if (selector.length > 0) { anchorEl = selector[0]; } } var /** @type {?} */ offsetTop = 0; var /** @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; } var /** @type {?} */ top_1 = $(anchorEl).offset().top + $(anchorEl).height() + offsetTop; var /** @type {?} */ leftEllipsisButton = $(this.elementRef.nativeElement).offset().left + offsetLeft; var /** @type {?} */ widthEllipsisButton = $(this.elementRef.nativeElement).outerWidth(); var /** @type {?} */ setLeft = leftEllipsisButton + widthEllipsisButton; this.contextMenu.showAt(top_1, setLeft); } } }; /** * @return {?} */ ContextMenuButton.prototype.getContextMenu = /** * @return {?} */ function () { return this.contextMenu; }; /** * @param {?} menu * @return {?} */ ContextMenuButton.prototype.setContextMenu = /** * @param {?} menu * @return {?} */ function (menu) { this.contextMenu = menu; }; /** * @return {?} */ ContextMenuButton.prototype.getMenuModelFactory = /** * @return {?} */ function () { return this.menuFactory; }; /** * @param {?} menuFactory * @return {?} */ ContextMenuButton.prototype.setMenuModelFactory = /** * @param {?} menuFactory * @return {?} */ function (menuFactory) { this.menuFactory = menuFactory; }; /** * @return {?} */ ContextMenuButton.prototype.getMenuModel = /** * @return {?} */ function () { return this.menuModel; }; /** * @return {?} */ ContextMenuButton.prototype.isSelfDataDirty = /** * @return {?} */ function () { return false; }; /** * @param {?} data * @return {?} */ ContextMenuButton.prototype.selfSaveData = /** * @param {?} data * @return {?} */ function (data) { }; /** * @return {?} */ ContextMenuButton.prototype.selfResetData = /** * @return {?} */ function () { }; /** * @return {?} */ ContextMenuButton.prototype.doPreload = /** * @return {?} */ function () { return new Promise(function (resolve, reject) { resolve(null); }); }; /** * @return {?} */ ContextMenuButton.prototype.doLoaded = /** * @return {?} */ function () { }; /** * @return {?} */ ContextMenuButton.prototype.isIconURLEmpty = /** * @return {?} */ function () { if (this.iconURL == null || this.iconURL === undefined) { return true; } return false; }; /** * @return {?} */ ContextMenuButton.prototype.getIconURL = /** * @return {?} */ function () { return this.iconURL; }; /** * @return {?} */ ContextMenuButton.prototype.getStyleClasses = /** * @return {?} */ function () { return this.styleClasses; }; /** * @return {?} */ ContextMenuButton.prototype.hideMenu = /** * @return {?} */ function () { if (this.contextMenu != null && typeof this.contextMenu !== 'undefined') { this.contextMenu.hide(); } }; /** * @return {?} */ ContextMenuButton.prototype.isShowMenu = /** * @return {?} */ function () { return this.contextMenu.isShow(); }; /** * @return {?} */ ContextMenuButton.prototype.isAutoFocus = /** * @return {?} */ function () { return this.autoFocus; }; /** * @param {?} event * @return {?} */ ContextMenuButton.prototype.onFocus = /** * @param {?} event * @return {?} */ function (event) { }; /** * @param {?} event * @return {?} */ ContextMenuButton.prototype.onLostFocus = /** * @param {?} event * @return {?} */ function (event) { this.hideMenu(); }; /** * @param {?} $event * @return {?} */ ContextMenuButton.prototype._doFocus = /** * @param {?} $event * @return {?} */ function ($event) { // do something when focus }; /** * @param {?} $event * @return {?} */ ContextMenuButton.prototype._doLostFocus = /** * @param {?} $event * @return {?} */ function ($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)\">\n <div class=\"icon-img\" *ngIf=\"!isIconURLEmpty()\">\n <img src=\"{{getIconURL()}}\">\n </div>\n <button type=\"button\" class=\"fake\" (focusin)=\"_doFocus($event)\" (blur)=\"_doLostFocus($event)\"></button>\n</div>\n<phx-context-menu [model]=\"getMenuModel()\" [context]=\"this\" class=\"vertical\" [autoFocus]=\"isAutoFocus()\"></phx-context-menu>\n" },] }, ]; /** @nocollapse */ ContextMenuButton.ctorParameters = function () { return [ { 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); return ContextMenuButton; }(AbstractHasData)); export { ContextMenuButton }; 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"]}