@angular/forms 19.0.0-next.1 → 19.0.0-next.11
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +21 -0
- package/fesm2022/forms.mjs +186 -132
- package/fesm2022/forms.mjs.map +1 -1
- package/index.d.ts +6 -5
- package/package.json +4 -6
- package/esm2022/forms.mjs +0 -5
- package/esm2022/index.mjs +0 -13
- package/esm2022/public_api.mjs +0 -15
- package/esm2022/src/directives/abstract_control_directive.mjs +0 -279
- package/esm2022/src/directives/abstract_form_group_directive.mjs +0 -61
- package/esm2022/src/directives/checkbox_value_accessor.mjs +0 -58
- package/esm2022/src/directives/control_container.mjs +0 -32
- package/esm2022/src/directives/control_value_accessor.mjs +0 -92
- package/esm2022/src/directives/default_value_accessor.mjs +0 -124
- package/esm2022/src/directives/error_examples.mjs +0 -57
- package/esm2022/src/directives/form_interface.mjs +0 -9
- package/esm2022/src/directives/ng_control.mjs +0 -38
- package/esm2022/src/directives/ng_control_status.mjs +0 -139
- package/esm2022/src/directives/ng_form.mjs +0 -313
- package/esm2022/src/directives/ng_model.mjs +0 -331
- package/esm2022/src/directives/ng_model_group.mjs +0 -95
- package/esm2022/src/directives/ng_no_validate_directive.mjs +0 -39
- package/esm2022/src/directives/number_value_accessor.mjs +0 -70
- package/esm2022/src/directives/radio_control_value_accessor.mjs +0 -201
- package/esm2022/src/directives/range_value_accessor.mjs +0 -72
- package/esm2022/src/directives/reactive_directives/form_control_directive.mjs +0 -183
- package/esm2022/src/directives/reactive_directives/form_control_name.mjs +0 -216
- package/esm2022/src/directives/reactive_directives/form_group_directive.mjs +0 -359
- package/esm2022/src/directives/reactive_directives/form_group_name.mjs +0 -246
- package/esm2022/src/directives/reactive_errors.mjs +0 -119
- package/esm2022/src/directives/select_control_value_accessor.mjs +0 -220
- package/esm2022/src/directives/select_multiple_control_value_accessor.mjs +0 -252
- package/esm2022/src/directives/shared.mjs +0 -350
- package/esm2022/src/directives/template_driven_errors.mjs +0 -54
- package/esm2022/src/directives/validators.mjs +0 -505
- package/esm2022/src/directives.mjs +0 -128
- package/esm2022/src/errors.mjs +0 -9
- package/esm2022/src/form_builder.mjs +0 -258
- package/esm2022/src/form_providers.mjs +0 -105
- package/esm2022/src/forms.mjs +0 -49
- package/esm2022/src/model/abstract_model.mjs +0 -992
- package/esm2022/src/model/form_array.mjs +0 -461
- package/esm2022/src/model/form_control.mjs +0 -126
- package/esm2022/src/model/form_group.mjs +0 -490
- package/esm2022/src/util.mjs +0 -13
- package/esm2022/src/validators.mjs +0 -680
- package/esm2022/src/version.mjs +0 -18
|
@@ -1,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.1", 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.1", 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.1", 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.1", 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.1", type: ɵNgSelectMultipleOption, selector: "option", inputs: { ngValue: "ngValue", value: "value" }, ngImport: i0 }); }
|
|
236
|
-
}
|
|
237
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.0.0-next.1", 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"]}
|