UNPKG

@angular-mdl/core

Version:

Angular components, directives and styles based on material design lite https://getmdl.io.

462 lines 42 kB
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"]}