46 lines
1.3 KiB
JavaScript
46 lines
1.3 KiB
JavaScript
const createExpoWebpackConfigAsync = require('@expo/webpack-config')
|
|
const {withAlias} = require('@expo/webpack-config/addons')
|
|
const ReactRefreshWebpackPlugin = require('@pmmmwh/react-refresh-webpack-plugin')
|
|
const {BundleAnalyzerPlugin} = require('webpack-bundle-analyzer')
|
|
|
|
const GENERATE_STATS = process.env.EXPO_PUBLIC_GENERATE_STATS === '1'
|
|
const OPEN_ANALYZER = process.env.EXPO_PUBLIC_OPEN_ANALYZER === '1'
|
|
|
|
const reactNativeWebWebviewConfiguration = {
|
|
test: /postMock.html$/,
|
|
use: {
|
|
loader: 'file-loader',
|
|
options: {
|
|
name: '[name].[ext]',
|
|
},
|
|
},
|
|
}
|
|
|
|
module.exports = async function (env, argv) {
|
|
let config = await createExpoWebpackConfigAsync(env, argv)
|
|
config = withAlias(config, {
|
|
'react-native$': 'react-native-web',
|
|
'react-native-webview': 'react-native-web-webview',
|
|
})
|
|
config.module.rules = [
|
|
...(config.module.rules || []),
|
|
reactNativeWebWebviewConfiguration,
|
|
]
|
|
if (env.mode === 'development') {
|
|
config.plugins.push(new ReactRefreshWebpackPlugin())
|
|
}
|
|
|
|
if (GENERATE_STATS || OPEN_ANALYZER) {
|
|
config.plugins.push(
|
|
new BundleAnalyzerPlugin({
|
|
openAnalyzer: OPEN_ANALYZER,
|
|
generateStatsFile: true,
|
|
statsFilename: '../stats.json',
|
|
analyzerMode: OPEN_ANALYZER ? 'server' : 'json',
|
|
defaultSizes: 'parsed',
|
|
}),
|
|
)
|
|
}
|
|
return config
|
|
}
|