UNPKG

com.phloxui

Version:

PhloxUI Ng2+ Framework

192 lines (191 loc) 17.7 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 const /** @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 */ export class AbstractMenuItem extends AbstractI18NApplicable { /** * @param {?} needFocusService */ constructor(needFocusService) { super(); this.needFocusService = needFocusService; this.clickEvent = new EventEmitter(); this.beforeClickEvent = new EventEmitter(); } /** * @param {?} $event * @param {?=} fireEvent * @return {?} */ onClick($event, fireEvent) { if (fireEvent === null || fireEvent === undefined) { fireEvent = true; } EventUtils.handleBrowserEvent(this, 'beforeClickEvent', $event, fireEvent, ($event) => { // doEvent this.emitActionPerform($event); }, ($event) => { // emitBeforeEvent this.emitBeforeClickEvent($event); }, ($event) => { // emitAfterEvent this.emitClickEvent($event); }, ($event) => { // doPrevented }); } /** * @param {?=} $event * @return {?} */ emitActionPerform($event) { if (this.model !== null && typeof this.model !== 'undefined') { if (this.model.actionPerformedHandler !== null && typeof this.model.actionPerformedHandler === 'function') { let /** @type {?} */ data = null; let /** @type {?} */ ev = EventUtils.newCustomEvent(ACTION_PERFORM, this, data, $event); this.model.actionPerformedHandler.call(null, ev); let /** @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 {?} */ emitBeforeClickEvent($event) { let /** @type {?} */ eventData = null; // emit event let /** @type {?} */ data = eventData; let /** @type {?} */ ev = EventUtils.newCustomEvent(BEFORE_CLICK_EVENT, this, data, $event); if (this.beforeClickEvent !== null && this.beforeClickEvent !== undefined) { this.beforeClickEvent.emit(ev); } } /** * @param {?=} $event * @return {?} */ emitClickEvent($event) { let /** @type {?} */ eventData = null; // emit event let /** @type {?} */ data = eventData; let /** @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 {?} */ getMenu() { 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 {?} */ setMenu(menu) { this.menu = menu; } /** * <p style="text-indent: 1em;"> * Get the <code>model</code> of <code>this</code> <code>menu item</code>. * </p> * @return {?} */ getModel() { 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 {?} */ setModel(model) { this.model = model; } /** * @return {?} */ getClickEvent() { return this.clickEvent; } /** * @param {?} event * @return {?} */ setClickEvent(event) { this.clickEvent = event; } /** * @return {?} */ getBeforeClickEvent() { return this.beforeClickEvent; } /** * @param {?} event * @return {?} */ setBeforeClickEvent(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); 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"]}