igniteui-angular 16.0.0-beta.3 → 16.0.0-beta.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -244,6 +244,7 @@ export class IgxInputDirective {
244
244
  }
245
245
  if (this.ngControl) {
246
246
  this._statusChanges$ = this.ngControl.statusChanges.subscribe(this.onStatusChanged.bind(this));
247
+ this._valueChanges$ = this.ngControl.valueChanges.subscribe(this.onValueChanged.bind(this));
247
248
  }
248
249
  this.cdr.detectChanges();
249
250
  }
@@ -252,6 +253,9 @@ export class IgxInputDirective {
252
253
  if (this._statusChanges$) {
253
254
  this._statusChanges$.unsubscribe();
254
255
  }
256
+ if (this._valueChanges$) {
257
+ this._valueChanges$.unsubscribe();
258
+ }
255
259
  }
256
260
  /**
257
261
  * Sets a focus on the igxInput.
@@ -283,6 +287,12 @@ export class IgxInputDirective {
283
287
  }
284
288
  this.updateValidityState();
285
289
  }
290
+ /** @hidden @internal */
291
+ onValueChanged() {
292
+ if (this._fileNames && !this.value) {
293
+ this._fileNames = '';
294
+ }
295
+ }
286
296
  /**
287
297
  * @hidden
288
298
  * @internal
@@ -473,4 +483,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0", ngImpor
473
483
  type: HostListener,
474
484
  args: ['change', ['$event']]
475
485
  }] } });
476
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input.directive.js","sourceRoot":"","sources":["../../../../../../projects/igniteui-angular/src/lib/directives/input/input.directive.ts"],"names":[],"mappings":"AAAA,OAAO,EAGH,SAAS,EAET,WAAW,EACX,YAAY,EACZ,MAAM,EACN,KAAK,EAEL,QAAQ,EAER,IAAI,GACP,MAAM,eAAe,CAAC;AACvB,OAAO,EAEH,SAAS,EACT,OAAO,EACV,MAAM,gBAAgB,CAAC;;;;AAIxB,MAAM,0BAA0B,GAAG;IAC/B,UAAU;IACV,SAAS;IACT,WAAW;IACX,WAAW;IACX,KAAK;IACL,KAAK;IACL,MAAM;CACT,CAAC;AAEF,MAAM,CAAN,IAAY,aAIX;AAJD,WAAY,aAAa;IACrB,uDAAO,CAAA;IACP,mDAAK,CAAA;IACL,uDAAO,CAAA;AACX,CAAC,EAJW,aAAa,KAAb,aAAa,QAIxB;AAED;;;;;;;;;;;;;;;;;;;;GAoBG;AAMH,MAAM,OAAO,iBAAiB;IAyC1B,YACW,UAA6B,EACW,OAAgB,EAIrD,WAAsB,EACtB,OAAqC,EACrC,GAAsB,EACtB,QAAmB;QARtB,eAAU,GAAV,UAAU,CAAmB;QACW,YAAO,GAAP,OAAO,CAAS;QAIrD,gBAAW,GAAX,WAAW,CAAW;QACtB,YAAO,GAAP,OAAO,CAA8B;QACrC,QAAG,GAAH,GAAG,CAAmB;QACtB,aAAQ,GAAR,QAAQ,CAAW;QA/CjC;;;;;;;;;;;;;WAaG;QAEI,YAAO,GAAG,KAAK,CAAC;QACvB;;;;;;;;;;;;;WAaG;QAEI,eAAU,GAAG,KAAK,CAAC;QAElB,WAAM,GAAG,aAAa,CAAC,OAAO,CAAC;QAG/B,cAAS,GAAG,KAAK,CAAC;IAYtB,CAAC;IAEL,IAAY,SAAS;QACjB,OAAO,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC;IAC1D,CAAC;IAED;;;;;;;;;OASG;IACH,IACW,KAAK,CAAC,KAAU;QACvB,IAAI,CAAC,aAAa,CAAC,KAAK,GAAG,KAAK,IAAI,EAAE,CAAC;QACvC,IAAI,CAAC,mBAAmB,EAAE,CAAC;IAC/B,CAAC;IACD;;;;;;;;;OASG;IACH,IAAW,KAAK;QACZ,OAAO,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC;IACpC,CAAC;IACD;;;;;;;;;OASG;IACH,IAEW,QAAQ,CAAC,KAAc;QAC9B,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,UAAU,CAAC,QAAQ,GAAG,CAAC,CAAC,CAAC,CAAC,KAAY,KAAK,EAAE,CAAC,IAAI,KAAK,CAAC,CAAC;QAC/E,IAAI,IAAI,CAAC,OAAO,IAAI,IAAI,CAAC,SAAS,EAAE;YAChC,kGAAkG;YAClG,IAAI,CAAC,UAAU,CAAC,SAAS,GAAG,KAAK,CAAC;SACrC;IACL,CAAC;IACD;;;;;;;;;OASG;IACH,IAAW,QAAQ;QACf,OAAO,IAAI,CAAC,SAAS,CAAC;IAC1B,CAAC;IAED;;;;;;;;;OASG;IACH,IACW,QAAQ,CAAC,KAAc;QAC9B,IAAI,CAAC,aAAa,CAAC,QAAQ,GAAG,IAAI,CAAC,UAAU,CAAC,UAAU,GAAG,CAAC,KAAY,KAAK,EAAE,CAAC,IAAI,KAAK,CAAC;IAC9F,CAAC;IAED;;;;;;;OAOG;IACH,IAAW,QAAQ;QACf,IAAI,UAAU,CAAC;QACf,IAAI,IAAI,CAAC,SAAS,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,SAAS,IAAI,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,cAAc,CAAC,EAAE;YAC/F,UAAU,GAAG,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,SAAS,CAAC,EAAqB,CAAC,CAAC;SACxE;QACD,OAAO,UAAU,IAAI,UAAU,CAAC,QAAQ,IAAI,IAAI,CAAC,aAAa,CAAC,YAAY,CAAC,UAAU,CAAC,CAAC;IAC5F,CAAC;IACD;;;OAGG;IAEI,OAAO;QACV,IAAI,CAAC,UAAU,CAAC,SAAS,GAAG,IAAI,CAAC;IACrC,CAAC;IACD;;;;;OAKG;IAEI,MAAM;QACT,IAAI,CAAC,UAAU,CAAC,SAAS,GAAG,KAAK,CAAC;QAClC,IAAI,CAAC,mBAAmB,EAAE,CAAC;IAC/B,CAAC;IACD,wBAAwB;IAEjB,OAAO;QACV,IAAI,CAAC,mBAAmB,EAAE,CAAC;IAC/B,CAAC;IACD,wBAAwB;IAEjB,MAAM,CAAC,KAAY;QACtB,IAAI,IAAI,CAAC,IAAI,KAAK,MAAM,EAAE;YACtB,MAAM,QAAQ,GAAqB,KAAK,CAAC,MAA2B;iBAC/D,KAAK,CAAC;YACX,MAAM,SAAS,GAAW,EAAE,CAAC;YAE7B,IAAI,QAAQ,EAAE;gBACV,KAAK,MAAM,IAAI,IAAI,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAE;oBACrC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;iBACxB;aACJ;YAED,IAAI,CAAC,UAAU,GAAG,CAAC,SAAS,IAAI,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAO,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YAExE,IAAI,IAAI,CAAC,QAAQ,IAAI,QAAQ,EAAE,MAAM,GAAG,CAAC,EAAE;gBACvC,IAAI,CAAC,MAAM,GAAG,aAAa,CAAC,OAAO,CAAC;aACvC;SACJ;IACL,CAAC;IAED,wBAAwB;IACxB,IAAW,SAAS;QAChB,OAAO,IAAI,CAAC,UAAU,CAAC;IAC3B,CAAC;IAED,wBAAwB;IACjB,KAAK;QACR,IAAI,CAAC,SAAS,EAAE,OAAO,EAAE,QAAQ,CAAC,EAAE,CAAC,CAAC;QACtC,IAAI,CAAC,aAAa,CAAC,KAAK,GAAG,IAAI,CAAC;QAChC,IAAI,CAAC,UAAU,GAAG,EAAE,CAAC;IACzB,CAAC;IAED,wBAAwB;IACjB,eAAe;QAClB,IAAI,CAAC,UAAU,CAAC,cAAc,GAAG,IAAI,CAAC,aAAa,CAAC,YAAY,CAC5D,aAAa,CAChB,CAAC;QAEF,IAAI,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,SAAS,CAAC,QAAQ,KAAK,IAAI,EAAE;YACpD,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC;SAC3C;QACD,IAAI,CAAC,UAAU,CAAC,QAAQ;YACpB,IAAI,CAAC,UAAU,CAAC,QAAQ;gBACxB,IAAI,CAAC,aAAa,CAAC,YAAY,CAAC,UAAU,CAAC,CAAC;QAChD,IAAI,CAAC,UAAU,CAAC,UAAU,GAAG,IAAI,CAAC,aAAa,CAAC,YAAY,CACxD,UAAU,CACb,CAAC;QAEF,mDAAmD;QACnD,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE;YACjB,IAAI,CAAC,MAAM,GAAG,aAAa,CAAC,OAAO,CAAC;SACvC;QACD,mDAAmD;QACnD,IAAI,IAAI,CAAC,QAAQ,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,UAAU,EAAE;YAC9C,IAAI,CAAC,UAAU,CAAC,UAAU,GAAG,IAAI,CAAC,QAAQ,CAAC;SAC9C;QAED,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,IAAI,CAAC,aAAa,EAAE,eAAe,EAAE,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC,CAAC;QAE1F,MAAM,KAAK,GAAG,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,WAAW,EAAE,CAAC;QACvD,IAAI,KAAK,KAAK,UAAU,EAAE;YACtB,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;SAC1B;aAAM;YACH,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;SACvB;QAED,IAAI,IAAI,CAAC,SAAS,EAAE;YAChB,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,SAAS,CACzD,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC,CAClC,CAAC;SACL;QAED,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;IAC7B,CAAC;IACD,wBAAwB;IACjB,WAAW;QACd,IAAI,IAAI,CAAC,eAAe,EAAE;YACtB,IAAI,CAAC,eAAe,CAAC,WAAW,EAAE,CAAC;SACtC;IACL,CAAC;IACD;;;;;;;OAOG;IACI,KAAK;QACR,IAAI,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;IAC/B,CAAC;IACD;;;;;;;OAOG;IACH,IAAW,aAAa;QACpB,OAAO,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC;IACtC,CAAC;IACD,wBAAwB;IACd,eAAe;QACrB,kDAAkD;QAClD,IAAI,IAAI,CAAC,QAAQ,KAAK,IAAI,CAAC,SAAS,CAAC,QAAQ,EAAE;YAC3C,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC;SAC3C;QACD,IAAI,CAAC,mBAAmB,EAAE,CAAC;IAC/B,CAAC;IACD;;;OAGG;IACO,mBAAmB;QACzB,IAAI,IAAI,CAAC,SAAS,EAAE;YAChB,IAAI,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,SAAS,IAAI,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,cAAc,EAAE;gBAC3E,wEAAwE;gBACxE,MAAM,KAAK,GAAG,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,SAAS,CAAC,EAAqB,CAAC,CAAC;gBACtE,IAAI,CAAC,UAAU,CAAC,UAAU,GAAG,KAAK,IAAI,KAAK,CAAC,QAAQ,CAAC;gBACrD,IAAI,CAAC,IAAI,CAAC,QAAQ,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,OAAO,IAAI,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE;oBACpF,sDAAsD;oBACtD,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC;wBAClC,aAAa,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;wBACxD,aAAa,CAAC,OAAO,CAAC;iBACjC;qBAAM;oBACH,2GAA2G;oBAC3G,gDAAgD;oBAChD,IAAI,CAAC,MAAM,GAAG,aAAa,CAAC,OAAO,CAAC;iBACvC;aACJ;iBAAM;gBACH,uGAAuG;gBACvG,IAAI,CAAC,MAAM,GAAG,aAAa,CAAC,OAAO,CAAC;gBACpC,IAAI,CAAC,UAAU,CAAC,UAAU,GAAG,KAAK,CAAC;aACtC;YACD,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,IAAI,CAAC,aAAa,EAAE,eAAe,EAAE,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC,CAAC;YAC1F,MAAM,WAAW,GAAG,IAAI,CAAC,KAAK,KAAK,aAAa,CAAC,OAAO,CAAC;YACzD,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,IAAI,CAAC,aAAa,EAAE,cAAc,EAAE,WAAW,CAAC,QAAQ,EAAE,CAAC,CAAC;SAC1F;aAAM;YACH,IAAI,CAAC,mBAAmB,EAAE,CAAC;SAC9B;IACL,CAAC;IACD;;;;;;;OAOG;IACH,IAAW,cAAc;QACrB,OAAO,IAAI,CAAC,aAAa,CAAC,YAAY,CAAC,aAAa,CAAC,CAAC;IAC1D,CAAC;IACD;;;;;;;OAOG;IACH,IAAW,WAAW;QAClB,OAAO,IAAI,CAAC,aAAa,CAAC,WAAW,CAAC;IAC1C,CAAC;IAED;;;;;OAKG;IACK,cAAc;QAClB,KAAK,MAAM,yBAAyB,IAAI,0BAA0B,EAAE;YAChE,IAAI,IAAI,CAAC,aAAa,CAAC,YAAY,CAAC,yBAAyB,CAAC,EAAE;gBAC5D,OAAO,IAAI,CAAC;aACf;SACJ;QACD,OAAO,KAAK,CAAC;IACjB,CAAC;IAED;;;;;;;OAOG;IACH,IAAW,OAAO;QACd,OAAO,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC;IACrC,CAAC;IACD;;;;;;;OAOG;IACH,IAAW,KAAK;QACZ,OAAO,IAAI,CAAC,MAAM,CAAC;IACvB,CAAC;IAED;;;;;;;OAOG;IACH,IAAW,KAAK,CAAC,KAAoB;QACjC,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;IACxB,CAAC;IAED;;;;;;;OAOG;IACH,IAAW,OAAO;QACd,OAAO,IAAI,CAAC,KAAK,KAAK,aAAa,CAAC,OAAO,CAAC;IAChD,CAAC;IAED;;;;;;OAMG;IACK,mBAAmB;QACvB,IAAI,CAAC,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,cAAc,EAAE,EAAE;YACzC,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,aAAa,CAAC,aAAa,EAAE,CAAC,CAAC;gBAC9C,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC;gBAC5D,aAAa,CAAC,OAAO,CAAC;SAC7B;IACL,CAAC;IAED;;;;;OAKG;IACH,IAAW,IAAI;QACX,OAAO,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC;IACnC,CAAC;8GAxaQ,iBAAiB,mDA2CM,OAAO,yCAG3B,SAAS;kGA9CZ,iBAAiB;;2FAAjB,iBAAiB;kBAL7B,SAAS;mBAAC;oBACP,QAAQ,EAAE,YAAY;oBACtB,QAAQ,EAAE,UAAU;oBACpB,UAAU,EAAE,IAAI;iBACnB;;0BA4CQ,QAAQ;;0BAAI,IAAI;;0BAAI,MAAM;2BAAC,OAAO;;0BAClC,QAAQ;;0BACR,IAAI;;0BACJ,MAAM;2BAAC,SAAS;6HA5Bd,OAAO;sBADb,WAAW;uBAAC,8BAA8B;gBAiBpC,UAAU;sBADhB,WAAW;uBAAC,iCAAiC;gBAmCnC,KAAK;sBADf,KAAK;gBA8BK,QAAQ;sBAFlB,KAAK;;sBACL,WAAW;uBAAC,UAAU;gBAiCZ,QAAQ;sBADlB,KAAK;gBAyBC,OAAO;sBADb,YAAY;uBAAC,OAAO;gBAWd,MAAM;sBADZ,YAAY;uBAAC,MAAM;gBAOb,OAAO;sBADb,YAAY;uBAAC,OAAO;gBAMd,MAAM;sBADZ,YAAY;uBAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC","sourcesContent":["import {\n    AfterViewInit,\n    ChangeDetectorRef,\n    Directive,\n    ElementRef,\n    HostBinding,\n    HostListener,\n    Inject,\n    Input,\n    OnDestroy,\n    Optional,\n    Renderer2,\n    Self,\n} from '@angular/core';\nimport {\n    AbstractControl,\n    NgControl,\n    NgModel\n} from '@angular/forms';\nimport { Subscription } from 'rxjs';\nimport { IgxInputGroupBase } from '../../input-group/input-group.common';\n\nconst nativeValidationAttributes = [\n    'required',\n    'pattern',\n    'minlength',\n    'maxlength',\n    'min',\n    'max',\n    'step',\n];\n\nexport enum IgxInputState {\n    INITIAL,\n    VALID,\n    INVALID,\n}\n\n/**\n * The `igxInput` directive creates single- or multiline text elements, covering common scenarios when dealing with form inputs.\n *\n * @igxModule IgxInputGroupModule\n *\n * @igxParent Data Entry & Display\n *\n * @igxTheme igx-input-group-theme\n *\n * @igxKeywords input, input group, form, field, validation\n *\n * @igxGroup presentation\n *\n * @example\n * ```html\n * <input-group>\n *  <label for=\"address\">Address</label>\n *  <input igxInput name=\"address\" type=\"text\" [(ngModel)]=\"customer.address\">\n * </input-group>\n * ```\n */\n@Directive({\n    selector: '[igxInput]',\n    exportAs: 'igxInput',\n    standalone: true\n})\nexport class IgxInputDirective implements AfterViewInit, OnDestroy {\n    private static ngAcceptInputType_required: boolean | '';\n    private static ngAcceptInputType_disabled: boolean | '';\n    /**\n     * Sets/gets whether the `\"igx-input-group__input\"` class is added to the host element.\n     * Default value is `false`.\n     *\n     * @example\n     * ```typescript\n     * this.igxInput.isInput = true;\n     * ```\n     *\n     * @example\n     * ```typescript\n     * let isCLassAdded = this.igxInput.isInput;\n     * ```\n     */\n    @HostBinding('class.igx-input-group__input')\n    public isInput = false;\n    /**\n     * Sets/gets whether the `\"class.igx-input-group__textarea\"` class is added to the host element.\n     * Default value is `false`.\n     *\n     * @example\n     * ```typescript\n     * this.igxInput.isTextArea = true;\n     * ```\n     *\n     * @example\n     * ```typescript\n     * let isCLassAdded = this.igxInput.isTextArea;\n     * ```\n     */\n    @HostBinding('class.igx-input-group__textarea')\n    public isTextArea = false;\n\n    private _valid = IgxInputState.INITIAL;\n    private _statusChanges$: Subscription;\n    private _fileNames: string;\n    private _disabled = false;\n\n    constructor(\n        public inputGroup: IgxInputGroupBase,\n        @Optional() @Self() @Inject(NgModel) protected ngModel: NgModel,\n        @Optional()\n        @Self()\n        @Inject(NgControl)\n        protected formControl: NgControl,\n        protected element: ElementRef<HTMLInputElement>,\n        protected cdr: ChangeDetectorRef,\n        protected renderer: Renderer2\n    ) { }\n\n    private get ngControl(): NgControl {\n        return this.ngModel ? this.ngModel : this.formControl;\n    }\n\n    /**\n     * Sets the `value` property.\n     *\n     * @example\n     * ```html\n     * <input-group>\n     *  <input igxInput #igxInput [value]=\"'IgxInput Value'\">\n     * </input-group>\n     * ```\n     */\n    @Input()\n    public set value(value: any) {\n        this.nativeElement.value = value ?? '';\n        this.updateValidityState();\n    }\n    /**\n     * Gets the `value` property.\n     *\n     * @example\n     * ```typescript\n     * @ViewChild('igxInput', {read: IgxInputDirective})\n     *  public igxInput: IgxInputDirective;\n     * let inputValue = this.igxInput.value;\n     * ```\n     */\n    public get value() {\n        return this.nativeElement.value;\n    }\n    /**\n     * Sets the `disabled` property.\n     *\n     * @example\n     * ```html\n     * <input-group>\n     *  <input igxInput #igxInput [disabled]=\"true\">\n     * </input-group>\n     * ```\n     */\n    @Input()\n    @HostBinding('disabled')\n    public set disabled(value: boolean) {\n        this._disabled = this.inputGroup.disabled = !!((value as any === '') || value);\n        if (this.focused && this._disabled) {\n            // Browser focus may not fire in good time and mess with change detection, adjust here in advance:\n            this.inputGroup.isFocused = false;\n        }\n    }\n    /**\n     * Gets the `disabled` property\n     *\n     * @example\n     * ```typescript\n     * @ViewChild('igxInput', {read: IgxInputDirective})\n     *  public igxInput: IgxInputDirective;\n     * let isDisabled = this.igxInput.disabled;\n     * ```\n     */\n    public get disabled() {\n        return this._disabled;\n    }\n\n    /**\n     * Sets the `required` property.\n     *\n     * @example\n     * ```html\n     * <input-group>\n     *  <input igxInput #igxInput required>\n     * </input-group>\n     * ```\n     */\n    @Input()\n    public set required(value: boolean) {\n        this.nativeElement.required = this.inputGroup.isRequired = (value as any === '') || value;\n    }\n\n    /**\n     * Gets whether the igxInput is required.\n     *\n     * @example\n     * ```typescript\n     * let isRequired = this.igxInput.required;\n     * ```\n     */\n    public get required() {\n        let validation;\n        if (this.ngControl && (this.ngControl.control.validator || this.ngControl.control.asyncValidator)) {\n            validation = this.ngControl.control.validator({} as AbstractControl);\n        }\n        return validation && validation.required || this.nativeElement.hasAttribute('required');\n    }\n    /**\n     * @hidden\n     * @internal\n     */\n    @HostListener('focus')\n    public onFocus() {\n        this.inputGroup.isFocused = true;\n    }\n    /**\n     * @param event The event to invoke the handler\n     *\n     * @hidden\n     * @internal\n     */\n    @HostListener('blur')\n    public onBlur() {\n        this.inputGroup.isFocused = false;\n        this.updateValidityState();\n    }\n    /** @hidden @internal */\n    @HostListener('input')\n    public onInput() {\n        this.checkNativeValidity();\n    }\n    /** @hidden @internal */\n    @HostListener('change', ['$event'])\n    public change(event: Event) {\n        if (this.type === 'file') {\n            const fileList: FileList | null = (event.target as HTMLInputElement)\n                .files;\n            const fileArray: File[] = [];\n\n            if (fileList) {\n                for (const file of Array.from(fileList)) {\n                    fileArray.push(file);\n                }\n            }\n\n            this._fileNames = (fileArray || []).map((f: File) => f.name).join(', ');\n\n            if (this.required && fileList?.length > 0) {\n                this._valid = IgxInputState.INITIAL;\n            }\n        }\n    }\n\n    /** @hidden @internal */\n    public get fileNames() {\n        return this._fileNames;\n    }\n\n    /** @hidden @internal */\n    public clear() {\n        this.ngControl?.control?.setValue('');\n        this.nativeElement.value = null;\n        this._fileNames = '';\n    }\n\n    /** @hidden @internal */\n    public ngAfterViewInit() {\n        this.inputGroup.hasPlaceholder = this.nativeElement.hasAttribute(\n            'placeholder'\n        );\n\n        if (this.ngControl && this.ngControl.disabled !== null) {\n            this.disabled = this.ngControl.disabled;\n        }\n        this.inputGroup.disabled =\n            this.inputGroup.disabled ||\n            this.nativeElement.hasAttribute('disabled');\n        this.inputGroup.isRequired = this.nativeElement.hasAttribute(\n            'required'\n        );\n\n        // Make sure we do not invalidate the input on init\n        if (!this.ngControl) {\n            this._valid = IgxInputState.INITIAL;\n        }\n        // Also check the control's validators for required\n        if (this.required && !this.inputGroup.isRequired) {\n            this.inputGroup.isRequired = this.required;\n        }\n\n        this.renderer.setAttribute(this.nativeElement, 'aria-required', this.required.toString());\n\n        const elTag = this.nativeElement.tagName.toLowerCase();\n        if (elTag === 'textarea') {\n            this.isTextArea = true;\n        } else {\n            this.isInput = true;\n        }\n\n        if (this.ngControl) {\n            this._statusChanges$ = this.ngControl.statusChanges.subscribe(\n                this.onStatusChanged.bind(this)\n            );\n        }\n\n        this.cdr.detectChanges();\n    }\n    /** @hidden @internal */\n    public ngOnDestroy() {\n        if (this._statusChanges$) {\n            this._statusChanges$.unsubscribe();\n        }\n    }\n    /**\n     * Sets a focus on the igxInput.\n     *\n     * @example\n     * ```typescript\n     * this.igxInput.focus();\n     * ```\n     */\n    public focus() {\n        this.nativeElement.focus();\n    }\n    /**\n     * Gets the `nativeElement` of the igxInput.\n     *\n     * @example\n     * ```typescript\n     * let igxInputNativeElement = this.igxInput.nativeElement;\n     * ```\n     */\n    public get nativeElement() {\n        return this.element.nativeElement;\n    }\n    /** @hidden @internal */\n    protected onStatusChanged() {\n        // Enable/Disable control based on ngControl #7086\n        if (this.disabled !== this.ngControl.disabled) {\n            this.disabled = this.ngControl.disabled;\n        }\n        this.updateValidityState();\n    }\n    /**\n     * @hidden\n     * @internal\n     */\n    protected updateValidityState() {\n        if (this.ngControl) {\n            if (this.ngControl.control.validator || this.ngControl.control.asyncValidator) {\n                // Run the validation with empty object to check if required is enabled.\n                const error = this.ngControl.control.validator({} as AbstractControl);\n                this.inputGroup.isRequired = error && error.required;\n                if (!this.disabled && (this.ngControl.control.touched || this.ngControl.control.dirty)) {\n                    // the control is not disabled and is touched or dirty\n                    this._valid = this.ngControl.invalid ?\n                        IgxInputState.INVALID : this.focused ? IgxInputState.VALID :\n                            IgxInputState.INITIAL;\n                } else {\n                    //  if control is untouched, pristine, or disabled its state is initial. This is when user did not interact\n                    //  with the input or when form/control is reset\n                    this._valid = IgxInputState.INITIAL;\n                }\n            } else {\n                // If validator is dynamically cleared, reset label's required class(asterisk) and IgxInputState #10010\n                this._valid = IgxInputState.INITIAL;\n                this.inputGroup.isRequired = false;\n            }\n            this.renderer.setAttribute(this.nativeElement, 'aria-required', this.required.toString());\n            const ariaInvalid = this.valid === IgxInputState.INVALID;\n            this.renderer.setAttribute(this.nativeElement, 'aria-invalid', ariaInvalid.toString());\n        } else {\n            this.checkNativeValidity();\n        }\n    }\n    /**\n     * Gets whether the igxInput has a placeholder.\n     *\n     * @example\n     * ```typescript\n     * let hasPlaceholder = this.igxInput.hasPlaceholder;\n     * ```\n     */\n    public get hasPlaceholder() {\n        return this.nativeElement.hasAttribute('placeholder');\n    }\n    /**\n     * Gets the placeholder element of the igxInput.\n     *\n     * @example\n     * ```typescript\n     * let igxInputPlaceholder = this.igxInput.placeholder;\n     * ```\n     */\n    public get placeholder() {\n        return this.nativeElement.placeholder;\n    }\n\n    /**\n     * @returns An indicator of whether the input has validator attributes or not\n     *\n     * @hidden\n     * @internal\n     */\n    private _hasValidators(): boolean {\n        for (const nativeValidationAttribute of nativeValidationAttributes) {\n            if (this.nativeElement.hasAttribute(nativeValidationAttribute)) {\n                return true;\n            }\n        }\n        return false;\n    }\n\n    /**\n     * Gets whether the igxInput is focused.\n     *\n     * @example\n     * ```typescript\n     * let isFocused = this.igxInput.focused;\n     * ```\n     */\n    public get focused() {\n        return this.inputGroup.isFocused;\n    }\n    /**\n     * Gets the state of the igxInput.\n     *\n     * @example\n     * ```typescript\n     * let igxInputState = this.igxInput.valid;\n     * ```\n     */\n    public get valid(): IgxInputState {\n        return this._valid;\n    }\n\n    /**\n     * Sets the state of the igxInput.\n     *\n     * @example\n     * ```typescript\n     * this.igxInput.valid = IgxInputState.INVALID;\n     * ```\n     */\n    public set valid(value: IgxInputState) {\n        this._valid = value;\n    }\n\n    /**\n     * Gets whether the igxInput is valid.\n     *\n     * @example\n     * ```typescript\n     * let valid = this.igxInput.isValid;\n     * ```\n     */\n    public get isValid(): boolean {\n        return this.valid !== IgxInputState.INVALID;\n    }\n\n    /**\n     * A function to assign a native validity property of an input.\n     * This should be used when there's no ngControl\n     *\n     * @hidden\n     * @internal\n     */\n    private checkNativeValidity() {\n        if (!this.disabled && this._hasValidators()) {\n            this._valid = this.nativeElement.checkValidity() ?\n                this.focused ? IgxInputState.VALID : IgxInputState.INITIAL :\n                IgxInputState.INVALID;\n        }\n    }\n\n    /**\n     * Returns the input type.\n     *\n     * @hidden\n     * @internal\n     */\n    public get type() {\n        return this.nativeElement.type;\n    }\n}\n"]}
486
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input.directive.js","sourceRoot":"","sources":["../../../../../../projects/igniteui-angular/src/lib/directives/input/input.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterViewInit,\n    ChangeDetectorRef,\n    Directive,\n    ElementRef,\n    HostBinding,\n    HostListener,\n    Inject,\n    Input,\n    OnDestroy,\n    Optional,\n    Renderer2,\n    Self,\n} from '@angular/core';\nimport {\n    AbstractControl,\n    NgControl,\n    NgModel\n} from '@angular/forms';\nimport { Subscription } from 'rxjs';\nimport { IgxInputGroupBase } from '../../input-group/input-group.common';\n\nconst nativeValidationAttributes = [\n    'required',\n    'pattern',\n    'minlength',\n    'maxlength',\n    'min',\n    'max',\n    'step',\n];\n\nexport enum IgxInputState {\n    INITIAL,\n    VALID,\n    INVALID,\n}\n\n/**\n * The `igxInput` directive creates single- or multiline text elements, covering common scenarios when dealing with form inputs.\n *\n * @igxModule IgxInputGroupModule\n *\n * @igxParent Data Entry & Display\n *\n * @igxTheme igx-input-group-theme\n *\n * @igxKeywords input, input group, form, field, validation\n *\n * @igxGroup presentation\n *\n * @example\n * ```html\n * <input-group>\n *  <label for=\"address\">Address</label>\n *  <input igxInput name=\"address\" type=\"text\" [(ngModel)]=\"customer.address\">\n * </input-group>\n * ```\n */\n@Directive({\n    selector: '[igxInput]',\n    exportAs: 'igxInput',\n    standalone: true\n})\nexport class IgxInputDirective implements AfterViewInit, OnDestroy {\n    private static ngAcceptInputType_required: boolean | '';\n    private static ngAcceptInputType_disabled: boolean | '';\n    /**\n     * Sets/gets whether the `\"igx-input-group__input\"` class is added to the host element.\n     * Default value is `false`.\n     *\n     * @example\n     * ```typescript\n     * this.igxInput.isInput = true;\n     * ```\n     *\n     * @example\n     * ```typescript\n     * let isCLassAdded = this.igxInput.isInput;\n     * ```\n     */\n    @HostBinding('class.igx-input-group__input')\n    public isInput = false;\n    /**\n     * Sets/gets whether the `\"class.igx-input-group__textarea\"` class is added to the host element.\n     * Default value is `false`.\n     *\n     * @example\n     * ```typescript\n     * this.igxInput.isTextArea = true;\n     * ```\n     *\n     * @example\n     * ```typescript\n     * let isCLassAdded = this.igxInput.isTextArea;\n     * ```\n     */\n    @HostBinding('class.igx-input-group__textarea')\n    public isTextArea = false;\n\n    private _valid = IgxInputState.INITIAL;\n    private _statusChanges$: Subscription;\n    private _valueChanges$: Subscription;\n    private _fileNames: string;\n    private _disabled = false;\n\n    constructor(\n        public inputGroup: IgxInputGroupBase,\n        @Optional() @Self() @Inject(NgModel) protected ngModel: NgModel,\n        @Optional()\n        @Self()\n        @Inject(NgControl)\n        protected formControl: NgControl,\n        protected element: ElementRef<HTMLInputElement>,\n        protected cdr: ChangeDetectorRef,\n        protected renderer: Renderer2\n    ) { }\n\n    private get ngControl(): NgControl {\n        return this.ngModel ? this.ngModel : this.formControl;\n    }\n\n    /**\n     * Sets the `value` property.\n     *\n     * @example\n     * ```html\n     * <input-group>\n     *  <input igxInput #igxInput [value]=\"'IgxInput Value'\">\n     * </input-group>\n     * ```\n     */\n    @Input()\n    public set value(value: any) {\n        this.nativeElement.value = value ?? '';\n        this.updateValidityState();\n    }\n    /**\n     * Gets the `value` property.\n     *\n     * @example\n     * ```typescript\n     * @ViewChild('igxInput', {read: IgxInputDirective})\n     *  public igxInput: IgxInputDirective;\n     * let inputValue = this.igxInput.value;\n     * ```\n     */\n    public get value() {\n        return this.nativeElement.value;\n    }\n    /**\n     * Sets the `disabled` property.\n     *\n     * @example\n     * ```html\n     * <input-group>\n     *  <input igxInput #igxInput [disabled]=\"true\">\n     * </input-group>\n     * ```\n     */\n    @Input()\n    @HostBinding('disabled')\n    public set disabled(value: boolean) {\n        this._disabled = this.inputGroup.disabled = !!((value as any === '') || value);\n        if (this.focused && this._disabled) {\n            // Browser focus may not fire in good time and mess with change detection, adjust here in advance:\n            this.inputGroup.isFocused = false;\n        }\n    }\n    /**\n     * Gets the `disabled` property\n     *\n     * @example\n     * ```typescript\n     * @ViewChild('igxInput', {read: IgxInputDirective})\n     *  public igxInput: IgxInputDirective;\n     * let isDisabled = this.igxInput.disabled;\n     * ```\n     */\n    public get disabled() {\n        return this._disabled;\n    }\n\n    /**\n     * Sets the `required` property.\n     *\n     * @example\n     * ```html\n     * <input-group>\n     *  <input igxInput #igxInput required>\n     * </input-group>\n     * ```\n     */\n    @Input()\n    public set required(value: boolean) {\n        this.nativeElement.required = this.inputGroup.isRequired = (value as any === '') || value;\n    }\n\n    /**\n     * Gets whether the igxInput is required.\n     *\n     * @example\n     * ```typescript\n     * let isRequired = this.igxInput.required;\n     * ```\n     */\n    public get required() {\n        let validation;\n        if (this.ngControl && (this.ngControl.control.validator || this.ngControl.control.asyncValidator)) {\n            validation = this.ngControl.control.validator({} as AbstractControl);\n        }\n        return validation && validation.required || this.nativeElement.hasAttribute('required');\n    }\n    /**\n     * @hidden\n     * @internal\n     */\n    @HostListener('focus')\n    public onFocus() {\n        this.inputGroup.isFocused = true;\n    }\n    /**\n     * @param event The event to invoke the handler\n     *\n     * @hidden\n     * @internal\n     */\n    @HostListener('blur')\n    public onBlur() {\n        this.inputGroup.isFocused = false;\n        this.updateValidityState();\n    }\n    /** @hidden @internal */\n    @HostListener('input')\n    public onInput() {\n        this.checkNativeValidity();\n    }\n    /** @hidden @internal */\n    @HostListener('change', ['$event'])\n    public change(event: Event) {\n        if (this.type === 'file') {\n            const fileList: FileList | null = (event.target as HTMLInputElement)\n                .files;\n            const fileArray: File[] = [];\n\n            if (fileList) {\n                for (const file of Array.from(fileList)) {\n                    fileArray.push(file);\n                }\n            }\n\n            this._fileNames = (fileArray || []).map((f: File) => f.name).join(', ');\n\n            if (this.required && fileList?.length > 0) {\n                this._valid = IgxInputState.INITIAL;\n            }\n        }\n    }\n\n    /** @hidden @internal */\n    public get fileNames() {\n        return this._fileNames;\n    }\n\n    /** @hidden @internal */\n    public clear() {\n        this.ngControl?.control?.setValue('');\n        this.nativeElement.value = null;\n        this._fileNames = '';\n    }\n\n    /** @hidden @internal */\n    public ngAfterViewInit() {\n        this.inputGroup.hasPlaceholder = this.nativeElement.hasAttribute(\n            'placeholder'\n        );\n\n        if (this.ngControl && this.ngControl.disabled !== null) {\n            this.disabled = this.ngControl.disabled;\n        }\n        this.inputGroup.disabled =\n            this.inputGroup.disabled ||\n            this.nativeElement.hasAttribute('disabled');\n        this.inputGroup.isRequired = this.nativeElement.hasAttribute(\n            'required'\n        );\n\n        // Make sure we do not invalidate the input on init\n        if (!this.ngControl) {\n            this._valid = IgxInputState.INITIAL;\n        }\n        // Also check the control's validators for required\n        if (this.required && !this.inputGroup.isRequired) {\n            this.inputGroup.isRequired = this.required;\n        }\n\n        this.renderer.setAttribute(this.nativeElement, 'aria-required', this.required.toString());\n\n        const elTag = this.nativeElement.tagName.toLowerCase();\n        if (elTag === 'textarea') {\n            this.isTextArea = true;\n        } else {\n            this.isInput = true;\n        }\n\n        if (this.ngControl) {\n            this._statusChanges$ = this.ngControl.statusChanges.subscribe(\n                this.onStatusChanged.bind(this)\n            );\n\n            this._valueChanges$ = this.ngControl.valueChanges.subscribe(\n                this.onValueChanged.bind(this)\n            );\n        }\n\n        this.cdr.detectChanges();\n    }\n    /** @hidden @internal */\n    public ngOnDestroy() {\n        if (this._statusChanges$) {\n            this._statusChanges$.unsubscribe();\n        }\n\n        if (this._valueChanges$) {\n            this._valueChanges$.unsubscribe();\n        }\n    }\n    /**\n     * Sets a focus on the igxInput.\n     *\n     * @example\n     * ```typescript\n     * this.igxInput.focus();\n     * ```\n     */\n    public focus() {\n        this.nativeElement.focus();\n    }\n    /**\n     * Gets the `nativeElement` of the igxInput.\n     *\n     * @example\n     * ```typescript\n     * let igxInputNativeElement = this.igxInput.nativeElement;\n     * ```\n     */\n    public get nativeElement() {\n        return this.element.nativeElement;\n    }\n    /** @hidden @internal */\n    protected onStatusChanged() {\n        // Enable/Disable control based on ngControl #7086\n        if (this.disabled !== this.ngControl.disabled) {\n            this.disabled = this.ngControl.disabled;\n        }\n        this.updateValidityState();\n    }\n\n    /** @hidden @internal */\n    protected onValueChanged() {\n        if (this._fileNames && !this.value) {\n            this._fileNames = '';\n        }\n    }\n\n    /**\n     * @hidden\n     * @internal\n     */\n    protected updateValidityState() {\n        if (this.ngControl) {\n            if (this.ngControl.control.validator || this.ngControl.control.asyncValidator) {\n                // Run the validation with empty object to check if required is enabled.\n                const error = this.ngControl.control.validator({} as AbstractControl);\n                this.inputGroup.isRequired = error && error.required;\n                if (!this.disabled && (this.ngControl.control.touched || this.ngControl.control.dirty)) {\n                    // the control is not disabled and is touched or dirty\n                    this._valid = this.ngControl.invalid ?\n                        IgxInputState.INVALID : this.focused ? IgxInputState.VALID :\n                            IgxInputState.INITIAL;\n                } else {\n                    //  if control is untouched, pristine, or disabled its state is initial. This is when user did not interact\n                    //  with the input or when form/control is reset\n                    this._valid = IgxInputState.INITIAL;\n                }\n            } else {\n                // If validator is dynamically cleared, reset label's required class(asterisk) and IgxInputState #10010\n                this._valid = IgxInputState.INITIAL;\n                this.inputGroup.isRequired = false;\n            }\n            this.renderer.setAttribute(this.nativeElement, 'aria-required', this.required.toString());\n            const ariaInvalid = this.valid === IgxInputState.INVALID;\n            this.renderer.setAttribute(this.nativeElement, 'aria-invalid', ariaInvalid.toString());\n        } else {\n            this.checkNativeValidity();\n        }\n    }\n    /**\n     * Gets whether the igxInput has a placeholder.\n     *\n     * @example\n     * ```typescript\n     * let hasPlaceholder = this.igxInput.hasPlaceholder;\n     * ```\n     */\n    public get hasPlaceholder() {\n        return this.nativeElement.hasAttribute('placeholder');\n    }\n    /**\n     * Gets the placeholder element of the igxInput.\n     *\n     * @example\n     * ```typescript\n     * let igxInputPlaceholder = this.igxInput.placeholder;\n     * ```\n     */\n    public get placeholder() {\n        return this.nativeElement.placeholder;\n    }\n\n    /**\n     * @returns An indicator of whether the input has validator attributes or not\n     *\n     * @hidden\n     * @internal\n     */\n    private _hasValidators(): boolean {\n        for (const nativeValidationAttribute of nativeValidationAttributes) {\n            if (this.nativeElement.hasAttribute(nativeValidationAttribute)) {\n                return true;\n            }\n        }\n        return false;\n    }\n\n    /**\n     * Gets whether the igxInput is focused.\n     *\n     * @example\n     * ```typescript\n     * let isFocused = this.igxInput.focused;\n     * ```\n     */\n    public get focused() {\n        return this.inputGroup.isFocused;\n    }\n    /**\n     * Gets the state of the igxInput.\n     *\n     * @example\n     * ```typescript\n     * let igxInputState = this.igxInput.valid;\n     * ```\n     */\n    public get valid(): IgxInputState {\n        return this._valid;\n    }\n\n    /**\n     * Sets the state of the igxInput.\n     *\n     * @example\n     * ```typescript\n     * this.igxInput.valid = IgxInputState.INVALID;\n     * ```\n     */\n    public set valid(value: IgxInputState) {\n        this._valid = value;\n    }\n\n    /**\n     * Gets whether the igxInput is valid.\n     *\n     * @example\n     * ```typescript\n     * let valid = this.igxInput.isValid;\n     * ```\n     */\n    public get isValid(): boolean {\n        return this.valid !== IgxInputState.INVALID;\n    }\n\n    /**\n     * A function to assign a native validity property of an input.\n     * This should be used when there's no ngControl\n     *\n     * @hidden\n     * @internal\n     */\n    private checkNativeValidity() {\n        if (!this.disabled && this._hasValidators()) {\n            this._valid = this.nativeElement.checkValidity() ?\n                this.focused ? IgxInputState.VALID : IgxInputState.INITIAL :\n                IgxInputState.INVALID;\n        }\n    }\n\n    /**\n     * Returns the input type.\n     *\n     * @hidden\n     * @internal\n     */\n    public get type() {\n        return this.nativeElement.type;\n    }\n}\n"]}