com.phloxui
Version:
PhloxUI Ng2+ Framework
265 lines (264 loc) • 18.3 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes} checked by tsc
*/
import * as tslib_1 from "tslib";
import { Component, Input, EventEmitter, Output } from '@angular/core';
import { AbstractRippleButton } from './AbstractRippleButton';
import { PhloxAppService } from '../service/PhloxAppService.service';
import { NeedFocusService } from '../service/NeedFocusService.service';
import { CLICK_EVENT, BEFORE_CLICK_EVENT } from '../share/CustomEventType';
import { Option } from '../decorator/Option.decorator';
import { EventUtils } from '../share/utils/EventUtils';
var /** @type {?} */ TYPE_NAME = "phx-simple-ripple-btn";
var SimpleRippleButton = /** @class */ (function (_super) {
tslib_1.__extends(SimpleRippleButton, _super);
function SimpleRippleButton(phloxAppService, needFocusService) {
var _this = _super.call(this, phloxAppService, needFocusService) || this;
_this.beforeClickEvent = new EventEmitter();
_this.clickEvent = new EventEmitter();
return _this;
}
/**
* @return {?}
*/
SimpleRippleButton.prototype.ngOnInit = /**
* @return {?}
*/
function () {
};
/**
* @param {?} $event
* @return {?}
*/
SimpleRippleButton.prototype.doFocus = /**
* @param {?} $event
* @return {?}
*/
function ($event) {
};
/**
* @param {?} $event
* @return {?}
*/
SimpleRippleButton.prototype.doLostFocus = /**
* @param {?} $event
* @return {?}
*/
function ($event) {
};
/**
* @param {?} label
* @return {?}
*/
SimpleRippleButton.prototype.setLabel = /**
* @param {?} label
* @return {?}
*/
function (label) {
this.label = label;
};
/**
* @return {?}
*/
SimpleRippleButton.prototype.getLabel = /**
* @return {?}
*/
function () {
return this.label;
};
/**
* @param {?} $event
* @param {?=} fireEvent
* @return {?}
*/
SimpleRippleButton.prototype.onClick = /**
* @param {?} $event
* @param {?=} fireEvent
* @return {?}
*/
function ($event, fireEvent) {
_super.prototype.onClick.call(this, $event);
if (this.clickHandler !== null && typeof this.clickHandler === 'function') {
this.clickHandler.call(this, $event);
}
if (fireEvent === null || fireEvent === undefined) {
fireEvent = true;
}
EventUtils.handleBrowserEvent(this, 'beforeClickEvent', $event, fireEvent, function ($browserEvent) {
// Do nothing while clicked.
}, this.emitBeforeClickEvent, this.emitClickEvent);
};
/**
* @param {?=} $event
* @return {?}
*/
SimpleRippleButton.prototype.emitBeforeClickEvent = /**
* @param {?=} $event
* @return {?}
*/
function ($event) {
// emit event
var /** @type {?} */ data = {
event: $event,
instance: this
};
var /** @type {?} */ ev = EventUtils.newCustomEvent(BEFORE_CLICK_EVENT, this, data, $event);
if (this.beforeClickEvent !== null && this.beforeClickEvent !== undefined) {
this.beforeClickEvent.emit(ev);
}
};
/**
* @param {?=} $event
* @return {?}
*/
SimpleRippleButton.prototype.emitClickEvent = /**
* @param {?=} $event
* @return {?}
*/
function ($event) {
// emit event
var /** @type {?} */ data = {
event: $event,
instance: this
};
var /** @type {?} */ ev = EventUtils.newCustomEvent(CLICK_EVENT, this, data, $event);
if (this.clickEvent !== null && this.clickEvent !== undefined) {
this.clickEvent.emit(ev);
}
};
/**
* @return {?}
*/
SimpleRippleButton.prototype.getClickEvent = /**
* @return {?}
*/
function () {
return this.clickEvent;
};
/**
* @param {?} event
* @return {?}
*/
SimpleRippleButton.prototype.setClickEvent = /**
* @param {?} event
* @return {?}
*/
function (event) {
this.clickEvent = event;
};
/**
* @return {?}
*/
SimpleRippleButton.prototype.getBeforeClickEvent = /**
* @return {?}
*/
function () {
return this.beforeClickEvent;
};
/**
* @param {?} event
* @return {?}
*/
SimpleRippleButton.prototype.setBeforeClickEvent = /**
* @param {?} event
* @return {?}
*/
function (event) {
this.beforeClickEvent = event;
};
/**
* @return {?}
*/
SimpleRippleButton.prototype.isDisabled = /**
* @return {?}
*/
function () {
return this.disabled;
};
SimpleRippleButton.TYPE_NAME = TYPE_NAME;
SimpleRippleButton.decorators = [
{ type: Component, args: [{
moduleId: module.id,
selector: TYPE_NAME,
template: "<div class=\"phx-simple-ripple-btn\" [class.disabled]=\"isDisabled()\">\n <button type=\"button\" (click)=\"onClick($event)\" (focusin)=\"onFocusing($event)\" (blur)=\"onLostFocusing($event)\">\n <div class=\"table-wrapper fluid\">\n <div class=\"table-cell-wrapper middle\">\n {{getLabel()}}\n </div>\n </div>\n </button>\n</div>\n"
},] },
];
/** @nocollapse */
SimpleRippleButton.ctorParameters = function () { return [
{ type: PhloxAppService, },
{ type: NeedFocusService, },
]; };
SimpleRippleButton.propDecorators = {
"label": [{ type: Input },],
"disabled": [{ type: Input },],
"clickHandler": [{ type: Input },],
"beforeClickEvent": [{ type: Output, args: ['phxBeforeClick',] },],
"clickEvent": [{ type: Output, args: ['phxClick',] },],
"dataParent": [{ type: Input },],
"beforeFocusEvent": [{ type: Output, args: ['phxBeforeFocus',] },],
"focusEvent": [{ type: Output, args: ['phxFocus',] },],
"beforeLostFocusEvent": [{ type: Output, args: ['phxBeforeLostFocus',] },],
"lostFocusEvent": [{ type: Output, args: ['phxLostFocus',] },],
};
tslib_1.__decorate([
Option('beforeClick'),
tslib_1.__metadata("design:type", EventEmitter)
], SimpleRippleButton.prototype, "beforeClickEvent", void 0);
tslib_1.__decorate([
Option('click'),
tslib_1.__metadata("design:type", EventEmitter)
], SimpleRippleButton.prototype, "clickEvent", void 0);
tslib_1.__decorate([
Option('beforeFocus'),
tslib_1.__metadata("design:type", EventEmitter)
], SimpleRippleButton.prototype, "beforeFocusEvent", void 0);
tslib_1.__decorate([
Option('focus'),
tslib_1.__metadata("design:type", EventEmitter)
], SimpleRippleButton.prototype, "focusEvent", void 0);
tslib_1.__decorate([
Option('beforeLostFocus'),
tslib_1.__metadata("design:type", EventEmitter)
], SimpleRippleButton.prototype, "beforeLostFocusEvent", void 0);
tslib_1.__decorate([
Option('lostFocus'),
tslib_1.__metadata("design:type", EventEmitter)
], SimpleRippleButton.prototype, "lostFocusEvent", void 0);
return SimpleRippleButton;
}(AbstractRippleButton));
export { SimpleRippleButton };
function SimpleRippleButton_tsickle_Closure_declarations() {
/** @type {!Array<{type: !Function, args: (undefined|!Array<?>)}>} */
SimpleRippleButton.decorators;
/**
* @nocollapse
* @type {function(): !Array<(null|{type: ?, decorators: (undefined|!Array<{type: !Function, args: (undefined|!Array<?>)}>)})>}
*/
SimpleRippleButton.ctorParameters;
/** @type {!Object<string,!Array<{type: !Function, args: (undefined|!Array<?>)}>>} */
SimpleRippleButton.propDecorators;
/** @type {?} */
SimpleRippleButton.TYPE_NAME;
/** @type {?} */
SimpleRippleButton.prototype.label;
/** @type {?} */
SimpleRippleButton.prototype.disabled;
/** @type {?} */
SimpleRippleButton.prototype.clickHandler;
/** @type {?} */
SimpleRippleButton.prototype.beforeClickEvent;
/** @type {?} */
SimpleRippleButton.prototype.clickEvent;
/** @type {?} */
SimpleRippleButton.prototype.dataParent;
/** @type {?} */
SimpleRippleButton.prototype.beforeFocusEvent;
/** @type {?} */
SimpleRippleButton.prototype.focusEvent;
/** @type {?} */
SimpleRippleButton.prototype.beforeLostFocusEvent;
/** @type {?} */
SimpleRippleButton.prototype.lostFocusEvent;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"SimpleRippleButton.component.js","sourceRoot":"ng://com.phloxui/","sources":["lib/component/SimpleRippleButton.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input, EventEmitter, Output } from '@angular/core';\nimport { AbstractRippleButton } from './AbstractRippleButton';\nimport { PhloxAppService } from '../service/PhloxAppService.service';\nimport { NeedFocusService } from '../service/NeedFocusService.service';\nimport { CLICK_EVENT, BEFORE_CLICK_EVENT } from '../share/CustomEventType';\nimport { Option } from '../decorator/Option.decorator';\nimport { IHasData } from './IHasData';\nimport { EventUtils } from '../share/utils/EventUtils';\n\ndeclare var $: any;\n\nconst TYPE_NAME: string = \"phx-simple-ripple-btn\";\n\n@Component({\n  moduleId: module.id,\n  selector: TYPE_NAME,\n  template: `<div class=\"phx-simple-ripple-btn\" [class.disabled]=\"isDisabled()\">\n  <button type=\"button\" (click)=\"onClick($event)\" (focusin)=\"onFocusing($event)\" (blur)=\"onLostFocusing($event)\">\n    <div class=\"table-wrapper fluid\">\n      <div class=\"table-cell-wrapper middle\">\n        {{getLabel()}}\n      </div>\n    </div>\n  </button>\n</div>\n`\n})\nexport class SimpleRippleButton extends AbstractRippleButton implements OnInit {\n\n  public static readonly TYPE_NAME: string = TYPE_NAME;\n\n  @Input()\n  private label: string;\n  @Input()\n  private disabled: boolean;\n  @Input()\n  private clickHandler: Function;\n  @Option('beforeClick')\n  @Output('phxBeforeClick')\n  private beforeClickEvent: EventEmitter<any>;\n  @Option('click')\n  @Output('phxClick')\n  private clickEvent: EventEmitter<any>;\n  @Input()\n  protected dataParent: IHasData;\n  @Output('phxBeforeFocus')\n  @Option('beforeFocus')\n  protected beforeFocusEvent: EventEmitter<any>;\n  @Output('phxFocus')\n  @Option('focus')\n  protected focusEvent: EventEmitter<any>;\n  @Output('phxBeforeLostFocus')\n  @Option('beforeLostFocus')\n  protected beforeLostFocusEvent: EventEmitter<any>;\n  @Output('phxLostFocus')\n  @Option('lostFocus')\n  protected lostFocusEvent: EventEmitter<any>;\n\n  constructor(phloxAppService: PhloxAppService, needFocusService: NeedFocusService) {\n    super(phloxAppService, needFocusService);\n\n    this.beforeClickEvent = new EventEmitter();\n\n    this.clickEvent = new EventEmitter<any>();\n  }\n\n  public ngOnInit(): void {\n\n  }\n\n  protected doFocus($event: Event): void {\n\n  }\n\n  protected doLostFocus($event: Event): void {\n\n  }\n\n  public setLabel(label: string): void {\n    this.label = label;\n  }\n\n  public getLabel(): string {\n    return this.label;\n  }\n\n  public onClick($event: MouseEvent, fireEvent?: boolean): void {\n    super.onClick($event);\n\n    if (this.clickHandler !== null && typeof this.clickHandler === 'function') {\n      this.clickHandler.call(this, $event);\n    }\n\n    if (fireEvent === null || fireEvent === undefined) {\n      fireEvent = true;\n    }\n\n    EventUtils.handleBrowserEvent(this, 'beforeClickEvent', $event, fireEvent, ($browserEvent: Event): void => {\n      // Do nothing while clicked.\n    }, this.emitBeforeClickEvent, this.emitClickEvent);\n  }\n\n  protected emitBeforeClickEvent($event?: any): void {\n    // emit event\n    let data: any = {\n      event: $event,\n      instance: this\n    };\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    // emit event\n    let data: any = {\n      event: $event,\n      instance: this\n    };\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  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: any) {\n    this.beforeClickEvent = event;\n  }\n\n  public isDisabled(): boolean {\n    return this.disabled;\n  }\n}\n"]}