UNPKG

com.phloxui

Version:

PhloxUI Ng2+ Framework

427 lines (426 loc) 34.2 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 */ var AbstractRippleButton = /** @class */ (function (_super) { tslib_1.__extends(AbstractRippleButton, _super); function AbstractRippleButton(phloxAppService, needFocusService) { var _this = _super.call(this) || this; 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 _this; } Object.defineProperty(AbstractRippleButton.prototype, "app", { get: /** * @return {?} */ function () { if (this.phloxAppService === null || typeof this.phloxAppService === 'undefined') { return null; } return this.phloxAppService.getInstance(); }, enumerable: true, configurable: true }); /** * @return {?} */ AbstractRippleButton.prototype.getApplication = /** * @return {?} */ function () { return this.app; }; /** * @param {?=} $event * @return {?} */ AbstractRippleButton.prototype.emitBeforeFocusEvent = /** * @param {?=} $event * @return {?} */ function ($event) { // emit event var /** @type {?} */ data = null; var /** @type {?} */ ev = EventUtils.newCustomEvent(BEFORE_FOCUS_EVENT, this, data, $event); if (this.beforeFocusEvent !== null && this.beforeFocusEvent !== undefined) { this.beforeFocusEvent.emit(ev); } }; /** * @param {?} $event * @return {?} */ AbstractRippleButton.prototype.emitFocusEvent = /** * @param {?} $event * @return {?} */ function ($event) { var /** @type {?} */ data = null; var /** @type {?} */ ev = EventUtils.newCustomEvent(FOCUS_EVENT, this, data, $event); if (this.focusEvent !== null && this.focusEvent !== undefined) { this.focusEvent.emit(ev); } }; /** * @param {?=} $event * @return {?} */ AbstractRippleButton.prototype.emitBeforeLostFocusEvent = /** * @param {?=} $event * @return {?} */ function ($event) { // emit event var /** @type {?} */ data = null; var /** @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 {?} */ AbstractRippleButton.prototype.emitLostFocusEvent = /** * @param {?} $event * @return {?} */ function ($event) { var /** @type {?} */ data = null; var /** @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 {?} */ AbstractRippleButton.prototype.onLostFocus = /** * @param {?} $event * @param {?=} fireEvent * @return {?} */ function ($event, fireEvent) { var _this = this; if (fireEvent === null || fireEvent === undefined) { fireEvent = true; } EventUtils.handleBrowserEvent(this, 'beforeLostFocusEvent', $event, fireEvent, function ($event) { // doEvent // doEvent _this.doLostFocus($event); }, function ($event) { // emitBeforeEvent // emitBeforeEvent _this.emitBeforeLostFocusEvent($event); }, function ($event) { // emitAfterEvent // emitAfterEvent _this.emitLostFocusEvent($event); }, function ($event) { // doPrevented setTimeout(function () { _this.doFocus($event); }, 5); }); }; /** * @param {?} $event * @param {?=} fireEvent * @return {?} */ AbstractRippleButton.prototype.onFocus = /** * @param {?} $event * @param {?=} fireEvent * @return {?} */ function ($event, fireEvent) { var _this = this; if (fireEvent === null || fireEvent === undefined) { fireEvent = true; } EventUtils.handleBrowserEvent(this, 'beforeFocusEvent', $event, fireEvent, function ($event) { // doEvent // doEvent _this.doFocus($event); }, function ($event) { // emitBeforeEvent // emitBeforeEvent _this.emitBeforeFocusEvent($event); }, function ($event) { // emitAfterEvent // emitAfterEvent _this.emitFocusEvent($event); }, function ($event) { // doPrevented setTimeout(function () { _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 {?} */ AbstractRippleButton.prototype.playRippleEffect = /** * <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 {?} */ function (event, target) { var _this = this; if (target === null || typeof target === 'undefined') { target = event.target; } return new Promise(function (resolve, reject) { try { var /** @type {?} */ $div_1 = $('<div/>'); var /** @type {?} */ btnOffset = $(target).offset(); var /** @type {?} */ xPos = event.pageX - btnOffset.left; var /** @type {?} */ yPos = event.pageY - btnOffset.top; var /** @type {?} */ customBG = $(target).data("ripple-color"); $div_1.addClass('phlox-ripple-effect'); // dynamically set annimation duration from app settings // dynamically set annimation duration from app settings $div_1.css('animation', 'phlox-ripple-animation ' + _this.app.getAppInfo().settings.RIPPLE_EFFECT_DURATION + 's'); $div_1.css("height", $(target).height() * _this.app.getAppInfo().settings.RIPPLE_EFFECT_HEIGHT_RATIO); $div_1.css("width", $(target).height() * _this.app.getAppInfo().settings.RIPPLE_EFFECT_WIDTH_RATIO); $div_1.css({ top: yPos - ($div_1.height() / 2), left: xPos - ($div_1.width() / 2) }); if (customBG !== null && typeof customBG !== 'undefined') { $div_1.css('background', customBG); } $div_1.appendTo($(target)); setTimeout(function () { try { $div_1.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 {?} */ AbstractRippleButton.prototype.onClick = /** * <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 {?} */ function (event) { // Prevent event's default event.preventDefault(); this.playRippleEffect(event); }; /** * @param {?} $event * @return {?} */ AbstractRippleButton.prototype.onFocusing = /** * @param {?} $event * @return {?} */ function ($event) { this.needFocusService.setFocusingComponent(this, $event); }; /** * @param {?} $event * @return {?} */ AbstractRippleButton.prototype.onLostFocusing = /** * @param {?} $event * @return {?} */ function ($event) { this.needFocusService.resetFocusingComponent($event); }; /** * @return {?} */ AbstractRippleButton.prototype.getBeforeLostFocusEvent = /** * @return {?} */ function () { return this.beforeLostFocusEvent; }; /** * @param {?} event * @return {?} */ AbstractRippleButton.prototype.setBeforeLostFocusEvent = /** * @param {?} event * @return {?} */ function (event) { this.beforeLostFocusEvent = event; }; /** * @return {?} */ AbstractRippleButton.prototype.getLostFocusEvent = /** * @return {?} */ function () { return this.lostFocusEvent; }; /** * @param {?} event * @return {?} */ AbstractRippleButton.prototype.setLostFocusEvent = /** * @param {?} event * @return {?} */ function (event) { this.lostFocusEvent = event; }; /** * @return {?} */ AbstractRippleButton.prototype.getBeforeFocusEvent = /** * @return {?} */ function () { return this.beforeFocusEvent; }; /** * @param {?} event * @return {?} */ AbstractRippleButton.prototype.setBeforeFocusEvent = /** * @param {?} event * @return {?} */ function (event) { this.beforeFocusEvent = event; }; /** * @return {?} */ AbstractRippleButton.prototype.getFocusEvent = /** * @return {?} */ function () { return this.focusEvent; }; /** * @param {?} event * @return {?} */ AbstractRippleButton.prototype.setFocusEvent = /** * @param {?} event * @return {?} */ function (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); return AbstractRippleButton; }(AbstractI18NApplicable)); export { AbstractRippleButton }; 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"]}