This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
import createHistory from 'history/createMemoryHistory' | |
import configureStore from '../src/configureStore' | |
export default async (req, res) => { | |
const history = createHistory({ initialEntries: [req.path] }) | |
const { store, thunk } = configureStore(history) | |
await thunk(store) // THE PAYOFF! | |
const status = store.getState().location.type === NOT_FOUND ? 404 : 200 |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
import React from 'react' | |
import ReactDOM from 'react-dom/server' | |
import { Provider } from 'react-redux' | |
import configureStore from './configureStore' | |
import App from '../src/components/App' | |
export default () => async (req, res, next) => { | |
const store = await configureStore(req, res) | |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
// client | |
const webpack = require('webpack') | |
const path = require('path') | |
module.exports = { | |
name: 'client', | |
entry: [ | |
path.resolve(__dirname, '../src/index.js') | |
], | |
output: { |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
const app = express() | |
const multiCompiler = webpack([clientConfig, serverConfig]) | |
const clientCompiler = multiCompiler.compilers[0] | |
app.use(webpackDevMiddleware(multiCompiler, { publicPath })) | |
app.use(webpackHotMiddleware(clientCompiler)) | |
app.use(webpackHotServerMiddleware(multiCompiler) | |
app.listen(3000, () => console.log('READY')) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
import createHistory from 'history/createMemoryHistory' | |
import { NOT_FOUND } from 'redux-first-router' | |
import configureStore from '../src/configureStore' | |
export default async (req, res) => { | |
const history = createHistory({ initialEntries: [req.path] }) | |
const { store, thunk } = configureStore(history) | |
await thunk(store) // THE PAYOFF! |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
import createHistory from 'history/createMemoryHistory' | |
import { NOT_FOUND } from 'redux-first-router' | |
import configureStore from '../src/configureStore' | |
export default async (req, res) => { | |
const history = createHistory({ initialEntries: [req.path] }) | |
const { store, thunk } = configureStore(history) | |
await thunk(store) // THE PAYOFF! |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
import createHistory from 'history/createMemoryHistory' | |
import { NOT_FOUND } from 'redux-first-router' | |
import configureStore from '../src/configureStore' | |
export default async (req, res) => { | |
const history = createHistory({ initialEntries: [req.path] }) | |
const { store, thunk } = configureStore(history) | |
// perhaps request + dispatch app-wide state as well: | |
// await Promise.all([ store.dispatch(myThunkA), store.dispatch(myThunkB) ]) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
import createHistory from 'history/createMemoryHistory' | |
import { NOT_FOUND } from 'redux-first-router' | |
import configureStore from '../src/configureStore' | |
export default async (req, res) => { | |
const history = createHistory({ initialEntries: [req.path] }) | |
const { store, thunk } = configureStore(history) | |
let location = store.getState().location | |
if (doesRedirect(location, res)) return false |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
externals: !isNode ? [] : | |
fs.readdirSync(path.resolve(__dirname, '../../node_modules')) | |
.filter( | |
x => !/\.bin|react-universal-component|webpack-flush-chunks|^normalize.css/.test(x), | |
) | |
.reduce((externals, mod) => { | |
externals[mod] = `commonjs ${mod}`; // eslint-disable-line | |
return externals; | |
}, {}), |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
const requireWeak = (modulePath) => { | |
try { | |
const moduleId = require.resolveWeak(modulePath) | |
return __webpack_require__(moduleId) | |
} | |
catch (err) { | |
return null | |
} | |
} |