UNPKG

com.phloxui

Version:

PhloxUI Ng2+ Framework

254 lines (253 loc) 19.8 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes} checked by tsc */ import * as tslib_1 from "tslib"; import { EventEmitter } from '@angular/core'; import { AbstractI18NApplicable } from '../share/AbstractI18NApplicable'; import { EventUtils } from '../share/utils/EventUtils'; import { Option } from '../decorator/Option.decorator'; import { CLICK_EVENT, BEFORE_CLICK_EVENT } from '../share/CustomEventType'; export var /** @type {?} */ ACTION_PERFORM = 'actionPerform'; /** * <p style="text-indent: 2em;"> * An abstract base class for <code>menu item</code> component. This class provides you a default [[onClick]] event handler which * automatically call the [[MenuItemModel.actionPerformedHandler]] if specified. It also resets the current focusing component if * [[MenuItemModel.autoResetFocus]] is set to <code>true</code>. A <code>menu item</code> can be, but not necessary, in a parent * <code>menu</code>. It is up to each component implementation which is a sub class of this class to decide that it is required * to allow a <code>menu item</code> can be displayed standalone outside the parent <code>menu</code> or not. * </p> * * @author shiorin, tee4cute * @see [[MenuItemModel]] * @see [[AbstractMenu]] * @abstract */ var AbstractMenuItem = /** @class */ (function (_super) { tslib_1.__extends(AbstractMenuItem, _super); function AbstractMenuItem(needFocusService) { var _this = _super.call(this) || this; _this.needFocusService = needFocusService; _this.clickEvent = new EventEmitter(); _this.beforeClickEvent = new EventEmitter(); return _this; } /** * @param {?} $event * @param {?=} fireEvent * @return {?} */ AbstractMenuItem.prototype.onClick = /** * @param {?} $event * @param {?=} fireEvent * @return {?} */ function ($event, fireEvent) { var _this = this; if (fireEvent === null || fireEvent === undefined) { fireEvent = true; } EventUtils.handleBrowserEvent(this, 'beforeClickEvent', $event, fireEvent, function ($event) { // doEvent // doEvent _this.emitActionPerform($event); }, function ($event) { // emitBeforeEvent // emitBeforeEvent _this.emitBeforeClickEvent($event); }, function ($event) { // emitAfterEvent // emitAfterEvent _this.emitClickEvent($event); }, function ($event) { // doPrevented }); }; /** * @param {?=} $event * @return {?} */ AbstractMenuItem.prototype.emitActionPerform = /** * @param {?=} $event * @return {?} */ function ($event) { if (this.model !== null && typeof this.model !== 'undefined') { if (this.model.actionPerformedHandler !== null && typeof this.model.actionPerformedHandler === 'function') { var /** @type {?} */ data = null; var /** @type {?} */ ev = EventUtils.newCustomEvent(ACTION_PERFORM, this, data, $event); this.model.actionPerformedHandler.call(null, ev); var /** @type {?} */ autoFocus = true; if (this.model.autoResetFocus !== null && typeof this.model.autoResetFocus !== 'undefined') { autoFocus = this.model.autoResetFocus; } if (autoFocus) { if (this.needFocusService !== null && typeof this.needFocusService !== 'undefined') { this.needFocusService.resetFocusingComponent(ev); } } } } }; /** * @param {?=} $event * @return {?} */ AbstractMenuItem.prototype.emitBeforeClickEvent = /** * @param {?=} $event * @return {?} */ function ($event) { var /** @type {?} */ eventData = null; // emit event var /** @type {?} */ data = eventData; var /** @type {?} */ ev = EventUtils.newCustomEvent(BEFORE_CLICK_EVENT, this, data, $event); if (this.beforeClickEvent !== null && this.beforeClickEvent !== undefined) { this.beforeClickEvent.emit(ev); } }; /** * @param {?=} $event * @return {?} */ AbstractMenuItem.prototype.emitClickEvent = /** * @param {?=} $event * @return {?} */ function ($event) { var /** @type {?} */ eventData = null; // emit event var /** @type {?} */ data = eventData; var /** @type {?} */ ev = EventUtils.newCustomEvent(CLICK_EVENT, this, data, $event); if (this.clickEvent !== null && this.clickEvent !== undefined) { this.clickEvent.emit(ev); } }; /** * <p style="text-indent: 1em;"> * Get the parent <code>memu</code> associated with <code>this</code> <code>menu item</code>. * </p> * @return {?} */ AbstractMenuItem.prototype.getMenu = /** * <p style="text-indent: 1em;"> * Get the parent <code>memu</code> associated with <code>this</code> <code>menu item</code>. * </p> * @return {?} */ function () { return this.menu; }; /** * <p style="text-indent: 1em;"> * Set a parent <code>menu</code> associated with <code>this</code> <code>menu item</code>. * </p> * @param {?} menu * @return {?} */ AbstractMenuItem.prototype.setMenu = /** * <p style="text-indent: 1em;"> * Set a parent <code>menu</code> associated with <code>this</code> <code>menu item</code>. * </p> * @param {?} menu * @return {?} */ function (menu) { this.menu = menu; }; /** * <p style="text-indent: 1em;"> * Get the <code>model</code> of <code>this</code> <code>menu item</code>. * </p> * @return {?} */ AbstractMenuItem.prototype.getModel = /** * <p style="text-indent: 1em;"> * Get the <code>model</code> of <code>this</code> <code>menu item</code>. * </p> * @return {?} */ function () { return this.model; }; /** * <p style="text-indent: 1em;"> * Set a <code>model</code> of <code>this</code> <code>menu item</code>. * </p> * @param {?} model * @return {?} */ AbstractMenuItem.prototype.setModel = /** * <p style="text-indent: 1em;"> * Set a <code>model</code> of <code>this</code> <code>menu item</code>. * </p> * @param {?} model * @return {?} */ function (model) { this.model = model; }; /** * @return {?} */ AbstractMenuItem.prototype.getClickEvent = /** * @return {?} */ function () { return this.clickEvent; }; /** * @param {?} event * @return {?} */ AbstractMenuItem.prototype.setClickEvent = /** * @param {?} event * @return {?} */ function (event) { this.clickEvent = event; }; /** * @return {?} */ AbstractMenuItem.prototype.getBeforeClickEvent = /** * @return {?} */ function () { return this.beforeClickEvent; }; /** * @param {?} event * @return {?} */ AbstractMenuItem.prototype.setBeforeClickEvent = /** * @param {?} event * @return {?} */ function (event) { this.beforeClickEvent = event; }; tslib_1.__decorate([ Option('click'), tslib_1.__metadata("design:type", EventEmitter) ], AbstractMenuItem.prototype, "clickEvent", void 0); tslib_1.__decorate([ Option('beforeClick'), tslib_1.__metadata("design:type", EventEmitter) ], AbstractMenuItem.prototype, "beforeClickEvent", void 0); return AbstractMenuItem; }(AbstractI18NApplicable)); export { AbstractMenuItem }; function AbstractMenuItem_tsickle_Closure_declarations() { /** @type {?} */ AbstractMenuItem.prototype.model; /** @type {?} */ AbstractMenuItem.prototype.menu; /** @type {?} */ AbstractMenuItem.prototype.needFocusService; /** @type {?} */ AbstractMenuItem.prototype.clickEvent; /** @type {?} */ AbstractMenuItem.prototype.beforeClickEvent; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"AbstractMenuItem.js","sourceRoot":"ng://com.phloxui/","sources":["lib/component/AbstractMenuItem.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, ElementRef, Input, EventEmitter } from '@angular/core';\n\nimport { AbstractMenu } from './AbstractMenu';\n\nimport { NeedFocusService } from '../service/NeedFocusService.service';\n\nimport { AbstractI18NApplicable } from '../share/AbstractI18NApplicable';\n\nimport { MenuItemModel } from './model/MenuItemModel';\nimport { EventUtils } from '../share/utils/EventUtils';\nimport { Option } from '../decorator/Option.decorator';\nimport { CLICK_EVENT, BEFORE_CLICK_EVENT } from '../share/CustomEventType';\n\nexport const ACTION_PERFORM: string = 'actionPerform';\n\n/**\n * <p style=\"text-indent: 2em;\">\n * An abstract base class for <code>menu item</code> component. This class provides you a default [[onClick]] event handler which\n * automatically call the [[MenuItemModel.actionPerformedHandler]] if specified. It also resets the current focusing component if\n * [[MenuItemModel.autoResetFocus]] is set to <code>true</code>. A <code>menu item</code> can be, but not necessary, in a parent\n * <code>menu</code>. It is up to each component implementation which is a sub class of this class to decide that it is required\n * to allow a <code>menu item</code> can be displayed standalone outside the parent <code>menu</code> or not.\n * </p>\n *\n * @author shiorin, tee4cute\n * @see [[MenuItemModel]]\n * @see [[AbstractMenu]]\n */\nexport abstract class AbstractMenuItem extends AbstractI18NApplicable {\n\n  // @Option()\n  // @I18N()\n  protected model: MenuItemModel;\n  protected menu: AbstractMenu;\n  protected needFocusService: NeedFocusService;\n\n  @Option('click')\n  protected clickEvent: EventEmitter<any>;\n  @Option('beforeClick')\n  protected beforeClickEvent: EventEmitter<any>;\n\n  constructor(needFocusService: NeedFocusService) {\n    super();\n\n    this.needFocusService = needFocusService;\n    this.clickEvent = new EventEmitter();\n    this.beforeClickEvent = new EventEmitter();\n  }\n\n  public onClick($event: MouseEvent, fireEvent?: boolean): void {\n\n    if (fireEvent === null || fireEvent === undefined) {\n      fireEvent = true;\n    }\n\n    EventUtils.handleBrowserEvent(this, 'beforeClickEvent', $event, fireEvent, ($event: Event) => {\n      // doEvent\n      this.emitActionPerform($event);\n    }, ($event: Event) => {\n      // emitBeforeEvent\n      this.emitBeforeClickEvent($event);\n    }, ($event: Event) => {\n      // emitAfterEvent\n      this.emitClickEvent($event);\n    }, ($event: Event) => {\n      // doPrevented\n    });\n  }\n\n  public emitActionPerform($event?: any): void {\n    if (this.model !== null && typeof this.model !== 'undefined') {\n      if (this.model.actionPerformedHandler !== null && typeof this.model.actionPerformedHandler === 'function') {\n\n        let data: any = null;\n        let ev = EventUtils.newCustomEvent(ACTION_PERFORM, this, data, $event);\n\n        this.model.actionPerformedHandler.call(null, ev);\n\n        let autoFocus = true;\n        if (this.model.autoResetFocus !== null && typeof this.model.autoResetFocus !== 'undefined') {\n          autoFocus = this.model.autoResetFocus;\n        }\n        if (autoFocus) {\n          if (this.needFocusService !== null && typeof this.needFocusService !== 'undefined') {\n            this.needFocusService.resetFocusingComponent(ev);\n          }\n        }\n      }\n    }\n  }\n\n  protected emitBeforeClickEvent($event?: any): void {\n    let eventData: any = null;\n\n    // emit event\n    let data: any = eventData;\n    let ev = EventUtils.newCustomEvent(BEFORE_CLICK_EVENT, this, data, $event);\n\n    if (this.beforeClickEvent !== null && this.beforeClickEvent !== undefined) {\n      this.beforeClickEvent.emit(ev);\n    }\n  }\n\n  protected emitClickEvent($event?: any): void {\n    let eventData: any = null;\n\n    // emit event\n    let data: any = eventData;\n    let ev = EventUtils.newCustomEvent(CLICK_EVENT, this, data, $event);\n\n    if (this.clickEvent !== null && this.clickEvent !== undefined) {\n      this.clickEvent.emit(ev);\n    }\n  }\n\n  /**\n   * <p style=\"text-indent: 1em;\">\n   * Get the parent <code>memu</code> associated with <code>this</code> <code>menu item</code>.\n   * </p>\n   */\n  public getMenu(): AbstractMenu {\n    return this.menu;\n  }\n\n  /**\n   * <p style=\"text-indent: 1em;\">\n   * Set a parent <code>menu</code> associated with <code>this</code> <code>menu item</code>.\n   * </p>\n   */\n  public setMenu(menu: AbstractMenu): void {\n    this.menu = menu;\n  }\n\n  /**\n   * <p style=\"text-indent: 1em;\">\n   * Get the <code>model</code> of <code>this</code> <code>menu item</code>.\n   * </p>\n   */\n  public getModel(): MenuItemModel {\n    return this.model;\n  }\n\n  /**\n   * <p style=\"text-indent: 1em;\">\n   * Set a <code>model</code> of <code>this</code> <code>menu item</code>.\n   * </p>\n   */\n  public setModel(model: MenuItemModel): void {\n    this.model = model;\n  }\n\n  public getClickEvent(): EventEmitter<any> {\n    return this.clickEvent;\n  }\n\n  public setClickEvent(event: EventEmitter<any>): void {\n    this.clickEvent = event;\n  }\n\n  public getBeforeClickEvent(): EventEmitter<any> {\n    return this.beforeClickEvent;\n  }\n\n  public setBeforeClickEvent(event: EventEmitter<any>): void {\n    this.beforeClickEvent = event;\n  }\n}\n"]}