Skip to content

espeakers/react-loose-forms

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

33 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

react-loose-forms

A form library for React that flexible and dynamic allowing it to be effective in many (if not all) situations where you need to collect user input.

This library is focused on the schema and state management of forms. Rendering and layout of input fields are handled separately. Here are libraries that help provide the layout and rendering of input fields:

Examples

See react-loose-forms.examples

FormMixin

var FormMixin = require("react-loose-forms");

child method: buildSchema()

Return your form fields schema. This method is called during state changes so you should always return the current schema for your form (i.e. don't use hidden fields, rather don't include them in your schema if they are not to be shown).

The schema is a simple object/map/hash where the keys are the field names and the value is the schema for the field.

  mixins: [FormMixin],
  ...
  buildSchema: function(){
    var data = this.state.data;//this is how you can get access to the
                               //current state of the form

    return {
      username: {
        type: "text", //at the bare minimum every field should define
                      //what type of input it is

        validate: function(v){//optionally add a validation function for
                              //this input. If you don't provide one it
                              //will fallback to the input types default
                              //validation, if it doesn't have one it
                              //simply returns true

          //return true if valid, otherwise return an error. An error can
          //be anything really, typically you can just return a string that
          //represents the error message that should be displayed to the user.
        }

        name: //don't define "name", the mixin will stomp over this and set
              //it to the field name. In this case it would be "username"

        //you can tac on anything else you want. It will be visible to the
        //input component. For example a select input might want you to
        //specify an "options" property with an array of options to select from
      },
      ...
    };
  },
  ...
  render: function(){
    ...
  }

See react-loose-forms.examples for more examples.

child method: onFormChanged(field_name, new_value)

This is called whenever a field changes state. This way you can observe state changes.

child method: onInitialValuesChanged()

This is called whenever getInitialValuesSourceVersion changes and the new form state has been setup.

child method: getInitialValues(props)

Define this to setup the initial values for your form fields. Simply return an object keyed by field name. Use the props passed in the function rather than this.props.

child method: getInitialValuesSourceVersion(props)

Return a string that is used to identify which initial values you are working with. When this string changes, the FormMixin will know that it is now working with different underlying data. By default it will JSON.stringify(this.getInitialValues(props))

this.props.onSubmit(data)

This is called when a user submits the form and it passes validation. The data is the current this.state.data.

this.props.onSubmitFail(data)

Optionaly pass in a function to be called when a submit attempt fails due to not passing validation.

this.state.data

An object where the keys are the field names and the values are the current value of the field. They can be strings, object whatever.

this.state.errors

An object where the keys are the field names and the values are errors returned from the validation function. If there isn't an error for a field, it won't be

this.state.submit_attempts

The number of times the user has attempted a submit. This number is reset to 0 upon a successful (no validation errors) submit.

this.Form_buildSchema()

Call this to get the current schema. This calls your buildSchema method but ensures each field has a name property that is the same as the key for that field in the schema.

this.Form_onSubmit(e)

Submit the form. This first validates the form state. If an event is passed as the first argument it will call preventDefault on it. Typically you use it like this:

  render: function(){

    return React.createElement("form", {onSubmit: this.Form_onSubmit},
      ...
    );
  }

this.Form_buildInput(field)

Returns an React component for the field schema. The input will be wired up to the form so it can properly sync changes, validation etc....

this.Form_reset()

Reset the form back to it's initial state.

this.Form_validate()

Run validation on all the fields. This does not update the state, it simply returns an object where the keys are the field names and the values is the error. (if there is no error, it's simply not in the object)

this.Form_areChangesMade()

Returns true if the form state is different than the initial state.

this.Form_onChange(field_name, new_value)

Call this if you manually want to update the state of a form field. (Internally this is what input components call to update their state.)

InputTypes

var InputTypes = require("react-loose-forms/InputTypes");

InputTypes.setInputType(type, input)

This is how you register an input type.

InputTypes.setInputType("your_input_type_name_goes_here", {
  component: // (required)
             // the React component that renders the input
             // It takes 3 props:
             //  * field -> the field schema to render
             //  * value -> the current value
             //  * onChange(new_value) -> call this on new values

  validate: // (optional) a default validation function for this input type
});

See react-loose-forms.bootstrap3/inputs for some example inputs.

InputTypes.getInputByType(type)

This returns the input object associated with the type name. If the type is not found it returns the input for "text". (since a "password" or "email" type usually is the same as a text field)

Changelog

This project follows semantic versioning for releases.

v2.0.0

  • removing FormInputMixin (instead of this.FormInput\_newValue(value), just use this.props.onChange(value))
  • getInitialValuesSourceVersion json stringifies getInitialValues by default
  • The default validation simply returns true

v1.0.1

  • fixing validation error message

v1.0.0

  • initial release

License

MIT

About

form library for React that is very flexible yet powerful

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Contributors 3

  •  
  •  
  •