This package includes helper types for when you are dealing with Angular's typed reactive forms system. These types allow for translating raw typescript interfaces/types into the Reactive Forms Types and back into raw typescript interfaces/types for the value.
npm install --save-dev @oasisdigital/angular-typed-forms-helpers
yarn add --dev @oasisdigital/angular-typed-forms-helpers
Then you can simply import the helper interfaces from angular-typed-forms-helpers
.
- 3.3.x - Angular 18.x.x
- 3.2.x - Angular 17.x.x
- 3.1.x - Angular 16.x.x
- 2.2.x - Angular 15.x.x
- 2.1.x - Angular 14.x.x
For the below sections describing the different interfaces/types, if you want a
NonNullable
version of any of them simply prefix the type/interface withNonNullable
. This does not include the value & rawValue types as they work regardless of Nullability.For example, with
AngularForm
you would doNonNullableAngularForm
.
This interface allows for deeply translating an object or general TS type/interface into one of the 3 main Angular Reactive Forms types (FormControl, FormGroup, FormArray).
import { FormArray, FormControl, FormGroup } from '@angular/forms';
import { AngularForm } from '@oasisdigital/angular-typed-forms-helpers';
export interface Animal {
name: string;
species: string;
lifeStage: string;
birthDate: Date;
alive: boolean;
}
export interface Zone {
name: string;
maxCapacity: number;
animals: Animal[];
}
type AnimalForm = AngularForm<Animal>;
type ZoneForm = AngularForm<Zone>;
const animalForm: AnimalForm = new FormGroup({
name: new FormControl(''),
species: new FormControl(''),
lifeStage: new FormControl(''),
birthDate: new FormControl(new Date('01 Jan 1994')),
alive: new FormControl(true),
});
const zoneForm: ZoneForm = new FormGroup({
name: new FormControl(''),
maxCapacity: new FormControl(10),
animals: new FormArray<AnimalForm>([]),
});
It is important to note this interface only covers basic cases of form structures, it makes the
assumption that all objects are FormGroups and arrays are FormArrays. If you would like to convert
on a per property basis consider using the AngularFormGroup
or AngularFormArray
from the below
sections.
The
NonNullable
version of this type isNonNullableAngularForm
.
This interface will do a shallow conversion of an object over to the Angular Typed Forms system. Where every property of the object becomes a FormControl.
type ZoneForm = AngularFormGroupShallow<Zone>;
const zoneForm: ZoneForm = new FormGroup({
name: new FormControl(''),
maxCapacity: new FormControl(10),
animals: new FormControl<Animal[]>([]),
});
The
NonNullable
version of this type isNonNullableAngularFormGroupShallow
.
This is a subset of the AngularForm
interface that deeply converts an object over to the Angular
Typed Forms system. If you give an array type to this interface the return will be never
. This is
due to a limitation of diffing arrays and objects in the generic extension type.
type ZoneForm = AngularFormGroup<Zone>;
const zoneForm: ZoneForm = new FormGroup({
name: new FormControl(''),
maxCapacity: new FormControl(10),
animals: new FormArray<AnimalForm[]>([]),
});
The
NonNullable
version of this type isNonNullableAngularFormGroup
.
This interface will do a shallow conversion of an array over to the Angular Typed Forms system. Where the Array subtype becomes a matching FormControl subtype for the FormArray.
type ZonesForm = AngularFormArrayShallow<Zone[]>;
const zonesForm: ZonesForm = new FormArray([
{
name: new FormControl(''),
maxCapacity: new FormControl(10),
animals: new FormControl<Animal[]>([]),
},
{
name: new FormControl(''),
maxCapacity: new FormControl(10),
animals: new FormControl<Animal[]>([]),
},
]);
The
NonNullable
version of this type isNonNullableAngularFormArrayShallow
.
This is a subset of the AngularForm
interface that deeply converts an array over to the Angular
Typed Forms system.
type ZonesForm = AngularFormArray<Zone[]>;
const zonesForm: ZonesForm = new FormArray([
{
name: new FormControl(''),
maxCapacity: new FormControl(10),
animals: new FormArray<AnimalForm>([]),
},
{
name: new FormControl(''),
maxCapacity: new FormControl(10),
animals: new FormArray<AnimalForm>([]),
},
]);
The
NonNullable
version of this type isNonNullableAngularFormArray
.
This interface is used to translate the .value
property type from a Angular Reactive Forms object.
This interface automatically accounts for the Partial<>
nature of FormGroups since sub-controls
can be disabled. If you would like the whole form value regardless of disabled controls see
AngularFormRawValue
below.
type AnimalForm = AngularForm<Animal>;
const animalForm: AnimalForm = new FormGroup({
name: new FormControl(''),
species: new FormControl(''),
lifeStage: new FormControl({ value: '', disabled: true }),
birthDate: new FormControl(new Date('01 Jan 1994')),
alive: new FormControl(true),
});
const animalValue: AngularFormValue<AnimalForm> = animalForm.value;
/*
{
name?: string | null;
species?: string | null;
lifeStage?: string | null;
birthDate?: Date | null;
}
*/
This interface also works for custom implementations of the AbstractControl
class.
This interface is used to translate the .getRawValue()
method return type from a Angular Reactive
Forms object. This will include all sub-controls regardless of their disabled state.
type AnimalForm = AngularForm<Animal>;
const animalForm: AnimalForm = new FormGroup({
name: new FormControl(''),
species: new FormControl(''),
lifeStage: new FormControl({ value: '', disabled: true }),
birthDate: new FormControl(new Date('01 Jan 1994')),
alive: new FormControl(true),
});
const animalValue: AngularFormRawValue<AnimalForm> = animalForm.getRawValue();
/*
{
name: string | null;
species: string | null;
lifeStage: string | null;
birthDate: Date | null;
}
*/
This interface also works for custom implementations of the AbstractControl
class.