An HTML-free component for React form creation that employs a JSON structure to support a variety of form fields with a simple user interface. Simply import LlamaForm from llama-form to get a great form that is driven by JSON schema.
Content
npm i llama-forms-react
- Simple to use
- Form based on a schema
- Validation regex support
- Form answer in JSON format
- Submit button with loader that may be customized
- Form submission callback function support
- Custom errorMessage support
- Support for sensitivity validation
- Custom style support
- multi-step form with:
- Progress bar
- Current step count with respective to total step
- User defined initial step (Default is 1)
- Callback function on each step submission
Create a Login Form using Llama Form
import LlamaForm from "llama-forms-react";
export default function Example() {
const handleLogin = (data) => {
console.log("Login data", data);
};
return (
<LlamaForm
schema={{
title: "Login Form Example",
description:
"This is an example of a login form using llama-forms-react.",
wizard: false, // optional (true for multi-step forms)
properties: {
email: {
type: "string",
required: true,
},
password: {
type: "string",
required: true,
},
},
}}
options={{
fields: {
email: {
type: "email",
label: "User Email",
placeholder: "Your email address",
description: "Email field description",
validationRegex: "", // validation regex for the input field
errorMessage: "Email field validation error",
readOnly: false, // (defaults to false)
maxLength: 30,
autoFocus: true,
autoComplete: true,
},
password: {
type: "password",
label: "User Passsword",
placeholder: "Your password Please",
description: "Password field description",
validationRegex: "",
errorMessage: "Password field validation error",
readOnly: false,
autoFocus: false,
autoComplete: true,
},
},
}}
onSubmit={handleLogin}
/>
);
}
schema: The form's foundation, where you may provide a json schema for the form's creation.
options: Field properties for the provided schema.
data: Form field default values
onSubmit: A callback that accepts a function and returns the form data.
- title: Title of the form.
- description: Descripton of the form.
- wizard: Option to enable multi-step form, default is
false
. - properties: Dynamic custom field which you want to render in form.
- required: Specific field is requirement, default value is false.
- enum: For option values, this property is applicable for dropdown fields, checkbox fields, radio fields, etc.
- step: Specify the field position on multistep form. For instance, if the step value is 2 then that field will occur on the second step of the form, deafult value is 1.
Here we pass all schema fields properties. Which basically contains an object for each field that we describe in the schema.
- fields:
- type: Type of input field, as for email we use "type - email".
Input Field type support by llama-forms-react.
- text - text field
- textarea - text area field
- email - email field
- password - password field
- radio - radio button is used to select one option in multiple options.
- checkbox - This is used to select multiple options.
- dropdown - This is used for dropdown value. Here we pass multiple values.
- color - This is used as color picker
- file - This is used for uploading files.
- number - number filed.
- range - This is used to set a range between two values.
- tel - This is used for telephone number input.
- time - time field
- date - date field
- datetime-local - This is used for both date and time at a time.
- week- week field
- month - month field
- uri - This is used for input URI.
- label:
- placeholder:
- description: Description of input field.
- validationRegex: Custome regex to input field validation.
- errorMessage:
- readOnly:
- maxLength:
- autoFocus:
- autoComplete:
- maxFileSize:
- minFileSize:
- min: Minimum value of the input field.
- max: TMaximum value of the input field.
- interval: Applicaple with range input field type, we can specify interval between two values.
- accept: Applicaple with file input field type, we can specify the acceptable file extension. ex - ["jpg", "png", "jpeg"]
- type: Type of input field, as for email we use "type - email".
Input Field type support by llama-forms-react.
👤 NetTantra Technologies React Developers (https://github.com/orgs/nettantra/teams/llama-forms-core)
- Website: www.nettantra.com
- Github: @nettantra
Contributions, issues and feature requests are welcome!
Feel free to check issues page.
Give a ⭐️ if this project helped you!
Copyright © 2022 NetTantra Technologies.
This project is MIT licensed.