mirror of
https://github.com/zhigang1992/react-native-web.git
synced 2026-01-12 22:51:09 +08:00
Builds on the exclusion of PropTypes from production builds: - Remove 'lodash' and use smaller modules for equivalent functions. - Remove use of some unnecessary Facebook utilities. - Remove 'TouchableBounce'; it isn't part of React Native anymore. - Remove stray import of 'react-dom/server'. - Exclude 'StyleSheetValidation' from production. Measuring the UMD build (gzip)… Before: ~100KB After: ~60KB
50 lines
1.2 KiB
JavaScript
50 lines
1.2 KiB
JavaScript
const path = require('path')
|
|
const webpack = require('webpack')
|
|
const BundleAnalyzerPlugin = require('webpack-bundle-analyzer').BundleAnalyzerPlugin;
|
|
|
|
const DIST_DIRECTORY = './dist'
|
|
|
|
module.exports = {
|
|
entry: {
|
|
main: DIST_DIRECTORY
|
|
},
|
|
externals: [
|
|
{
|
|
react: {
|
|
root: 'React',
|
|
commonjs2: 'react',
|
|
commonjs: 'react',
|
|
amd: 'react'
|
|
}
|
|
}
|
|
],
|
|
output: {
|
|
filename: 'ReactNative.js',
|
|
library: 'ReactNative',
|
|
libraryTarget: 'umd',
|
|
path: DIST_DIRECTORY
|
|
},
|
|
plugins: [
|
|
new BundleAnalyzerPlugin({
|
|
analyzerMode: 'static',
|
|
openAnalyzer: false
|
|
}),
|
|
new webpack.DefinePlugin({ 'process.env.NODE_ENV': JSON.stringify('production') }),
|
|
new webpack.optimize.DedupePlugin(),
|
|
// https://github.com/animatedjs/animated/issues/40
|
|
new webpack.NormalModuleReplacementPlugin(
|
|
/es6-set/,
|
|
path.join(__dirname, 'src/modules/polyfills/Set.js')
|
|
),
|
|
new webpack.optimize.OccurenceOrderPlugin(),
|
|
new webpack.optimize.UglifyJsPlugin({
|
|
compress: {
|
|
dead_code: true,
|
|
drop_console: true,
|
|
screw_ie8: true,
|
|
warnings: true
|
|
}
|
|
})
|
|
]
|
|
}
|