UNPKG

ng-zorro-antd-mobile

Version:

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

263 lines 31 kB
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":"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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    // 只允许一个小数点且不能是首位\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"]}