ng-zorro-antd-mobile
Version:
An enterprise-class mobile UI components based on Ant Design and Angular
725 lines • 43.4 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { Component, Input, Output, EventEmitter, ViewChild, forwardRef, HostBinding, ElementRef, Renderer2 } from '@angular/core';
import { NG_VALUE_ACCESSOR } from '@angular/forms';
var TextareaItemComponent = /** @class */ (function () {
function TextareaItemComponent(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 = (/**
* @param {?} _
* @return {?}
*/
function (_) { });
this._el = element.nativeElement;
}
Object.defineProperty(TextareaItemComponent.prototype, "value", {
get: /**
* @return {?}
*/
function () {
return this._value;
},
set: /**
* @param {?} v
* @return {?}
*/
function (v) {
if (typeof v === 'undefined' || v === null) {
this._value = '';
}
else {
this._value = v;
}
this.textRef.nativeElement.value = this._value;
this._onChange(this._value);
},
enumerable: true,
configurable: true
});
Object.defineProperty(TextareaItemComponent.prototype, "defaultValue", {
get: /**
* @return {?}
*/
function () {
return this._defaultValue;
},
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
this._defaultValue = value;
this._value = this._defaultValue;
this.textRef.nativeElement.value = this._value;
},
enumerable: true,
configurable: true
});
Object.defineProperty(TextareaItemComponent.prototype, "placeholder", {
get: /**
* @return {?}
*/
function () {
return this._placeholder;
},
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
this._placeholder = value;
},
enumerable: true,
configurable: true
});
Object.defineProperty(TextareaItemComponent.prototype, "editable", {
get: /**
* @return {?}
*/
function () {
return this._editable;
},
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
this._editable = value;
},
enumerable: true,
configurable: true
});
Object.defineProperty(TextareaItemComponent.prototype, "disabled", {
get: /**
* @return {?}
*/
function () {
return this._disabled;
},
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
this._disabled = value;
this.setCls();
},
enumerable: true,
configurable: true
});
Object.defineProperty(TextareaItemComponent.prototype, "clear", {
get: /**
* @return {?}
*/
function () {
return this._clear;
},
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
this._clear = value;
},
enumerable: true,
configurable: true
});
Object.defineProperty(TextareaItemComponent.prototype, "rows", {
get: /**
* @return {?}
*/
function () {
return this._rows;
},
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
this._rows = value;
this.setCls();
},
enumerable: true,
configurable: true
});
Object.defineProperty(TextareaItemComponent.prototype, "error", {
get: /**
* @return {?}
*/
function () {
return this._error;
},
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
this._error = value;
this.setCls();
},
enumerable: true,
configurable: true
});
Object.defineProperty(TextareaItemComponent.prototype, "labelNumber", {
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
this._labelNumber = value;
this.setCls();
},
enumerable: true,
configurable: true
});
Object.defineProperty(TextareaItemComponent.prototype, "count", {
get: /**
* @return {?}
*/
function () {
return this._count;
},
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
this._count = value;
this.setCls();
this.setCharacterLength();
},
enumerable: true,
configurable: true
});
Object.defineProperty(TextareaItemComponent.prototype, "prefixListCls", {
get: /**
* @return {?}
*/
function () {
return this._prefixListCls;
},
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
this._prefixListCls = value;
this.setCls();
},
enumerable: true,
configurable: true
});
Object.defineProperty(TextareaItemComponent.prototype, "name", {
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
this._name = value;
this.textRef.nativeElement.name = this._name;
},
enumerable: true,
configurable: true
});
Object.defineProperty(TextareaItemComponent.prototype, "autoHeight", {
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
this._autoHeight = value;
},
enumerable: true,
configurable: true
});
Object.defineProperty(TextareaItemComponent.prototype, "title", {
get: /**
* @return {?}
*/
function () {
return this._title;
},
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
this._title = value;
this.isTitleString = true;
if (typeof value !== 'string') {
this.isTitleString = false;
}
},
enumerable: true,
configurable: true
});
Object.defineProperty(TextareaItemComponent.prototype, "focus", {
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
if (value && value.focus) {
this.textRef.nativeElement.focus();
this.inputFocus('');
}
},
enumerable: true,
configurable: true
});
Object.defineProperty(TextareaItemComponent.prototype, "autoFocus", {
get: /**
* @return {?}
*/
function () {
return this._autoFocus;
},
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
this._autoFocus = value;
},
enumerable: true,
configurable: true
});
/**
* @return {?}
*/
TextareaItemComponent.prototype.setCls = /**
* @return {?}
*/
function () {
var _a, _b, _c;
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 = (_a = {},
_a[this.prefixCls + "-label"] = true,
_a[this.prefixCls + "-label-2"] = this._labelNumber === 2,
_a[this.prefixCls + "-label-3"] = this._labelNumber === 3,
_a[this.prefixCls + "-label-4"] = this._labelNumber === 4,
_a[this.prefixCls + "-label-5"] = this._labelNumber === 5,
_a[this.prefixCls + "-label-6"] = this._labelNumber === 6,
_a[this.prefixCls + "-label-7"] = this._labelNumber === 7,
_a);
this.controlCls = (_b = {}, _b[this.prefixCls + "-control"] = true, _b);
this.clearCls = (_c = {},
_c[this.prefixCls + "-clear-active"] = this._isClickingClear,
_c);
};
/**
* @return {?}
*/
TextareaItemComponent.prototype.setCharacterLength = /**
* @return {?}
*/
function () {
this.characterLength = this.countSymbols(this._value);
if (this._count > 0) {
this.maxLength = this._count - this.characterLength + (this._value ? this._value.length : 0);
}
};
/**
* @param {?} e
* @return {?}
*/
TextareaItemComponent.prototype.inputChange = /**
* @param {?} e
* @return {?}
*/
function (e) {
this._value = e;
this.textRef.nativeElement.value = this._value;
this.setCharacterLength();
this._onChange(this._value);
this.onChange.emit(this._value);
};
/**
* @param {?} value
* @return {?}
*/
TextareaItemComponent.prototype.inputFocus = /**
* @param {?} value
* @return {?}
*/
function (value) {
this._focus = true;
this.setCls();
if (value !== undefined) {
this.onFocus.emit(value);
}
};
/**
* @param {?} value
* @param {?} event
* @return {?}
*/
TextareaItemComponent.prototype.inputBlur = /**
* @param {?} value
* @param {?} event
* @return {?}
*/
function (value, event) {
var _this = this;
setTimeout((/**
* @return {?}
*/
function () {
_this._focus = false;
_this.setCls();
_this.onBlur.emit(value);
_this._isClear = false;
}), 100);
};
/**
* @return {?}
*/
TextareaItemComponent.prototype.clearInput = /**
* @return {?}
*/
function () {
var _this = this;
this._isClickingClear = true;
this.setCls();
setTimeout((/**
* @return {?}
*/
function () {
_this._value = '';
_this.inputChange('');
_this.inputFocus(_this._value);
_this._isClickingClear = false;
_this.setCls();
}), 100);
};
/**
* @param {?} e
* @return {?}
*/
TextareaItemComponent.prototype.errorClick = /**
* @param {?} e
* @return {?}
*/
function (e) {
if (this.onErrorClick) {
this.onErrorClick.emit(e);
}
};
/**
* @return {?}
*/
TextareaItemComponent.prototype.reAlignHeight = /**
* @return {?}
*/
function () {
/** @type {?} */
var textareaDom = this.textRef.nativeElement;
textareaDom.style.height = '';
textareaDom.style.height = textareaDom.scrollHeight + "px";
};
/**
* @param {?=} text
* @return {?}
*/
TextareaItemComponent.prototype.countSymbols = /**
* @param {?=} text
* @return {?}
*/
function (text) {
if (text === void 0) { text = ''; }
/** @type {?} */
var regexAstralSymbols = /[\uD800-\uDBFF][\uDC00-\uDFFF]|\n/g;
return text.replace(regexAstralSymbols, '_').length;
};
/**
* @param {?} value
* @return {?}
*/
TextareaItemComponent.prototype.writeValue = /**
* @param {?} value
* @return {?}
*/
function (value) {
if (typeof value === 'undefined' || value === null) {
this._value = '';
}
else {
this._value = value;
}
};
/**
* @param {?} fn
* @return {?}
*/
TextareaItemComponent.prototype.registerOnChange = /**
* @param {?} fn
* @return {?}
*/
function (fn) {
this._onChange = fn;
};
/**
* @param {?} fn
* @return {?}
*/
TextareaItemComponent.prototype.registerOnTouched = /**
* @param {?} fn
* @return {?}
*/
function (fn) { };
/**
* @return {?}
*/
TextareaItemComponent.prototype.ngOnInit = /**
* @return {?}
*/
function () {
this.textRef.nativeElement.value = this._value;
this.setCls();
this.setCharacterLength();
};
/**
* @return {?}
*/
TextareaItemComponent.prototype.ngAfterContentChecked = /**
* @return {?}
*/
function () {
if (this._autoHeight) {
this.reAlignHeight();
}
};
TextareaItemComponent.decorators = [
{ type: Component, args: [{
selector: 'TextareaItem , nzm-textarea-item',
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",
providers: [
{
provide: NG_VALUE_ACCESSOR,
useExisting: forwardRef((/**
* @return {?}
*/
function () { return TextareaItemComponent; })),
multi: true
}
]
}] }
];
/** @nocollapse */
TextareaItemComponent.ctorParameters = function () { return [
{ type: ElementRef },
{ type: Renderer2 }
]; };
TextareaItemComponent.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',] }]
};
return TextareaItemComponent;
}());
export { TextareaItemComponent };
if (false) {
/** @type {?} */
TextareaItemComponent.prototype.prefixCls;
/** @type {?} */
TextareaItemComponent.prototype.wrapCls;
/** @type {?} */
TextareaItemComponent.prototype.labelCls;
/** @type {?} */
TextareaItemComponent.prototype.controlCls;
/** @type {?} */
TextareaItemComponent.prototype.clearCls;
/** @type {?} */
TextareaItemComponent.prototype.hasCount;
/** @type {?} */
TextareaItemComponent.prototype.characterLength;
/** @type {?} */
TextareaItemComponent.prototype.isTitleString;
/** @type {?} */
TextareaItemComponent.prototype.maxLength;
/**
* @type {?}
* @private
*/
TextareaItemComponent.prototype._el;
/**
* @type {?}
* @private
*/
TextareaItemComponent.prototype._prefixListCls;
/**
* @type {?}
* @private
*/
TextareaItemComponent.prototype._value;
/**
* @type {?}
* @private
*/
TextareaItemComponent.prototype._defaultValue;
/**
* @type {?}
* @private
*/
TextareaItemComponent.prototype._placeholder;
/**
* @type {?}
* @private
*/
TextareaItemComponent.prototype._editable;
/**
* @type {?}
* @private
*/
TextareaItemComponent.prototype._disabled;
/**
* @type {?}
* @private
*/
TextareaItemComponent.prototype._clear;
/**
* @type {?}
* @private
*/
TextareaItemComponent.prototype._rows;
/**
* @type {?}
* @private
*/
TextareaItemComponent.prototype._count;
/**
* @type {?}
* @private
*/
TextareaItemComponent.prototype._autoHeight;
/**
* @type {?}
* @private
*/
TextareaItemComponent.prototype._error;
/**
* @type {?}
* @private
*/
TextareaItemComponent.prototype._labelNumber;
/**
* @type {?}
* @private
*/
TextareaItemComponent.prototype._name;
/**
* @type {?}
* @private
*/
TextareaItemComponent.prototype._title;
/**
* @type {?}
* @private
*/
TextareaItemComponent.prototype._focus;
/**
* @type {?}
* @private
*/
TextareaItemComponent.prototype._autoFocus;
/**
* @type {?}
* @private
*/
TextareaItemComponent.prototype._isClear;
/**
* @type {?}
* @private
*/
TextareaItemComponent.prototype._isClickingClear;
/** @type {?} */
TextareaItemComponent.prototype.textRef;
/** @type {?} */
TextareaItemComponent.prototype.onChange;
/** @type {?} */
TextareaItemComponent.prototype.onBlur;
/** @type {?} */
TextareaItemComponent.prototype.onFocus;
/** @type {?} */
TextareaItemComponent.prototype.onErrorClick;
/** @type {?} */
TextareaItemComponent.prototype.clsItem;
/** @type {?} */
TextareaItemComponent.prototype.clsDisabled;
/** @type {?} */
TextareaItemComponent.prototype.clsError;
/** @type {?} */
TextareaItemComponent.prototype.clsFocus;
/** @type {?} */
TextareaItemComponent.prototype.clsSingleLine;
/** @type {?} */
TextareaItemComponent.prototype.clsHasCount;
/** @type {?} */
TextareaItemComponent.prototype._onChange;
/**
* @type {?}
* @private
*/
TextareaItemComponent.prototype.element;
/**
* @type {?}
* @private
*/
TextareaItemComponent.prototype.render;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"textarea-item.component.js","sourceRoot":"ng://ng-zorro-antd-mobile/","sources":["textarea-item/textarea-item.component.ts"],"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  }\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"]}