Formatic
Automatic forms.
Warning!
Formatic is currently early alpha and still in heavy development. Everything is
subject to change! You should probably just look away till this warning goes
away!
Start hacking
git clone git@github.com:zapier/formatic.git
cd formatic
npm install
gulp live
Point your browser to localhost:3000/index.html
. Hack away on the code, the
styles or the HTML in the demo directory, and the browser will automatically
reload with your changes.
Note: Don't mess with the files in the live
directory. All those are copied
from elsewhere.
Build
git clone git@github.com:zapier/formatic.git
cd formatic
npm install
gulp build
This will build two files in the build directory: formatic-min.js (minified)
and formatic-dev.js (not minified and includes source maps for development).
What is formatic?
Formatic is a configurable, pluggable forms library for React. Pass in JSON
fields that define your form, along with a value to be edited, and Formatic
gives you a form to edit your value.
Using formatic
If you're happy with the default configuration, you can use it like this:
var Formatic = require('formatic');
var Form = React.createFactory(Formatic);
var fields = [
{
type: 'string',
isSingleLine: true,
key: 'firstName',
label: 'First Name'
},
{
type: 'str',
isSingleLine: true,
key: 'lastName',
label: 'Last Name'
}
];
React.render(Form({
fields: fields,
onChange: function (newValue) {
console.log(newValue);
}
}), document.body);
This creates a simple form like this (assuming you're using formatic.css):
The above assumes you're using a CommonJS build tool like browserify or webpack.
If you use the standalone build, you can just the global `Formatic'.
Documentation
The documentation is a work in progress,
but there's already a lot of useful info there.