Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

easy-react-form

Package Overview
Dependencies
Maintainers
1
Versions
56
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

easy-react-form

Simple, fast and easy-to-use React Form.

  • 2.0.8
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
107
increased by345.83%
Maintainers
1
Weekly downloads
 
Created
Source

easy-react-form

Simple, fast and easy-to-use React Form.

npm version

Install

npm install easy-react-form --save

Use

  1. Create a <Form/> element with onSubmit property being a function of values.
  2. Put several <Field/>s inside the <Form/> each one having a name and a component.
  3. Put a submit button inside the <Form/>.

Simplest example:

import { Form, Field } from 'easy-react-form'

<Form onSubmit={ values => console.log(values) }>
  <Field
    name="phone"
    component="input"
    type="tel"
    placeholder="Enter phone number" />

  <button> Submit </button>
</Form>

Advanced example:

import { Form, Field, Submit } from 'easy-react-form'

class AdvancedExample extends React.Component {
  // Form field validation example.
  // If `validate` returns a string
  // then it becomes the `error` of the `<Field/>`.
  validatePhone = (value) => {
    if (value && !isValidPhoneNumber(value)) {
      return 'Invalid phone number'
    }
  }

  // Form submit function.
  // Can be `async/await`.
  // Can return a `Promise`.
  submit = (values) => {
    console.log(values)
    return new Promise(resolve => setTimeout(resolve, 3000))
  }

  render() {
    // Initial form field value example.
    const { user } = this.props

    return (
      <Form onSubmit={ this.submit }>
        <Field
          required
          name="phone"
          component={ TextInput }
          type="tel"
          placeholder="Enter phone number"
          // Initial value for this field.
          value={ user.phone }
          validate={ this.validatePhone } />

        <Submit component={ SubmitButton }>
          Save
        </Submit>
      </Form>
    )
  }
}

// `error` is passed if the field is invalid.
function TextInput({ error, ...rest }) {
  return (
    <div>
      <input type="text" {...rest}/>
      {error &&
        <div className="error">{error}</div>
      }
    </div>
  )
}

// `wait` is `true` while form is submitting.
function SubmitButton({ wait, children }) {
  return (
    <button disabled={ wait }>
      { children }
    </button>
  )
}

API

Form

The <Form/> takes the following required properties:

  • onSubmit : Function(values) — Can be async or return a Promise.

The <Form/> takes the following optional properties:

  • values : object — The initial values for this form's fields.

  • trim : Boolean – By default, the form trims string field values when passing them to onSubmit() function. To disable this feature, set trim property to false (defaults to true). Regardless of the trim setting, empty string field values are converted to nulls when passed to onSubmit() function.

  • requiredMessage : String – The default error message for <Field required/>. Is "Required" by default.

  • onError : Function(Error) — Submit error handler. E.g. can show a popup with error message.

  • autoFocus : Boolean — Set to true to automatically focus on the first form field when the form is mounted. Defauls to false.

  • initialState : object — One can pass a previously stored form state in order to restore the form to the state it was at that point in time.

  • onStateDidChange(newState : object) — Will get called whenever a form's state has changed.

    • There's no prevState : object? argument currently because the state object is mutated "in place" instead of creating an "immutable" copy of it every time it changes.
  • onBeforeSubmit : Function

  • onAfterSubmit : Function

  • onAbandon : Function(fieldName, fieldValue) — If a form field was focused but then the form wasn't submitted and was unmounted then this function is called meaning that the user possibly tried to fill out the form but then decided to move on for some reason (e.g. didn't know what to enter in a particular form field).

The <Form/> component instance (ref) provides the following methods:

  • focus(fieldName : String) — Focuses on a field.

  • scroll(fieldName : String) — Scrolls to a field (if it's not visible on the screen).

  • clear(fieldName : String) — Clears field value.

  • get(fieldName : String) — Gets form field value.

  • set(fieldName : String, value : any) — Sets form field value.

  • watch(fieldName : String) : any — Watches a form field's value. Returns the current form field's value and re-renders the whole form whenever that value changes.

  • values : object? — An object containing all form field values. Is undefined until the form has mounted.

  • reset() — Resets all form field values.

Upon form submission, if any one of its fields is invalid, then that field will be automatically scrolled to and focused, and the actual form submission won't happen.

The <Form/> can also accept children being a function(parameters) returning a React.Element that will be called on any form value change, so it can be used in cases when re-rendering the whole <Form/> is required on any form value change. Available parameters:

  • values : Object — Form values. Is undefined until the form is initialized (mounted) (<Field/> values are undefined until those <Feild/>s are mounted).

  • set(fieldName : String, value : any) — Sets form field value.

  • clear(fieldName : String) — Clears field value.

  • reset() — Resets all form field values.

  • watch(fieldName : String) : any — Watches a form field's value. Returns the current form field's value and re-renders the whole form whenever that value changes. Returns undefined until the form is initialized (mounted) (<Field/> defaultValues are not set until those <Feild/>s have mounted).

  • focus(fieldName : String) — Focuses on a field.

  • scroll(fieldName : String) — Scrolls to a field (if it's not visible on the screen).

  • submitting : boolean — Whether the form is currently being submitted.

Field

<Field/> takes the following required properties:

  • name : String

  • component : (React.Component|Function|String) — React component (can also be a string like input). Must accept a ref for calling ref.current.focus() and also must provide the means of obtaining the DOM Element for calling element.scrollIntoView(). Therefore, component must be either a string, or a React.Component, or a "functional" component wrapped in React.forwardRef(), or a "functional" component using useImperativeRef() "hook" providing .focus() and .getDOMNode() methods.

<Field/> takes the following optional properties:

  • value - the initial value of the field.

  • validate(value) : String? — Form field value validation function. Is only called when value is not "empty": null / undefined / "" / []. Should return an error message if the field value is invalid.

  • required : String or Boolean — adds "this field is required" validation for the <Field/> with the error message equal to required property value if it's a String defaulting to "Required" otherwise. Note that value={false} is valid in case of required because false is a non-empty value (e.g. "Yes"/"No" dropdown), therefore use validate function instead of required for checkboxes that are required to be checked, otherwise an unchecked checkbox will have value={false} and will pass the required check.

<Field/> passes the following properties to the field component:

  • value

  • onChange

  • onFocus

  • onBlur

  • wait : Boolean — is true when form is submitting.

  • required : Boolean — is true when the <Field/> is required and the value is missing.

  • error : String — error message.

  • All other properties are passed through.

The error display algorithm is as follows:

  • Initially, if validate() returns an error for a field's default value, that error is shown.

  • Whenever the user submits the form, errors are displayed for all invalid form fields.

  • Whenever the user edits a field's value, error becomes undefined for that field while the user is focused on the field.

  • Whenever the user focuses out of a field it is re-validated and error is passed if it's invalid.

  • By default, required errors are only displayed after the user has attempted submitting the form.

Therefore, the error message is only shown when the user is not editing the field. For example, while the user is typing a phone number that phone number is invalid until the used inputs it fully, but it wouldn't make sense to show the "Invalid phone number" error to the user while he is in the process of inputting the phone number (it would just be an annoying distraction).

Submit

<Submit/> takes the following required properties:

  • component : (React.Component|Function|String) — React component (can also be a string like button).

<Submit/> passes the following properties to the component:

  • wait : Boolean — indicates if the form is currently being submitted.

  • All other properties are passed through.

function Example() {
  return (
    <Form onSubmit={ ... }>
      <Field name="text" component={ Input } />

      <Submit component={ SubmitButton }>
        Submit
      </Submit>
    </Form>
  )
}

function SubmitButton({ wait, children }) {
  return (
    <button disabled={ wait }>
      { wait && <Spinner/> }
      { children }
    </button>
  )
}

Lists

Sometimes there're forms on which new rows can be added by clicking "Add new row" button. For such cases there's <List/> component that handles adding new rows and removing existing ones.

import React from 'react'
import { Form, Field, List, Submit } from 'easy-react-form'

export default function Page() {
  return (
    <Form onSubmit={...}>
      <h1>
        The list of employees
      </h1>
      <List name="employees">
        {(items) => (
          <React.Fragment>
            {items.map((itemId) => (
              <React.Fragment key={itemId}>
                <Field
                  item={itemId}
                  name="firstName"
                  .../>
                <Field
                  item={itemId}
                  name="lastName"
                  .../>
                <button type="button" onClick={() => items.remove(itemId)}>
                  Remove
                </button>
              </React.Fragment>
            ))}
            <button type="button" onClick={() => items.add()}>
              Add
            </button>
          </React.Fragment>
        )}
      </List>
      <Submit component="button">
        Save
      </Submit>
    </Form>
  )
}

<List/> accepts properties:

  • name: String — (required) The name of the list property in form values.
  • count: Number — The initial items count. Is 1 by default.

Nested <List/>s are not supported.

License

MIT

Keywords

FAQs

Package last updated on 17 Feb 2023

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc