@angular/forms 19.0.0-next.0 → 19.0.0-next.10

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (48) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +1 -1
  3. package/fesm2022/forms.mjs +186 -132
  4. package/fesm2022/forms.mjs.map +1 -1
  5. package/index.d.ts +6 -5
  6. package/package.json +4 -6
  7. package/esm2022/forms.mjs +0 -5
  8. package/esm2022/index.mjs +0 -13
  9. package/esm2022/public_api.mjs +0 -15
  10. package/esm2022/src/directives/abstract_control_directive.mjs +0 -279
  11. package/esm2022/src/directives/abstract_form_group_directive.mjs +0 -61
  12. package/esm2022/src/directives/checkbox_value_accessor.mjs +0 -58
  13. package/esm2022/src/directives/control_container.mjs +0 -32
  14. package/esm2022/src/directives/control_value_accessor.mjs +0 -92
  15. package/esm2022/src/directives/default_value_accessor.mjs +0 -124
  16. package/esm2022/src/directives/error_examples.mjs +0 -57
  17. package/esm2022/src/directives/form_interface.mjs +0 -9
  18. package/esm2022/src/directives/ng_control.mjs +0 -38
  19. package/esm2022/src/directives/ng_control_status.mjs +0 -139
  20. package/esm2022/src/directives/ng_form.mjs +0 -313
  21. package/esm2022/src/directives/ng_model.mjs +0 -331
  22. package/esm2022/src/directives/ng_model_group.mjs +0 -95
  23. package/esm2022/src/directives/ng_no_validate_directive.mjs +0 -39
  24. package/esm2022/src/directives/number_value_accessor.mjs +0 -70
  25. package/esm2022/src/directives/radio_control_value_accessor.mjs +0 -201
  26. package/esm2022/src/directives/range_value_accessor.mjs +0 -72
  27. package/esm2022/src/directives/reactive_directives/form_control_directive.mjs +0 -183
  28. package/esm2022/src/directives/reactive_directives/form_control_name.mjs +0 -216
  29. package/esm2022/src/directives/reactive_directives/form_group_directive.mjs +0 -359
  30. package/esm2022/src/directives/reactive_directives/form_group_name.mjs +0 -246
  31. package/esm2022/src/directives/reactive_errors.mjs +0 -119
  32. package/esm2022/src/directives/select_control_value_accessor.mjs +0 -220
  33. package/esm2022/src/directives/select_multiple_control_value_accessor.mjs +0 -252
  34. package/esm2022/src/directives/shared.mjs +0 -350
  35. package/esm2022/src/directives/template_driven_errors.mjs +0 -54
  36. package/esm2022/src/directives/validators.mjs +0 -505
  37. package/esm2022/src/directives.mjs +0 -128
  38. package/esm2022/src/errors.mjs +0 -9
  39. package/esm2022/src/form_builder.mjs +0 -258
  40. package/esm2022/src/form_providers.mjs +0 -105
  41. package/esm2022/src/forms.mjs +0 -49
  42. package/esm2022/src/model/abstract_model.mjs +0 -992
  43. package/esm2022/src/model/form_array.mjs +0 -461
  44. package/esm2022/src/model/form_control.mjs +0 -126
  45. package/esm2022/src/model/form_group.mjs +0 -490
  46. package/esm2022/src/util.mjs +0 -13
  47. package/esm2022/src/validators.mjs +0 -680
  48. package/esm2022/src/version.mjs +0 -18
@@ -1,252 +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, ElementRef, forwardRef, Host, Input, Optional, Renderer2, ɵRuntimeError as RuntimeError, } from '@angular/core';
9
- import { BuiltInControlValueAccessor, NG_VALUE_ACCESSOR, } from './control_value_accessor';
10
- import * as i0 from "@angular/core";
11
- const SELECT_MULTIPLE_VALUE_ACCESSOR = {
12
- provide: NG_VALUE_ACCESSOR,
13
- useExisting: forwardRef(() => SelectMultipleControlValueAccessor),
14
- multi: true,
15
- };
16
- function _buildValueString(id, value) {
17
- if (id == null)
18
- return `${value}`;
19
- if (typeof value === 'string')
20
- value = `'${value}'`;
21
- if (value && typeof value === 'object')
22
- value = 'Object';
23
- return `${id}: ${value}`.slice(0, 50);
24
- }
25
- function _extractId(valueString) {
26
- return valueString.split(':')[0];
27
- }
28
- /** Mock interface for HTMLCollection */
29
- class HTMLCollection {
30
- }
31
- /**
32
- * @description
33
- * The `ControlValueAccessor` for writing multi-select control values and listening to multi-select
34
- * control changes. The value accessor is used by the `FormControlDirective`, `FormControlName`, and
35
- * `NgModel` directives.
36
- *
37
- * @see {@link SelectControlValueAccessor}
38
- *
39
- * @usageNotes
40
- *
41
- * ### Using a multi-select control
42
- *
43
- * The follow example shows you how to use a multi-select control with a reactive form.
44
- *
45
- * ```ts
46
- * const countryControl = new FormControl();
47
- * ```
48
- *
49
- * ```
50
- * <select multiple name="countries" [formControl]="countryControl">
51
- * <option *ngFor="let country of countries" [ngValue]="country">
52
- * {{ country.name }}
53
- * </option>
54
- * </select>
55
- * ```
56
- *
57
- * ### Customizing option selection
58
- *
59
- * To customize the default option comparison algorithm, `<select>` supports `compareWith` input.
60
- * See the `SelectControlValueAccessor` for usage.
61
- *
62
- * @ngModule ReactiveFormsModule
63
- * @ngModule FormsModule
64
- * @publicApi
65
- */
66
- export class SelectMultipleControlValueAccessor extends BuiltInControlValueAccessor {
67
- constructor() {
68
- super(...arguments);
69
- /** @internal */
70
- this._optionMap = new Map();
71
- /** @internal */
72
- this._idCounter = 0;
73
- this._compareWith = Object.is;
74
- }
75
- /**
76
- * @description
77
- * Tracks the option comparison algorithm for tracking identities when
78
- * checking for changes.
79
- */
80
- set compareWith(fn) {
81
- if (typeof fn !== 'function' && (typeof ngDevMode === 'undefined' || ngDevMode)) {
82
- throw new RuntimeError(1201 /* RuntimeErrorCode.COMPAREWITH_NOT_A_FN */, `compareWith must be a function, but received ${JSON.stringify(fn)}`);
83
- }
84
- this._compareWith = fn;
85
- }
86
- /**
87
- * Sets the "value" property on one or of more of the select's options.
88
- * @nodoc
89
- */
90
- writeValue(value) {
91
- this.value = value;
92
- let optionSelectedStateSetter;
93
- if (Array.isArray(value)) {
94
- // convert values to ids
95
- const ids = value.map((v) => this._getOptionId(v));
96
- optionSelectedStateSetter = (opt, o) => {
97
- opt._setSelected(ids.indexOf(o.toString()) > -1);
98
- };
99
- }
100
- else {
101
- optionSelectedStateSetter = (opt, o) => {
102
- opt._setSelected(false);
103
- };
104
- }
105
- this._optionMap.forEach(optionSelectedStateSetter);
106
- }
107
- /**
108
- * Registers a function called when the control value changes
109
- * and writes an array of the selected options.
110
- * @nodoc
111
- */
112
- registerOnChange(fn) {
113
- this.onChange = (element) => {
114
- const selected = [];
115
- const selectedOptions = element.selectedOptions;
116
- if (selectedOptions !== undefined) {
117
- const options = selectedOptions;
118
- for (let i = 0; i < options.length; i++) {
119
- const opt = options[i];
120
- const val = this._getOptionValue(opt.value);
121
- selected.push(val);
122
- }
123
- }
124
- // Degrade to use `options` when `selectedOptions` property is not available.
125
- // Note: the `selectedOptions` is available in all supported browsers, but the Domino lib
126
- // doesn't have it currently, see https://github.com/fgnass/domino/issues/177.
127
- else {
128
- const options = element.options;
129
- for (let i = 0; i < options.length; i++) {
130
- const opt = options[i];
131
- if (opt.selected) {
132
- const val = this._getOptionValue(opt.value);
133
- selected.push(val);
134
- }
135
- }
136
- }
137
- this.value = selected;
138
- fn(selected);
139
- };
140
- }
141
- /** @internal */
142
- _registerOption(value) {
143
- const id = (this._idCounter++).toString();
144
- this._optionMap.set(id, value);
145
- return id;
146
- }
147
- /** @internal */
148
- _getOptionId(value) {
149
- for (const id of this._optionMap.keys()) {
150
- if (this._compareWith(this._optionMap.get(id)._value, value))
151
- return id;
152
- }
153
- return null;
154
- }
155
- /** @internal */
156
- _getOptionValue(valueString) {
157
- const id = _extractId(valueString);
158
- return this._optionMap.has(id) ? this._optionMap.get(id)._value : valueString;
159
- }
160
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.0.0-next.0", ngImport: i0, type: SelectMultipleControlValueAccessor, deps: null, target: i0.ɵɵFactoryTarget.Directive }); }
161
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "19.0.0-next.0", type: SelectMultipleControlValueAccessor, selector: "select[multiple][formControlName],select[multiple][formControl],select[multiple][ngModel]", inputs: { compareWith: "compareWith" }, host: { listeners: { "change": "onChange($event.target)", "blur": "onTouched()" } }, providers: [SELECT_MULTIPLE_VALUE_ACCESSOR], usesInheritance: true, ngImport: i0 }); }
162
- }
163
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.0.0-next.0", ngImport: i0, type: SelectMultipleControlValueAccessor, decorators: [{
164
- type: Directive,
165
- args: [{
166
- selector: 'select[multiple][formControlName],select[multiple][formControl],select[multiple][ngModel]',
167
- host: { '(change)': 'onChange($event.target)', '(blur)': 'onTouched()' },
168
- providers: [SELECT_MULTIPLE_VALUE_ACCESSOR],
169
- }]
170
- }], propDecorators: { compareWith: [{
171
- type: Input
172
- }] } });
173
- /**
174
- * @description
175
- * Marks `<option>` as dynamic, so Angular can be notified when options change.
176
- *
177
- * @see {@link SelectMultipleControlValueAccessor}
178
- *
179
- * @ngModule ReactiveFormsModule
180
- * @ngModule FormsModule
181
- * @publicApi
182
- */
183
- export class ɵNgSelectMultipleOption {
184
- constructor(_element, _renderer, _select) {
185
- this._element = _element;
186
- this._renderer = _renderer;
187
- this._select = _select;
188
- if (this._select) {
189
- this.id = this._select._registerOption(this);
190
- }
191
- }
192
- /**
193
- * @description
194
- * Tracks the value bound to the option element. Unlike the value binding,
195
- * ngValue supports binding to objects.
196
- */
197
- set ngValue(value) {
198
- if (this._select == null)
199
- return;
200
- this._value = value;
201
- this._setElementValue(_buildValueString(this.id, value));
202
- this._select.writeValue(this._select.value);
203
- }
204
- /**
205
- * @description
206
- * Tracks simple string values bound to the option element.
207
- * For objects, use the `ngValue` input binding.
208
- */
209
- set value(value) {
210
- if (this._select) {
211
- this._value = value;
212
- this._setElementValue(_buildValueString(this.id, value));
213
- this._select.writeValue(this._select.value);
214
- }
215
- else {
216
- this._setElementValue(value);
217
- }
218
- }
219
- /** @internal */
220
- _setElementValue(value) {
221
- this._renderer.setProperty(this._element.nativeElement, 'value', value);
222
- }
223
- /** @internal */
224
- _setSelected(selected) {
225
- this._renderer.setProperty(this._element.nativeElement, 'selected', selected);
226
- }
227
- /** @nodoc */
228
- ngOnDestroy() {
229
- if (this._select) {
230
- this._select._optionMap.delete(this.id);
231
- this._select.writeValue(this._select.value);
232
- }
233
- }
234
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.0.0-next.0", ngImport: i0, type: ɵNgSelectMultipleOption, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }, { token: SelectMultipleControlValueAccessor, host: true, optional: true }], target: i0.ɵɵFactoryTarget.Directive }); }
235
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "19.0.0-next.0", type: ɵNgSelectMultipleOption, selector: "option", inputs: { ngValue: "ngValue", value: "value" }, ngImport: i0 }); }
236
- }
237
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.0.0-next.0", ngImport: i0, type: ɵNgSelectMultipleOption, decorators: [{
238
- type: Directive,
239
- args: [{ selector: 'option' }]
240
- }], ctorParameters: () => [{ type: i0.ElementRef }, { type: i0.Renderer2 }, { type: SelectMultipleControlValueAccessor, decorators: [{
241
- type: Optional
242
- }, {
243
- type: Host
244
- }] }], propDecorators: { ngValue: [{
245
- type: Input,
246
- args: ['ngValue']
247
- }], value: [{
248
- type: Input,
249
- args: ['value']
250
- }] } });
251
- export { ɵNgSelectMultipleOption as NgSelectMultipleOption };
252
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select_multiple_control_value_accessor.js","sourceRoot":"","sources":["../../../../../../../packages/forms/src/directives/select_multiple_control_value_accessor.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  ElementRef,\n  forwardRef,\n  Host,\n  Input,\n  OnDestroy,\n  Optional,\n  Provider,\n  Renderer2,\n  ɵRuntimeError as RuntimeError,\n} from '@angular/core';\n\nimport {RuntimeErrorCode} from '../errors';\n\nimport {\n  BuiltInControlValueAccessor,\n  ControlValueAccessor,\n  NG_VALUE_ACCESSOR,\n} from './control_value_accessor';\n\nconst SELECT_MULTIPLE_VALUE_ACCESSOR: Provider = {\n  provide: NG_VALUE_ACCESSOR,\n  useExisting: forwardRef(() => SelectMultipleControlValueAccessor),\n  multi: true,\n};\n\nfunction _buildValueString(id: string, value: any): string {\n  if (id == null) return `${value}`;\n  if (typeof value === 'string') value = `'${value}'`;\n  if (value && typeof value === 'object') value = 'Object';\n  return `${id}: ${value}`.slice(0, 50);\n}\n\nfunction _extractId(valueString: string): string {\n  return valueString.split(':')[0];\n}\n\n/** Mock interface for HTML Options */\ninterface HTMLOption {\n  value: string;\n  selected: boolean;\n}\n\n/** Mock interface for HTMLCollection */\nabstract class HTMLCollection {\n  // TODO(issue/24571): remove '!'.\n  length!: number;\n  abstract item(_: number): HTMLOption;\n}\n\n/**\n * @description\n * The `ControlValueAccessor` for writing multi-select control values and listening to multi-select\n * control changes. The value accessor is used by the `FormControlDirective`, `FormControlName`, and\n * `NgModel` directives.\n *\n * @see {@link SelectControlValueAccessor}\n *\n * @usageNotes\n *\n * ### Using a multi-select control\n *\n * The follow example shows you how to use a multi-select control with a reactive form.\n *\n * ```ts\n * const countryControl = new FormControl();\n * ```\n *\n * ```\n * <select multiple name=\"countries\" [formControl]=\"countryControl\">\n *   <option *ngFor=\"let country of countries\" [ngValue]=\"country\">\n *     {{ country.name }}\n *   </option>\n * </select>\n * ```\n *\n * ### Customizing option selection\n *\n * To customize the default option comparison algorithm, `<select>` supports `compareWith` input.\n * See the `SelectControlValueAccessor` for usage.\n *\n * @ngModule ReactiveFormsModule\n * @ngModule FormsModule\n * @publicApi\n */\n@Directive({\n  selector:\n    'select[multiple][formControlName],select[multiple][formControl],select[multiple][ngModel]',\n  host: {'(change)': 'onChange($event.target)', '(blur)': 'onTouched()'},\n  providers: [SELECT_MULTIPLE_VALUE_ACCESSOR],\n})\nexport class SelectMultipleControlValueAccessor\n  extends BuiltInControlValueAccessor\n  implements ControlValueAccessor\n{\n  /**\n   * The current value.\n   * @nodoc\n   */\n  value: any;\n\n  /** @internal */\n  _optionMap: Map<string, ɵNgSelectMultipleOption> = new Map<string, ɵNgSelectMultipleOption>();\n\n  /** @internal */\n  _idCounter: number = 0;\n\n  /**\n   * @description\n   * Tracks the option comparison algorithm for tracking identities when\n   * checking for changes.\n   */\n  @Input()\n  set compareWith(fn: (o1: any, o2: any) => boolean) {\n    if (typeof fn !== 'function' && (typeof ngDevMode === 'undefined' || ngDevMode)) {\n      throw new RuntimeError(\n        RuntimeErrorCode.COMPAREWITH_NOT_A_FN,\n        `compareWith must be a function, but received ${JSON.stringify(fn)}`,\n      );\n    }\n    this._compareWith = fn;\n  }\n\n  private _compareWith: (o1: any, o2: any) => boolean = Object.is;\n\n  /**\n   * Sets the \"value\" property on one or of more of the select's options.\n   * @nodoc\n   */\n  writeValue(value: any): void {\n    this.value = value;\n    let optionSelectedStateSetter: (opt: ɵNgSelectMultipleOption, o: any) => void;\n    if (Array.isArray(value)) {\n      // convert values to ids\n      const ids = value.map((v) => this._getOptionId(v));\n      optionSelectedStateSetter = (opt, o) => {\n        opt._setSelected(ids.indexOf(o.toString()) > -1);\n      };\n    } else {\n      optionSelectedStateSetter = (opt, o) => {\n        opt._setSelected(false);\n      };\n    }\n    this._optionMap.forEach(optionSelectedStateSetter);\n  }\n\n  /**\n   * Registers a function called when the control value changes\n   * and writes an array of the selected options.\n   * @nodoc\n   */\n  override registerOnChange(fn: (value: any) => any): void {\n    this.onChange = (element: HTMLSelectElement) => {\n      const selected: Array<any> = [];\n      const selectedOptions = element.selectedOptions;\n      if (selectedOptions !== undefined) {\n        const options = selectedOptions;\n        for (let i = 0; i < options.length; i++) {\n          const opt = options[i];\n          const val = this._getOptionValue(opt.value);\n          selected.push(val);\n        }\n      }\n      // Degrade to use `options` when `selectedOptions` property is not available.\n      // Note: the `selectedOptions` is available in all supported browsers, but the Domino lib\n      // doesn't have it currently, see https://github.com/fgnass/domino/issues/177.\n      else {\n        const options = element.options;\n        for (let i = 0; i < options.length; i++) {\n          const opt = options[i];\n          if (opt.selected) {\n            const val = this._getOptionValue(opt.value);\n            selected.push(val);\n          }\n        }\n      }\n      this.value = selected;\n      fn(selected);\n    };\n  }\n\n  /** @internal */\n  _registerOption(value: ɵNgSelectMultipleOption): string {\n    const id: string = (this._idCounter++).toString();\n    this._optionMap.set(id, value);\n    return id;\n  }\n\n  /** @internal */\n  _getOptionId(value: any): string | null {\n    for (const id of this._optionMap.keys()) {\n      if (this._compareWith(this._optionMap.get(id)!._value, value)) return id;\n    }\n    return null;\n  }\n\n  /** @internal */\n  _getOptionValue(valueString: string): any {\n    const id: string = _extractId(valueString);\n    return this._optionMap.has(id) ? this._optionMap.get(id)!._value : valueString;\n  }\n}\n\n/**\n * @description\n * Marks `<option>` as dynamic, so Angular can be notified when options change.\n *\n * @see {@link SelectMultipleControlValueAccessor}\n *\n * @ngModule ReactiveFormsModule\n * @ngModule FormsModule\n * @publicApi\n */\n@Directive({selector: 'option'})\nexport class ɵNgSelectMultipleOption implements OnDestroy {\n  // TODO(issue/24571): remove '!'.\n  id!: string;\n  /** @internal */\n  _value: any;\n\n  constructor(\n    private _element: ElementRef,\n    private _renderer: Renderer2,\n    @Optional() @Host() private _select: SelectMultipleControlValueAccessor,\n  ) {\n    if (this._select) {\n      this.id = this._select._registerOption(this);\n    }\n  }\n\n  /**\n   * @description\n   * Tracks the value bound to the option element. Unlike the value binding,\n   * ngValue supports binding to objects.\n   */\n  @Input('ngValue')\n  set ngValue(value: any) {\n    if (this._select == null) return;\n    this._value = value;\n    this._setElementValue(_buildValueString(this.id, value));\n    this._select.writeValue(this._select.value);\n  }\n\n  /**\n   * @description\n   * Tracks simple string values bound to the option element.\n   * For objects, use the `ngValue` input binding.\n   */\n  @Input('value')\n  set value(value: any) {\n    if (this._select) {\n      this._value = value;\n      this._setElementValue(_buildValueString(this.id, value));\n      this._select.writeValue(this._select.value);\n    } else {\n      this._setElementValue(value);\n    }\n  }\n\n  /** @internal */\n  _setElementValue(value: string): void {\n    this._renderer.setProperty(this._element.nativeElement, 'value', value);\n  }\n\n  /** @internal */\n  _setSelected(selected: boolean) {\n    this._renderer.setProperty(this._element.nativeElement, 'selected', selected);\n  }\n\n  /** @nodoc */\n  ngOnDestroy(): void {\n    if (this._select) {\n      this._select._optionMap.delete(this.id);\n      this._select.writeValue(this._select.value);\n    }\n  }\n}\n\nexport {ɵNgSelectMultipleOption as NgSelectMultipleOption};\n"]}