From 9ceee07d83f1db731371edc0457d8819c4d49bc8 Mon Sep 17 00:00:00 2001 From: cexbrayat Date: Thu, 8 Aug 2019 19:19:41 +0200 Subject: [PATCH] fix(forms): accept number length in length validators (#32057) Both `MinLengthValidator` and `MaxLengthValidator` accepted only string inputs for the length required, which throws with Ivy and `fullTemplateTypeCheck` enabled: with: Type 'number' is not assignable to type 'string | undefined' This relaxes the accepted type to `string | number` to avoid breakage when developers switch to Ivy and fTTC. PR Close #32057 --- packages/forms/src/directives/validators.ts | 12 +++++++----- tools/public_api_guard/forms/forms.d.ts | 4 ++-- 2 files changed, 9 insertions(+), 7 deletions(-) diff --git a/packages/forms/src/directives/validators.ts b/packages/forms/src/directives/validators.ts index d3e000dc24..e8d6c0d251 100644 --- a/packages/forms/src/directives/validators.ts +++ b/packages/forms/src/directives/validators.ts @@ -333,7 +333,7 @@ export const MIN_LENGTH_VALIDATOR: any = { /** * A directive that adds minimum length validation to controls marked with the - * `minlength` attribute. The directive is provided with the `NG_VALIDATORS` mult-provider list. + * `minlength` attribute. The directive is provided with the `NG_VALIDATORS` multi-provider list. * * @see [Form Validation](guide/form-validation) * @@ -369,7 +369,7 @@ export class MinLengthValidator implements Validator, * Tracks changes to the the minimum length bound to this directive. */ // TODO(issue/24571): remove '!'. - @Input() minlength !: string; + @Input() minlength !: string | number; /** * @description @@ -403,7 +403,8 @@ export class MinLengthValidator implements Validator, registerOnValidatorChange(fn: () => void): void { this._onChange = fn; } private _createValidator(): void { - this._validator = Validators.minLength(parseInt(this.minlength, 10)); + this._validator = Validators.minLength( + typeof this.minlength === 'number' ? this.minlength : parseInt(this.minlength, 10)); } } @@ -455,7 +456,7 @@ export class MaxLengthValidator implements Validator, * Tracks changes to the the maximum length bound to this directive. */ // TODO(issue/24571): remove '!'. - @Input() maxlength !: string; + @Input() maxlength !: string | number; /** * @description @@ -489,7 +490,8 @@ export class MaxLengthValidator implements Validator, registerOnValidatorChange(fn: () => void): void { this._onChange = fn; } private _createValidator(): void { - this._validator = Validators.maxLength(parseInt(this.maxlength, 10)); + this._validator = Validators.maxLength( + typeof this.maxlength === 'number' ? this.maxlength : parseInt(this.maxlength, 10)); } } diff --git a/tools/public_api_guard/forms/forms.d.ts b/tools/public_api_guard/forms/forms.d.ts index 685841ba05..68b73fc058 100644 --- a/tools/public_api_guard/forms/forms.d.ts +++ b/tools/public_api_guard/forms/forms.d.ts @@ -330,14 +330,14 @@ export declare class FormsModule { } export declare class MaxLengthValidator implements Validator, OnChanges { - maxlength: string; + maxlength: string | number; ngOnChanges(changes: SimpleChanges): void; registerOnValidatorChange(fn: () => void): void; validate(control: AbstractControl): ValidationErrors | null; } export declare class MinLengthValidator implements Validator, OnChanges { - minlength: string; + minlength: string | number; ngOnChanges(changes: SimpleChanges): void; registerOnValidatorChange(fn: () => void): void; validate(control: AbstractControl): ValidationErrors | null;