* Align dist and release tags on all platforms
* Upload web sourcemaps
* Debug code
* Send debug and error logging to Sentry
* Let .env do the work
* Try straight env
* Try copy in Dockerfile
* Ok ok ok
* Debug Dockerfile
* Proper setup
* See where we're at
* Reference var correctly
* Fall back to package version
* Verbose force env
* Should be working native builds
* Comments
* Remove unused deps
* Revert unneeded changes
* Remove debug code
* Clarify intent
* Remove deprecated files
* Add sentry vars to OTA
* Debug
* Revert "Debug"
This reverts commit 2d5857fb0fb0858ac3e2f98bc56bde913078d0a7.
* Use included CLI to upload native source maps post-OTA build
* Use included bin script
See 0d87adb516
* Bump sentry, update script
* Comment
* fix failing CI
* Pin sentry, update patch, update lock
---------
Co-authored-by: Samuel Newman <mozzius@protonmail.com>
65 lines
1.9 KiB
JavaScript
65 lines
1.9 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 {sentryWebpackPlugin} = require('@sentry/webpack-plugin')
|
|
const {version} = require('./package.json')
|
|
|
|
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())
|
|
} else {
|
|
// Support static CDN for chunks
|
|
config.output.publicPath = 'auto'
|
|
}
|
|
|
|
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',
|
|
}),
|
|
)
|
|
}
|
|
if (process.env.SENTRY_AUTH_TOKEN) {
|
|
config.plugins.push(
|
|
sentryWebpackPlugin({
|
|
org: 'blueskyweb',
|
|
project: 'app',
|
|
authToken: process.env.SENTRY_AUTH_TOKEN,
|
|
release: {
|
|
// env is undefined for Render.com builds, fall back
|
|
name: process.env.SENTRY_RELEASE || version,
|
|
dist: process.env.SENTRY_DIST,
|
|
},
|
|
}),
|
|
)
|
|
}
|
|
return config
|
|
}
|