@moreonion/formprefill v0.15.0
Form prefill plugin for jQuery
Built by more onion as a part of Campaignion.
Installation
import { formPrefill } from "path/to/formprefill.min.js";Note: Promises and other ES6 features might need polyfilling for IE.
Usage
Call formPrefill() on the form. If values for any fields are present in one of the stores, the fields are prefilled with the corresponding values.
You can pass an options object (see below).
formPrefill(document.querySelector('form'));For each field that you want to prefill or save you have to set the keys in the markup:
<!-- This will read from and write to the first_name key: -->
<input type="text" data-form-prefill-keys="first_name">
<!-- You can specify multiple keys separated by spaces: -->
<input type="text" data-form-prefill-keys="first_name firstname name">
<!-- You can set different keys to read from and to write to: -->
<input type="text" data-form-prefill-read="first_name firstname" data-form-prefill-write="first_name">
<!-- If the data attributes are omitted the keys are parsed from the name attribute, using the last term in brackets by default. -->
<input type="text" name="person[first_name]">
<input type="text" name="first_name">In case you’re not in control of the markup, you can pass custom logic to set the keys for a field:
formPrefill(document.querySelector('form'), {
  storageKeys: function($element) {
    // Guess the keys from $element...
    return {
      read: "first_name",
      write: "first_name"
    };
  },
});API
The form’s API is accesible via the return value of formPrefill(form).
// Prefill all fields that have values saved in the stores (this is done automatically when you call the plugin on a form):
let api = formPrefill(document.querySelector('form'))
api.readAll()
// Write values to the stores for each field in the form:
// Use this with caution: Depending on your exclusions this will also include unchanged default values
// and hidden-fields used internally by your backend (ie. form tokens).
api.writeAll()
// Clear values from the stores for each field in the form and reset their values to what they were when the plugin was initialized:
api.removeAll()
// Clear each field’s values from the stores, leave the current field values untouched:
api.removeAll({resetFields: false})Each field exposes its own API object in the apiRegistry: apiRegistry.get(form.querySelector('input[name=first_name]'))
let firstName = form.querySelector('input[name=first_name]')
// Read this field’s value from the stores and fill the field in:
apiRegistry.get(firstName).read();
// Write this field’s value to the stores. When called on a checkbox or radio, all checkboxes/radios that have the same keys in their data-form-prefill-write attribute are considered one set of fields.
apiRegistry.get(firstName).write();
// Clear this field’s value from the stores:
apiRegistry.get(firstName).write({delete: true});Each of the field API methods returns a Promise.
Populate the stores via url hash
You can pass values in the url’s hash as follows: The hash can be splitted in segments divided by ;, every segment containing values prefixed with p: will be parsed and stripped from the hash. The values are saved into the stores and any corresponfing form fields are filled in.
Hash examples:
- Field values are separated with ampersands: #p:first_name=Jane&last_name=Doe
- Pass mulitple values for the same property to populate sets of checkboxes: #p:likes=cats&likes=dogswill result in the checkboxes withvalue="cats"andvalue=dogschecked.
- Other parts of the hash remain untouched: #anchor;p:first_name=Jane
Options
| Option | Type | Default | Description | 
|---|---|---|---|
| prefix | String | formPrefill | All entries in the stores are prefixed with this. | 
| storageKeys | Function | A function that sets the storage keys for a given field (passed in as a jQuery object). The function must return an object with a readand awritekey. | |
| map | Object | {} | A map of aliases that are used when looking up keys in the stores. In the case of {'first_name': ['firstname', 'firstName', 'fname']}, a field with the attributedata-form-prefill-keys="first_name"gets prefilled from thefirstNameentry in any of the stores if neither afirst_namenor afirstnameentry exist. | 
| exclude | String | [data-form-prefill-exclude] | Selector for fields or containers in the form that should be excluded from prefilling. | 
| include | String | [data-form-prefill-include] | Selector for fields or containers inside excluded containers that should be included nevertheless. | 
| stringPrefix | String | s | Entries in the stores describing strings are prefixed with this string. | 
| listPrefix | String | l | Entries in the stores describing lists are prefixed with this string. | 
| stores | Array | ['sessionStorage'] | An array of custom store instances or names of predefined stores. A store instance has to expose a setItems, aremoveItems, and agetFirstmethod, each of which should return a Promise. This way your store could make an XHR request, resolving the promise and thus prefilling the form only when the data arrives. Pre-defined stores are:cookie,sessionStorageandlocalStorage | 
| cookieDomain | String | '' | The domain from which cookies can be accessed. Defaults to the current domain, not including (other) subdomains. | 
Events
By default, the stores are updated when fields fire the change event.
When the plugin populates a field, it fires form-prefill:prefilled on the field.
When it fails to retrieve a value for a field, it fires form-prefill:failed on the field, providing the cause as the second argument to the handler function.
These events bubbles up.
When you call removeAll() on the form’s API, form-prefill:cleared is fired on the form.
Running the tests
The test-suite is written using Qunit. You can run it by starting a development server (eg. using php -S localhost:8000) and then navigating to qunit.html (http://localhost:8000/tests/qunit.html).