UNPKG

com.phloxui

Version:

PhloxUI Ng2+ Framework

330 lines (329 loc) 30.6 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes} checked by tsc */ import * as tslib_1 from "tslib"; import { EventEmitter } from '@angular/core'; import { Option } from '../decorator/Option.decorator'; import { EventUtils } from '../share/utils/EventUtils'; import { FOCUS_EVENT, BEFORE_LOST_FOCUS_EVENT, BEFORE_FOCUS_EVENT } from '../share/CustomEventType'; import { AbstractI18NApplicable } from '../share/AbstractI18NApplicable'; /** * <p style="text-indent: 2em;"> * An abstract base class of clickable component (such as buttons) playing <code>ripple</code> effect when it is clicked. * </p> * * @author shiorin, tee4cute * @abstract */ export class AbstractRippleButton extends AbstractI18NApplicable { /** * @param {?} phloxAppService * @param {?} needFocusService */ constructor(phloxAppService, needFocusService) { super(); if (phloxAppService !== null && typeof phloxAppService !== 'undefined') { this.phloxAppService = phloxAppService; } this.needFocusService = needFocusService; this.beforeLostFocusEvent = new EventEmitter(); this.beforeFocusEvent = new EventEmitter(); this.lostFocusEvent = new EventEmitter(); this.focusEvent = new EventEmitter(); } /** * @return {?} */ get app() { if (this.phloxAppService === null || typeof this.phloxAppService === 'undefined') { return null; } return this.phloxAppService.getInstance(); } /** * @return {?} */ getApplication() { return this.app; } /** * @param {?=} $event * @return {?} */ emitBeforeFocusEvent($event) { // emit event let /** @type {?} */ data = null; let /** @type {?} */ ev = EventUtils.newCustomEvent(BEFORE_FOCUS_EVENT, this, data, $event); if (this.beforeFocusEvent !== null && this.beforeFocusEvent !== undefined) { this.beforeFocusEvent.emit(ev); } } /** * @param {?} $event * @return {?} */ emitFocusEvent($event) { let /** @type {?} */ data = null; let /** @type {?} */ ev = EventUtils.newCustomEvent(FOCUS_EVENT, this, data, $event); if (this.focusEvent !== null && this.focusEvent !== undefined) { this.focusEvent.emit(ev); } } /** * @param {?=} $event * @return {?} */ emitBeforeLostFocusEvent($event) { // emit event let /** @type {?} */ data = null; let /** @type {?} */ ev = EventUtils.newCustomEvent(BEFORE_LOST_FOCUS_EVENT, this, data, $event); if (this.beforeLostFocusEvent !== null && this.beforeLostFocusEvent !== undefined) { this.beforeLostFocusEvent.emit(ev); } } /** * @param {?} $event * @return {?} */ emitLostFocusEvent($event) { let /** @type {?} */ data = null; let /** @type {?} */ ev = EventUtils.newCustomEvent(FOCUS_EVENT, this, data, $event); if (this.lostFocusEvent !== null && this.lostFocusEvent !== undefined) { this.lostFocusEvent.emit(ev); } } /** * @param {?} $event * @param {?=} fireEvent * @return {?} */ onLostFocus($event, fireEvent) { if (fireEvent === null || fireEvent === undefined) { fireEvent = true; } EventUtils.handleBrowserEvent(this, 'beforeLostFocusEvent', $event, fireEvent, ($event) => { // doEvent this.doLostFocus($event); }, ($event) => { // emitBeforeEvent this.emitBeforeLostFocusEvent($event); }, ($event) => { // emitAfterEvent this.emitLostFocusEvent($event); }, ($event) => { // doPrevented setTimeout(() => { this.doFocus($event); }, 5); }); } /** * @param {?} $event * @param {?=} fireEvent * @return {?} */ onFocus($event, fireEvent) { if (fireEvent === null || fireEvent === undefined) { fireEvent = true; } EventUtils.handleBrowserEvent(this, 'beforeFocusEvent', $event, fireEvent, ($event) => { // doEvent this.doFocus($event); }, ($event) => { // emitBeforeEvent this.emitBeforeFocusEvent($event); }, ($event) => { // emitAfterEvent this.emitFocusEvent($event); }, ($event) => { // doPrevented setTimeout(() => { this.doLostFocus($event); }, 5); }); } /** * <p style="text-indent: 1em;"> * Play a <code>ripple</code> effect at the position specified in <code><b>event</b></code> object. * </p> * * @param {?} event A mouse event causing the <code>ripple</code> effect to be played. For example, a mouse click event, etc. * @param {?=} target A target DOM element to display the effect. By default, this should be an element causing an event to * occur (<code>event.target</code>). * @return {?} */ playRippleEffect(event, target) { if (target === null || typeof target === 'undefined') { target = event.target; } return new Promise((resolve, reject) => { try { let /** @type {?} */ $div = $('<div/>'); let /** @type {?} */ btnOffset = $(target).offset(); let /** @type {?} */ xPos = event.pageX - btnOffset.left; let /** @type {?} */ yPos = event.pageY - btnOffset.top; let /** @type {?} */ customBG = $(target).data("ripple-color"); $div.addClass('phlox-ripple-effect'); // dynamically set annimation duration from app settings $div.css('animation', 'phlox-ripple-animation ' + this.app.getAppInfo().settings.RIPPLE_EFFECT_DURATION + 's'); $div.css("height", $(target).height() * this.app.getAppInfo().settings.RIPPLE_EFFECT_HEIGHT_RATIO); $div.css("width", $(target).height() * this.app.getAppInfo().settings.RIPPLE_EFFECT_WIDTH_RATIO); $div.css({ top: yPos - ($div.height() / 2), left: xPos - ($div.width() / 2) }); if (customBG !== null && typeof customBG !== 'undefined') { $div.css('background', customBG); } $div.appendTo($(target)); setTimeout(function () { try { $div.remove(); if (typeof resolve === 'function') { resolve(); } } catch (/** @type {?} */ e) { if (typeof reject === 'function') { reject(e); } } }, this.app.getAppInfo().settings.RIPPLE_EFFECT_REMOVE_DURATION * 1000); } catch (/** @type {?} */ e) { if (typeof reject === 'function') { reject(e); } } }); } /** * <p style="text-indent: 1em;"> * A default implementation of <code>click</code> <code>handler</code> method which automatcially plays a <code>ripple</code> effect * ([[playRippleEffect]]) at the position specified in <code><b>event</b></code> object. * </p> * @param {?} event * @return {?} */ onClick(event) { // Prevent event's default event.preventDefault(); this.playRippleEffect(event); } /** * @param {?} $event * @return {?} */ onFocusing($event) { this.needFocusService.setFocusingComponent(this, $event); } /** * @param {?} $event * @return {?} */ onLostFocusing($event) { this.needFocusService.resetFocusingComponent($event); } /** * @return {?} */ getBeforeLostFocusEvent() { return this.beforeLostFocusEvent; } /** * @param {?} event * @return {?} */ setBeforeLostFocusEvent(event) { this.beforeLostFocusEvent = event; } /** * @return {?} */ getLostFocusEvent() { return this.lostFocusEvent; } /** * @param {?} event * @return {?} */ setLostFocusEvent(event) { this.lostFocusEvent = event; } /** * @return {?} */ getBeforeFocusEvent() { return this.beforeFocusEvent; } /** * @param {?} event * @return {?} */ setBeforeFocusEvent(event) { this.beforeFocusEvent = event; } /** * @return {?} */ getFocusEvent() { return this.focusEvent; } /** * @param {?} event * @return {?} */ setFocusEvent(event) { this.focusEvent = event; } } tslib_1.__decorate([ Option('beforeFocus'), tslib_1.__metadata("design:type", EventEmitter) ], AbstractRippleButton.prototype, "beforeFocusEvent", void 0); tslib_1.__decorate([ Option('focus'), tslib_1.__metadata("design:type", EventEmitter) ], AbstractRippleButton.prototype, "focusEvent", void 0); tslib_1.__decorate([ Option('beforeLostFocus'), tslib_1.__metadata("design:type", EventEmitter) ], AbstractRippleButton.prototype, "beforeLostFocusEvent", void 0); tslib_1.__decorate([ Option('lostFocus'), tslib_1.__metadata("design:type", EventEmitter) ], AbstractRippleButton.prototype, "lostFocusEvent", void 0); tslib_1.__decorate([ Option('beforeChange'), tslib_1.__metadata("design:type", EventEmitter) ], AbstractRippleButton.prototype, "beforeChangeEvent", void 0); function AbstractRippleButton_tsickle_Closure_declarations() { /** @type {?} */ AbstractRippleButton.prototype.beforeFocusEvent; /** @type {?} */ AbstractRippleButton.prototype.focusEvent; /** @type {?} */ AbstractRippleButton.prototype.beforeLostFocusEvent; /** @type {?} */ AbstractRippleButton.prototype.lostFocusEvent; /** @type {?} */ AbstractRippleButton.prototype.beforeChangeEvent; /** @type {?} */ AbstractRippleButton.prototype.phloxAppService; /** @type {?} */ AbstractRippleButton.prototype.needFocusService; /** * @abstract * @param {?} $event * @return {?} */ AbstractRippleButton.prototype.doFocus = function ($event) { }; /** * @abstract * @param {?} $event * @return {?} */ AbstractRippleButton.prototype.doLostFocus = function ($event) { }; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"AbstractRippleButton.js","sourceRoot":"ng://com.phloxui/","sources":["lib/component/AbstractRippleButton.ts"],"names":[],"mappings":"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","sourcesContent":["import { EventEmitter } from '@angular/core';\nimport { IApplicationAware } from './IApplicationAware';\nimport { PhloxApp } from './PhloxApp.component';\nimport { PhloxAppService } from '../service/PhloxAppService.service';\nimport { NeedFocusService } from '../service/NeedFocusService.service';\nimport { INeedFocus } from '../component/INeedFocus';\nimport { Option } from '../decorator/Option.decorator';\nimport { EventUtils } from '../share/utils/EventUtils';\nimport {\n  LOST_FOCUS_EVENT, FOCUS_EVENT, BEFORE_LOST_FOCUS_EVENT, BEFORE_FOCUS_EVENT\n} from '../share/CustomEventType';\n\nimport { AbstractI18NApplicable } from '../share/AbstractI18NApplicable';\n\n// Declare jQuery var\ndeclare var $: any;\n\n/**\n * <p style=\"text-indent: 2em;\">\n * An abstract base class of clickable component (such as buttons) playing <code>ripple</code> effect when it is clicked.\n * </p>\n *\n * @author shiorin, tee4cute\n */\nexport abstract class AbstractRippleButton extends AbstractI18NApplicable implements IApplicationAware, INeedFocus {\n\n  @Option('beforeFocus')\n  protected beforeFocusEvent: EventEmitter<any>;\n  @Option('focus')\n  protected focusEvent: EventEmitter<any>;\n  @Option('beforeLostFocus')\n  protected beforeLostFocusEvent: EventEmitter<any>;\n  @Option('lostFocus')\n  protected lostFocusEvent: EventEmitter<any>;\n  @Option('beforeChange')\n  protected beforeChangeEvent: EventEmitter<any>;\n  protected phloxAppService: PhloxAppService;\n  protected needFocusService: NeedFocusService;\n\n  private get app(): PhloxApp {\n    if (this.phloxAppService === null || typeof this.phloxAppService === 'undefined') {\n      return null;\n    }\n    return this.phloxAppService.getInstance();\n  }\n\n  constructor(phloxAppService: PhloxAppService, needFocusService: NeedFocusService) {\n    super();\n\n    if (phloxAppService !== null && typeof phloxAppService !== 'undefined') {\n      this.phloxAppService = phloxAppService;\n    }\n\n    this.needFocusService = needFocusService;\n\n    this.beforeLostFocusEvent = new EventEmitter();\n    this.beforeFocusEvent = new EventEmitter();\n    this.lostFocusEvent = new EventEmitter();\n    this.focusEvent = new EventEmitter();\n  }\n\n  public getApplication(): PhloxApp {\n    return this.app;\n  }\n\n  protected emitBeforeFocusEvent($event?: any): void {\n    // emit event\n    let data: any = null;\n    let ev = EventUtils.newCustomEvent(BEFORE_FOCUS_EVENT, this, data, $event);\n\n    if (this.beforeFocusEvent !== null && this.beforeFocusEvent !== undefined) {\n      this.beforeFocusEvent.emit(ev);\n    }\n  }\n\n  protected emitFocusEvent($event: any): void {\n    let data: any = null;\n    let ev = EventUtils.newCustomEvent(FOCUS_EVENT, this, data, $event);\n\n    if (this.focusEvent !== null && this.focusEvent !== undefined) {\n      this.focusEvent.emit(ev);\n    }\n  }\n\n  protected emitBeforeLostFocusEvent($event?: any): void {\n    // emit event\n    let data: any = null;\n    let ev = EventUtils.newCustomEvent(BEFORE_LOST_FOCUS_EVENT, this, data, $event);\n\n    if (this.beforeLostFocusEvent !== null && this.beforeLostFocusEvent !== undefined) {\n      this.beforeLostFocusEvent.emit(ev);\n    }\n  }\n\n  protected emitLostFocusEvent($event: any): void {\n    let data: any = null;\n\n    let ev = EventUtils.newCustomEvent(FOCUS_EVENT, this, data, $event);\n\n    if (this.lostFocusEvent !== null && this.lostFocusEvent !== undefined) {\n      this.lostFocusEvent.emit(ev);\n    }\n  }\n\n  // emit end validate\n  public onLostFocus($event: any, fireEvent?: boolean): void {\n    if (fireEvent === null || fireEvent === undefined) {\n      fireEvent = true;\n    }\n\n    EventUtils.handleBrowserEvent(this, 'beforeLostFocusEvent', $event, fireEvent, ($event: Event) => {\n      // doEvent\n      this.doLostFocus($event);\n    }, ($event: Event) => {\n      // emitBeforeEvent\n      this.emitBeforeLostFocusEvent($event);\n    }, ($event: Event) => {\n      // emitAfterEvent\n      this.emitLostFocusEvent($event);\n    }, ($event: Event) => {\n      // doPrevented\n      setTimeout(() => {\n        this.doFocus($event);\n      }, 5);\n    });\n  }\n\n  public onFocus($event: any, fireEvent?: boolean): void {\n    if (fireEvent === null || fireEvent === undefined) {\n      fireEvent = true;\n    }\n\n    EventUtils.handleBrowserEvent(this, 'beforeFocusEvent', $event, fireEvent, ($event: Event) => {\n      // doEvent\n      this.doFocus($event);\n    }, ($event: Event) => {\n      // emitBeforeEvent\n      this.emitBeforeFocusEvent($event);\n    }, ($event: Event) => {\n      // emitAfterEvent\n      this.emitFocusEvent($event);\n    }, ($event: Event) => {\n      // doPrevented\n      setTimeout(() => {\n        this.doLostFocus($event);\n      }, 5);\n    });\n  }\n\n  /**\n   * <p style=\"text-indent: 1em;\">\n   * Play a <code>ripple</code> effect at the position specified in <code><b>event</b></code> object.\n   * </p>\n   *\n   * @param event A mouse event causing the <code>ripple</code> effect to be played. For example, a mouse click event, etc.\n   * @param target A target DOM element to display the effect. By default, this should be an element causing an event to\n   * occur (<code>event.target</code>).\n   */\n  public playRippleEffect(event: MouseEvent, target?: any): Promise<any> {\n    if (target === null || typeof target === 'undefined') {\n      target = event.target;\n    }\n\n    return new Promise((resolve, reject) => {\n      try {\n        let $div: any = $('<div/>');\n        let btnOffset: any = $(target).offset();\n        let xPos: any = event.pageX - btnOffset.left;\n        let yPos: any = event.pageY - btnOffset.top;\n        let customBG: any = $(target).data(\"ripple-color\");\n\n        $div.addClass('phlox-ripple-effect');\n\n        // dynamically set annimation duration from app settings\n        $div.css('animation', 'phlox-ripple-animation ' + this.app.getAppInfo().settings.RIPPLE_EFFECT_DURATION + 's');\n        $div.css(\"height\", $(target).height() * this.app.getAppInfo().settings.RIPPLE_EFFECT_HEIGHT_RATIO);\n        $div.css(\"width\", $(target).height() * this.app.getAppInfo().settings.RIPPLE_EFFECT_WIDTH_RATIO);\n        $div.css({\n          top: yPos - ($div.height() / 2),\n          left: xPos - ($div.width() / 2)\n        });\n        if (customBG !== null && typeof customBG !== 'undefined') {\n          $div.css('background', customBG);\n        }\n        $div.appendTo($(target));\n\n        setTimeout(function() {\n          try {\n            $div.remove();\n\n            if (typeof resolve === 'function') {\n              resolve();\n            }\n          } catch (e) {\n            if (typeof reject === 'function') {\n              reject(e);\n            }\n          }\n        }, this.app.getAppInfo().settings.RIPPLE_EFFECT_REMOVE_DURATION * 1000);\n      } catch (e) {\n        if (typeof reject === 'function') {\n          reject(e);\n        }\n      }\n    });\n  }\n\n  /**\n   * <p style=\"text-indent: 1em;\">\n   * A default implementation of <code>click</code> <code>handler</code> method which automatcially plays a <code>ripple</code> effect\n   * ([[playRippleEffect]]) at the position specified in <code><b>event</b></code> object.\n   * </p>\n   */\n  public onClick(event: MouseEvent): void {\n    // Prevent event's default\n    event.preventDefault();\n\n    this.playRippleEffect(event);\n  }\n\n  public onFocusing($event: Event): void {\n    this.needFocusService.setFocusingComponent(this, $event);\n  }\n\n  public onLostFocusing($event: Event): void {\n    this.needFocusService.resetFocusingComponent($event);\n  }\n\n  public getBeforeLostFocusEvent(): EventEmitter<any> {\n    return this.beforeLostFocusEvent;\n  }\n\n  public setBeforeLostFocusEvent(event: EventEmitter<any>) {\n    this.beforeLostFocusEvent = event;\n  }\n\n  public getLostFocusEvent(): EventEmitter<any> {\n    return this.lostFocusEvent;\n  }\n\n  public setLostFocusEvent(event: EventEmitter<any>): void {\n    this.lostFocusEvent = event;\n  }\n\n  public getBeforeFocusEvent(): EventEmitter<any> {\n    return this.beforeFocusEvent;\n  }\n\n  public setBeforeFocusEvent(event: EventEmitter<any>): void {\n    this.beforeFocusEvent = event;\n  }\n\n  public getFocusEvent(): EventEmitter<any> {\n    return this.focusEvent;\n  }\n\n  public setFocusEvent(event: EventEmitter<any>): void {\n    this.focusEvent = event;\n  }\n\n  protected abstract doFocus($event: Event): void;\n\n  protected abstract doLostFocus($event: Event): void;\n\n}\n"]}