init for release
This commit is contained in:
100
webpack.config.js
Normal file
100
webpack.config.js
Normal file
@@ -0,0 +1,100 @@
|
||||
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,
|
||||
},
|
||||
};
|
||||
Reference in New Issue
Block a user