@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.
- 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,216 +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, EventEmitter, forwardRef, Host, Inject, Input, Optional, Output, 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 { NG_VALUE_ACCESSOR } from '../control_value_accessor';
|
|
13
|
-
import { NgControl } from '../ng_control';
|
|
14
|
-
import { controlParentException, disabledAttrWarning, ngModelGroupException, } from '../reactive_errors';
|
|
15
|
-
import { _ngModelWarning, controlPath, isPropertyUpdated, selectValueAccessor } from '../shared';
|
|
16
|
-
import { NG_MODEL_WITH_FORM_CONTROL_WARNING } from './form_control_directive';
|
|
17
|
-
import { FormGroupDirective } from './form_group_directive';
|
|
18
|
-
import { FormArrayName, FormGroupName } from './form_group_name';
|
|
19
|
-
import * as i0 from "@angular/core";
|
|
20
|
-
import * as i1 from "../control_container";
|
|
21
|
-
const controlNameBinding = {
|
|
22
|
-
provide: NgControl,
|
|
23
|
-
useExisting: forwardRef(() => FormControlName),
|
|
24
|
-
};
|
|
25
|
-
/**
|
|
26
|
-
* @description
|
|
27
|
-
* Syncs a `FormControl` in an existing `FormGroup` to a form control
|
|
28
|
-
* element by name.
|
|
29
|
-
*
|
|
30
|
-
* @see [Reactive Forms Guide](guide/forms/reactive-forms)
|
|
31
|
-
* @see {@link FormControl}
|
|
32
|
-
* @see {@link AbstractControl}
|
|
33
|
-
*
|
|
34
|
-
* @usageNotes
|
|
35
|
-
*
|
|
36
|
-
* ### Register `FormControl` within a group
|
|
37
|
-
*
|
|
38
|
-
* The following example shows how to register multiple form controls within a form group
|
|
39
|
-
* and set their value.
|
|
40
|
-
*
|
|
41
|
-
* {@example forms/ts/simpleFormGroup/simple_form_group_example.ts region='Component'}
|
|
42
|
-
*
|
|
43
|
-
* To see `formControlName` examples with different form control types, see:
|
|
44
|
-
*
|
|
45
|
-
* * Radio buttons: `RadioControlValueAccessor`
|
|
46
|
-
* * Selects: `SelectControlValueAccessor`
|
|
47
|
-
*
|
|
48
|
-
* ### Use with ngModel is deprecated
|
|
49
|
-
*
|
|
50
|
-
* Support for using the `ngModel` input property and `ngModelChange` event with reactive
|
|
51
|
-
* form directives has been deprecated in Angular v6 and is scheduled for removal in
|
|
52
|
-
* a future version of Angular.
|
|
53
|
-
*
|
|
54
|
-
* @ngModule ReactiveFormsModule
|
|
55
|
-
* @publicApi
|
|
56
|
-
*/
|
|
57
|
-
export class FormControlName extends NgControl {
|
|
58
|
-
/**
|
|
59
|
-
* @description
|
|
60
|
-
* Triggers a warning in dev mode that this input should not be used with reactive forms.
|
|
61
|
-
*/
|
|
62
|
-
set isDisabled(isDisabled) {
|
|
63
|
-
if (typeof ngDevMode === 'undefined' || ngDevMode) {
|
|
64
|
-
console.warn(disabledAttrWarning);
|
|
65
|
-
}
|
|
66
|
-
}
|
|
67
|
-
/**
|
|
68
|
-
* @description
|
|
69
|
-
* Static property used to track whether any ngModel warnings have been sent across
|
|
70
|
-
* all instances of FormControlName. Used to support warning config of "once".
|
|
71
|
-
*
|
|
72
|
-
* @internal
|
|
73
|
-
*/
|
|
74
|
-
static { this._ngModelWarningSentOnce = false; }
|
|
75
|
-
constructor(parent, validators, asyncValidators, valueAccessors, _ngModelWarningConfig) {
|
|
76
|
-
super();
|
|
77
|
-
this._ngModelWarningConfig = _ngModelWarningConfig;
|
|
78
|
-
this._added = false;
|
|
79
|
-
/**
|
|
80
|
-
* @description
|
|
81
|
-
* Tracks the name of the `FormControl` bound to the directive. The name corresponds
|
|
82
|
-
* to a key in the parent `FormGroup` or `FormArray`.
|
|
83
|
-
* Accepts a name as a string or a number.
|
|
84
|
-
* The name in the form of a string is useful for individual forms,
|
|
85
|
-
* while the numerical form allows for form controls to be bound
|
|
86
|
-
* to indices when iterating over controls in a `FormArray`.
|
|
87
|
-
*/
|
|
88
|
-
this.name = null;
|
|
89
|
-
/** @deprecated as of v6 */
|
|
90
|
-
this.update = new EventEmitter();
|
|
91
|
-
/**
|
|
92
|
-
* @description
|
|
93
|
-
* Instance property used to track whether an ngModel warning has been sent out for this
|
|
94
|
-
* particular FormControlName instance. Used to support warning config of "always".
|
|
95
|
-
*
|
|
96
|
-
* @internal
|
|
97
|
-
*/
|
|
98
|
-
this._ngModelWarningSent = false;
|
|
99
|
-
this._parent = parent;
|
|
100
|
-
this._setValidators(validators);
|
|
101
|
-
this._setAsyncValidators(asyncValidators);
|
|
102
|
-
this.valueAccessor = selectValueAccessor(this, valueAccessors);
|
|
103
|
-
}
|
|
104
|
-
/** @nodoc */
|
|
105
|
-
ngOnChanges(changes) {
|
|
106
|
-
if (!this._added)
|
|
107
|
-
this._setUpControl();
|
|
108
|
-
if (isPropertyUpdated(changes, this.viewModel)) {
|
|
109
|
-
if (typeof ngDevMode === 'undefined' || ngDevMode) {
|
|
110
|
-
_ngModelWarning('formControlName', FormControlName, this, this._ngModelWarningConfig);
|
|
111
|
-
}
|
|
112
|
-
this.viewModel = this.model;
|
|
113
|
-
this.formDirective.updateModel(this, this.model);
|
|
114
|
-
}
|
|
115
|
-
}
|
|
116
|
-
/** @nodoc */
|
|
117
|
-
ngOnDestroy() {
|
|
118
|
-
if (this.formDirective) {
|
|
119
|
-
this.formDirective.removeControl(this);
|
|
120
|
-
}
|
|
121
|
-
}
|
|
122
|
-
/**
|
|
123
|
-
* @description
|
|
124
|
-
* Sets the new value for the view model and emits an `ngModelChange` event.
|
|
125
|
-
*
|
|
126
|
-
* @param newValue The new value for the view model.
|
|
127
|
-
*/
|
|
128
|
-
viewToModelUpdate(newValue) {
|
|
129
|
-
this.viewModel = newValue;
|
|
130
|
-
this.update.emit(newValue);
|
|
131
|
-
}
|
|
132
|
-
/**
|
|
133
|
-
* @description
|
|
134
|
-
* Returns an array that represents the path from the top-level form to this control.
|
|
135
|
-
* Each index is the string name of the control on that level.
|
|
136
|
-
*/
|
|
137
|
-
get path() {
|
|
138
|
-
return controlPath(this.name == null ? this.name : this.name.toString(), this._parent);
|
|
139
|
-
}
|
|
140
|
-
/**
|
|
141
|
-
* @description
|
|
142
|
-
* The top-level directive for this group if present, otherwise null.
|
|
143
|
-
*/
|
|
144
|
-
get formDirective() {
|
|
145
|
-
return this._parent ? this._parent.formDirective : null;
|
|
146
|
-
}
|
|
147
|
-
_checkParentType() {
|
|
148
|
-
if (typeof ngDevMode === 'undefined' || ngDevMode) {
|
|
149
|
-
if (!(this._parent instanceof FormGroupName) &&
|
|
150
|
-
this._parent instanceof AbstractFormGroupDirective) {
|
|
151
|
-
throw ngModelGroupException();
|
|
152
|
-
}
|
|
153
|
-
else if (!(this._parent instanceof FormGroupName) &&
|
|
154
|
-
!(this._parent instanceof FormGroupDirective) &&
|
|
155
|
-
!(this._parent instanceof FormArrayName)) {
|
|
156
|
-
throw controlParentException(this.name);
|
|
157
|
-
}
|
|
158
|
-
}
|
|
159
|
-
}
|
|
160
|
-
_setUpControl() {
|
|
161
|
-
this._checkParentType();
|
|
162
|
-
this.control = this.formDirective.addControl(this);
|
|
163
|
-
this._added = true;
|
|
164
|
-
}
|
|
165
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.0.0-next.1", ngImport: i0, type: FormControlName, 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 }, { token: NG_VALUE_ACCESSOR, optional: true, self: true }, { token: NG_MODEL_WITH_FORM_CONTROL_WARNING, optional: true }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
166
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "19.0.0-next.1", type: FormControlName, selector: "[formControlName]", inputs: { name: ["formControlName", "name"], isDisabled: ["disabled", "isDisabled"], model: ["ngModel", "model"] }, outputs: { update: "ngModelChange" }, providers: [controlNameBinding], usesInheritance: true, usesOnChanges: true, ngImport: i0 }); }
|
|
167
|
-
}
|
|
168
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.0.0-next.1", ngImport: i0, type: FormControlName, decorators: [{
|
|
169
|
-
type: Directive,
|
|
170
|
-
args: [{ selector: '[formControlName]', providers: [controlNameBinding] }]
|
|
171
|
-
}], ctorParameters: () => [{ type: i1.ControlContainer, decorators: [{
|
|
172
|
-
type: Optional
|
|
173
|
-
}, {
|
|
174
|
-
type: Host
|
|
175
|
-
}, {
|
|
176
|
-
type: SkipSelf
|
|
177
|
-
}] }, { type: undefined, decorators: [{
|
|
178
|
-
type: Optional
|
|
179
|
-
}, {
|
|
180
|
-
type: Self
|
|
181
|
-
}, {
|
|
182
|
-
type: Inject,
|
|
183
|
-
args: [NG_VALIDATORS]
|
|
184
|
-
}] }, { type: undefined, decorators: [{
|
|
185
|
-
type: Optional
|
|
186
|
-
}, {
|
|
187
|
-
type: Self
|
|
188
|
-
}, {
|
|
189
|
-
type: Inject,
|
|
190
|
-
args: [NG_ASYNC_VALIDATORS]
|
|
191
|
-
}] }, { type: undefined, decorators: [{
|
|
192
|
-
type: Optional
|
|
193
|
-
}, {
|
|
194
|
-
type: Self
|
|
195
|
-
}, {
|
|
196
|
-
type: Inject,
|
|
197
|
-
args: [NG_VALUE_ACCESSOR]
|
|
198
|
-
}] }, { type: undefined, decorators: [{
|
|
199
|
-
type: Optional
|
|
200
|
-
}, {
|
|
201
|
-
type: Inject,
|
|
202
|
-
args: [NG_MODEL_WITH_FORM_CONTROL_WARNING]
|
|
203
|
-
}] }], propDecorators: { name: [{
|
|
204
|
-
type: Input,
|
|
205
|
-
args: ['formControlName']
|
|
206
|
-
}], isDisabled: [{
|
|
207
|
-
type: Input,
|
|
208
|
-
args: ['disabled']
|
|
209
|
-
}], model: [{
|
|
210
|
-
type: Input,
|
|
211
|
-
args: ['ngModel']
|
|
212
|
-
}], update: [{
|
|
213
|
-
type: Output,
|
|
214
|
-
args: ['ngModelChange']
|
|
215
|
-
}] } });
|
|
216
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form_control_name.js","sourceRoot":"","sources":["../../../../../../../../packages/forms/src/directives/reactive_directives/form_control_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 {\n  Directive,\n  EventEmitter,\n  forwardRef,\n  Host,\n  Inject,\n  Input,\n  OnChanges,\n  OnDestroy,\n  Optional,\n  Output,\n  Provider,\n  Self,\n  SimpleChanges,\n  SkipSelf,\n  ɵWritable as Writable,\n} from '@angular/core';\n\nimport {FormControl} from '../../model/form_control';\nimport {NG_ASYNC_VALIDATORS, NG_VALIDATORS} from '../../validators';\nimport {AbstractFormGroupDirective} from '../abstract_form_group_directive';\nimport {ControlContainer} from '../control_container';\nimport {ControlValueAccessor, NG_VALUE_ACCESSOR} from '../control_value_accessor';\nimport {NgControl} from '../ng_control';\nimport {\n  controlParentException,\n  disabledAttrWarning,\n  ngModelGroupException,\n} from '../reactive_errors';\nimport {_ngModelWarning, controlPath, isPropertyUpdated, selectValueAccessor} from '../shared';\nimport {AsyncValidator, AsyncValidatorFn, Validator, ValidatorFn} from '../validators';\n\nimport {NG_MODEL_WITH_FORM_CONTROL_WARNING} from './form_control_directive';\nimport {FormGroupDirective} from './form_group_directive';\nimport {FormArrayName, FormGroupName} from './form_group_name';\n\nconst controlNameBinding: Provider = {\n  provide: NgControl,\n  useExisting: forwardRef(() => FormControlName),\n};\n\n/**\n * @description\n * Syncs a `FormControl` in an existing `FormGroup` to a form control\n * element by name.\n *\n * @see [Reactive Forms Guide](guide/forms/reactive-forms)\n * @see {@link FormControl}\n * @see {@link AbstractControl}\n *\n * @usageNotes\n *\n * ### Register `FormControl` within a group\n *\n * The following example shows how to register multiple form controls within a form group\n * and set their value.\n *\n * {@example forms/ts/simpleFormGroup/simple_form_group_example.ts region='Component'}\n *\n * To see `formControlName` examples with different form control types, see:\n *\n * * Radio buttons: `RadioControlValueAccessor`\n * * Selects: `SelectControlValueAccessor`\n *\n * ### Use with ngModel is deprecated\n *\n * Support for using the `ngModel` input property and `ngModelChange` event with reactive\n * form directives has been deprecated in Angular v6 and is scheduled for removal in\n * a future version of Angular.\n *\n * @ngModule ReactiveFormsModule\n * @publicApi\n */\n@Directive({selector: '[formControlName]', providers: [controlNameBinding]})\nexport class FormControlName extends NgControl implements OnChanges, OnDestroy {\n  private _added = false;\n  /**\n   * Internal reference to the view model value.\n   * @internal\n   */\n  viewModel: any;\n\n  /**\n   * @description\n   * Tracks the `FormControl` instance bound to the directive.\n   */\n  // TODO(issue/24571): remove '!'.\n  override readonly control!: FormControl;\n\n  /**\n   * @description\n   * Tracks the name of the `FormControl` 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 controls to be bound\n   * to indices when iterating over controls in a `FormArray`.\n   */\n  @Input('formControlName') override name: string | number | null = null;\n\n  /**\n   * @description\n   * Triggers a warning in dev mode that this input should not be used with reactive forms.\n   */\n  @Input('disabled')\n  set isDisabled(isDisabled: boolean) {\n    if (typeof ngDevMode === 'undefined' || ngDevMode) {\n      console.warn(disabledAttrWarning);\n    }\n  }\n\n  // TODO(kara): remove next 4 properties once deprecation period is over\n\n  /** @deprecated as of v6 */\n  @Input('ngModel') model: any;\n\n  /** @deprecated as of v6 */\n  @Output('ngModelChange') update = new EventEmitter();\n\n  /**\n   * @description\n   * Static property used to track whether any ngModel warnings have been sent across\n   * all instances of FormControlName. Used to support warning config of \"once\".\n   *\n   * @internal\n   */\n  static _ngModelWarningSentOnce = false;\n\n  /**\n   * @description\n   * Instance property used to track whether an ngModel warning has been sent out for this\n   * particular FormControlName instance. Used to support warning config of \"always\".\n   *\n   * @internal\n   */\n  _ngModelWarningSent = false;\n\n  constructor(\n    @Optional() @Host() @SkipSelf() parent: ControlContainer,\n    @Optional() @Self() @Inject(NG_VALIDATORS) validators: (Validator | ValidatorFn)[],\n    @Optional()\n    @Self()\n    @Inject(NG_ASYNC_VALIDATORS)\n    asyncValidators: (AsyncValidator | AsyncValidatorFn)[],\n    @Optional() @Self() @Inject(NG_VALUE_ACCESSOR) valueAccessors: ControlValueAccessor[],\n    @Optional()\n    @Inject(NG_MODEL_WITH_FORM_CONTROL_WARNING)\n    private _ngModelWarningConfig: string | null,\n  ) {\n    super();\n    this._parent = parent;\n    this._setValidators(validators);\n    this._setAsyncValidators(asyncValidators);\n    this.valueAccessor = selectValueAccessor(this, valueAccessors);\n  }\n\n  /** @nodoc */\n  ngOnChanges(changes: SimpleChanges) {\n    if (!this._added) this._setUpControl();\n    if (isPropertyUpdated(changes, this.viewModel)) {\n      if (typeof ngDevMode === 'undefined' || ngDevMode) {\n        _ngModelWarning('formControlName', FormControlName, this, this._ngModelWarningConfig);\n      }\n      this.viewModel = this.model;\n      this.formDirective.updateModel(this, this.model);\n    }\n  }\n\n  /** @nodoc */\n  ngOnDestroy(): void {\n    if (this.formDirective) {\n      this.formDirective.removeControl(this);\n    }\n  }\n\n  /**\n   * @description\n   * Sets the new value for the view model and emits an `ngModelChange` event.\n   *\n   * @param newValue The new value for the view model.\n   */\n  override viewToModelUpdate(newValue: any): void {\n    this.viewModel = newValue;\n    this.update.emit(newValue);\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  /**\n   * @description\n   * The top-level directive for this group if present, otherwise null.\n   */\n  get formDirective(): any {\n    return this._parent ? this._parent.formDirective : null;\n  }\n\n  private _checkParentType(): void {\n    if (typeof ngDevMode === 'undefined' || ngDevMode) {\n      if (\n        !(this._parent instanceof FormGroupName) &&\n        this._parent instanceof AbstractFormGroupDirective\n      ) {\n        throw ngModelGroupException();\n      } else if (\n        !(this._parent instanceof FormGroupName) &&\n        !(this._parent instanceof FormGroupDirective) &&\n        !(this._parent instanceof FormArrayName)\n      ) {\n        throw controlParentException(this.name);\n      }\n    }\n  }\n\n  private _setUpControl() {\n    this._checkParentType();\n    (this as Writable<this>).control = this.formDirective.addControl(this);\n    this._added = true;\n  }\n}\n"]}
|
|
@@ -1,359 +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 { computed, Directive, EventEmitter, forwardRef, Inject, Input, Optional, Output, Self, signal, untracked, } from '@angular/core';
|
|
9
|
-
import { isFormControl } from '../../model/form_control';
|
|
10
|
-
import { FormGroup } from '../../model/form_group';
|
|
11
|
-
import { NG_ASYNC_VALIDATORS, NG_VALIDATORS } from '../../validators';
|
|
12
|
-
import { ControlContainer } from '../control_container';
|
|
13
|
-
import { missingFormException } from '../reactive_errors';
|
|
14
|
-
import { CALL_SET_DISABLED_STATE, cleanUpControl, cleanUpFormContainer, cleanUpValidators, removeListItem, setUpControl, setUpFormContainer, setUpValidators, syncPendingControls, } from '../shared';
|
|
15
|
-
import { FormResetEvent, FormSubmittedEvent } from '../../model/abstract_model';
|
|
16
|
-
import * as i0 from "@angular/core";
|
|
17
|
-
const formDirectiveProvider = {
|
|
18
|
-
provide: ControlContainer,
|
|
19
|
-
useExisting: forwardRef(() => FormGroupDirective),
|
|
20
|
-
};
|
|
21
|
-
/**
|
|
22
|
-
* @description
|
|
23
|
-
*
|
|
24
|
-
* Binds an existing `FormGroup` or `FormRecord` to a DOM element.
|
|
25
|
-
*
|
|
26
|
-
* This directive accepts an existing `FormGroup` instance. It will then use this
|
|
27
|
-
* `FormGroup` instance to match any child `FormControl`, `FormGroup`/`FormRecord`,
|
|
28
|
-
* and `FormArray` instances to child `FormControlName`, `FormGroupName`,
|
|
29
|
-
* and `FormArrayName` directives.
|
|
30
|
-
*
|
|
31
|
-
* @see [Reactive Forms Guide](guide/forms/reactive-forms)
|
|
32
|
-
* @see {@link AbstractControl}
|
|
33
|
-
*
|
|
34
|
-
* @usageNotes
|
|
35
|
-
* ### Register Form Group
|
|
36
|
-
*
|
|
37
|
-
* The following example registers a `FormGroup` with first name and last name controls,
|
|
38
|
-
* and listens for the *ngSubmit* event when the button is clicked.
|
|
39
|
-
*
|
|
40
|
-
* {@example forms/ts/simpleFormGroup/simple_form_group_example.ts region='Component'}
|
|
41
|
-
*
|
|
42
|
-
* @ngModule ReactiveFormsModule
|
|
43
|
-
* @publicApi
|
|
44
|
-
*/
|
|
45
|
-
export class FormGroupDirective extends ControlContainer {
|
|
46
|
-
/**
|
|
47
|
-
* @description
|
|
48
|
-
* Reports whether the form submission has been triggered.
|
|
49
|
-
*/
|
|
50
|
-
get submitted() {
|
|
51
|
-
return untracked(this._submittedReactive);
|
|
52
|
-
}
|
|
53
|
-
// TODO(atscott): Remove once invalid API usage is cleaned up internally
|
|
54
|
-
set submitted(value) {
|
|
55
|
-
this._submittedReactive.set(value);
|
|
56
|
-
}
|
|
57
|
-
constructor(validators, asyncValidators, callSetDisabledState) {
|
|
58
|
-
super();
|
|
59
|
-
this.callSetDisabledState = callSetDisabledState;
|
|
60
|
-
/** @internal */
|
|
61
|
-
this._submitted = computed(() => this._submittedReactive());
|
|
62
|
-
this._submittedReactive = signal(false);
|
|
63
|
-
/**
|
|
64
|
-
* Callback that should be invoked when controls in FormGroup or FormArray collection change
|
|
65
|
-
* (added or removed). This callback triggers corresponding DOM updates.
|
|
66
|
-
*/
|
|
67
|
-
this._onCollectionChange = () => this._updateDomValue();
|
|
68
|
-
/**
|
|
69
|
-
* @description
|
|
70
|
-
* Tracks the list of added `FormControlName` instances
|
|
71
|
-
*/
|
|
72
|
-
this.directives = [];
|
|
73
|
-
/**
|
|
74
|
-
* @description
|
|
75
|
-
* Tracks the `FormGroup` bound to this directive.
|
|
76
|
-
*/
|
|
77
|
-
this.form = null;
|
|
78
|
-
/**
|
|
79
|
-
* @description
|
|
80
|
-
* Emits an event when the form submission has been triggered.
|
|
81
|
-
*/
|
|
82
|
-
this.ngSubmit = new EventEmitter();
|
|
83
|
-
this._setValidators(validators);
|
|
84
|
-
this._setAsyncValidators(asyncValidators);
|
|
85
|
-
}
|
|
86
|
-
/** @nodoc */
|
|
87
|
-
ngOnChanges(changes) {
|
|
88
|
-
this._checkFormPresent();
|
|
89
|
-
if (changes.hasOwnProperty('form')) {
|
|
90
|
-
this._updateValidators();
|
|
91
|
-
this._updateDomValue();
|
|
92
|
-
this._updateRegistrations();
|
|
93
|
-
this._oldForm = this.form;
|
|
94
|
-
}
|
|
95
|
-
}
|
|
96
|
-
/** @nodoc */
|
|
97
|
-
ngOnDestroy() {
|
|
98
|
-
if (this.form) {
|
|
99
|
-
cleanUpValidators(this.form, this);
|
|
100
|
-
// Currently the `onCollectionChange` callback is rewritten each time the
|
|
101
|
-
// `_registerOnCollectionChange` function is invoked. The implication is that cleanup should
|
|
102
|
-
// happen *only* when the `onCollectionChange` callback was set by this directive instance.
|
|
103
|
-
// Otherwise it might cause overriding a callback of some other directive instances. We should
|
|
104
|
-
// consider updating this logic later to make it similar to how `onChange` callbacks are
|
|
105
|
-
// handled, see https://github.com/angular/angular/issues/39732 for additional info.
|
|
106
|
-
if (this.form._onCollectionChange === this._onCollectionChange) {
|
|
107
|
-
this.form._registerOnCollectionChange(() => { });
|
|
108
|
-
}
|
|
109
|
-
}
|
|
110
|
-
}
|
|
111
|
-
/**
|
|
112
|
-
* @description
|
|
113
|
-
* Returns this directive's instance.
|
|
114
|
-
*/
|
|
115
|
-
get formDirective() {
|
|
116
|
-
return this;
|
|
117
|
-
}
|
|
118
|
-
/**
|
|
119
|
-
* @description
|
|
120
|
-
* Returns the `FormGroup` bound to this directive.
|
|
121
|
-
*/
|
|
122
|
-
get control() {
|
|
123
|
-
return this.form;
|
|
124
|
-
}
|
|
125
|
-
/**
|
|
126
|
-
* @description
|
|
127
|
-
* Returns an array representing the path to this group. Because this directive
|
|
128
|
-
* always lives at the top level of a form, it always an empty array.
|
|
129
|
-
*/
|
|
130
|
-
get path() {
|
|
131
|
-
return [];
|
|
132
|
-
}
|
|
133
|
-
/**
|
|
134
|
-
* @description
|
|
135
|
-
* Method that sets up the control directive in this group, re-calculates its value
|
|
136
|
-
* and validity, and adds the instance to the internal list of directives.
|
|
137
|
-
*
|
|
138
|
-
* @param dir The `FormControlName` directive instance.
|
|
139
|
-
*/
|
|
140
|
-
addControl(dir) {
|
|
141
|
-
const ctrl = this.form.get(dir.path);
|
|
142
|
-
setUpControl(ctrl, dir, this.callSetDisabledState);
|
|
143
|
-
ctrl.updateValueAndValidity({ emitEvent: false });
|
|
144
|
-
this.directives.push(dir);
|
|
145
|
-
return ctrl;
|
|
146
|
-
}
|
|
147
|
-
/**
|
|
148
|
-
* @description
|
|
149
|
-
* Retrieves the `FormControl` instance from the provided `FormControlName` directive
|
|
150
|
-
*
|
|
151
|
-
* @param dir The `FormControlName` directive instance.
|
|
152
|
-
*/
|
|
153
|
-
getControl(dir) {
|
|
154
|
-
return this.form.get(dir.path);
|
|
155
|
-
}
|
|
156
|
-
/**
|
|
157
|
-
* @description
|
|
158
|
-
* Removes the `FormControlName` instance from the internal list of directives
|
|
159
|
-
*
|
|
160
|
-
* @param dir The `FormControlName` directive instance.
|
|
161
|
-
*/
|
|
162
|
-
removeControl(dir) {
|
|
163
|
-
cleanUpControl(dir.control || null, dir, /* validateControlPresenceOnChange */ false);
|
|
164
|
-
removeListItem(this.directives, dir);
|
|
165
|
-
}
|
|
166
|
-
/**
|
|
167
|
-
* Adds a new `FormGroupName` directive instance to the form.
|
|
168
|
-
*
|
|
169
|
-
* @param dir The `FormGroupName` directive instance.
|
|
170
|
-
*/
|
|
171
|
-
addFormGroup(dir) {
|
|
172
|
-
this._setUpFormContainer(dir);
|
|
173
|
-
}
|
|
174
|
-
/**
|
|
175
|
-
* Performs the necessary cleanup when a `FormGroupName` directive instance is removed from the
|
|
176
|
-
* view.
|
|
177
|
-
*
|
|
178
|
-
* @param dir The `FormGroupName` directive instance.
|
|
179
|
-
*/
|
|
180
|
-
removeFormGroup(dir) {
|
|
181
|
-
this._cleanUpFormContainer(dir);
|
|
182
|
-
}
|
|
183
|
-
/**
|
|
184
|
-
* @description
|
|
185
|
-
* Retrieves the `FormGroup` for a provided `FormGroupName` directive instance
|
|
186
|
-
*
|
|
187
|
-
* @param dir The `FormGroupName` directive instance.
|
|
188
|
-
*/
|
|
189
|
-
getFormGroup(dir) {
|
|
190
|
-
return this.form.get(dir.path);
|
|
191
|
-
}
|
|
192
|
-
/**
|
|
193
|
-
* Performs the necessary setup when a `FormArrayName` directive instance is added to the view.
|
|
194
|
-
*
|
|
195
|
-
* @param dir The `FormArrayName` directive instance.
|
|
196
|
-
*/
|
|
197
|
-
addFormArray(dir) {
|
|
198
|
-
this._setUpFormContainer(dir);
|
|
199
|
-
}
|
|
200
|
-
/**
|
|
201
|
-
* Performs the necessary cleanup when a `FormArrayName` directive instance is removed from the
|
|
202
|
-
* view.
|
|
203
|
-
*
|
|
204
|
-
* @param dir The `FormArrayName` directive instance.
|
|
205
|
-
*/
|
|
206
|
-
removeFormArray(dir) {
|
|
207
|
-
this._cleanUpFormContainer(dir);
|
|
208
|
-
}
|
|
209
|
-
/**
|
|
210
|
-
* @description
|
|
211
|
-
* Retrieves the `FormArray` for a provided `FormArrayName` directive instance.
|
|
212
|
-
*
|
|
213
|
-
* @param dir The `FormArrayName` directive instance.
|
|
214
|
-
*/
|
|
215
|
-
getFormArray(dir) {
|
|
216
|
-
return this.form.get(dir.path);
|
|
217
|
-
}
|
|
218
|
-
/**
|
|
219
|
-
* Sets the new value for the provided `FormControlName` directive.
|
|
220
|
-
*
|
|
221
|
-
* @param dir The `FormControlName` directive instance.
|
|
222
|
-
* @param value The new value for the directive's control.
|
|
223
|
-
*/
|
|
224
|
-
updateModel(dir, value) {
|
|
225
|
-
const ctrl = this.form.get(dir.path);
|
|
226
|
-
ctrl.setValue(value);
|
|
227
|
-
}
|
|
228
|
-
/**
|
|
229
|
-
* @description
|
|
230
|
-
* Method called with the "submit" event is triggered on the form.
|
|
231
|
-
* Triggers the `ngSubmit` emitter to emit the "submit" event as its payload.
|
|
232
|
-
*
|
|
233
|
-
* @param $event The "submit" event object
|
|
234
|
-
*/
|
|
235
|
-
onSubmit($event) {
|
|
236
|
-
this._submittedReactive.set(true);
|
|
237
|
-
syncPendingControls(this.form, this.directives);
|
|
238
|
-
this.ngSubmit.emit($event);
|
|
239
|
-
this.form._events.next(new FormSubmittedEvent(this.control));
|
|
240
|
-
// Forms with `method="dialog"` have some special behavior that won't reload the page and that
|
|
241
|
-
// shouldn't be prevented. Note that we need to null check the `event` and the `target`, because
|
|
242
|
-
// some internal apps call this method directly with the wrong arguments.
|
|
243
|
-
return $event?.target?.method === 'dialog';
|
|
244
|
-
}
|
|
245
|
-
/**
|
|
246
|
-
* @description
|
|
247
|
-
* Method called when the "reset" event is triggered on the form.
|
|
248
|
-
*/
|
|
249
|
-
onReset() {
|
|
250
|
-
this.resetForm();
|
|
251
|
-
}
|
|
252
|
-
/**
|
|
253
|
-
* @description
|
|
254
|
-
* Resets the form to an initial value and resets its submitted status.
|
|
255
|
-
*
|
|
256
|
-
* @param value The new value for the form.
|
|
257
|
-
*/
|
|
258
|
-
resetForm(value = undefined) {
|
|
259
|
-
this.form.reset(value);
|
|
260
|
-
this._submittedReactive.set(false);
|
|
261
|
-
this.form._events.next(new FormResetEvent(this.form));
|
|
262
|
-
}
|
|
263
|
-
/** @internal */
|
|
264
|
-
_updateDomValue() {
|
|
265
|
-
this.directives.forEach((dir) => {
|
|
266
|
-
const oldCtrl = dir.control;
|
|
267
|
-
const newCtrl = this.form.get(dir.path);
|
|
268
|
-
if (oldCtrl !== newCtrl) {
|
|
269
|
-
// Note: the value of the `dir.control` may not be defined, for example when it's a first
|
|
270
|
-
// `FormControl` that is added to a `FormGroup` instance (via `addControl` call).
|
|
271
|
-
cleanUpControl(oldCtrl || null, dir);
|
|
272
|
-
// Check whether new control at the same location inside the corresponding `FormGroup` is an
|
|
273
|
-
// instance of `FormControl` and perform control setup only if that's the case.
|
|
274
|
-
// Note: we don't need to clear the list of directives (`this.directives`) here, it would be
|
|
275
|
-
// taken care of in the `removeControl` method invoked when corresponding `formControlName`
|
|
276
|
-
// directive instance is being removed (invoked from `FormControlName.ngOnDestroy`).
|
|
277
|
-
if (isFormControl(newCtrl)) {
|
|
278
|
-
setUpControl(newCtrl, dir, this.callSetDisabledState);
|
|
279
|
-
dir.control = newCtrl;
|
|
280
|
-
}
|
|
281
|
-
}
|
|
282
|
-
});
|
|
283
|
-
this.form._updateTreeValidity({ emitEvent: false });
|
|
284
|
-
}
|
|
285
|
-
_setUpFormContainer(dir) {
|
|
286
|
-
const ctrl = this.form.get(dir.path);
|
|
287
|
-
setUpFormContainer(ctrl, dir);
|
|
288
|
-
// NOTE: this operation looks unnecessary in case no new validators were added in
|
|
289
|
-
// `setUpFormContainer` call. Consider updating this code to match the logic in
|
|
290
|
-
// `_cleanUpFormContainer` function.
|
|
291
|
-
ctrl.updateValueAndValidity({ emitEvent: false });
|
|
292
|
-
}
|
|
293
|
-
_cleanUpFormContainer(dir) {
|
|
294
|
-
if (this.form) {
|
|
295
|
-
const ctrl = this.form.get(dir.path);
|
|
296
|
-
if (ctrl) {
|
|
297
|
-
const isControlUpdated = cleanUpFormContainer(ctrl, dir);
|
|
298
|
-
if (isControlUpdated) {
|
|
299
|
-
// Run validity check only in case a control was updated (i.e. view validators were
|
|
300
|
-
// removed) as removing view validators might cause validity to change.
|
|
301
|
-
ctrl.updateValueAndValidity({ emitEvent: false });
|
|
302
|
-
}
|
|
303
|
-
}
|
|
304
|
-
}
|
|
305
|
-
}
|
|
306
|
-
_updateRegistrations() {
|
|
307
|
-
this.form._registerOnCollectionChange(this._onCollectionChange);
|
|
308
|
-
if (this._oldForm) {
|
|
309
|
-
this._oldForm._registerOnCollectionChange(() => { });
|
|
310
|
-
}
|
|
311
|
-
}
|
|
312
|
-
_updateValidators() {
|
|
313
|
-
setUpValidators(this.form, this);
|
|
314
|
-
if (this._oldForm) {
|
|
315
|
-
cleanUpValidators(this._oldForm, this);
|
|
316
|
-
}
|
|
317
|
-
}
|
|
318
|
-
_checkFormPresent() {
|
|
319
|
-
if (!this.form && (typeof ngDevMode === 'undefined' || ngDevMode)) {
|
|
320
|
-
throw missingFormException();
|
|
321
|
-
}
|
|
322
|
-
}
|
|
323
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.0.0-next.1", ngImport: i0, type: FormGroupDirective, deps: [{ token: NG_VALIDATORS, optional: true, self: true }, { token: NG_ASYNC_VALIDATORS, optional: true, self: true }, { token: CALL_SET_DISABLED_STATE, optional: true }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
324
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "19.0.0-next.1", type: FormGroupDirective, selector: "[formGroup]", inputs: { form: ["formGroup", "form"] }, outputs: { ngSubmit: "ngSubmit" }, host: { listeners: { "submit": "onSubmit($event)", "reset": "onReset()" } }, providers: [formDirectiveProvider], exportAs: ["ngForm"], usesInheritance: true, usesOnChanges: true, ngImport: i0 }); }
|
|
325
|
-
}
|
|
326
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.0.0-next.1", ngImport: i0, type: FormGroupDirective, decorators: [{
|
|
327
|
-
type: Directive,
|
|
328
|
-
args: [{
|
|
329
|
-
selector: '[formGroup]',
|
|
330
|
-
providers: [formDirectiveProvider],
|
|
331
|
-
host: { '(submit)': 'onSubmit($event)', '(reset)': 'onReset()' },
|
|
332
|
-
exportAs: 'ngForm',
|
|
333
|
-
}]
|
|
334
|
-
}], ctorParameters: () => [{ type: undefined, decorators: [{
|
|
335
|
-
type: Optional
|
|
336
|
-
}, {
|
|
337
|
-
type: Self
|
|
338
|
-
}, {
|
|
339
|
-
type: Inject,
|
|
340
|
-
args: [NG_VALIDATORS]
|
|
341
|
-
}] }, { type: undefined, decorators: [{
|
|
342
|
-
type: Optional
|
|
343
|
-
}, {
|
|
344
|
-
type: Self
|
|
345
|
-
}, {
|
|
346
|
-
type: Inject,
|
|
347
|
-
args: [NG_ASYNC_VALIDATORS]
|
|
348
|
-
}] }, { type: undefined, decorators: [{
|
|
349
|
-
type: Optional
|
|
350
|
-
}, {
|
|
351
|
-
type: Inject,
|
|
352
|
-
args: [CALL_SET_DISABLED_STATE]
|
|
353
|
-
}] }], propDecorators: { form: [{
|
|
354
|
-
type: Input,
|
|
355
|
-
args: ['formGroup']
|
|
356
|
-
}], ngSubmit: [{
|
|
357
|
-
type: Output
|
|
358
|
-
}] } });
|
|
359
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form_group_directive.js","sourceRoot":"","sources":["../../../../../../../../packages/forms/src/directives/reactive_directives/form_group_directive.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  computed,\n  Directive,\n  EventEmitter,\n  forwardRef,\n  Inject,\n  Input,\n  OnChanges,\n  OnDestroy,\n  Optional,\n  Output,\n  Provider,\n  Self,\n  signal,\n  SimpleChanges,\n  untracked,\n  ɵWritable as Writable,\n} from '@angular/core';\n\nimport {FormArray} from '../../model/form_array';\nimport {FormControl, isFormControl} from '../../model/form_control';\nimport {FormGroup} from '../../model/form_group';\nimport {NG_ASYNC_VALIDATORS, NG_VALIDATORS} from '../../validators';\nimport {ControlContainer} from '../control_container';\nimport {Form} from '../form_interface';\nimport {missingFormException} from '../reactive_errors';\nimport {\n  CALL_SET_DISABLED_STATE,\n  cleanUpControl,\n  cleanUpFormContainer,\n  cleanUpValidators,\n  removeListItem,\n  SetDisabledStateOption,\n  setUpControl,\n  setUpFormContainer,\n  setUpValidators,\n  syncPendingControls,\n} from '../shared';\nimport {AsyncValidator, AsyncValidatorFn, Validator, ValidatorFn} from '../validators';\n\nimport {FormControlName} from './form_control_name';\nimport {FormArrayName, FormGroupName} from './form_group_name';\nimport {FormResetEvent, FormSubmittedEvent} from '../../model/abstract_model';\n\nconst formDirectiveProvider: Provider = {\n  provide: ControlContainer,\n  useExisting: forwardRef(() => FormGroupDirective),\n};\n\n/**\n * @description\n *\n * Binds an existing `FormGroup` or `FormRecord` to a DOM element.\n *\n * This directive accepts an existing `FormGroup` instance. It will then use this\n * `FormGroup` instance to match any child `FormControl`, `FormGroup`/`FormRecord`,\n * and `FormArray` instances to child `FormControlName`, `FormGroupName`,\n * and `FormArrayName` directives.\n *\n * @see [Reactive Forms Guide](guide/forms/reactive-forms)\n * @see {@link AbstractControl}\n *\n * @usageNotes\n * ### Register Form Group\n *\n * The following example registers a `FormGroup` with first name and last name controls,\n * and listens for the *ngSubmit* event when the button is clicked.\n *\n * {@example forms/ts/simpleFormGroup/simple_form_group_example.ts region='Component'}\n *\n * @ngModule ReactiveFormsModule\n * @publicApi\n */\n@Directive({\n  selector: '[formGroup]',\n  providers: [formDirectiveProvider],\n  host: {'(submit)': 'onSubmit($event)', '(reset)': 'onReset()'},\n  exportAs: 'ngForm',\n})\nexport class FormGroupDirective extends ControlContainer implements Form, OnChanges, OnDestroy {\n  /**\n   * @description\n   * Reports whether the form submission has been triggered.\n   */\n  get submitted() {\n    return untracked(this._submittedReactive);\n  }\n  // TODO(atscott): Remove once invalid API usage is cleaned up internally\n  private set submitted(value: boolean) {\n    this._submittedReactive.set(value);\n  }\n  /** @internal */\n  readonly _submitted = computed(() => this._submittedReactive());\n  private readonly _submittedReactive = signal(false);\n\n  /**\n   * Reference to an old form group input value, which is needed to cleanup\n   * old instance in case it was replaced with a new one.\n   */\n  private _oldForm: FormGroup | undefined;\n\n  /**\n   * Callback that should be invoked when controls in FormGroup or FormArray collection change\n   * (added or removed). This callback triggers corresponding DOM updates.\n   */\n  private readonly _onCollectionChange = () => this._updateDomValue();\n\n  /**\n   * @description\n   * Tracks the list of added `FormControlName` instances\n   */\n  directives: FormControlName[] = [];\n\n  /**\n   * @description\n   * Tracks the `FormGroup` bound to this directive.\n   */\n  @Input('formGroup') form: FormGroup = null!;\n\n  /**\n   * @description\n   * Emits an event when the form submission has been triggered.\n   */\n  @Output() ngSubmit = new EventEmitter();\n\n  constructor(\n    @Optional() @Self() @Inject(NG_VALIDATORS) validators: (Validator | ValidatorFn)[],\n    @Optional()\n    @Self()\n    @Inject(NG_ASYNC_VALIDATORS)\n    asyncValidators: (AsyncValidator | AsyncValidatorFn)[],\n    @Optional()\n    @Inject(CALL_SET_DISABLED_STATE)\n    private callSetDisabledState?: SetDisabledStateOption,\n  ) {\n    super();\n    this._setValidators(validators);\n    this._setAsyncValidators(asyncValidators);\n  }\n\n  /** @nodoc */\n  ngOnChanges(changes: SimpleChanges): void {\n    this._checkFormPresent();\n    if (changes.hasOwnProperty('form')) {\n      this._updateValidators();\n      this._updateDomValue();\n      this._updateRegistrations();\n      this._oldForm = this.form;\n    }\n  }\n\n  /** @nodoc */\n  ngOnDestroy() {\n    if (this.form) {\n      cleanUpValidators(this.form, this);\n\n      // Currently the `onCollectionChange` callback is rewritten each time the\n      // `_registerOnCollectionChange` function is invoked. The implication is that cleanup should\n      // happen *only* when the `onCollectionChange` callback was set by this directive instance.\n      // Otherwise it might cause overriding a callback of some other directive instances. We should\n      // consider updating this logic later to make it similar to how `onChange` callbacks are\n      // handled, see https://github.com/angular/angular/issues/39732 for additional info.\n      if (this.form._onCollectionChange === this._onCollectionChange) {\n        this.form._registerOnCollectionChange(() => {});\n      }\n    }\n  }\n\n  /**\n   * @description\n   * Returns this directive's instance.\n   */\n  override get formDirective(): Form {\n    return this;\n  }\n\n  /**\n   * @description\n   * Returns the `FormGroup` bound to this directive.\n   */\n  override get control(): FormGroup {\n    return this.form;\n  }\n\n  /**\n   * @description\n   * Returns an array representing the path to this group. Because this directive\n   * always lives at the top level of a form, it always an empty array.\n   */\n  override get path(): string[] {\n    return [];\n  }\n\n  /**\n   * @description\n   * Method that sets up the control directive in this group, re-calculates its value\n   * and validity, and adds the instance to the internal list of directives.\n   *\n   * @param dir The `FormControlName` directive instance.\n   */\n  addControl(dir: FormControlName): FormControl {\n    const ctrl: any = this.form.get(dir.path);\n    setUpControl(ctrl, dir, this.callSetDisabledState);\n    ctrl.updateValueAndValidity({emitEvent: false});\n    this.directives.push(dir);\n    return ctrl;\n  }\n\n  /**\n   * @description\n   * Retrieves the `FormControl` instance from the provided `FormControlName` directive\n   *\n   * @param dir The `FormControlName` directive instance.\n   */\n  getControl(dir: FormControlName): FormControl {\n    return <FormControl>this.form.get(dir.path);\n  }\n\n  /**\n   * @description\n   * Removes the `FormControlName` instance from the internal list of directives\n   *\n   * @param dir The `FormControlName` directive instance.\n   */\n  removeControl(dir: FormControlName): void {\n    cleanUpControl(dir.control || null, dir, /* validateControlPresenceOnChange */ false);\n    removeListItem(this.directives, dir);\n  }\n\n  /**\n   * Adds a new `FormGroupName` directive instance to the form.\n   *\n   * @param dir The `FormGroupName` directive instance.\n   */\n  addFormGroup(dir: FormGroupName): void {\n    this._setUpFormContainer(dir);\n  }\n\n  /**\n   * Performs the necessary cleanup when a `FormGroupName` directive instance is removed from the\n   * view.\n   *\n   * @param dir The `FormGroupName` directive instance.\n   */\n  removeFormGroup(dir: FormGroupName): void {\n    this._cleanUpFormContainer(dir);\n  }\n\n  /**\n   * @description\n   * Retrieves the `FormGroup` for a provided `FormGroupName` directive instance\n   *\n   * @param dir The `FormGroupName` directive instance.\n   */\n  getFormGroup(dir: FormGroupName): FormGroup {\n    return <FormGroup>this.form.get(dir.path);\n  }\n\n  /**\n   * Performs the necessary setup when a `FormArrayName` directive instance is added to the view.\n   *\n   * @param dir The `FormArrayName` directive instance.\n   */\n  addFormArray(dir: FormArrayName): void {\n    this._setUpFormContainer(dir);\n  }\n\n  /**\n   * Performs the necessary cleanup when a `FormArrayName` directive instance is removed from the\n   * view.\n   *\n   * @param dir The `FormArrayName` directive instance.\n   */\n  removeFormArray(dir: FormArrayName): void {\n    this._cleanUpFormContainer(dir);\n  }\n\n  /**\n   * @description\n   * Retrieves the `FormArray` for a provided `FormArrayName` directive instance.\n   *\n   * @param dir The `FormArrayName` directive instance.\n   */\n  getFormArray(dir: FormArrayName): FormArray {\n    return <FormArray>this.form.get(dir.path);\n  }\n\n  /**\n   * Sets the new value for the provided `FormControlName` directive.\n   *\n   * @param dir The `FormControlName` directive instance.\n   * @param value The new value for the directive's control.\n   */\n  updateModel(dir: FormControlName, value: any): void {\n    const ctrl = <FormControl>this.form.get(dir.path);\n    ctrl.setValue(value);\n  }\n\n  /**\n   * @description\n   * Method called with the \"submit\" event is triggered on the form.\n   * Triggers the `ngSubmit` emitter to emit the \"submit\" event as its payload.\n   *\n   * @param $event The \"submit\" event object\n   */\n  onSubmit($event: Event): boolean {\n    this._submittedReactive.set(true);\n    syncPendingControls(this.form, this.directives);\n    this.ngSubmit.emit($event);\n    this.form._events.next(new FormSubmittedEvent(this.control));\n\n    // Forms with `method=\"dialog\"` have some special behavior that won't reload the page and that\n    // shouldn't be prevented. Note that we need to null check the `event` and the `target`, because\n    // some internal apps call this method directly with the wrong arguments.\n    return ($event?.target as HTMLFormElement | null)?.method === 'dialog';\n  }\n\n  /**\n   * @description\n   * Method called when the \"reset\" event is triggered on the form.\n   */\n  onReset(): void {\n    this.resetForm();\n  }\n\n  /**\n   * @description\n   * Resets the form to an initial value and resets its submitted status.\n   *\n   * @param value The new value for the form.\n   */\n  resetForm(value: any = undefined): void {\n    this.form.reset(value);\n    this._submittedReactive.set(false);\n    this.form._events.next(new FormResetEvent(this.form));\n  }\n\n  /** @internal */\n  _updateDomValue() {\n    this.directives.forEach((dir) => {\n      const oldCtrl = dir.control;\n      const newCtrl = this.form.get(dir.path);\n      if (oldCtrl !== newCtrl) {\n        // Note: the value of the `dir.control` may not be defined, for example when it's a first\n        // `FormControl` that is added to a `FormGroup` instance (via `addControl` call).\n        cleanUpControl(oldCtrl || null, dir);\n\n        // Check whether new control at the same location inside the corresponding `FormGroup` is an\n        // instance of `FormControl` and perform control setup only if that's the case.\n        // Note: we don't need to clear the list of directives (`this.directives`) here, it would be\n        // taken care of in the `removeControl` method invoked when corresponding `formControlName`\n        // directive instance is being removed (invoked from `FormControlName.ngOnDestroy`).\n        if (isFormControl(newCtrl)) {\n          setUpControl(newCtrl, dir, this.callSetDisabledState);\n          (dir as Writable<FormControlName>).control = newCtrl;\n        }\n      }\n    });\n\n    this.form._updateTreeValidity({emitEvent: false});\n  }\n\n  private _setUpFormContainer(dir: FormArrayName | FormGroupName): void {\n    const ctrl: any = this.form.get(dir.path);\n    setUpFormContainer(ctrl, dir);\n    // NOTE: this operation looks unnecessary in case no new validators were added in\n    // `setUpFormContainer` call. Consider updating this code to match the logic in\n    // `_cleanUpFormContainer` function.\n    ctrl.updateValueAndValidity({emitEvent: false});\n  }\n\n  private _cleanUpFormContainer(dir: FormArrayName | FormGroupName): void {\n    if (this.form) {\n      const ctrl: any = this.form.get(dir.path);\n      if (ctrl) {\n        const isControlUpdated = cleanUpFormContainer(ctrl, dir);\n        if (isControlUpdated) {\n          // Run validity check only in case a control was updated (i.e. view validators were\n          // removed) as removing view validators might cause validity to change.\n          ctrl.updateValueAndValidity({emitEvent: false});\n        }\n      }\n    }\n  }\n\n  private _updateRegistrations() {\n    this.form._registerOnCollectionChange(this._onCollectionChange);\n    if (this._oldForm) {\n      this._oldForm._registerOnCollectionChange(() => {});\n    }\n  }\n\n  private _updateValidators() {\n    setUpValidators(this.form, this);\n    if (this._oldForm) {\n      cleanUpValidators(this._oldForm, this);\n    }\n  }\n\n  private _checkFormPresent() {\n    if (!this.form && (typeof ngDevMode === 'undefined' || ngDevMode)) {\n      throw missingFormException();\n    }\n  }\n}\n"]}
|