forked from pluginever/wc-serial-numbers
-
Notifications
You must be signed in to change notification settings - Fork 0
/
webpack.config.js
85 lines (82 loc) · 2.58 KB
/
webpack.config.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
const defaultConfig = require('@wordpress/scripts/config/webpack.config');
const RemoveEmptyScriptsPlugin = require('webpack-remove-empty-scripts');
const MiniCSSExtractPlugin = require('mini-css-extract-plugin');
const {CleanWebpackPlugin} = require('clean-webpack-plugin');
const CopyWebpackPlugin = require('copy-webpack-plugin');
const path = require('path');
const isProduction = process.env.NODE_ENV === 'production';
const mode = isProduction ? 'production' : 'development';
module.exports = {
...defaultConfig,
entry: {
'js/admin-script': './assets/js/admin-script.js',
'js/frontend-script': './assets/js/frontend-script.js',
'blocks/blocks': './assets/blocks/index.js',
'css/admin-style': './assets/css/admin-style.scss',
'css/frontend-style': './assets/css/frontend-style.scss',
},
output: {
clean: true,
path: path.resolve(__dirname, 'assets/dist'),
chunkFilename: 'chunks/[name].js',
},
performance: {
maxAssetSize: (isProduction ? 100 : 10000) * 1024,
maxEntrypointSize: (isProduction ? 400 : 40000) * 1024,
hints: 'warning',
},
module: {
rules: [
...defaultConfig.module.rules,
{
test: /\.svg$/,
issuer: /\.(j|t)sx?$/,
use: ['@svgr/webpack', 'url-loader'],
type: 'javascript/auto',
},
{
test: /\.svg$/,
issuer: /\.(sc|sa|c)ss$/,
type: 'asset/inline',
},
{
test: /\.(bmp|png|jpe?g|gif)$/i,
type: 'asset/resource',
generator: {
filename: 'images/[name].[hash:8][ext]',
},
},
],
},
plugins: [
...defaultConfig.plugins,
// During rebuilds, all webpack assets that are not used anymore will be
// removed automatically. There is an exception added in watch mode for
// fonts and images. It is a known limitations:
// https://github.com/johnagan/clean-webpack-plugin/issues/159
new CleanWebpackPlugin({
cleanAfterEveryBuildPatterns: ['!fonts/**', '!images/**'],
// Prevent it from deleting webpack assets during builds that have
// multiple configurations returned to the webpack config.
cleanStaleWebpackAssets: false,
}),
// Copy images to the build folder.
new CopyWebpackPlugin({
patterns: [
{
from: path.resolve(__dirname, 'assets/images'),
to: path.resolve(__dirname, 'assets/dist/images'),
}
]
}),
// MiniCSSExtractPlugin to extract the CSS that's gets imported into JavaScript.
new MiniCSSExtractPlugin({
//esModule: false,
filename: '[name].css',
chunkFilename: '[id].css',
}),
// WP_NO_EXTERNALS global variable controls whether scripts' assets get
// generated, and the default externals set.
new RemoveEmptyScriptsPlugin(),
],
};