UNPKG

com.phloxui

Version:

PhloxUI Ng2+ Framework

370 lines (369 loc) 31.8 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes} checked by tsc */ import * as tslib_1 from "tslib"; import { Component, Input, Output, EventEmitter, ElementRef } from '@angular/core'; import { ActionModel, ActionModelMenu } from '../model/models'; import { ContextMenu } from '../ContextMenu.component'; import { DefaultActionModelMenuFactory } from './DefaultActionModelMenuFactory'; import { Option } from '../../decorator/Option.decorator'; import { I18N } from '../../decorator/I18N.decorator'; import { AbstractI18NApplicable } from '../../share/AbstractI18NApplicable'; import { NeedFocusService } from '../../service/NeedFocusService.service'; const /** @type {?} */ TYPE_NAME = "phx-action-btn"; export class ActionButton extends AbstractI18NApplicable { /** * @param {?} elementRef * @param {?} needFocusService */ constructor(elementRef, needFocusService) { super(); this.ACTION_CONTEXT_MENU_TOP_REDUCE = 5; this.clickEvent = new EventEmitter(); this.elementRef = elementRef; this.needFocusService = needFocusService; } /** * @return {?} */ ngOnInit() { if (!this.model && this.options && this.options['model']) { this.model = new ActionModel(); this.model.setOptions(this.options['model']); } this.init(); } /** * @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); } else { this.menuFactory = new DefaultActionModelMenuFactory(); this.menuModel = this.menuFactory.createMenuModel(this); } } /** * @param {?} $event * @return {?} */ doFocus($event) { $(this.elementRef.nativeElement).find("div > button").focus(); } /** * @param {?} $event * @return {?} */ doBlur($event) { $(this.elementRef.nativeElement).find("div > button").blur(); } /** * @param {?} $event * @return {?} */ onActionBtnClicked($event) { if (this.model === null || typeof this.model === 'undefined') { return; } this.doFocus($event); if (this.contextMenu !== null && typeof this.contextMenu !== 'undefined') { this.contextMenu.hide(); } if (this.model.actionPerformedHandler !== null && typeof this.model.actionPerformedHandler !== 'undefined') { this.model.actionPerformedHandler.call(null, $event); } else { this.onMoreBtnClicked($event); } this.clickEvent.emit($event); } /** * @param {?} $event * @return {?} */ onMoreBtnClicked($event) { if (this.model === null || typeof this.model === 'undefined') { return; } this.doFocus($event); if (this.model.constructor.name === 'ActionModelMenu') { $event.stopPropagation(); if (this.menuFactory !== null && typeof this.menuFactory !== 'undefined') { this.menuModel = this.menuFactory.createMenuModel(this); } if (this.contextMenu !== null && typeof this.contextMenu !== 'undefined') { if (this.contextMenu.isShow()) { this.contextMenu.hide(); } else { let /** @type {?} */ scrollTop = $(this.elementRef.nativeElement).scrollTop(); let /** @type {?} */ top = $(this.elementRef.nativeElement).offset().top + $(this.elementRef.nativeElement).height(); let /** @type {?} */ left = $(this.elementRef.nativeElement).offset().left; top = top - this.ACTION_CONTEXT_MENU_TOP_REDUCE; this.contextMenu.showAt(top, left); } } } } /** * @return {?} */ _isShowMoreBtn() { if (this.model === null || typeof this.model === 'undefined') { return false; } if (this.model instanceof ActionModelMenu) { return true; } return false; } /** * @return {?} */ _hasIcon() { if (this.model !== null && this.model != undefined) { if (this.model.iconURL !== null && this.model.iconURL != undefined) { return true; } } return false; } /** * @return {?} */ getClickEvent() { return this.clickEvent; } /** * @param {?} event * @return {?} */ setClickedEvent(event) { this.clickEvent = event; } /** * @param {?} context * @return {?} */ isShow(context) { if (this.model.isShow === null) { return false; } if (typeof this.model.isShow !== 'function') { return false; } return this.model.isShow(context); } /** * @param {?} context * @return {?} */ isEnabled(context) { if (this.model.isEnabled === null) { return false; } if (typeof this.model.isEnabled !== 'function') { return false; } return this.model.isEnabled(context); } /** * @return {?} */ getContextMenu() { return this.contextMenu; } /** * @param {?} menu * @return {?} */ setContextMenu(menu) { this.contextMenu = menu; if (this.contextMenu) { if (this.options && this.options['menu']) { this.contextMenu.setOptions(this.options['menu']); } if (this.i18nValue && this.i18nValue['menu']) { this.contextMenu.applyI18N(this.i18nValue['menu']); } } } /** * @return {?} */ getMenuModelFactory() { return this.menuFactory; } /** * @param {?} menuFactory * @return {?} */ setMenuModelFactory(menuFactory) { this.menuFactory = menuFactory; } /** * @return {?} */ hasModel() { if (this.model !== null && this.model != undefined) { return true; } return false; } /** * @return {?} */ getModel() { return this.model; } /** * @param {?} model * @return {?} */ setModel(model) { this.model = model; if (this.menuFactory !== null && typeof this.menuFactory !== 'undefined') { this.menuModel = this.menuFactory.createMenuModel(this); } } /** * @return {?} */ getMenuModel() { return this.menuModel; } /** * @param {?} $event * @return {?} */ focusing($event) { this.needFocusService.setFocusingComponent(this, $event); } /** * @param {?} $event * @return {?} */ onLostFocusing($event) { if (this._itemLostFocusingTimeout !== null && typeof this._itemLostFocusingTimeout !== 'undefined') { clearTimeout(this._itemLostFocusingTimeout); this._itemLostFocusingTimeout = null; } this._itemLostFocusingTimeout = setTimeout(() => { this.doBlur($event); this.needFocusService.resetFocusingComponent($event); }, 150); } /** * @param {?} event * @return {?} */ onLostFocus(event) { if (this.contextMenu !== null && typeof this.contextMenu !== 'undefined') { this.contextMenu.hide(); } } /** * @param {?} event * @return {?} */ onFocus(event) { } } ActionButton.TYPE_NAME = TYPE_NAME; ActionButton.decorators = [ { type: Component, args: [{ moduleId: module.id, selector: TYPE_NAME, template: `<div class="phx-action-button" *ngIf="hasModel()"> <div class="group" [class.more]="_isShowMoreBtn()" *ngIf="!_isShowMoreBtn()"> <button (focusin)="focusing($event)" (blur)="onLostFocusing($event)" (click)="onActionBtnClicked($event)"> <img *ngIf="_hasIcon()" src="{{getModel().iconURL}}" title="{{getModel().label}}"> {{getModel().label}} </button> </div> <div class="more-menu" *ngIf="_isShowMoreBtn()"> <button (focusin)="focusing($event)" (blur)="onLostFocusing($event)" (click)="onMoreBtnClicked($event)"> <div class="wrapper"> <div> {{getModel().label}} </div> <div> <div class="icon-arrow-down"></div> </div> </div> </button> </div> </div> <phx-context-menu *ngIf="getMenuModel() !== null" [model]="getMenuModel()" [context]="this" class="vertical"></phx-context-menu> ` },] }, ]; /** @nocollapse */ ActionButton.ctorParameters = () => [ { type: ElementRef, }, { type: NeedFocusService, }, ]; ActionButton.propDecorators = { "menuFactory": [{ type: Input },], "model": [{ type: Input },], "options": [{ type: Input },], "clickEvent": [{ type: Output, args: ['phxClick',] },], }; tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", Object) ], ActionButton.prototype, "menuFactory", void 0); tslib_1.__decorate([ I18N(), Option(), tslib_1.__metadata("design:type", ActionModel) ], ActionButton.prototype, "model", void 0); tslib_1.__decorate([ Option('click'), tslib_1.__metadata("design:type", EventEmitter) ], ActionButton.prototype, "clickEvent", void 0); tslib_1.__decorate([ I18N('menu'), Option('menu'), tslib_1.__metadata("design:type", ContextMenu) ], ActionButton.prototype, "contextMenu", void 0); function ActionButton_tsickle_Closure_declarations() { /** @type {!Array<{type: !Function, args: (undefined|!Array<?>)}>} */ ActionButton.decorators; /** * @nocollapse * @type {function(): !Array<(null|{type: ?, decorators: (undefined|!Array<{type: !Function, args: (undefined|!Array<?>)}>)})>} */ ActionButton.ctorParameters; /** @type {!Object<string,!Array<{type: !Function, args: (undefined|!Array<?>)}>>} */ ActionButton.propDecorators; /** @type {?} */ ActionButton.TYPE_NAME; /** @type {?} */ ActionButton.prototype.ACTION_CONTEXT_MENU_TOP_REDUCE; /** @type {?} */ ActionButton.prototype.menuFactory; /** @type {?} */ ActionButton.prototype.model; /** @type {?} */ ActionButton.prototype.options; /** @type {?} */ ActionButton.prototype.clickEvent; /** @type {?} */ ActionButton.prototype.contextMenu; /** @type {?} */ ActionButton.prototype.menuModel; /** @type {?} */ ActionButton.prototype.elementRef; /** @type {?} */ ActionButton.prototype.needFocusService; /** @type {?} */ ActionButton.prototype._itemLostFocusingTimeout; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ActionButton.component.js","sourceRoot":"ng://com.phloxui/","sources":["lib/component/editor/ActionButton.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, Output, EventEmitter, OnInit, ElementRef } from '@angular/core';\nimport { ActionModel, ActionModelMenu, MenuModel } from '../model/models';\nimport { IContext } from '../IContext';\nimport { IHasModel } from '../IHasModel';\nimport { INeedFocus } from '../INeedFocus';\nimport { ContextMenu } from '../ContextMenu.component';\nimport { IMenuModelFactory } from '../IMenuModelFactory';\nimport { DefaultActionModelMenuFactory } from './DefaultActionModelMenuFactory';\nimport { Option } from '../../decorator/Option.decorator';\nimport { I18N } from '../../decorator/I18N.decorator';\nimport { AbstractI18NApplicable } from '../../share/AbstractI18NApplicable';\nimport { NeedFocusService } from '../../service/NeedFocusService.service';\n\ndeclare var $: any;\n\nconst TYPE_NAME: string = \"phx-action-btn\";\n\n@Component({\n  moduleId: module.id,\n  selector: TYPE_NAME,\n  template: `<div class=\"phx-action-button\" *ngIf=\"hasModel()\">\n\t<div class=\"group\" [class.more]=\"_isShowMoreBtn()\" *ngIf=\"!_isShowMoreBtn()\">\n\t\t<button (focusin)=\"focusing($event)\" (blur)=\"onLostFocusing($event)\" (click)=\"onActionBtnClicked($event)\">\n\t\t\t<img *ngIf=\"_hasIcon()\" src=\"{{getModel().iconURL}}\" title=\"{{getModel().label}}\">\n\t\t\t{{getModel().label}}\n\t\t</button>\n\t</div>\n\t<div class=\"more-menu\" *ngIf=\"_isShowMoreBtn()\">\n\t\t<button (focusin)=\"focusing($event)\" (blur)=\"onLostFocusing($event)\" (click)=\"onMoreBtnClicked($event)\">\n\t\t\t<div class=\"wrapper\">\n\t\t\t\t<div>\n\t\t\t\t\t{{getModel().label}}\n\t\t\t\t</div>\n\t\t\t\t<div>\n\t\t\t\t\t<div class=\"icon-arrow-down\"></div>\n\t\t\t\t</div>\n\t\t\t</div>\n\t\t</button>\n\t</div>\n</div>\n<phx-context-menu *ngIf=\"getMenuModel() !== null\" [model]=\"getMenuModel()\" [context]=\"this\" class=\"vertical\"></phx-context-menu>\n`\n})\nexport class ActionButton extends AbstractI18NApplicable implements OnInit, IContext, IHasModel, INeedFocus {\n\n  public static readonly TYPE_NAME: string = TYPE_NAME;\n\n  private ACTION_CONTEXT_MENU_TOP_REDUCE: number = 5; // as pixel\n  @Input()\n  @Option()\n  private menuFactory: IMenuModelFactory;\n  @Input()\n  @I18N()\n  @Option()\n  private model: ActionModel;\n  @Input()\n  protected options: any;\n  @Option('click')\n  @Output('phxClick')\n  private clickEvent: EventEmitter<any>;\n  // contextMenu & menuModel is dynamically created.\n  // ! TODO Why \"contextMenu\" is not bound ty @ViewChild?\n  @I18N('menu')\n  @Option('menu')\n  private contextMenu: ContextMenu;\n  private menuModel: MenuModel;\n\n  private elementRef: ElementRef;\n  private needFocusService: NeedFocusService;\n  private _itemLostFocusingTimeout: any;\n\n  constructor(elementRef: ElementRef, needFocusService: NeedFocusService) {\n    super();\n    this.clickEvent = new EventEmitter();\n    this.elementRef = elementRef;\n    this.needFocusService = needFocusService;\n  }\n\n  public ngOnInit(): void {\n    if (!this.model && this.options && this.options['model']) {\n      this.model = new ActionModel();\n\n      this.model.setOptions(this.options['model']);\n    }\n\n    this.init();\n  }\n\n  public init(): void {\n    if (this.contextMenu != null && typeof this.contextMenu !== 'undefined') {\n      this.contextMenu.setContext(this);\n    }\n    if (this.menuFactory !== null && typeof this.menuFactory !== 'undefined') {\n      this.menuModel = this.menuFactory.createMenuModel(this);\n    } else {\n      this.menuFactory = new DefaultActionModelMenuFactory();\n      this.menuModel = this.menuFactory.createMenuModel(this);\n    }\n  }\n\n  protected doFocus($event: Event): void {\n    $(this.elementRef.nativeElement).find(\"div > button\").focus();\n  }\n\n  protected doBlur($event: Event): void {\n    $(this.elementRef.nativeElement).find(\"div > button\").blur();\n  }\n\n  public onActionBtnClicked($event: Event): void {\n    if (this.model === null || typeof this.model === 'undefined') {\n      return;\n    }\n\n    this.doFocus($event);\n\n    if (this.contextMenu !== null && typeof this.contextMenu !== 'undefined') {\n      this.contextMenu.hide();\n    }\n    if (this.model.actionPerformedHandler !== null && typeof this.model.actionPerformedHandler !== 'undefined') {\n      this.model.actionPerformedHandler.call(null, $event);\n    } else {\n      this.onMoreBtnClicked($event);\n    }\n\n    this.clickEvent.emit($event);\n  }\n\n  public onMoreBtnClicked($event: Event): void {\n    if (this.model === null || typeof this.model === 'undefined') {\n      return;\n    }\n\n    this.doFocus($event);\n\n    if (this.model.constructor.name === 'ActionModelMenu') {\n      $event.stopPropagation();\n\n      if (this.menuFactory !== null && typeof this.menuFactory !== 'undefined') {\n        this.menuModel = this.menuFactory.createMenuModel(this);\n      }\n\n      if (this.contextMenu !== null && typeof this.contextMenu !== 'undefined') {\n        if (this.contextMenu.isShow()) {\n          this.contextMenu.hide();\n        } else {\n          let scrollTop = $(this.elementRef.nativeElement).scrollTop();\n          let top = $(this.elementRef.nativeElement).offset().top + $(this.elementRef.nativeElement).height();\n          let left = $(this.elementRef.nativeElement).offset().left;\n          top = top - this.ACTION_CONTEXT_MENU_TOP_REDUCE;\n\n          this.contextMenu.showAt(top, left);\n        }\n      }\n    }\n  }\n\n  public _isShowMoreBtn(): boolean {\n    if (this.model === null || typeof this.model === 'undefined') {\n      return false;\n    }\n\n    if (this.model instanceof ActionModelMenu) {\n      return true;\n    }\n\n    return false;\n  }\n\n  public _hasIcon(): boolean {\n    if (this.model !== null && this.model != undefined) {\n      if (this.model.iconURL !== null && this.model.iconURL != undefined) {\n        return true;\n      }\n    }\n\n    return false;\n  }\n\n  public getClickEvent(): EventEmitter<any> {\n    return this.clickEvent;\n  }\n\n  public setClickedEvent(event: EventEmitter<any>): void {\n    this.clickEvent = event;\n  }\n\n  public isShow(context: IContext): boolean {\n    if (this.model.isShow === null) {\n      return false;\n    }\n    if (typeof this.model.isShow !== 'function') {\n      return false\n    }\n    return this.model.isShow(context);\n  }\n\n  public isEnabled(context: IContext): boolean {\n    if (this.model.isEnabled === null) {\n      return false;\n    }\n    if (typeof this.model.isEnabled !== 'function') {\n      return false\n    }\n    return this.model.isEnabled(context);\n  }\n\n  public getContextMenu(): ContextMenu {\n    return this.contextMenu;\n  }\n\n  public setContextMenu(menu: ContextMenu): void {\n    this.contextMenu = menu;\n\n    if (this.contextMenu) {\n      if (this.options && this.options['menu']) {\n        this.contextMenu.setOptions(this.options['menu']);\n      }\n      if (this.i18nValue && this.i18nValue['menu']) {\n        this.contextMenu.applyI18N(this.i18nValue['menu']);\n      }\n    }\n  }\n\n  public getMenuModelFactory(): IMenuModelFactory {\n    return this.menuFactory;\n  }\n\n  public setMenuModelFactory(menuFactory: IMenuModelFactory): void {\n    this.menuFactory = menuFactory;\n  }\n\n  public hasModel(): boolean {\n    if (this.model !== null && this.model != undefined) {\n      return true;\n    }\n\n    return false;\n  }\n\n  public getModel(): any {\n    return this.model;\n  }\n\n  public setModel(model: any): void {\n    this.model = model;\n    if (this.menuFactory !== null && typeof this.menuFactory !== 'undefined') {\n      this.menuModel = this.menuFactory.createMenuModel(this);\n    }\n  }\n\n  public getMenuModel(): MenuModel {\n    return this.menuModel;\n  }\n\n  public focusing($event: Event): void {\n    this.needFocusService.setFocusingComponent(this, $event);\n  }\n\n  public onLostFocusing($event: Event): void {\n    if (this._itemLostFocusingTimeout !== null && typeof this._itemLostFocusingTimeout !== 'undefined') {\n      clearTimeout(this._itemLostFocusingTimeout);\n      this._itemLostFocusingTimeout = null;\n    }\n\n    this._itemLostFocusingTimeout = setTimeout(() => {\n      this.doBlur($event);\n      this.needFocusService.resetFocusingComponent($event);\n    }, 150);\n  }\n\n  public onLostFocus(event: any): void {\n    if (this.contextMenu !== null && typeof this.contextMenu !== 'undefined') {\n      this.contextMenu.hide();\n    }\n  }\n\n  public onFocus(event: any): void {\n\n  }\n}\n"]}