-
Notifications
You must be signed in to change notification settings - Fork 2
/
webpack.config.js
77 lines (73 loc) · 1.99 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
const defaultConfig = require( '@wordpress/scripts/config/webpack.config' );
const path = require( 'path' );
const { spawn } = require( 'child_process' );
// const BundleAnalyzerPlugin = require('webpack-bundle-analyzer').BundleAnalyzerPlugin;
class UAGBRunAdditionalProcess {
apply( compiler ) {
compiler.hooks.afterEmit.tapAsync( 'UAGBRunAdditionalProcess', ( compilation, callback ) => {
spawn(
/^win/.test( process.platform ) ? 'npm-run-all.cmd' : 'npm-run-all',
[ '--sequential', 'build:sass', 'build:placeholder' ],
{ stdio: 'inherit' }
);
callback();
} );
}
}
const wp_rules = defaultConfig.module.rules.filter( function ( item ) {
if ( String( item.test ) === String( /\.jsx?$/ ) ) {
return true;
}
if ( String( item.test ) === String( /\.(sc|sa)ss$/ ) ) {
item.exclude = [ /node_modules/, /editor/ ];
return true;
}
return false;
} );
module.exports = {
...defaultConfig,
plugins: [
...defaultConfig.plugins,
// new BundleAnalyzerPlugin,
new UAGBRunAdditionalProcess(),
],
entry: {
blocks: path.resolve( __dirname, 'src/blocks.js' ),
},
resolve: {
alias: {
...defaultConfig.resolve.alias,
'@Controls': path.resolve( __dirname, 'blocks-config/uagb-controls/' ),
'@Components': path.resolve( __dirname, 'src/components/' ),
'@Utils': path.resolve( __dirname, 'blocks-config/utils/' ),
'@Blocks': path.resolve( __dirname, 'src/blocks/' ),
'@Attributes': path.resolve( __dirname, 'blocks-config/blocks-attributes/' ),
'@Store': path.resolve( __dirname, 'src/store/' ),
},
},
module: {
rules: [
...wp_rules,
{
test: /\.(scss|css)$/,
exclude: [ /node_modules/, /style/ ],
use: [
{
loader: 'style-loader',
options: {
injectType: 'lazySingletonStyleTag',
attributes: { id: 'uagb-editor-styles' },
},
},
'css-loader',
'sass-loader',
],
},
],
},
output: {
...defaultConfig.output,
// eslint-disable-next-line no-undef
path: path.resolve( __dirname, 'dist' ),
},
};