Form
Last updated
Last updated
You will never experience the pain of coding another HTML form again. The Form
component is a self-validating form that accepts an object for inputs. It supports various input types, validation, and can handle file uploads and Stripe payments.
buttonText
submit button tet
optional
string
callback
function executed on successful submit
optional
function
cancel
cancel callback (also shows a cancel button)
optional
function
className
custom styling
optional
SCSS or Tailwind
destructive
set submit button color to red
optional
boolean
method
HTTP request type
optional
string
onChange
callback function executed on input change
optional
function
redirect
url to redirect to after a successful submit
optional
string
submitOnChange
submit the form on each input change
optional
boolean
url
url to post the form to
optional
string
When constructing a form object, each outer key represents an input name and is associated with an object containing various input properties.
The following input types are available.
card (creditcard input)
checkbox
date
file
hidden
number
password
phone
radio
select
switch
text
textarea
url
otp (one-time password)
Props are passed to the input by the form. A full list of props for the inputs can be found below.
aria-describedby
id of the element that describes the input
optional
string
aria-invalid
determines if the input is valid
required
boolean
className
custom style
optional
SCSS or Tailwind style
defaultValue
default value
optional
string
disabled
disable the input
optional
boolean
id
html id for the input
optional
string
name
input name
required
string
onChange
callback function executed on change
required
function
placeholder
placeholder text
optional
string
required
determines if a value is required
optional
boolean
value
current value
optional
string
min
minimum value
optional
integer
minLength
minimum length
optional
integer
max
maximum value
optional
integer
maxLength
maximum length
optional
integer
options
array of options for a radio, checkbox, or select
optional
array
The form will validate the standard input types, as defined in the form/input/map.js file. Here you can extend the validation and add your own custom validation rules.
When your form is submitted, Gravity will optimise the request and only send the name/value pairs. On the server, you can access a submitted value using:
To show an error on a specific form input, throw an error on the server with an inputError
key and the input name.
To create a Stripe payment form, use the <PaymentForm>
component. This is a standard form (as above) wrapped in a Stripe provider.
The Form
component uses the useForm
and Controller
from react-hook-form
for form management and validation.
The inputs
prop defines the form inputs and their configurations.
The buttonText
prop specifies the text for the submit button.
The callback
prop is a function executed on successful form submission.
The destructive
prop sets the submit button color to red.
The submitOnChange
prop submits the form on each change.
The url
and method
props define the endpoint and HTTP method for form submission.
The Form
component also includes support for Stripe payments through the PaymentForm
component.
For more details, refer to the Shadcn Form documentation.