Skip to content

jQuery plugin to save form fields values to Local Storage via HMTL5 Web Storage API

License

Notifications You must be signed in to change notification settings

thakerhardiks/jquery-phoenix

 
 

Repository files navigation

Phoenix Code Climate

jQuery plugin to save form fields values to Local Storage via HMTL5 Web Storage API

Lost connections, crashed browsers, broken validations – all these shit loose forms data you've filled in with love and care.

Phoenix keeps bad things away from your forms. It is very tiny – 3Kb (1Kb gziped), but powerful. Phoenix saves form fields values, checkboxes and radio button states to your browser Local Storage using HTML5 Web Storage API.

Enough words! Take a look at

Demo

Phoenix Demo

Try the DEMO!

Requirements

It's jQuery plugin so it requires jQuery.

Installation

Clone from source, download (minified) or install with bower.

Usage

  1. Require jQuery
  2. Require jquery.phoenix.js or its minified version
  3. $('input').phoenix() – cast the magic
  4. $('input').phoenix('remove') – clear storage on successful form submission (or any other event your like more)

Something like this

<form id='stored-form'>
  <input type="text" class="phoenix-input" />
  <textarea type="text" class="phoenix-input"></textarea>
</div>

<script type="text/javascript">
  $('.phoenix-input').phoenix()
  $('#my-form').submit(function(e){
    $('.phoenix-input').phoenix('remove')
  })
</script>

Do take a look at demo file source to understand usage.

API

Phoenix provides simple but flexible API.

Options

You can pass an options object on Phoenix initialization.

$('.phoenix-input').phoenix({
    namespace: 'phoenixStorage',
    maxItems: 100,
    saveInterval: 1000,
    clearOnSubmit: '#stored-form'
  })

Possible options are:

  • namespace – localStorage namespace (if you don't like default) – string: phoenixStorage,
  • maxItems – max items to store (every form field is an item) – integer: 100,
  • saveInterval – how often to save field values to localStorage (milliseconds) – integer: 1000
  • clearOnSubmit – form selector (when you submit this form Phoenix will clean up stored items) – string: false

Methods

When Phoenix initialized you can use API methods to manage it. Call method with $(selector).phoenix('methodName'), where methodName is one of these:

  • start – start saving timer, it will save field values every saveIntervalms (saveInterval is an option as you remember)
  • stop – stop saving timer
  • load – load value from stored item to field
  • save – save value from field to stored item
  • remove – stop saving timer and remove stored item from localStorage

NB Phoenix doesn't remove stored item from localStorage by itself. So don't forget to call remove event when you don't need filled in form field values anymore or use clearOnSubmit option with form id.

Events

Every Phoenix method call fires an event you can bind to. For example

$('.phoenix-input').bind('phnx.loaded', function (e) {
  console.log('Data loaded... ')
})

Events naming is very obvious, so try them out

  • phnx.started
  • phnx.stopped
  • phnx.loaded
  • phnx.saved
  • phnx.removed

Compatibility

Browsers

Any compatible with HTML5 Web Storage API browser works well with Phoenix.

  • Chrome 4+
  • Firefox 3.5+
  • Safary 4+
  • Opera 10.5+
  • IE 8+
  • All modern mobile browsers (except Opera Mini)

CanIuse cheatsheet

Other plugins

Dozens of plugins make form inputs more powerful and pretty. Chosen or Select2 for example. You can use it with Phoenix safely. Just make sure that you initialize Phoenix before these plugins.

Registries

License

Distributed under MIT license

Contributing

Feel free to create pull request of your changes. But only in CoffeeScript.

Almighty contributors.


Sponsored by Roem.ru Roem.ru
Donate to Gittip or Flattr

About

jQuery plugin to save form fields values to Local Storage via HMTL5 Web Storage API

Resources

License

Stars

Watchers

Forks

Packages

No packages published