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

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (56) hide show
  1. package/{esm2020 → esm2022}/src/directives/abstract_form_group_directive.mjs +4 -4
  2. package/{esm2020 → esm2022}/src/directives/checkbox_value_accessor.mjs +4 -4
  3. package/{esm2020 → esm2022}/src/directives/control_value_accessor.mjs +7 -7
  4. package/{esm2020 → esm2022}/src/directives/default_value_accessor.mjs +4 -4
  5. package/{esm2020 → esm2022}/src/directives/ng_control_status.mjs +7 -7
  6. package/{esm2020 → esm2022}/src/directives/ng_form.mjs +4 -4
  7. package/esm2022/src/directives/ng_model.mjs +332 -0
  8. package/esm2022/src/directives/ng_model_group.mjs +95 -0
  9. package/{esm2020 → esm2022}/src/directives/ng_no_validate_directive.mjs +4 -4
  10. package/{esm2020 → esm2022}/src/directives/number_value_accessor.mjs +4 -4
  11. package/{esm2020 → esm2022}/src/directives/radio_control_value_accessor.mjs +11 -11
  12. package/{esm2020 → esm2022}/src/directives/range_value_accessor.mjs +4 -4
  13. package/esm2022/src/directives/reactive_directives/form_control_directive.mjs +185 -0
  14. package/esm2022/src/directives/reactive_directives/form_control_name.mjs +219 -0
  15. package/{esm2020 → esm2022}/src/directives/reactive_directives/form_group_directive.mjs +4 -4
  16. package/esm2022/src/directives/reactive_directives/form_group_name.mjs +247 -0
  17. package/{esm2020 → esm2022}/src/directives/select_control_value_accessor.mjs +7 -7
  18. package/{esm2020 → esm2022}/src/directives/select_multiple_control_value_accessor.mjs +7 -7
  19. package/{esm2020 → esm2022}/src/directives/validators.mjs +28 -28
  20. package/{esm2020 → esm2022}/src/directives.mjs +43 -43
  21. package/{esm2020 → esm2022}/src/form_builder.mjs +10 -10
  22. package/{esm2020 → esm2022}/src/form_providers.mjs +9 -9
  23. package/esm2022/src/model/abstract_model.mjs +939 -0
  24. package/esm2022/src/validators.mjs +678 -0
  25. package/{esm2020 → esm2022}/src/version.mjs +1 -1
  26. package/{fesm2020 → fesm2022}/forms.mjs +228 -187
  27. package/fesm2022/forms.mjs.map +1 -0
  28. package/index.d.ts +21 -21
  29. package/package.json +8 -14
  30. package/esm2020/src/directives/ng_model.mjs +0 -326
  31. package/esm2020/src/directives/ng_model_group.mjs +0 -89
  32. package/esm2020/src/directives/reactive_directives/form_control_directive.mjs +0 -185
  33. package/esm2020/src/directives/reactive_directives/form_control_name.mjs +0 -209
  34. package/esm2020/src/directives/reactive_directives/form_group_name.mjs +0 -227
  35. package/esm2020/src/model/abstract_model.mjs +0 -939
  36. package/esm2020/src/validators.mjs +0 -679
  37. package/fesm2015/forms.mjs +0 -7272
  38. package/fesm2015/forms.mjs.map +0 -1
  39. package/fesm2020/forms.mjs.map +0 -1
  40. /package/{esm2020 → esm2022}/forms.mjs +0 -0
  41. /package/{esm2020 → esm2022}/index.mjs +0 -0
  42. /package/{esm2020 → esm2022}/public_api.mjs +0 -0
  43. /package/{esm2020 → esm2022}/src/directives/abstract_control_directive.mjs +0 -0
  44. /package/{esm2020 → esm2022}/src/directives/control_container.mjs +0 -0
  45. /package/{esm2020 → esm2022}/src/directives/error_examples.mjs +0 -0
  46. /package/{esm2020 → esm2022}/src/directives/form_interface.mjs +0 -0
  47. /package/{esm2020 → esm2022}/src/directives/ng_control.mjs +0 -0
  48. /package/{esm2020 → esm2022}/src/directives/reactive_errors.mjs +0 -0
  49. /package/{esm2020 → esm2022}/src/directives/shared.mjs +0 -0
  50. /package/{esm2020 → esm2022}/src/directives/template_driven_errors.mjs +0 -0
  51. /package/{esm2020 → esm2022}/src/errors.mjs +0 -0
  52. /package/{esm2020 → esm2022}/src/forms.mjs +0 -0
  53. /package/{esm2020 → esm2022}/src/model/form_array.mjs +0 -0
  54. /package/{esm2020 → esm2022}/src/model/form_control.mjs +0 -0
  55. /package/{esm2020 → esm2022}/src/model/form_group.mjs +0 -0
  56. /package/{esm2020 → esm2022}/src/util.mjs +0 -0
package/index.d.ts CHANGED
@@ -1,5 +1,5 @@
1
1
  /**
2
- * @license Angular v16.0.0-next.3
2
+ * @license Angular v16.0.0-next.5
3
3
  * (c) 2010-2022 Google LLC. https://angular.io/
4
4
  * License: MIT
5
5
  */
@@ -1371,7 +1371,7 @@ export declare class EmailValidator extends AbstractValidatorDirective {
1371
1371
  /** @nodoc */
1372
1372
  enabled(input: boolean): boolean;
1373
1373
  static ɵfac: i0.ɵɵFactoryDeclaration<EmailValidator, never>;
1374
- static ɵdir: i0.ɵɵDirectiveDeclaration<EmailValidator, "[email][formControlName],[email][formControl],[email][ngModel]", never, { "email": "email"; }, {}, never, never, false, never>;
1374
+ static ɵdir: i0.ɵɵDirectiveDeclaration<EmailValidator, "[email][formControlName],[email][formControl],[email][ngModel]", never, { "email": { "alias": "email"; "required": false; }; }, {}, never, never, false, never>;
1375
1375
  }
1376
1376
 
1377
1377
  /**
@@ -1828,7 +1828,7 @@ export declare class FormArrayName extends ControlContainer implements OnInit, O
1828
1828
  get path(): string[];
1829
1829
  private _checkParentType;
1830
1830
  static ɵfac: i0.ɵɵFactoryDeclaration<FormArrayName, [{ optional: true; host: true; skipSelf: true; }, { optional: true; self: true; }, { optional: true; self: true; }]>;
1831
- static ɵdir: i0.ɵɵDirectiveDeclaration<FormArrayName, "[formArrayName]", never, { "name": "formArrayName"; }, {}, never, never, false, never>;
1831
+ static ɵdir: i0.ɵɵDirectiveDeclaration<FormArrayName, "[formArrayName]", never, { "name": { "alias": "formArrayName"; "required": false; }; }, {}, never, never, false, never>;
1832
1832
  }
1833
1833
 
1834
1834
  declare const formArrayNameProvider: any;
@@ -2299,7 +2299,7 @@ export declare class FormControlDirective extends NgControl implements OnChanges
2299
2299
  viewToModelUpdate(newValue: any): void;
2300
2300
  private _isControlChanged;
2301
2301
  static ɵfac: i0.ɵɵFactoryDeclaration<FormControlDirective, [{ optional: true; self: true; }, { optional: true; self: true; }, { optional: true; self: true; }, { optional: true; }, { optional: true; }]>;
2302
- static ɵdir: i0.ɵɵDirectiveDeclaration<FormControlDirective, "[formControl]", ["ngForm"], { "form": "formControl"; "isDisabled": "disabled"; "model": "ngModel"; }, { "update": "ngModelChange"; }, never, never, false, never>;
2302
+ static ɵdir: i0.ɵɵDirectiveDeclaration<FormControlDirective, "[formControl]", ["ngForm"], { "form": { "alias": "formControl"; "required": false; }; "isDisabled": { "alias": "disabled"; "required": false; }; "model": { "alias": "ngModel"; "required": false; }; }, { "update": "ngModelChange"; }, never, never, false, never>;
2303
2303
  }
2304
2304
 
2305
2305
  /**
@@ -2389,7 +2389,7 @@ export declare class FormControlName extends NgControl implements OnChanges, OnD
2389
2389
  private _checkParentType;
2390
2390
  private _setUpControl;
2391
2391
  static ɵfac: i0.ɵɵFactoryDeclaration<FormControlName, [{ optional: true; host: true; skipSelf: true; }, { optional: true; self: true; }, { optional: true; self: true; }, { optional: true; self: true; }, { optional: true; }]>;
2392
- static ɵdir: i0.ɵɵDirectiveDeclaration<FormControlName, "[formControlName]", never, { "name": "formControlName"; "isDisabled": "disabled"; "model": "ngModel"; }, { "update": "ngModelChange"; }, never, never, false, never>;
2392
+ static ɵdir: i0.ɵɵDirectiveDeclaration<FormControlName, "[formControlName]", never, { "name": { "alias": "formControlName"; "required": false; }; "isDisabled": { "alias": "disabled"; "required": false; }; "model": { "alias": "ngModel"; "required": false; }; }, { "update": "ngModelChange"; }, never, never, false, never>;
2393
2393
  }
2394
2394
 
2395
2395
  /**
@@ -2972,7 +2972,7 @@ export declare class FormGroupDirective extends ControlContainer implements Form
2972
2972
  private _updateValidators;
2973
2973
  private _checkFormPresent;
2974
2974
  static ɵfac: i0.ɵɵFactoryDeclaration<FormGroupDirective, [{ optional: true; self: true; }, { optional: true; self: true; }, { optional: true; }]>;
2975
- static ɵdir: i0.ɵɵDirectiveDeclaration<FormGroupDirective, "[formGroup]", ["ngForm"], { "form": "formGroup"; }, { "ngSubmit": "ngSubmit"; }, never, never, false, never>;
2975
+ static ɵdir: i0.ɵɵDirectiveDeclaration<FormGroupDirective, "[formGroup]", ["ngForm"], { "form": { "alias": "formGroup"; "required": false; }; }, { "ngSubmit": "ngSubmit"; }, never, never, false, never>;
2976
2976
  }
2977
2977
 
2978
2978
  /**
@@ -3035,7 +3035,7 @@ export declare class FormGroupName extends AbstractFormGroupDirective implements
3035
3035
  name: string | number | null;
3036
3036
  constructor(parent: ControlContainer, validators: (Validator | ValidatorFn)[], asyncValidators: (AsyncValidator | AsyncValidatorFn)[]);
3037
3037
  static ɵfac: i0.ɵɵFactoryDeclaration<FormGroupName, [{ optional: true; host: true; skipSelf: true; }, { optional: true; self: true; }, { optional: true; self: true; }]>;
3038
- static ɵdir: i0.ɵɵDirectiveDeclaration<FormGroupName, "[formGroupName]", never, { "name": "formGroupName"; }, {}, never, never, false, never>;
3038
+ static ɵdir: i0.ɵɵDirectiveDeclaration<FormGroupName, "[formGroupName]", never, { "name": { "alias": "formGroupName"; "required": false; }; }, {}, never, never, false, never>;
3039
3039
  }
3040
3040
 
3041
3041
  declare type FormHooks = 'change' | 'blur' | 'submit';
@@ -3420,7 +3420,7 @@ export declare class MaxLengthValidator extends AbstractValidatorDirective {
3420
3420
  */
3421
3421
  maxlength: string | number | null;
3422
3422
  static ɵfac: i0.ɵɵFactoryDeclaration<MaxLengthValidator, never>;
3423
- static ɵdir: i0.ɵɵDirectiveDeclaration<MaxLengthValidator, "[maxlength][formControlName],[maxlength][formControl],[maxlength][ngModel]", never, { "maxlength": "maxlength"; }, {}, never, never, false, never>;
3423
+ static ɵdir: i0.ɵɵDirectiveDeclaration<MaxLengthValidator, "[maxlength][formControlName],[maxlength][formControl],[maxlength][ngModel]", never, { "maxlength": { "alias": "maxlength"; "required": false; }; }, {}, never, never, false, never>;
3424
3424
  }
3425
3425
 
3426
3426
  /**
@@ -3451,7 +3451,7 @@ export declare class MaxValidator extends AbstractValidatorDirective {
3451
3451
  */
3452
3452
  max: string | number | null;
3453
3453
  static ɵfac: i0.ɵɵFactoryDeclaration<MaxValidator, never>;
3454
- static ɵdir: i0.ɵɵDirectiveDeclaration<MaxValidator, "input[type=number][max][formControlName],input[type=number][max][formControl],input[type=number][max][ngModel]", never, { "max": "max"; }, {}, never, never, false, never>;
3454
+ static ɵdir: i0.ɵɵDirectiveDeclaration<MaxValidator, "input[type=number][max][formControlName],input[type=number][max][formControl],input[type=number][max][ngModel]", never, { "max": { "alias": "max"; "required": false; }; }, {}, never, never, false, never>;
3455
3455
  }
3456
3456
 
3457
3457
  /**
@@ -3494,7 +3494,7 @@ export declare class MinLengthValidator extends AbstractValidatorDirective {
3494
3494
  */
3495
3495
  minlength: string | number | null;
3496
3496
  static ɵfac: i0.ɵɵFactoryDeclaration<MinLengthValidator, never>;
3497
- static ɵdir: i0.ɵɵDirectiveDeclaration<MinLengthValidator, "[minlength][formControlName],[minlength][formControl],[minlength][ngModel]", never, { "minlength": "minlength"; }, {}, never, never, false, never>;
3497
+ static ɵdir: i0.ɵɵDirectiveDeclaration<MinLengthValidator, "[minlength][formControlName],[minlength][formControl],[minlength][ngModel]", never, { "minlength": { "alias": "minlength"; "required": false; }; }, {}, never, never, false, never>;
3498
3498
  }
3499
3499
 
3500
3500
  /**
@@ -3525,7 +3525,7 @@ export declare class MinValidator extends AbstractValidatorDirective {
3525
3525
  */
3526
3526
  min: string | number | null;
3527
3527
  static ɵfac: i0.ɵɵFactoryDeclaration<MinValidator, never>;
3528
- static ɵdir: i0.ɵɵDirectiveDeclaration<MinValidator, "input[type=number][min][formControlName],input[type=number][min][formControl],input[type=number][min][ngModel]", never, { "min": "min"; }, {}, never, never, false, never>;
3528
+ static ɵdir: i0.ɵɵDirectiveDeclaration<MinValidator, "input[type=number][min][formControlName],input[type=number][min][formControl],input[type=number][min][ngModel]", never, { "min": { "alias": "min"; "required": false; }; }, {}, never, never, false, never>;
3529
3529
  }
3530
3530
 
3531
3531
  declare const modelGroupProvider: any;
@@ -3891,7 +3891,7 @@ export declare class NgForm extends ControlContainer implements Form, AfterViewI
3891
3891
  private _setUpdateStrategy;
3892
3892
  private _findContainer;
3893
3893
  static ɵfac: i0.ɵɵFactoryDeclaration<NgForm, [{ optional: true; self: true; }, { optional: true; self: true; }, { optional: true; }]>;
3894
- static ɵdir: i0.ɵɵDirectiveDeclaration<NgForm, "form:not([ngNoForm]):not([formGroup]),ng-form,[ngForm]", ["ngForm"], { "options": "ngFormOptions"; }, { "ngSubmit": "ngSubmit"; }, never, never, false, never>;
3894
+ static ɵdir: i0.ɵɵDirectiveDeclaration<NgForm, "form:not([ngNoForm]):not([formGroup]),ng-form,[ngForm]", ["ngForm"], { "options": { "alias": "ngFormOptions"; "required": false; }; }, { "ngSubmit": "ngSubmit"; }, never, never, false, never>;
3895
3895
  }
3896
3896
 
3897
3897
  declare const ngGroupStatusHost: {
@@ -4078,7 +4078,7 @@ export declare class NgModel extends NgControl implements OnChanges, OnDestroy {
4078
4078
  private _updateDisabled;
4079
4079
  private _getPath;
4080
4080
  static ɵfac: i0.ɵɵFactoryDeclaration<NgModel, [{ optional: true; host: true; }, { optional: true; self: true; }, { optional: true; self: true; }, { optional: true; self: true; }, { optional: true; }, { optional: true; }]>;
4081
- static ɵdir: i0.ɵɵDirectiveDeclaration<NgModel, "[ngModel]:not([formControlName]):not([formControl])", ["ngModel"], { "name": "name"; "isDisabled": "disabled"; "model": "ngModel"; "options": "ngModelOptions"; }, { "update": "ngModelChange"; }, never, never, false, never>;
4081
+ static ɵdir: i0.ɵɵDirectiveDeclaration<NgModel, "[ngModel]:not([formControlName]):not([formControl])", ["ngModel"], { "name": { "alias": "name"; "required": false; }; "isDisabled": { "alias": "disabled"; "required": false; }; "model": { "alias": "ngModel"; "required": false; }; "options": { "alias": "ngModelOptions"; "required": false; }; }, { "update": "ngModelChange"; }, never, never, false, never>;
4082
4082
  }
4083
4083
 
4084
4084
  /**
@@ -4116,7 +4116,7 @@ export declare class NgModelGroup extends AbstractFormGroupDirective implements
4116
4116
  name: string;
4117
4117
  constructor(parent: ControlContainer, validators: (Validator | ValidatorFn)[], asyncValidators: (AsyncValidator | AsyncValidatorFn)[]);
4118
4118
  static ɵfac: i0.ɵɵFactoryDeclaration<NgModelGroup, [{ host: true; skipSelf: true; }, { optional: true; self: true; }, { optional: true; self: true; }]>;
4119
- static ɵdir: i0.ɵɵDirectiveDeclaration<NgModelGroup, "[ngModelGroup]", ["ngModelGroup"], { "name": "ngModelGroup"; }, {}, never, never, false, never>;
4119
+ static ɵdir: i0.ɵɵDirectiveDeclaration<NgModelGroup, "[ngModelGroup]", ["ngModelGroup"], { "name": { "alias": "ngModelGroup"; "required": false; }; }, {}, never, never, false, never>;
4120
4120
  }
4121
4121
 
4122
4122
  /**
@@ -4154,7 +4154,7 @@ export declare class NgSelectOption implements OnDestroy {
4154
4154
  /** @nodoc */
4155
4155
  ngOnDestroy(): void;
4156
4156
  static ɵfac: i0.ɵɵFactoryDeclaration<NgSelectOption, [null, null, { optional: true; host: true; }]>;
4157
- static ɵdir: i0.ɵɵDirectiveDeclaration<NgSelectOption, "option", never, { "ngValue": "ngValue"; "value": "value"; }, {}, never, never, false, never>;
4157
+ static ɵdir: i0.ɵɵDirectiveDeclaration<NgSelectOption, "option", never, { "ngValue": { "alias": "ngValue"; "required": false; }; "value": { "alias": "value"; "required": false; }; }, {}, never, never, false, never>;
4158
4158
  }
4159
4159
 
4160
4160
  /**
@@ -4271,7 +4271,7 @@ export declare class PatternValidator extends AbstractValidatorDirective {
4271
4271
  */
4272
4272
  pattern: string | RegExp;
4273
4273
  static ɵfac: i0.ɵɵFactoryDeclaration<PatternValidator, never>;
4274
- static ɵdir: i0.ɵɵDirectiveDeclaration<PatternValidator, "[pattern][formControlName],[pattern][formControl],[pattern][ngModel]", never, { "pattern": "pattern"; }, {}, never, never, false, never>;
4274
+ static ɵdir: i0.ɵɵDirectiveDeclaration<PatternValidator, "[pattern][formControlName],[pattern][formControl],[pattern][ngModel]", never, { "pattern": { "alias": "pattern"; "required": false; }; }, {}, never, never, false, never>;
4275
4275
  }
4276
4276
 
4277
4277
  /**
@@ -4404,7 +4404,7 @@ export declare class RadioControlValueAccessor extends BuiltInControlValueAccess
4404
4404
  fireUncheck(value: any): void;
4405
4405
  private _checkName;
4406
4406
  static ɵfac: i0.ɵɵFactoryDeclaration<RadioControlValueAccessor, never>;
4407
- static ɵdir: i0.ɵɵDirectiveDeclaration<RadioControlValueAccessor, "input[type=radio][formControlName],input[type=radio][formControl],input[type=radio][ngModel]", never, { "name": "name"; "formControlName": "formControlName"; "value": "value"; }, {}, never, never, false, never>;
4407
+ static ɵdir: i0.ɵɵDirectiveDeclaration<RadioControlValueAccessor, "input[type=radio][formControlName],input[type=radio][formControl],input[type=radio][ngModel]", never, { "name": { "alias": "name"; "required": false; }; "formControlName": { "alias": "formControlName"; "required": false; }; "value": { "alias": "value"; "required": false; }; }, {}, never, never, false, never>;
4408
4408
  }
4409
4409
 
4410
4410
  /**
@@ -4515,7 +4515,7 @@ export declare class RequiredValidator extends AbstractValidatorDirective {
4515
4515
  /** @nodoc */
4516
4516
  enabled(input: boolean): boolean;
4517
4517
  static ɵfac: i0.ɵɵFactoryDeclaration<RequiredValidator, never>;
4518
- static ɵdir: i0.ɵɵDirectiveDeclaration<RequiredValidator, ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", never, { "required": "required"; }, {}, never, never, false, never>;
4518
+ static ɵdir: i0.ɵɵDirectiveDeclaration<RequiredValidator, ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", never, { "required": { "alias": "required"; "required": false; }; }, {}, never, never, false, never>;
4519
4519
  }
4520
4520
 
4521
4521
  /**
@@ -4595,7 +4595,7 @@ export declare class SelectControlValueAccessor extends BuiltInControlValueAcces
4595
4595
  */
4596
4596
  registerOnChange(fn: (value: any) => any): void;
4597
4597
  static ɵfac: i0.ɵɵFactoryDeclaration<SelectControlValueAccessor, never>;
4598
- static ɵdir: i0.ɵɵDirectiveDeclaration<SelectControlValueAccessor, "select:not([multiple])[formControlName],select:not([multiple])[formControl],select:not([multiple])[ngModel]", never, { "compareWith": "compareWith"; }, {}, never, never, false, never>;
4598
+ static ɵdir: i0.ɵɵDirectiveDeclaration<SelectControlValueAccessor, "select:not([multiple])[formControlName],select:not([multiple])[formControl],select:not([multiple])[ngModel]", never, { "compareWith": { "alias": "compareWith"; "required": false; }; }, {}, never, never, false, never>;
4599
4599
  }
4600
4600
 
4601
4601
  /**
@@ -4658,7 +4658,7 @@ export declare class SelectMultipleControlValueAccessor extends BuiltInControlVa
4658
4658
  */
4659
4659
  registerOnChange(fn: (value: any) => any): void;
4660
4660
  static ɵfac: i0.ɵɵFactoryDeclaration<SelectMultipleControlValueAccessor, never>;
4661
- static ɵdir: i0.ɵɵDirectiveDeclaration<SelectMultipleControlValueAccessor, "select[multiple][formControlName],select[multiple][formControl],select[multiple][ngModel]", never, { "compareWith": "compareWith"; }, {}, never, never, false, never>;
4661
+ static ɵdir: i0.ɵɵDirectiveDeclaration<SelectMultipleControlValueAccessor, "select[multiple][formControlName],select[multiple][formControl],select[multiple][ngModel]", never, { "compareWith": { "alias": "compareWith"; "required": false; }; }, {}, never, never, false, never>;
4662
4662
  }
4663
4663
 
4664
4664
  /**
@@ -5331,7 +5331,7 @@ export declare class ɵNgSelectMultipleOption implements OnDestroy {
5331
5331
  /** @nodoc */
5332
5332
  ngOnDestroy(): void;
5333
5333
  static ɵfac: i0.ɵɵFactoryDeclaration<ɵNgSelectMultipleOption, [null, null, { optional: true; host: true; }]>;
5334
- static ɵdir: i0.ɵɵDirectiveDeclaration<ɵNgSelectMultipleOption, "option", never, { "ngValue": "ngValue"; "value": "value"; }, {}, never, never, false, never>;
5334
+ static ɵdir: i0.ɵɵDirectiveDeclaration<ɵNgSelectMultipleOption, "option", never, { "ngValue": { "alias": "ngValue"; "required": false; }; "value": { "alias": "value"; "required": false; }; }, {}, never, never, false, never>;
5335
5335
  }
5336
5336
 
5337
5337
  /**
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@angular/forms",
3
- "version": "16.0.0-next.3",
3
+ "version": "16.0.0-next.5",
4
4
  "description": "Angular - directives and services for creating forms",
5
5
  "author": "angular",
6
6
  "license": "MIT",
@@ -11,9 +11,9 @@
11
11
  "tslib": "^2.3.0"
12
12
  },
13
13
  "peerDependencies": {
14
- "@angular/core": "16.0.0-next.3",
15
- "@angular/common": "16.0.0-next.3",
16
- "@angular/platform-browser": "16.0.0-next.3",
14
+ "@angular/core": "16.0.0-next.5",
15
+ "@angular/common": "16.0.0-next.5",
16
+ "@angular/platform-browser": "16.0.0-next.5",
17
17
  "rxjs": "^6.5.3 || ^7.4.0"
18
18
  },
19
19
  "repository": {
@@ -42,12 +42,8 @@
42
42
  ]
43
43
  },
44
44
  "sideEffects": false,
45
- "fesm2020": "./fesm2020/forms.mjs",
46
- "fesm2015": "./fesm2015/forms.mjs",
47
- "esm2020": "./esm2020/forms.mjs",
45
+ "module": "./fesm2022/forms.mjs",
48
46
  "typings": "./index.d.ts",
49
- "module": "./fesm2015/forms.mjs",
50
- "es2020": "./fesm2020/forms.mjs",
51
47
  "type": "module",
52
48
  "exports": {
53
49
  "./package.json": {
@@ -55,11 +51,9 @@
55
51
  },
56
52
  ".": {
57
53
  "types": "./index.d.ts",
58
- "esm2020": "./esm2020/forms.mjs",
59
- "es2020": "./fesm2020/forms.mjs",
60
- "es2015": "./fesm2015/forms.mjs",
61
- "node": "./fesm2015/forms.mjs",
62
- "default": "./fesm2020/forms.mjs"
54
+ "esm2022": "./esm2022/forms.mjs",
55
+ "esm": "./esm2022/forms.mjs",
56
+ "default": "./fesm2022/forms.mjs"
63
57
  }
64
58
  }
65
59
  }
@@ -1,326 +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 { ChangeDetectorRef, Directive, EventEmitter, forwardRef, Host, Inject, Input, Optional, Output, Self, ɵcoerceToBoolean as coerceToBoolean } from '@angular/core';
9
- import { FormControl } from '../model/form_control';
10
- import { NG_ASYNC_VALIDATORS, NG_VALIDATORS } from '../validators';
11
- import { AbstractFormGroupDirective } from './abstract_form_group_directive';
12
- import { ControlContainer } from './control_container';
13
- import { NG_VALUE_ACCESSOR } from './control_value_accessor';
14
- import { NgControl } from './ng_control';
15
- import { NgForm } from './ng_form';
16
- import { NgModelGroup } from './ng_model_group';
17
- import { CALL_SET_DISABLED_STATE, controlPath, isPropertyUpdated, selectValueAccessor, setUpControl } from './shared';
18
- import { formGroupNameException, missingNameException, modelParentException } from './template_driven_errors';
19
- import * as i0 from "@angular/core";
20
- import * as i1 from "./control_container";
21
- const formControlBinding = {
22
- provide: NgControl,
23
- useExisting: forwardRef(() => NgModel)
24
- };
25
- /**
26
- * `ngModel` forces an additional change detection run when its inputs change:
27
- * E.g.:
28
- * ```
29
- * <div>{{myModel.valid}}</div>
30
- * <input [(ngModel)]="myValue" #myModel="ngModel">
31
- * ```
32
- * I.e. `ngModel` can export itself on the element and then be used in the template.
33
- * Normally, this would result in expressions before the `input` that use the exported directive
34
- * to have an old value as they have been
35
- * dirty checked before. As this is a very common case for `ngModel`, we added this second change
36
- * detection run.
37
- *
38
- * Notes:
39
- * - this is just one extra run no matter how many `ngModel`s have been changed.
40
- * - this is a general problem when using `exportAs` for directives!
41
- */
42
- const resolvedPromise = (() => Promise.resolve())();
43
- /**
44
- * @description
45
- * Creates a `FormControl` instance from a domain model and binds it
46
- * to a form control element.
47
- *
48
- * The `FormControl` instance tracks the value, user interaction, and
49
- * validation status of the control and keeps the view synced with the model. If used
50
- * within a parent form, the directive also registers itself with the form as a child
51
- * control.
52
- *
53
- * This directive is used by itself or as part of a larger form. Use the
54
- * `ngModel` selector to activate it.
55
- *
56
- * It accepts a domain model as an optional `Input`. If you have a one-way binding
57
- * to `ngModel` with `[]` syntax, changing the domain model's value in the component
58
- * class sets the value in the view. If you have a two-way binding with `[()]` syntax
59
- * (also known as 'banana-in-a-box syntax'), the value in the UI always syncs back to
60
- * the domain model in your class.
61
- *
62
- * To inspect the properties of the associated `FormControl` (like the validity state),
63
- * export the directive into a local template variable using `ngModel` as the key (ex:
64
- * `#myVar="ngModel"`). You can then access the control using the directive's `control` property.
65
- * However, the most commonly used properties (like `valid` and `dirty`) also exist on the control
66
- * for direct access. See a full list of properties directly available in
67
- * `AbstractControlDirective`.
68
- *
69
- * @see `RadioControlValueAccessor`
70
- * @see `SelectControlValueAccessor`
71
- *
72
- * @usageNotes
73
- *
74
- * ### Using ngModel on a standalone control
75
- *
76
- * The following examples show a simple standalone control using `ngModel`:
77
- *
78
- * {@example forms/ts/simpleNgModel/simple_ng_model_example.ts region='Component'}
79
- *
80
- * When using the `ngModel` within `<form>` tags, you'll also need to supply a `name` attribute
81
- * so that the control can be registered with the parent form under that name.
82
- *
83
- * In the context of a parent form, it's often unnecessary to include one-way or two-way binding,
84
- * as the parent form syncs the value for you. You access its properties by exporting it into a
85
- * local template variable using `ngForm` such as (`#f="ngForm"`). Use the variable where
86
- * needed on form submission.
87
- *
88
- * If you do need to populate initial values into your form, using a one-way binding for
89
- * `ngModel` tends to be sufficient as long as you use the exported form's value rather
90
- * than the domain model's value on submit.
91
- *
92
- * ### Using ngModel within a form
93
- *
94
- * The following example shows controls using `ngModel` within a form:
95
- *
96
- * {@example forms/ts/simpleForm/simple_form_example.ts region='Component'}
97
- *
98
- * ### Using a standalone ngModel within a group
99
- *
100
- * The following example shows you how to use a standalone ngModel control
101
- * within a form. This controls the display of the form, but doesn't contain form data.
102
- *
103
- * ```html
104
- * <form>
105
- * <input name="login" ngModel placeholder="Login">
106
- * <input type="checkbox" ngModel [ngModelOptions]="{standalone: true}"> Show more options?
107
- * </form>
108
- * <!-- form value: {login: ''} -->
109
- * ```
110
- *
111
- * ### Setting the ngModel `name` attribute through options
112
- *
113
- * The following example shows you an alternate way to set the name attribute. Here,
114
- * an attribute identified as name is used within a custom form control component. To still be able
115
- * to specify the NgModel's name, you must specify it using the `ngModelOptions` input instead.
116
- *
117
- * ```html
118
- * <form>
119
- * <my-custom-form-control name="Nancy" ngModel [ngModelOptions]="{name: 'user'}">
120
- * </my-custom-form-control>
121
- * </form>
122
- * <!-- form value: {user: ''} -->
123
- * ```
124
- *
125
- * @ngModule FormsModule
126
- * @publicApi
127
- */
128
- class NgModel extends NgControl {
129
- constructor(parent, validators, asyncValidators, valueAccessors, _changeDetectorRef, callSetDisabledState) {
130
- super();
131
- this._changeDetectorRef = _changeDetectorRef;
132
- this.callSetDisabledState = callSetDisabledState;
133
- this.control = new FormControl();
134
- /** @internal */
135
- this._registered = false;
136
- /**
137
- * @description
138
- * Event emitter for producing the `ngModelChange` event after
139
- * the view model updates.
140
- */
141
- this.update = new EventEmitter();
142
- this._parent = parent;
143
- this._setValidators(validators);
144
- this._setAsyncValidators(asyncValidators);
145
- this.valueAccessor = selectValueAccessor(this, valueAccessors);
146
- }
147
- /** @nodoc */
148
- ngOnChanges(changes) {
149
- this._checkForErrors();
150
- if (!this._registered || 'name' in changes) {
151
- if (this._registered) {
152
- this._checkName();
153
- if (this.formDirective) {
154
- // We can't call `formDirective.removeControl(this)`, because the `name` has already been
155
- // changed. We also can't reset the name temporarily since the logic in `removeControl`
156
- // is inside a promise and it won't run immediately. We work around it by giving it an
157
- // object with the same shape instead.
158
- const oldName = changes['name'].previousValue;
159
- this.formDirective.removeControl({ name: oldName, path: this._getPath(oldName) });
160
- }
161
- }
162
- this._setUpControl();
163
- }
164
- if ('isDisabled' in changes) {
165
- this._updateDisabled(changes);
166
- }
167
- if (isPropertyUpdated(changes, this.viewModel)) {
168
- this._updateValue(this.model);
169
- this.viewModel = this.model;
170
- }
171
- }
172
- /** @nodoc */
173
- ngOnDestroy() {
174
- this.formDirective && this.formDirective.removeControl(this);
175
- }
176
- /**
177
- * @description
178
- * Returns an array that represents the path from the top-level form to this control.
179
- * Each index is the string name of the control on that level.
180
- */
181
- get path() {
182
- return this._getPath(this.name);
183
- }
184
- /**
185
- * @description
186
- * The top-level directive for this control if present, otherwise null.
187
- */
188
- get formDirective() {
189
- return this._parent ? this._parent.formDirective : null;
190
- }
191
- /**
192
- * @description
193
- * Sets the new value for the view model and emits an `ngModelChange` event.
194
- *
195
- * @param newValue The new value emitted by `ngModelChange`.
196
- */
197
- viewToModelUpdate(newValue) {
198
- this.viewModel = newValue;
199
- this.update.emit(newValue);
200
- }
201
- _setUpControl() {
202
- this._setUpdateStrategy();
203
- this._isStandalone() ? this._setUpStandalone() : this.formDirective.addControl(this);
204
- this._registered = true;
205
- }
206
- _setUpdateStrategy() {
207
- if (this.options && this.options.updateOn != null) {
208
- this.control._updateOn = this.options.updateOn;
209
- }
210
- }
211
- _isStandalone() {
212
- return !this._parent || !!(this.options && this.options.standalone);
213
- }
214
- _setUpStandalone() {
215
- setUpControl(this.control, this, this.callSetDisabledState);
216
- this.control.updateValueAndValidity({ emitEvent: false });
217
- }
218
- _checkForErrors() {
219
- if (!this._isStandalone()) {
220
- this._checkParentType();
221
- }
222
- this._checkName();
223
- }
224
- _checkParentType() {
225
- if (typeof ngDevMode === 'undefined' || ngDevMode) {
226
- if (!(this._parent instanceof NgModelGroup) &&
227
- this._parent instanceof AbstractFormGroupDirective) {
228
- throw formGroupNameException();
229
- }
230
- else if (!(this._parent instanceof NgModelGroup) && !(this._parent instanceof NgForm)) {
231
- throw modelParentException();
232
- }
233
- }
234
- }
235
- _checkName() {
236
- if (this.options && this.options.name)
237
- this.name = this.options.name;
238
- if (!this._isStandalone() && !this.name && (typeof ngDevMode === 'undefined' || ngDevMode)) {
239
- throw missingNameException();
240
- }
241
- }
242
- _updateValue(value) {
243
- resolvedPromise.then(() => {
244
- this.control.setValue(value, { emitViewToModelChange: false });
245
- this._changeDetectorRef?.markForCheck();
246
- });
247
- }
248
- _updateDisabled(changes) {
249
- const disabledValue = changes['isDisabled'].currentValue;
250
- // checking for 0 to avoid breaking change
251
- const isDisabled = disabledValue !== 0 && coerceToBoolean(disabledValue);
252
- resolvedPromise.then(() => {
253
- if (isDisabled && !this.control.disabled) {
254
- this.control.disable();
255
- }
256
- else if (!isDisabled && this.control.disabled) {
257
- this.control.enable();
258
- }
259
- this._changeDetectorRef?.markForCheck();
260
- });
261
- }
262
- _getPath(controlName) {
263
- return this._parent ? controlPath(controlName, this._parent) : [controlName];
264
- }
265
- }
266
- NgModel.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0-next.3", ngImport: i0, type: NgModel, deps: [{ token: i1.ControlContainer, host: true, optional: 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: ChangeDetectorRef, optional: true }, { token: CALL_SET_DISABLED_STATE, optional: true }], target: i0.ɵɵFactoryTarget.Directive });
267
- NgModel.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.0.0-next.3", type: NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: { name: "name", isDisabled: ["disabled", "isDisabled"], model: ["ngModel", "model"], options: ["ngModelOptions", "options"] }, outputs: { update: "ngModelChange" }, providers: [formControlBinding], exportAs: ["ngModel"], usesInheritance: true, usesOnChanges: true, ngImport: i0 });
268
- export { NgModel };
269
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0-next.3", ngImport: i0, type: NgModel, decorators: [{
270
- type: Directive,
271
- args: [{
272
- selector: '[ngModel]:not([formControlName]):not([formControl])',
273
- providers: [formControlBinding],
274
- exportAs: 'ngModel'
275
- }]
276
- }], ctorParameters: function () { return [{ type: i1.ControlContainer, decorators: [{
277
- type: Optional
278
- }, {
279
- type: Host
280
- }] }, { type: undefined, decorators: [{
281
- type: Optional
282
- }, {
283
- type: Self
284
- }, {
285
- type: Inject,
286
- args: [NG_VALIDATORS]
287
- }] }, { type: undefined, decorators: [{
288
- type: Optional
289
- }, {
290
- type: Self
291
- }, {
292
- type: Inject,
293
- args: [NG_ASYNC_VALIDATORS]
294
- }] }, { type: undefined, decorators: [{
295
- type: Optional
296
- }, {
297
- type: Self
298
- }, {
299
- type: Inject,
300
- args: [NG_VALUE_ACCESSOR]
301
- }] }, { type: i0.ChangeDetectorRef, decorators: [{
302
- type: Optional
303
- }, {
304
- type: Inject,
305
- args: [ChangeDetectorRef]
306
- }] }, { type: undefined, decorators: [{
307
- type: Optional
308
- }, {
309
- type: Inject,
310
- args: [CALL_SET_DISABLED_STATE]
311
- }] }]; }, propDecorators: { name: [{
312
- type: Input
313
- }], isDisabled: [{
314
- type: Input,
315
- args: ['disabled']
316
- }], model: [{
317
- type: Input,
318
- args: ['ngModel']
319
- }], options: [{
320
- type: Input,
321
- args: ['ngModelOptions']
322
- }], update: [{
323
- type: Output,
324
- args: ['ngModelChange']
325
- }] } });
326
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ng_model.js","sourceRoot":"","sources":["../../../../../../../packages/forms/src/directives/ng_model.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 {ChangeDetectorRef, Directive, EventEmitter, forwardRef, Host, Inject, Input, OnChanges, OnDestroy, Optional, Output, Provider, Self, SimpleChanges, ɵcoerceToBoolean as coerceToBoolean} from '@angular/core';\n\nimport {FormHooks} from '../model/abstract_model';\nimport {FormControl} from '../model/form_control';\nimport {NG_ASYNC_VALIDATORS, NG_VALIDATORS} from '../validators';\n\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 {NgForm} from './ng_form';\nimport {NgModelGroup} from './ng_model_group';\nimport {CALL_SET_DISABLED_STATE, controlPath, isPropertyUpdated, selectValueAccessor, SetDisabledStateOption, setUpControl} from './shared';\nimport {formGroupNameException, missingNameException, modelParentException} from './template_driven_errors';\nimport {AsyncValidator, AsyncValidatorFn, Validator, ValidatorFn} from './validators';\n\nconst formControlBinding: Provider = {\n  provide: NgControl,\n  useExisting: forwardRef(() => NgModel)\n};\n\n/**\n * `ngModel` forces an additional change detection run when its inputs change:\n * E.g.:\n * ```\n * <div>{{myModel.valid}}</div>\n * <input [(ngModel)]=\"myValue\" #myModel=\"ngModel\">\n * ```\n * I.e. `ngModel` can export itself on the element and then be used in the template.\n * Normally, this would result in expressions before the `input` that use the exported directive\n * to have an old value as they have been\n * dirty checked before. As this is a very common case for `ngModel`, we added this second change\n * detection run.\n *\n * Notes:\n * - this is just one extra run no matter how many `ngModel`s have been changed.\n * - this is a general problem when using `exportAs` for directives!\n */\nconst resolvedPromise = (() => Promise.resolve())();\n\n/**\n * @description\n * Creates a `FormControl` instance from a domain model and binds it\n * to a form control element.\n *\n * The `FormControl` instance tracks the value, user interaction, and\n * validation status of the control and keeps the view synced with the model. If used\n * within a parent form, the directive also registers itself with the form as a child\n * control.\n *\n * This directive is used by itself or as part of a larger form. Use the\n * `ngModel` selector to activate it.\n *\n * It accepts a domain model as an optional `Input`. If you have a one-way binding\n * to `ngModel` with `[]` syntax, changing the domain model's value in the component\n * class sets the value in the view. If you have a two-way binding with `[()]` syntax\n * (also known as 'banana-in-a-box syntax'), the value in the UI always syncs back to\n * the domain model in your class.\n *\n * To inspect the properties of the associated `FormControl` (like the validity state),\n * export the directive into a local template variable using `ngModel` as the key (ex:\n * `#myVar=\"ngModel\"`). You can then access the control using the directive's `control` property.\n * However, the most commonly used properties (like `valid` and `dirty`) also exist on the control\n * for direct access. See a full list of properties directly available in\n * `AbstractControlDirective`.\n *\n * @see `RadioControlValueAccessor`\n * @see `SelectControlValueAccessor`\n *\n * @usageNotes\n *\n * ### Using ngModel on a standalone control\n *\n * The following examples show a simple standalone control using `ngModel`:\n *\n * {@example forms/ts/simpleNgModel/simple_ng_model_example.ts region='Component'}\n *\n * When using the `ngModel` within `<form>` tags, you'll also need to supply a `name` attribute\n * so that the control can be registered with the parent form under that name.\n *\n * In the context of a parent form, it's often unnecessary to include one-way or two-way binding,\n * as the parent form syncs the value for you. You access its properties by exporting it into a\n * local template variable using `ngForm` such as (`#f=\"ngForm\"`). Use the variable where\n * needed on form submission.\n *\n * If you do need to populate initial values into your form, using a one-way binding for\n * `ngModel` tends to be sufficient as long as you use the exported form's value rather\n * than the domain model's value on submit.\n *\n * ### Using ngModel within a form\n *\n * The following example shows controls using `ngModel` within a form:\n *\n * {@example forms/ts/simpleForm/simple_form_example.ts region='Component'}\n *\n * ### Using a standalone ngModel within a group\n *\n * The following example shows you how to use a standalone ngModel control\n * within a form. This controls the display of the form, but doesn't contain form data.\n *\n * ```html\n * <form>\n *   <input name=\"login\" ngModel placeholder=\"Login\">\n *   <input type=\"checkbox\" ngModel [ngModelOptions]=\"{standalone: true}\"> Show more options?\n * </form>\n * <!-- form value: {login: ''} -->\n * ```\n *\n * ### Setting the ngModel `name` attribute through options\n *\n * The following example shows you an alternate way to set the name attribute. Here,\n * an attribute identified as name is used within a custom form control component. To still be able\n * to specify the NgModel's name, you must specify it using the `ngModelOptions` input instead.\n *\n * ```html\n * <form>\n *   <my-custom-form-control name=\"Nancy\" ngModel [ngModelOptions]=\"{name: 'user'}\">\n *   </my-custom-form-control>\n * </form>\n * <!-- form value: {user: ''} -->\n * ```\n *\n * @ngModule FormsModule\n * @publicApi\n */\n@Directive({\n  selector: '[ngModel]:not([formControlName]):not([formControl])',\n  providers: [formControlBinding],\n  exportAs: 'ngModel'\n})\nexport class NgModel extends NgControl implements OnChanges, OnDestroy {\n  public override readonly control: FormControl = new FormControl();\n\n  // At runtime we coerce arbitrary values assigned to the \"disabled\" input to a \"boolean\".\n  // This is not reflected in the type of the property because outside of templates, consumers\n  // should only deal with booleans. In templates, a string is allowed for convenience and to\n  // match the native \"disabled attribute\" semantics which can be observed on input elements.\n  // This static member tells the compiler that values of type \"string\" can also be assigned\n  // to the input in a template.\n  /** @nodoc */\n  static ngAcceptInputType_isDisabled: boolean|string;\n\n  /** @internal */\n  _registered = false;\n\n  /**\n   * Internal reference to the view model value.\n   * @nodoc\n   */\n  viewModel: any;\n\n  /**\n   * @description\n   * Tracks the name bound to the directive. If a parent form exists, it\n   * uses this name as a key to retrieve this control's value.\n   */\n  // TODO(issue/24571): remove '!'.\n  @Input() override name!: string;\n\n  /**\n   * @description\n   * Tracks whether the control is disabled.\n   */\n  // TODO(issue/24571): remove '!'.\n  @Input('disabled') isDisabled!: boolean;\n\n  /**\n   * @description\n   * Tracks the value bound to this directive.\n   */\n  @Input('ngModel') model: any;\n\n  /**\n   * @description\n   * Tracks the configuration options for this `ngModel` instance.\n   *\n   * **name**: An alternative to setting the name attribute on the form control element. See\n   * the [example](api/forms/NgModel#using-ngmodel-on-a-standalone-control) for using `NgModel`\n   * as a standalone control.\n   *\n   * **standalone**: When set to true, the `ngModel` will not register itself with its parent form,\n   * and acts as if it's not in the form. Defaults to false. If no parent form exists, this option\n   * has no effect.\n   *\n   * **updateOn**: Defines the event upon which the form control value and validity update.\n   * Defaults to 'change'. Possible values: `'change'` | `'blur'` | `'submit'`.\n   *\n   */\n  // TODO(issue/24571): remove '!'.\n  @Input('ngModelOptions') options!: {name?: string, standalone?: boolean, updateOn?: FormHooks};\n\n  /**\n   * @description\n   * Event emitter for producing the `ngModelChange` event after\n   * the view model updates.\n   */\n  @Output('ngModelChange') update = new EventEmitter();\n\n  constructor(\n      @Optional() @Host() 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(ChangeDetectorRef) private _changeDetectorRef?: ChangeDetectorRef|null,\n      @Optional() @Inject(CALL_SET_DISABLED_STATE) private callSetDisabledState?:\n          SetDisabledStateOption) {\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    this._checkForErrors();\n    if (!this._registered || 'name' in changes) {\n      if (this._registered) {\n        this._checkName();\n        if (this.formDirective) {\n          // We can't call `formDirective.removeControl(this)`, because the `name` has already been\n          // changed. We also can't reset the name temporarily since the logic in `removeControl`\n          // is inside a promise and it won't run immediately. We work around it by giving it an\n          // object with the same shape instead.\n          const oldName = changes['name'].previousValue;\n          this.formDirective.removeControl({name: oldName, path: this._getPath(oldName)});\n        }\n      }\n      this._setUpControl();\n    }\n    if ('isDisabled' in changes) {\n      this._updateDisabled(changes);\n    }\n\n    if (isPropertyUpdated(changes, this.viewModel)) {\n      this._updateValue(this.model);\n      this.viewModel = this.model;\n    }\n  }\n\n  /** @nodoc */\n  ngOnDestroy(): void {\n    this.formDirective && this.formDirective.removeControl(this);\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 this._getPath(this.name);\n  }\n\n  /**\n   * @description\n   * The top-level directive for this control if present, otherwise null.\n   */\n  get formDirective(): any {\n    return this._parent ? this._parent.formDirective : null;\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 emitted by `ngModelChange`.\n   */\n  override viewToModelUpdate(newValue: any): void {\n    this.viewModel = newValue;\n    this.update.emit(newValue);\n  }\n\n  private _setUpControl(): void {\n    this._setUpdateStrategy();\n    this._isStandalone() ? this._setUpStandalone() : this.formDirective.addControl(this);\n    this._registered = true;\n  }\n\n  private _setUpdateStrategy(): void {\n    if (this.options && this.options.updateOn != null) {\n      this.control._updateOn = this.options.updateOn;\n    }\n  }\n\n  private _isStandalone(): boolean {\n    return !this._parent || !!(this.options && this.options.standalone);\n  }\n\n  private _setUpStandalone(): void {\n    setUpControl(this.control, this, this.callSetDisabledState);\n    this.control.updateValueAndValidity({emitEvent: false});\n  }\n\n  private _checkForErrors(): void {\n    if (!this._isStandalone()) {\n      this._checkParentType();\n    }\n    this._checkName();\n  }\n\n  private _checkParentType(): void {\n    if (typeof ngDevMode === 'undefined' || ngDevMode) {\n      if (!(this._parent instanceof NgModelGroup) &&\n          this._parent instanceof AbstractFormGroupDirective) {\n        throw formGroupNameException();\n      } else if (!(this._parent instanceof NgModelGroup) && !(this._parent instanceof NgForm)) {\n        throw modelParentException();\n      }\n    }\n  }\n\n  private _checkName(): void {\n    if (this.options && this.options.name) this.name = this.options.name;\n\n    if (!this._isStandalone() && !this.name && (typeof ngDevMode === 'undefined' || ngDevMode)) {\n      throw missingNameException();\n    }\n  }\n\n  private _updateValue(value: any): void {\n    resolvedPromise.then(() => {\n      this.control.setValue(value, {emitViewToModelChange: false});\n      this._changeDetectorRef?.markForCheck();\n    });\n  }\n\n  private _updateDisabled(changes: SimpleChanges) {\n    const disabledValue = changes['isDisabled'].currentValue;\n    // checking for 0 to avoid breaking change\n    const isDisabled = disabledValue !== 0 && coerceToBoolean(disabledValue);\n\n    resolvedPromise.then(() => {\n      if (isDisabled && !this.control.disabled) {\n        this.control.disable();\n      } else if (!isDisabled && this.control.disabled) {\n        this.control.enable();\n      }\n\n      this._changeDetectorRef?.markForCheck();\n    });\n  }\n\n  private _getPath(controlName: string): string[] {\n    return this._parent ? controlPath(controlName, this._parent) : [controlName];\n  }\n}\n"]}