mirror of
https://github.com/AdguardTeam/AdGuardHome.git
synced 2025-01-09 23:47:23 +03:00
114 lines
3.8 KiB
JavaScript
114 lines
3.8 KiB
JavaScript
|
const history = require('connect-history-api-fallback');
|
||
|
const { merge } = require('webpack-merge');
|
||
|
const path = require('path');
|
||
|
const proxy = require('http-proxy-middleware');
|
||
|
const Webpack = require('webpack');
|
||
|
|
||
|
const { getDevServerConfig } = require('./helpers');
|
||
|
const baseConfig = require('./webpack.config.base');
|
||
|
|
||
|
const target = getDevServerConfig();
|
||
|
|
||
|
const options = {
|
||
|
target: `http://${target.host}:${target.port}`, // target host
|
||
|
changeOrigin: true, // needed for virtual hosted sites
|
||
|
};
|
||
|
const apiProxy = proxy.createProxyMiddleware(options);
|
||
|
|
||
|
module.exports = merge(baseConfig, {
|
||
|
mode: 'development',
|
||
|
output: {
|
||
|
path: path.resolve(__dirname, '../../build2'),
|
||
|
filename: '[name].bundle.js',
|
||
|
},
|
||
|
optimization: {
|
||
|
noEmitOnErrors: true,
|
||
|
},
|
||
|
devServer: {
|
||
|
port: 4000,
|
||
|
historyApiFallback: true,
|
||
|
before: (app) => {
|
||
|
app.use('/control', apiProxy);
|
||
|
app.use(history({
|
||
|
rewrites: [
|
||
|
{
|
||
|
from: /\.(png|jpe?g|gif)$/,
|
||
|
to: (context) => {
|
||
|
const name = context.parsedUrl.pathname.split('/');
|
||
|
return `/images/${name[name.length - 1]}`
|
||
|
}
|
||
|
}, {
|
||
|
from: /\.(woff|woff2)$/,
|
||
|
to: (context) => {
|
||
|
const name = context.parsedUrl.pathname.split('/');
|
||
|
return `/${name[name.length - 1]}`
|
||
|
}
|
||
|
}, {
|
||
|
from: /\.(js|css)$/,
|
||
|
to: (context) => {
|
||
|
const name = context.parsedUrl.pathname.split('/');
|
||
|
return `/${name[name.length - 1]}`
|
||
|
}
|
||
|
}
|
||
|
],
|
||
|
}));
|
||
|
}
|
||
|
},
|
||
|
devtool: 'eval-source-map',
|
||
|
module: {
|
||
|
rules: [
|
||
|
{
|
||
|
enforce: 'pre',
|
||
|
test: /\.tsx?$/,
|
||
|
exclude: /node_modules/,
|
||
|
loader: 'eslint-loader',
|
||
|
options: {
|
||
|
configFile: path.resolve(__dirname, '../lint/dev.js'),
|
||
|
}
|
||
|
},
|
||
|
{
|
||
|
test: (resource) => {
|
||
|
return (
|
||
|
resource.indexOf('.pcss')+1
|
||
|
|| resource.indexOf('.css')+1
|
||
|
|| resource.indexOf('.less')+1
|
||
|
) && !(resource.indexOf('.module.')+1);
|
||
|
},
|
||
|
use: ['style-loader', 'css-loader', 'postcss-loader', {
|
||
|
loader: 'less-loader',
|
||
|
options: {
|
||
|
javascriptEnabled: true,
|
||
|
},
|
||
|
}],
|
||
|
},
|
||
|
{
|
||
|
test: /\.module\.p?css$/,
|
||
|
use: [
|
||
|
'style-loader',
|
||
|
{
|
||
|
loader: 'css-loader',
|
||
|
options: {
|
||
|
modules: true,
|
||
|
sourceMap: true,
|
||
|
importLoaders: 1,
|
||
|
modules: {
|
||
|
localIdentName: "[name]__[local]___[hash:base64:5]",
|
||
|
}
|
||
|
},
|
||
|
},
|
||
|
'postcss-loader',
|
||
|
],
|
||
|
exclude: /node_modules/,
|
||
|
},
|
||
|
]
|
||
|
},
|
||
|
plugins: [
|
||
|
new Webpack.DefinePlugin({
|
||
|
DEV: true,
|
||
|
'process.env.DEV_SERVER_PORT': JSON.stringify(3000),
|
||
|
}),
|
||
|
new Webpack.HotModuleReplacementPlugin(),
|
||
|
new Webpack.ProgressPlugin(),
|
||
|
],
|
||
|
});
|