Skip to content

chrisamaral/formerly

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

79 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

#Formerly

js-standard-style

A modest form library for React, designed to make form serialization and validation easier.


Basics

First thing you want to do is understand how to build a form using formerly components.

import React from 'react'
import {Form, Input, Select} from 'formerly'

function NewsletterForm () {
   return (
     <Form onSubmit={handleSubmit}>

       <label>Your name</label>
       <Input name='name' placeholder='nicolas cage' required/>

       <label>Email</label>
       <Input type='email' name='email' />

       <label>How do you commute to work?</label>
       <Select name='wayOfTransp'>
         <option>Car</option>
         <option>Bus</option>
         <option>Bike</option>
         <option>Dont work</option>
       </Select>

       <label>Tell us more about yourself</label>
       <TextArea name='nonsense' />

       <div className='very-small-text'>
         <Input id='sendSpam' type='checkbox' name='sendSpam' defaultValue={true} />
         <label htmlFor='sendSpam'>
           Would you like to discover the meaning of life?
         </label>
       </div>

       <button type='submit'>Submit</button>
     </Form>
   )
}

export default NewsletterForm

That's it, our very first formerly form. Now, you're probably wondering how that handleSubmit function looks like. Fortunately, it is just a bit different from your regular event handler, and in a simpler way: you don't need to call event.preventDefault() and can just consume the the inputted values right away. Here is how:

function handleSubmit (errors, formData) {
  if(errors) return alert("please don't")

   // complicated AI stuff
   if (formData.nonsense.match(/music/i)) {
     formData.sendSpamFrom = 'spotity'
   }

   fetch('/big-data', {
     method: 'POST',
     body: JSON.stringify(formData)
   })
}

Although being a very basic example, we introduced the key concepts from formerly. We can see that it exposes a few components with familiar sounding names, Form, Input, Select and TextArea. You can think of them as extensions to native elements. Important takeaway: They won't work outside a Form and formerly wont serialize any other native <input> you put inside the Form.

Complex Forms

An important use case we wanted to get just right was the serialization of larger forms, which are often complex and have nested objects/arrays in them.

So, let's get setup a new example. Say, you work for Wikipedia and you have this person database storing all kinds of creepy personal information, our hypothetical object representation for a random personality would look like this:

const thisOnePerson = {
	fullName: 'Samuel L. Jackson',
	occupations: ['actor', 'film producer'],
	almaMater: 'Morehouse College',
	birth: {
	  day: '12/21/1948',
	  place: 'Washington, D.C., U.S.'
	},
	significantOther: {
		fullName: 'LaTanya Richardson',
		occupations: ['actress', 'producer']
	},
	children: [{
		fullName: 'Zoe Jackson'
	}]
}

Now suppose your job is to come up with a single form to fill all this stuff, scary right? Of course, especially from a UX point of view, it's a nightmare! But a job is a job so... formerly to the rescue! Here is how we could represent that same object on a component using formerly:

import {Form, Entity, Input, Select} from 'formerly'

function handleSubmit (errors, person) {
 // ...
}

function PersonForm () {
  return (
    <Form onSubmit={handleSubmit}>
	    <label>Person Name</label>
	    <Input name='fullName' value='Samuel L. Jackson' />

		<h3>Occupations</h3><hr/>
		<Entity name='occupations'>
  		    <!-- using a number as *name* hints formerly
			    to serialize the entity as an array -->

		    <Input name={0} value='actor' />
		    <Input name={1} value='film producer' />
		</Entity>

		<label>Alma Mater</label>
		<Select name='almaMater'>
			<option>Morehouse College</option>
			<option>École Normale Superieure</option>
			<option>Oxford</option>
			<option>USP</option>
		</Select>


		<Entity name='birth'>
			<label>Birthday</label>
			<Input type='date' name='day' value='1948-12-21' />

			<label>Birth place</label>
			<Input name='place' value='Washington, D.C., U.S.' />
		</Entity>

		<Entity name='significantOther'>
		    <label>Significant Other</label>
		    <Input name='fullName' value='LaTanya Richardson' />

			<h3>Occupations</h3><hr/>
			<Entity name='occupations'>
			    <Input name={0} value='actress' />
			    <Input name={1} value='producer' />
			</Entity>
		</Entity>

		<Entity name='children'>
			<Entity name={0}>
				<label>Child name</label>
			    <Input name='fullName' value='Zoe Jackson' />
		    </Entity>
		</Entity>

       <button type='submit'>Submit</button>
    </Form>
  )
}

export default PersonForm

API

  • Form

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Packages

No packages published