2020-06-04 00:59:08 -07:00
|
|
|
const webpack = require('webpack');
|
2020-06-23 21:23:29 -07:00
|
|
|
const TerserPlugin = require('terser-webpack-plugin');
|
2020-06-04 00:59:08 -07:00
|
|
|
const path = require('path');
|
|
|
|
const config = require('sapper/config/webpack.js');
|
|
|
|
const pkg = require('./package.json');
|
|
|
|
|
|
|
|
const mode = process.env.NODE_ENV;
|
|
|
|
const dev = mode === 'development';
|
|
|
|
|
|
|
|
const alias = { svelte: path.resolve('node_modules', 'svelte') };
|
|
|
|
const extensions = ['.mjs', '.js', '.json', '.svelte', '.html'];
|
|
|
|
const mainFields = ['svelte', 'module', 'browser', 'main'];
|
|
|
|
|
2020-06-12 00:26:27 -07:00
|
|
|
const onwarn = (warning, handler) => warning.code === 'css-unused-selector' || handler(warning);
|
|
|
|
|
2020-06-04 00:59:08 -07:00
|
|
|
module.exports = {
|
|
|
|
client: {
|
|
|
|
entry: config.client.entry(),
|
|
|
|
output: config.client.output(),
|
|
|
|
resolve: { alias, extensions, mainFields },
|
|
|
|
module: {
|
|
|
|
rules: [
|
2020-06-23 21:23:29 -07:00
|
|
|
{
|
|
|
|
test: /\.(js|mjs|html|svelte)$/,
|
|
|
|
exclude: /(node_modules\/@babel)/,
|
|
|
|
use: {
|
|
|
|
loader: 'babel-loader',
|
|
|
|
options: {
|
|
|
|
presets: [
|
|
|
|
['@babel/preset-env', {
|
2020-08-29 03:17:04 -07:00
|
|
|
targets: '> 0.25%, ie >= 8, not dead'
|
2020-06-23 21:23:29 -07:00
|
|
|
}]
|
|
|
|
],
|
|
|
|
plugins: [
|
|
|
|
'@babel/plugin-syntax-dynamic-import',
|
|
|
|
'@babel/plugin-proposal-object-rest-spread',
|
|
|
|
['@babel/plugin-transform-runtime', {
|
|
|
|
regenerator: true
|
|
|
|
}],
|
|
|
|
],
|
|
|
|
sourceType: 'unambiguous'
|
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
2020-06-04 00:59:08 -07:00
|
|
|
{
|
|
|
|
test: /\.(svelte|html)$/,
|
|
|
|
use: {
|
|
|
|
loader: 'svelte-loader',
|
|
|
|
options: {
|
|
|
|
dev,
|
2020-06-23 21:23:29 -07:00
|
|
|
hydratable: true,
|
2020-06-12 00:26:27 -07:00
|
|
|
hotReload: true,
|
|
|
|
onwarn
|
2020-06-04 00:59:08 -07:00
|
|
|
}
|
|
|
|
}
|
2020-08-28 23:12:24 -07:00
|
|
|
}
|
2020-06-04 00:59:08 -07:00
|
|
|
]
|
|
|
|
},
|
|
|
|
mode,
|
|
|
|
plugins: [
|
|
|
|
// pending https://github.com/sveltejs/svelte/issues/2377
|
|
|
|
// dev && new webpack.HotModuleReplacementPlugin(),
|
|
|
|
new webpack.DefinePlugin({
|
|
|
|
'process.browser': true,
|
|
|
|
'process.env.NODE_ENV': JSON.stringify(mode)
|
|
|
|
}),
|
|
|
|
].filter(Boolean),
|
2020-06-23 21:23:29 -07:00
|
|
|
devtool: dev && 'inline-source-map',
|
|
|
|
optimization: {
|
|
|
|
minimize: true,
|
|
|
|
minimizer: [new TerserPlugin()],
|
|
|
|
},
|
2020-06-04 00:59:08 -07:00
|
|
|
},
|
|
|
|
|
|
|
|
server: {
|
|
|
|
entry: config.server.entry(),
|
|
|
|
output: config.server.output(),
|
|
|
|
target: 'node',
|
|
|
|
resolve: { alias, extensions, mainFields },
|
|
|
|
externals: Object.keys(pkg.dependencies).concat('encoding'),
|
|
|
|
module: {
|
|
|
|
rules: [
|
|
|
|
{
|
|
|
|
test: /\.(svelte|html)$/,
|
|
|
|
use: {
|
|
|
|
loader: 'svelte-loader',
|
|
|
|
options: {
|
|
|
|
css: false,
|
|
|
|
generate: 'ssr',
|
2020-06-12 00:26:27 -07:00
|
|
|
dev,
|
|
|
|
onwarn
|
2020-06-04 00:59:08 -07:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
]
|
|
|
|
},
|
|
|
|
mode: process.env.NODE_ENV,
|
|
|
|
performance: {
|
|
|
|
hints: false // it doesn't matter if server.js is large
|
2020-06-11 10:51:09 -07:00
|
|
|
},
|
2020-06-04 00:59:08 -07:00
|
|
|
},
|
|
|
|
|
|
|
|
serviceworker: {
|
|
|
|
entry: config.serviceworker.entry(),
|
|
|
|
output: config.serviceworker.output(),
|
|
|
|
mode: process.env.NODE_ENV
|
|
|
|
}
|
|
|
|
};
|