@angular/forms 19.0.0-next.1 → 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.
- 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,92 +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, InjectionToken, Renderer2 } from '@angular/core';
|
|
9
|
-
import * as i0 from "@angular/core";
|
|
10
|
-
/**
|
|
11
|
-
* Base class for all ControlValueAccessor classes defined in Forms package.
|
|
12
|
-
* Contains common logic and utility functions.
|
|
13
|
-
*
|
|
14
|
-
* Note: this is an *internal-only* class and should not be extended or used directly in
|
|
15
|
-
* applications code.
|
|
16
|
-
*/
|
|
17
|
-
export class BaseControlValueAccessor {
|
|
18
|
-
constructor(_renderer, _elementRef) {
|
|
19
|
-
this._renderer = _renderer;
|
|
20
|
-
this._elementRef = _elementRef;
|
|
21
|
-
/**
|
|
22
|
-
* The registered callback function called when a change or input event occurs on the input
|
|
23
|
-
* element.
|
|
24
|
-
* @nodoc
|
|
25
|
-
*/
|
|
26
|
-
this.onChange = (_) => { };
|
|
27
|
-
/**
|
|
28
|
-
* The registered callback function called when a blur event occurs on the input element.
|
|
29
|
-
* @nodoc
|
|
30
|
-
*/
|
|
31
|
-
this.onTouched = () => { };
|
|
32
|
-
}
|
|
33
|
-
/**
|
|
34
|
-
* Helper method that sets a property on a target element using the current Renderer
|
|
35
|
-
* implementation.
|
|
36
|
-
* @nodoc
|
|
37
|
-
*/
|
|
38
|
-
setProperty(key, value) {
|
|
39
|
-
this._renderer.setProperty(this._elementRef.nativeElement, key, value);
|
|
40
|
-
}
|
|
41
|
-
/**
|
|
42
|
-
* Registers a function called when the control is touched.
|
|
43
|
-
* @nodoc
|
|
44
|
-
*/
|
|
45
|
-
registerOnTouched(fn) {
|
|
46
|
-
this.onTouched = fn;
|
|
47
|
-
}
|
|
48
|
-
/**
|
|
49
|
-
* Registers a function called when the control value changes.
|
|
50
|
-
* @nodoc
|
|
51
|
-
*/
|
|
52
|
-
registerOnChange(fn) {
|
|
53
|
-
this.onChange = fn;
|
|
54
|
-
}
|
|
55
|
-
/**
|
|
56
|
-
* Sets the "disabled" property on the range input element.
|
|
57
|
-
* @nodoc
|
|
58
|
-
*/
|
|
59
|
-
setDisabledState(isDisabled) {
|
|
60
|
-
this.setProperty('disabled', isDisabled);
|
|
61
|
-
}
|
|
62
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.0.0-next.1", ngImport: i0, type: BaseControlValueAccessor, deps: [{ token: i0.Renderer2 }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
63
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "19.0.0-next.1", type: BaseControlValueAccessor, ngImport: i0 }); }
|
|
64
|
-
}
|
|
65
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.0.0-next.1", ngImport: i0, type: BaseControlValueAccessor, decorators: [{
|
|
66
|
-
type: Directive
|
|
67
|
-
}], ctorParameters: () => [{ type: i0.Renderer2 }, { type: i0.ElementRef }] });
|
|
68
|
-
/**
|
|
69
|
-
* Base class for all built-in ControlValueAccessor classes (except DefaultValueAccessor, which is
|
|
70
|
-
* used in case no other CVAs can be found). We use this class to distinguish between default CVA,
|
|
71
|
-
* built-in CVAs and custom CVAs, so that Forms logic can recognize built-in CVAs and treat custom
|
|
72
|
-
* ones with higher priority (when both built-in and custom CVAs are present).
|
|
73
|
-
*
|
|
74
|
-
* Note: this is an *internal-only* class and should not be extended or used directly in
|
|
75
|
-
* applications code.
|
|
76
|
-
*/
|
|
77
|
-
export class BuiltInControlValueAccessor extends BaseControlValueAccessor {
|
|
78
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.0.0-next.1", ngImport: i0, type: BuiltInControlValueAccessor, deps: null, target: i0.ɵɵFactoryTarget.Directive }); }
|
|
79
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "19.0.0-next.1", type: BuiltInControlValueAccessor, usesInheritance: true, ngImport: i0 }); }
|
|
80
|
-
}
|
|
81
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.0.0-next.1", ngImport: i0, type: BuiltInControlValueAccessor, decorators: [{
|
|
82
|
-
type: Directive
|
|
83
|
-
}] });
|
|
84
|
-
/**
|
|
85
|
-
* Used to provide a `ControlValueAccessor` for form controls.
|
|
86
|
-
*
|
|
87
|
-
* See `DefaultValueAccessor` for how to implement one.
|
|
88
|
-
*
|
|
89
|
-
* @publicApi
|
|
90
|
-
*/
|
|
91
|
-
export const NG_VALUE_ACCESSOR = new InjectionToken(ngDevMode ? 'NgValueAccessor' : '');
|
|
92
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"control_value_accessor.js","sourceRoot":"","sources":["../../../../../../../packages/forms/src/directives/control_value_accessor.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAEH,OAAO,EAAC,SAAS,EAAE,UAAU,EAAE,cAAc,EAAE,SAAS,EAAC,MAAM,eAAe,CAAC;;AA6H/E;;;;;;GAMG;AAEH,MAAM,OAAO,wBAAwB;IAcnC,YACU,SAAoB,EACpB,WAAuB;QADvB,cAAS,GAAT,SAAS,CAAW;QACpB,gBAAW,GAAX,WAAW,CAAY;QAfjC;;;;WAIG;QACH,aAAQ,GAAG,CAAC,CAAM,EAAE,EAAE,GAAE,CAAC,CAAC;QAE1B;;;WAGG;QACH,cAAS,GAAG,GAAG,EAAE,GAAE,CAAC,CAAC;IAKlB,CAAC;IAEJ;;;;OAIG;IACO,WAAW,CAAC,GAAW,EAAE,KAAU;QAC3C,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,IAAI,CAAC,WAAW,CAAC,aAAa,EAAE,GAAG,EAAE,KAAK,CAAC,CAAC;IACzE,CAAC;IAED;;;OAGG;IACH,iBAAiB,CAAC,EAAc;QAC9B,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;IACtB,CAAC;IAED;;;OAGG;IACH,gBAAgB,CAAC,EAAkB;QACjC,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC;IACrB,CAAC;IAED;;;OAGG;IACH,gBAAgB,CAAC,UAAmB;QAClC,IAAI,CAAC,WAAW,CAAC,UAAU,EAAE,UAAU,CAAC,CAAC;IAC3C,CAAC;yHAlDU,wBAAwB;6GAAxB,wBAAwB;;sGAAxB,wBAAwB;kBADpC,SAAS;;AAsDV;;;;;;;;GAQG;AAEH,MAAM,OAAO,2BAA4B,SAAQ,wBAAwB;yHAA5D,2BAA2B;6GAA3B,2BAA2B;;sGAA3B,2BAA2B;kBADvC,SAAS;;AAGV;;;;;;GAMG;AACH,MAAM,CAAC,MAAM,iBAAiB,GAAG,IAAI,cAAc,CACjD,SAAS,CAAC,CAAC,CAAC,iBAAiB,CAAC,CAAC,CAAC,EAAE,CACnC,CAAC","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport {Directive, ElementRef, InjectionToken, Renderer2} from '@angular/core';\n\n/**\n * @description\n * Defines an interface that acts as a bridge between the Angular forms API and a\n * native element in the DOM.\n *\n * Implement this interface to create a custom form control directive\n * that integrates with Angular forms.\n *\n * @see {@link DefaultValueAccessor}\n *\n * @publicApi\n */\nexport interface ControlValueAccessor {\n  /**\n   * @description\n   * Writes a new value to the element.\n   *\n   * This method is called by the forms API to write to the view when programmatic\n   * changes from model to view are requested.\n   *\n   * @usageNotes\n   * ### Write a value to the element\n   *\n   * The following example writes a value to the native DOM element.\n   *\n   * ```ts\n   * writeValue(value: any): void {\n   *   this._renderer.setProperty(this._elementRef.nativeElement, 'value', value);\n   * }\n   * ```\n   *\n   * @param obj The new value for the element\n   */\n  writeValue(obj: any): void;\n\n  /**\n   * @description\n   * Registers a callback function that is called when the control's value\n   * changes in the UI.\n   *\n   * This method is called by the forms API on initialization to update the form\n   * model when values propagate from the view to the model.\n   *\n   * When implementing the `registerOnChange` method in your own value accessor,\n   * save the given function so your class calls it at the appropriate time.\n   *\n   * @usageNotes\n   * ### Store the change function\n   *\n   * The following example stores the provided function as an internal method.\n   *\n   * ```ts\n   * registerOnChange(fn: (_: any) => void): void {\n   *   this._onChange = fn;\n   * }\n   * ```\n   *\n   * When the value changes in the UI, call the registered\n   * function to allow the forms API to update itself:\n   *\n   * ```ts\n   * host: {\n   *    '(change)': '_onChange($event.target.value)'\n   * }\n   * ```\n   *\n   * @param fn The callback function to register\n   */\n  registerOnChange(fn: any): void;\n\n  /**\n   * @description\n   * Registers a callback function that is called by the forms API on initialization\n   * to update the form model on blur.\n   *\n   * When implementing `registerOnTouched` in your own value accessor, save the given\n   * function so your class calls it when the control should be considered\n   * blurred or \"touched\".\n   *\n   * @usageNotes\n   * ### Store the callback function\n   *\n   * The following example stores the provided function as an internal method.\n   *\n   * ```ts\n   * registerOnTouched(fn: any): void {\n   *   this._onTouched = fn;\n   * }\n   * ```\n   *\n   * On blur (or equivalent), your class should call the registered function to allow\n   * the forms API to update itself:\n   *\n   * ```ts\n   * host: {\n   *    '(blur)': '_onTouched()'\n   * }\n   * ```\n   *\n   * @param fn The callback function to register\n   */\n  registerOnTouched(fn: any): void;\n\n  /**\n   * @description\n   * Function that is called by the forms API when the control status changes to\n   * or from 'DISABLED'. Depending on the status, it enables or disables the\n   * appropriate DOM element.\n   *\n   * @usageNotes\n   * The following is an example of writing the disabled property to a native DOM element:\n   *\n   * ```ts\n   * setDisabledState(isDisabled: boolean): void {\n   *   this._renderer.setProperty(this._elementRef.nativeElement, 'disabled', isDisabled);\n   * }\n   * ```\n   *\n   * @param isDisabled The disabled status to set on the element\n   */\n  setDisabledState?(isDisabled: boolean): void;\n}\n\n/**\n * Base class for all ControlValueAccessor classes defined in Forms package.\n * Contains common logic and utility functions.\n *\n * Note: this is an *internal-only* class and should not be extended or used directly in\n * applications code.\n */\n@Directive()\nexport class BaseControlValueAccessor {\n  /**\n   * The registered callback function called when a change or input event occurs on the input\n   * element.\n   * @nodoc\n   */\n  onChange = (_: any) => {};\n\n  /**\n   * The registered callback function called when a blur event occurs on the input element.\n   * @nodoc\n   */\n  onTouched = () => {};\n\n  constructor(\n    private _renderer: Renderer2,\n    private _elementRef: ElementRef,\n  ) {}\n\n  /**\n   * Helper method that sets a property on a target element using the current Renderer\n   * implementation.\n   * @nodoc\n   */\n  protected setProperty(key: string, value: any): void {\n    this._renderer.setProperty(this._elementRef.nativeElement, key, value);\n  }\n\n  /**\n   * Registers a function called when the control is touched.\n   * @nodoc\n   */\n  registerOnTouched(fn: () => void): void {\n    this.onTouched = fn;\n  }\n\n  /**\n   * Registers a function called when the control value changes.\n   * @nodoc\n   */\n  registerOnChange(fn: (_: any) => {}): void {\n    this.onChange = fn;\n  }\n\n  /**\n   * Sets the \"disabled\" property on the range input element.\n   * @nodoc\n   */\n  setDisabledState(isDisabled: boolean): void {\n    this.setProperty('disabled', isDisabled);\n  }\n}\n\n/**\n * Base class for all built-in ControlValueAccessor classes (except DefaultValueAccessor, which is\n * used in case no other CVAs can be found). We use this class to distinguish between default CVA,\n * built-in CVAs and custom CVAs, so that Forms logic can recognize built-in CVAs and treat custom\n * ones with higher priority (when both built-in and custom CVAs are present).\n *\n * Note: this is an *internal-only* class and should not be extended or used directly in\n * applications code.\n */\n@Directive()\nexport class BuiltInControlValueAccessor extends BaseControlValueAccessor {}\n\n/**\n * Used to provide a `ControlValueAccessor` for form controls.\n *\n * See `DefaultValueAccessor` for how to implement one.\n *\n * @publicApi\n */\nexport const NG_VALUE_ACCESSOR = new InjectionToken<ReadonlyArray<ControlValueAccessor>>(\n  ngDevMode ? 'NgValueAccessor' : '',\n);\n"]}
|
|
@@ -1,124 +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 { ɵgetDOM as getDOM } from '@angular/common';
|
|
9
|
-
import { Directive, ElementRef, forwardRef, Inject, InjectionToken, Optional, Renderer2, } from '@angular/core';
|
|
10
|
-
import { BaseControlValueAccessor, NG_VALUE_ACCESSOR, } from './control_value_accessor';
|
|
11
|
-
import * as i0 from "@angular/core";
|
|
12
|
-
export const DEFAULT_VALUE_ACCESSOR = {
|
|
13
|
-
provide: NG_VALUE_ACCESSOR,
|
|
14
|
-
useExisting: forwardRef(() => DefaultValueAccessor),
|
|
15
|
-
multi: true,
|
|
16
|
-
};
|
|
17
|
-
/**
|
|
18
|
-
* We must check whether the agent is Android because composition events
|
|
19
|
-
* behave differently between iOS and Android.
|
|
20
|
-
*/
|
|
21
|
-
function _isAndroid() {
|
|
22
|
-
const userAgent = getDOM() ? getDOM().getUserAgent() : '';
|
|
23
|
-
return /android (\d+)/.test(userAgent.toLowerCase());
|
|
24
|
-
}
|
|
25
|
-
/**
|
|
26
|
-
* @description
|
|
27
|
-
* Provide this token to control if form directives buffer IME input until
|
|
28
|
-
* the "compositionend" event occurs.
|
|
29
|
-
* @publicApi
|
|
30
|
-
*/
|
|
31
|
-
export const COMPOSITION_BUFFER_MODE = new InjectionToken(ngDevMode ? 'CompositionEventMode' : '');
|
|
32
|
-
/**
|
|
33
|
-
* The default `ControlValueAccessor` for writing a value and listening to changes on input
|
|
34
|
-
* elements. The accessor is used by the `FormControlDirective`, `FormControlName`, and
|
|
35
|
-
* `NgModel` directives.
|
|
36
|
-
*
|
|
37
|
-
* {@searchKeywords ngDefaultControl}
|
|
38
|
-
*
|
|
39
|
-
* @usageNotes
|
|
40
|
-
*
|
|
41
|
-
* ### Using the default value accessor
|
|
42
|
-
*
|
|
43
|
-
* The following example shows how to use an input element that activates the default value accessor
|
|
44
|
-
* (in this case, a text field).
|
|
45
|
-
*
|
|
46
|
-
* ```ts
|
|
47
|
-
* const firstNameControl = new FormControl();
|
|
48
|
-
* ```
|
|
49
|
-
*
|
|
50
|
-
* ```
|
|
51
|
-
* <input type="text" [formControl]="firstNameControl">
|
|
52
|
-
* ```
|
|
53
|
-
*
|
|
54
|
-
* This value accessor is used by default for `<input type="text">` and `<textarea>` elements, but
|
|
55
|
-
* you could also use it for custom components that have similar behavior and do not require special
|
|
56
|
-
* processing. In order to attach the default value accessor to a custom element, add the
|
|
57
|
-
* `ngDefaultControl` attribute as shown below.
|
|
58
|
-
*
|
|
59
|
-
* ```
|
|
60
|
-
* <custom-input-component ngDefaultControl [(ngModel)]="value"></custom-input-component>
|
|
61
|
-
* ```
|
|
62
|
-
*
|
|
63
|
-
* @ngModule ReactiveFormsModule
|
|
64
|
-
* @ngModule FormsModule
|
|
65
|
-
* @publicApi
|
|
66
|
-
*/
|
|
67
|
-
export class DefaultValueAccessor extends BaseControlValueAccessor {
|
|
68
|
-
constructor(renderer, elementRef, _compositionMode) {
|
|
69
|
-
super(renderer, elementRef);
|
|
70
|
-
this._compositionMode = _compositionMode;
|
|
71
|
-
/** Whether the user is creating a composition string (IME events). */
|
|
72
|
-
this._composing = false;
|
|
73
|
-
if (this._compositionMode == null) {
|
|
74
|
-
this._compositionMode = !_isAndroid();
|
|
75
|
-
}
|
|
76
|
-
}
|
|
77
|
-
/**
|
|
78
|
-
* Sets the "value" property on the input element.
|
|
79
|
-
* @nodoc
|
|
80
|
-
*/
|
|
81
|
-
writeValue(value) {
|
|
82
|
-
const normalizedValue = value == null ? '' : value;
|
|
83
|
-
this.setProperty('value', normalizedValue);
|
|
84
|
-
}
|
|
85
|
-
/** @internal */
|
|
86
|
-
_handleInput(value) {
|
|
87
|
-
if (!this._compositionMode || (this._compositionMode && !this._composing)) {
|
|
88
|
-
this.onChange(value);
|
|
89
|
-
}
|
|
90
|
-
}
|
|
91
|
-
/** @internal */
|
|
92
|
-
_compositionStart() {
|
|
93
|
-
this._composing = true;
|
|
94
|
-
}
|
|
95
|
-
/** @internal */
|
|
96
|
-
_compositionEnd(value) {
|
|
97
|
-
this._composing = false;
|
|
98
|
-
this._compositionMode && this.onChange(value);
|
|
99
|
-
}
|
|
100
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.0.0-next.1", ngImport: i0, type: DefaultValueAccessor, deps: [{ token: i0.Renderer2 }, { token: i0.ElementRef }, { token: COMPOSITION_BUFFER_MODE, optional: true }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
101
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "19.0.0-next.1", type: DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]", host: { listeners: { "input": "$any(this)._handleInput($event.target.value)", "blur": "onTouched()", "compositionstart": "$any(this)._compositionStart()", "compositionend": "$any(this)._compositionEnd($event.target.value)" } }, providers: [DEFAULT_VALUE_ACCESSOR], usesInheritance: true, ngImport: i0 }); }
|
|
102
|
-
}
|
|
103
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.0.0-next.1", ngImport: i0, type: DefaultValueAccessor, decorators: [{
|
|
104
|
-
type: Directive,
|
|
105
|
-
args: [{
|
|
106
|
-
selector: 'input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]',
|
|
107
|
-
// TODO: vsavkin replace the above selector with the one below it once
|
|
108
|
-
// https://github.com/angular/angular/issues/3011 is implemented
|
|
109
|
-
// selector: '[ngModel],[formControl],[formControlName]',
|
|
110
|
-
host: {
|
|
111
|
-
'(input)': '$any(this)._handleInput($event.target.value)',
|
|
112
|
-
'(blur)': 'onTouched()',
|
|
113
|
-
'(compositionstart)': '$any(this)._compositionStart()',
|
|
114
|
-
'(compositionend)': '$any(this)._compositionEnd($event.target.value)',
|
|
115
|
-
},
|
|
116
|
-
providers: [DEFAULT_VALUE_ACCESSOR],
|
|
117
|
-
}]
|
|
118
|
-
}], ctorParameters: () => [{ type: i0.Renderer2 }, { type: i0.ElementRef }, { type: undefined, decorators: [{
|
|
119
|
-
type: Optional
|
|
120
|
-
}, {
|
|
121
|
-
type: Inject,
|
|
122
|
-
args: [COMPOSITION_BUFFER_MODE]
|
|
123
|
-
}] }] });
|
|
124
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"default_value_accessor.js","sourceRoot":"","sources":["../../../../../../../packages/forms/src/directives/default_value_accessor.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAEH,OAAO,EAAC,OAAO,IAAI,MAAM,EAAC,MAAM,iBAAiB,CAAC;AAClD,OAAO,EACL,SAAS,EACT,UAAU,EACV,UAAU,EACV,MAAM,EACN,cAAc,EACd,QAAQ,EAER,SAAS,GACV,MAAM,eAAe,CAAC;AAEvB,OAAO,EACL,wBAAwB,EAExB,iBAAiB,GAClB,MAAM,0BAA0B,CAAC;;AAElC,MAAM,CAAC,MAAM,sBAAsB,GAAa;IAC9C,OAAO,EAAE,iBAAiB;IAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,oBAAoB,CAAC;IACnD,KAAK,EAAE,IAAI;CACZ,CAAC;AAEF;;;GAGG;AACH,SAAS,UAAU;IACjB,MAAM,SAAS,GAAG,MAAM,EAAE,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC,YAAY,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;IAC1D,OAAO,eAAe,CAAC,IAAI,CAAC,SAAS,CAAC,WAAW,EAAE,CAAC,CAAC;AACvD,CAAC;AAED;;;;;GAKG;AACH,MAAM,CAAC,MAAM,uBAAuB,GAAG,IAAI,cAAc,CACvD,SAAS,CAAC,CAAC,CAAC,sBAAsB,CAAC,CAAC,CAAC,EAAE,CACxC,CAAC;AAEF;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAkCG;AAeH,MAAM,OAAO,oBAAqB,SAAQ,wBAAwB;IAIhE,YACE,QAAmB,EACnB,UAAsB,EAC+B,gBAAyB;QAE9E,KAAK,CAAC,QAAQ,EAAE,UAAU,CAAC,CAAC;QAFyB,qBAAgB,GAAhB,gBAAgB,CAAS;QANhF,sEAAsE;QAC9D,eAAU,GAAG,KAAK,CAAC;QAQzB,IAAI,IAAI,CAAC,gBAAgB,IAAI,IAAI,EAAE,CAAC;YAClC,IAAI,CAAC,gBAAgB,GAAG,CAAC,UAAU,EAAE,CAAC;QACxC,CAAC;IACH,CAAC;IAED;;;OAGG;IACH,UAAU,CAAC,KAAU;QACnB,MAAM,eAAe,GAAG,KAAK,IAAI,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC;QACnD,IAAI,CAAC,WAAW,CAAC,OAAO,EAAE,eAAe,CAAC,CAAC;IAC7C,CAAC;IAED,gBAAgB;IAChB,YAAY,CAAC,KAAU;QACrB,IAAI,CAAC,IAAI,CAAC,gBAAgB,IAAI,CAAC,IAAI,CAAC,gBAAgB,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE,CAAC;YAC1E,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;QACvB,CAAC;IACH,CAAC;IAED,gBAAgB;IAChB,iBAAiB;QACf,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;IACzB,CAAC;IAED,gBAAgB;IAChB,eAAe,CAAC,KAAU;QACxB,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;QACxB,IAAI,CAAC,gBAAgB,IAAI,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;IAChD,CAAC;yHAxCU,oBAAoB,qEAOT,uBAAuB;6GAPlC,oBAAoB,2cAFpB,CAAC,sBAAsB,CAAC;;sGAExB,oBAAoB;kBAdhC,SAAS;mBAAC;oBACT,QAAQ,EACN,8MAA8M;oBAChN,sEAAsE;oBACtE,gEAAgE;oBAChE,yDAAyD;oBACzD,IAAI,EAAE;wBACJ,SAAS,EAAE,8CAA8C;wBACzD,QAAQ,EAAE,aAAa;wBACvB,oBAAoB,EAAE,gCAAgC;wBACtD,kBAAkB,EAAE,iDAAiD;qBACtE;oBACD,SAAS,EAAE,CAAC,sBAAsB,CAAC;iBACpC;;0BAQI,QAAQ;;0BAAI,MAAM;2BAAC,uBAAuB","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 {ɵgetDOM as getDOM} from '@angular/common';\nimport {\n  Directive,\n  ElementRef,\n  forwardRef,\n  Inject,\n  InjectionToken,\n  Optional,\n  Provider,\n  Renderer2,\n} from '@angular/core';\n\nimport {\n  BaseControlValueAccessor,\n  ControlValueAccessor,\n  NG_VALUE_ACCESSOR,\n} from './control_value_accessor';\n\nexport const DEFAULT_VALUE_ACCESSOR: Provider = {\n  provide: NG_VALUE_ACCESSOR,\n  useExisting: forwardRef(() => DefaultValueAccessor),\n  multi: true,\n};\n\n/**\n * We must check whether the agent is Android because composition events\n * behave differently between iOS and Android.\n */\nfunction _isAndroid(): boolean {\n  const userAgent = getDOM() ? getDOM().getUserAgent() : '';\n  return /android (\\d+)/.test(userAgent.toLowerCase());\n}\n\n/**\n * @description\n * Provide this token to control if form directives buffer IME input until\n * the \"compositionend\" event occurs.\n * @publicApi\n */\nexport const COMPOSITION_BUFFER_MODE = new InjectionToken<boolean>(\n  ngDevMode ? 'CompositionEventMode' : '',\n);\n\n/**\n * The default `ControlValueAccessor` for writing a value and listening to changes on input\n * elements. The accessor is used by the `FormControlDirective`, `FormControlName`, and\n * `NgModel` directives.\n *\n * {@searchKeywords ngDefaultControl}\n *\n * @usageNotes\n *\n * ### Using the default value accessor\n *\n * The following example shows how to use an input element that activates the default value accessor\n * (in this case, a text field).\n *\n * ```ts\n * const firstNameControl = new FormControl();\n * ```\n *\n * ```\n * <input type=\"text\" [formControl]=\"firstNameControl\">\n * ```\n *\n * This value accessor is used by default for `<input type=\"text\">` and `<textarea>` elements, but\n * you could also use it for custom components that have similar behavior and do not require special\n * processing. In order to attach the default value accessor to a custom element, add the\n * `ngDefaultControl` attribute as shown below.\n *\n * ```\n * <custom-input-component ngDefaultControl [(ngModel)]=\"value\"></custom-input-component>\n * ```\n *\n * @ngModule ReactiveFormsModule\n * @ngModule FormsModule\n * @publicApi\n */\n@Directive({\n  selector:\n    'input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]',\n  // TODO: vsavkin replace the above selector with the one below it once\n  // https://github.com/angular/angular/issues/3011 is implemented\n  // selector: '[ngModel],[formControl],[formControlName]',\n  host: {\n    '(input)': '$any(this)._handleInput($event.target.value)',\n    '(blur)': 'onTouched()',\n    '(compositionstart)': '$any(this)._compositionStart()',\n    '(compositionend)': '$any(this)._compositionEnd($event.target.value)',\n  },\n  providers: [DEFAULT_VALUE_ACCESSOR],\n})\nexport class DefaultValueAccessor extends BaseControlValueAccessor implements ControlValueAccessor {\n  /** Whether the user is creating a composition string (IME events). */\n  private _composing = false;\n\n  constructor(\n    renderer: Renderer2,\n    elementRef: ElementRef,\n    @Optional() @Inject(COMPOSITION_BUFFER_MODE) private _compositionMode: boolean,\n  ) {\n    super(renderer, elementRef);\n    if (this._compositionMode == null) {\n      this._compositionMode = !_isAndroid();\n    }\n  }\n\n  /**\n   * Sets the \"value\" property on the input element.\n   * @nodoc\n   */\n  writeValue(value: any): void {\n    const normalizedValue = value == null ? '' : value;\n    this.setProperty('value', normalizedValue);\n  }\n\n  /** @internal */\n  _handleInput(value: any): void {\n    if (!this._compositionMode || (this._compositionMode && !this._composing)) {\n      this.onChange(value);\n    }\n  }\n\n  /** @internal */\n  _compositionStart(): void {\n    this._composing = true;\n  }\n\n  /** @internal */\n  _compositionEnd(value: any): void {\n    this._composing = false;\n    this._compositionMode && this.onChange(value);\n  }\n}\n"]}
|
|
@@ -1,57 +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
|
-
export const formControlNameExample = `
|
|
9
|
-
<div [formGroup]="myGroup">
|
|
10
|
-
<input formControlName="firstName">
|
|
11
|
-
</div>
|
|
12
|
-
|
|
13
|
-
In your class:
|
|
14
|
-
|
|
15
|
-
this.myGroup = new FormGroup({
|
|
16
|
-
firstName: new FormControl()
|
|
17
|
-
});`;
|
|
18
|
-
export const formGroupNameExample = `
|
|
19
|
-
<div [formGroup]="myGroup">
|
|
20
|
-
<div formGroupName="person">
|
|
21
|
-
<input formControlName="firstName">
|
|
22
|
-
</div>
|
|
23
|
-
</div>
|
|
24
|
-
|
|
25
|
-
In your class:
|
|
26
|
-
|
|
27
|
-
this.myGroup = new FormGroup({
|
|
28
|
-
person: new FormGroup({ firstName: new FormControl() })
|
|
29
|
-
});`;
|
|
30
|
-
export const formArrayNameExample = `
|
|
31
|
-
<div [formGroup]="myGroup">
|
|
32
|
-
<div formArrayName="cities">
|
|
33
|
-
<div *ngFor="let city of cityArray.controls; index as i">
|
|
34
|
-
<input [formControlName]="i">
|
|
35
|
-
</div>
|
|
36
|
-
</div>
|
|
37
|
-
</div>
|
|
38
|
-
|
|
39
|
-
In your class:
|
|
40
|
-
|
|
41
|
-
this.cityArray = new FormArray([new FormControl('SF')]);
|
|
42
|
-
this.myGroup = new FormGroup({
|
|
43
|
-
cities: this.cityArray
|
|
44
|
-
});`;
|
|
45
|
-
export const ngModelGroupExample = `
|
|
46
|
-
<form>
|
|
47
|
-
<div ngModelGroup="person">
|
|
48
|
-
<input [(ngModel)]="person.name" name="firstName">
|
|
49
|
-
</div>
|
|
50
|
-
</form>`;
|
|
51
|
-
export const ngModelWithFormGroupExample = `
|
|
52
|
-
<div [formGroup]="myGroup">
|
|
53
|
-
<input formControlName="firstName">
|
|
54
|
-
<input [(ngModel)]="showMoreControls" [ngModelOptions]="{standalone: true}">
|
|
55
|
-
</div>
|
|
56
|
-
`;
|
|
57
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXJyb3JfZXhhbXBsZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9mb3Jtcy9zcmMvZGlyZWN0aXZlcy9lcnJvcl9leGFtcGxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7O0dBTUc7QUFFSCxNQUFNLENBQUMsTUFBTSxzQkFBc0IsR0FBRzs7Ozs7Ozs7O01BU2hDLENBQUM7QUFFUCxNQUFNLENBQUMsTUFBTSxvQkFBb0IsR0FBRzs7Ozs7Ozs7Ozs7TUFXOUIsQ0FBQztBQUVQLE1BQU0sQ0FBQyxNQUFNLG9CQUFvQixHQUFHOzs7Ozs7Ozs7Ozs7OztNQWM5QixDQUFDO0FBRVAsTUFBTSxDQUFDLE1BQU0sbUJBQW1CLEdBQUc7Ozs7O1VBS3pCLENBQUM7QUFFWCxNQUFNLENBQUMsTUFBTSwyQkFBMkIsR0FBRzs7Ozs7Q0FLMUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQGxpY2Vuc2VcbiAqIENvcHlyaWdodCBHb29nbGUgTExDIEFsbCBSaWdodHMgUmVzZXJ2ZWQuXG4gKlxuICogVXNlIG9mIHRoaXMgc291cmNlIGNvZGUgaXMgZ292ZXJuZWQgYnkgYW4gTUlULXN0eWxlIGxpY2Vuc2UgdGhhdCBjYW4gYmVcbiAqIGZvdW5kIGluIHRoZSBMSUNFTlNFIGZpbGUgYXQgaHR0cHM6Ly9hbmd1bGFyLmlvL2xpY2Vuc2VcbiAqL1xuXG5leHBvcnQgY29uc3QgZm9ybUNvbnRyb2xOYW1lRXhhbXBsZSA9IGBcbiAgPGRpdiBbZm9ybUdyb3VwXT1cIm15R3JvdXBcIj5cbiAgICA8aW5wdXQgZm9ybUNvbnRyb2xOYW1lPVwiZmlyc3ROYW1lXCI+XG4gIDwvZGl2PlxuXG4gIEluIHlvdXIgY2xhc3M6XG5cbiAgdGhpcy5teUdyb3VwID0gbmV3IEZvcm1Hcm91cCh7XG4gICAgICBmaXJzdE5hbWU6IG5ldyBGb3JtQ29udHJvbCgpXG4gIH0pO2A7XG5cbmV4cG9ydCBjb25zdCBmb3JtR3JvdXBOYW1lRXhhbXBsZSA9IGBcbiAgPGRpdiBbZm9ybUdyb3VwXT1cIm15R3JvdXBcIj5cbiAgICAgIDxkaXYgZm9ybUdyb3VwTmFtZT1cInBlcnNvblwiPlxuICAgICAgICA8aW5wdXQgZm9ybUNvbnRyb2xOYW1lPVwiZmlyc3ROYW1lXCI+XG4gICAgICA8L2Rpdj5cbiAgPC9kaXY+XG5cbiAgSW4geW91ciBjbGFzczpcblxuICB0aGlzLm15R3JvdXAgPSBuZXcgRm9ybUdyb3VwKHtcbiAgICAgIHBlcnNvbjogbmV3IEZvcm1Hcm91cCh7IGZpcnN0TmFtZTogbmV3IEZvcm1Db250cm9sKCkgfSlcbiAgfSk7YDtcblxuZXhwb3J0IGNvbnN0IGZvcm1BcnJheU5hbWVFeGFtcGxlID0gYFxuICA8ZGl2IFtmb3JtR3JvdXBdPVwibXlHcm91cFwiPlxuICAgIDxkaXYgZm9ybUFycmF5TmFtZT1cImNpdGllc1wiPlxuICAgICAgPGRpdiAqbmdGb3I9XCJsZXQgY2l0eSBvZiBjaXR5QXJyYXkuY29udHJvbHM7IGluZGV4IGFzIGlcIj5cbiAgICAgICAgPGlucHV0IFtmb3JtQ29udHJvbE5hbWVdPVwiaVwiPlxuICAgICAgPC9kaXY+XG4gICAgPC9kaXY+XG4gIDwvZGl2PlxuXG4gIEluIHlvdXIgY2xhc3M6XG5cbiAgdGhpcy5jaXR5QXJyYXkgPSBuZXcgRm9ybUFycmF5KFtuZXcgRm9ybUNvbnRyb2woJ1NGJyldKTtcbiAgdGhpcy5teUdyb3VwID0gbmV3IEZvcm1Hcm91cCh7XG4gICAgY2l0aWVzOiB0aGlzLmNpdHlBcnJheVxuICB9KTtgO1xuXG5leHBvcnQgY29uc3QgbmdNb2RlbEdyb3VwRXhhbXBsZSA9IGBcbiAgPGZvcm0+XG4gICAgICA8ZGl2IG5nTW9kZWxHcm91cD1cInBlcnNvblwiPlxuICAgICAgICA8aW5wdXQgWyhuZ01vZGVsKV09XCJwZXJzb24ubmFtZVwiIG5hbWU9XCJmaXJzdE5hbWVcIj5cbiAgICAgIDwvZGl2PlxuICA8L2Zvcm0+YDtcblxuZXhwb3J0IGNvbnN0IG5nTW9kZWxXaXRoRm9ybUdyb3VwRXhhbXBsZSA9IGBcbiAgPGRpdiBbZm9ybUdyb3VwXT1cIm15R3JvdXBcIj5cbiAgICAgIDxpbnB1dCBmb3JtQ29udHJvbE5hbWU9XCJmaXJzdE5hbWVcIj5cbiAgICAgIDxpbnB1dCBbKG5nTW9kZWwpXT1cInNob3dNb3JlQ29udHJvbHNcIiBbbmdNb2RlbE9wdGlvbnNdPVwie3N0YW5kYWxvbmU6IHRydWV9XCI+XG4gIDwvZGl2PlxuYDtcbiJdfQ==
|
|
@@ -1,9 +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
|
-
export {};
|
|
9
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybV9pbnRlcmZhY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9mb3Jtcy9zcmMvZGlyZWN0aXZlcy9mb3JtX2ludGVyZmFjZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7O0dBTUciLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBsaWNlbnNlXG4gKiBDb3B5cmlnaHQgR29vZ2xlIExMQyBBbGwgUmlnaHRzIFJlc2VydmVkLlxuICpcbiAqIFVzZSBvZiB0aGlzIHNvdXJjZSBjb2RlIGlzIGdvdmVybmVkIGJ5IGFuIE1JVC1zdHlsZSBsaWNlbnNlIHRoYXQgY2FuIGJlXG4gKiBmb3VuZCBpbiB0aGUgTElDRU5TRSBmaWxlIGF0IGh0dHBzOi8vYW5ndWxhci5pby9saWNlbnNlXG4gKi9cblxuaW1wb3J0IHtGb3JtQ29udHJvbH0gZnJvbSAnLi4vbW9kZWwvZm9ybV9jb250cm9sJztcbmltcG9ydCB7Rm9ybUdyb3VwfSBmcm9tICcuLi9tb2RlbC9mb3JtX2dyb3VwJztcblxuaW1wb3J0IHtBYnN0cmFjdEZvcm1Hcm91cERpcmVjdGl2ZX0gZnJvbSAnLi9hYnN0cmFjdF9mb3JtX2dyb3VwX2RpcmVjdGl2ZSc7XG5pbXBvcnQge05nQ29udHJvbH0gZnJvbSAnLi9uZ19jb250cm9sJztcblxuLyoqXG4gKiBAZGVzY3JpcHRpb25cbiAqIEFuIGludGVyZmFjZSBpbXBsZW1lbnRlZCBieSBgRm9ybUdyb3VwRGlyZWN0aXZlYCBhbmQgYE5nRm9ybWAgZGlyZWN0aXZlcy5cbiAqXG4gKiBPbmx5IHVzZWQgYnkgdGhlIGBSZWFjdGl2ZUZvcm1zTW9kdWxlYCBhbmQgYEZvcm1zTW9kdWxlYC5cbiAqXG4gKiBAcHVibGljQXBpXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgRm9ybSB7XG4gIC8qKlxuICAgKiBAZGVzY3JpcHRpb25cbiAgICogQWRkIGEgY29udHJvbCB0byB0aGlzIGZvcm0uXG4gICAqXG4gICAqIEBwYXJhbSBkaXIgVGhlIGNvbnRyb2wgZGlyZWN0aXZlIHRvIGFkZCB0byB0aGUgZm9ybS5cbiAgICovXG4gIGFkZENvbnRyb2woZGlyOiBOZ0NvbnRyb2wpOiB2b2lkO1xuXG4gIC8qKlxuICAgKiBAZGVzY3JpcHRpb25cbiAgICogUmVtb3ZlIGEgY29udHJvbCBmcm9tIHRoaXMgZm9ybS5cbiAgICpcbiAgICogQHBhcmFtIGRpcjogVGhlIGNvbnRyb2wgZGlyZWN0aXZlIHRvIHJlbW92ZSBmcm9tIHRoZSBmb3JtLlxuICAgKi9cbiAgcmVtb3ZlQ29udHJvbChkaXI6IE5nQ29udHJvbCk6IHZvaWQ7XG5cbiAgLyoqXG4gICAqIEBkZXNjcmlwdGlvblxuICAgKiBUaGUgY29udHJvbCBkaXJlY3RpdmUgZnJvbSB3aGljaCB0byBnZXQgdGhlIGBGb3JtQ29udHJvbGAuXG4gICAqXG4gICAqIEBwYXJhbSBkaXI6IFRoZSBjb250cm9sIGRpcmVjdGl2ZS5cbiAgICovXG4gIGdldENvbnRyb2woZGlyOiBOZ0NvbnRyb2wpOiBGb3JtQ29udHJvbDtcblxuICAvKipcbiAgICogQGRlc2NyaXB0aW9uXG4gICAqIEFkZCBhIGdyb3VwIG9mIGNvbnRyb2xzIHRvIHRoaXMgZm9ybS5cbiAgICpcbiAgICogQHBhcmFtIGRpcjogVGhlIGNvbnRyb2wgZ3JvdXAgZGlyZWN0aXZlIHRvIGFkZC5cbiAgICovXG4gIGFkZEZvcm1Hcm91cChkaXI6IEFic3RyYWN0Rm9ybUdyb3VwRGlyZWN0aXZlKTogdm9pZDtcblxuICAvKipcbiAgICogQGRlc2NyaXB0aW9uXG4gICAqIFJlbW92ZSBhIGdyb3VwIG9mIGNvbnRyb2xzIHRvIHRoaXMgZm9ybS5cbiAgICpcbiAgICogQHBhcmFtIGRpcjogVGhlIGNvbnRyb2wgZ3JvdXAgZGlyZWN0aXZlIHRvIHJlbW92ZS5cbiAgICovXG4gIHJlbW92ZUZvcm1Hcm91cChkaXI6IEFic3RyYWN0Rm9ybUdyb3VwRGlyZWN0aXZlKTogdm9pZDtcblxuICAvKipcbiAgICogQGRlc2NyaXB0aW9uXG4gICAqIFRoZSBgRm9ybUdyb3VwYCBhc3NvY2lhdGVkIHdpdGggYSBwYXJ0aWN1bGFyIGBBYnN0cmFjdEZvcm1Hcm91cERpcmVjdGl2ZWAuXG4gICAqXG4gICAqIEBwYXJhbSBkaXI6IFRoZSBmb3JtIGdyb3VwIGRpcmVjdGl2ZSBmcm9tIHdoaWNoIHRvIGdldCB0aGUgYEZvcm1Hcm91cGAuXG4gICAqL1xuICBnZXRGb3JtR3JvdXAoZGlyOiBBYnN0cmFjdEZvcm1Hcm91cERpcmVjdGl2ZSk6IEZvcm1Hcm91cDtcblxuICAvKipcbiAgICogQGRlc2NyaXB0aW9uXG4gICAqIFVwZGF0ZSB0aGUgbW9kZWwgZm9yIGEgcGFydGljdWxhciBjb250cm9sIHdpdGggYSBuZXcgdmFsdWUuXG4gICAqXG4gICAqIEBwYXJhbSBkaXI6IFRoZSBjb250cm9sIGRpcmVjdGl2ZSB0byB1cGRhdGUuXG4gICAqIEBwYXJhbSB2YWx1ZTogVGhlIG5ldyB2YWx1ZSBmb3IgdGhlIGNvbnRyb2wuXG4gICAqL1xuICB1cGRhdGVNb2RlbChkaXI6IE5nQ29udHJvbCwgdmFsdWU6IGFueSk6IHZvaWQ7XG59XG4iXX0=
|
|
@@ -1,38 +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 { AbstractControlDirective } from './abstract_control_directive';
|
|
9
|
-
/**
|
|
10
|
-
* @description
|
|
11
|
-
* A base class that all `FormControl`-based directives extend. It binds a `FormControl`
|
|
12
|
-
* object to a DOM element.
|
|
13
|
-
*
|
|
14
|
-
* @publicApi
|
|
15
|
-
*/
|
|
16
|
-
export class NgControl extends AbstractControlDirective {
|
|
17
|
-
constructor() {
|
|
18
|
-
super(...arguments);
|
|
19
|
-
/**
|
|
20
|
-
* @description
|
|
21
|
-
* The parent form for the control.
|
|
22
|
-
*
|
|
23
|
-
* @internal
|
|
24
|
-
*/
|
|
25
|
-
this._parent = null;
|
|
26
|
-
/**
|
|
27
|
-
* @description
|
|
28
|
-
* The name for the control
|
|
29
|
-
*/
|
|
30
|
-
this.name = null;
|
|
31
|
-
/**
|
|
32
|
-
* @description
|
|
33
|
-
* The value accessor for the control
|
|
34
|
-
*/
|
|
35
|
-
this.valueAccessor = null;
|
|
36
|
-
}
|
|
37
|
-
}
|
|
38
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmdfY29udHJvbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2Zvcm1zL3NyYy9kaXJlY3RpdmVzL25nX2NvbnRyb2wudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7OztHQU1HO0FBRUgsT0FBTyxFQUFDLHdCQUF3QixFQUFDLE1BQU0sOEJBQThCLENBQUM7QUFJdEU7Ozs7OztHQU1HO0FBQ0gsTUFBTSxPQUFnQixTQUFVLFNBQVEsd0JBQXdCO0lBQWhFOztRQUNFOzs7OztXQUtHO1FBQ0gsWUFBTyxHQUE0QixJQUFJLENBQUM7UUFFeEM7OztXQUdHO1FBQ0gsU0FBSSxHQUEyQixJQUFJLENBQUM7UUFFcEM7OztXQUdHO1FBQ0gsa0JBQWEsR0FBZ0MsSUFBSSxDQUFDO0lBU3BELENBQUM7Q0FBQSIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQGxpY2Vuc2VcbiAqIENvcHlyaWdodCBHb29nbGUgTExDIEFsbCBSaWdodHMgUmVzZXJ2ZWQuXG4gKlxuICogVXNlIG9mIHRoaXMgc291cmNlIGNvZGUgaXMgZ292ZXJuZWQgYnkgYW4gTUlULXN0eWxlIGxpY2Vuc2UgdGhhdCBjYW4gYmVcbiAqIGZvdW5kIGluIHRoZSBMSUNFTlNFIGZpbGUgYXQgaHR0cHM6Ly9hbmd1bGFyLmlvL2xpY2Vuc2VcbiAqL1xuXG5pbXBvcnQge0Fic3RyYWN0Q29udHJvbERpcmVjdGl2ZX0gZnJvbSAnLi9hYnN0cmFjdF9jb250cm9sX2RpcmVjdGl2ZSc7XG5pbXBvcnQge0NvbnRyb2xDb250YWluZXJ9IGZyb20gJy4vY29udHJvbF9jb250YWluZXInO1xuaW1wb3J0IHtDb250cm9sVmFsdWVBY2Nlc3Nvcn0gZnJvbSAnLi9jb250cm9sX3ZhbHVlX2FjY2Vzc29yJztcblxuLyoqXG4gKiBAZGVzY3JpcHRpb25cbiAqIEEgYmFzZSBjbGFzcyB0aGF0IGFsbCBgRm9ybUNvbnRyb2xgLWJhc2VkIGRpcmVjdGl2ZXMgZXh0ZW5kLiBJdCBiaW5kcyBhIGBGb3JtQ29udHJvbGBcbiAqIG9iamVjdCB0byBhIERPTSBlbGVtZW50LlxuICpcbiAqIEBwdWJsaWNBcGlcbiAqL1xuZXhwb3J0IGFic3RyYWN0IGNsYXNzIE5nQ29udHJvbCBleHRlbmRzIEFic3RyYWN0Q29udHJvbERpcmVjdGl2ZSB7XG4gIC8qKlxuICAgKiBAZGVzY3JpcHRpb25cbiAgICogVGhlIHBhcmVudCBmb3JtIGZvciB0aGUgY29udHJvbC5cbiAgICpcbiAgICogQGludGVybmFsXG4gICAqL1xuICBfcGFyZW50OiBDb250cm9sQ29udGFpbmVyIHwgbnVsbCA9IG51bGw7XG5cbiAgLyoqXG4gICAqIEBkZXNjcmlwdGlvblxuICAgKiBUaGUgbmFtZSBmb3IgdGhlIGNvbnRyb2xcbiAgICovXG4gIG5hbWU6IHN0cmluZyB8IG51bWJlciB8IG51bGwgPSBudWxsO1xuXG4gIC8qKlxuICAgKiBAZGVzY3JpcHRpb25cbiAgICogVGhlIHZhbHVlIGFjY2Vzc29yIGZvciB0aGUgY29udHJvbFxuICAgKi9cbiAgdmFsdWVBY2Nlc3NvcjogQ29udHJvbFZhbHVlQWNjZXNzb3IgfCBudWxsID0gbnVsbDtcblxuICAvKipcbiAgICogQGRlc2NyaXB0aW9uXG4gICAqIFRoZSBjYWxsYmFjayBtZXRob2QgdG8gdXBkYXRlIHRoZSBtb2RlbCBmcm9tIHRoZSB2aWV3IHdoZW4gcmVxdWVzdGVkXG4gICAqXG4gICAqIEBwYXJhbSBuZXdWYWx1ZSBUaGUgbmV3IHZhbHVlIGZvciB0aGUgdmlld1xuICAgKi9cbiAgYWJzdHJhY3Qgdmlld1RvTW9kZWxVcGRhdGUobmV3VmFsdWU6IGFueSk6IHZvaWQ7XG59XG4iXX0=
|
|
@@ -1,139 +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, Optional, Self } from '@angular/core';
|
|
9
|
-
import { ControlContainer } from './control_container';
|
|
10
|
-
import { NgControl } from './ng_control';
|
|
11
|
-
import * as i0 from "@angular/core";
|
|
12
|
-
import * as i1 from "./ng_control";
|
|
13
|
-
import * as i2 from "./control_container";
|
|
14
|
-
// DO NOT REFACTOR!
|
|
15
|
-
// Each status is represented by a separate function to make sure that
|
|
16
|
-
// advanced Closure Compiler optimizations related to property renaming
|
|
17
|
-
// can work correctly.
|
|
18
|
-
export class AbstractControlStatus {
|
|
19
|
-
constructor(cd) {
|
|
20
|
-
this._cd = cd;
|
|
21
|
-
}
|
|
22
|
-
get isTouched() {
|
|
23
|
-
// track the touched signal
|
|
24
|
-
this._cd?.control?._touched?.();
|
|
25
|
-
return !!this._cd?.control?.touched;
|
|
26
|
-
}
|
|
27
|
-
get isUntouched() {
|
|
28
|
-
return !!this._cd?.control?.untouched;
|
|
29
|
-
}
|
|
30
|
-
get isPristine() {
|
|
31
|
-
// track the pristine signal
|
|
32
|
-
this._cd?.control?._pristine?.();
|
|
33
|
-
return !!this._cd?.control?.pristine;
|
|
34
|
-
}
|
|
35
|
-
get isDirty() {
|
|
36
|
-
// pristine signal already tracked above
|
|
37
|
-
return !!this._cd?.control?.dirty;
|
|
38
|
-
}
|
|
39
|
-
get isValid() {
|
|
40
|
-
// track the status signal
|
|
41
|
-
this._cd?.control?._status?.();
|
|
42
|
-
return !!this._cd?.control?.valid;
|
|
43
|
-
}
|
|
44
|
-
get isInvalid() {
|
|
45
|
-
// status signal already tracked above
|
|
46
|
-
return !!this._cd?.control?.invalid;
|
|
47
|
-
}
|
|
48
|
-
get isPending() {
|
|
49
|
-
// status signal already tracked above
|
|
50
|
-
return !!this._cd?.control?.pending;
|
|
51
|
-
}
|
|
52
|
-
get isSubmitted() {
|
|
53
|
-
// track the submitted signal
|
|
54
|
-
this._cd?._submitted?.();
|
|
55
|
-
// We check for the `submitted` field from `NgForm` and `FormGroupDirective` classes, but
|
|
56
|
-
// we avoid instanceof checks to prevent non-tree-shakable references to those types.
|
|
57
|
-
return !!this._cd?.submitted;
|
|
58
|
-
}
|
|
59
|
-
}
|
|
60
|
-
export const ngControlStatusHost = {
|
|
61
|
-
'[class.ng-untouched]': 'isUntouched',
|
|
62
|
-
'[class.ng-touched]': 'isTouched',
|
|
63
|
-
'[class.ng-pristine]': 'isPristine',
|
|
64
|
-
'[class.ng-dirty]': 'isDirty',
|
|
65
|
-
'[class.ng-valid]': 'isValid',
|
|
66
|
-
'[class.ng-invalid]': 'isInvalid',
|
|
67
|
-
'[class.ng-pending]': 'isPending',
|
|
68
|
-
};
|
|
69
|
-
export const ngGroupStatusHost = {
|
|
70
|
-
...ngControlStatusHost,
|
|
71
|
-
'[class.ng-submitted]': 'isSubmitted',
|
|
72
|
-
};
|
|
73
|
-
/**
|
|
74
|
-
* @description
|
|
75
|
-
* Directive automatically applied to Angular form controls that sets CSS classes
|
|
76
|
-
* based on control status.
|
|
77
|
-
*
|
|
78
|
-
* @usageNotes
|
|
79
|
-
*
|
|
80
|
-
* ### CSS classes applied
|
|
81
|
-
*
|
|
82
|
-
* The following classes are applied as the properties become true:
|
|
83
|
-
*
|
|
84
|
-
* * ng-valid
|
|
85
|
-
* * ng-invalid
|
|
86
|
-
* * ng-pending
|
|
87
|
-
* * ng-pristine
|
|
88
|
-
* * ng-dirty
|
|
89
|
-
* * ng-untouched
|
|
90
|
-
* * ng-touched
|
|
91
|
-
*
|
|
92
|
-
* @ngModule ReactiveFormsModule
|
|
93
|
-
* @ngModule FormsModule
|
|
94
|
-
* @publicApi
|
|
95
|
-
*/
|
|
96
|
-
export class NgControlStatus extends AbstractControlStatus {
|
|
97
|
-
constructor(cd) {
|
|
98
|
-
super(cd);
|
|
99
|
-
}
|
|
100
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.0.0-next.1", ngImport: i0, type: NgControlStatus, deps: [{ token: i1.NgControl, self: true }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
101
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "19.0.0-next.1", type: NgControlStatus, selector: "[formControlName],[ngModel],[formControl]", host: { properties: { "class.ng-untouched": "isUntouched", "class.ng-touched": "isTouched", "class.ng-pristine": "isPristine", "class.ng-dirty": "isDirty", "class.ng-valid": "isValid", "class.ng-invalid": "isInvalid", "class.ng-pending": "isPending" } }, usesInheritance: true, ngImport: i0 }); }
|
|
102
|
-
}
|
|
103
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.0.0-next.1", ngImport: i0, type: NgControlStatus, decorators: [{
|
|
104
|
-
type: Directive,
|
|
105
|
-
args: [{ selector: '[formControlName],[ngModel],[formControl]', host: ngControlStatusHost }]
|
|
106
|
-
}], ctorParameters: () => [{ type: i1.NgControl, decorators: [{
|
|
107
|
-
type: Self
|
|
108
|
-
}] }] });
|
|
109
|
-
/**
|
|
110
|
-
* @description
|
|
111
|
-
* Directive automatically applied to Angular form groups that sets CSS classes
|
|
112
|
-
* based on control status (valid/invalid/dirty/etc). On groups, this includes the additional
|
|
113
|
-
* class ng-submitted.
|
|
114
|
-
*
|
|
115
|
-
* @see {@link NgControlStatus}
|
|
116
|
-
*
|
|
117
|
-
* @ngModule ReactiveFormsModule
|
|
118
|
-
* @ngModule FormsModule
|
|
119
|
-
* @publicApi
|
|
120
|
-
*/
|
|
121
|
-
export class NgControlStatusGroup extends AbstractControlStatus {
|
|
122
|
-
constructor(cd) {
|
|
123
|
-
super(cd);
|
|
124
|
-
}
|
|
125
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.0.0-next.1", ngImport: i0, type: NgControlStatusGroup, deps: [{ token: i2.ControlContainer, optional: true, self: true }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
126
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "19.0.0-next.1", type: NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]", host: { properties: { "class.ng-untouched": "isUntouched", "class.ng-touched": "isTouched", "class.ng-pristine": "isPristine", "class.ng-dirty": "isDirty", "class.ng-valid": "isValid", "class.ng-invalid": "isInvalid", "class.ng-pending": "isPending", "class.ng-submitted": "isSubmitted" } }, usesInheritance: true, ngImport: i0 }); }
|
|
127
|
-
}
|
|
128
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.0.0-next.1", ngImport: i0, type: NgControlStatusGroup, decorators: [{
|
|
129
|
-
type: Directive,
|
|
130
|
-
args: [{
|
|
131
|
-
selector: '[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]',
|
|
132
|
-
host: ngGroupStatusHost,
|
|
133
|
-
}]
|
|
134
|
-
}], ctorParameters: () => [{ type: i2.ControlContainer, decorators: [{
|
|
135
|
-
type: Optional
|
|
136
|
-
}, {
|
|
137
|
-
type: Self
|
|
138
|
-
}] }] });
|
|
139
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ng_control_status.js","sourceRoot":"","sources":["../../../../../../../packages/forms/src/directives/ng_control_status.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAEH,OAAO,EAAC,SAAS,EAAE,QAAQ,EAAE,IAAI,EAAwB,MAAM,eAAe,CAAC;AAG/E,OAAO,EAAC,gBAAgB,EAAC,MAAM,qBAAqB,CAAC;AACrD,OAAO,EAAC,SAAS,EAAC,MAAM,cAAc,CAAC;;;;AAIvC,mBAAmB;AACnB,sEAAsE;AACtE,uEAAuE;AACvE,sBAAsB;AACtB,MAAM,OAAO,qBAAqB;IAGhC,YAAY,EAAmC;QAC7C,IAAI,CAAC,GAAG,GAAG,EAAE,CAAC;IAChB,CAAC;IAED,IAAc,SAAS;QACrB,2BAA2B;QAC3B,IAAI,CAAC,GAAG,EAAE,OAAO,EAAE,QAAQ,EAAE,EAAE,CAAC;QAChC,OAAO,CAAC,CAAC,IAAI,CAAC,GAAG,EAAE,OAAO,EAAE,OAAO,CAAC;IACtC,CAAC;IAED,IAAc,WAAW;QACvB,OAAO,CAAC,CAAC,IAAI,CAAC,GAAG,EAAE,OAAO,EAAE,SAAS,CAAC;IACxC,CAAC;IAED,IAAc,UAAU;QACtB,4BAA4B;QAC5B,IAAI,CAAC,GAAG,EAAE,OAAO,EAAE,SAAS,EAAE,EAAE,CAAC;QACjC,OAAO,CAAC,CAAC,IAAI,CAAC,GAAG,EAAE,OAAO,EAAE,QAAQ,CAAC;IACvC,CAAC;IAED,IAAc,OAAO;QACnB,wCAAwC;QACxC,OAAO,CAAC,CAAC,IAAI,CAAC,GAAG,EAAE,OAAO,EAAE,KAAK,CAAC;IACpC,CAAC;IAED,IAAc,OAAO;QACnB,0BAA0B;QAC1B,IAAI,CAAC,GAAG,EAAE,OAAO,EAAE,OAAO,EAAE,EAAE,CAAC;QAC/B,OAAO,CAAC,CAAC,IAAI,CAAC,GAAG,EAAE,OAAO,EAAE,KAAK,CAAC;IACpC,CAAC;IAED,IAAc,SAAS;QACrB,sCAAsC;QACtC,OAAO,CAAC,CAAC,IAAI,CAAC,GAAG,EAAE,OAAO,EAAE,OAAO,CAAC;IACtC,CAAC;IAED,IAAc,SAAS;QACrB,sCAAsC;QACtC,OAAO,CAAC,CAAC,IAAI,CAAC,GAAG,EAAE,OAAO,EAAE,OAAO,CAAC;IACtC,CAAC;IAED,IAAc,WAAW;QACvB,6BAA6B;QAC5B,IAAI,CAAC,GAAoD,EAAE,UAAU,EAAE,EAAE,CAAC;QAC3E,yFAAyF;QACzF,qFAAqF;QACrF,OAAO,CAAC,CAAE,IAAI,CAAC,GAAoD,EAAE,SAAS,CAAC;IACjF,CAAC;CACF;AAED,MAAM,CAAC,MAAM,mBAAmB,GAAG;IACjC,sBAAsB,EAAE,aAAa;IACrC,oBAAoB,EAAE,WAAW;IACjC,qBAAqB,EAAE,YAAY;IACnC,kBAAkB,EAAE,SAAS;IAC7B,kBAAkB,EAAE,SAAS;IAC7B,oBAAoB,EAAE,WAAW;IACjC,oBAAoB,EAAE,WAAW;CAClC,CAAC;AAEF,MAAM,CAAC,MAAM,iBAAiB,GAAG;IAC/B,GAAG,mBAAmB;IACtB,sBAAsB,EAAE,aAAa;CACtC,CAAC;AAEF;;;;;;;;;;;;;;;;;;;;;;GAsBG;AAEH,MAAM,OAAO,eAAgB,SAAQ,qBAAqB;IACxD,YAAoB,EAAa;QAC/B,KAAK,CAAC,EAAE,CAAC,CAAC;IACZ,CAAC;yHAHU,eAAe;6GAAf,eAAe;;sGAAf,eAAe;kBAD3B,SAAS;mBAAC,EAAC,QAAQ,EAAE,2CAA2C,EAAE,IAAI,EAAE,mBAAmB,EAAC;;0BAE9E,IAAI;;AAKnB;;;;;;;;;;;GAWG;AAMH,MAAM,OAAO,oBAAqB,SAAQ,qBAAqB;IAC7D,YAAgC,EAAoB;QAClD,KAAK,CAAC,EAAE,CAAC,CAAC;IACZ,CAAC;yHAHU,oBAAoB;6GAApB,oBAAoB;;sGAApB,oBAAoB;kBALhC,SAAS;mBAAC;oBACT,QAAQ,EACN,0FAA0F;oBAC5F,IAAI,EAAE,iBAAiB;iBACxB;;0BAEc,QAAQ;;0BAAI,IAAI","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport {Directive, Optional, Self, ɵWritable as Writable} from '@angular/core';\n\nimport {AbstractControlDirective} from './abstract_control_directive';\nimport {ControlContainer} from './control_container';\nimport {NgControl} from './ng_control';\nimport {type NgForm} from './ng_form';\nimport {type FormGroupDirective} from './reactive_directives/form_group_directive';\n\n// DO NOT REFACTOR!\n// Each status is represented by a separate function to make sure that\n// advanced Closure Compiler optimizations related to property renaming\n// can work correctly.\nexport class AbstractControlStatus {\n  private _cd: AbstractControlDirective | null;\n\n  constructor(cd: AbstractControlDirective | null) {\n    this._cd = cd;\n  }\n\n  protected get isTouched() {\n    // track the touched signal\n    this._cd?.control?._touched?.();\n    return !!this._cd?.control?.touched;\n  }\n\n  protected get isUntouched() {\n    return !!this._cd?.control?.untouched;\n  }\n\n  protected get isPristine() {\n    // track the pristine signal\n    this._cd?.control?._pristine?.();\n    return !!this._cd?.control?.pristine;\n  }\n\n  protected get isDirty() {\n    // pristine signal already tracked above\n    return !!this._cd?.control?.dirty;\n  }\n\n  protected get isValid() {\n    // track the status signal\n    this._cd?.control?._status?.();\n    return !!this._cd?.control?.valid;\n  }\n\n  protected get isInvalid() {\n    // status signal already tracked above\n    return !!this._cd?.control?.invalid;\n  }\n\n  protected get isPending() {\n    // status signal already tracked above\n    return !!this._cd?.control?.pending;\n  }\n\n  protected get isSubmitted() {\n    // track the submitted signal\n    (this._cd as Writable<NgForm | FormGroupDirective> | null)?._submitted?.();\n    // We check for the `submitted` field from `NgForm` and `FormGroupDirective` classes, but\n    // we avoid instanceof checks to prevent non-tree-shakable references to those types.\n    return !!(this._cd as Writable<NgForm | FormGroupDirective> | null)?.submitted;\n  }\n}\n\nexport const ngControlStatusHost = {\n  '[class.ng-untouched]': 'isUntouched',\n  '[class.ng-touched]': 'isTouched',\n  '[class.ng-pristine]': 'isPristine',\n  '[class.ng-dirty]': 'isDirty',\n  '[class.ng-valid]': 'isValid',\n  '[class.ng-invalid]': 'isInvalid',\n  '[class.ng-pending]': 'isPending',\n};\n\nexport const ngGroupStatusHost = {\n  ...ngControlStatusHost,\n  '[class.ng-submitted]': 'isSubmitted',\n};\n\n/**\n * @description\n * Directive automatically applied to Angular form controls that sets CSS classes\n * based on control status.\n *\n * @usageNotes\n *\n * ### CSS classes applied\n *\n * The following classes are applied as the properties become true:\n *\n * * ng-valid\n * * ng-invalid\n * * ng-pending\n * * ng-pristine\n * * ng-dirty\n * * ng-untouched\n * * ng-touched\n *\n * @ngModule ReactiveFormsModule\n * @ngModule FormsModule\n * @publicApi\n */\n@Directive({selector: '[formControlName],[ngModel],[formControl]', host: ngControlStatusHost})\nexport class NgControlStatus extends AbstractControlStatus {\n  constructor(@Self() cd: NgControl) {\n    super(cd);\n  }\n}\n\n/**\n * @description\n * Directive automatically applied to Angular form groups that sets CSS classes\n * based on control status (valid/invalid/dirty/etc). On groups, this includes the additional\n * class ng-submitted.\n *\n * @see {@link NgControlStatus}\n *\n * @ngModule ReactiveFormsModule\n * @ngModule FormsModule\n * @publicApi\n */\n@Directive({\n  selector:\n    '[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]',\n  host: ngGroupStatusHost,\n})\nexport class NgControlStatusGroup extends AbstractControlStatus {\n  constructor(@Optional() @Self() cd: ControlContainer) {\n    super(cd);\n  }\n}\n"]}
|