ng-zorro-antd-mobile
Version:
An enterprise-class mobile UI components based on Ant Design and Angular
263 lines • 31 kB
JavaScript
import { Component, ElementRef, EventEmitter, Input, Output, ViewEncapsulation, HostBinding, NgZone } from '@angular/core';
import { CustomInputService } from './custom-input.service';
import * as i0 from "@angular/core";
import * as i1 from "./custom-input.service";
import * as i2 from "@angular/common";
export class CustomInputComponent {
get value() {
return this._value;
}
set value(v) {
if (typeof v === 'undefined' || v === null) {
this._value = '';
}
else if (this._maxLength !== undefined && this._maxLength >= 0) {
this._value = v.toString().substr(0, this._maxLength);
}
else {
this._value = v.toString();
}
}
set defaultValue(value) {
this._defaultValue = value;
if (!this._value) {
this._value = this._defaultValue.toString();
}
}
set maxLength(value) {
this._maxLength = value;
}
get placeholder() {
return this._placeholder;
}
set placeholder(value) {
this._placeholder = value;
}
set editable(value) {
this._editable = value;
}
set disabled(value) {
this._disabled = value;
}
get fontColor() {
return this._fontColor;
}
set fontColor(value) {
this._fontColor = value;
}
set moneyKeyboardAlign(value) {
this._moneyKeyboardAlign = value;
this.setContainerCls();
}
set setFocus(value) {
if (value) {
this._setFocus = value.focus;
if (this._setFocus) {
this.inputFocus();
}
}
}
constructor(_ref, _customInputService, _ngZone) {
this._ref = _ref;
this._customInputService = _customInputService;
this._ngZone = _ngZone;
this.keyboardPrefixCls = 'am-number-keyboard';
this.focus = false;
this._value = '';
this._defaultValue = '';
this._placeholder = '';
this._editable = true;
this._disabled = false;
this._setFocus = false;
this.onChange = new EventEmitter();
this.onBlur = new EventEmitter();
this.onFocus = new EventEmitter();
this.clsFakeContainer = true;
this.inputFocus = () => {
this.removeBlurListener();
const focus = this.focus;
if (!focus || this._setFocus) {
this.onInputFocus();
}
setTimeout(() => {
this.addBlurListener();
}, 50);
};
this.doBlur = ev => {
const value = this._value;
// 点击是否是组件本身
let parentFound = false;
// 点击目标是否是custom-input
let isInput = false;
// 点击目标是否是custom-keyboard
let isKeyboard = false;
let isClear = false;
let target = ev.target;
while (target && target !== null && !parentFound) {
if (target === this._ref.nativeElement) {
parentFound = true;
}
if (target.localName === 'custominput') {
isInput = true;
}
if (target.localName === 'customkeyboard') {
isKeyboard = true;
}
if (target.className.indexOf('am-input-clear') >= 0) {
isClear = true;
}
target = target.parentElement;
}
// 当点击目标是本身的时候,获取焦点、不隐藏keyboard
// 当点击目标不是本身但是其他的custom-input时,失去焦点、不隐藏keyboard
// 当点击目标是keyboard时,不失去焦点,不隐藏keyboard
if (parentFound) {
this.focus = true;
}
else if (isInput) {
this._setFocus = false;
this.focus = false;
this.onBlur.emit(this._value);
}
if (this.focus && isKeyboard) {
this.focus = true;
this.onKeyboardClick(CustomInputService.clickValue);
}
if (!parentFound && !isInput && !isKeyboard && !isClear && !this._setFocus) {
this.focus = false;
this._setFocus = false;
this.onBlur.emit(this._value);
CustomInputService.hideKeyboard();
}
this.setFakeInputCls();
};
this.removeBlurListener = () => {
document.removeEventListener('click', this.doBlur, false);
};
this.addBlurListener = () => {
document.addEventListener('click', this.doBlur, false);
};
this.onInputBlur = value => {
this.focus = false;
this.setFakeInputCls();
this.onBlur.emit(this._value);
CustomInputService.hideKeyboard();
};
this.onInputFocus = () => {
this.onFocus.emit(this._value);
this.focus = true;
this._setFocus = false;
this.setFakeInputCls();
setTimeout(() => {
CustomInputService.showKeyboard();
}, 100);
};
this.setFakeInputCls = () => {
this.fakeInputCls = {
[`fake-input`]: true,
['fake-input-disabled']: this._disabled,
['focus']: this.focus
};
};
this.setContainerCls = () => {
this.clsFakeContainerLeft = this._moneyKeyboardAlign === 'left';
};
this.onKeyboardClick = keyboardItemValue => {
// 只允许一个小数点且不能是首位
if (keyboardItemValue === '.' && (this._value.includes('.') || this._value === '')) {
return;
}
let valueAfterChange;
// 删除键
if (keyboardItemValue === 'delete') {
valueAfterChange = this._value.substring(0, this._value.length - 1);
this.onChange.emit(valueAfterChange);
// 确认键
}
else if (keyboardItemValue === 'confirm') {
valueAfterChange = this._value;
this.onChange.emit(valueAfterChange);
this.onInputBlur(this._value);
// 收起键
}
else if (keyboardItemValue === 'hide') {
valueAfterChange = this._value;
this.onInputBlur(valueAfterChange);
}
else {
if (this._maxLength !== undefined &&
+this._maxLength >= 0 &&
(this._value + keyboardItemValue).length > this._maxLength) {
valueAfterChange = (this._value + keyboardItemValue).substr(0, this._maxLength);
this.onChange.emit(valueAfterChange);
}
else {
valueAfterChange = this._value + keyboardItemValue;
this.onChange.emit(valueAfterChange);
}
}
this._ngZone.run(() => {
this._value = valueAfterChange;
});
};
}
onFakeInputClick() {
if (this._preventKeyboard) {
return;
}
this.inputFocus();
}
ngOnInit() {
this._preventKeyboard = this._disabled || !this._editable;
this.setFakeInputCls();
this.setContainerCls();
}
ngOnDestroy() {
this.removeBlurListener();
if (CustomInputService) {
CustomInputService.hideKeyboard();
CustomInputService.compRef = null;
}
const container = document.querySelector(`#${this.keyboardPrefixCls}-container`);
if (container) {
container.remove();
}
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: CustomInputComponent, deps: [{ token: i0.ElementRef }, { token: i1.CustomInputService }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Component }); }
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.8", type: CustomInputComponent, selector: "CustomInput", inputs: { value: "value", defaultValue: "defaultValue", maxLength: "maxLength", placeholder: "placeholder", editable: "editable", disabled: "disabled", fontColor: "fontColor", moneyKeyboardAlign: "moneyKeyboardAlign", setFocus: "setFocus" }, outputs: { onChange: "onChange", onBlur: "onBlur", onFocus: "onFocus" }, host: { properties: { "class.fake-input-container": "this.clsFakeContainer", "class.fake-input-container-left": "this.clsFakeContainerLeft" } }, providers: [CustomInputService], ngImport: i0, template: "<div *ngIf=\"value === ''\" class=\"fake-input-placeholder\">\n {{ placeholder }}\n</div>\n<div [ngClass]=\"fakeInputCls\" [style.color]=\"fontColor\" (click)=\"onFakeInputClick()\">\n {{ value }}\n</div>\n", dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], encapsulation: i0.ViewEncapsulation.None }); }
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: CustomInputComponent, decorators: [{
type: Component,
args: [{ selector: 'CustomInput', encapsulation: ViewEncapsulation.None, providers: [CustomInputService], template: "<div *ngIf=\"value === ''\" class=\"fake-input-placeholder\">\n {{ placeholder }}\n</div>\n<div [ngClass]=\"fakeInputCls\" [style.color]=\"fontColor\" (click)=\"onFakeInputClick()\">\n {{ value }}\n</div>\n" }]
}], ctorParameters: () => [{ type: i0.ElementRef }, { type: i1.CustomInputService }, { type: i0.NgZone }], propDecorators: { value: [{
type: Input
}], defaultValue: [{
type: Input
}], maxLength: [{
type: Input
}], placeholder: [{
type: Input
}], editable: [{
type: Input
}], disabled: [{
type: Input
}], fontColor: [{
type: Input
}], moneyKeyboardAlign: [{
type: Input
}], setFocus: [{
type: Input
}], onChange: [{
type: Output
}], onBlur: [{
type: Output
}], onFocus: [{
type: Output
}], clsFakeContainer: [{
type: HostBinding,
args: ['class.fake-input-container']
}], clsFakeContainerLeft: [{
type: HostBinding,
args: ['class.fake-input-container-left']
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"custom-input.component.js","sourceRoot":"","sources":["../../../../components/input-item/custom-input/custom-input.component.ts","../../../../components/input-item/custom-input/custom-input.component.html"],"names":[],"mappings":"AAAA,OAAO,EACL,SAAS,EACT,UAAU,EACV,YAAY,EACZ,KAAK,EACL,MAAM,EAGN,iBAAiB,EACjB,WAAW,EACX,MAAM,EACP,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,kBAAkB,EAAE,MAAM,wBAAwB,CAAC;;;;AAQ5D,MAAM,OAAO,oBAAoB;IAgB/B,IACI,KAAK;QACP,OAAO,IAAI,CAAC,MAAM,CAAC;IACrB,CAAC;IACD,IAAI,KAAK,CAAC,CAAS;QACjB,IAAI,OAAO,CAAC,KAAK,WAAW,IAAI,CAAC,KAAK,IAAI,EAAE;YAC1C,IAAI,CAAC,MAAM,GAAG,EAAE,CAAC;SAClB;aAAM,IAAI,IAAI,CAAC,UAAU,KAAK,SAAS,IAAI,IAAI,CAAC,UAAU,IAAI,CAAC,EAAE;YAChE,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,QAAQ,EAAE,CAAC,MAAM,CAAC,CAAC,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;SACvD;aAAM;YACL,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,QAAQ,EAAE,CAAC;SAC5B;IACH,CAAC;IACD,IACI,YAAY,CAAC,KAAa;QAC5B,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;QAC3B,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE;YAChB,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,aAAa,CAAC,QAAQ,EAAE,CAAC;SAC7C;IACH,CAAC;IACD,IACI,SAAS,CAAC,KAAa;QACzB,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;IAC1B,CAAC;IACD,IACI,WAAW;QACb,OAAO,IAAI,CAAC,YAAY,CAAC;IAC3B,CAAC;IACD,IAAI,WAAW,CAAC,KAAa;QAC3B,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;IAC5B,CAAC;IACD,IACI,QAAQ,CAAC,KAAc;QACzB,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;IACzB,CAAC;IACD,IACI,QAAQ,CAAC,KAAc;QACzB,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;IACzB,CAAC;IACD,IACI,SAAS;QACX,OAAO,IAAI,CAAC,UAAU,CAAC;IACzB,CAAC;IACD,IAAI,SAAS,CAAC,KAAa;QACzB,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;IAC1B,CAAC;IACD,IACI,kBAAkB,CAAC,KAAa;QAClC,IAAI,CAAC,mBAAmB,GAAG,KAAK,CAAC;QACjC,IAAI,CAAC,eAAe,EAAE,CAAC;IACzB,CAAC;IACD,IACI,QAAQ,CAAC,KAAK;QAChB,IAAI,KAAK,EAAE;YACT,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC,KAAK,CAAC;YAC7B,IAAI,IAAI,CAAC,SAAS,EAAE;gBAClB,IAAI,CAAC,UAAU,EAAE,CAAC;aACnB;SACF;IACH,CAAC;IAaD,YAAoB,IAAgB,EAAU,mBAAuC,EAAU,OAAe;QAA1F,SAAI,GAAJ,IAAI,CAAY;QAAU,wBAAmB,GAAnB,mBAAmB,CAAoB;QAAU,YAAO,GAAP,OAAO,CAAQ;QAvF9G,sBAAiB,GAAW,oBAAoB,CAAC;QAEjD,UAAK,GAAY,KAAK,CAAC;QAEf,WAAM,GAAW,EAAE,CAAC;QACpB,kBAAa,GAAW,EAAE,CAAC;QAC3B,iBAAY,GAAW,EAAE,CAAC;QAE1B,cAAS,GAAY,IAAI,CAAC;QAC1B,cAAS,GAAY,KAAK,CAAC;QAC3B,cAAS,GAAY,KAAK,CAAC;QAkEnC,aAAQ,GAAsB,IAAI,YAAY,EAAO,CAAC;QAEtD,WAAM,GAAsB,IAAI,YAAY,EAAO,CAAC;QAEpD,YAAO,GAAsB,IAAI,YAAY,EAAO,CAAC;QAGrD,qBAAgB,GAAY,IAAI,CAAC;QAajC,eAAU,GAAG,GAAG,EAAE;YAChB,IAAI,CAAC,kBAAkB,EAAE,CAAC;YAC1B,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC;YACzB,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,SAAS,EAAE;gBAC5B,IAAI,CAAC,YAAY,EAAE,CAAC;aACrB;YACD,UAAU,CAAC,GAAG,EAAE;gBACd,IAAI,CAAC,eAAe,EAAE,CAAC;YACzB,CAAC,EAAE,EAAE,CAAC,CAAC;QACT,CAAC,CAAA;QAED,WAAM,GAAG,EAAE,CAAC,EAAE;YACZ,MAAM,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC;YAC1B,YAAY;YACZ,IAAI,WAAW,GAAG,KAAK,CAAC;YACxB,sBAAsB;YACtB,IAAI,OAAO,GAAG,KAAK,CAAC;YACpB,yBAAyB;YACzB,IAAI,UAAU,GAAG,KAAK,CAAC;YACvB,IAAI,OAAO,GAAG,KAAK,CAAC;YACpB,IAAI,MAAM,GAAG,EAAE,CAAC,MAAM,CAAC;YACvB,OAAO,MAAM,IAAI,MAAM,KAAK,IAAI,IAAI,CAAC,WAAW,EAAE;gBAChD,IAAI,MAAM,KAAK,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE;oBACtC,WAAW,GAAG,IAAI,CAAC;iBACpB;gBACD,IAAI,MAAM,CAAC,SAAS,KAAK,aAAa,EAAE;oBACtC,OAAO,GAAG,IAAI,CAAC;iBAChB;gBACD,IAAI,MAAM,CAAC,SAAS,KAAK,gBAAgB,EAAE;oBACzC,UAAU,GAAG,IAAI,CAAC;iBACnB;gBACD,IAAI,MAAM,CAAC,SAAS,CAAC,OAAO,CAAC,gBAAgB,CAAC,IAAI,CAAC,EAAE;oBACnD,OAAO,GAAG,IAAI,CAAC;iBAChB;gBACD,MAAM,GAAG,MAAM,CAAC,aAAa,CAAC;aAC/B;YACD,+BAA+B;YAC/B,+CAA+C;YAC/C,oCAAoC;YACpC,IAAI,WAAW,EAAE;gBACf,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;aACnB;iBAAM,IAAI,OAAO,EAAE;gBAClB,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;gBACvB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;gBACnB,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;aAC/B;YACD,IAAI,IAAI,CAAC,KAAK,IAAI,UAAU,EAAE;gBAC5B,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;gBAClB,IAAI,CAAC,eAAe,CAAC,kBAAkB,CAAC,UAAU,CAAC,CAAC;aACrD;YACD,IAAI,CAAC,WAAW,IAAI,CAAC,OAAO,IAAI,CAAC,UAAU,IAAI,CAAC,OAAO,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE;gBAC1E,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;gBACnB,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;gBACvB,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;gBAC9B,kBAAkB,CAAC,YAAY,EAAE,CAAC;aACnC;YACD,IAAI,CAAC,eAAe,EAAE,CAAC;QACzB,CAAC,CAAA;QAED,uBAAkB,GAAG,GAAG,EAAE;YACxB,QAAQ,CAAC,mBAAmB,CAAC,OAAO,EAAE,IAAI,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC;QAC5D,CAAC,CAAA;QAED,oBAAe,GAAG,GAAG,EAAE;YACrB,QAAQ,CAAC,gBAAgB,CAAC,OAAO,EAAE,IAAI,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC;QACzD,CAAC,CAAA;QAED,gBAAW,GAAG,KAAK,CAAC,EAAE;YACpB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;YACnB,IAAI,CAAC,eAAe,EAAE,CAAC;YACvB,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;YAC9B,kBAAkB,CAAC,YAAY,EAAE,CAAC;QACpC,CAAC,CAAA;QAED,iBAAY,GAAG,GAAG,EAAE;YAClB,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;YAC/B,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;YAClB,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;YACvB,IAAI,CAAC,eAAe,EAAE,CAAC;YACvB,UAAU,CAAC,GAAG,EAAE;gBACd,kBAAkB,CAAC,YAAY,EAAE,CAAC;YACpC,CAAC,EAAE,GAAG,CAAC,CAAC;QACV,CAAC,CAAA;QAED,oBAAe,GAAG,GAAG,EAAE;YACrB,IAAI,CAAC,YAAY,GAAG;gBAClB,CAAC,YAAY,CAAC,EAAE,IAAI;gBACpB,CAAC,qBAAqB,CAAC,EAAE,IAAI,CAAC,SAAS;gBACvC,CAAC,OAAO,CAAC,EAAE,IAAI,CAAC,KAAK;aACtB,CAAC;QACJ,CAAC,CAAA;QAED,oBAAe,GAAG,GAAG,EAAE;YACrB,IAAI,CAAC,oBAAoB,GAAG,IAAI,CAAC,mBAAmB,KAAK,MAAM,CAAC;QAClE,CAAC,CAAA;QAED,oBAAe,GAAG,iBAAiB,CAAC,EAAE;YACpC,iBAAiB;YACjB,IAAI,iBAAiB,KAAK,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,GAAG,CAAC,IAAI,IAAI,CAAC,MAAM,KAAK,EAAE,CAAC,EAAE;gBAClF,OAAO;aACR;YAED,IAAI,gBAAgB,CAAC;YACrB,MAAM;YACN,IAAI,iBAAiB,KAAK,QAAQ,EAAE;gBAClC,gBAAgB,GAAG,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,EAAE,IAAI,CAAC,MAAM,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;gBACpE,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;gBACrC,MAAM;aACP;iBAAM,IAAI,iBAAiB,KAAK,SAAS,EAAE;gBAC1C,gBAAgB,GAAG,IAAI,CAAC,MAAM,CAAC;gBAC/B,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;gBACrC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;gBAC9B,MAAM;aACP;iBAAM,IAAI,iBAAiB,KAAK,MAAM,EAAE;gBACvC,gBAAgB,GAAG,IAAI,CAAC,MAAM,CAAC;gBAC/B,IAAI,CAAC,WAAW,CAAC,gBAAgB,CAAC,CAAC;aACpC;iBAAM;gBACL,IACE,IAAI,CAAC,UAAU,KAAK,SAAS;oBAC7B,CAAC,IAAI,CAAC,UAAU,IAAI,CAAC;oBACrB,CAAC,IAAI,CAAC,MAAM,GAAG,iBAAiB,CAAC,CAAC,MAAM,GAAG,IAAI,CAAC,UAAU,EAC1D;oBACA,gBAAgB,GAAG,CAAC,IAAI,CAAC,MAAM,GAAG,iBAAiB,CAAC,CAAC,MAAM,CAAC,CAAC,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;oBAChF,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;iBACtC;qBAAM;oBACL,gBAAgB,GAAG,IAAI,CAAC,MAAM,GAAG,iBAAiB,CAAC;oBACnD,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;iBACtC;aACF;YACD,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,GAAG,EAAE;gBACpB,IAAI,CAAC,MAAM,GAAG,gBAAgB,CAAC;YACjC,CAAC,CAAC,CAAC;QACL,CAAC,CAAA;IA7IgH,CAAC;IAElH,gBAAgB;QACd,IAAI,IAAI,CAAC,gBAAgB,EAAE;YACzB,OAAO;SACR;QACD,IAAI,CAAC,UAAU,EAAE,CAAC;IACpB,CAAC;IAwID,QAAQ;QACN,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,SAAS,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC;QAC1D,IAAI,CAAC,eAAe,EAAE,CAAC;QACvB,IAAI,CAAC,eAAe,EAAE,CAAC;IACzB,CAAC;IAED,WAAW;QACT,IAAI,CAAC,kBAAkB,EAAE,CAAC;QAC1B,IAAI,kBAAkB,EAAE;YACtB,kBAAkB,CAAC,YAAY,EAAE,CAAC;YAClC,kBAAkB,CAAC,OAAO,GAAG,IAAI,CAAC;SACnC;QACD,MAAM,SAAS,GAAG,QAAQ,CAAC,aAAa,CAAC,IAAI,IAAI,CAAC,iBAAiB,YAAY,CAAC,CAAC;QACjF,IAAI,SAAS,EAAE;YACb,SAAS,CAAC,MAAM,EAAE,CAAC;SACpB;IACH,CAAC;8GAvPU,oBAAoB;kGAApB,oBAAoB,kfAFpB,CAAC,kBAAkB,CAAC,0BClBjC,kNAMA;;2FDca,oBAAoB;kBANhC,SAAS;+BACE,aAAa,iBAER,iBAAiB,CAAC,IAAI,aAC1B,CAAC,kBAAkB,CAAC;qIAmB3B,KAAK;sBADR,KAAK;gBAcF,YAAY;sBADf,KAAK;gBAQF,SAAS;sBADZ,KAAK;gBAKF,WAAW;sBADd,KAAK;gBAQF,QAAQ;sBADX,KAAK;gBAKF,QAAQ;sBADX,KAAK;gBAKF,SAAS;sBADZ,KAAK;gBAQF,kBAAkB;sBADrB,KAAK;gBAMF,QAAQ;sBADX,KAAK;gBAUN,QAAQ;sBADP,MAAM;gBAGP,MAAM;sBADL,MAAM;gBAGP,OAAO;sBADN,MAAM;gBAIP,gBAAgB;sBADf,WAAW;uBAAC,4BAA4B;gBAGzC,oBAAoB;sBADnB,WAAW;uBAAC,iCAAiC","sourcesContent":["import {\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  Output,\n  OnInit,\n  OnDestroy,\n  ViewEncapsulation,\n  HostBinding,\n  NgZone\n} from '@angular/core';\nimport { CustomInputService } from './custom-input.service';\n\n@Component({\n  selector: 'CustomInput',\n  templateUrl: './custom-input.component.html',\n  encapsulation: ViewEncapsulation.None,\n  providers: [CustomInputService]\n})\nexport class CustomInputComponent implements OnInit, OnDestroy {\n  keyboardPrefixCls: string = 'am-number-keyboard';\n  fakeInputCls: object;\n  focus: boolean = false;\n\n  private _value: string = '';\n  private _defaultValue: string = '';\n  private _placeholder: string = '';\n  private _maxLength: number;\n  private _editable: boolean = true;\n  private _disabled: boolean = false;\n  private _setFocus: boolean = false;\n  private _preventKeyboard: boolean;\n  private _moneyKeyboardAlign: string;\n  private _fontColor: string;\n\n  @Input()\n  get value(): string {\n    return this._value;\n  }\n  set value(v: string) {\n    if (typeof v === 'undefined' || v === null) {\n      this._value = '';\n    } else if (this._maxLength !== undefined && this._maxLength >= 0) {\n      this._value = v.toString().substr(0, this._maxLength);\n    } else {\n      this._value = v.toString();\n    }\n  }\n  @Input()\n  set defaultValue(value: string) {\n    this._defaultValue = value;\n    if (!this._value) {\n      this._value = this._defaultValue.toString();\n    }\n  }\n  @Input()\n  set maxLength(value: number) {\n    this._maxLength = value;\n  }\n  @Input()\n  get placeholder(): string {\n    return this._placeholder;\n  }\n  set placeholder(value: string) {\n    this._placeholder = value;\n  }\n  @Input()\n  set editable(value: boolean) {\n    this._editable = value;\n  }\n  @Input()\n  set disabled(value: boolean) {\n    this._disabled = value;\n  }\n  @Input()\n  get fontColor() {\n    return this._fontColor;\n  }\n  set fontColor(value: string) {\n    this._fontColor = value;\n  }\n  @Input()\n  set moneyKeyboardAlign(value: string) {\n    this._moneyKeyboardAlign = value;\n    this.setContainerCls();\n  }\n  @Input()\n  set setFocus(value) {\n    if (value) {\n      this._setFocus = value.focus;\n      if (this._setFocus) {\n        this.inputFocus();\n      }\n    }\n  }\n  @Output()\n  onChange: EventEmitter<any> = new EventEmitter<any>();\n  @Output()\n  onBlur: EventEmitter<any> = new EventEmitter<any>();\n  @Output()\n  onFocus: EventEmitter<any> = new EventEmitter<any>();\n\n  @HostBinding('class.fake-input-container')\n  clsFakeContainer: boolean = true;\n  @HostBinding('class.fake-input-container-left')\n  clsFakeContainerLeft: boolean;\n\n  constructor(private _ref: ElementRef, private _customInputService: CustomInputService, private _ngZone: NgZone) {}\n\n  onFakeInputClick() {\n    if (this._preventKeyboard) {\n      return;\n    }\n    this.inputFocus();\n  }\n\n  inputFocus = () => {\n    this.removeBlurListener();\n    const focus = this.focus;\n    if (!focus || this._setFocus) {\n      this.onInputFocus();\n    }\n    setTimeout(() => {\n      this.addBlurListener();\n    }, 50);\n  }\n\n  doBlur = ev => {\n    const value = this._value;\n    // 点击是否是组件本身\n    let parentFound = false;\n    // 点击目标是否是custom-input\n    let isInput = false;\n    // 点击目标是否是custom-keyboard\n    let isKeyboard = false;\n    let isClear = false;\n    let target = ev.target;\n    while (target && target !== null && !parentFound) {\n      if (target === this._ref.nativeElement) {\n        parentFound = true;\n      }\n      if (target.localName === 'custominput') {\n        isInput = true;\n      }\n      if (target.localName === 'customkeyboard') {\n        isKeyboard = true;\n      }\n      if (target.className.indexOf('am-input-clear') >= 0) {\n        isClear = true;\n      }\n      target = target.parentElement;\n    }\n    // 当点击目标是本身的时候，获取焦点、不隐藏keyboard\n    // 当点击目标不是本身但是其他的custom-input时，失去焦点、不隐藏keyboard\n    // 当点击目标是keyboard时，不失去焦点，不隐藏keyboard\n    if (parentFound) {\n      this.focus = true;\n    } else if (isInput) {\n      this._setFocus = false;\n      this.focus = false;\n      this.onBlur.emit(this._value);\n    }\n    if (this.focus && isKeyboard) {\n      this.focus = true;\n      this.onKeyboardClick(CustomInputService.clickValue);\n    }\n    if (!parentFound && !isInput && !isKeyboard && !isClear && !this._setFocus) {\n      this.focus = false;\n      this._setFocus = false;\n      this.onBlur.emit(this._value);\n      CustomInputService.hideKeyboard();\n    }\n    this.setFakeInputCls();\n  }\n\n  removeBlurListener = () => {\n    document.removeEventListener('click', this.doBlur, false);\n  }\n\n  addBlurListener = () => {\n    document.addEventListener('click', this.doBlur, false);\n  }\n\n  onInputBlur = value => {\n    this.focus = false;\n    this.setFakeInputCls();\n    this.onBlur.emit(this._value);\n    CustomInputService.hideKeyboard();\n  }\n\n  onInputFocus = () => {\n    this.onFocus.emit(this._value);\n    this.focus = true;\n    this._setFocus = false;\n    this.setFakeInputCls();\n    setTimeout(() => {\n      CustomInputService.showKeyboard();\n    }, 100);\n  }\n\n  setFakeInputCls = () => {\n    this.fakeInputCls = {\n      [`fake-input`]: true,\n      ['fake-input-disabled']: this._disabled,\n      ['focus']: this.focus\n    };\n  }\n\n  setContainerCls = () => {\n    this.clsFakeContainerLeft = this._moneyKeyboardAlign === 'left';\n  }\n\n  onKeyboardClick = keyboardItemValue => {\n    // 只允许一个小数点且不能是首位\n    if (keyboardItemValue === '.' && (this._value.includes('.') || this._value === '')) {\n      return;\n    }\n\n    let valueAfterChange;\n    // 删除键\n    if (keyboardItemValue === 'delete') {\n      valueAfterChange = this._value.substring(0, this._value.length - 1);\n      this.onChange.emit(valueAfterChange);\n      // 确认键\n    } else if (keyboardItemValue === 'confirm') {\n      valueAfterChange = this._value;\n      this.onChange.emit(valueAfterChange);\n      this.onInputBlur(this._value);\n      // 收起键\n    } else if (keyboardItemValue === 'hide') {\n      valueAfterChange = this._value;\n      this.onInputBlur(valueAfterChange);\n    } else {\n      if (\n        this._maxLength !== undefined &&\n        +this._maxLength >= 0 &&\n        (this._value + keyboardItemValue).length > this._maxLength\n      ) {\n        valueAfterChange = (this._value + keyboardItemValue).substr(0, this._maxLength);\n        this.onChange.emit(valueAfterChange);\n      } else {\n        valueAfterChange = this._value + keyboardItemValue;\n        this.onChange.emit(valueAfterChange);\n      }\n    }\n    this._ngZone.run(() => {\n      this._value = valueAfterChange;\n    });\n  }\n\n  ngOnInit() {\n    this._preventKeyboard = this._disabled || !this._editable;\n    this.setFakeInputCls();\n    this.setContainerCls();\n  }\n\n  ngOnDestroy() {\n    this.removeBlurListener();\n    if (CustomInputService) {\n      CustomInputService.hideKeyboard();\n      CustomInputService.compRef = null;\n    }\n    const container = document.querySelector(`#${this.keyboardPrefixCls}-container`);\n    if (container) {\n      container.remove();\n    }\n  }\n}\n","<div *ngIf=\"value === ''\" class=\"fake-input-placeholder\">\n  {{ placeholder }}\n</div>\n<div [ngClass]=\"fakeInputCls\" [style.color]=\"fontColor\" (click)=\"onFakeInputClick()\">\n  {{ value }}\n</div>\n"]}