com.phloxui
Version:
PhloxUI Ng2+ Framework
330 lines (329 loc) • 30.6 kB
JavaScript
/**
* @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":";;;;;AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,eAAe,CAAC;AAM7C,OAAO,EAAE,MAAM,EAAE,MAAM,+BAA+B,CAAC;AACvD,OAAO,EAAE,UAAU,EAAE,MAAM,2BAA2B,CAAC;AACvD,OAAO,EACa,WAAW,EAAE,uBAAuB,EAAE,kBAAkB,EAC3E,MAAM,0BAA0B,CAAC;AAElC,OAAO,EAAE,sBAAsB,EAAE,MAAM,iCAAiC,CAAC;;;;;;;;;AAYzE,MAAM,2BAAqC,SAAQ,sBAAsB;;;;;IAsBvE,YAAY,eAAgC,EAAE,gBAAkC;QAC9E,KAAK,EAAE,CAAC;QAER,EAAE,CAAC,CAAC,eAAe,KAAK,IAAI,IAAI,OAAO,eAAe,KAAK,WAAW,CAAC,CAAC,CAAC;YACvE,IAAI,CAAC,eAAe,GAAG,eAAe,CAAC;SACxC;QAED,IAAI,CAAC,gBAAgB,GAAG,gBAAgB,CAAC;QAEzC,IAAI,CAAC,oBAAoB,GAAG,IAAI,YAAY,EAAE,CAAC;QAC/C,IAAI,CAAC,gBAAgB,GAAG,IAAI,YAAY,EAAE,CAAC;QAC3C,IAAI,CAAC,cAAc,GAAG,IAAI,YAAY,EAAE,CAAC;QACzC,IAAI,CAAC,UAAU,GAAG,IAAI,YAAY,EAAE,CAAC;KACtC;;;;QApBW,GAAG;QACb,EAAE,CAAC,CAAC,IAAI,CAAC,eAAe,KAAK,IAAI,IAAI,OAAO,IAAI,CAAC,eAAe,KAAK,WAAW,CAAC,CAAC,CAAC;YACjF,MAAM,CAAC,IAAI,CAAC;SACb;QACD,MAAM,CAAC,IAAI,CAAC,eAAe,CAAC,WAAW,EAAE,CAAC;;;;;IAkBrC,cAAc;QACnB,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC;;;;;;IAGR,oBAAoB,CAAC,MAAY;;QAEzC,qBAAI,IAAI,GAAQ,IAAI,CAAC;QACrB,qBAAI,EAAE,GAAG,UAAU,CAAC,cAAc,CAAC,kBAAkB,EAAE,IAAI,EAAE,IAAI,EAAE,MAAM,CAAC,CAAC;QAE3E,EAAE,CAAC,CAAC,IAAI,CAAC,gBAAgB,KAAK,IAAI,IAAI,IAAI,CAAC,gBAAgB,KAAK,SAAS,CAAC,CAAC,CAAC;YAC1E,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;SAChC;KACF;;;;;IAES,cAAc,CAAC,MAAW;QAClC,qBAAI,IAAI,GAAQ,IAAI,CAAC;QACrB,qBAAI,EAAE,GAAG,UAAU,CAAC,cAAc,CAAC,WAAW,EAAE,IAAI,EAAE,IAAI,EAAE,MAAM,CAAC,CAAC;QAEpE,EAAE,CAAC,CAAC,IAAI,CAAC,UAAU,KAAK,IAAI,IAAI,IAAI,CAAC,UAAU,KAAK,SAAS,CAAC,CAAC,CAAC;YAC9D,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;SAC1B;KACF;;;;;IAES,wBAAwB,CAAC,MAAY;;QAE7C,qBAAI,IAAI,GAAQ,IAAI,CAAC;QACrB,qBAAI,EAAE,GAAG,UAAU,CAAC,cAAc,CAAC,uBAAuB,EAAE,IAAI,EAAE,IAAI,EAAE,MAAM,CAAC,CAAC;QAEhF,EAAE,CAAC,CAAC,IAAI,CAAC,oBAAoB,KAAK,IAAI,IAAI,IAAI,CAAC,oBAAoB,KAAK,SAAS,CAAC,CAAC,CAAC;YAClF,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;SACpC;KACF;;;;;IAES,kBAAkB,CAAC,MAAW;QACtC,qBAAI,IAAI,GAAQ,IAAI,CAAC;QAErB,qBAAI,EAAE,GAAG,UAAU,CAAC,cAAc,CAAC,WAAW,EAAE,IAAI,EAAE,IAAI,EAAE,MAAM,CAAC,CAAC;QAEpE,EAAE,CAAC,CAAC,IAAI,CAAC,cAAc,KAAK,IAAI,IAAI,IAAI,CAAC,cAAc,KAAK,SAAS,CAAC,CAAC,CAAC;YACtE,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;SAC9B;KACF;;;;;;IAGM,WAAW,CAAC,MAAW,EAAE,SAAmB;QACjD,EAAE,CAAC,CAAC,SAAS,KAAK,IAAI,IAAI,SAAS,KAAK,SAAS,CAAC,CAAC,CAAC;YAClD,SAAS,GAAG,IAAI,CAAC;SAClB;QAED,UAAU,CAAC,kBAAkB,CAAC,IAAI,EAAE,sBAAsB,EAAE,MAAM,EAAE,SAAS,EAAE,CAAC,MAAa,EAAE,EAAE;;YAE/F,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC;SAC1B,EAAE,CAAC,MAAa,EAAE,EAAE;;YAEnB,IAAI,CAAC,wBAAwB,CAAC,MAAM,CAAC,CAAC;SACvC,EAAE,CAAC,MAAa,EAAE,EAAE;;YAEnB,IAAI,CAAC,kBAAkB,CAAC,MAAM,CAAC,CAAC;SACjC,EAAE,CAAC,MAAa,EAAE,EAAE;;YAEnB,UAAU,CAAC,GAAG,EAAE;gBACd,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;aACtB,EAAE,CAAC,CAAC,CAAC;SACP,CAAC,CAAC;;;;;;;IAGE,OAAO,CAAC,MAAW,EAAE,SAAmB;QAC7C,EAAE,CAAC,CAAC,SAAS,KAAK,IAAI,IAAI,SAAS,KAAK,SAAS,CAAC,CAAC,CAAC;YAClD,SAAS,GAAG,IAAI,CAAC;SAClB;QAED,UAAU,CAAC,kBAAkB,CAAC,IAAI,EAAE,kBAAkB,EAAE,MAAM,EAAE,SAAS,EAAE,CAAC,MAAa,EAAE,EAAE;;YAE3F,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;SACtB,EAAE,CAAC,MAAa,EAAE,EAAE;;YAEnB,IAAI,CAAC,oBAAoB,CAAC,MAAM,CAAC,CAAC;SACnC,EAAE,CAAC,MAAa,EAAE,EAAE;;YAEnB,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC;SAC7B,EAAE,CAAC,MAAa,EAAE,EAAE;;YAEnB,UAAU,CAAC,GAAG,EAAE;gBACd,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC;aAC1B,EAAE,CAAC,CAAC,CAAC;SACP,CAAC,CAAC;;;;;;;;;;;;IAYE,gBAAgB,CAAC,KAAiB,EAAE,MAAY;QACrD,EAAE,CAAC,CAAC,MAAM,KAAK,IAAI,IAAI,OAAO,MAAM,KAAK,WAAW,CAAC,CAAC,CAAC;YACrD,MAAM,GAAG,KAAK,CAAC,MAAM,CAAC;SACvB;QAED,MAAM,CAAC,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;YACrC,IAAI,CAAC;gBACH,qBAAI,IAAI,GAAQ,CAAC,CAAC,QAAQ,CAAC,CAAC;gBAC5B,qBAAI,SAAS,GAAQ,CAAC,CAAC,MAAM,CAAC,CAAC,MAAM,EAAE,CAAC;gBACxC,qBAAI,IAAI,GAAQ,KAAK,CAAC,KAAK,GAAG,SAAS,CAAC,IAAI,CAAC;gBAC7C,qBAAI,IAAI,GAAQ,KAAK,CAAC,KAAK,GAAG,SAAS,CAAC,GAAG,CAAC;gBAC5C,qBAAI,QAAQ,GAAQ,CAAC,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;gBAEnD,IAAI,CAAC,QAAQ,CAAC,qBAAqB,CAAC,CAAC;;gBAGrC,IAAI,CAAC,GAAG,CAAC,WAAW,EAAE,yBAAyB,GAAG,IAAI,CAAC,GAAG,CAAC,UAAU,EAAE,CAAC,QAAQ,CAAC,sBAAsB,GAAG,GAAG,CAAC,CAAC;gBAC/G,IAAI,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC,CAAC,MAAM,CAAC,CAAC,MAAM,EAAE,GAAG,IAAI,CAAC,GAAG,CAAC,UAAU,EAAE,CAAC,QAAQ,CAAC,0BAA0B,CAAC,CAAC;gBACnG,IAAI,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC,CAAC,MAAM,CAAC,CAAC,MAAM,EAAE,GAAG,IAAI,CAAC,GAAG,CAAC,UAAU,EAAE,CAAC,QAAQ,CAAC,yBAAyB,CAAC,CAAC;gBACjG,IAAI,CAAC,GAAG,CAAC;oBACP,GAAG,EAAE,IAAI,GAAG,CAAC,IAAI,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;oBAC/B,IAAI,EAAE,IAAI,GAAG,CAAC,IAAI,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC;iBAChC,CAAC,CAAC;gBACH,EAAE,CAAC,CAAC,QAAQ,KAAK,IAAI,IAAI,OAAO,QAAQ,KAAK,WAAW,CAAC,CAAC,CAAC;oBACzD,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,QAAQ,CAAC,CAAC;iBAClC;gBACD,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC;gBAEzB,UAAU,CAAC;oBACT,IAAI,CAAC;wBACH,IAAI,CAAC,MAAM,EAAE,CAAC;wBAEd,EAAE,CAAC,CAAC,OAAO,OAAO,KAAK,UAAU,CAAC,CAAC,CAAC;4BAClC,OAAO,EAAE,CAAC;yBACX;qBACF;oBAAC,KAAK,CAAC,CAAC,iBAAA,CAAC,EAAE,CAAC;wBACX,EAAE,CAAC,CAAC,OAAO,MAAM,KAAK,UAAU,CAAC,CAAC,CAAC;4BACjC,MAAM,CAAC,CAAC,CAAC,CAAC;yBACX;qBACF;iBACF,EAAE,IAAI,CAAC,GAAG,CAAC,UAAU,EAAE,CAAC,QAAQ,CAAC,6BAA6B,GAAG,IAAI,CAAC,CAAC;aACzE;YAAC,KAAK,CAAC,CAAC,iBAAA,CAAC,EAAE,CAAC;gBACX,EAAE,CAAC,CAAC,OAAO,MAAM,KAAK,UAAU,CAAC,CAAC,CAAC;oBACjC,MAAM,CAAC,CAAC,CAAC,CAAC;iBACX;aACF;SACF,CAAC,CAAC;;;;;;;;;;IASE,OAAO,CAAC,KAAiB;;QAE9B,KAAK,CAAC,cAAc,EAAE,CAAC;QAEvB,IAAI,CAAC,gBAAgB,CAAC,KAAK,CAAC,CAAC;;;;;;IAGxB,UAAU,CAAC,MAAa;QAC7B,IAAI,CAAC,gBAAgB,CAAC,oBAAoB,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC;;;;;;IAGpD,cAAc,CAAC,MAAa;QACjC,IAAI,CAAC,gBAAgB,CAAC,sBAAsB,CAAC,MAAM,CAAC,CAAC;;;;;IAGhD,uBAAuB;QAC5B,MAAM,CAAC,IAAI,CAAC,oBAAoB,CAAC;;;;;;IAG5B,uBAAuB,CAAC,KAAwB;QACrD,IAAI,CAAC,oBAAoB,GAAG,KAAK,CAAC;;;;;IAG7B,iBAAiB;QACtB,MAAM,CAAC,IAAI,CAAC,cAAc,CAAC;;;;;;IAGtB,iBAAiB,CAAC,KAAwB;QAC/C,IAAI,CAAC,cAAc,GAAG,KAAK,CAAC;;;;;IAGvB,mBAAmB;QACxB,MAAM,CAAC,IAAI,CAAC,gBAAgB,CAAC;;;;;;IAGxB,mBAAmB,CAAC,KAAwB;QACjD,IAAI,CAAC,gBAAgB,GAAG,KAAK,CAAC;;;;;IAGzB,aAAa;QAClB,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC;;;;;;IAGlB,aAAa,CAAC,KAAwB;QAC3C,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;;CAO3B;;IA9OE,MAAM,CAAC,aAAa,CAAC;sCACM,YAAY;;;IACvC,MAAM,CAAC,OAAO,CAAC;sCACM,YAAY;;;IACjC,MAAM,CAAC,iBAAiB,CAAC;sCACM,YAAY;;;IAC3C,MAAM,CAAC,WAAW,CAAC;sCACM,YAAY;;;IACrC,MAAM,CAAC,cAAc,CAAC;sCACM,YAAY","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"]}