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

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (47) hide show
  1. package/LICENSE +21 -0
  2. package/fesm2022/forms.mjs +186 -132
  3. package/fesm2022/forms.mjs.map +1 -1
  4. package/index.d.ts +6 -5
  5. package/package.json +4 -6
  6. package/esm2022/forms.mjs +0 -5
  7. package/esm2022/index.mjs +0 -13
  8. package/esm2022/public_api.mjs +0 -15
  9. package/esm2022/src/directives/abstract_control_directive.mjs +0 -279
  10. package/esm2022/src/directives/abstract_form_group_directive.mjs +0 -61
  11. package/esm2022/src/directives/checkbox_value_accessor.mjs +0 -58
  12. package/esm2022/src/directives/control_container.mjs +0 -32
  13. package/esm2022/src/directives/control_value_accessor.mjs +0 -92
  14. package/esm2022/src/directives/default_value_accessor.mjs +0 -124
  15. package/esm2022/src/directives/error_examples.mjs +0 -57
  16. package/esm2022/src/directives/form_interface.mjs +0 -9
  17. package/esm2022/src/directives/ng_control.mjs +0 -38
  18. package/esm2022/src/directives/ng_control_status.mjs +0 -139
  19. package/esm2022/src/directives/ng_form.mjs +0 -313
  20. package/esm2022/src/directives/ng_model.mjs +0 -331
  21. package/esm2022/src/directives/ng_model_group.mjs +0 -95
  22. package/esm2022/src/directives/ng_no_validate_directive.mjs +0 -39
  23. package/esm2022/src/directives/number_value_accessor.mjs +0 -70
  24. package/esm2022/src/directives/radio_control_value_accessor.mjs +0 -201
  25. package/esm2022/src/directives/range_value_accessor.mjs +0 -72
  26. package/esm2022/src/directives/reactive_directives/form_control_directive.mjs +0 -183
  27. package/esm2022/src/directives/reactive_directives/form_control_name.mjs +0 -216
  28. package/esm2022/src/directives/reactive_directives/form_group_directive.mjs +0 -359
  29. package/esm2022/src/directives/reactive_directives/form_group_name.mjs +0 -246
  30. package/esm2022/src/directives/reactive_errors.mjs +0 -119
  31. package/esm2022/src/directives/select_control_value_accessor.mjs +0 -220
  32. package/esm2022/src/directives/select_multiple_control_value_accessor.mjs +0 -252
  33. package/esm2022/src/directives/shared.mjs +0 -350
  34. package/esm2022/src/directives/template_driven_errors.mjs +0 -54
  35. package/esm2022/src/directives/validators.mjs +0 -505
  36. package/esm2022/src/directives.mjs +0 -128
  37. package/esm2022/src/errors.mjs +0 -9
  38. package/esm2022/src/form_builder.mjs +0 -258
  39. package/esm2022/src/form_providers.mjs +0 -105
  40. package/esm2022/src/forms.mjs +0 -49
  41. package/esm2022/src/model/abstract_model.mjs +0 -992
  42. package/esm2022/src/model/form_array.mjs +0 -461
  43. package/esm2022/src/model/form_control.mjs +0 -126
  44. package/esm2022/src/model/form_group.mjs +0 -490
  45. package/esm2022/src/util.mjs +0 -13
  46. package/esm2022/src/validators.mjs +0 -680
  47. package/esm2022/src/version.mjs +0 -18
@@ -1,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"]}