@angular/forms 19.0.0-next.1 → 19.0.0-next.11
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.
- package/LICENSE +21 -0
- package/fesm2022/forms.mjs +186 -132
- package/fesm2022/forms.mjs.map +1 -1
- package/index.d.ts +6 -5
- package/package.json +4 -6
- package/esm2022/forms.mjs +0 -5
- package/esm2022/index.mjs +0 -13
- package/esm2022/public_api.mjs +0 -15
- package/esm2022/src/directives/abstract_control_directive.mjs +0 -279
- package/esm2022/src/directives/abstract_form_group_directive.mjs +0 -61
- package/esm2022/src/directives/checkbox_value_accessor.mjs +0 -58
- package/esm2022/src/directives/control_container.mjs +0 -32
- package/esm2022/src/directives/control_value_accessor.mjs +0 -92
- package/esm2022/src/directives/default_value_accessor.mjs +0 -124
- package/esm2022/src/directives/error_examples.mjs +0 -57
- package/esm2022/src/directives/form_interface.mjs +0 -9
- package/esm2022/src/directives/ng_control.mjs +0 -38
- package/esm2022/src/directives/ng_control_status.mjs +0 -139
- package/esm2022/src/directives/ng_form.mjs +0 -313
- package/esm2022/src/directives/ng_model.mjs +0 -331
- package/esm2022/src/directives/ng_model_group.mjs +0 -95
- package/esm2022/src/directives/ng_no_validate_directive.mjs +0 -39
- package/esm2022/src/directives/number_value_accessor.mjs +0 -70
- package/esm2022/src/directives/radio_control_value_accessor.mjs +0 -201
- package/esm2022/src/directives/range_value_accessor.mjs +0 -72
- package/esm2022/src/directives/reactive_directives/form_control_directive.mjs +0 -183
- package/esm2022/src/directives/reactive_directives/form_control_name.mjs +0 -216
- package/esm2022/src/directives/reactive_directives/form_group_directive.mjs +0 -359
- package/esm2022/src/directives/reactive_directives/form_group_name.mjs +0 -246
- package/esm2022/src/directives/reactive_errors.mjs +0 -119
- package/esm2022/src/directives/select_control_value_accessor.mjs +0 -220
- package/esm2022/src/directives/select_multiple_control_value_accessor.mjs +0 -252
- package/esm2022/src/directives/shared.mjs +0 -350
- package/esm2022/src/directives/template_driven_errors.mjs +0 -54
- package/esm2022/src/directives/validators.mjs +0 -505
- package/esm2022/src/directives.mjs +0 -128
- package/esm2022/src/errors.mjs +0 -9
- package/esm2022/src/form_builder.mjs +0 -258
- package/esm2022/src/form_providers.mjs +0 -105
- package/esm2022/src/forms.mjs +0 -49
- package/esm2022/src/model/abstract_model.mjs +0 -992
- package/esm2022/src/model/form_array.mjs +0 -461
- package/esm2022/src/model/form_control.mjs +0 -126
- package/esm2022/src/model/form_group.mjs +0 -490
- package/esm2022/src/util.mjs +0 -13
- package/esm2022/src/validators.mjs +0 -680
- package/esm2022/src/version.mjs +0 -18
|
@@ -1,505 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* @license
|
|
3
|
-
* Copyright Google LLC All Rights Reserved.
|
|
4
|
-
*
|
|
5
|
-
* Use of this source code is governed by an MIT-style license that can be
|
|
6
|
-
* found in the LICENSE file at https://angular.io/license
|
|
7
|
-
*/
|
|
8
|
-
import { booleanAttribute, Directive, forwardRef, Input, } from '@angular/core';
|
|
9
|
-
import { emailValidator, maxLengthValidator, maxValidator, minLengthValidator, minValidator, NG_VALIDATORS, nullValidator, patternValidator, requiredTrueValidator, requiredValidator, } from '../validators';
|
|
10
|
-
import * as i0 from "@angular/core";
|
|
11
|
-
/**
|
|
12
|
-
* Method that updates string to integer if not already a number
|
|
13
|
-
*
|
|
14
|
-
* @param value The value to convert to integer.
|
|
15
|
-
* @returns value of parameter converted to number or integer.
|
|
16
|
-
*/
|
|
17
|
-
function toInteger(value) {
|
|
18
|
-
return typeof value === 'number' ? value : parseInt(value, 10);
|
|
19
|
-
}
|
|
20
|
-
/**
|
|
21
|
-
* Method that ensures that provided value is a float (and converts it to float if needed).
|
|
22
|
-
*
|
|
23
|
-
* @param value The value to convert to float.
|
|
24
|
-
* @returns value of parameter converted to number or float.
|
|
25
|
-
*/
|
|
26
|
-
function toFloat(value) {
|
|
27
|
-
return typeof value === 'number' ? value : parseFloat(value);
|
|
28
|
-
}
|
|
29
|
-
/**
|
|
30
|
-
* A base class for Validator-based Directives. The class contains common logic shared across such
|
|
31
|
-
* Directives.
|
|
32
|
-
*
|
|
33
|
-
* For internal use only, this class is not intended for use outside of the Forms package.
|
|
34
|
-
*/
|
|
35
|
-
class AbstractValidatorDirective {
|
|
36
|
-
constructor() {
|
|
37
|
-
this._validator = nullValidator;
|
|
38
|
-
}
|
|
39
|
-
/** @nodoc */
|
|
40
|
-
ngOnChanges(changes) {
|
|
41
|
-
if (this.inputName in changes) {
|
|
42
|
-
const input = this.normalizeInput(changes[this.inputName].currentValue);
|
|
43
|
-
this._enabled = this.enabled(input);
|
|
44
|
-
this._validator = this._enabled ? this.createValidator(input) : nullValidator;
|
|
45
|
-
if (this._onChange) {
|
|
46
|
-
this._onChange();
|
|
47
|
-
}
|
|
48
|
-
}
|
|
49
|
-
}
|
|
50
|
-
/** @nodoc */
|
|
51
|
-
validate(control) {
|
|
52
|
-
return this._validator(control);
|
|
53
|
-
}
|
|
54
|
-
/** @nodoc */
|
|
55
|
-
registerOnValidatorChange(fn) {
|
|
56
|
-
this._onChange = fn;
|
|
57
|
-
}
|
|
58
|
-
/**
|
|
59
|
-
* @description
|
|
60
|
-
* Determines whether this validator should be active or not based on an input.
|
|
61
|
-
* Base class implementation checks whether an input is defined (if the value is different from
|
|
62
|
-
* `null` and `undefined`). Validator classes that extend this base class can override this
|
|
63
|
-
* function with the logic specific to a particular validator directive.
|
|
64
|
-
*/
|
|
65
|
-
enabled(input) {
|
|
66
|
-
return input != null /* both `null` and `undefined` */;
|
|
67
|
-
}
|
|
68
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.0.0-next.1", ngImport: i0, type: AbstractValidatorDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
69
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "19.0.0-next.1", type: AbstractValidatorDirective, usesOnChanges: true, ngImport: i0 }); }
|
|
70
|
-
}
|
|
71
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.0.0-next.1", ngImport: i0, type: AbstractValidatorDirective, decorators: [{
|
|
72
|
-
type: Directive
|
|
73
|
-
}] });
|
|
74
|
-
/**
|
|
75
|
-
* @description
|
|
76
|
-
* Provider which adds `MaxValidator` to the `NG_VALIDATORS` multi-provider list.
|
|
77
|
-
*/
|
|
78
|
-
export const MAX_VALIDATOR = {
|
|
79
|
-
provide: NG_VALIDATORS,
|
|
80
|
-
useExisting: forwardRef(() => MaxValidator),
|
|
81
|
-
multi: true,
|
|
82
|
-
};
|
|
83
|
-
/**
|
|
84
|
-
* A directive which installs the {@link MaxValidator} for any `formControlName`,
|
|
85
|
-
* `formControl`, or control with `ngModel` that also has a `max` attribute.
|
|
86
|
-
*
|
|
87
|
-
* @see [Form Validation](guide/forms/form-validation)
|
|
88
|
-
*
|
|
89
|
-
* @usageNotes
|
|
90
|
-
*
|
|
91
|
-
* ### Adding a max validator
|
|
92
|
-
*
|
|
93
|
-
* The following example shows how to add a max validator to an input attached to an
|
|
94
|
-
* ngModel binding.
|
|
95
|
-
*
|
|
96
|
-
* ```html
|
|
97
|
-
* <input type="number" ngModel max="4">
|
|
98
|
-
* ```
|
|
99
|
-
*
|
|
100
|
-
* @ngModule ReactiveFormsModule
|
|
101
|
-
* @ngModule FormsModule
|
|
102
|
-
* @publicApi
|
|
103
|
-
*/
|
|
104
|
-
export class MaxValidator extends AbstractValidatorDirective {
|
|
105
|
-
constructor() {
|
|
106
|
-
super(...arguments);
|
|
107
|
-
/** @internal */
|
|
108
|
-
this.inputName = 'max';
|
|
109
|
-
/** @internal */
|
|
110
|
-
this.normalizeInput = (input) => toFloat(input);
|
|
111
|
-
/** @internal */
|
|
112
|
-
this.createValidator = (max) => maxValidator(max);
|
|
113
|
-
}
|
|
114
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.0.0-next.1", ngImport: i0, type: MaxValidator, deps: null, target: i0.ɵɵFactoryTarget.Directive }); }
|
|
115
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "19.0.0-next.1", type: MaxValidator, selector: "input[type=number][max][formControlName],input[type=number][max][formControl],input[type=number][max][ngModel]", inputs: { max: "max" }, host: { properties: { "attr.max": "_enabled ? max : null" } }, providers: [MAX_VALIDATOR], usesInheritance: true, ngImport: i0 }); }
|
|
116
|
-
}
|
|
117
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.0.0-next.1", ngImport: i0, type: MaxValidator, decorators: [{
|
|
118
|
-
type: Directive,
|
|
119
|
-
args: [{
|
|
120
|
-
selector: 'input[type=number][max][formControlName],input[type=number][max][formControl],input[type=number][max][ngModel]',
|
|
121
|
-
providers: [MAX_VALIDATOR],
|
|
122
|
-
host: { '[attr.max]': '_enabled ? max : null' },
|
|
123
|
-
}]
|
|
124
|
-
}], propDecorators: { max: [{
|
|
125
|
-
type: Input
|
|
126
|
-
}] } });
|
|
127
|
-
/**
|
|
128
|
-
* @description
|
|
129
|
-
* Provider which adds `MinValidator` to the `NG_VALIDATORS` multi-provider list.
|
|
130
|
-
*/
|
|
131
|
-
export const MIN_VALIDATOR = {
|
|
132
|
-
provide: NG_VALIDATORS,
|
|
133
|
-
useExisting: forwardRef(() => MinValidator),
|
|
134
|
-
multi: true,
|
|
135
|
-
};
|
|
136
|
-
/**
|
|
137
|
-
* A directive which installs the {@link MinValidator} for any `formControlName`,
|
|
138
|
-
* `formControl`, or control with `ngModel` that also has a `min` attribute.
|
|
139
|
-
*
|
|
140
|
-
* @see [Form Validation](guide/forms/form-validation)
|
|
141
|
-
*
|
|
142
|
-
* @usageNotes
|
|
143
|
-
*
|
|
144
|
-
* ### Adding a min validator
|
|
145
|
-
*
|
|
146
|
-
* The following example shows how to add a min validator to an input attached to an
|
|
147
|
-
* ngModel binding.
|
|
148
|
-
*
|
|
149
|
-
* ```html
|
|
150
|
-
* <input type="number" ngModel min="4">
|
|
151
|
-
* ```
|
|
152
|
-
*
|
|
153
|
-
* @ngModule ReactiveFormsModule
|
|
154
|
-
* @ngModule FormsModule
|
|
155
|
-
* @publicApi
|
|
156
|
-
*/
|
|
157
|
-
export class MinValidator extends AbstractValidatorDirective {
|
|
158
|
-
constructor() {
|
|
159
|
-
super(...arguments);
|
|
160
|
-
/** @internal */
|
|
161
|
-
this.inputName = 'min';
|
|
162
|
-
/** @internal */
|
|
163
|
-
this.normalizeInput = (input) => toFloat(input);
|
|
164
|
-
/** @internal */
|
|
165
|
-
this.createValidator = (min) => minValidator(min);
|
|
166
|
-
}
|
|
167
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.0.0-next.1", ngImport: i0, type: MinValidator, deps: null, target: i0.ɵɵFactoryTarget.Directive }); }
|
|
168
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "19.0.0-next.1", type: MinValidator, selector: "input[type=number][min][formControlName],input[type=number][min][formControl],input[type=number][min][ngModel]", inputs: { min: "min" }, host: { properties: { "attr.min": "_enabled ? min : null" } }, providers: [MIN_VALIDATOR], usesInheritance: true, ngImport: i0 }); }
|
|
169
|
-
}
|
|
170
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.0.0-next.1", ngImport: i0, type: MinValidator, decorators: [{
|
|
171
|
-
type: Directive,
|
|
172
|
-
args: [{
|
|
173
|
-
selector: 'input[type=number][min][formControlName],input[type=number][min][formControl],input[type=number][min][ngModel]',
|
|
174
|
-
providers: [MIN_VALIDATOR],
|
|
175
|
-
host: { '[attr.min]': '_enabled ? min : null' },
|
|
176
|
-
}]
|
|
177
|
-
}], propDecorators: { min: [{
|
|
178
|
-
type: Input
|
|
179
|
-
}] } });
|
|
180
|
-
/**
|
|
181
|
-
* @description
|
|
182
|
-
* Provider which adds `RequiredValidator` to the `NG_VALIDATORS` multi-provider list.
|
|
183
|
-
*/
|
|
184
|
-
export const REQUIRED_VALIDATOR = {
|
|
185
|
-
provide: NG_VALIDATORS,
|
|
186
|
-
useExisting: forwardRef(() => RequiredValidator),
|
|
187
|
-
multi: true,
|
|
188
|
-
};
|
|
189
|
-
/**
|
|
190
|
-
* @description
|
|
191
|
-
* Provider which adds `CheckboxRequiredValidator` to the `NG_VALIDATORS` multi-provider list.
|
|
192
|
-
*/
|
|
193
|
-
export const CHECKBOX_REQUIRED_VALIDATOR = {
|
|
194
|
-
provide: NG_VALIDATORS,
|
|
195
|
-
useExisting: forwardRef(() => CheckboxRequiredValidator),
|
|
196
|
-
multi: true,
|
|
197
|
-
};
|
|
198
|
-
/**
|
|
199
|
-
* @description
|
|
200
|
-
* A directive that adds the `required` validator to any controls marked with the
|
|
201
|
-
* `required` attribute. The directive is provided with the `NG_VALIDATORS` multi-provider list.
|
|
202
|
-
*
|
|
203
|
-
* @see [Form Validation](guide/forms/form-validation)
|
|
204
|
-
*
|
|
205
|
-
* @usageNotes
|
|
206
|
-
*
|
|
207
|
-
* ### Adding a required validator using template-driven forms
|
|
208
|
-
*
|
|
209
|
-
* ```
|
|
210
|
-
* <input name="fullName" ngModel required>
|
|
211
|
-
* ```
|
|
212
|
-
*
|
|
213
|
-
* @ngModule FormsModule
|
|
214
|
-
* @ngModule ReactiveFormsModule
|
|
215
|
-
* @publicApi
|
|
216
|
-
*/
|
|
217
|
-
export class RequiredValidator extends AbstractValidatorDirective {
|
|
218
|
-
constructor() {
|
|
219
|
-
super(...arguments);
|
|
220
|
-
/** @internal */
|
|
221
|
-
this.inputName = 'required';
|
|
222
|
-
/** @internal */
|
|
223
|
-
this.normalizeInput = booleanAttribute;
|
|
224
|
-
/** @internal */
|
|
225
|
-
this.createValidator = (input) => requiredValidator;
|
|
226
|
-
}
|
|
227
|
-
/** @nodoc */
|
|
228
|
-
enabled(input) {
|
|
229
|
-
return input;
|
|
230
|
-
}
|
|
231
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.0.0-next.1", ngImport: i0, type: RequiredValidator, deps: null, target: i0.ɵɵFactoryTarget.Directive }); }
|
|
232
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "19.0.0-next.1", type: RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: { required: "required" }, host: { properties: { "attr.required": "_enabled ? \"\" : null" } }, providers: [REQUIRED_VALIDATOR], usesInheritance: true, ngImport: i0 }); }
|
|
233
|
-
}
|
|
234
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.0.0-next.1", ngImport: i0, type: RequiredValidator, decorators: [{
|
|
235
|
-
type: Directive,
|
|
236
|
-
args: [{
|
|
237
|
-
selector: ':not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]',
|
|
238
|
-
providers: [REQUIRED_VALIDATOR],
|
|
239
|
-
host: { '[attr.required]': '_enabled ? "" : null' },
|
|
240
|
-
}]
|
|
241
|
-
}], propDecorators: { required: [{
|
|
242
|
-
type: Input
|
|
243
|
-
}] } });
|
|
244
|
-
/**
|
|
245
|
-
* A Directive that adds the `required` validator to checkbox controls marked with the
|
|
246
|
-
* `required` attribute. The directive is provided with the `NG_VALIDATORS` multi-provider list.
|
|
247
|
-
*
|
|
248
|
-
* @see [Form Validation](guide/forms/form-validation)
|
|
249
|
-
*
|
|
250
|
-
* @usageNotes
|
|
251
|
-
*
|
|
252
|
-
* ### Adding a required checkbox validator using template-driven forms
|
|
253
|
-
*
|
|
254
|
-
* The following example shows how to add a checkbox required validator to an input attached to an
|
|
255
|
-
* ngModel binding.
|
|
256
|
-
*
|
|
257
|
-
* ```
|
|
258
|
-
* <input type="checkbox" name="active" ngModel required>
|
|
259
|
-
* ```
|
|
260
|
-
*
|
|
261
|
-
* @publicApi
|
|
262
|
-
* @ngModule FormsModule
|
|
263
|
-
* @ngModule ReactiveFormsModule
|
|
264
|
-
*/
|
|
265
|
-
export class CheckboxRequiredValidator extends RequiredValidator {
|
|
266
|
-
constructor() {
|
|
267
|
-
super(...arguments);
|
|
268
|
-
/** @internal */
|
|
269
|
-
this.createValidator = (input) => requiredTrueValidator;
|
|
270
|
-
}
|
|
271
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.0.0-next.1", ngImport: i0, type: CheckboxRequiredValidator, deps: null, target: i0.ɵɵFactoryTarget.Directive }); }
|
|
272
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "19.0.0-next.1", type: CheckboxRequiredValidator, selector: "input[type=checkbox][required][formControlName],input[type=checkbox][required][formControl],input[type=checkbox][required][ngModel]", host: { properties: { "attr.required": "_enabled ? \"\" : null" } }, providers: [CHECKBOX_REQUIRED_VALIDATOR], usesInheritance: true, ngImport: i0 }); }
|
|
273
|
-
}
|
|
274
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.0.0-next.1", ngImport: i0, type: CheckboxRequiredValidator, decorators: [{
|
|
275
|
-
type: Directive,
|
|
276
|
-
args: [{
|
|
277
|
-
selector: 'input[type=checkbox][required][formControlName],input[type=checkbox][required][formControl],input[type=checkbox][required][ngModel]',
|
|
278
|
-
providers: [CHECKBOX_REQUIRED_VALIDATOR],
|
|
279
|
-
host: { '[attr.required]': '_enabled ? "" : null' },
|
|
280
|
-
}]
|
|
281
|
-
}] });
|
|
282
|
-
/**
|
|
283
|
-
* @description
|
|
284
|
-
* Provider which adds `EmailValidator` to the `NG_VALIDATORS` multi-provider list.
|
|
285
|
-
*/
|
|
286
|
-
export const EMAIL_VALIDATOR = {
|
|
287
|
-
provide: NG_VALIDATORS,
|
|
288
|
-
useExisting: forwardRef(() => EmailValidator),
|
|
289
|
-
multi: true,
|
|
290
|
-
};
|
|
291
|
-
/**
|
|
292
|
-
* A directive that adds the `email` validator to controls marked with the
|
|
293
|
-
* `email` attribute. The directive is provided with the `NG_VALIDATORS` multi-provider list.
|
|
294
|
-
*
|
|
295
|
-
* The email validation is based on the WHATWG HTML specification with some enhancements to
|
|
296
|
-
* incorporate more RFC rules. More information can be found on the [Validators.email
|
|
297
|
-
* page](api/forms/Validators#email).
|
|
298
|
-
*
|
|
299
|
-
* @see [Form Validation](guide/forms/form-validation)
|
|
300
|
-
*
|
|
301
|
-
* @usageNotes
|
|
302
|
-
*
|
|
303
|
-
* ### Adding an email validator
|
|
304
|
-
*
|
|
305
|
-
* The following example shows how to add an email validator to an input attached to an ngModel
|
|
306
|
-
* binding.
|
|
307
|
-
*
|
|
308
|
-
* ```
|
|
309
|
-
* <input type="email" name="email" ngModel email>
|
|
310
|
-
* <input type="email" name="email" ngModel email="true">
|
|
311
|
-
* <input type="email" name="email" ngModel [email]="true">
|
|
312
|
-
* ```
|
|
313
|
-
*
|
|
314
|
-
* @publicApi
|
|
315
|
-
* @ngModule FormsModule
|
|
316
|
-
* @ngModule ReactiveFormsModule
|
|
317
|
-
*/
|
|
318
|
-
export class EmailValidator extends AbstractValidatorDirective {
|
|
319
|
-
constructor() {
|
|
320
|
-
super(...arguments);
|
|
321
|
-
/** @internal */
|
|
322
|
-
this.inputName = 'email';
|
|
323
|
-
/** @internal */
|
|
324
|
-
this.normalizeInput = booleanAttribute;
|
|
325
|
-
/** @internal */
|
|
326
|
-
this.createValidator = (input) => emailValidator;
|
|
327
|
-
}
|
|
328
|
-
/** @nodoc */
|
|
329
|
-
enabled(input) {
|
|
330
|
-
return input;
|
|
331
|
-
}
|
|
332
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.0.0-next.1", ngImport: i0, type: EmailValidator, deps: null, target: i0.ɵɵFactoryTarget.Directive }); }
|
|
333
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "19.0.0-next.1", type: EmailValidator, selector: "[email][formControlName],[email][formControl],[email][ngModel]", inputs: { email: "email" }, providers: [EMAIL_VALIDATOR], usesInheritance: true, ngImport: i0 }); }
|
|
334
|
-
}
|
|
335
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.0.0-next.1", ngImport: i0, type: EmailValidator, decorators: [{
|
|
336
|
-
type: Directive,
|
|
337
|
-
args: [{
|
|
338
|
-
selector: '[email][formControlName],[email][formControl],[email][ngModel]',
|
|
339
|
-
providers: [EMAIL_VALIDATOR],
|
|
340
|
-
}]
|
|
341
|
-
}], propDecorators: { email: [{
|
|
342
|
-
type: Input
|
|
343
|
-
}] } });
|
|
344
|
-
/**
|
|
345
|
-
* @description
|
|
346
|
-
* Provider which adds `MinLengthValidator` to the `NG_VALIDATORS` multi-provider list.
|
|
347
|
-
*/
|
|
348
|
-
export const MIN_LENGTH_VALIDATOR = {
|
|
349
|
-
provide: NG_VALIDATORS,
|
|
350
|
-
useExisting: forwardRef(() => MinLengthValidator),
|
|
351
|
-
multi: true,
|
|
352
|
-
};
|
|
353
|
-
/**
|
|
354
|
-
* A directive that adds minimum length validation to controls marked with the
|
|
355
|
-
* `minlength` attribute. The directive is provided with the `NG_VALIDATORS` multi-provider list.
|
|
356
|
-
*
|
|
357
|
-
* @see [Form Validation](guide/forms/form-validation)
|
|
358
|
-
*
|
|
359
|
-
* @usageNotes
|
|
360
|
-
*
|
|
361
|
-
* ### Adding a minimum length validator
|
|
362
|
-
*
|
|
363
|
-
* The following example shows how to add a minimum length validator to an input attached to an
|
|
364
|
-
* ngModel binding.
|
|
365
|
-
*
|
|
366
|
-
* ```html
|
|
367
|
-
* <input name="firstName" ngModel minlength="4">
|
|
368
|
-
* ```
|
|
369
|
-
*
|
|
370
|
-
* @ngModule ReactiveFormsModule
|
|
371
|
-
* @ngModule FormsModule
|
|
372
|
-
* @publicApi
|
|
373
|
-
*/
|
|
374
|
-
export class MinLengthValidator extends AbstractValidatorDirective {
|
|
375
|
-
constructor() {
|
|
376
|
-
super(...arguments);
|
|
377
|
-
/** @internal */
|
|
378
|
-
this.inputName = 'minlength';
|
|
379
|
-
/** @internal */
|
|
380
|
-
this.normalizeInput = (input) => toInteger(input);
|
|
381
|
-
/** @internal */
|
|
382
|
-
this.createValidator = (minlength) => minLengthValidator(minlength);
|
|
383
|
-
}
|
|
384
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.0.0-next.1", ngImport: i0, type: MinLengthValidator, deps: null, target: i0.ɵɵFactoryTarget.Directive }); }
|
|
385
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "19.0.0-next.1", type: MinLengthValidator, selector: "[minlength][formControlName],[minlength][formControl],[minlength][ngModel]", inputs: { minlength: "minlength" }, host: { properties: { "attr.minlength": "_enabled ? minlength : null" } }, providers: [MIN_LENGTH_VALIDATOR], usesInheritance: true, ngImport: i0 }); }
|
|
386
|
-
}
|
|
387
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.0.0-next.1", ngImport: i0, type: MinLengthValidator, decorators: [{
|
|
388
|
-
type: Directive,
|
|
389
|
-
args: [{
|
|
390
|
-
selector: '[minlength][formControlName],[minlength][formControl],[minlength][ngModel]',
|
|
391
|
-
providers: [MIN_LENGTH_VALIDATOR],
|
|
392
|
-
host: { '[attr.minlength]': '_enabled ? minlength : null' },
|
|
393
|
-
}]
|
|
394
|
-
}], propDecorators: { minlength: [{
|
|
395
|
-
type: Input
|
|
396
|
-
}] } });
|
|
397
|
-
/**
|
|
398
|
-
* @description
|
|
399
|
-
* Provider which adds `MaxLengthValidator` to the `NG_VALIDATORS` multi-provider list.
|
|
400
|
-
*/
|
|
401
|
-
export const MAX_LENGTH_VALIDATOR = {
|
|
402
|
-
provide: NG_VALIDATORS,
|
|
403
|
-
useExisting: forwardRef(() => MaxLengthValidator),
|
|
404
|
-
multi: true,
|
|
405
|
-
};
|
|
406
|
-
/**
|
|
407
|
-
* A directive that adds maximum length validation to controls marked with the
|
|
408
|
-
* `maxlength` attribute. The directive is provided with the `NG_VALIDATORS` multi-provider list.
|
|
409
|
-
*
|
|
410
|
-
* @see [Form Validation](guide/forms/form-validation)
|
|
411
|
-
*
|
|
412
|
-
* @usageNotes
|
|
413
|
-
*
|
|
414
|
-
* ### Adding a maximum length validator
|
|
415
|
-
*
|
|
416
|
-
* The following example shows how to add a maximum length validator to an input attached to an
|
|
417
|
-
* ngModel binding.
|
|
418
|
-
*
|
|
419
|
-
* ```html
|
|
420
|
-
* <input name="firstName" ngModel maxlength="25">
|
|
421
|
-
* ```
|
|
422
|
-
*
|
|
423
|
-
* @ngModule ReactiveFormsModule
|
|
424
|
-
* @ngModule FormsModule
|
|
425
|
-
* @publicApi
|
|
426
|
-
*/
|
|
427
|
-
export class MaxLengthValidator extends AbstractValidatorDirective {
|
|
428
|
-
constructor() {
|
|
429
|
-
super(...arguments);
|
|
430
|
-
/** @internal */
|
|
431
|
-
this.inputName = 'maxlength';
|
|
432
|
-
/** @internal */
|
|
433
|
-
this.normalizeInput = (input) => toInteger(input);
|
|
434
|
-
/** @internal */
|
|
435
|
-
this.createValidator = (maxlength) => maxLengthValidator(maxlength);
|
|
436
|
-
}
|
|
437
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.0.0-next.1", ngImport: i0, type: MaxLengthValidator, deps: null, target: i0.ɵɵFactoryTarget.Directive }); }
|
|
438
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "19.0.0-next.1", type: MaxLengthValidator, selector: "[maxlength][formControlName],[maxlength][formControl],[maxlength][ngModel]", inputs: { maxlength: "maxlength" }, host: { properties: { "attr.maxlength": "_enabled ? maxlength : null" } }, providers: [MAX_LENGTH_VALIDATOR], usesInheritance: true, ngImport: i0 }); }
|
|
439
|
-
}
|
|
440
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.0.0-next.1", ngImport: i0, type: MaxLengthValidator, decorators: [{
|
|
441
|
-
type: Directive,
|
|
442
|
-
args: [{
|
|
443
|
-
selector: '[maxlength][formControlName],[maxlength][formControl],[maxlength][ngModel]',
|
|
444
|
-
providers: [MAX_LENGTH_VALIDATOR],
|
|
445
|
-
host: { '[attr.maxlength]': '_enabled ? maxlength : null' },
|
|
446
|
-
}]
|
|
447
|
-
}], propDecorators: { maxlength: [{
|
|
448
|
-
type: Input
|
|
449
|
-
}] } });
|
|
450
|
-
/**
|
|
451
|
-
* @description
|
|
452
|
-
* Provider which adds `PatternValidator` to the `NG_VALIDATORS` multi-provider list.
|
|
453
|
-
*/
|
|
454
|
-
export const PATTERN_VALIDATOR = {
|
|
455
|
-
provide: NG_VALIDATORS,
|
|
456
|
-
useExisting: forwardRef(() => PatternValidator),
|
|
457
|
-
multi: true,
|
|
458
|
-
};
|
|
459
|
-
/**
|
|
460
|
-
* @description
|
|
461
|
-
* A directive that adds regex pattern validation to controls marked with the
|
|
462
|
-
* `pattern` attribute. The regex must match the entire control value.
|
|
463
|
-
* The directive is provided with the `NG_VALIDATORS` multi-provider list.
|
|
464
|
-
*
|
|
465
|
-
* @see [Form Validation](guide/forms/form-validation)
|
|
466
|
-
*
|
|
467
|
-
* @usageNotes
|
|
468
|
-
*
|
|
469
|
-
* ### Adding a pattern validator
|
|
470
|
-
*
|
|
471
|
-
* The following example shows how to add a pattern validator to an input attached to an
|
|
472
|
-
* ngModel binding.
|
|
473
|
-
*
|
|
474
|
-
* ```html
|
|
475
|
-
* <input name="firstName" ngModel pattern="[a-zA-Z ]*">
|
|
476
|
-
* ```
|
|
477
|
-
*
|
|
478
|
-
* @ngModule ReactiveFormsModule
|
|
479
|
-
* @ngModule FormsModule
|
|
480
|
-
* @publicApi
|
|
481
|
-
*/
|
|
482
|
-
export class PatternValidator extends AbstractValidatorDirective {
|
|
483
|
-
constructor() {
|
|
484
|
-
super(...arguments);
|
|
485
|
-
/** @internal */
|
|
486
|
-
this.inputName = 'pattern';
|
|
487
|
-
/** @internal */
|
|
488
|
-
this.normalizeInput = (input) => input;
|
|
489
|
-
/** @internal */
|
|
490
|
-
this.createValidator = (input) => patternValidator(input);
|
|
491
|
-
}
|
|
492
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.0.0-next.1", ngImport: i0, type: PatternValidator, deps: null, target: i0.ɵɵFactoryTarget.Directive }); }
|
|
493
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "19.0.0-next.1", type: PatternValidator, selector: "[pattern][formControlName],[pattern][formControl],[pattern][ngModel]", inputs: { pattern: "pattern" }, host: { properties: { "attr.pattern": "_enabled ? pattern : null" } }, providers: [PATTERN_VALIDATOR], usesInheritance: true, ngImport: i0 }); }
|
|
494
|
-
}
|
|
495
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.0.0-next.1", ngImport: i0, type: PatternValidator, decorators: [{
|
|
496
|
-
type: Directive,
|
|
497
|
-
args: [{
|
|
498
|
-
selector: '[pattern][formControlName],[pattern][formControl],[pattern][ngModel]',
|
|
499
|
-
providers: [PATTERN_VALIDATOR],
|
|
500
|
-
host: { '[attr.pattern]': '_enabled ? pattern : null' },
|
|
501
|
-
}]
|
|
502
|
-
}], propDecorators: { pattern: [{
|
|
503
|
-
type: Input
|
|
504
|
-
}] } });
|
|
505
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"validators.js","sourceRoot":"","sources":["../../../../../../../packages/forms/src/directives/validators.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport {\n  booleanAttribute,\n  Directive,\n  forwardRef,\n  Input,\n  OnChanges,\n  Provider,\n  SimpleChanges,\n} from '@angular/core';\nimport {Observable} from 'rxjs';\n\nimport {AbstractControl} from '../model/abstract_model';\nimport {\n  emailValidator,\n  maxLengthValidator,\n  maxValidator,\n  minLengthValidator,\n  minValidator,\n  NG_VALIDATORS,\n  nullValidator,\n  patternValidator,\n  requiredTrueValidator,\n  requiredValidator,\n} from '../validators';\n\n/**\n * Method that updates string to integer if not already a number\n *\n * @param value The value to convert to integer.\n * @returns value of parameter converted to number or integer.\n */\nfunction toInteger(value: string | number): number {\n  return typeof value === 'number' ? value : parseInt(value, 10);\n}\n\n/**\n * Method that ensures that provided value is a float (and converts it to float if needed).\n *\n * @param value The value to convert to float.\n * @returns value of parameter converted to number or float.\n */\nfunction toFloat(value: string | number): number {\n  return typeof value === 'number' ? value : parseFloat(value);\n}\n\n/**\n * @description\n * Defines the map of errors returned from failed validation checks.\n *\n * @publicApi\n */\nexport type ValidationErrors = {\n  [key: string]: any;\n};\n\n/**\n * @description\n * An interface implemented by classes that perform synchronous validation.\n *\n * @usageNotes\n *\n * ### Provide a custom validator\n *\n * The following example implements the `Validator` interface to create a\n * validator directive with a custom error key.\n *\n * ```typescript\n * @Directive({\n *   selector: '[customValidator]',\n *   providers: [{provide: NG_VALIDATORS, useExisting: CustomValidatorDirective, multi: true}]\n * })\n * class CustomValidatorDirective implements Validator {\n *   validate(control: AbstractControl): ValidationErrors|null {\n *     return {'custom': true};\n *   }\n * }\n * ```\n *\n * @publicApi\n */\nexport interface Validator {\n  /**\n   * @description\n   * Method that performs synchronous validation against the provided control.\n   *\n   * @param control The control to validate against.\n   *\n   * @returns A map of validation errors if validation fails,\n   * otherwise null.\n   */\n  validate(control: AbstractControl): ValidationErrors | null;\n\n  /**\n   * @description\n   * Registers a callback function to call when the validator inputs change.\n   *\n   * @param fn The callback function\n   */\n  registerOnValidatorChange?(fn: () => void): void;\n}\n\n/**\n * A base class for Validator-based Directives. The class contains common logic shared across such\n * Directives.\n *\n * For internal use only, this class is not intended for use outside of the Forms package.\n */\n@Directive()\nabstract class AbstractValidatorDirective implements Validator, OnChanges {\n  private _validator: ValidatorFn = nullValidator;\n  private _onChange!: () => void;\n\n  /**\n   * A flag that tracks whether this validator is enabled.\n   *\n   * Marking it `internal` (vs `protected`), so that this flag can be used in host bindings of\n   * directive classes that extend this base class.\n   * @internal\n   */\n  _enabled?: boolean;\n\n  /**\n   * Name of an input that matches directive selector attribute (e.g. `minlength` for\n   * `MinLengthDirective`). An input with a given name might contain configuration information (like\n   * `minlength='10'`) or a flag that indicates whether validator should be enabled (like\n   * `[required]='false'`).\n   *\n   * @internal\n   */\n  abstract inputName: string;\n\n  /**\n   * Creates an instance of a validator (specific to a directive that extends this base class).\n   *\n   * @internal\n   */\n  abstract createValidator(input: unknown): ValidatorFn;\n\n  /**\n   * Performs the necessary input normalization based on a specific logic of a Directive.\n   * For example, the function might be used to convert string-based representation of the\n   * `minlength` input to an integer value that can later be used in the `Validators.minLength`\n   * validator.\n   *\n   * @internal\n   */\n  abstract normalizeInput(input: unknown): unknown;\n\n  /** @nodoc */\n  ngOnChanges(changes: SimpleChanges): void {\n    if (this.inputName in changes) {\n      const input = this.normalizeInput(changes[this.inputName].currentValue);\n      this._enabled = this.enabled(input);\n      this._validator = this._enabled ? this.createValidator(input) : nullValidator;\n      if (this._onChange) {\n        this._onChange();\n      }\n    }\n  }\n\n  /** @nodoc */\n  validate(control: AbstractControl): ValidationErrors | null {\n    return this._validator(control);\n  }\n\n  /** @nodoc */\n  registerOnValidatorChange(fn: () => void): void {\n    this._onChange = fn;\n  }\n\n  /**\n   * @description\n   * Determines whether this validator should be active or not based on an input.\n   * Base class implementation checks whether an input is defined (if the value is different from\n   * `null` and `undefined`). Validator classes that extend this base class can override this\n   * function with the logic specific to a particular validator directive.\n   */\n  enabled(input: unknown): boolean {\n    return input != null /* both `null` and `undefined` */;\n  }\n}\n\n/**\n * @description\n * Provider which adds `MaxValidator` to the `NG_VALIDATORS` multi-provider list.\n */\nexport const MAX_VALIDATOR: Provider = {\n  provide: NG_VALIDATORS,\n  useExisting: forwardRef(() => MaxValidator),\n  multi: true,\n};\n\n/**\n * A directive which installs the {@link MaxValidator} for any `formControlName`,\n * `formControl`, or control with `ngModel` that also has a `max` attribute.\n *\n * @see [Form Validation](guide/forms/form-validation)\n *\n * @usageNotes\n *\n * ### Adding a max validator\n *\n * The following example shows how to add a max validator to an input attached to an\n * ngModel binding.\n *\n * ```html\n * <input type=\"number\" ngModel max=\"4\">\n * ```\n *\n * @ngModule ReactiveFormsModule\n * @ngModule FormsModule\n * @publicApi\n */\n@Directive({\n  selector:\n    'input[type=number][max][formControlName],input[type=number][max][formControl],input[type=number][max][ngModel]',\n  providers: [MAX_VALIDATOR],\n  host: {'[attr.max]': '_enabled ? max : null'},\n})\nexport class MaxValidator extends AbstractValidatorDirective {\n  /**\n   * @description\n   * Tracks changes to the max bound to this directive.\n   */\n  @Input() max!: string | number | null;\n  /** @internal */\n  override inputName = 'max';\n  /** @internal */\n  override normalizeInput = (input: string | number): number => toFloat(input);\n  /** @internal */\n  override createValidator = (max: number): ValidatorFn => maxValidator(max);\n}\n\n/**\n * @description\n * Provider which adds `MinValidator` to the `NG_VALIDATORS` multi-provider list.\n */\nexport const MIN_VALIDATOR: Provider = {\n  provide: NG_VALIDATORS,\n  useExisting: forwardRef(() => MinValidator),\n  multi: true,\n};\n\n/**\n * A directive which installs the {@link MinValidator} for any `formControlName`,\n * `formControl`, or control with `ngModel` that also has a `min` attribute.\n *\n * @see [Form Validation](guide/forms/form-validation)\n *\n * @usageNotes\n *\n * ### Adding a min validator\n *\n * The following example shows how to add a min validator to an input attached to an\n * ngModel binding.\n *\n * ```html\n * <input type=\"number\" ngModel min=\"4\">\n * ```\n *\n * @ngModule ReactiveFormsModule\n * @ngModule FormsModule\n * @publicApi\n */\n@Directive({\n  selector:\n    'input[type=number][min][formControlName],input[type=number][min][formControl],input[type=number][min][ngModel]',\n  providers: [MIN_VALIDATOR],\n  host: {'[attr.min]': '_enabled ? min : null'},\n})\nexport class MinValidator extends AbstractValidatorDirective {\n  /**\n   * @description\n   * Tracks changes to the min bound to this directive.\n   */\n  @Input() min!: string | number | null;\n  /** @internal */\n  override inputName = 'min';\n  /** @internal */\n  override normalizeInput = (input: string | number): number => toFloat(input);\n  /** @internal */\n  override createValidator = (min: number): ValidatorFn => minValidator(min);\n}\n\n/**\n * @description\n * An interface implemented by classes that perform asynchronous validation.\n *\n * @usageNotes\n *\n * ### Provide a custom async validator directive\n *\n * The following example implements the `AsyncValidator` interface to create an\n * async validator directive with a custom error key.\n *\n * ```typescript\n * import { of } from 'rxjs';\n *\n * @Directive({\n *   selector: '[customAsyncValidator]',\n *   providers: [{provide: NG_ASYNC_VALIDATORS, useExisting: CustomAsyncValidatorDirective, multi:\n * true}]\n * })\n * class CustomAsyncValidatorDirective implements AsyncValidator {\n *   validate(control: AbstractControl): Observable<ValidationErrors|null> {\n *     return of({'custom': true});\n *   }\n * }\n * ```\n *\n * @publicApi\n */\nexport interface AsyncValidator extends Validator {\n  /**\n   * @description\n   * Method that performs async validation against the provided control.\n   *\n   * @param control The control to validate against.\n   *\n   * @returns A promise or observable that resolves a map of validation errors\n   * if validation fails, otherwise null.\n   */\n  validate(\n    control: AbstractControl,\n  ): Promise<ValidationErrors | null> | Observable<ValidationErrors | null>;\n}\n\n/**\n * @description\n * Provider which adds `RequiredValidator` to the `NG_VALIDATORS` multi-provider list.\n */\nexport const REQUIRED_VALIDATOR: Provider = {\n  provide: NG_VALIDATORS,\n  useExisting: forwardRef(() => RequiredValidator),\n  multi: true,\n};\n\n/**\n * @description\n * Provider which adds `CheckboxRequiredValidator` to the `NG_VALIDATORS` multi-provider list.\n */\nexport const CHECKBOX_REQUIRED_VALIDATOR: Provider = {\n  provide: NG_VALIDATORS,\n  useExisting: forwardRef(() => CheckboxRequiredValidator),\n  multi: true,\n};\n\n/**\n * @description\n * A directive that adds the `required` validator to any controls marked with the\n * `required` attribute. The directive is provided with the `NG_VALIDATORS` multi-provider list.\n *\n * @see [Form Validation](guide/forms/form-validation)\n *\n * @usageNotes\n *\n * ### Adding a required validator using template-driven forms\n *\n * ```\n * <input name=\"fullName\" ngModel required>\n * ```\n *\n * @ngModule FormsModule\n * @ngModule ReactiveFormsModule\n * @publicApi\n */\n@Directive({\n  selector:\n    ':not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]',\n  providers: [REQUIRED_VALIDATOR],\n  host: {'[attr.required]': '_enabled ? \"\" : null'},\n})\nexport class RequiredValidator extends AbstractValidatorDirective {\n  /**\n   * @description\n   * Tracks changes to the required attribute bound to this directive.\n   */\n  @Input() required!: boolean | string;\n\n  /** @internal */\n  override inputName = 'required';\n\n  /** @internal */\n  override normalizeInput = booleanAttribute;\n\n  /** @internal */\n  override createValidator = (input: boolean): ValidatorFn => requiredValidator;\n\n  /** @nodoc */\n  override enabled(input: boolean): boolean {\n    return input;\n  }\n}\n\n/**\n * A Directive that adds the `required` validator to checkbox controls marked with the\n * `required` attribute. The directive is provided with the `NG_VALIDATORS` multi-provider list.\n *\n * @see [Form Validation](guide/forms/form-validation)\n *\n * @usageNotes\n *\n * ### Adding a required checkbox validator using template-driven forms\n *\n * The following example shows how to add a checkbox required validator to an input attached to an\n * ngModel binding.\n *\n * ```\n * <input type=\"checkbox\" name=\"active\" ngModel required>\n * ```\n *\n * @publicApi\n * @ngModule FormsModule\n * @ngModule ReactiveFormsModule\n */\n@Directive({\n  selector:\n    'input[type=checkbox][required][formControlName],input[type=checkbox][required][formControl],input[type=checkbox][required][ngModel]',\n  providers: [CHECKBOX_REQUIRED_VALIDATOR],\n  host: {'[attr.required]': '_enabled ? \"\" : null'},\n})\nexport class CheckboxRequiredValidator extends RequiredValidator {\n  /** @internal */\n  override createValidator = (input: unknown): ValidatorFn => requiredTrueValidator;\n}\n\n/**\n * @description\n * Provider which adds `EmailValidator` to the `NG_VALIDATORS` multi-provider list.\n */\nexport const EMAIL_VALIDATOR: any = {\n  provide: NG_VALIDATORS,\n  useExisting: forwardRef(() => EmailValidator),\n  multi: true,\n};\n\n/**\n * A directive that adds the `email` validator to controls marked with the\n * `email` attribute. The directive is provided with the `NG_VALIDATORS` multi-provider list.\n *\n * The email validation is based on the WHATWG HTML specification with some enhancements to\n * incorporate more RFC rules. More information can be found on the [Validators.email\n * page](api/forms/Validators#email).\n *\n * @see [Form Validation](guide/forms/form-validation)\n *\n * @usageNotes\n *\n * ### Adding an email validator\n *\n * The following example shows how to add an email validator to an input attached to an ngModel\n * binding.\n *\n * ```\n * <input type=\"email\" name=\"email\" ngModel email>\n * <input type=\"email\" name=\"email\" ngModel email=\"true\">\n * <input type=\"email\" name=\"email\" ngModel [email]=\"true\">\n * ```\n *\n * @publicApi\n * @ngModule FormsModule\n * @ngModule ReactiveFormsModule\n */\n@Directive({\n  selector: '[email][formControlName],[email][formControl],[email][ngModel]',\n  providers: [EMAIL_VALIDATOR],\n})\nexport class EmailValidator extends AbstractValidatorDirective {\n  /**\n   * @description\n   * Tracks changes to the email attribute bound to this directive.\n   */\n  @Input() email!: boolean | string;\n\n  /** @internal */\n  override inputName = 'email';\n\n  /** @internal */\n  override normalizeInput = booleanAttribute;\n\n  /** @internal */\n  override createValidator = (input: number): ValidatorFn => emailValidator;\n\n  /** @nodoc */\n  override enabled(input: boolean): boolean {\n    return input;\n  }\n}\n\n/**\n * @description\n * A function that receives a control and synchronously returns a map of\n * validation errors if present, otherwise null.\n *\n * @publicApi\n */\nexport interface ValidatorFn {\n  (control: AbstractControl): ValidationErrors | null;\n}\n\n/**\n * @description\n * A function that receives a control and returns a Promise or observable\n * that emits validation errors if present, otherwise null.\n *\n * @publicApi\n */\nexport interface AsyncValidatorFn {\n  (\n    control: AbstractControl,\n  ): Promise<ValidationErrors | null> | Observable<ValidationErrors | null>;\n}\n\n/**\n * @description\n * Provider which adds `MinLengthValidator` to the `NG_VALIDATORS` multi-provider list.\n */\nexport const MIN_LENGTH_VALIDATOR: any = {\n  provide: NG_VALIDATORS,\n  useExisting: forwardRef(() => MinLengthValidator),\n  multi: true,\n};\n\n/**\n * A directive that adds minimum length validation to controls marked with the\n * `minlength` attribute. The directive is provided with the `NG_VALIDATORS` multi-provider list.\n *\n * @see [Form Validation](guide/forms/form-validation)\n *\n * @usageNotes\n *\n * ### Adding a minimum length validator\n *\n * The following example shows how to add a minimum length validator to an input attached to an\n * ngModel binding.\n *\n * ```html\n * <input name=\"firstName\" ngModel minlength=\"4\">\n * ```\n *\n * @ngModule ReactiveFormsModule\n * @ngModule FormsModule\n * @publicApi\n */\n@Directive({\n  selector: '[minlength][formControlName],[minlength][formControl],[minlength][ngModel]',\n  providers: [MIN_LENGTH_VALIDATOR],\n  host: {'[attr.minlength]': '_enabled ? minlength : null'},\n})\nexport class MinLengthValidator extends AbstractValidatorDirective {\n  /**\n   * @description\n   * Tracks changes to the minimum length bound to this directive.\n   */\n  @Input() minlength!: string | number | null;\n\n  /** @internal */\n  override inputName = 'minlength';\n\n  /** @internal */\n  override normalizeInput = (input: string | number): number => toInteger(input);\n\n  /** @internal */\n  override createValidator = (minlength: number): ValidatorFn => minLengthValidator(minlength);\n}\n\n/**\n * @description\n * Provider which adds `MaxLengthValidator` to the `NG_VALIDATORS` multi-provider list.\n */\nexport const MAX_LENGTH_VALIDATOR: any = {\n  provide: NG_VALIDATORS,\n  useExisting: forwardRef(() => MaxLengthValidator),\n  multi: true,\n};\n\n/**\n * A directive that adds maximum length validation to controls marked with the\n * `maxlength` attribute. The directive is provided with the `NG_VALIDATORS` multi-provider list.\n *\n * @see [Form Validation](guide/forms/form-validation)\n *\n * @usageNotes\n *\n * ### Adding a maximum length validator\n *\n * The following example shows how to add a maximum length validator to an input attached to an\n * ngModel binding.\n *\n * ```html\n * <input name=\"firstName\" ngModel maxlength=\"25\">\n * ```\n *\n * @ngModule ReactiveFormsModule\n * @ngModule FormsModule\n * @publicApi\n */\n@Directive({\n  selector: '[maxlength][formControlName],[maxlength][formControl],[maxlength][ngModel]',\n  providers: [MAX_LENGTH_VALIDATOR],\n  host: {'[attr.maxlength]': '_enabled ? maxlength : null'},\n})\nexport class MaxLengthValidator extends AbstractValidatorDirective {\n  /**\n   * @description\n   * Tracks changes to the maximum length bound to this directive.\n   */\n  @Input() maxlength!: string | number | null;\n\n  /** @internal */\n  override inputName = 'maxlength';\n\n  /** @internal */\n  override normalizeInput = (input: string | number): number => toInteger(input);\n\n  /** @internal */\n  override createValidator = (maxlength: number): ValidatorFn => maxLengthValidator(maxlength);\n}\n\n/**\n * @description\n * Provider which adds `PatternValidator` to the `NG_VALIDATORS` multi-provider list.\n */\nexport const PATTERN_VALIDATOR: any = {\n  provide: NG_VALIDATORS,\n  useExisting: forwardRef(() => PatternValidator),\n  multi: true,\n};\n\n/**\n * @description\n * A directive that adds regex pattern validation to controls marked with the\n * `pattern` attribute. The regex must match the entire control value.\n * The directive is provided with the `NG_VALIDATORS` multi-provider list.\n *\n * @see [Form Validation](guide/forms/form-validation)\n *\n * @usageNotes\n *\n * ### Adding a pattern validator\n *\n * The following example shows how to add a pattern validator to an input attached to an\n * ngModel binding.\n *\n * ```html\n * <input name=\"firstName\" ngModel pattern=\"[a-zA-Z ]*\">\n * ```\n *\n * @ngModule ReactiveFormsModule\n * @ngModule FormsModule\n * @publicApi\n */\n@Directive({\n  selector: '[pattern][formControlName],[pattern][formControl],[pattern][ngModel]',\n  providers: [PATTERN_VALIDATOR],\n  host: {'[attr.pattern]': '_enabled ? pattern : null'},\n})\nexport class PatternValidator extends AbstractValidatorDirective {\n  /**\n   * @description\n   * Tracks changes to the pattern bound to this directive.\n   */\n  @Input()\n  pattern!: string | RegExp; // This input is always defined, since the name matches selector.\n\n  /** @internal */\n  override inputName = 'pattern';\n\n  /** @internal */\n  override normalizeInput = (input: string | RegExp): string | RegExp => input;\n\n  /** @internal */\n  override createValidator = (input: string | RegExp): ValidatorFn => patternValidator(input);\n}\n"]}
|