100 lines
3.0 KiB
JavaScript
100 lines
3.0 KiB
JavaScript
const path = require('path');
|
|
const HtmlWebpackPlugin = require('html-webpack-plugin');
|
|
const webpack = require('webpack');
|
|
|
|
module.exports = {
|
|
devtool: 'source-map',
|
|
// entry: './src/index.js',
|
|
entry: {
|
|
main: './src/index.js',
|
|
subscriber: './src/subscriber.js',
|
|
bus_monitor: './src/bus_monitor.js',
|
|
esc_panel: './src/esc_panel.js',
|
|
actuator_panel: './src/actuator_panel.js',
|
|
},
|
|
output: {
|
|
filename: '[name].bundle.js',
|
|
path: path.resolve(__dirname, 'dist')
|
|
},
|
|
module: {
|
|
rules: [
|
|
{
|
|
test: /\.(js|jsx)$/,
|
|
exclude: /node_modules/,
|
|
use: {
|
|
loader: 'babel-loader',
|
|
options: {
|
|
presets: ['@babel/preset-env', '@babel/preset-react'],
|
|
},
|
|
},
|
|
},
|
|
{
|
|
test: /\.css$/,
|
|
use: ['style-loader', 'css-loader'],
|
|
},
|
|
{
|
|
test: /\.(png|jpg|gif)$/,
|
|
use: [
|
|
{
|
|
loader: 'file-loader',
|
|
options: {
|
|
name: '[path][name].[ext]',
|
|
},
|
|
},
|
|
],
|
|
},
|
|
],
|
|
},
|
|
resolve: {
|
|
extensions: ['.js', '.jsx'],
|
|
fallback: {
|
|
"util": require.resolve("util/"),
|
|
"buffer": require.resolve("buffer/"),
|
|
"underscore": require.resolve("underscore/modules/index.js"),
|
|
"crypto": require.resolve("crypto-browserify"),
|
|
"long": require.resolve("long"),
|
|
"vm": require.resolve("vm-browserify"),
|
|
"stream": require.resolve("stream-browserify"),
|
|
"process": require.resolve("process/browser")
|
|
},
|
|
},
|
|
plugins: [
|
|
new HtmlWebpackPlugin({
|
|
template: './public/index.html',
|
|
filename: 'index.html',
|
|
chunks: ['main']
|
|
}),
|
|
new HtmlWebpackPlugin({
|
|
template: './public/subscriber.html',
|
|
filename: 'subscriber.html',
|
|
chunks: ['subscriber']
|
|
}),
|
|
new HtmlWebpackPlugin({
|
|
template: './public/bus_monitor.html',
|
|
filename: 'bus_monitor.html',
|
|
chunks: ['bus_monitor']
|
|
}),
|
|
new HtmlWebpackPlugin({
|
|
template: './public/esc_panel.html',
|
|
filename: 'esc_panel.html',
|
|
chunks: ['esc_panel']
|
|
}),
|
|
new HtmlWebpackPlugin({
|
|
template: './public/actuator_panel.html',
|
|
filename: 'actuator_panel.html',
|
|
chunks: ['actuator_panel']
|
|
}),
|
|
new webpack.ProvidePlugin({
|
|
process: 'process/browser',
|
|
util: 'util',
|
|
Buffer: ['buffer', 'Buffer'],
|
|
}),
|
|
],
|
|
devServer: {
|
|
static: {
|
|
directory: path.join(__dirname, 'dist'),
|
|
},
|
|
compress: true,
|
|
port: 8080,
|
|
},
|
|
}; |