/redux-restore

Handles storage in React Native

Primary LanguageJavaScript

##redux-restore

This is a simple wrapper around async storage that saves your store data to AsyncStorage in react native. Works with Android and iOS! Tested on 0.18

##Install

npm install redux-restore --save

##Setup

###Register Middleware

Create your store with the storage middleware

import { combineReducers, applyMiddleware, createStore } from 'redux'
import items from './items'
import authentication from './authentication' //reducer name
import { storage } from 'redux-restore'

let createStoreWithMiddleware = applyMiddleware(
  storage(['authentication']) //reducer name
)(createStore)

let reducers = combineReducers({
  items,
  authentication
})

export default createStoreWithMiddleware(reducers)

Pass an array with reducer names. Each one you pass will be saved to storage.

###Use RestoreProvider

Use this instead of the usual Provider from redux. When you load the app, it will dispatch from storage with the current state, if there is any.

import React from 'react-native'
import Scene from './scene'
import store from '../../reducers'
import { RestoreProvider } from 'redux-restore'

export default class App extends React.Component {
  render() {
    return (
      <RestoreProvider store={store}>
        <Scene />
      </RestoreProvider>
    );
  }
}

###Add an action to your reducer

case 'authentication':
  delete action.type
  return Immutable.Map(action)

Create a new case with the name of your reducer. This will be called with all of the stored state.

That's it! You're all set!

###Conclusion

This library is one of the nicest AsyncStorage wrappers I've seen. The only problem I see is the way the state is restored. I think the RestoreProvider component could be done better.