react/packages/react-devtools-shell/webpack.config.js
Brian Vaughn 51626ae2f9 Prettier
2019-08-13 18:12:19 -07:00

93 lines
1.9 KiB
JavaScript

const {resolve} = require('path');
const {DefinePlugin} = require('webpack');
const {getGitHubURL, getVersionString} = require('../utils');
const NODE_ENV = process.env.NODE_ENV;
if (!NODE_ENV) {
console.error('NODE_ENV not set');
process.exit(1);
}
const TARGET = process.env.TARGET;
if (!TARGET) {
console.error('TARGET not set');
process.exit(1);
}
const __DEV__ = NODE_ENV === 'development';
const root = resolve(__dirname, '../..');
const GITHUB_URL = getGitHubURL();
const DEVTOOLS_VERSION = getVersionString();
const config = {
mode: __DEV__ ? 'development' : 'production',
devtool: false,
entry: {
app: './app/index.js',
devtools: './src/devtools.js',
},
resolve: {
alias: {
'react-devtools-inline': resolve(
root,
'packages/react-devtools-inline/src/',
),
src: resolve(root, 'src'),
},
},
plugins: [
new DefinePlugin({
__DEV__,
__TEST__: false,
'process.env.GITHUB_URL': `"${GITHUB_URL}"`,
'process.env.DEVTOOLS_VERSION': `"${DEVTOOLS_VERSION}"`,
}),
],
module: {
rules: [
{
test: /\.js$/,
loader: 'babel-loader',
options: {
configFile: resolve(root, 'babel.config.js'),
},
},
{
test: /\.css$/,
use: [
{
loader: 'style-loader',
},
{
loader: 'css-loader',
options: {
sourceMap: true,
modules: true,
localIdentName: '[local]___[hash:base64:5]',
},
},
],
},
],
},
};
if (TARGET === 'local') {
config.devServer = {
hot: true,
port: 8080,
clientLogLevel: 'warning',
publicPath: '/dist/',
stats: 'errors-only',
};
} else {
config.output = {
path: resolve(__dirname, 'dist'),
filename: '[name].js',
};
}
module.exports = config;