UNPKG

ng-zorro-antd-mobile

Version:

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

324 lines 38.2 kB
import { Component, Input, Output, EventEmitter, ViewChild, forwardRef, HostBinding, ElementRef, Renderer2 } from '@angular/core'; import { NG_VALUE_ACCESSOR } from '@angular/forms'; import * as i0 from "@angular/core"; import * as i1 from "@angular/common"; import * as i2 from "@angular/forms"; export class TextareaItemComponent { get value() { return this._value; } set value(v) { if (typeof v === 'undefined' || v === null) { this._value = ''; } else { this._value = v; } this.textRef.nativeElement.value = this._value; this._onChange(this._value); } get defaultValue() { return this._defaultValue; } set defaultValue(value) { this._defaultValue = value; this._value = this._defaultValue; this.textRef.nativeElement.value = this._value; } get placeholder() { return this._placeholder; } set placeholder(value) { this._placeholder = value; } get editable() { return this._editable; } set editable(value) { this._editable = value; } get disabled() { return this._disabled; } set disabled(value) { this._disabled = value; this.setCls(); } get clear() { return this._clear; } set clear(value) { this._clear = value; } get rows() { return this._rows; } set rows(value) { this._rows = value; this.setCls(); } get error() { return this._error; } set error(value) { this._error = value; this.setCls(); } set labelNumber(value) { this._labelNumber = value; this.setCls(); } get count() { return this._count; } set count(value) { this._count = value; this.setCls(); this.setCharacterLength(); } get prefixListCls() { return this._prefixListCls; } set prefixListCls(value) { this._prefixListCls = value; this.setCls(); } set name(value) { this._name = value; this.textRef.nativeElement.name = this._name; } set autoHeight(value) { this._autoHeight = value; } get title() { return this._title; } set title(value) { this._title = value; this.isTitleString = true; if (typeof value !== 'string') { this.isTitleString = false; } } set focus(value) { if (value && value.focus) { this.textRef.nativeElement.focus(); this.inputFocus(''); } } get autoFocus() { return this._autoFocus; } set autoFocus(value) { this._autoFocus = value; } constructor(element, render) { this.element = element; this.render = render; this.prefixCls = 'am-textarea'; this.isTitleString = true; this.maxLength = Infinity; this._prefixListCls = 'am-list'; this._defaultValue = ''; this._placeholder = ''; this._editable = true; this._disabled = false; this._clear = false; this._rows = 1; this._error = false; this._labelNumber = 5; this._name = ''; this._focus = false; this._autoFocus = false; this._isClear = false; this._isClickingClear = false; this.onChange = new EventEmitter(); this.onBlur = new EventEmitter(); this.onFocus = new EventEmitter(); this.onErrorClick = new EventEmitter(); this.clsItem = true; this._onChange = (_) => { }; this._el = element.nativeElement; } setCls() { this.hasCount = this._count > 0 && this._rows > 1; this.render.addClass(this._el, this._prefixListCls + '-item'); this.clsSingleLine = this._rows === 1 && !this._autoHeight; this.clsDisabled = this._disabled; this.clsError = this._error; this.clsFocus = this._focus; this.clsHasCount = this.hasCount; this.labelCls = { [`${this.prefixCls}-label`]: true, [`${this.prefixCls}-label-2`]: this._labelNumber === 2, [`${this.prefixCls}-label-3`]: this._labelNumber === 3, [`${this.prefixCls}-label-4`]: this._labelNumber === 4, [`${this.prefixCls}-label-5`]: this._labelNumber === 5, [`${this.prefixCls}-label-6`]: this._labelNumber === 6, [`${this.prefixCls}-label-7`]: this._labelNumber === 7 }; this.controlCls = { [`${this.prefixCls}-control`]: true }; this.clearCls = { [`${this.prefixCls}-clear-active`]: this._isClickingClear }; } setCharacterLength() { this.characterLength = this.countSymbols(this._value); if (this._count > 0) { this.maxLength = this._count - this.characterLength + (this._value ? this._value.length : 0); } } inputChange(e) { this._value = e; this.textRef.nativeElement.value = this._value; this.setCharacterLength(); this._onChange(this._value); this.onChange.emit(this._value); } inputFocus(value) { this._focus = true; this.setCls(); if (value !== undefined) { this.onFocus.emit(value); } } inputBlur(value, event) { setTimeout(() => { this._focus = false; this.setCls(); this.onBlur.emit(value); this._isClear = false; }, 100); } clearInput() { this._isClickingClear = true; this.setCls(); setTimeout(() => { this._value = ''; this.inputChange(''); this.inputFocus(this._value); this._isClickingClear = false; this.setCls(); }, 100); } errorClick(e) { if (this.onErrorClick) { this.onErrorClick.emit(e); } } reAlignHeight() { const textareaDom = this.textRef.nativeElement; textareaDom.style.height = ''; textareaDom.style.height = `${textareaDom.scrollHeight}px`; } countSymbols(text = '') { const regexAstralSymbols = /[\uD800-\uDBFF][\uDC00-\uDFFF]|\n/g; return text.replace(regexAstralSymbols, '_').length; } writeValue(value) { if (typeof value === 'undefined' || value === null) { this._value = ''; } else { this._value = value; } this.setCharacterLength(); } setDisabledState(isDisabled) { this.disabled = isDisabled; } registerOnChange(fn) { this._onChange = fn; } registerOnTouched(fn) { } ngOnInit() { this.textRef.nativeElement.value = this._value; this.setCls(); this.setCharacterLength(); } ngAfterContentChecked() { if (this._autoHeight) { this.reAlignHeight(); } } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: TextareaItemComponent, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Component }); } static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.8", type: TextareaItemComponent, selector: "TextareaItem , nzm-textarea-item", inputs: { value: "value", defaultValue: "defaultValue", placeholder: "placeholder", editable: "editable", disabled: "disabled", clear: "clear", rows: "rows", error: "error", labelNumber: "labelNumber", count: "count", prefixListCls: "prefixListCls", name: "name", autoHeight: "autoHeight", title: "title", focus: "focus", autoFocus: "autoFocus" }, outputs: { onChange: "onChange", onBlur: "onBlur", onFocus: "onFocus", onErrorClick: "onErrorClick" }, host: { properties: { "class.am-textarea-item": "this.clsItem", "class.am-textarea-disabled": "this.clsDisabled", "class.am-textarea-error": "this.clsError", "class.am-textarea-focus": "this.clsFocus", "class.am-textarea-item-single-line": "this.clsSingleLine", "class.am-textarea-has-count": "this.clsHasCount" } }, providers: [ { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => TextareaItemComponent), multi: true } ], viewQueries: [{ propertyName: "textRef", first: true, predicate: ["text"], descendants: true, static: true }], ngImport: i0, template: "<div *ngIf=\"title && isTitleString\" [ngClass]=\"labelCls\">{{ title }}</div>\n<div *ngIf=\"title && !isTitleString\" [ngClass]=\"labelCls\">\n <ng-template [ngTemplateOutlet]=\"title\"></ng-template>\n</div>\n<div [ngClass]=\"controlCls\">\n <textarea\n #text\n [rows]=\"rows\"\n [maxlength]=\"maxLength\"\n [(ngModel)]=\"value\"\n [defaultValue]=\"defaultValue\"\n [placeholder]=\"placeholder\"\n [disabled]=\"disabled\"\n [readOnly]=\"!editable\"\n [autofocus]=\"autoFocus\"\n (ngModelChange)=\"inputChange($event)\"\n (blur)=\"inputBlur(value, $event)\"\n (focus)=\"inputFocus(value)\"\n ></textarea>\n</div>\n<div\n *ngIf=\"clear && editable && !disabled && (value && value.length > 0)\"\n class=\"{{ prefixCls }}-clear\"\n [ngClass]=\"clearCls\"\n (click)=\"clearInput()\"\n></div>\n<div *ngIf=\"error\" class=\"{{ prefixCls }}-error-extra\" (click)=\"errorClick($event)\"></div>\n<span *ngIf=\"hasCount\" class=\"{{ prefixCls }}-count\">\n <span>{{ characterLength }}</span\n >/{{ count }}\n</span>\n", dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.MaxLengthValidator, selector: "[maxlength][formControlName],[maxlength][formControl],[maxlength][ngModel]", inputs: ["maxlength"] }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }] }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: TextareaItemComponent, decorators: [{ type: Component, args: [{ selector: 'TextareaItem , nzm-textarea-item', providers: [ { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => TextareaItemComponent), multi: true } ], template: "<div *ngIf=\"title && isTitleString\" [ngClass]=\"labelCls\">{{ title }}</div>\n<div *ngIf=\"title && !isTitleString\" [ngClass]=\"labelCls\">\n <ng-template [ngTemplateOutlet]=\"title\"></ng-template>\n</div>\n<div [ngClass]=\"controlCls\">\n <textarea\n #text\n [rows]=\"rows\"\n [maxlength]=\"maxLength\"\n [(ngModel)]=\"value\"\n [defaultValue]=\"defaultValue\"\n [placeholder]=\"placeholder\"\n [disabled]=\"disabled\"\n [readOnly]=\"!editable\"\n [autofocus]=\"autoFocus\"\n (ngModelChange)=\"inputChange($event)\"\n (blur)=\"inputBlur(value, $event)\"\n (focus)=\"inputFocus(value)\"\n ></textarea>\n</div>\n<div\n *ngIf=\"clear && editable && !disabled && (value && value.length > 0)\"\n class=\"{{ prefixCls }}-clear\"\n [ngClass]=\"clearCls\"\n (click)=\"clearInput()\"\n></div>\n<div *ngIf=\"error\" class=\"{{ prefixCls }}-error-extra\" (click)=\"errorClick($event)\"></div>\n<span *ngIf=\"hasCount\" class=\"{{ prefixCls }}-count\">\n <span>{{ characterLength }}</span\n >/{{ count }}\n</span>\n" }] }], ctorParameters: () => [{ type: i0.ElementRef }, { type: i0.Renderer2 }], propDecorators: { textRef: [{ type: ViewChild, args: ['text', { static: true }] }], value: [{ type: Input }], defaultValue: [{ type: Input }], placeholder: [{ type: Input }], editable: [{ type: Input }], disabled: [{ type: Input }], clear: [{ type: Input }], rows: [{ type: Input }], error: [{ type: Input }], labelNumber: [{ type: Input }], count: [{ type: Input }], prefixListCls: [{ type: Input }], name: [{ type: Input }], autoHeight: [{ type: Input }], title: [{ type: Input }], focus: [{ type: Input }], autoFocus: [{ type: Input }], onChange: [{ type: Output }], onBlur: [{ type: Output }], onFocus: [{ type: Output }], onErrorClick: [{ type: Output }], clsItem: [{ type: HostBinding, args: ['class.am-textarea-item'] }], clsDisabled: [{ type: HostBinding, args: ['class.am-textarea-disabled'] }], clsError: [{ type: HostBinding, args: ['class.am-textarea-error'] }], clsFocus: [{ type: HostBinding, args: ['class.am-textarea-focus'] }], clsSingleLine: [{ type: HostBinding, args: ['class.am-textarea-item-single-line'] }], clsHasCount: [{ type: HostBinding, args: ['class.am-textarea-has-count'] }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"textarea-item.component.js","sourceRoot":"","sources":["../../../components/textarea-item/textarea-item.component.ts","../../../components/textarea-item/textarea-item.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  OnInit,\n  Input,\n  Output,\n  EventEmitter,\n  ViewChild,\n  TemplateRef,\n  AfterContentChecked,\n  forwardRef,\n  HostBinding,\n  ElementRef,\n  Renderer2\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\n\n@Component({\n  selector: 'TextareaItem , nzm-textarea-item',\n  templateUrl: './textarea-item.component.html',\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => TextareaItemComponent),\n      multi: true\n    }\n  ]\n})\nexport class TextareaItemComponent implements OnInit, AfterContentChecked, ControlValueAccessor {\n  prefixCls: string = 'am-textarea';\n  wrapCls: object;\n  labelCls: object;\n  controlCls: object;\n  clearCls: object;\n  hasCount: boolean;\n  characterLength: number;\n  isTitleString: boolean = true;\n  maxLength: number = Infinity;\n\n  private _el: ElementRef;\n  private _prefixListCls = 'am-list';\n  private _value: string;\n  private _defaultValue: string = '';\n  private _placeholder: string = '';\n  private _editable: boolean = true;\n  private _disabled: boolean = false;\n  private _clear: boolean = false;\n  private _rows: number = 1;\n  private _count: number;\n  private _autoHeight: boolean;\n  private _error: boolean = false;\n  private _labelNumber: number = 5;\n  private _name: string = '';\n  private _title: string | TemplateRef<any>;\n  private _focus: boolean = false;\n  private _autoFocus: boolean = false;\n  private _isClear: boolean = false;\n  private _isClickingClear: boolean = false;\n\n  @ViewChild('text', { static: true })\n  textRef;\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 {\n      this._value = v;\n    }\n    this.textRef.nativeElement.value = this._value;\n    this._onChange(this._value);\n  }\n  @Input()\n  get defaultValue(): string {\n    return this._defaultValue;\n  }\n  set defaultValue(value: string) {\n    this._defaultValue = value;\n    this._value = this._defaultValue;\n    this.textRef.nativeElement.value = this._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  get editable(): boolean {\n    return this._editable;\n  }\n  set editable(value: boolean) {\n    this._editable = value;\n  }\n  @Input()\n  get disabled(): boolean {\n    return this._disabled;\n  }\n  set disabled(value: boolean) {\n    this._disabled = value;\n    this.setCls();\n  }\n  @Input()\n  get clear(): boolean {\n    return this._clear;\n  }\n  set clear(value: boolean) {\n    this._clear = value;\n  }\n  @Input()\n  get rows(): number {\n    return this._rows;\n  }\n  set rows(value: number) {\n    this._rows = value;\n    this.setCls();\n  }\n  @Input()\n  get error(): boolean {\n    return this._error;\n  }\n  set error(value: boolean) {\n    this._error = value;\n    this.setCls();\n  }\n  @Input()\n  set labelNumber(value: number) {\n    this._labelNumber = value;\n    this.setCls();\n  }\n  @Input()\n  get count(): number {\n    return this._count;\n  }\n  set count(value) {\n    this._count = value;\n    this.setCls();\n    this.setCharacterLength();\n  }\n  @Input()\n  get prefixListCls(): string {\n    return this._prefixListCls;\n  }\n  set prefixListCls(value: string) {\n    this._prefixListCls = value;\n    this.setCls();\n  }\n  @Input()\n  set name(value: string) {\n    this._name = value;\n    this.textRef.nativeElement.name = this._name;\n  }\n  @Input()\n  set autoHeight(value: boolean) {\n    this._autoHeight = value;\n  }\n  @Input()\n  get title(): string | TemplateRef<any> {\n    return this._title;\n  }\n  set title(value: string | TemplateRef<any>) {\n    this._title = value;\n    this.isTitleString = true;\n    if (typeof value !== 'string') {\n      this.isTitleString = false;\n    }\n  }\n  @Input()\n  set focus(value) {\n    if (value && value.focus) {\n      this.textRef.nativeElement.focus();\n      this.inputFocus('');\n    }\n  }\n  @Input()\n  get autoFocus(): boolean {\n    return this._autoFocus;\n  }\n  set autoFocus(value: boolean) {\n    this._autoFocus = value;\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  @Output()\n  onErrorClick: EventEmitter<any> = new EventEmitter<any>();\n\n  @HostBinding('class.am-textarea-item')\n  clsItem: boolean = true;\n  @HostBinding('class.am-textarea-disabled')\n  clsDisabled: boolean;\n  @HostBinding('class.am-textarea-error')\n  clsError: boolean;\n  @HostBinding('class.am-textarea-focus')\n  clsFocus: boolean;\n  @HostBinding('class.am-textarea-item-single-line')\n  clsSingleLine: boolean;\n  @HostBinding('class.am-textarea-has-count')\n  clsHasCount: boolean;\n\n  constructor(private element: ElementRef, private render: Renderer2) {\n    this._el = element.nativeElement;\n  }\n\n  _onChange = (_: any) => {};\n\n  setCls() {\n    this.hasCount = this._count > 0 && this._rows > 1;\n    this.render.addClass(this._el, this._prefixListCls + '-item');\n    this.clsSingleLine = this._rows === 1 && !this._autoHeight;\n    this.clsDisabled = this._disabled;\n    this.clsError = this._error;\n    this.clsFocus = this._focus;\n    this.clsHasCount = this.hasCount;\n    this.labelCls = {\n      [`${this.prefixCls}-label`]: true,\n      [`${this.prefixCls}-label-2`]: this._labelNumber === 2,\n      [`${this.prefixCls}-label-3`]: this._labelNumber === 3,\n      [`${this.prefixCls}-label-4`]: this._labelNumber === 4,\n      [`${this.prefixCls}-label-5`]: this._labelNumber === 5,\n      [`${this.prefixCls}-label-6`]: this._labelNumber === 6,\n      [`${this.prefixCls}-label-7`]: this._labelNumber === 7\n    };\n    this.controlCls = { [`${this.prefixCls}-control`]: true };\n    this.clearCls = {\n      [`${this.prefixCls}-clear-active`]: this._isClickingClear\n    };\n  }\n  setCharacterLength() {\n    this.characterLength = this.countSymbols(this._value);\n    if (this._count > 0) {\n      this.maxLength = this._count - this.characterLength + (this._value ? this._value.length : 0);\n    }\n  }\n\n  inputChange(e) {\n    this._value = e;\n    this.textRef.nativeElement.value = this._value;\n    this.setCharacterLength();\n    this._onChange(this._value);\n    this.onChange.emit(this._value);\n  }\n\n  inputFocus(value) {\n    this._focus = true;\n    this.setCls();\n    if (value !== undefined) {\n      this.onFocus.emit(value);\n    }\n  }\n\n  inputBlur(value, event) {\n    setTimeout(() => {\n      this._focus = false;\n      this.setCls();\n      this.onBlur.emit(value);\n      this._isClear = false;\n    }, 100);\n  }\n\n  clearInput() {\n    this._isClickingClear = true;\n    this.setCls();\n    setTimeout(() => {\n      this._value = '';\n      this.inputChange('');\n      this.inputFocus(this._value);\n      this._isClickingClear = false;\n      this.setCls();\n    }, 100);\n  }\n  errorClick(e) {\n    if (this.onErrorClick) {\n      this.onErrorClick.emit(e);\n    }\n  }\n  reAlignHeight() {\n    const textareaDom = this.textRef.nativeElement;\n    textareaDom.style.height = '';\n    textareaDom.style.height = `${textareaDom.scrollHeight}px`;\n  }\n\n  countSymbols(text = '') {\n    const regexAstralSymbols = /[\\uD800-\\uDBFF][\\uDC00-\\uDFFF]|\\n/g;\n    return text.replace(regexAstralSymbols, '_').length;\n  }\n\n  writeValue(value: any): void {\n    if (typeof value === 'undefined' || value === null) {\n      this._value = '';\n    } else {\n      this._value = value;\n    }\n    this.setCharacterLength();\n  }\n\n  setDisabledState(isDisabled: boolean): void {\n    this.disabled = isDisabled;\n  }\n\n  registerOnChange(fn: (_: any) => void): void {\n    this._onChange = fn;\n  }\n\n  registerOnTouched(fn: any): void {}\n\n  ngOnInit() {\n    this.textRef.nativeElement.value = this._value;\n    this.setCls();\n    this.setCharacterLength();\n  }\n\n  ngAfterContentChecked() {\n    if (this._autoHeight) {\n      this.reAlignHeight();\n    }\n  }\n}\n","<div *ngIf=\"title && isTitleString\" [ngClass]=\"labelCls\">{{ title }}</div>\n<div *ngIf=\"title && !isTitleString\" [ngClass]=\"labelCls\">\n  <ng-template [ngTemplateOutlet]=\"title\"></ng-template>\n</div>\n<div [ngClass]=\"controlCls\">\n  <textarea\n    #text\n    [rows]=\"rows\"\n    [maxlength]=\"maxLength\"\n    [(ngModel)]=\"value\"\n    [defaultValue]=\"defaultValue\"\n    [placeholder]=\"placeholder\"\n    [disabled]=\"disabled\"\n    [readOnly]=\"!editable\"\n    [autofocus]=\"autoFocus\"\n    (ngModelChange)=\"inputChange($event)\"\n    (blur)=\"inputBlur(value, $event)\"\n    (focus)=\"inputFocus(value)\"\n  ></textarea>\n</div>\n<div\n  *ngIf=\"clear && editable && !disabled && (value && value.length > 0)\"\n  class=\"{{ prefixCls }}-clear\"\n  [ngClass]=\"clearCls\"\n  (click)=\"clearInput()\"\n></div>\n<div *ngIf=\"error\" class=\"{{ prefixCls }}-error-extra\" (click)=\"errorClick($event)\"></div>\n<span *ngIf=\"hasCount\" class=\"{{ prefixCls }}-count\">\n  <span>{{ characterLength }}</span\n  >/{{ count }}\n</span>\n"]}