react-form-designer
v1.3.91
Published
UI for creating forms via dragging dropping required options
Downloads
58
Readme
react-form-designer
UI for creating forms via dragging dropping required options
Install
npm install --save react-form-designer
Usage
import React, { Component } from 'react'
import FormDesigner from 'react-form-designer'
const App = () => {
const [fields, setFields] = useState([])
return (
<FormDesigner
fields={fields}
onChange={(newFields) => setFields(newFields)}
onFieldStartedEdit={(fieldStartedEdit) => console.log(fieldStartedEdit)}
onFieldEdit={(fieldOnEdit) => console.log({ fieldOnEdit })}
onFieldDelete={(deletedField) => console.log({ deletedField })}
containerHeight={900}
expectedOptions={[
'SINGLECHECKBOX',
'MULTIPLECHECKBOXES',
'DATEPICKER',
'DROPDOWNSELECT',
'SINGLELINETEXT',
'MULTIPLECHECKBOXES',
'MULTILINETEXT',
'FILE',
'RADIOSELECT',
'CONTACT',
'NUMBER'
]}
customOptions={[
{
type: 'SINGLECHECKBOX',
title: 'Single Check Box',
options: true,
renderIn: (field,fieldIndex) => {
return <div>this is custom JSX{fieldIndex}</div>
}
},
{
type: 'MULTIPLECHECKBOXES',
title: 'Multiple Checkboxes',
options: true,
renderIn: (field,fieldIndex) => {
return <div>this is custom JSX{fieldIndex}</div>
}
},
{
type: 'DATEPICKER',
title: 'Date Picker',
options: true,
renderIn: (field,fieldIndex) => {
return <div>this is custom JSX{fieldIndex}</div>
}
},
{
type: 'DROPDOWNSELECT',
title: 'Dropdown Select',
options: true,
renderIn: (field,fieldIndex) => {
return <div>this is custom JSX{fieldIndex}</div>
}
},
{
type: 'SINGLELINETEXT',
title: 'Single Line Text',
options: true,
renderIn: (field,fieldIndex) => {
return <div>this is custom JSX{fieldIndex}</div>
}
},
{
type: 'MULTIPLECHECKBOXES',
title: 'Multiple checkboxes',
options: true,
renderIn: (field,fieldIndex) => {
return <div>this is custom JSX{fieldIndex}</div>
}
},
{
type: 'MULTILINETEXT',
title: 'Multiline text',
options: true,
renderIn: (field,fieldIndex) => {
return <div>this is custom JSX{fieldIndex}</div>
}
},
{
type: 'FILE',
title: 'File',
options: true,
renderIn: (field,fieldIndex) => {
return <div>this is custom JSX{fieldIndex}</div>
}
},
{
type: 'RADIOSELECT',
title: 'Radio Select',
options: true,
renderIn: (field,fieldIndex) => {
return <div>this is custom JSX{fieldIndex}</div>
}
},
{
type: 'CONTACT',
title: 'Contact',
options: true,
renderIn: (field,fieldIndex) => {
return <div>this is custom JSX{fieldIndex}</div>
}
},
{
type: 'NUMBER',
title: 'Number',
options: true,
renderIn: (field,fieldIndex) => {
return <div>this is custom JSX{fieldIndex}</div>
}
}
]}
/>
)
}
Optional Parameters
- expectedOptions
- styles
- renderInToolBox
- onFieldEdit
- onFieldDelete
- onFieldStartedEdit
- customOptions
- containerHeight
License
MIT © AmirjanyanIT