An example react application (master-detail feed) with isomorphic rendering, async react-router routes, async redux reducers, async data fetching, and code-splitting.
The file size of isomorphic React apps can quickly get out of hand. Many isomorphic starter kits look awesome to begin with but yield a several megabyte javascript file for the client to download. This project aims to demonstrate some possible solutions.
- Node.js
- Express
- React
- Redux
- React Router 2.0
- Aphrodite for CSS by Khan Academy
- React Helmet for meta tags by the NFL
- Redial for data fetching by @markdalgleish
- Babel 6
- Webpack with code splitting
- React Hot Loader
- example-react-router-server-rendering-lazy-routes by @ryanflorence
- Cake's approach to React Router server rendering w/code splitting and Redux by @rgrove
- How to dynamically load reducers for code splitting in a Redux application? by @dan_abramov
.
├── /build/ # The folder for compiled output
├── /node_modules/ # 3rd-party libraries and utilities
├── /src/ # The source code of the application
│ ├── /components/ # Global React components
│ ├── /middleware/ # Redux middleware (comes with callAPIMiddileware)
│ ├── /routes/ # React-router routes
│ | ├── /PostList/ # PostList page
│ | ├── /Edit/ # Edit page (stub)
│ | ├── /Post/ # Post (async)
│ | | ├── /components/ # Post components (async)
│ | | ├── actions.js # Post actions (async)
│ | | ├── reducer.js # Post reducer (async)
│ | | ├── index.js # Post Route (async)
│ | ├── /root.js # React-router root
│ ├── /client.js # Client-side entry point
│ ├── /store.js # Async store configuration
│ ├── /constants.js # Global constants (Action types, Aphrodite layout/style vars)
│ ├── /createReducer.js # Like rootReducer, but async
│ ├── /server/ # Server
│ | ├── /api/ # API endpoints
│ | | ├── /posts.js # Posts endpoint
│ | | ├── /post.js # Single Post endpoint
│ | ├── /fakeDB.js # Database Stub
│ | ├── /server.js # Express app
│ | ├── /index.js # Server entry point (with babel-register)
├── /test/ # Mocha tests (e.g. xxx_spec.js)
├── /coverage/ # Code coverage data
│── .env # **Server-side configuration variables**
│── Procfile # Heroku startup commands
│── package.json # The list of 3rd party libraries and utilities and NPM scripts
│── webpack.config.dev.js # Webpack Development Configuration File
└── webpack.config.prod.js # Webpack Production Configuration File
git clone https://github.com/jaredpalmer/react-production-starter MyApp
cd MyApp
npm install
npm start
# Open localhost:5000
More docs soon. PRs welcome!