@angular/forms 16.0.0-next.4 → 16.0.0-next.5
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/{esm2020 → esm2022}/src/directives/abstract_form_group_directive.mjs +4 -4
- package/{esm2020 → esm2022}/src/directives/checkbox_value_accessor.mjs +4 -4
- package/{esm2020 → esm2022}/src/directives/control_value_accessor.mjs +7 -7
- package/{esm2020 → esm2022}/src/directives/default_value_accessor.mjs +4 -4
- package/{esm2020 → esm2022}/src/directives/ng_control_status.mjs +7 -7
- package/{esm2020 → esm2022}/src/directives/ng_form.mjs +4 -4
- package/esm2022/src/directives/ng_model.mjs +332 -0
- package/esm2022/src/directives/ng_model_group.mjs +95 -0
- package/{esm2020 → esm2022}/src/directives/ng_no_validate_directive.mjs +4 -4
- package/{esm2020 → esm2022}/src/directives/number_value_accessor.mjs +4 -4
- package/{esm2020 → esm2022}/src/directives/radio_control_value_accessor.mjs +11 -11
- package/{esm2020 → esm2022}/src/directives/range_value_accessor.mjs +4 -4
- package/esm2022/src/directives/reactive_directives/form_control_directive.mjs +185 -0
- package/esm2022/src/directives/reactive_directives/form_control_name.mjs +219 -0
- package/{esm2020 → esm2022}/src/directives/reactive_directives/form_group_directive.mjs +4 -4
- package/esm2022/src/directives/reactive_directives/form_group_name.mjs +247 -0
- package/{esm2020 → esm2022}/src/directives/select_control_value_accessor.mjs +7 -7
- package/{esm2020 → esm2022}/src/directives/select_multiple_control_value_accessor.mjs +7 -7
- package/{esm2020 → esm2022}/src/directives/validators.mjs +28 -28
- package/{esm2020 → esm2022}/src/directives.mjs +43 -43
- package/{esm2020 → esm2022}/src/form_builder.mjs +10 -10
- package/{esm2020 → esm2022}/src/form_providers.mjs +9 -9
- package/esm2022/src/model/abstract_model.mjs +939 -0
- package/esm2022/src/validators.mjs +678 -0
- package/{esm2020 → esm2022}/src/version.mjs +1 -1
- package/{fesm2020 → fesm2022}/forms.mjs +228 -187
- package/fesm2022/forms.mjs.map +1 -0
- package/index.d.ts +1 -1
- package/package.json +8 -14
- package/esm2020/src/directives/ng_model.mjs +0 -326
- package/esm2020/src/directives/ng_model_group.mjs +0 -89
- package/esm2020/src/directives/reactive_directives/form_control_directive.mjs +0 -185
- package/esm2020/src/directives/reactive_directives/form_control_name.mjs +0 -209
- package/esm2020/src/directives/reactive_directives/form_group_name.mjs +0 -227
- package/esm2020/src/model/abstract_model.mjs +0 -939
- package/esm2020/src/validators.mjs +0 -679
- package/fesm2015/forms.mjs +0 -7272
- package/fesm2015/forms.mjs.map +0 -1
- package/fesm2020/forms.mjs.map +0 -1
- /package/{esm2020 → esm2022}/forms.mjs +0 -0
- /package/{esm2020 → esm2022}/index.mjs +0 -0
- /package/{esm2020 → esm2022}/public_api.mjs +0 -0
- /package/{esm2020 → esm2022}/src/directives/abstract_control_directive.mjs +0 -0
- /package/{esm2020 → esm2022}/src/directives/control_container.mjs +0 -0
- /package/{esm2020 → esm2022}/src/directives/error_examples.mjs +0 -0
- /package/{esm2020 → esm2022}/src/directives/form_interface.mjs +0 -0
- /package/{esm2020 → esm2022}/src/directives/ng_control.mjs +0 -0
- /package/{esm2020 → esm2022}/src/directives/reactive_errors.mjs +0 -0
- /package/{esm2020 → esm2022}/src/directives/shared.mjs +0 -0
- /package/{esm2020 → esm2022}/src/directives/template_driven_errors.mjs +0 -0
- /package/{esm2020 → esm2022}/src/errors.mjs +0 -0
- /package/{esm2020 → esm2022}/src/forms.mjs +0 -0
- /package/{esm2020 → esm2022}/src/model/form_array.mjs +0 -0
- /package/{esm2020 → esm2022}/src/model/form_control.mjs +0 -0
- /package/{esm2020 → esm2022}/src/model/form_group.mjs +0 -0
- /package/{esm2020 → esm2022}/src/util.mjs +0 -0
|
@@ -1,185 +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, Inject, InjectionToken, Input, Optional, Output, Self } from '@angular/core';
|
|
9
|
-
import { FormControl } from '../../model/form_control';
|
|
10
|
-
import { NG_ASYNC_VALIDATORS, NG_VALIDATORS } from '../../validators';
|
|
11
|
-
import { NG_VALUE_ACCESSOR } from '../control_value_accessor';
|
|
12
|
-
import { NgControl } from '../ng_control';
|
|
13
|
-
import { disabledAttrWarning } from '../reactive_errors';
|
|
14
|
-
import { _ngModelWarning, CALL_SET_DISABLED_STATE, cleanUpControl, isPropertyUpdated, selectValueAccessor, setUpControl } from '../shared';
|
|
15
|
-
import * as i0 from "@angular/core";
|
|
16
|
-
/**
|
|
17
|
-
* Token to provide to turn off the ngModel warning on formControl and formControlName.
|
|
18
|
-
*/
|
|
19
|
-
export const NG_MODEL_WITH_FORM_CONTROL_WARNING = new InjectionToken('NgModelWithFormControlWarning');
|
|
20
|
-
const formControlBinding = {
|
|
21
|
-
provide: NgControl,
|
|
22
|
-
useExisting: forwardRef(() => FormControlDirective)
|
|
23
|
-
};
|
|
24
|
-
/**
|
|
25
|
-
* @description
|
|
26
|
-
* Synchronizes a standalone `FormControl` instance to a form control element.
|
|
27
|
-
*
|
|
28
|
-
* Note that support for using the `ngModel` input property and `ngModelChange` event with reactive
|
|
29
|
-
* form directives was deprecated in Angular v6 and is scheduled for removal in
|
|
30
|
-
* a future version of Angular.
|
|
31
|
-
* For details, see [Deprecated features](guide/deprecations#ngmodel-with-reactive-forms).
|
|
32
|
-
*
|
|
33
|
-
* @see [Reactive Forms Guide](guide/reactive-forms)
|
|
34
|
-
* @see `FormControl`
|
|
35
|
-
* @see `AbstractControl`
|
|
36
|
-
*
|
|
37
|
-
* @usageNotes
|
|
38
|
-
*
|
|
39
|
-
* The following example shows how to register a standalone control and set its value.
|
|
40
|
-
*
|
|
41
|
-
* {@example forms/ts/simpleFormControl/simple_form_control_example.ts region='Component'}
|
|
42
|
-
*
|
|
43
|
-
* @ngModule ReactiveFormsModule
|
|
44
|
-
* @publicApi
|
|
45
|
-
*/
|
|
46
|
-
class FormControlDirective extends NgControl {
|
|
47
|
-
/**
|
|
48
|
-
* @description
|
|
49
|
-
* Triggers a warning in dev mode that this input should not be used with reactive forms.
|
|
50
|
-
*/
|
|
51
|
-
set isDisabled(isDisabled) {
|
|
52
|
-
if (typeof ngDevMode === 'undefined' || ngDevMode) {
|
|
53
|
-
console.warn(disabledAttrWarning);
|
|
54
|
-
}
|
|
55
|
-
}
|
|
56
|
-
constructor(validators, asyncValidators, valueAccessors, _ngModelWarningConfig, callSetDisabledState) {
|
|
57
|
-
super();
|
|
58
|
-
this._ngModelWarningConfig = _ngModelWarningConfig;
|
|
59
|
-
this.callSetDisabledState = callSetDisabledState;
|
|
60
|
-
/** @deprecated as of v6 */
|
|
61
|
-
this.update = new EventEmitter();
|
|
62
|
-
/**
|
|
63
|
-
* @description
|
|
64
|
-
* Instance property used to track whether an ngModel warning has been sent out for this
|
|
65
|
-
* particular `FormControlDirective` instance. Used to support warning config of "always".
|
|
66
|
-
*
|
|
67
|
-
* @internal
|
|
68
|
-
*/
|
|
69
|
-
this._ngModelWarningSent = false;
|
|
70
|
-
this._setValidators(validators);
|
|
71
|
-
this._setAsyncValidators(asyncValidators);
|
|
72
|
-
this.valueAccessor = selectValueAccessor(this, valueAccessors);
|
|
73
|
-
}
|
|
74
|
-
/** @nodoc */
|
|
75
|
-
ngOnChanges(changes) {
|
|
76
|
-
if (this._isControlChanged(changes)) {
|
|
77
|
-
const previousForm = changes['form'].previousValue;
|
|
78
|
-
if (previousForm) {
|
|
79
|
-
cleanUpControl(previousForm, this, /* validateControlPresenceOnChange */ false);
|
|
80
|
-
}
|
|
81
|
-
setUpControl(this.form, this, this.callSetDisabledState);
|
|
82
|
-
this.form.updateValueAndValidity({ emitEvent: false });
|
|
83
|
-
}
|
|
84
|
-
if (isPropertyUpdated(changes, this.viewModel)) {
|
|
85
|
-
if (typeof ngDevMode === 'undefined' || ngDevMode) {
|
|
86
|
-
_ngModelWarning('formControl', FormControlDirective, this, this._ngModelWarningConfig);
|
|
87
|
-
}
|
|
88
|
-
this.form.setValue(this.model);
|
|
89
|
-
this.viewModel = this.model;
|
|
90
|
-
}
|
|
91
|
-
}
|
|
92
|
-
/** @nodoc */
|
|
93
|
-
ngOnDestroy() {
|
|
94
|
-
if (this.form) {
|
|
95
|
-
cleanUpControl(this.form, this, /* validateControlPresenceOnChange */ false);
|
|
96
|
-
}
|
|
97
|
-
}
|
|
98
|
-
/**
|
|
99
|
-
* @description
|
|
100
|
-
* Returns an array that represents the path from the top-level form to this control.
|
|
101
|
-
* Each index is the string name of the control on that level.
|
|
102
|
-
*/
|
|
103
|
-
get path() {
|
|
104
|
-
return [];
|
|
105
|
-
}
|
|
106
|
-
/**
|
|
107
|
-
* @description
|
|
108
|
-
* The `FormControl` bound to this directive.
|
|
109
|
-
*/
|
|
110
|
-
get control() {
|
|
111
|
-
return this.form;
|
|
112
|
-
}
|
|
113
|
-
/**
|
|
114
|
-
* @description
|
|
115
|
-
* Sets the new value for the view model and emits an `ngModelChange` event.
|
|
116
|
-
*
|
|
117
|
-
* @param newValue The new value for the view model.
|
|
118
|
-
*/
|
|
119
|
-
viewToModelUpdate(newValue) {
|
|
120
|
-
this.viewModel = newValue;
|
|
121
|
-
this.update.emit(newValue);
|
|
122
|
-
}
|
|
123
|
-
_isControlChanged(changes) {
|
|
124
|
-
return changes.hasOwnProperty('form');
|
|
125
|
-
}
|
|
126
|
-
}
|
|
127
|
-
/**
|
|
128
|
-
* @description
|
|
129
|
-
* Static property used to track whether any ngModel warnings have been sent across
|
|
130
|
-
* all instances of FormControlDirective. Used to support warning config of "once".
|
|
131
|
-
*
|
|
132
|
-
* @internal
|
|
133
|
-
*/
|
|
134
|
-
FormControlDirective._ngModelWarningSentOnce = false;
|
|
135
|
-
FormControlDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0-next.4", ngImport: i0, type: FormControlDirective, deps: [{ 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 }, { token: CALL_SET_DISABLED_STATE, optional: true }], target: i0.ɵɵFactoryTarget.Directive });
|
|
136
|
-
FormControlDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.0.0-next.4", type: FormControlDirective, selector: "[formControl]", inputs: { form: ["formControl", "form"], isDisabled: ["disabled", "isDisabled"], model: ["ngModel", "model"] }, outputs: { update: "ngModelChange" }, providers: [formControlBinding], exportAs: ["ngForm"], usesInheritance: true, usesOnChanges: true, ngImport: i0 });
|
|
137
|
-
export { FormControlDirective };
|
|
138
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0-next.4", ngImport: i0, type: FormControlDirective, decorators: [{
|
|
139
|
-
type: Directive,
|
|
140
|
-
args: [{ selector: '[formControl]', providers: [formControlBinding], exportAs: 'ngForm' }]
|
|
141
|
-
}], ctorParameters: function () { return [{ type: undefined, decorators: [{
|
|
142
|
-
type: Optional
|
|
143
|
-
}, {
|
|
144
|
-
type: Self
|
|
145
|
-
}, {
|
|
146
|
-
type: Inject,
|
|
147
|
-
args: [NG_VALIDATORS]
|
|
148
|
-
}] }, { type: undefined, decorators: [{
|
|
149
|
-
type: Optional
|
|
150
|
-
}, {
|
|
151
|
-
type: Self
|
|
152
|
-
}, {
|
|
153
|
-
type: Inject,
|
|
154
|
-
args: [NG_ASYNC_VALIDATORS]
|
|
155
|
-
}] }, { type: undefined, decorators: [{
|
|
156
|
-
type: Optional
|
|
157
|
-
}, {
|
|
158
|
-
type: Self
|
|
159
|
-
}, {
|
|
160
|
-
type: Inject,
|
|
161
|
-
args: [NG_VALUE_ACCESSOR]
|
|
162
|
-
}] }, { type: undefined, decorators: [{
|
|
163
|
-
type: Optional
|
|
164
|
-
}, {
|
|
165
|
-
type: Inject,
|
|
166
|
-
args: [NG_MODEL_WITH_FORM_CONTROL_WARNING]
|
|
167
|
-
}] }, { type: undefined, decorators: [{
|
|
168
|
-
type: Optional
|
|
169
|
-
}, {
|
|
170
|
-
type: Inject,
|
|
171
|
-
args: [CALL_SET_DISABLED_STATE]
|
|
172
|
-
}] }]; }, propDecorators: { form: [{
|
|
173
|
-
type: Input,
|
|
174
|
-
args: ['formControl']
|
|
175
|
-
}], isDisabled: [{
|
|
176
|
-
type: Input,
|
|
177
|
-
args: ['disabled']
|
|
178
|
-
}], model: [{
|
|
179
|
-
type: Input,
|
|
180
|
-
args: ['ngModel']
|
|
181
|
-
}], update: [{
|
|
182
|
-
type: Output,
|
|
183
|
-
args: ['ngModelChange']
|
|
184
|
-
}] } });
|
|
185
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form_control_directive.js","sourceRoot":"","sources":["../../../../../../../../packages/forms/src/directives/reactive_directives/form_control_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 {Directive, EventEmitter, forwardRef, Inject, InjectionToken, Input, OnChanges, OnDestroy, Optional, Output, Provider, Self, SimpleChanges} from '@angular/core';\n\nimport {FormControl} from '../../model/form_control';\nimport {NG_ASYNC_VALIDATORS, NG_VALIDATORS} from '../../validators';\nimport {ControlValueAccessor, NG_VALUE_ACCESSOR} from '../control_value_accessor';\nimport {NgControl} from '../ng_control';\nimport {disabledAttrWarning} from '../reactive_errors';\nimport {_ngModelWarning, CALL_SET_DISABLED_STATE, cleanUpControl, isPropertyUpdated, selectValueAccessor, SetDisabledStateOption, setUpControl} from '../shared';\nimport {AsyncValidator, AsyncValidatorFn, Validator, ValidatorFn} from '../validators';\n\n\n/**\n * Token to provide to turn off the ngModel warning on formControl and formControlName.\n */\nexport const NG_MODEL_WITH_FORM_CONTROL_WARNING =\n    new InjectionToken('NgModelWithFormControlWarning');\n\nconst formControlBinding: Provider = {\n  provide: NgControl,\n  useExisting: forwardRef(() => FormControlDirective)\n};\n\n/**\n * @description\n * Synchronizes a standalone `FormControl` instance to a form control element.\n *\n * Note that support for using the `ngModel` input property and `ngModelChange` event with reactive\n * form directives was deprecated in Angular v6 and is scheduled for removal in\n * a future version of Angular.\n * For details, see [Deprecated features](guide/deprecations#ngmodel-with-reactive-forms).\n *\n * @see [Reactive Forms Guide](guide/reactive-forms)\n * @see `FormControl`\n * @see `AbstractControl`\n *\n * @usageNotes\n *\n * The following example shows how to register a standalone control and set its value.\n *\n * {@example forms/ts/simpleFormControl/simple_form_control_example.ts region='Component'}\n *\n * @ngModule ReactiveFormsModule\n * @publicApi\n */\n@Directive({selector: '[formControl]', providers: [formControlBinding], exportAs: 'ngForm'})\nexport class FormControlDirective extends NgControl implements OnChanges, OnDestroy {\n  /**\n   * Internal reference to the view model value.\n   * @nodoc\n   */\n  viewModel: any;\n\n  /**\n   * @description\n   * Tracks the `FormControl` instance bound to the directive.\n   */\n  // TODO(issue/24571): remove '!'.\n  @Input('formControl') form!: FormControl;\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 FormControlDirective. 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 `FormControlDirective` instance. Used to support warning config of \"always\".\n   *\n   * @internal\n   */\n  _ngModelWarningSent = false;\n\n  constructor(\n      @Optional() @Self() @Inject(NG_VALIDATORS) validators: (Validator|ValidatorFn)[],\n      @Optional() @Self() @Inject(NG_ASYNC_VALIDATORS) asyncValidators:\n          (AsyncValidator|AsyncValidatorFn)[],\n      @Optional() @Self() @Inject(NG_VALUE_ACCESSOR) valueAccessors: ControlValueAccessor[],\n      @Optional() @Inject(NG_MODEL_WITH_FORM_CONTROL_WARNING) private _ngModelWarningConfig: string|\n      null,\n      @Optional() @Inject(CALL_SET_DISABLED_STATE) private callSetDisabledState?:\n          SetDisabledStateOption) {\n    super();\n    this._setValidators(validators);\n    this._setAsyncValidators(asyncValidators);\n    this.valueAccessor = selectValueAccessor(this, valueAccessors);\n  }\n\n  /** @nodoc */\n  ngOnChanges(changes: SimpleChanges): void {\n    if (this._isControlChanged(changes)) {\n      const previousForm = changes['form'].previousValue;\n      if (previousForm) {\n        cleanUpControl(previousForm, this, /* validateControlPresenceOnChange */ false);\n      }\n      setUpControl(this.form, this, this.callSetDisabledState);\n      this.form.updateValueAndValidity({emitEvent: false});\n    }\n    if (isPropertyUpdated(changes, this.viewModel)) {\n      if (typeof ngDevMode === 'undefined' || ngDevMode) {\n        _ngModelWarning('formControl', FormControlDirective, this, this._ngModelWarningConfig);\n      }\n      this.form.setValue(this.model);\n      this.viewModel = this.model;\n    }\n  }\n\n  /** @nodoc */\n  ngOnDestroy() {\n    if (this.form) {\n      cleanUpControl(this.form, this, /* validateControlPresenceOnChange */ false);\n    }\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 [];\n  }\n\n  /**\n   * @description\n   * The `FormControl` bound to this directive.\n   */\n  override get control(): FormControl {\n    return this.form;\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  private _isControlChanged(changes: {[key: string]: any}): boolean {\n    return changes.hasOwnProperty('form');\n  }\n}\n"]}
|
|
@@ -1,209 +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/reactive-forms)
|
|
31
|
-
* @see `FormControl`
|
|
32
|
-
* @see `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
|
-
* For details, see [Deprecated features](guide/deprecations#ngmodel-with-reactive-forms).
|
|
55
|
-
*
|
|
56
|
-
* @ngModule ReactiveFormsModule
|
|
57
|
-
* @publicApi
|
|
58
|
-
*/
|
|
59
|
-
class FormControlName extends NgControl {
|
|
60
|
-
/**
|
|
61
|
-
* @description
|
|
62
|
-
* Triggers a warning in dev mode that this input should not be used with reactive forms.
|
|
63
|
-
*/
|
|
64
|
-
set isDisabled(isDisabled) {
|
|
65
|
-
if (typeof ngDevMode === 'undefined' || ngDevMode) {
|
|
66
|
-
console.warn(disabledAttrWarning);
|
|
67
|
-
}
|
|
68
|
-
}
|
|
69
|
-
constructor(parent, validators, asyncValidators, valueAccessors, _ngModelWarningConfig) {
|
|
70
|
-
super();
|
|
71
|
-
this._ngModelWarningConfig = _ngModelWarningConfig;
|
|
72
|
-
this._added = false;
|
|
73
|
-
/** @deprecated as of v6 */
|
|
74
|
-
this.update = new EventEmitter();
|
|
75
|
-
/**
|
|
76
|
-
* @description
|
|
77
|
-
* Instance property used to track whether an ngModel warning has been sent out for this
|
|
78
|
-
* particular FormControlName instance. Used to support warning config of "always".
|
|
79
|
-
*
|
|
80
|
-
* @internal
|
|
81
|
-
*/
|
|
82
|
-
this._ngModelWarningSent = false;
|
|
83
|
-
this._parent = parent;
|
|
84
|
-
this._setValidators(validators);
|
|
85
|
-
this._setAsyncValidators(asyncValidators);
|
|
86
|
-
this.valueAccessor = selectValueAccessor(this, valueAccessors);
|
|
87
|
-
}
|
|
88
|
-
/** @nodoc */
|
|
89
|
-
ngOnChanges(changes) {
|
|
90
|
-
if (!this._added)
|
|
91
|
-
this._setUpControl();
|
|
92
|
-
if (isPropertyUpdated(changes, this.viewModel)) {
|
|
93
|
-
if (typeof ngDevMode === 'undefined' || ngDevMode) {
|
|
94
|
-
_ngModelWarning('formControlName', FormControlName, this, this._ngModelWarningConfig);
|
|
95
|
-
}
|
|
96
|
-
this.viewModel = this.model;
|
|
97
|
-
this.formDirective.updateModel(this, this.model);
|
|
98
|
-
}
|
|
99
|
-
}
|
|
100
|
-
/** @nodoc */
|
|
101
|
-
ngOnDestroy() {
|
|
102
|
-
if (this.formDirective) {
|
|
103
|
-
this.formDirective.removeControl(this);
|
|
104
|
-
}
|
|
105
|
-
}
|
|
106
|
-
/**
|
|
107
|
-
* @description
|
|
108
|
-
* Sets the new value for the view model and emits an `ngModelChange` event.
|
|
109
|
-
*
|
|
110
|
-
* @param newValue The new value for the view model.
|
|
111
|
-
*/
|
|
112
|
-
viewToModelUpdate(newValue) {
|
|
113
|
-
this.viewModel = newValue;
|
|
114
|
-
this.update.emit(newValue);
|
|
115
|
-
}
|
|
116
|
-
/**
|
|
117
|
-
* @description
|
|
118
|
-
* Returns an array that represents the path from the top-level form to this control.
|
|
119
|
-
* Each index is the string name of the control on that level.
|
|
120
|
-
*/
|
|
121
|
-
get path() {
|
|
122
|
-
return controlPath(this.name == null ? this.name : this.name.toString(), this._parent);
|
|
123
|
-
}
|
|
124
|
-
/**
|
|
125
|
-
* @description
|
|
126
|
-
* The top-level directive for this group if present, otherwise null.
|
|
127
|
-
*/
|
|
128
|
-
get formDirective() {
|
|
129
|
-
return this._parent ? this._parent.formDirective : null;
|
|
130
|
-
}
|
|
131
|
-
_checkParentType() {
|
|
132
|
-
if (typeof ngDevMode === 'undefined' || ngDevMode) {
|
|
133
|
-
if (!(this._parent instanceof FormGroupName) &&
|
|
134
|
-
this._parent instanceof AbstractFormGroupDirective) {
|
|
135
|
-
throw ngModelGroupException();
|
|
136
|
-
}
|
|
137
|
-
else if (!(this._parent instanceof FormGroupName) &&
|
|
138
|
-
!(this._parent instanceof FormGroupDirective) &&
|
|
139
|
-
!(this._parent instanceof FormArrayName)) {
|
|
140
|
-
throw controlParentException();
|
|
141
|
-
}
|
|
142
|
-
}
|
|
143
|
-
}
|
|
144
|
-
_setUpControl() {
|
|
145
|
-
this._checkParentType();
|
|
146
|
-
this.control = this.formDirective.addControl(this);
|
|
147
|
-
this._added = true;
|
|
148
|
-
}
|
|
149
|
-
}
|
|
150
|
-
/**
|
|
151
|
-
* @description
|
|
152
|
-
* Static property used to track whether any ngModel warnings have been sent across
|
|
153
|
-
* all instances of FormControlName. Used to support warning config of "once".
|
|
154
|
-
*
|
|
155
|
-
* @internal
|
|
156
|
-
*/
|
|
157
|
-
FormControlName._ngModelWarningSentOnce = false;
|
|
158
|
-
FormControlName.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0-next.4", 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 });
|
|
159
|
-
FormControlName.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.0.0-next.4", 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 });
|
|
160
|
-
export { FormControlName };
|
|
161
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0-next.4", ngImport: i0, type: FormControlName, decorators: [{
|
|
162
|
-
type: Directive,
|
|
163
|
-
args: [{ selector: '[formControlName]', providers: [controlNameBinding] }]
|
|
164
|
-
}], ctorParameters: function () { return [{ type: i1.ControlContainer, decorators: [{
|
|
165
|
-
type: Optional
|
|
166
|
-
}, {
|
|
167
|
-
type: Host
|
|
168
|
-
}, {
|
|
169
|
-
type: SkipSelf
|
|
170
|
-
}] }, { type: undefined, decorators: [{
|
|
171
|
-
type: Optional
|
|
172
|
-
}, {
|
|
173
|
-
type: Self
|
|
174
|
-
}, {
|
|
175
|
-
type: Inject,
|
|
176
|
-
args: [NG_VALIDATORS]
|
|
177
|
-
}] }, { type: undefined, decorators: [{
|
|
178
|
-
type: Optional
|
|
179
|
-
}, {
|
|
180
|
-
type: Self
|
|
181
|
-
}, {
|
|
182
|
-
type: Inject,
|
|
183
|
-
args: [NG_ASYNC_VALIDATORS]
|
|
184
|
-
}] }, { type: undefined, decorators: [{
|
|
185
|
-
type: Optional
|
|
186
|
-
}, {
|
|
187
|
-
type: Self
|
|
188
|
-
}, {
|
|
189
|
-
type: Inject,
|
|
190
|
-
args: [NG_VALUE_ACCESSOR]
|
|
191
|
-
}] }, { type: undefined, decorators: [{
|
|
192
|
-
type: Optional
|
|
193
|
-
}, {
|
|
194
|
-
type: Inject,
|
|
195
|
-
args: [NG_MODEL_WITH_FORM_CONTROL_WARNING]
|
|
196
|
-
}] }]; }, propDecorators: { name: [{
|
|
197
|
-
type: Input,
|
|
198
|
-
args: ['formControlName']
|
|
199
|
-
}], isDisabled: [{
|
|
200
|
-
type: Input,
|
|
201
|
-
args: ['disabled']
|
|
202
|
-
}], model: [{
|
|
203
|
-
type: Input,
|
|
204
|
-
args: ['ngModel']
|
|
205
|
-
}], update: [{
|
|
206
|
-
type: Output,
|
|
207
|
-
args: ['ngModelChange']
|
|
208
|
-
}] } });
|
|
209
|
-
//# 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 {Directive, EventEmitter, forwardRef, Host, Inject, Input, OnChanges, OnDestroy, Optional, Output, Provider, Self, SimpleChanges, SkipSelf} 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 {controlParentException, disabledAttrWarning, ngModelGroupException} 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/reactive-forms)\n * @see `FormControl`\n * @see `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 * For details, see [Deprecated features](guide/deprecations#ngmodel-with-reactive-forms).\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  // TODO(issue/24571): remove '!'.\n  @Input('formControlName') override name!: string|number|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() @Self() @Inject(NG_ASYNC_VALIDATORS) asyncValidators:\n          (AsyncValidator|AsyncValidatorFn)[],\n      @Optional() @Self() @Inject(NG_VALUE_ACCESSOR) valueAccessors: ControlValueAccessor[],\n      @Optional() @Inject(NG_MODEL_WITH_FORM_CONTROL_WARNING) private _ngModelWarningConfig: string|\n      null) {\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 (!(this._parent instanceof FormGroupName) &&\n          this._parent instanceof AbstractFormGroupDirective) {\n        throw ngModelGroupException();\n      } else if (\n          !(this._parent instanceof FormGroupName) &&\n          !(this._parent instanceof FormGroupDirective) &&\n          !(this._parent instanceof FormArrayName)) {\n        throw controlParentException();\n      }\n    }\n  }\n\n  private _setUpControl() {\n    this._checkParentType();\n    (this as {control: FormControl}).control = this.formDirective.addControl(this);\n    this._added = true;\n  }\n}\n"]}
|