react-data-form v1.0.0
react-input-schema
This is one of many components that tries to solve the form input problems of React. As I tried many diffent solutions I found that all of them try to enforce a certain layout. I want a solution that just provides an easy way to fix the binding of data to input components without any interferance in the way I do my layout.
Simple
This component provides a simple way of displaying an input form and automatic binding of data. All you have to do is to provide the data, one or more schema's.
Formatting
An optional feature is the formatting of data. Per field you can configure if you want to format the data value into an input value and if you want to format the entered value into a data value.
For example: Suppose your data structure contains a date field. You do want to format this value into a locale date format and format the entered value back into a date value.
Validation
An other optional feature is date validation. You can provide a function that validates a value. This is a per field configuration.
Field style
If a field fails, the css class of the field can be changed based on the validation.
Schema style
If a schema fails, the css class of the schema can be changed based on the validation.
Form style
If a form fails, the css class of the schema can be changed based on the validation.
If one validation fails, the form cannot submit.
Submit
When the form submits, you receive bunch of information:
- The values (of course)
- The original values
- Per field a boolean that tells if the value changed
- The entered values
- The formatted values
example1: A simple schema
const schema = [
  { id: 'firstname', component: (props) => <Row><Col>Firstname:</Col><Col><input {...props} /></Col><Row>}
  { id: 'lastname', component: (props) => <Row><Col>Lastname:</Col><Col><input {...props} /></Col><Row>}
];
return (
  <Form data={myData}>
    <Schema schema={schema} />
  </Form>
)example 2: Two schema's
const schema1 = [
  { id: 'firstname', component: (props) => <Row><Col>Firstname:</Col><Col><input {...props} /></Col><Row>}
  { id: 'lastname', component: (props) => <Row><Col>Lastname:</Col><Col><input {...props} /></Col><Row>}
];
const schema2 = [
  { id: 'birthdate', component: (props) => <Row><Col>Date of birth:</Col><Col><input {...props} /></Col><Row>}
  { id: 'birthplace', component: (props) => <Row><Col>Place of birth:</Col><Col><input {...props} /></Col><Row>}
];
return (
  <Form data={myData}>
    <Column>
      <Schema schema={schema1} />
    </Column>
    <Column>
      <Schema schema={schema2} />
    </Column>
  </Form>
)example 3: Validation
const ageValidation = age => (age >= 18 && age < 65);
const schema = [
  { id: 'firstname', component: (props) => <Row><Col>Firstname:</Col><Col><input {...props} /></Col><Row>},
  { id: 'lastname', component: (props) => <Row><Col>Lastname:</Col><Col><input {...props} /></Col><Row>},
  { id: 'age', validate: ageValidation, component: (props) => <Row><Col>Age:</Col><Col><input {...props} /></Col><Row>}
];
return (
  <Form data={myData}>
    <Schema schema={schema} />
  </Form>
)7 years ago