@angular/forms 19.0.0-next.1 → 19.0.0-next.10

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.
Files changed (47) hide show
  1. package/LICENSE +21 -0
  2. package/fesm2022/forms.mjs +186 -132
  3. package/fesm2022/forms.mjs.map +1 -1
  4. package/index.d.ts +6 -5
  5. package/package.json +4 -6
  6. package/esm2022/forms.mjs +0 -5
  7. package/esm2022/index.mjs +0 -13
  8. package/esm2022/public_api.mjs +0 -15
  9. package/esm2022/src/directives/abstract_control_directive.mjs +0 -279
  10. package/esm2022/src/directives/abstract_form_group_directive.mjs +0 -61
  11. package/esm2022/src/directives/checkbox_value_accessor.mjs +0 -58
  12. package/esm2022/src/directives/control_container.mjs +0 -32
  13. package/esm2022/src/directives/control_value_accessor.mjs +0 -92
  14. package/esm2022/src/directives/default_value_accessor.mjs +0 -124
  15. package/esm2022/src/directives/error_examples.mjs +0 -57
  16. package/esm2022/src/directives/form_interface.mjs +0 -9
  17. package/esm2022/src/directives/ng_control.mjs +0 -38
  18. package/esm2022/src/directives/ng_control_status.mjs +0 -139
  19. package/esm2022/src/directives/ng_form.mjs +0 -313
  20. package/esm2022/src/directives/ng_model.mjs +0 -331
  21. package/esm2022/src/directives/ng_model_group.mjs +0 -95
  22. package/esm2022/src/directives/ng_no_validate_directive.mjs +0 -39
  23. package/esm2022/src/directives/number_value_accessor.mjs +0 -70
  24. package/esm2022/src/directives/radio_control_value_accessor.mjs +0 -201
  25. package/esm2022/src/directives/range_value_accessor.mjs +0 -72
  26. package/esm2022/src/directives/reactive_directives/form_control_directive.mjs +0 -183
  27. package/esm2022/src/directives/reactive_directives/form_control_name.mjs +0 -216
  28. package/esm2022/src/directives/reactive_directives/form_group_directive.mjs +0 -359
  29. package/esm2022/src/directives/reactive_directives/form_group_name.mjs +0 -246
  30. package/esm2022/src/directives/reactive_errors.mjs +0 -119
  31. package/esm2022/src/directives/select_control_value_accessor.mjs +0 -220
  32. package/esm2022/src/directives/select_multiple_control_value_accessor.mjs +0 -252
  33. package/esm2022/src/directives/shared.mjs +0 -350
  34. package/esm2022/src/directives/template_driven_errors.mjs +0 -54
  35. package/esm2022/src/directives/validators.mjs +0 -505
  36. package/esm2022/src/directives.mjs +0 -128
  37. package/esm2022/src/errors.mjs +0 -9
  38. package/esm2022/src/form_builder.mjs +0 -258
  39. package/esm2022/src/form_providers.mjs +0 -105
  40. package/esm2022/src/forms.mjs +0 -49
  41. package/esm2022/src/model/abstract_model.mjs +0 -992
  42. package/esm2022/src/model/form_array.mjs +0 -461
  43. package/esm2022/src/model/form_control.mjs +0 -126
  44. package/esm2022/src/model/form_group.mjs +0 -490
  45. package/esm2022/src/util.mjs +0 -13
  46. package/esm2022/src/validators.mjs +0 -680
  47. 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"]}