UNPKG

ng-zorro-antd-mobile

Version:

An enterprise-class mobile UI components based on Ant Design and Angular

506 lines 35.2 kB
/** * @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"]}