import { createStore, applyMiddleware, combineReducers } from 'redux'; import { Provider } from 'react-redux'; import { Navigation } from 'react-native-navigation'; import thunk from 'redux-thunk'; import * as reducers from './reducers'; import * as appActions from './reducers/app/actions'; // redux related book keeping const createStoreWithMiddleware = applyMiddleware(thunk)(createStore); const reducer = combineReducers(reducers); const store = createStoreWithMiddleware(reducer); // screen related book keeping import { registerScreens } from './screens'; registerScreens(store, Provider); // notice that this is just a simple class, it's not a React component export default class App { constructor() { // since react-redux only works on components, we need to subscribe this class manually store.subscribe(this.onStoreUpdate.bind(this)); store.dispatch(appActions.appInitialized()); } onStoreUpdate() { const { root } = store.getState().app; // handle a root change // if your app doesn't change roots in runtime, you can remove onStoreUpdate() altogether if (this.currentRoot != root) { this.currentRoot = root; this.startApp(root); } } startApp(root) { switch (root) { case 'login': Navigation.startSingleScreenApp({ screen: { screen: 'example.LoginScreen', title: 'Login', navigatorStyle: {} } }); return; case 'after-login': Navigation.startTabBasedApp({ tabs: [ { label: 'One', screen: 'example.FirstTabScreen', icon: require('../img/one.png'), selectedIcon: require('../img/one_selected.png'), title: 'Screen One', navigatorStyle: {} }, { label: 'Two', screen: 'example.SecondTabScreen', icon: require('../img/two.png'), selectedIcon: require('../img/two_selected.png'), title: 'Screen Two', navigatorStyle: {} } ], animationType: 'slide-down', title: 'Redux Example' }); return; default: console.error('Unknown app root'); } } }