UNPKG

ngx-materialize

Version:

An Angular wrap around Materialize library

276 lines (275 loc) 24.4 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes} checked by tsc */ import { Component, ComponentFactoryResolver, ElementRef, HostBinding, HostListener, Input, Renderer, ViewContainerRef, ViewEncapsulation, } from '@angular/core'; import { NgControl } from '@angular/forms'; import { ErrorMessageResource, MzErrorMessageComponent } from './error-message/index'; var MzValidationComponent = /** @class */ (function () { function MzValidationComponent(elementRef, resolver, viewContainerRef, ngControl, renderer) { this.elementRef = elementRef; this.resolver = resolver; this.viewContainerRef = viewContainerRef; this.ngControl = ngControl; this.renderer = renderer; this.errorMessageComponent = null; this._formControlDisabled = false; this._required = false; } Object.defineProperty(MzValidationComponent.prototype, "required", { get: /** * @return {?} */ function () { return this._required; }, set: /** * @param {?} value * @return {?} */ function (value) { this._required = (value != null && "" + value !== 'false'); }, enumerable: true, configurable: true }); Object.defineProperty(MzValidationComponent.prototype, "formControlDisabled", { get: /** * @return {?} */ function () { return this._formControlDisabled; }, set: /** * @param {?} value * @return {?} */ function (value) { this._formControlDisabled = value; if (this._formControlDisabled) { this.ngControl.control.disable(); } else { this.ngControl.control.enable(); } }, enumerable: true, configurable: true }); Object.defineProperty(MzValidationComponent.prototype, "elementToAddValidation", { get: /** * @return {?} */ function () { return this.isNativeSelectElement ? this.inputSelectDropdown : this.nativeElement; }, enumerable: true, configurable: true }); Object.defineProperty(MzValidationComponent.prototype, "inputSelectDropdown", { get: /** * @return {?} */ function () { return this.nativeElement.siblings('input.select-dropdown'); }, enumerable: true, configurable: true }); Object.defineProperty(MzValidationComponent.prototype, "isNativeSelectElement", { get: /** * @return {?} */ function () { return this.nativeElement[0].nodeName === 'SELECT'; }, enumerable: true, configurable: true }); /** * @param {?} target * @return {?} */ MzValidationComponent.prototype.onFocusOut = /** * @param {?} target * @return {?} */ function (target) { this.ngControl.control.markAsTouched(); this.setValidationState(); }; /** * @return {?} */ MzValidationComponent.prototype.ngAfterViewInit = /** * @return {?} */ function () { this.initElements(); this.initErrorMessageComponent(); this.subscribeStatusChanges(); }; /** * @return {?} */ MzValidationComponent.prototype.ngOnDestroy = /** * @return {?} */ function () { this.statusChangesSubscription.unsubscribe(); this.errorMessageComponent.destroy(); }; /** * @param {?} element * @return {?} */ MzValidationComponent.prototype.clearValidationState = /** * @param {?} element * @return {?} */ function (element) { this.renderer.setElementClass(element[0], 'valid', false); this.renderer.setElementClass(element[0], 'invalid', false); }; /** * @return {?} */ MzValidationComponent.prototype.createRequiredSpanElement = /** * @return {?} */ function () { if (this.required && this.labelElement) { var /** @type {?} */ spanElement = document.createElement('span'); spanElement.setAttribute('class', 'placeholder-required'); spanElement.textContent = ' *'; this.renderer.invokeElementMethod(this.labelElement, 'appendChild', [spanElement]); } }; /** * @return {?} */ MzValidationComponent.prototype.initElements = /** * @return {?} */ function () { this.labelElement = $('label[for="' + this.id + '"]')[0]; this.nativeElement = $(this.elementRef.nativeElement); this.createRequiredSpanElement(); }; /** * @return {?} */ MzValidationComponent.prototype.initErrorMessageComponent = /** * @return {?} */ function () { var /** @type {?} */ errorMessageFactory = this.resolver.resolveComponentFactory(MzErrorMessageComponent); this.errorMessageComponent = this.viewContainerRef.createComponent(errorMessageFactory); this.errorMessageComponent.instance.errorMessageResource = this.errorMessageResource; this.errorMessageComponent.instance.control = this.ngControl.control; this.errorMessageComponent.changeDetectorRef.detectChanges(); var /** @type {?} */ errorMessage = this.nativeElement.parent().children('mz-error-message'); this.renderer.invokeElementMethod(errorMessage, 'insertAfter', [this.labelElement]); }; /** * @return {?} */ MzValidationComponent.prototype.setValidationState = /** * @return {?} */ function () { // to handle reset form if (this.ngControl.control.untouched && this.ngControl.control.pristine) { this.clearValidationState(this.elementToAddValidation); return; } // to handle field validity if (this.ngControl.control.enabled) { if (this.ngControl.control.valid) { this.renderer.setElementClass(this.elementToAddValidation[0], 'valid', true); this.renderer.setElementClass(this.elementToAddValidation[0], 'invalid', false); } else { this.renderer.setElementClass(this.elementToAddValidation[0], 'valid', false); this.renderer.setElementClass(this.elementToAddValidation[0], 'invalid', true); } } else { this.clearValidationState(this.elementToAddValidation); } }; /** * @return {?} */ MzValidationComponent.prototype.subscribeStatusChanges = /** * @return {?} */ function () { var _this = this; this.statusChangesSubscription = this.ngControl.control.statusChanges.subscribe(function (status) { // TODO Find a better way to handle validation after the form subscription. (see demo form-validation) // wait for the valueChanges method from FormGroup to have been triggered before handling the validation state // /!\ race condition warning /!\ setTimeout(function () { return _this.setValidationState(); }); }); }; MzValidationComponent.decorators = [ { type: Component, args: [{ encapsulation: ViewEncapsulation.None, selector: 'mz-validation, [mz-validation], [mzValidation]', template: "<ng-content></ng-content>", styles: [".select-wrapper input.select-dropdown.invalid,textarea.ng-invalid.ng-touched:focus{border-bottom:1px solid #f44336;box-shadow:0 1px 0 0 #f44336}.select-wrapper input.select-dropdown.valid{border-bottom:1px solid #4caf50;box-shadow:0 1px 0 0 #4caf50}input:not([type=checkbox]):focus+label.active span.placeholder-required,textarea:focus+label.active span.placeholder-required{color:#f44336}"], },] }, ]; /** @nocollapse */ MzValidationComponent.ctorParameters = function () { return [ { type: ElementRef, }, { type: ComponentFactoryResolver, }, { type: ViewContainerRef, }, { type: NgControl, }, { type: Renderer, }, ]; }; MzValidationComponent.propDecorators = { "id": [{ type: Input },], "errorMessageResource": [{ type: Input },], "required": [{ type: HostBinding, args: ['attr.required',] }, { type: Input },], "formControlDisabled": [{ type: Input },], "onFocusOut": [{ type: HostListener, args: ['focusout', ['$event.target'],] },], }; return MzValidationComponent; }()); export { MzValidationComponent }; function MzValidationComponent_tsickle_Closure_declarations() { /** @type {!Array<{type: !Function, args: (undefined|!Array<?>)}>} */ MzValidationComponent.decorators; /** * @nocollapse * @type {function(): !Array<(null|{type: ?, decorators: (undefined|!Array<{type: !Function, args: (undefined|!Array<?>)}>)})>} */ MzValidationComponent.ctorParameters; /** @type {!Object<string,!Array<{type: !Function, args: (undefined|!Array<?>)}>>} */ MzValidationComponent.propDecorators; /** @type {?} */ MzValidationComponent.prototype.errorMessageComponent; /** @type {?} */ MzValidationComponent.prototype.labelElement; /** @type {?} */ MzValidationComponent.prototype.nativeElement; /** @type {?} */ MzValidationComponent.prototype.statusChangesSubscription; /** @type {?} */ MzValidationComponent.prototype.id; /** @type {?} */ MzValidationComponent.prototype.errorMessageResource; /** @type {?} */ MzValidationComponent.prototype._formControlDisabled; /** @type {?} */ MzValidationComponent.prototype._required; /** @type {?} */ MzValidationComponent.prototype.elementRef; /** @type {?} */ MzValidationComponent.prototype.resolver; /** @type {?} */ MzValidationComponent.prototype.viewContainerRef; /** @type {?} */ MzValidationComponent.prototype.ngControl; /** @type {?} */ MzValidationComponent.prototype.renderer; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"validation.component.js","sourceRoot":"ng://ngx-materialize/","sources":["src/validation/validation.component.ts"],"names":[],"mappings":";;;;AAAA,OAAO,EAEL,SAAS,EACT,wBAAwB,EAExB,UAAU,EACV,WAAW,EACX,YAAY,EACZ,KAAK,EAEL,QAAQ,EACR,gBAAgB,EAChB,iBAAiB,GAClB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAG3C,OAAO,EAAE,oBAAoB,EAAE,uBAAuB,EAAE,MAAM,uBAAuB,CAAC;;IA2DpF,+BACU,YACA,UACA,kBACD,WACA;QAJC,eAAU,GAAV,UAAU;QACV,aAAQ,GAAR,QAAQ;QACR,qBAAgB,GAAhB,gBAAgB;QACjB,cAAS,GAAT,SAAS;QACT,aAAQ,GAAR,QAAQ;qCAvD+C,IAAI;oCAWrC,KAAK;yBAChB,KAAK;KA4CpB;0BAxCD,2CAAQ;;;;sBAAK,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC;;;;;QACvC,UAAa,KAAU,IAAI,IAAI,CAAC,SAAS,GAAG,CAAC,KAAK,IAAI,IAAI,IAAI,KAAG,KAAO,KAAK,OAAO,CAAC,CAAC,EAAE;;;;0BAGpF,sDAAmB;;;;sBAAK,MAAM,CAAC,IAAI,CAAC,oBAAoB,CAAC;;;;;QAC7D,UAAwB,KAAc;YACpC,IAAI,CAAC,oBAAoB,GAAG,KAAK,CAAC;YAClC,EAAE,CAAC,CAAC,IAAI,CAAC,oBAAoB,CAAC,CAAC,CAAC;gBAC9B,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,OAAO,EAAE,CAAC;aAClC;YAAC,IAAI,CAAC,CAAC;gBACN,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,MAAM,EAAE,CAAC;aACjC;SACF;;;;IAED,sBAAI,yDAAsB;;;;QAA1B;YACE,MAAM,CAAC,IAAI,CAAC,qBAAqB;gBAC/B,CAAC,CAAC,IAAI,CAAC,mBAAmB;gBAC1B,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC;SACxB;;;OAAA;IAED,sBAAI,sDAAmB;;;;QAAvB;YACE,MAAM,CAAC,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,uBAAuB,CAAC,CAAC;SAC7D;;;OAAA;IAED,sBAAI,wDAAqB;;;;QAAzB;YACE,MAAM,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,QAAQ,KAAK,QAAQ,CAAC;SACpD;;;OAAA;;;;;IAGD,0CAAU;;;;cAAC,MAAa;QACtB,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,aAAa,EAAE,CAAC;QACvC,IAAI,CAAC,kBAAkB,EAAE,CAAC;;;;;IAW5B,+CAAe;;;IAAf;QACE,IAAI,CAAC,YAAY,EAAE,CAAC;QACpB,IAAI,CAAC,yBAAyB,EAAE,CAAC;QACjC,IAAI,CAAC,sBAAsB,EAAE,CAAC;KAC/B;;;;IAED,2CAAW;;;IAAX;QACE,IAAI,CAAC,yBAAyB,CAAC,WAAW,EAAE,CAAC;QAC7C,IAAI,CAAC,qBAAqB,CAAC,OAAO,EAAE,CAAC;KACtC;;;;;IAED,oDAAoB;;;;IAApB,UAAqB,OAAe;QAClC,IAAI,CAAC,QAAQ,CAAC,eAAe,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,OAAO,EAAE,KAAK,CAAC,CAAC;QAC1D,IAAI,CAAC,QAAQ,CAAC,eAAe,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,SAAS,EAAE,KAAK,CAAC,CAAC;KAC7D;;;;IAED,yDAAyB;;;IAAzB;QACE,EAAE,CAAC,CAAC,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC;YACvC,qBAAM,WAAW,GAAG,QAAQ,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC;YACnD,WAAW,CAAC,YAAY,CAAC,OAAO,EAAE,sBAAsB,CAAC,CAAC;YAC1D,WAAW,CAAC,WAAW,GAAG,IAAI,CAAC;YAC/B,IAAI,CAAC,QAAQ,CAAC,mBAAmB,CAAC,IAAI,CAAC,YAAY,EAAE,aAAa,EAAE,CAAC,WAAW,CAAC,CAAC,CAAC;SACpF;KACF;;;;IAED,4CAAY;;;IAAZ;QACE,IAAI,CAAC,YAAY,GAAG,CAAC,CAAC,aAAa,GAAG,IAAI,CAAC,EAAE,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;QACzD,IAAI,CAAC,aAAa,GAAG,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,CAAC;QACtD,IAAI,CAAC,yBAAyB,EAAE,CAAC;KAClC;;;;IAED,yDAAyB;;;IAAzB;QACE,qBAAM,mBAAmB,GAAG,IAAI,CAAC,QAAQ,CAAC,uBAAuB,CAAC,uBAAuB,CAAC,CAAC;QAC3F,IAAI,CAAC,qBAAqB,GAAG,IAAI,CAAC,gBAAgB,CAAC,eAAe,CAAC,mBAAmB,CAAC,CAAC;QACxF,IAAI,CAAC,qBAAqB,CAAC,QAAQ,CAAC,oBAAoB,GAAG,IAAI,CAAC,oBAAoB,CAAC;QACrF,IAAI,CAAC,qBAAqB,CAAC,QAAQ,CAAC,OAAO,GAAG,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC;QACrE,IAAI,CAAC,qBAAqB,CAAC,iBAAiB,CAAC,aAAa,EAAE,CAAC;QAE7D,qBAAM,YAAY,GAAG,IAAI,CAAC,aAAa,CAAC,MAAM,EAAE,CAAC,QAAQ,CAAC,kBAAkB,CAAC,CAAC;QAC9E,IAAI,CAAC,QAAQ,CAAC,mBAAmB,CAAC,YAAY,EAAE,aAAa,EAAE,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC;KACrF;;;;IAED,kDAAkB;;;IAAlB;;QAEE,EAAE,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,SAAS,IAAI,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC;YACxE,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,sBAAsB,CAAC,CAAC;YACvD,MAAM,CAAC;SACR;;QAED,EAAE,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC;YACnC,EAAE,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC;gBACjC,IAAI,CAAC,QAAQ,CAAC,eAAe,CAAC,IAAI,CAAC,sBAAsB,CAAC,CAAC,CAAC,EAAE,OAAO,EAAE,IAAI,CAAC,CAAC;gBAC7E,IAAI,CAAC,QAAQ,CAAC,eAAe,CAAC,IAAI,CAAC,sBAAsB,CAAC,CAAC,CAAC,EAAE,SAAS,EAAE,KAAK,CAAC,CAAC;aACjF;YAAC,IAAI,CAAC,CAAC;gBACN,IAAI,CAAC,QAAQ,CAAC,eAAe,CAAC,IAAI,CAAC,sBAAsB,CAAC,CAAC,CAAC,EAAE,OAAO,EAAE,KAAK,CAAC,CAAC;gBAC9E,IAAI,CAAC,QAAQ,CAAC,eAAe,CAAC,IAAI,CAAC,sBAAsB,CAAC,CAAC,CAAC,EAAE,SAAS,EAAE,IAAI,CAAC,CAAC;aAChF;SACF;QAAC,IAAI,CAAC,CAAC;YACN,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,sBAAsB,CAAC,CAAC;SACxD;KACF;;;;IAED,sDAAsB;;;IAAtB;QAAA,iBAOC;QANC,IAAI,CAAC,yBAAyB,GAAG,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,aAAa,CAAC,SAAS,CAAC,UAAC,MAAc;;;;YAI7F,UAAU,CAAC,cAAM,OAAA,KAAI,CAAC,kBAAkB,EAAE,EAAzB,CAAyB,CAAC,CAAC;SAC7C,CAAC,CAAC;KACJ;;gBAtIF,SAAS,SAAC;oBACT,aAAa,EAAE,iBAAiB,CAAC,IAAI;oBACrC,QAAQ,EAAE,gDAAgD;oBAC1D,QAAQ,EAAE,2BAA2B;oBACrC,MAAM,EAAE,CAAC,uYAAuY,CAAC;iBAClZ;;;;gBAnBC,UAAU;gBAFV,wBAAwB;gBAQxB,gBAAgB;gBAGT,SAAS;gBAJhB,QAAQ;;;uBAsBP,KAAK;yCAGL,KAAK;6BAKL,WAAW,SAAC,eAAe,cAC3B,KAAK;wCAIL,KAAK;+BAyBL,YAAY,SAAC,UAAU,EAAE,CAAC,eAAe,CAAC;;gCAtE7C;;SAyBa,qBAAqB","sourcesContent":["import {\r\n  AfterViewInit,\r\n  Component,\r\n  ComponentFactoryResolver,\r\n  ComponentRef,\r\n  ElementRef,\r\n  HostBinding,\r\n  HostListener,\r\n  Input,\r\n  OnDestroy,\r\n  Renderer,\r\n  ViewContainerRef,\r\n  ViewEncapsulation,\r\n} from '@angular/core';\r\nimport { NgControl } from '@angular/forms';\r\nimport { Subscription } from 'rxjs';\r\n\r\nimport { ErrorMessageResource, MzErrorMessageComponent } from './error-message/index';\r\n\r\n@Component({\r\n  encapsulation: ViewEncapsulation.None,\r\n  selector: 'mz-validation, [mz-validation], [mzValidation]',\r\n  template: `<ng-content></ng-content>`,\r\n  styles: [`.select-wrapper input.select-dropdown.invalid,textarea.ng-invalid.ng-touched:focus{border-bottom:1px solid #f44336;box-shadow:0 1px 0 0 #f44336}.select-wrapper input.select-dropdown.valid{border-bottom:1px solid #4caf50;box-shadow:0 1px 0 0 #4caf50}input:not([type=checkbox]):focus+label.active span.placeholder-required,textarea:focus+label.active span.placeholder-required{color:#f44336}`],\r\n})\r\nexport class MzValidationComponent implements AfterViewInit, OnDestroy {\r\n  errorMessageComponent?: ComponentRef<MzErrorMessageComponent> = null;\r\n  labelElement: HTMLElement;\r\n  nativeElement: JQuery;\r\n  statusChangesSubscription: Subscription;\r\n\r\n  // native properties\r\n  @Input() id: string;\r\n\r\n  // component properties\r\n  @Input() errorMessageResource: ErrorMessageResource;\r\n\r\n  private _formControlDisabled = false;\r\n  private _required = false;\r\n\r\n  @HostBinding('attr.required')\r\n  @Input()\r\n  get required() { return this._required; }\r\n  set required(value: any) { this._required = (value != null && `${value}` !== 'false'); }\r\n\r\n  @Input()\r\n  get formControlDisabled() { return this._formControlDisabled; }\r\n  set formControlDisabled(value: boolean) {\r\n    this._formControlDisabled = value;\r\n    if (this._formControlDisabled) {\r\n      this.ngControl.control.disable();\r\n    } else {\r\n      this.ngControl.control.enable();\r\n    }\r\n  }\r\n\r\n  get elementToAddValidation(): JQuery {\r\n    return this.isNativeSelectElement\r\n      ? this.inputSelectDropdown\r\n      : this.nativeElement;\r\n  }\r\n\r\n  get inputSelectDropdown(): JQuery {\r\n    return this.nativeElement.siblings('input.select-dropdown');\r\n  }\r\n\r\n  get isNativeSelectElement(): boolean {\r\n    return this.nativeElement[0].nodeName === 'SELECT';\r\n  }\r\n\r\n  @HostListener('focusout', ['$event.target'])\r\n  onFocusOut(target: Event) {\r\n    this.ngControl.control.markAsTouched();\r\n    this.setValidationState();\r\n  }\r\n\r\n  constructor(\r\n    private elementRef: ElementRef,\r\n    private resolver: ComponentFactoryResolver,\r\n    private viewContainerRef: ViewContainerRef,\r\n    public ngControl: NgControl,\r\n    public renderer: Renderer,\r\n  ) { }\r\n\r\n  ngAfterViewInit() {\r\n    this.initElements();\r\n    this.initErrorMessageComponent();\r\n    this.subscribeStatusChanges();\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this.statusChangesSubscription.unsubscribe();\r\n    this.errorMessageComponent.destroy();\r\n  }\r\n\r\n  clearValidationState(element: JQuery) {\r\n    this.renderer.setElementClass(element[0], 'valid', false);\r\n    this.renderer.setElementClass(element[0], 'invalid', false);\r\n  }\r\n\r\n  createRequiredSpanElement() {\r\n    if (this.required && this.labelElement) {\r\n      const spanElement = document.createElement('span');\r\n      spanElement.setAttribute('class', 'placeholder-required');\r\n      spanElement.textContent = ' *';\r\n      this.renderer.invokeElementMethod(this.labelElement, 'appendChild', [spanElement]);\r\n    }\r\n  }\r\n\r\n  initElements() {\r\n    this.labelElement = $('label[for=\"' + this.id + '\"]')[0];\r\n    this.nativeElement = $(this.elementRef.nativeElement);\r\n    this.createRequiredSpanElement();\r\n  }\r\n\r\n  initErrorMessageComponent() {\r\n    const errorMessageFactory = this.resolver.resolveComponentFactory(MzErrorMessageComponent);\r\n    this.errorMessageComponent = this.viewContainerRef.createComponent(errorMessageFactory);\r\n    this.errorMessageComponent.instance.errorMessageResource = this.errorMessageResource;\r\n    this.errorMessageComponent.instance.control = this.ngControl.control;\r\n    this.errorMessageComponent.changeDetectorRef.detectChanges();\r\n\r\n    const errorMessage = this.nativeElement.parent().children('mz-error-message');\r\n    this.renderer.invokeElementMethod(errorMessage, 'insertAfter', [this.labelElement]);\r\n  }\r\n\r\n  setValidationState() {\r\n    // to handle reset form\r\n    if (this.ngControl.control.untouched && this.ngControl.control.pristine) {\r\n      this.clearValidationState(this.elementToAddValidation);\r\n      return;\r\n    }\r\n    // to handle field validity\r\n    if (this.ngControl.control.enabled) {\r\n      if (this.ngControl.control.valid) {\r\n        this.renderer.setElementClass(this.elementToAddValidation[0], 'valid', true);\r\n        this.renderer.setElementClass(this.elementToAddValidation[0], 'invalid', false);\r\n      } else {\r\n        this.renderer.setElementClass(this.elementToAddValidation[0], 'valid', false);\r\n        this.renderer.setElementClass(this.elementToAddValidation[0], 'invalid', true);\r\n      }\r\n    } else {\r\n      this.clearValidationState(this.elementToAddValidation);\r\n    }\r\n  }\r\n\r\n  subscribeStatusChanges() {\r\n    this.statusChangesSubscription = this.ngControl.control.statusChanges.subscribe((status: string) => {\r\n      // TODO Find a better way to handle validation after the form subscription. (see demo form-validation)\r\n      // wait for the valueChanges method from FormGroup to have been triggered before handling the validation state\r\n      // /!\\ race condition warning /!\\\r\n      setTimeout(() => this.setValidationState());\r\n    });\r\n  }\r\n}\r\n"]}