com.phloxui
Version:
PhloxUI Ng2+ Framework
192 lines (191 loc) • 17.7 kB
JavaScript
/**
* @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"]}