@angular-mdl/core
Version:
Angular components, directives and styles based on material design lite https://getmdl.io.
462 lines • 42 kB
JavaScript
import { Component, ElementRef, EventEmitter, forwardRef, HostBinding, Inject, InjectionToken, Input, Optional, Output, Renderer2, ViewChild, ViewEncapsulation, } from "@angular/core";
import { NG_VALUE_ACCESSOR } from "@angular/forms";
import { toBoolean } from "../common/boolean-property";
import { toNumber } from "../common/number.property";
import { noop } from "../common/noop";
import * as i0 from "@angular/core";
import * as i1 from "../icon/mdl-icon.component";
import * as i2 from "../button/mdl-button.component";
import * as i3 from "@angular/forms";
import * as i4 from "@angular/common";
export const DISABLE_NATIVE_VALIDITY_CHECKING = new InjectionToken("disableNativeValidityChecking");
let nextId = 0;
const IS_FOCUSED = "is-focused";
const IS_DISABLED = "is-disabled";
const IS_INVALID = "is-invalid";
const IS_DIRTY = "is-dirty";
/* eslint-disable @angular-eslint/no-conflicting-lifecycle */
export class MdlTextFieldComponent {
constructor(renderer, elmRef, nativeCheckGlobalDisabled) {
this.renderer = renderer;
this.elmRef = elmRef;
this.nativeCheckGlobalDisabled = nativeCheckGlobalDisabled;
// eslint-disable-next-line
this.blurEmitter = new EventEmitter();
// eslint-disable-next-line
this.focusEmitter = new EventEmitter();
// eslint-disable-next-line
this.keyupEmitter = new EventEmitter();
this.type = "text";
this.id = `mdl-textfield-${nextId++}`;
this.tabindex = null;
this.maxlength = null;
this.isTextfield = true;
this.isUpgraded = true;
this.valueIntern = null;
this.onTouchedCallback = noop;
this.onChangeCallback = noop;
this.disabledIntern = false;
this.readonlyIntern = false;
this.requiredIntern = false;
this.autofocusIntern = false;
this.isFloatingLabelIntern = false;
this.rowsIntern = null;
this.maxrowsIntern = -1;
// @experimental
this.disableNativeValidityCheckingIntern = false;
this.el = elmRef.nativeElement;
}
get value() {
return this.valueIntern;
}
set value(v) {
this.valueIntern =
this.type === "number" ? (v === "" ? null : parseFloat(v)) : v;
this.onChangeCallback(this.value);
}
get disabled() {
return this.disabledIntern;
}
set disabled(value) {
this.disabledIntern = toBoolean(value);
}
get readonly() {
return this.readonlyIntern;
}
set readonly(value) {
this.readonlyIntern = toBoolean(value);
}
get required() {
return this.requiredIntern;
}
set required(value) {
this.requiredIntern = toBoolean(value);
}
get autofocus() {
return this.autofocusIntern;
}
set autofocus(value) {
this.autofocusIntern = toBoolean(value);
}
get isFloatingLabel() {
return this.isFloatingLabelIntern;
}
set isFloatingLabel(value) {
this.isFloatingLabelIntern = toBoolean(value);
}
get rows() {
return this.rowsIntern;
}
set rows(value) {
this.rowsIntern = toNumber(value);
}
get maxrows() {
return this.maxrowsIntern;
}
set maxrows(value) {
this.maxrowsIntern = toNumber(value) ?? -1;
}
get disableNativeValidityChecking() {
return this.disableNativeValidityCheckingIntern;
}
set disableNativeValidityChecking(value) {
this.disableNativeValidityCheckingIntern = toBoolean(value);
}
writeValue(value) {
this.valueIntern = value;
this.checkDirty();
}
registerOnChange(fn) {
this.onChangeCallback = fn;
}
registerOnTouched(fn) {
this.onTouchedCallback = fn;
}
setDisabledState(isDisabled) {
this.disabled = isDisabled;
}
// eslint-disable-next-line @angular-eslint/no-conflicting-lifecycle
ngOnChanges() {
this.checkDisabled();
}
// eslint-disable-next-line @angular-eslint/no-conflicting-lifecycle
ngDoCheck() {
this.checkValidity();
this.checkDirty();
}
setFocus() {
if (!this.inputEl) {
return;
}
this.inputEl.nativeElement.dispatchEvent(new Event("focus"));
}
keydownTextarea($event) {
const currentRowCount = this.inputEl?.nativeElement.value.split("\n").length;
// eslint-disable-next-line
if ($event.keyCode === 13) {
if (currentRowCount >= this.maxrows && this.maxrows !== -1) {
$event.preventDefault();
}
}
}
// model value.
triggerChange(event) {
this.value = event.target.value;
this.onTouchedCallback();
}
onFocus(event) {
this.renderer.addClass(this.el, IS_FOCUSED);
this.focusEmitter.emit(event);
}
onBlur(event) {
this.renderer.removeClass(this.el, IS_FOCUSED);
this.onTouchedCallback();
this.blurEmitter.emit(event);
}
onKeyup(event) {
this.keyupEmitter.emit(event);
}
checkDisabled() {
if (this.disabled) {
this.renderer.addClass(this.el, IS_DISABLED);
}
else {
this.renderer.removeClass(this.el, IS_DISABLED);
}
}
checkValidity() {
// check the global setting - if globally disabled do no check
if (this.nativeCheckGlobalDisabled === true) {
return;
}
// check local setting - if locally disabled do no check
if (this.disableNativeValidityChecking) {
return;
}
if (this.inputEl && this.inputEl.nativeElement.validity) {
if (!this.inputEl.nativeElement.validity.valid) {
this.renderer.addClass(this.el, IS_INVALID);
}
else {
this.renderer.removeClass(this.el, IS_INVALID);
}
}
}
checkDirty() {
const dirty = this.inputEl &&
this.inputEl.nativeElement.value &&
this.inputEl.nativeElement.value.length > 0;
if (dirty) {
this.renderer.addClass(this.el, IS_DIRTY);
}
else {
this.renderer.removeClass(this.el, IS_DIRTY);
}
}
}
MdlTextFieldComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: MdlTextFieldComponent, deps: [{ token: i0.Renderer2 }, { token: i0.ElementRef }, { token: DISABLE_NATIVE_VALIDITY_CHECKING, optional: true }], target: i0.ɵɵFactoryTarget.Component });
MdlTextFieldComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.4", type: MdlTextFieldComponent, selector: "mdl-textfield", inputs: { type: "type", label: "label", pattern: "pattern", min: "min", max: "max", step: "step", name: "name", id: "id", errorMessage: ["error-msg", "errorMessage"], placeholder: "placeholder", autocomplete: "autocomplete", icon: "icon", tabindex: "tabindex", maxlength: "maxlength", value: "value", disabled: "disabled", readonly: "readonly", required: "required", autofocus: "autofocus", isFloatingLabel: ["floating-label", "isFloatingLabel"], rows: "rows", maxrows: "maxrows", disableNativeValidityChecking: "disableNativeValidityChecking" }, outputs: { blurEmitter: "blur", focusEmitter: "focus", keyupEmitter: "keyup" }, host: { properties: { "class.has-placeholder": "this.placeholder", "class.mdl-textfield--expandable": "this.icon", "class.mdl-textfield": "this.isTextfield", "class.is-upgraded": "this.isUpgraded", "class.mdl-textfield--floating-label": "this.isFloatingLabel" } }, providers: [
{
provide: NG_VALUE_ACCESSOR,
useExisting: forwardRef(() => MdlTextFieldComponent),
multi: true,
},
], viewQueries: [{ propertyName: "inputEl", first: true, predicate: ["input"], descendants: true }], usesOnChanges: true, ngImport: i0, template: `
<div *ngIf="!icon">
<textarea
*ngIf="rows"
#input
[rows]="rows"
class="mdl-textfield__input"
type="text"
[attr.name]="name"
[id]="id"
[placeholder]="placeholder ? placeholder : ''"
(focus)="onFocus($event)"
(blur)="onBlur($event)"
(keydown)="keydownTextarea($event)"
(keyup)="onKeyup($event)"
[(ngModel)]="value"
[disabled]="disabled"
[required]="required"
[autofocus]="autofocus"
[readonly]="readonly"
[maxlength]="maxlength"
></textarea>
<input
*ngIf="!rows"
#input
class="mdl-textfield__input"
[type]="type"
[attr.name]="name"
[id]="id"
[pattern]="pattern ? pattern : '.*'"
[attr.min]="min"
[attr.max]="max"
[attr.step]="step"
[placeholder]="placeholder ? placeholder : ''"
[autocomplete]="autocomplete ? autocomplete : ''"
(focus)="onFocus($event)"
(blur)="onBlur($event)"
(keyup)="onKeyup($event)"
[(ngModel)]="value"
[disabled]="disabled"
[required]="required"
[autofocus]="autofocus"
[readonly]="readonly"
[attr.tabindex]="tabindex"
[maxlength]="maxlength"
/>
<label class="mdl-textfield__label" [attr.for]="id">{{ label }}</label>
<span class="mdl-textfield__error">{{ errorMessage }}</span>
</div>
<div *ngIf="icon">
<button mdl-button mdl-button-type="icon" (click)="setFocus()">
<mdl-icon>{{ icon }}</mdl-icon>
</button>
<div class="mdl-textfield__expandable-holder">
<input
#input
class="mdl-textfield__input"
[type]="type"
[attr.name]="name"
[id]="id"
[pattern]="pattern ? pattern : '.*'"
[attr.min]="min"
[attr.max]="max"
[attr.step]="step"
[placeholder]="placeholder ? placeholder : ''"
[autocomplete]="autocomplete ? autocomplete : ''"
(focus)="onFocus($event)"
(blur)="onBlur($event)"
(keyup)="onKeyup($event)"
[(ngModel)]="value"
[disabled]="disabled"
[required]="required"
[autofocus]="autofocus"
[readonly]="readonly"
[attr.tabindex]="tabindex"
[maxlength]="maxlength"
/>
<label class="mdl-textfield__label" [attr.for]="id">{{ label }}</label>
<span class="mdl-textfield__error">{{ errorMessage }}</span>
</div>
</div>
`, isInline: true, dependencies: [{ kind: "component", type: i1.MdlIconComponent, selector: "mdl-icon" }, { kind: "component", type: i2.MdlButtonComponent, selector: "mdl-button, button[mdl-button], a[mdl-button]", inputs: ["mdl-button-type", "mdl-colored", "disabled"], exportAs: ["mdlButton"] }, { kind: "directive", type: i3.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: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i3.MaxLengthValidator, selector: "[maxlength][formControlName],[maxlength][formControl],[maxlength][ngModel]", inputs: ["maxlength"] }, { kind: "directive", type: i3.PatternValidator, selector: "[pattern][formControlName],[pattern][formControl],[pattern][ngModel]", inputs: ["pattern"] }, { kind: "directive", type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], encapsulation: i0.ViewEncapsulation.None });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: MdlTextFieldComponent, decorators: [{
type: Component,
args: [{
selector: "mdl-textfield",
template: `
<div *ngIf="!icon">
<textarea
*ngIf="rows"
#input
[rows]="rows"
class="mdl-textfield__input"
type="text"
[attr.name]="name"
[id]="id"
[placeholder]="placeholder ? placeholder : ''"
(focus)="onFocus($event)"
(blur)="onBlur($event)"
(keydown)="keydownTextarea($event)"
(keyup)="onKeyup($event)"
[(ngModel)]="value"
[disabled]="disabled"
[required]="required"
[autofocus]="autofocus"
[readonly]="readonly"
[maxlength]="maxlength"
></textarea>
<input
*ngIf="!rows"
#input
class="mdl-textfield__input"
[type]="type"
[attr.name]="name"
[id]="id"
[pattern]="pattern ? pattern : '.*'"
[attr.min]="min"
[attr.max]="max"
[attr.step]="step"
[placeholder]="placeholder ? placeholder : ''"
[autocomplete]="autocomplete ? autocomplete : ''"
(focus)="onFocus($event)"
(blur)="onBlur($event)"
(keyup)="onKeyup($event)"
[(ngModel)]="value"
[disabled]="disabled"
[required]="required"
[autofocus]="autofocus"
[readonly]="readonly"
[attr.tabindex]="tabindex"
[maxlength]="maxlength"
/>
<label class="mdl-textfield__label" [attr.for]="id">{{ label }}</label>
<span class="mdl-textfield__error">{{ errorMessage }}</span>
</div>
<div *ngIf="icon">
<button mdl-button mdl-button-type="icon" (click)="setFocus()">
<mdl-icon>{{ icon }}</mdl-icon>
</button>
<div class="mdl-textfield__expandable-holder">
<input
#input
class="mdl-textfield__input"
[type]="type"
[attr.name]="name"
[id]="id"
[pattern]="pattern ? pattern : '.*'"
[attr.min]="min"
[attr.max]="max"
[attr.step]="step"
[placeholder]="placeholder ? placeholder : ''"
[autocomplete]="autocomplete ? autocomplete : ''"
(focus)="onFocus($event)"
(blur)="onBlur($event)"
(keyup)="onKeyup($event)"
[(ngModel)]="value"
[disabled]="disabled"
[required]="required"
[autofocus]="autofocus"
[readonly]="readonly"
[attr.tabindex]="tabindex"
[maxlength]="maxlength"
/>
<label class="mdl-textfield__label" [attr.for]="id">{{ label }}</label>
<span class="mdl-textfield__error">{{ errorMessage }}</span>
</div>
</div>
`,
providers: [
{
provide: NG_VALUE_ACCESSOR,
useExisting: forwardRef(() => MdlTextFieldComponent),
multi: true,
},
],
encapsulation: ViewEncapsulation.None,
}]
}], ctorParameters: function () { return [{ type: i0.Renderer2 }, { type: i0.ElementRef }, { type: undefined, decorators: [{
type: Optional
}, {
type: Inject,
args: [DISABLE_NATIVE_VALIDITY_CHECKING]
}] }]; }, propDecorators: { blurEmitter: [{
type: Output,
args: ["blur"]
}], focusEmitter: [{
type: Output,
args: ["focus"]
}], keyupEmitter: [{
type: Output,
args: ["keyup"]
}], inputEl: [{
type: ViewChild,
args: ["input"]
}], type: [{
type: Input
}], label: [{
type: Input
}], pattern: [{
type: Input
}], min: [{
type: Input
}], max: [{
type: Input
}], step: [{
type: Input
}], name: [{
type: Input
}], id: [{
type: Input
}], errorMessage: [{
type: Input,
args: ["error-msg"]
}], placeholder: [{
type: HostBinding,
args: ["class.has-placeholder"]
}, {
type: Input
}], autocomplete: [{
type: Input
}], icon: [{
type: HostBinding,
args: ["class.mdl-textfield--expandable"]
}, {
type: Input
}], tabindex: [{
type: Input
}], maxlength: [{
type: Input
}], isTextfield: [{
type: HostBinding,
args: ["class.mdl-textfield"]
}], isUpgraded: [{
type: HostBinding,
args: ["class.is-upgraded"]
}], value: [{
type: Input
}], disabled: [{
type: Input
}], readonly: [{
type: Input
}], required: [{
type: Input
}], autofocus: [{
type: Input
}], isFloatingLabel: [{
type: HostBinding,
args: ["class.mdl-textfield--floating-label"]
}, {
type: Input,
args: ["floating-label"]
}], rows: [{
type: Input
}], maxrows: [{
type: Input
}], disableNativeValidityChecking: [{
type: Input
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"mdl-textfield.component.js","sourceRoot":"","sources":["../../../../../../projects/core/src/lib/textfield/mdl-textfield.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  DoCheck,\n  ElementRef,\n  EventEmitter,\n  forwardRef,\n  HostBinding,\n  Inject,\n  InjectionToken,\n  Input,\n  OnChanges,\n  Optional,\n  Output,\n  Renderer2,\n  ViewChild,\n  ViewEncapsulation,\n} from \"@angular/core\";\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from \"@angular/forms\";\n\nimport { toBoolean } from \"../common/boolean-property\";\nimport { toNumber } from \"../common/number.property\";\nimport { noop } from \"../common/noop\";\n\nexport const DISABLE_NATIVE_VALIDITY_CHECKING = new InjectionToken<boolean>(\n  \"disableNativeValidityChecking\"\n);\n\nlet nextId = 0;\n\nconst IS_FOCUSED = \"is-focused\";\nconst IS_DISABLED = \"is-disabled\";\nconst IS_INVALID = \"is-invalid\";\nconst IS_DIRTY = \"is-dirty\";\n\n@Component({\n  selector: \"mdl-textfield\",\n  template: `\n    <div *ngIf=\"!icon\">\n      <textarea\n        *ngIf=\"rows\"\n        #input\n        [rows]=\"rows\"\n        class=\"mdl-textfield__input\"\n        type=\"text\"\n        [attr.name]=\"name\"\n        [id]=\"id\"\n        [placeholder]=\"placeholder ? placeholder : ''\"\n        (focus)=\"onFocus($event)\"\n        (blur)=\"onBlur($event)\"\n        (keydown)=\"keydownTextarea($event)\"\n        (keyup)=\"onKeyup($event)\"\n        [(ngModel)]=\"value\"\n        [disabled]=\"disabled\"\n        [required]=\"required\"\n        [autofocus]=\"autofocus\"\n        [readonly]=\"readonly\"\n        [maxlength]=\"maxlength\"\n      ></textarea>\n      <input\n        *ngIf=\"!rows\"\n        #input\n        class=\"mdl-textfield__input\"\n        [type]=\"type\"\n        [attr.name]=\"name\"\n        [id]=\"id\"\n        [pattern]=\"pattern ? pattern : '.*'\"\n        [attr.min]=\"min\"\n        [attr.max]=\"max\"\n        [attr.step]=\"step\"\n        [placeholder]=\"placeholder ? placeholder : ''\"\n        [autocomplete]=\"autocomplete ? autocomplete : ''\"\n        (focus)=\"onFocus($event)\"\n        (blur)=\"onBlur($event)\"\n        (keyup)=\"onKeyup($event)\"\n        [(ngModel)]=\"value\"\n        [disabled]=\"disabled\"\n        [required]=\"required\"\n        [autofocus]=\"autofocus\"\n        [readonly]=\"readonly\"\n        [attr.tabindex]=\"tabindex\"\n        [maxlength]=\"maxlength\"\n      />\n      <label class=\"mdl-textfield__label\" [attr.for]=\"id\">{{ label }}</label>\n      <span class=\"mdl-textfield__error\">{{ errorMessage }}</span>\n    </div>\n    <div *ngIf=\"icon\">\n      <button mdl-button mdl-button-type=\"icon\" (click)=\"setFocus()\">\n        <mdl-icon>{{ icon }}</mdl-icon>\n      </button>\n      <div class=\"mdl-textfield__expandable-holder\">\n        <input\n          #input\n          class=\"mdl-textfield__input\"\n          [type]=\"type\"\n          [attr.name]=\"name\"\n          [id]=\"id\"\n          [pattern]=\"pattern ? pattern : '.*'\"\n          [attr.min]=\"min\"\n          [attr.max]=\"max\"\n          [attr.step]=\"step\"\n          [placeholder]=\"placeholder ? placeholder : ''\"\n          [autocomplete]=\"autocomplete ? autocomplete : ''\"\n          (focus)=\"onFocus($event)\"\n          (blur)=\"onBlur($event)\"\n          (keyup)=\"onKeyup($event)\"\n          [(ngModel)]=\"value\"\n          [disabled]=\"disabled\"\n          [required]=\"required\"\n          [autofocus]=\"autofocus\"\n          [readonly]=\"readonly\"\n          [attr.tabindex]=\"tabindex\"\n          [maxlength]=\"maxlength\"\n        />\n        <label class=\"mdl-textfield__label\" [attr.for]=\"id\">{{ label }}</label>\n        <span class=\"mdl-textfield__error\">{{ errorMessage }}</span>\n      </div>\n    </div>\n  `,\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => MdlTextFieldComponent),\n      multi: true,\n    },\n  ],\n  encapsulation: ViewEncapsulation.None,\n})\n/* eslint-disable  @angular-eslint/no-conflicting-lifecycle */\nexport class MdlTextFieldComponent\n  implements ControlValueAccessor, OnChanges, DoCheck\n{\n  // eslint-disable-next-line\n  @Output(\"blur\")\n  blurEmitter: EventEmitter<FocusEvent> = new EventEmitter<FocusEvent>();\n  // eslint-disable-next-line\n  @Output(\"focus\")\n  focusEmitter: EventEmitter<FocusEvent> = new EventEmitter<FocusEvent>();\n  // eslint-disable-next-line\n  @Output(\"keyup\")\n  keyupEmitter: EventEmitter<KeyboardEvent> = new EventEmitter<KeyboardEvent>();\n  @ViewChild(\"input\")\n  inputEl: ElementRef | undefined;\n  @Input()\n  type = \"text\";\n  @Input()\n  label: string | undefined;\n  @Input()\n  pattern: string | undefined;\n  @Input()\n  min: number | string | undefined;\n  @Input()\n  max: number | string | undefined;\n  @Input()\n  step: number | string | undefined;\n  @Input()\n  name: string | undefined;\n  @Input()\n  id = `mdl-textfield-${nextId++}`;\n  // eslint-disable-next-line\n  @Input(\"error-msg\")\n  errorMessage: string | undefined;\n  @HostBinding(\"class.has-placeholder\")\n  @Input()\n  placeholder: string | undefined;\n  @Input()\n  autocomplete: string | undefined;\n  @HostBinding(\"class.mdl-textfield--expandable\")\n  @Input()\n  icon: string | undefined;\n  @Input()\n  tabindex: number | string | null = null;\n  @Input()\n  maxlength: number | string | null = null;\n  @HostBinding(\"class.mdl-textfield\")\n  isTextfield = true;\n  @HostBinding(\"class.is-upgraded\")\n  isUpgraded = true;\n  private valueIntern: string | number | null = null;\n\n  private readonly el: HTMLElement;\n  private onTouchedCallback: () => void = noop;\n  private onChangeCallback: (_: unknown) => void = noop;\n  private disabledIntern = false;\n  private readonlyIntern = false;\n  private requiredIntern = false;\n  private autofocusIntern = false;\n  private isFloatingLabelIntern = false;\n  private rowsIntern: number | undefined | null = null;\n  private maxrowsIntern = -1;\n  // @experimental\n  private disableNativeValidityCheckingIntern = false;\n\n  constructor(\n    private renderer: Renderer2,\n    private elmRef: ElementRef,\n    @Optional()\n    @Inject(DISABLE_NATIVE_VALIDITY_CHECKING)\n    private nativeCheckGlobalDisabled: boolean\n  ) {\n    this.el = elmRef.nativeElement;\n  }\n\n  get value(): string | number | null {\n    return this.valueIntern;\n  }\n\n  @Input() set value(v: string | number | null) {\n    this.valueIntern =\n      this.type === \"number\" ? (v === \"\" ? null : parseFloat(v as string)) : v;\n    this.onChangeCallback(this.value);\n  }\n\n  @Input()\n  get disabled(): boolean {\n    return this.disabledIntern;\n  }\n\n  set disabled(value: boolean | string) {\n    this.disabledIntern = toBoolean(value);\n  }\n\n  @Input()\n  get readonly(): boolean {\n    return this.readonlyIntern;\n  }\n\n  set readonly(value: boolean) {\n    this.readonlyIntern = toBoolean(value);\n  }\n\n  @Input()\n  get required(): boolean {\n    return this.requiredIntern;\n  }\n\n  set required(value: boolean | string) {\n    this.requiredIntern = toBoolean(value);\n  }\n\n  @Input()\n  get autofocus(): boolean {\n    return this.autofocusIntern;\n  }\n\n  set autofocus(value: boolean | string) {\n    this.autofocusIntern = toBoolean(value);\n  }\n\n  @HostBinding(\"class.mdl-textfield--floating-label\")\n  @Input(\"floating-label\")\n  get isFloatingLabel(): boolean {\n    return this.isFloatingLabelIntern;\n  }\n\n  set isFloatingLabel(value: boolean | string) {\n    this.isFloatingLabelIntern = toBoolean(value);\n  }\n\n  @Input()\n  get rows(): number | string | null | undefined {\n    return this.rowsIntern;\n  }\n\n  set rows(value: number | string | null | undefined) {\n    this.rowsIntern = toNumber(value);\n  }\n\n  @Input()\n  get maxrows(): number {\n    return this.maxrowsIntern;\n  }\n\n  set maxrows(value: number | string | null) {\n    this.maxrowsIntern = toNumber(value) ?? -1;\n  }\n\n  @Input()\n  get disableNativeValidityChecking(): boolean | string {\n    return this.disableNativeValidityCheckingIntern;\n  }\n\n  set disableNativeValidityChecking(value: boolean | string) {\n    this.disableNativeValidityCheckingIntern = toBoolean(value);\n  }\n\n  public writeValue(value: string | number): void {\n    this.valueIntern = value;\n    this.checkDirty();\n  }\n\n  public registerOnChange(fn: () => unknown): void {\n    this.onChangeCallback = fn;\n  }\n\n  public registerOnTouched(fn: () => unknown): void {\n    this.onTouchedCallback = fn;\n  }\n\n  public setDisabledState(isDisabled: boolean): void {\n    this.disabled = isDisabled;\n  }\n\n  // eslint-disable-next-line @angular-eslint/no-conflicting-lifecycle\n  ngOnChanges(): void {\n    this.checkDisabled();\n  }\n\n  // eslint-disable-next-line @angular-eslint/no-conflicting-lifecycle\n  ngDoCheck(): void {\n    this.checkValidity();\n    this.checkDirty();\n  }\n\n  setFocus(): void {\n    if (!this.inputEl) {\n      return;\n    }\n    (this.inputEl.nativeElement as HTMLInputElement).dispatchEvent(\n      new Event(\"focus\")\n    );\n  }\n\n  keydownTextarea($event: KeyboardEvent): void {\n    const currentRowCount =\n      this.inputEl?.nativeElement.value.split(\"\\n\").length;\n    // eslint-disable-next-line\n    if ($event.keyCode === 13) {\n      if (currentRowCount >= this.maxrows && this.maxrows !== -1) {\n        $event.preventDefault();\n      }\n    }\n  }\n\n  // model value.\n  triggerChange(event: Event): void {\n    this.value = (event.target as HTMLInputElement).value;\n    this.onTouchedCallback();\n  }\n\n  onFocus(event: FocusEvent): void {\n    this.renderer.addClass(this.el, IS_FOCUSED);\n    this.focusEmitter.emit(event);\n  }\n\n  onBlur(event: FocusEvent): void {\n    this.renderer.removeClass(this.el, IS_FOCUSED);\n    this.onTouchedCallback();\n    this.blurEmitter.emit(event);\n  }\n\n  onKeyup(event: KeyboardEvent): void {\n    this.keyupEmitter.emit(event);\n  }\n\n  private checkDisabled() {\n    if (this.disabled) {\n      this.renderer.addClass(this.el, IS_DISABLED);\n    } else {\n      this.renderer.removeClass(this.el, IS_DISABLED);\n    }\n  }\n\n  private checkValidity() {\n    // check the global setting - if globally disabled do no check\n    if (this.nativeCheckGlobalDisabled === true) {\n      return;\n    }\n    // check local setting - if locally disabled do no check\n    if (this.disableNativeValidityChecking) {\n      return;\n    }\n    if (this.inputEl && this.inputEl.nativeElement.validity) {\n      if (!this.inputEl.nativeElement.validity.valid) {\n        this.renderer.addClass(this.el, IS_INVALID);\n      } else {\n        this.renderer.removeClass(this.el, IS_INVALID);\n      }\n    }\n  }\n\n  private checkDirty() {\n    const dirty =\n      this.inputEl &&\n      this.inputEl.nativeElement.value &&\n      this.inputEl.nativeElement.value.length > 0;\n    if (dirty) {\n      this.renderer.addClass(this.el, IS_DIRTY);\n    } else {\n      this.renderer.removeClass(this.el, IS_DIRTY);\n    }\n  }\n}\n"]}