com.phloxui
Version:
PhloxUI Ng2+ Framework
226 lines (225 loc) • 16.6 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';
const /** @type {?} */ TYPE_NAME = "phx-simple-ripple-btn";
export class SimpleRippleButton extends AbstractRippleButton {
/**
* @param {?} phloxAppService
* @param {?} needFocusService
*/
constructor(phloxAppService, needFocusService) {
super(phloxAppService, needFocusService);
this.beforeClickEvent = new EventEmitter();
this.clickEvent = new EventEmitter();
}
/**
* @return {?}
*/
ngOnInit() {
}
/**
* @param {?} $event
* @return {?}
*/
doFocus($event) {
}
/**
* @param {?} $event
* @return {?}
*/
doLostFocus($event) {
}
/**
* @param {?} label
* @return {?}
*/
setLabel(label) {
this.label = label;
}
/**
* @return {?}
*/
getLabel() {
return this.label;
}
/**
* @param {?} $event
* @param {?=} fireEvent
* @return {?}
*/
onClick($event, fireEvent) {
super.onClick($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, ($browserEvent) => {
// Do nothing while clicked.
}, this.emitBeforeClickEvent, this.emitClickEvent);
}
/**
* @param {?=} $event
* @return {?}
*/
emitBeforeClickEvent($event) {
// emit event
let /** @type {?} */ data = {
event: $event,
instance: this
};
let /** @type {?} */ ev = EventUtils.newCustomEvent(BEFORE_CLICK_EVENT, this, data, $event);
if (this.beforeClickEvent !== null && this.beforeClickEvent !== undefined) {
this.beforeClickEvent.emit(ev);
}
}
/**
* @param {?=} $event
* @return {?}
*/
emitClickEvent($event) {
// emit event
let /** @type {?} */ data = {
event: $event,
instance: this
};
let /** @type {?} */ ev = EventUtils.newCustomEvent(CLICK_EVENT, this, data, $event);
if (this.clickEvent !== null && this.clickEvent !== undefined) {
this.clickEvent.emit(ev);
}
}
/**
* @return {?}
*/
getClickEvent() {
return this.clickEvent;
}
/**
* @param {?} event
* @return {?}
*/
setClickEvent(event) {
this.clickEvent = event;
}
/**
* @return {?}
*/
getBeforeClickEvent() {
return this.beforeClickEvent;
}
/**
* @param {?} event
* @return {?}
*/
setBeforeClickEvent(event) {
this.beforeClickEvent = event;
}
/**
* @return {?}
*/
isDisabled() {
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()">
<button type="button" (click)="onClick($event)" (focusin)="onFocusing($event)" (blur)="onLostFocusing($event)">
<div class="table-wrapper fluid">
<div class="table-cell-wrapper middle">
{{getLabel()}}
</div>
</div>
</button>
</div>
`
},] },
];
/** @nocollapse */
SimpleRippleButton.ctorParameters = () => [
{ 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);
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":";;;;;AAAA,OAAO,EAAE,SAAS,EAAU,KAAK,EAAE,YAAY,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAC/E,OAAO,EAAE,oBAAoB,EAAE,MAAM,wBAAwB,CAAC;AAC9D,OAAO,EAAE,eAAe,EAAE,MAAM,oCAAoC,CAAC;AACrE,OAAO,EAAE,gBAAgB,EAAE,MAAM,qCAAqC,CAAC;AACvE,OAAO,EAAE,WAAW,EAAE,kBAAkB,EAAE,MAAM,0BAA0B,CAAC;AAC3E,OAAO,EAAE,MAAM,EAAE,MAAM,+BAA+B,CAAC;AAEvD,OAAO,EAAE,UAAU,EAAE,MAAM,2BAA2B,CAAC;AAIvD,uBAAM,SAAS,GAAW,uBAAuB,CAAC;AAgBlD,MAAM,yBAA0B,SAAQ,oBAAoB;;;;;IA+B1D,YAAY,eAAgC,EAAE,gBAAkC;QAC9E,KAAK,CAAC,eAAe,EAAE,gBAAgB,CAAC,CAAC;QAEzC,IAAI,CAAC,gBAAgB,GAAG,IAAI,YAAY,EAAE,CAAC;QAE3C,IAAI,CAAC,UAAU,GAAG,IAAI,YAAY,EAAO,CAAC;KAC3C;;;;IAEM,QAAQ;;;;;;IAIL,OAAO,CAAC,MAAa;KAE9B;;;;;IAES,WAAW,CAAC,MAAa;KAElC;;;;;IAEM,QAAQ,CAAC,KAAa;QAC3B,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;;;;;IAGd,QAAQ;QACb,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC;;;;;;;IAGb,OAAO,CAAC,MAAkB,EAAE,SAAmB;QACpD,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;QAEtB,EAAE,CAAC,CAAC,IAAI,CAAC,YAAY,KAAK,IAAI,IAAI,OAAO,IAAI,CAAC,YAAY,KAAK,UAAU,CAAC,CAAC,CAAC;YAC1E,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC;SACtC;QAED,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,aAAoB,EAAQ,EAAE;;SAEzG,EAAE,IAAI,CAAC,oBAAoB,EAAE,IAAI,CAAC,cAAc,CAAC,CAAC;;;;;;IAG3C,oBAAoB,CAAC,MAAY;;QAEzC,qBAAI,IAAI,GAAQ;YACd,KAAK,EAAE,MAAM;YACb,QAAQ,EAAE,IAAI;SACf,CAAC;QACF,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,MAAY;;QAEnC,qBAAI,IAAI,GAAQ;YACd,KAAK,EAAE,MAAM;YACb,QAAQ,EAAE,IAAI;SACf,CAAC;QACF,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;;;;IAEM,aAAa;QAClB,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC;;;;;;IAGlB,aAAa,CAAC,KAAwB;QAC3C,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;;;;;IAGnB,mBAAmB;QACxB,MAAM,CAAC,IAAI,CAAC,gBAAgB,CAAC;;;;;;IAGxB,mBAAmB,CAAC,KAAU;QACnC,IAAI,CAAC,gBAAgB,GAAG,KAAK,CAAC;;;;;IAGzB,UAAU;QACf,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC;;;+BApHoB,SAAS;;YAhBrD,SAAS,SAAC;gBACT,QAAQ,EAAE,MAAM,CAAC,EAAE;gBACnB,QAAQ,EAAE,SAAS;gBACnB,QAAQ,EAAE;;;;;;;;;CASX;aACA;;;;YAxBQ,eAAe;YACf,gBAAgB;;;sBA4BtB,KAAK;yBAEL,KAAK;6BAEL,KAAK;iCAGL,MAAM,SAAC,gBAAgB;2BAGvB,MAAM,SAAC,UAAU;2BAEjB,KAAK;iCAEL,MAAM,SAAC,gBAAgB;2BAGvB,MAAM,SAAC,UAAU;qCAGjB,MAAM,SAAC,oBAAoB;+BAG3B,MAAM,SAAC,cAAc;;;IAjBrB,MAAM,CAAC,aAAa,CAAC;sCAEI,YAAY;;;IACrC,MAAM,CAAC,OAAO,CAAC;sCAEI,YAAY;;;IAI/B,MAAM,CAAC,aAAa,CAAC;sCACM,YAAY;;;IAEvC,MAAM,CAAC,OAAO,CAAC;sCACM,YAAY;;;IAEjC,MAAM,CAAC,iBAAiB,CAAC;sCACM,YAAY;;;IAE3C,MAAM,CAAC,WAAW,CAAC;sCACM,YAAY","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"]}