@angular/forms 16.0.0-next.4 → 16.0.0-next.5

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 (56) hide show
  1. package/{esm2020 → esm2022}/src/directives/abstract_form_group_directive.mjs +4 -4
  2. package/{esm2020 → esm2022}/src/directives/checkbox_value_accessor.mjs +4 -4
  3. package/{esm2020 → esm2022}/src/directives/control_value_accessor.mjs +7 -7
  4. package/{esm2020 → esm2022}/src/directives/default_value_accessor.mjs +4 -4
  5. package/{esm2020 → esm2022}/src/directives/ng_control_status.mjs +7 -7
  6. package/{esm2020 → esm2022}/src/directives/ng_form.mjs +4 -4
  7. package/esm2022/src/directives/ng_model.mjs +332 -0
  8. package/esm2022/src/directives/ng_model_group.mjs +95 -0
  9. package/{esm2020 → esm2022}/src/directives/ng_no_validate_directive.mjs +4 -4
  10. package/{esm2020 → esm2022}/src/directives/number_value_accessor.mjs +4 -4
  11. package/{esm2020 → esm2022}/src/directives/radio_control_value_accessor.mjs +11 -11
  12. package/{esm2020 → esm2022}/src/directives/range_value_accessor.mjs +4 -4
  13. package/esm2022/src/directives/reactive_directives/form_control_directive.mjs +185 -0
  14. package/esm2022/src/directives/reactive_directives/form_control_name.mjs +219 -0
  15. package/{esm2020 → esm2022}/src/directives/reactive_directives/form_group_directive.mjs +4 -4
  16. package/esm2022/src/directives/reactive_directives/form_group_name.mjs +247 -0
  17. package/{esm2020 → esm2022}/src/directives/select_control_value_accessor.mjs +7 -7
  18. package/{esm2020 → esm2022}/src/directives/select_multiple_control_value_accessor.mjs +7 -7
  19. package/{esm2020 → esm2022}/src/directives/validators.mjs +28 -28
  20. package/{esm2020 → esm2022}/src/directives.mjs +43 -43
  21. package/{esm2020 → esm2022}/src/form_builder.mjs +10 -10
  22. package/{esm2020 → esm2022}/src/form_providers.mjs +9 -9
  23. package/esm2022/src/model/abstract_model.mjs +939 -0
  24. package/esm2022/src/validators.mjs +678 -0
  25. package/{esm2020 → esm2022}/src/version.mjs +1 -1
  26. package/{fesm2020 → fesm2022}/forms.mjs +228 -187
  27. package/fesm2022/forms.mjs.map +1 -0
  28. package/index.d.ts +1 -1
  29. package/package.json +8 -14
  30. package/esm2020/src/directives/ng_model.mjs +0 -326
  31. package/esm2020/src/directives/ng_model_group.mjs +0 -89
  32. package/esm2020/src/directives/reactive_directives/form_control_directive.mjs +0 -185
  33. package/esm2020/src/directives/reactive_directives/form_control_name.mjs +0 -209
  34. package/esm2020/src/directives/reactive_directives/form_group_name.mjs +0 -227
  35. package/esm2020/src/model/abstract_model.mjs +0 -939
  36. package/esm2020/src/validators.mjs +0 -679
  37. package/fesm2015/forms.mjs +0 -7272
  38. package/fesm2015/forms.mjs.map +0 -1
  39. package/fesm2020/forms.mjs.map +0 -1
  40. /package/{esm2020 → esm2022}/forms.mjs +0 -0
  41. /package/{esm2020 → esm2022}/index.mjs +0 -0
  42. /package/{esm2020 → esm2022}/public_api.mjs +0 -0
  43. /package/{esm2020 → esm2022}/src/directives/abstract_control_directive.mjs +0 -0
  44. /package/{esm2020 → esm2022}/src/directives/control_container.mjs +0 -0
  45. /package/{esm2020 → esm2022}/src/directives/error_examples.mjs +0 -0
  46. /package/{esm2020 → esm2022}/src/directives/form_interface.mjs +0 -0
  47. /package/{esm2020 → esm2022}/src/directives/ng_control.mjs +0 -0
  48. /package/{esm2020 → esm2022}/src/directives/reactive_errors.mjs +0 -0
  49. /package/{esm2020 → esm2022}/src/directives/shared.mjs +0 -0
  50. /package/{esm2020 → esm2022}/src/directives/template_driven_errors.mjs +0 -0
  51. /package/{esm2020 → esm2022}/src/errors.mjs +0 -0
  52. /package/{esm2020 → esm2022}/src/forms.mjs +0 -0
  53. /package/{esm2020 → esm2022}/src/model/form_array.mjs +0 -0
  54. /package/{esm2020 → esm2022}/src/model/form_control.mjs +0 -0
  55. /package/{esm2020 → esm2022}/src/model/form_group.mjs +0 -0
  56. /package/{esm2020 → esm2022}/src/util.mjs +0 -0
@@ -1,227 +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 { Directive, forwardRef, Host, Inject, Input, Optional, Self, SkipSelf } from '@angular/core';
9
- import { NG_ASYNC_VALIDATORS, NG_VALIDATORS } from '../../validators';
10
- import { AbstractFormGroupDirective } from '../abstract_form_group_directive';
11
- import { ControlContainer } from '../control_container';
12
- import { arrayParentException, groupParentException } from '../reactive_errors';
13
- import { controlPath } from '../shared';
14
- import { FormGroupDirective } from './form_group_directive';
15
- import * as i0 from "@angular/core";
16
- import * as i1 from "../control_container";
17
- const formGroupNameProvider = {
18
- provide: ControlContainer,
19
- useExisting: forwardRef(() => FormGroupName)
20
- };
21
- /**
22
- * @description
23
- *
24
- * Syncs a nested `FormGroup` or `FormRecord` to a DOM element.
25
- *
26
- * This directive can only be used with a parent `FormGroupDirective`.
27
- *
28
- * It accepts the string name of the nested `FormGroup` or `FormRecord` to link, and
29
- * looks for a `FormGroup` or `FormRecord` registered with that name in the parent
30
- * `FormGroup` instance you passed into `FormGroupDirective`.
31
- *
32
- * Use nested form groups to validate a sub-group of a
33
- * form separately from the rest or to group the values of certain
34
- * controls into their own nested object.
35
- *
36
- * @see [Reactive Forms Guide](guide/reactive-forms)
37
- *
38
- * @usageNotes
39
- *
40
- * ### Access the group by name
41
- *
42
- * The following example uses the `AbstractControl.get` method to access the
43
- * associated `FormGroup`
44
- *
45
- * ```ts
46
- * this.form.get('name');
47
- * ```
48
- *
49
- * ### Access individual controls in the group
50
- *
51
- * The following example uses the `AbstractControl.get` method to access
52
- * individual controls within the group using dot syntax.
53
- *
54
- * ```ts
55
- * this.form.get('name.first');
56
- * ```
57
- *
58
- * ### Register a nested `FormGroup`.
59
- *
60
- * The following example registers a nested *name* `FormGroup` within an existing `FormGroup`,
61
- * and provides methods to retrieve the nested `FormGroup` and individual controls.
62
- *
63
- * {@example forms/ts/nestedFormGroup/nested_form_group_example.ts region='Component'}
64
- *
65
- * @ngModule ReactiveFormsModule
66
- * @publicApi
67
- */
68
- class FormGroupName extends AbstractFormGroupDirective {
69
- constructor(parent, validators, asyncValidators) {
70
- super();
71
- this._parent = parent;
72
- this._setValidators(validators);
73
- this._setAsyncValidators(asyncValidators);
74
- }
75
- /** @internal */
76
- _checkParentType() {
77
- if (_hasInvalidParent(this._parent) && (typeof ngDevMode === 'undefined' || ngDevMode)) {
78
- throw groupParentException();
79
- }
80
- }
81
- }
82
- FormGroupName.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0-next.4", ngImport: i0, type: FormGroupName, deps: [{ token: i1.ControlContainer, host: true, optional: true, skipSelf: true }, { token: NG_VALIDATORS, optional: true, self: true }, { token: NG_ASYNC_VALIDATORS, optional: true, self: true }], target: i0.ɵɵFactoryTarget.Directive });
83
- FormGroupName.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.0.0-next.4", type: FormGroupName, selector: "[formGroupName]", inputs: { name: ["formGroupName", "name"] }, providers: [formGroupNameProvider], usesInheritance: true, ngImport: i0 });
84
- export { FormGroupName };
85
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0-next.4", ngImport: i0, type: FormGroupName, decorators: [{
86
- type: Directive,
87
- args: [{ selector: '[formGroupName]', providers: [formGroupNameProvider] }]
88
- }], ctorParameters: function () { return [{ type: i1.ControlContainer, decorators: [{
89
- type: Optional
90
- }, {
91
- type: Host
92
- }, {
93
- type: SkipSelf
94
- }] }, { type: undefined, decorators: [{
95
- type: Optional
96
- }, {
97
- type: Self
98
- }, {
99
- type: Inject,
100
- args: [NG_VALIDATORS]
101
- }] }, { type: undefined, decorators: [{
102
- type: Optional
103
- }, {
104
- type: Self
105
- }, {
106
- type: Inject,
107
- args: [NG_ASYNC_VALIDATORS]
108
- }] }]; }, propDecorators: { name: [{
109
- type: Input,
110
- args: ['formGroupName']
111
- }] } });
112
- export const formArrayNameProvider = {
113
- provide: ControlContainer,
114
- useExisting: forwardRef(() => FormArrayName)
115
- };
116
- /**
117
- * @description
118
- *
119
- * Syncs a nested `FormArray` to a DOM element.
120
- *
121
- * This directive is designed to be used with a parent `FormGroupDirective` (selector:
122
- * `[formGroup]`).
123
- *
124
- * It accepts the string name of the nested `FormArray` you want to link, and
125
- * will look for a `FormArray` registered with that name in the parent
126
- * `FormGroup` instance you passed into `FormGroupDirective`.
127
- *
128
- * @see [Reactive Forms Guide](guide/reactive-forms)
129
- * @see `AbstractControl`
130
- *
131
- * @usageNotes
132
- *
133
- * ### Example
134
- *
135
- * {@example forms/ts/nestedFormArray/nested_form_array_example.ts region='Component'}
136
- *
137
- * @ngModule ReactiveFormsModule
138
- * @publicApi
139
- */
140
- class FormArrayName extends ControlContainer {
141
- constructor(parent, validators, asyncValidators) {
142
- super();
143
- this._parent = parent;
144
- this._setValidators(validators);
145
- this._setAsyncValidators(asyncValidators);
146
- }
147
- /**
148
- * A lifecycle method called when the directive's inputs are initialized. For internal use only.
149
- * @throws If the directive does not have a valid parent.
150
- * @nodoc
151
- */
152
- ngOnInit() {
153
- this._checkParentType();
154
- this.formDirective.addFormArray(this);
155
- }
156
- /**
157
- * A lifecycle method called before the directive's instance is destroyed. For internal use only.
158
- * @nodoc
159
- */
160
- ngOnDestroy() {
161
- if (this.formDirective) {
162
- this.formDirective.removeFormArray(this);
163
- }
164
- }
165
- /**
166
- * @description
167
- * The `FormArray` bound to this directive.
168
- */
169
- get control() {
170
- return this.formDirective.getFormArray(this);
171
- }
172
- /**
173
- * @description
174
- * The top-level directive for this group if present, otherwise null.
175
- */
176
- get formDirective() {
177
- return this._parent ? this._parent.formDirective : null;
178
- }
179
- /**
180
- * @description
181
- * Returns an array that represents the path from the top-level form to this control.
182
- * Each index is the string name of the control on that level.
183
- */
184
- get path() {
185
- return controlPath(this.name == null ? this.name : this.name.toString(), this._parent);
186
- }
187
- _checkParentType() {
188
- if (_hasInvalidParent(this._parent) && (typeof ngDevMode === 'undefined' || ngDevMode)) {
189
- throw arrayParentException();
190
- }
191
- }
192
- }
193
- FormArrayName.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0-next.4", ngImport: i0, type: FormArrayName, deps: [{ token: i1.ControlContainer, host: true, optional: true, skipSelf: true }, { token: NG_VALIDATORS, optional: true, self: true }, { token: NG_ASYNC_VALIDATORS, optional: true, self: true }], target: i0.ɵɵFactoryTarget.Directive });
194
- FormArrayName.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.0.0-next.4", type: FormArrayName, selector: "[formArrayName]", inputs: { name: ["formArrayName", "name"] }, providers: [formArrayNameProvider], usesInheritance: true, ngImport: i0 });
195
- export { FormArrayName };
196
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0-next.4", ngImport: i0, type: FormArrayName, decorators: [{
197
- type: Directive,
198
- args: [{ selector: '[formArrayName]', providers: [formArrayNameProvider] }]
199
- }], ctorParameters: function () { return [{ type: i1.ControlContainer, decorators: [{
200
- type: Optional
201
- }, {
202
- type: Host
203
- }, {
204
- type: SkipSelf
205
- }] }, { type: undefined, decorators: [{
206
- type: Optional
207
- }, {
208
- type: Self
209
- }, {
210
- type: Inject,
211
- args: [NG_VALIDATORS]
212
- }] }, { type: undefined, decorators: [{
213
- type: Optional
214
- }, {
215
- type: Self
216
- }, {
217
- type: Inject,
218
- args: [NG_ASYNC_VALIDATORS]
219
- }] }]; }, propDecorators: { name: [{
220
- type: Input,
221
- args: ['formArrayName']
222
- }] } });
223
- function _hasInvalidParent(parent) {
224
- return !(parent instanceof FormGroupName) && !(parent instanceof FormGroupDirective) &&
225
- !(parent instanceof FormArrayName);
226
- }
227
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form_group_name.js","sourceRoot":"","sources":["../../../../../../../../packages/forms/src/directives/reactive_directives/form_group_name.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 {Directive, forwardRef, Host, Inject, Input, OnDestroy, OnInit, Optional, Provider, Self, SkipSelf} from '@angular/core';\n\nimport {FormArray} from '../../model/form_array';\nimport {NG_ASYNC_VALIDATORS, NG_VALIDATORS} from '../../validators';\nimport {AbstractFormGroupDirective} from '../abstract_form_group_directive';\nimport {ControlContainer} from '../control_container';\nimport {arrayParentException, groupParentException} from '../reactive_errors';\nimport {controlPath} from '../shared';\nimport {AsyncValidator, AsyncValidatorFn, Validator, ValidatorFn} from '../validators';\n\nimport {FormGroupDirective} from './form_group_directive';\n\nconst formGroupNameProvider: Provider = {\n  provide: ControlContainer,\n  useExisting: forwardRef(() => FormGroupName)\n};\n\n/**\n * @description\n *\n * Syncs a nested `FormGroup` or `FormRecord` to a DOM element.\n *\n * This directive can only be used with a parent `FormGroupDirective`.\n *\n * It accepts the string name of the nested `FormGroup` or `FormRecord` to link, and\n * looks for a `FormGroup` or `FormRecord` registered with that name in the parent\n * `FormGroup` instance you passed into `FormGroupDirective`.\n *\n * Use nested form groups to validate a sub-group of a\n * form separately from the rest or to group the values of certain\n * controls into their own nested object.\n *\n * @see [Reactive Forms Guide](guide/reactive-forms)\n *\n * @usageNotes\n *\n * ### Access the group by name\n *\n * The following example uses the `AbstractControl.get` method to access the\n * associated `FormGroup`\n *\n * ```ts\n *   this.form.get('name');\n * ```\n *\n * ### Access individual controls in the group\n *\n * The following example uses the `AbstractControl.get` method to access\n * individual controls within the group using dot syntax.\n *\n * ```ts\n *   this.form.get('name.first');\n * ```\n *\n * ### Register a nested `FormGroup`.\n *\n * The following example registers a nested *name* `FormGroup` within an existing `FormGroup`,\n * and provides methods to retrieve the nested `FormGroup` and individual controls.\n *\n * {@example forms/ts/nestedFormGroup/nested_form_group_example.ts region='Component'}\n *\n * @ngModule ReactiveFormsModule\n * @publicApi\n */\n@Directive({selector: '[formGroupName]', providers: [formGroupNameProvider]})\nexport class FormGroupName extends AbstractFormGroupDirective implements OnInit, OnDestroy {\n  /**\n   * @description\n   * Tracks the name of the `FormGroup` bound to the directive. The name corresponds\n   * to a key in the parent `FormGroup` or `FormArray`.\n   * Accepts a name as a string or a number.\n   * The name in the form of a string is useful for individual forms,\n   * while the numerical form allows for form groups to be bound\n   * to indices when iterating over groups in a `FormArray`.\n   */\n  // TODO(issue/24571): remove '!'.\n  @Input('formGroupName') override name!: string|number|null;\n\n  constructor(\n      @Optional() @Host() @SkipSelf() parent: ControlContainer,\n      @Optional() @Self() @Inject(NG_VALIDATORS) validators: (Validator|ValidatorFn)[],\n      @Optional() @Self() @Inject(NG_ASYNC_VALIDATORS) asyncValidators:\n          (AsyncValidator|AsyncValidatorFn)[]) {\n    super();\n    this._parent = parent;\n    this._setValidators(validators);\n    this._setAsyncValidators(asyncValidators);\n  }\n\n  /** @internal */\n  override _checkParentType(): void {\n    if (_hasInvalidParent(this._parent) && (typeof ngDevMode === 'undefined' || ngDevMode)) {\n      throw groupParentException();\n    }\n  }\n}\n\nexport const formArrayNameProvider: any = {\n  provide: ControlContainer,\n  useExisting: forwardRef(() => FormArrayName)\n};\n\n/**\n * @description\n *\n * Syncs a nested `FormArray` to a DOM element.\n *\n * This directive is designed to be used with a parent `FormGroupDirective` (selector:\n * `[formGroup]`).\n *\n * It accepts the string name of the nested `FormArray` you want to link, and\n * will look for a `FormArray` registered with that name in the parent\n * `FormGroup` instance you passed into `FormGroupDirective`.\n *\n * @see [Reactive Forms Guide](guide/reactive-forms)\n * @see `AbstractControl`\n *\n * @usageNotes\n *\n * ### Example\n *\n * {@example forms/ts/nestedFormArray/nested_form_array_example.ts region='Component'}\n *\n * @ngModule ReactiveFormsModule\n * @publicApi\n */\n@Directive({selector: '[formArrayName]', providers: [formArrayNameProvider]})\nexport class FormArrayName extends ControlContainer implements OnInit, OnDestroy {\n  /** @internal */\n  _parent: ControlContainer;\n\n  /**\n   * @description\n   * Tracks the name of the `FormArray` bound to the directive. The name corresponds\n   * to a key in the parent `FormGroup` or `FormArray`.\n   * Accepts a name as a string or a number.\n   * The name in the form of a string is useful for individual forms,\n   * while the numerical form allows for form arrays to be bound\n   * to indices when iterating over arrays in a `FormArray`.\n   */\n  // TODO(issue/24571): remove '!'.\n  @Input('formArrayName') override name!: string|number|null;\n\n  constructor(\n      @Optional() @Host() @SkipSelf() parent: ControlContainer,\n      @Optional() @Self() @Inject(NG_VALIDATORS) validators: (Validator|ValidatorFn)[],\n      @Optional() @Self() @Inject(NG_ASYNC_VALIDATORS) asyncValidators:\n          (AsyncValidator|AsyncValidatorFn)[]) {\n    super();\n    this._parent = parent;\n    this._setValidators(validators);\n    this._setAsyncValidators(asyncValidators);\n  }\n\n  /**\n   * A lifecycle method called when the directive's inputs are initialized. For internal use only.\n   * @throws If the directive does not have a valid parent.\n   * @nodoc\n   */\n  ngOnInit(): void {\n    this._checkParentType();\n    this.formDirective!.addFormArray(this);\n  }\n\n  /**\n   * A lifecycle method called before the directive's instance is destroyed. For internal use only.\n   * @nodoc\n   */\n  ngOnDestroy(): void {\n    if (this.formDirective) {\n      this.formDirective.removeFormArray(this);\n    }\n  }\n\n  /**\n   * @description\n   * The `FormArray` bound to this directive.\n   */\n  override get control(): FormArray {\n    return this.formDirective!.getFormArray(this);\n  }\n\n  /**\n   * @description\n   * The top-level directive for this group if present, otherwise null.\n   */\n  override get formDirective(): FormGroupDirective|null {\n    return this._parent ? <FormGroupDirective>this._parent.formDirective : null;\n  }\n\n  /**\n   * @description\n   * Returns an array that represents the path from the top-level form to this control.\n   * Each index is the string name of the control on that level.\n   */\n  override get path(): string[] {\n    return controlPath(this.name == null ? this.name : this.name.toString(), this._parent);\n  }\n\n  private _checkParentType(): void {\n    if (_hasInvalidParent(this._parent) && (typeof ngDevMode === 'undefined' || ngDevMode)) {\n      throw arrayParentException();\n    }\n  }\n}\n\nfunction _hasInvalidParent(parent: ControlContainer): boolean {\n  return !(parent instanceof FormGroupName) && !(parent instanceof FormGroupDirective) &&\n      !(parent instanceof FormArrayName);\n}\n"]}