@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.
- package/{esm2020 → esm2022}/src/directives/abstract_form_group_directive.mjs +4 -4
- package/{esm2020 → esm2022}/src/directives/checkbox_value_accessor.mjs +4 -4
- package/{esm2020 → esm2022}/src/directives/control_value_accessor.mjs +7 -7
- package/{esm2020 → esm2022}/src/directives/default_value_accessor.mjs +4 -4
- package/{esm2020 → esm2022}/src/directives/ng_control_status.mjs +7 -7
- package/{esm2020 → esm2022}/src/directives/ng_form.mjs +4 -4
- package/esm2022/src/directives/ng_model.mjs +332 -0
- package/esm2022/src/directives/ng_model_group.mjs +95 -0
- package/{esm2020 → esm2022}/src/directives/ng_no_validate_directive.mjs +4 -4
- package/{esm2020 → esm2022}/src/directives/number_value_accessor.mjs +4 -4
- package/{esm2020 → esm2022}/src/directives/radio_control_value_accessor.mjs +11 -11
- package/{esm2020 → esm2022}/src/directives/range_value_accessor.mjs +4 -4
- package/esm2022/src/directives/reactive_directives/form_control_directive.mjs +185 -0
- package/esm2022/src/directives/reactive_directives/form_control_name.mjs +219 -0
- package/{esm2020 → esm2022}/src/directives/reactive_directives/form_group_directive.mjs +4 -4
- package/esm2022/src/directives/reactive_directives/form_group_name.mjs +247 -0
- package/{esm2020 → esm2022}/src/directives/select_control_value_accessor.mjs +7 -7
- package/{esm2020 → esm2022}/src/directives/select_multiple_control_value_accessor.mjs +7 -7
- package/{esm2020 → esm2022}/src/directives/validators.mjs +28 -28
- package/{esm2020 → esm2022}/src/directives.mjs +43 -43
- package/{esm2020 → esm2022}/src/form_builder.mjs +10 -10
- package/{esm2020 → esm2022}/src/form_providers.mjs +9 -9
- package/esm2022/src/model/abstract_model.mjs +939 -0
- package/esm2022/src/validators.mjs +678 -0
- package/{esm2020 → esm2022}/src/version.mjs +1 -1
- package/{fesm2020 → fesm2022}/forms.mjs +228 -187
- package/fesm2022/forms.mjs.map +1 -0
- package/index.d.ts +1 -1
- package/package.json +8 -14
- package/esm2020/src/directives/ng_model.mjs +0 -326
- package/esm2020/src/directives/ng_model_group.mjs +0 -89
- package/esm2020/src/directives/reactive_directives/form_control_directive.mjs +0 -185
- package/esm2020/src/directives/reactive_directives/form_control_name.mjs +0 -209
- package/esm2020/src/directives/reactive_directives/form_group_name.mjs +0 -227
- package/esm2020/src/model/abstract_model.mjs +0 -939
- package/esm2020/src/validators.mjs +0 -679
- package/fesm2015/forms.mjs +0 -7272
- package/fesm2015/forms.mjs.map +0 -1
- package/fesm2020/forms.mjs.map +0 -1
- /package/{esm2020 → esm2022}/forms.mjs +0 -0
- /package/{esm2020 → esm2022}/index.mjs +0 -0
- /package/{esm2020 → esm2022}/public_api.mjs +0 -0
- /package/{esm2020 → esm2022}/src/directives/abstract_control_directive.mjs +0 -0
- /package/{esm2020 → esm2022}/src/directives/control_container.mjs +0 -0
- /package/{esm2020 → esm2022}/src/directives/error_examples.mjs +0 -0
- /package/{esm2020 → esm2022}/src/directives/form_interface.mjs +0 -0
- /package/{esm2020 → esm2022}/src/directives/ng_control.mjs +0 -0
- /package/{esm2020 → esm2022}/src/directives/reactive_errors.mjs +0 -0
- /package/{esm2020 → esm2022}/src/directives/shared.mjs +0 -0
- /package/{esm2020 → esm2022}/src/directives/template_driven_errors.mjs +0 -0
- /package/{esm2020 → esm2022}/src/errors.mjs +0 -0
- /package/{esm2020 → esm2022}/src/forms.mjs +0 -0
- /package/{esm2020 → esm2022}/src/model/form_array.mjs +0 -0
- /package/{esm2020 → esm2022}/src/model/form_control.mjs +0 -0
- /package/{esm2020 → esm2022}/src/model/form_group.mjs +0 -0
- /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"]}
|