React Form Builder is a versatile and customizable form-building library powered by react-hook-form. It allows developers to effortlessly generate dynamic and feature-rich forms based on a JSON configuration.
Install the package via npm or yarn:
npm install @team-good-io/react-form-builder
yarn add @team-good-io/react-form-builder
import { FormProvider, useForm, useFormContext } from 'react-hook-form'
import { OptionsProvider, useFieldOptions } from "@team-good-io/react-form-builder"
const Field = ({ name }: { name: string }) => {
const { register } = useFormContext()
const options = useFieldOptions(name)
return (
<select {...register(name)}>
<option />
{options.data?.map(({ label, value }) => (<option value={value}>{label}</option>))}
</select>
)
}
export const Form = () => {
const instance = useForm()
const fields = ['COUNTRY', 'STATE']
const optionsConfig = {
'COUNTRY': [{ label: "Japan", value: "JP"}],
'STATE': {
deps: ['COUNTRY'],
path: '/api/to/states.json?country={COUNTRY}',
labelKey: 'label',
valueKey: 'value'
}
}
return (
<FormProvider {...instance}>
<OptionsProvider config={optionsConfig} useFormContext={useFormContext}>
{fields.map((field) => (<Field key={field} name={field}/>))}
</OptionsProvider>
</FormProvider>
)
}
import { FormProvider, useForm, useFormContext } from 'react-hook-form'
import { EffectsProvider, useFieldEffects } from "@team-good-io/react-form-builder"
const Field = ({ name }: { name: string }) => {
const { register } = useFormContext()
const { htmlAttrs, registerOptions } = useFieldEffects(name)
return <input {...htmlAttrs} {...register(name, registerOptions)} />
}
export const Form = () => {
const instance = useForm()
const fields = ['COUNTRY', 'STATE']
const effectssConfig = {
COUNTRY: {
NO_VALUE: {
STATE: {
htmlAttrs: {
disabled: true
},
resetField: true
}
},
HAS_VALUE: {
STATE: {
setValue: 'effect',
htmlAttrs: {
disabled: false
}
}
},
UK: {
STATE: {
setValue: 'STATE'
}
}
}
}
return (
<FormProvider {...instance}>
<EffectsProvider config={effectssConfig} useFormContext={useFormContext}>
{fields.map((field) => (<Field key={field} name={field}/>))}
</EffectsProvider>
</FormProvider>
)
}
- React Hook Form for providing the form library.
Feel free to suggest improvements or report bugs via issues.
This package is licensed under the MIT License.