ng-zorro-antd-mobile
Version:
An enterprise-class mobile UI components based on Ant Design and Angular
506 lines • 35.2 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { Component, ElementRef, EventEmitter, Input, Output, ViewEncapsulation, HostBinding, NgZone } from '@angular/core';
import { CustomInputService } from './custom-input.service';
var CustomInputComponent = /** @class */ (function () {
function CustomInputComponent(_ref, _customInputService, _ngZone) {
var _this = this;
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 = (/**
* @return {?}
*/
function () {
_this.removeBlurListener();
/** @type {?} */
var focus = _this.focus;
if (!focus || _this._setFocus) {
_this.onInputFocus();
}
setTimeout((/**
* @return {?}
*/
function () {
_this.addBlurListener();
}), 50);
});
this.doBlur = (/**
* @param {?} ev
* @return {?}
*/
function (ev) {
/** @type {?} */
var value = _this._value;
// 点击是否是组件本身
/** @type {?} */
var parentFound = false;
// 点击目标是否是custom-input
/** @type {?} */
var isInput = false;
// 点击目标是否是custom-keyboard
/** @type {?} */
var isKeyboard = false;
/** @type {?} */
var isClear = false;
/** @type {?} */
var 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 = (/**
* @return {?}
*/
function () {
document.removeEventListener('click', _this.doBlur, false);
});
this.addBlurListener = (/**
* @return {?}
*/
function () {
document.addEventListener('click', _this.doBlur, false);
});
this.onInputBlur = (/**
* @param {?} value
* @return {?}
*/
function (value) {
_this.focus = false;
_this.setFakeInputCls();
_this.onBlur.emit(_this._value);
CustomInputService.hideKeyboard();
});
this.onInputFocus = (/**
* @return {?}
*/
function () {
_this.onFocus.emit(_this._value);
_this.focus = true;
_this._setFocus = false;
_this.setFakeInputCls();
setTimeout((/**
* @return {?}
*/
function () {
CustomInputService.showKeyboard();
}), 100);
});
this.setFakeInputCls = (/**
* @return {?}
*/
function () {
var _a;
_this.fakeInputCls = (_a = {},
_a["fake-input"] = true,
_a['fake-input-disabled'] = _this._disabled,
_a['focus'] = _this.focus,
_a);
});
this.setContainerCls = (/**
* @return {?}
*/
function () {
_this.clsFakeContainerLeft = _this._moneyKeyboardAlign === 'left';
});
this.onKeyboardClick = (/**
* @param {?} keyboardItemValue
* @return {?}
*/
function (keyboardItemValue) {
/** @type {?} */
var 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((/**
* @return {?}
*/
function () {
_this._value = valueAfterChange;
}));
});
}
Object.defineProperty(CustomInputComponent.prototype, "value", {
get: /**
* @return {?}
*/
function () {
return this._value;
},
set: /**
* @param {?} v
* @return {?}
*/
function (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();
}
},
enumerable: true,
configurable: true
});
Object.defineProperty(CustomInputComponent.prototype, "defaultValue", {
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
this._defaultValue = value;
if (!this._value) {
this._value = this._defaultValue.toString();
}
},
enumerable: true,
configurable: true
});
Object.defineProperty(CustomInputComponent.prototype, "maxLength", {
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
this._maxLength = value;
},
enumerable: true,
configurable: true
});
Object.defineProperty(CustomInputComponent.prototype, "placeholder", {
get: /**
* @return {?}
*/
function () {
return this._placeholder;
},
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
this._placeholder = value;
},
enumerable: true,
configurable: true
});
Object.defineProperty(CustomInputComponent.prototype, "editable", {
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
this._editable = value;
},
enumerable: true,
configurable: true
});
Object.defineProperty(CustomInputComponent.prototype, "disabled", {
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
this._disabled = value;
},
enumerable: true,
configurable: true
});
Object.defineProperty(CustomInputComponent.prototype, "fontColor", {
get: /**
* @return {?}
*/
function () {
return this._fontColor;
},
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
this._fontColor = value;
},
enumerable: true,
configurable: true
});
Object.defineProperty(CustomInputComponent.prototype, "moneyKeyboardAlign", {
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
this._moneyKeyboardAlign = value;
this.setContainerCls();
},
enumerable: true,
configurable: true
});
Object.defineProperty(CustomInputComponent.prototype, "setFocus", {
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
if (value) {
this._setFocus = value.focus;
if (this._setFocus) {
this.inputFocus();
}
}
},
enumerable: true,
configurable: true
});
/**
* @return {?}
*/
CustomInputComponent.prototype.onFakeInputClick = /**
* @return {?}
*/
function () {
if (this._preventKeyboard) {
return;
}
this.inputFocus();
};
/**
* @return {?}
*/
CustomInputComponent.prototype.ngOnInit = /**
* @return {?}
*/
function () {
this._preventKeyboard = this._disabled || !this._editable;
this.setFakeInputCls();
this.setContainerCls();
};
/**
* @return {?}
*/
CustomInputComponent.prototype.ngOnDestroy = /**
* @return {?}
*/
function () {
this.removeBlurListener();
if (CustomInputService) {
CustomInputService.hideKeyboard();
CustomInputService.compRef = null;
}
/** @type {?} */
var container = document.querySelector("#" + this.keyboardPrefixCls + "-container");
if (container) {
container.remove();
}
};
CustomInputComponent.decorators = [
{ type: Component, args: [{
selector: 'CustomInput',
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",
encapsulation: ViewEncapsulation.None,
providers: [CustomInputService]
}] }
];
/** @nocollapse */
CustomInputComponent.ctorParameters = function () { return [
{ type: ElementRef },
{ type: CustomInputService },
{ type: NgZone }
]; };
CustomInputComponent.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',] }]
};
return CustomInputComponent;
}());
export { CustomInputComponent };
if (false) {
/** @type {?} */
CustomInputComponent.prototype.keyboardPrefixCls;
/** @type {?} */
CustomInputComponent.prototype.fakeInputCls;
/** @type {?} */
CustomInputComponent.prototype.focus;
/**
* @type {?}
* @private
*/
CustomInputComponent.prototype._value;
/**
* @type {?}
* @private
*/
CustomInputComponent.prototype._defaultValue;
/**
* @type {?}
* @private
*/
CustomInputComponent.prototype._placeholder;
/**
* @type {?}
* @private
*/
CustomInputComponent.prototype._maxLength;
/**
* @type {?}
* @private
*/
CustomInputComponent.prototype._editable;
/**
* @type {?}
* @private
*/
CustomInputComponent.prototype._disabled;
/**
* @type {?}
* @private
*/
CustomInputComponent.prototype._setFocus;
/**
* @type {?}
* @private
*/
CustomInputComponent.prototype._preventKeyboard;
/**
* @type {?}
* @private
*/
CustomInputComponent.prototype._moneyKeyboardAlign;
/**
* @type {?}
* @private
*/
CustomInputComponent.prototype._fontColor;
/** @type {?} */
CustomInputComponent.prototype.onChange;
/** @type {?} */
CustomInputComponent.prototype.onBlur;
/** @type {?} */
CustomInputComponent.prototype.onFocus;
/** @type {?} */
CustomInputComponent.prototype.clsFakeContainer;
/** @type {?} */
CustomInputComponent.prototype.clsFakeContainerLeft;
/** @type {?} */
CustomInputComponent.prototype.inputFocus;
/** @type {?} */
CustomInputComponent.prototype.doBlur;
/** @type {?} */
CustomInputComponent.prototype.removeBlurListener;
/** @type {?} */
CustomInputComponent.prototype.addBlurListener;
/** @type {?} */
CustomInputComponent.prototype.onInputBlur;
/** @type {?} */
CustomInputComponent.prototype.onInputFocus;
/** @type {?} */
CustomInputComponent.prototype.setFakeInputCls;
/** @type {?} */
CustomInputComponent.prototype.setContainerCls;
/** @type {?} */
CustomInputComponent.prototype.onKeyboardClick;
/**
* @type {?}
* @private
*/
CustomInputComponent.prototype._ref;
/**
* @type {?}
* @private
*/
CustomInputComponent.prototype._customInputService;
/**
* @type {?}
* @private
*/
CustomInputComponent.prototype._ngZone;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"custom-input.component.js","sourceRoot":"ng://ng-zorro-antd-mobile/","sources":["input-item/custom-input/custom-input.component.ts"],"names":[],"mappings":"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","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    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"]}