Reactive Form Builder for Angular
Generate form controls, form array and form group.

Demo
stackblitz
✔️ Version 2.7.0
- Customizing form array title by setting titleClass property
- Ability to define as many form group with as many fields you want for each
- Setting full with buttons for mobile and another device size by setting fullWidthButtons property
✔️ Version 2.6.0
- Sizing for control and label by values: small,medium and large.Default is medium
- Red color added to color of buttons
- Simple validation error style has added that shows red text without background color.You can reached it by setting simpleValidationError:true
Some Features
- Ability to define form fields by type
- Ability to define as many form arrays with as many fields you want for each
- Ability to define as many form group with as many fields you want for each
- Has a config for Add button of form array
- Ability to define the as many validation rules and error message of the field and the form array fields as desired
- Has a config for form array divider
- Ability to define Send, Reset and Cancel buttons with the desired title, color, and order
- Binding form by object in edit mode
-
Bootstrap style
Field types
Text
Range
Number
Password
Color
Dropdown
Radio
Checkbox
File
Date
Datetime local
Time
Week
Month
Form array
Form group
Table of contents
Install
npm i sh-dynamic-form-builder
Install dependencies
Use bootstrap V5
npm install bootstrap --save
npm install bootstrap-icons --save
npm install sh-ordinal-numbers --save
Quick start
import { DynamicFormBuilderModule } from "sh-dynamic-form-builder";
@NgModule({
imports: [DynamicFormBuilderModule],
})
export class AppModule {}
Import style and icon
In angular.json
"styles": [
"src/styles.scss",
"./node_modules/bootstrap/dist/css/bootstrap.min.css"
"./node_modules/bootstrap-icons/font/bootstrap-icons.scss"
]
If Bootstrap icons don't work, you should import them in global style.
@import "~bootstrap-icons/font/bootstrap-icons";
How to use?
In component
formGroup = new FormGroup({});
isSubmit: boolean = false;
config: IFormConfig = {
title: 'Profile',
fields: [
{
type: 'text', name: 'fullName', label: 'Full name', id: 'fullName',
validators: [
{ rule: 'required', msg: 'Full name is required' },
{ rule: 'minlength', value: 6, msg: 'Full name must be at least 6 characters long' },
],
},
{
type: 'form-array',
label: 'Tasks',
name: 'tasks',
formArray: {
simpleAddButton: true,
addButtonBGColor: 'green',
fields: [
{
type: 'text', name: 'title', label: 'title', validators: [
{ rule: 'required', msg: 'title is required!' },
{ rule: 'maxlength', value: 50, msg: 'Maximum length should be 50 characters' }
]
},
{
type: 'date', name: 'dueDate', label: 'due date', validators: [
{ rule: 'required', msg: 'date is required!' }
]
}
]
}
},
{
type: 'text', name: 'email1', label: 'E-mail',
validators: [
{ rule: 'email', msg: 'E-mail is wrong' }
],
},
{
type: 'file', name: 'avatar', label: 'Avatar',
onUpload: this.onUpload.bind(this), multipleFile: true
}
...
buttonSetting: {
fullWidthButtons: 'only-mobile',
buttons:
[
{ type: 'submit', caption: 'Submit', bgColor: 'blue' },
{ type: 'reset', caption: 'Reset', bgColor: 'orange' },
{ type: 'cancel', caption: 'Cancel', bgColor: 'light' }
]
}
}
private onUpload(event: any): void {
const files = event.files;
...
}
public submit(event: FormGroup): void {
this.isSubmit = true;
this.formGroup = event;
/**Sending data ... */
this.isSubmit = false;
}
public cancel(): void {
/** */
}
In template
<div class="container">
<sh-dynamic-form-builder
[config]="config"
[isSubmit]="isSubmit"
(submit)="submit($event)"
>
</sh-dynamic-form-builder>
</div>
Input
Name |
Type |
Default |
Required? |
Description |
config |
IFormConfig |
- |
yes |
Form config |
formValue |
object |
{} |
- |
Adjust form values |
isSubmit |
boolean |
false |
no |
Set in to your Submit Function. If it sets "true", Submit button will be disabled.When submit is clicked it must be set "true" value, when sending data will be ended it must be set "false" value |
Name |
Type |
Default |
Required? |
Description |
fields |
IMainFieldItem |
- |
yes |
Form fields |
title |
string |
- |
no |
Form title |
titleClass |
string |
- |
no |
Set style for form title, you can add one or more class name split by space. for example:'class1 class2 class3' |
buttonSetting |
IButtonSetting |
{} |
yes |
Button setting |
formControlConfig |
IFormControlConfig |
{} |
yes |
Form controls configuration |
Name |
Type |
Default |
Required? |
Description |
elementSize |
string |
medium |
no |
Control size and label size |
simpleValidationError |
boolean |
false |
no |
Red text without background color as the validation error message |
Output
Name |
Type |
Description |
(submit) |
FormGroup |
Output formGroup, when Submit button clicked |
(cancel) |
boolean |
When the Cancel button has been clicked |
Field properties and methods
Name |
Type |
Default |
Required? |
Description |
type |
string |
- |
yes |
Allowed values: text , range , number , password , color , dropdown , radio , checkbox , file , date , datetime-local , time , week , month , form-group and form-array
|
name |
string |
- |
yes |
Form control name |
defaultValue |
any |
- |
no |
Form control default value |
placeholder |
string |
- |
no |
Usable for text, number, password, dropdown and email |
[validators] |
IValidationRules |
- |
no |
Set validator rules and error messages |
id |
string |
- |
no |
Element id |
width |
number |
100% |
no |
Width of Control |
disable |
boolean |
false |
no |
Disable control |
-
File
Name |
Type |
Default |
Required? |
Description |
onUpload |
void |
- |
yes |
File selection event. |
multipleFile |
boolean |
false |
no |
Allow choice multiple file |
-
Text
Name |
Type |
Default |
Required? |
Description |
multiline |
boolean |
false |
no |
Multiline handling |
rowCount |
number |
5 |
no |
Specifies the visible height of a text area, in lines |
-
Radio
Name |
Type |
Default |
Required? |
Description |
[options] |
IOption |
- |
yes |
Define options: {key: string;label: string;} |
inline |
boolean |
false |
no |
Show on the same horizontal row |
-
dropdown
Name |
Type |
Default |
Required? |
Description |
[options] |
IOption |
- |
yes |
Define options: {key: string;label: string;} |
-
Range
Name |
Type |
Default |
Required? |
Description |
rangeMin |
number |
0 |
no |
value of the min |
rangeMax |
number |
100 |
no |
value of the max |
rangeStep |
number |
1 |
no |
value of the step |
Name |
Type |
Default |
Required? |
Description |
formGroup |
IFormGroup |
- |
no |
Set form group fields and validations |
Name |
Type |
Default |
Required? |
Description |
[fields] |
IFormGroupFieldItem |
- |
yes |
Form group fields |
titleClass |
string |
- |
no |
Set style for form group title, you can add one or more class name split by space. for example:'class1 class2 class3' |
showInCard |
boolean |
false |
no |
Show in bootstrap card |
-
Form-array
Name |
Type |
Default |
Required? |
Description |
formArray |
IFormArray |
- |
no |
Set form array fields and validations |
-
FormArray
Name |
Type |
Default |
Required? |
Description |
[fields] |
IFormArrayFieldItem |
- |
yes |
Form array fields |
simpleAddButton |
boolean |
false |
no |
Only icon on button, without text |
addButtonBGColor |
string |
gray |
no |
Allowed values: gray , green , blue , red , orange , light and dark
|
divider |
IDivider |
- |
no |
doesn't show an ordinal number in the center of the divider line |
-
Divider
Name |
Type |
Default |
Required? |
Description |
suppress |
boolean |
false |
no |
Doesn't show divider |
lineClass |
string |
- |
no |
Set style for divider line, you can add one or more class name split by space. for example:'class1 class2 class3' |
ordinalNumberClass |
string |
- |
no |
Set style for ordinal number between divider line, you can add one or more class name split by space. for example:'class1 class2 class3' |
suppressOrdinalNumber |
boolean |
false |
no |
Doesn't show an ordinal number in the center of the divider line |
height |
number |
3 |
no |
The height of divider |
Button setting
Name |
Type |
Default |
Required? |
Description |
[buttons] |
IButton |
[] |
yes |
The array of buttons, order by definition |
buttonsAlign |
string |
left |
no |
Usable when fullWidthButtons is false |
fullWidthButtons |
string |
none |
no |
Allowed values: none , all , only-mobile
|
Name |
Type |
Required? |
Description |
type |
string |
yes |
Allowed values: submit , cancel and reset
|
caption |
string |
yes |
Button caption |
bgColor |
string |
yes |
Allowed values: gray , green , blue , red , orange , light and dark
|
Validators
name |
type |
Required |
Description |
rule |
string |
yes |
Define rules |
msg |
string |
yes |
Error message |
value |
any |
no |
Usable for min, max,pattern,minlength and maxlength rules |
Name |
Type |
Description |
min |
number |
Validator that requires the control's value to be greater than or equal to the provided number. |
max |
number |
Validator that requires the control's value to be less than or equal to the provided number. |
email |
boolean |
Validator that requires the control's value pass an email validation test. |
pattern |
string |
Validator that requires the control's value to match a regex pattern. |
required |
boolean |
Validator that requires the control have a non-empty value. |
requiredTrue |
boolean |
Validator that requires the control's value be true. This validator is commonly used for required checkboxes. |
minLength |
number |
Validator that requires the length of the control's value to be greater than or equal to the provided minimum length |
maxLength |
number |
Validator that requires the length of the control's value to be less than or equal to the provided maximum length. |
Creator
Hakime sheikhalishahi
Donate
If you like my work and I save your time you can buy me a 🍺 or 🍕
My Trust Wallet address | Ethereum :
0x04e125a00BCd45A4DD23279DcAfF1eAFd49DbEf6
License
MIT