com.phloxui
Version:
PhloxUI Ng2+ Framework
427 lines (426 loc) • 34.2 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
*/
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"]}