react-component-form
Manage React Forms with ease.
⚠️ This project is not maintained anymore, you can still use the code as you wish and fork it to maintain it yourself.
📜 About
react-component-form is a lightweight form component for React.js, it allows you to get the inputs values without state thanks to onChange
or onSubmit
props.
There is also a React Hooks to be used in combination with the <Form />
component to validate the data with Ajv JSON schema validator, see advanced usage.
Example demo: https://react-component-form.vercel.app/.
💾 Install
npm install --save react-component-form
⚙️ Usage
Note: The examples use TypeScript, but obviously you can use JavaScript. Be aware that HandleForm
is the type definition for the onChange
and onSubmit
props.
import React from "react"
import { Form } from "react-component-form"
import type { HandleForm } from "react-component-form"
export const Example = () => {
const handleSubmit: HandleForm = (formData, formElement) => {
console.log(formData)
formElement.reset()
}
return (
<Form onSubmit={handleSubmit}>
<input type="text" name="inputName" />
<button type="submit">Submit</button>
</Form>
)
}
Basically you have access to the same props of the HTML form
tag in React, but the onSubmit
and the onChange
props are differents.
Instead to get the event
param you get formData
and formElement
parameters:
formData
: Object where the keys are the name of your inputs and the current value. Behind the scene, it uses the FormData constructor.formElement
: The HTML form element in the DOM so for example you can access the .reset()
method on a HTMLFormElement.
⚙️ Advanced Usage
This example shows how to use the <Form />
component with useForm
hook to validate the data with Ajv JSON schema validator.
You can see a more detailled example in the ./example folder.
import React from "react"
import { Form, useForm } from "react-component-form"
import type { HandleUseFormCallback } from "react-component-form"
const schema = {
inputName: {
type: "string",
minLength: 3,
maxLength: 20,
},
}
export const Example = () => {
const { handleUseForm, errors, message } = useForm(schema)
const onSubmit: HandleUseFormCallback<typeof schema> = (
formData,
formElement,
) => {
console.log(formData)
formElement.reset()
return {
type: "success",
message: "Success: Form submitted",
}
}
return (
<Form onSubmit={handleUseForm(onSubmit)}>
<input type="text" name="inputName" />
{errors.inputName != null && <p>{errors.inputName[0].message}</p>}
<button type="submit">Submit</button>
{message != null && <p>{message}</p>}
</Form>
)
}
API
useForm(schema)
Parameters
Returns
handleUseForm(onSubmit)
: Function to be used with the onSubmit
or onChange
prop of the <Form />
component.fetchState = 'idle'
: The current state of the form ('error' | 'success' | 'idle' | 'loading'
).setFetchState
: Function to update the fetchState
.message
: Global message of the form (not specific to a property).setMessage
: Function to update the message
.errors
: Object of errors:
- Key: correspond to a property in the JSON Schema.
- Value: array of ajv
ErrorObject
.
The array will always have at least one element (never empty) in case of errors.
If the value is undefined
, it means there are no errors for this property.
💡 Contributing
Anyone can help to improve the project, submit a Feature Request, a bug report or
even correct a simple spelling mistake.
The steps to contribute can be found in CONTRIBUTING.md.
📄 License
MIT