feat(forms): export NumberValueAccessor & RangeValueAccessor directives (#27743)
@angular/forms declares several directives and a module which are not exported from the package via the entrypoint, either intentionally or as a historical accident. Ivy's locality principle necessitates that directives used in user code be importable from the package which defines them. This requires these forms directives to be exported. Several directives which define ControlValueAccessors are exported: * NumberValueAccessor * RangeValueAccessor A few more directives and a module are exported privately (with a ɵ prefix): * NgNoValidate * NgSelectMultipleOption * InternalFormsSharedModule PR Close #27743
This commit is contained in:
parent
f4a9f5dae8
commit
ac157170c8
|
@ -38,6 +38,7 @@ export const NUMBER_VALUE_ACCESSOR: any = {
|
||||||
*
|
*
|
||||||
* @ngModule ReactiveFormsModule
|
* @ngModule ReactiveFormsModule
|
||||||
* @ngModule FormsModule
|
* @ngModule FormsModule
|
||||||
|
* @publicApi
|
||||||
*/
|
*/
|
||||||
@Directive({
|
@Directive({
|
||||||
selector:
|
selector:
|
||||||
|
|
|
@ -38,6 +38,7 @@ export const RANGE_VALUE_ACCESSOR: StaticProvider = {
|
||||||
*
|
*
|
||||||
* @ngModule ReactiveFormsModule
|
* @ngModule ReactiveFormsModule
|
||||||
* @ngModule FormsModule
|
* @ngModule FormsModule
|
||||||
|
* @publicApi
|
||||||
*/
|
*/
|
||||||
@Directive({
|
@Directive({
|
||||||
selector:
|
selector:
|
||||||
|
|
|
@ -18,6 +18,7 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
export {InternalFormsSharedModule as ɵInternalFormsSharedModule} from './directives';
|
||||||
export {AbstractControlDirective} from './directives/abstract_control_directive';
|
export {AbstractControlDirective} from './directives/abstract_control_directive';
|
||||||
export {AbstractFormGroupDirective} from './directives/abstract_form_group_directive';
|
export {AbstractFormGroupDirective} from './directives/abstract_form_group_directive';
|
||||||
export {CheckboxControlValueAccessor} from './directives/checkbox_value_accessor';
|
export {CheckboxControlValueAccessor} from './directives/checkbox_value_accessor';
|
||||||
|
@ -31,7 +32,10 @@ export {NgForm} from './directives/ng_form';
|
||||||
export {NgFormSelectorWarning} from './directives/ng_form_selector_warning';
|
export {NgFormSelectorWarning} from './directives/ng_form_selector_warning';
|
||||||
export {NgModel} from './directives/ng_model';
|
export {NgModel} from './directives/ng_model';
|
||||||
export {NgModelGroup} from './directives/ng_model_group';
|
export {NgModelGroup} from './directives/ng_model_group';
|
||||||
|
export {NgNoValidate as ɵNgNoValidate} from './directives/ng_no_validate_directive';
|
||||||
|
export {NumberValueAccessor} from './directives/number_value_accessor';
|
||||||
export {RadioControlValueAccessor} from './directives/radio_control_value_accessor';
|
export {RadioControlValueAccessor} from './directives/radio_control_value_accessor';
|
||||||
|
export {RangeValueAccessor} from './directives/range_value_accessor';
|
||||||
export {FormControlDirective} from './directives/reactive_directives/form_control_directive';
|
export {FormControlDirective} from './directives/reactive_directives/form_control_directive';
|
||||||
export {FormControlName} from './directives/reactive_directives/form_control_name';
|
export {FormControlName} from './directives/reactive_directives/form_control_name';
|
||||||
export {FormGroupDirective} from './directives/reactive_directives/form_group_directive';
|
export {FormGroupDirective} from './directives/reactive_directives/form_group_directive';
|
||||||
|
@ -39,6 +43,7 @@ export {FormArrayName} from './directives/reactive_directives/form_group_name';
|
||||||
export {FormGroupName} from './directives/reactive_directives/form_group_name';
|
export {FormGroupName} from './directives/reactive_directives/form_group_name';
|
||||||
export {NgSelectOption, SelectControlValueAccessor} from './directives/select_control_value_accessor';
|
export {NgSelectOption, SelectControlValueAccessor} from './directives/select_control_value_accessor';
|
||||||
export {SelectMultipleControlValueAccessor} from './directives/select_multiple_control_value_accessor';
|
export {SelectMultipleControlValueAccessor} from './directives/select_multiple_control_value_accessor';
|
||||||
|
export {NgSelectMultipleOption as ɵNgSelectMultipleOption} from './directives/select_multiple_control_value_accessor';
|
||||||
export {AsyncValidator, AsyncValidatorFn, CheckboxRequiredValidator, EmailValidator, MaxLengthValidator, MinLengthValidator, PatternValidator, RequiredValidator, ValidationErrors, Validator, ValidatorFn} from './directives/validators';
|
export {AsyncValidator, AsyncValidatorFn, CheckboxRequiredValidator, EmailValidator, MaxLengthValidator, MinLengthValidator, PatternValidator, RequiredValidator, ValidationErrors, Validator, ValidatorFn} from './directives/validators';
|
||||||
export {FormBuilder} from './form_builder';
|
export {FormBuilder} from './form_builder';
|
||||||
export {AbstractControl, AbstractControlOptions, FormArray, FormControl, FormGroup} from './model';
|
export {AbstractControl, AbstractControlOptions, FormArray, FormControl, FormGroup} from './model';
|
||||||
|
|
|
@ -435,6 +435,16 @@ export declare class NgSelectOption implements OnDestroy {
|
||||||
ngOnDestroy(): void;
|
ngOnDestroy(): void;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
export declare class NumberValueAccessor implements ControlValueAccessor {
|
||||||
|
onChange: (_: any) => void;
|
||||||
|
onTouched: () => void;
|
||||||
|
constructor(_renderer: Renderer2, _elementRef: ElementRef);
|
||||||
|
registerOnChange(fn: (_: number | null) => void): void;
|
||||||
|
registerOnTouched(fn: () => void): void;
|
||||||
|
setDisabledState(isDisabled: boolean): void;
|
||||||
|
writeValue(value: number): void;
|
||||||
|
}
|
||||||
|
|
||||||
export declare class PatternValidator implements Validator, OnChanges {
|
export declare class PatternValidator implements Validator, OnChanges {
|
||||||
pattern: string | RegExp;
|
pattern: string | RegExp;
|
||||||
ngOnChanges(changes: SimpleChanges): void;
|
ngOnChanges(changes: SimpleChanges): void;
|
||||||
|
@ -458,6 +468,16 @@ export declare class RadioControlValueAccessor implements ControlValueAccessor,
|
||||||
writeValue(value: any): void;
|
writeValue(value: any): void;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
export declare class RangeValueAccessor implements ControlValueAccessor {
|
||||||
|
onChange: (_: any) => void;
|
||||||
|
onTouched: () => void;
|
||||||
|
constructor(_renderer: Renderer2, _elementRef: ElementRef);
|
||||||
|
registerOnChange(fn: (_: number | null) => void): void;
|
||||||
|
registerOnTouched(fn: () => void): void;
|
||||||
|
setDisabledState(isDisabled: boolean): void;
|
||||||
|
writeValue(value: any): void;
|
||||||
|
}
|
||||||
|
|
||||||
export declare class ReactiveFormsModule {
|
export declare class ReactiveFormsModule {
|
||||||
static withConfig(opts: { warnOnNgModelWithFormControl: 'never' | 'once' | 'always';
|
static withConfig(opts: { warnOnNgModelWithFormControl: 'never' | 'once' | 'always';
|
||||||
}): ModuleWithProviders<ReactiveFormsModule>;
|
}): ModuleWithProviders<ReactiveFormsModule>;
|
||||||
|
|
Loading…
Reference in New Issue