localsync
a lightweight module to sync JS objects in realtime across tabs / windows of a browser. Uses local storage event emitters and falls back to cookie polling if using an unsupported browser (IE 9+ / Edge). Isomorphic. Tested with mocha.
data:image/s3,"s3://crabby-images/79f10/79f109a61f8b881604a54b64460a4abf8bfcff8b" alt="Build Status"
data:image/s3,"s3://crabby-images/d7bec/d7bec41ebadcec46e0bda8bb818b78440572cbde" alt="NPM"
Install
npm i -S localsync
How to use
import localsync from 'localsync'
const action = (userID, first, last) => ({ userID, first, last })
const handler = (new, old, url) => {
console.info(`Another tab at url ${url} switched user from "${old.first} ${old.last}" to "${new.first} ${new.last}".`)
}
const usersync = localsync('user', action, handler)
usersync.start()
if(usersync.isFallback)
console.warn('browser doesnt support local storage synchronization, falling back to cookie synchronization.')
usersync.trigger(1, 'jimmy', 'john')
setTimeout(() => {
usersync.trigger(2, 'jane', 'wonka')
}, 5000)
setTimeout(() => {
if(usersync.isRunning)
usersync.stop()
}, 10000)