redux-devtools/packages/redux-devtools-inspector-monitor/demo/config/webpack.config.ts

61 lines
1.5 KiB
TypeScript
Raw Normal View History

import * as path from 'path';
import * as webpack from 'webpack';
import HtmlWebpackPlugin from 'html-webpack-plugin';
import { CleanWebpackPlugin } from 'clean-webpack-plugin';
import ForkTsCheckerWebpackPlugin from 'fork-ts-checker-webpack-plugin';
import pkg from '../../package.json';
const isProduction = process.env.NODE_ENV === 'production';
module.exports = {
2019-01-09 03:06:21 +03:00
mode: process.env.NODE_ENV || 'development',
2019-01-10 21:51:14 +03:00
entry: isProduction
? ['./demo/src/js/index']
: [
'webpack-dev-server/client?http://localhost:3000',
'webpack/hot/only-dev-server',
'./demo/src/js/index',
2019-01-10 21:51:14 +03:00
],
output: {
path: path.join(__dirname, 'demo/dist'),
filename: 'js/bundle.js',
},
module: {
rules: [
{
test: /\.(js|ts)x?$/,
loader: 'babel-loader',
include: [
path.join(__dirname, '../../src'),
path.join(__dirname, '../src/js'),
],
},
],
},
resolve: {
extensions: ['.js', '.jsx', '.ts', '.tsx'],
},
plugins: [
new CleanWebpackPlugin(),
new HtmlWebpackPlugin({
inject: true,
template: 'demo/src/index.html',
package: pkg,
}),
new ForkTsCheckerWebpackPlugin({
typescript: {
configFile: 'demo/tsconfig.json',
},
}),
...(isProduction ? [] : [new webpack.HotModuleReplacementPlugin()]),
],
2019-01-10 21:51:14 +03:00
devServer: isProduction
? {}
2019-01-10 21:51:14 +03:00
: {
port: 3000,
hot: true,
historyApiFallback: true,
},
devtool: 'eval-source-map',
};