react-static
Version:
A progressive static site generator for React
80 lines (75 loc) • 2.58 kB
JavaScript
import webpack from 'webpack'
import resolveFrom from 'resolve-from'
import HtmlWebpackPlugin from 'html-webpack-plugin'
import CaseSensitivePathsPlugin from 'case-sensitive-paths-webpack-plugin'
import ExtractCssChunks from 'extract-css-chunks-webpack-plugin'
import path from 'path'
import rules from './rules'
export default function({ config }) {
const { DIST, NODE_MODULES, SRC, HTML_TEMPLATE } = config.paths
process.env.REACT_STATIC_BASE_PATH = config.basePath
process.env.REACT_STATIC_PUBLIC_PATH = config.publicPath
process.env.REACT_STATIC_ASSETS_PATH = config.assetsPath
return {
mode: 'development',
optimization: {
noEmitOnErrors: true,
concatenateModules: true,
},
context: path.resolve(__dirname, '../../../node_modules'),
entry: [
'react-hot-loader/patch',
...(config.disableRuntime
? []
: [
require.resolve('../../bootstrapPlugins'),
require.resolve('../../bootstrapTemplates'),
]),
config.entry,
].filter(Boolean),
output: {
filename: '[name].js', // never hash dev code
chunkFilename: 'templates/[name].js',
path: DIST,
publicPath: process.env.REACT_STATIC_ASSETS_PATH || '/',
},
module: {
rules: rules({ config, stage: 'dev' }),
strictExportPresence: true,
},
resolve: {
modules: [
NODE_MODULES,
SRC,
DIST,
...[NODE_MODULES, SRC, DIST].map(d => path.resolve(__dirname, d)),
'node_modules',
],
extensions: ['.wasm', '.mjs', '.js', '.json', '.jsx'],
alias: {
react$: resolveFrom(NODE_MODULES, 'react'),
'react-dom$': resolveFrom(NODE_MODULES, 'react-dom'),
'react-universal-component': resolveFrom(
__dirname,
'react-universal-component'
),
__react_static_root__: config.paths.ROOT,
// This is here so HMR modules use the same emitter instance.
// Likely this is only needed for locally linked dev on RS, but still...
'webpack/hot/emitter': resolveFrom(__dirname, 'webpack/hot/emitter'),
},
},
plugins: [
new webpack.EnvironmentPlugin(process.env),
new HtmlWebpackPlugin({
inject: true,
template: `!!raw-loader!${HTML_TEMPLATE}`,
}),
new webpack.HotModuleReplacementPlugin(),
new webpack.NamedModulesPlugin(),
new CaseSensitivePathsPlugin(),
new ExtractCssChunks({ filename: '[name].css' }), // never hash dev code
],
devtool: 'cheap-module-source-map',
}
}