-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathwebpack.config.js
executable file
·88 lines (86 loc) · 2.49 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
86
87
88
const webpack = require( 'webpack' )
const path = require( 'path' )
const MiniCssExtractPlugin = require( "mini-css-extract-plugin" )
const CssMinimizerPlugin = require( "css-minimizer-webpack-plugin" )
const TerserWebpackPlugin = require( "terser-webpack-plugin" )
const BrowserSyncPlugin = require( "browser-sync-webpack-plugin" )
const THEME = require( './wp-theme-meta.json' )
const wpThemeBanner =
'/**\n' +
' * Theme Name: ' + THEME.themeName + '\n' +
' * Theme URI: ' + THEME.themeUri + '\n' +
' * Author: ' + THEME.author + '\n' +
' * Author URI: ' + THEME.authorUri + '\n' +
' * Description: ' + THEME.description + '\n' +
' * Tags: ' + THEME.tags + '\n' +
' * Version: ' + THEME.version + '\n' +
' * Requires at least: ' + THEME.requiresAtLeast + '\n' +
' * Tested up to: ' + THEME.testedUpTo + '\n' +
' * Requires PHP: ' + THEME.requiresPhp + '\n' +
' * License: ' + THEME.license + '\n' +
' * License URI: ' + THEME.licenseUri + '\n' +
' * Text Domain: ' + THEME.textDomain + '\n' +
' */'
module.exports = {
cache: false,
stats: {
// all: true,
},
devtool: "source-map",
entry: {
bundle: './src/js/frontend.js',
style: './src/css/style.js',
'style-admin': './src/css/style-admin.js',
},
output: {
filename: '[name].js', // js output filename.
path: path.resolve( __dirname, 'js' ), // js output dir.
},
optimization: {
minimizer: [
new CssMinimizerPlugin(),
new TerserWebpackPlugin()
],
minimize: false
},
plugins: [
new MiniCssExtractPlugin( {
filename: "../[name].css", // css output relative to 'output' path.
} ),
new webpack.BannerPlugin( {
banner: wpThemeBanner, // the banner as string.
raw: true, // if true, banner will not be wrapped in a comment.
entryOnly: true,
include: /style\.(css|scss)$/
} ),
new BrowserSyncPlugin ( {
files: [
'**/*.php',
'./js/*.(js|jsx)',
'./style.css',
'!./node_modules',
'!./vendor*',
'!./dist',
'!./src',
'!./webpack.config.js',
'!./webpack.zip.config.js',
'!./package.json',
'!./package-lock.json',
'!./composer.json',
'!./composer.lock'
],
proxy: 'localhost:8001', // Live WordPress site. WordPress site URL must be set to 'localhost:port'.
ui: { port: 3001 }, // BrowserSync UI.
port: 3000, // browse to http://localhost:3000/ during development.
logLevel: "debug"
} )
],
module: {
rules: [
{
test: /\.(css|scss)$/,
use: [ MiniCssExtractPlugin.loader, 'css-loader', 'sass-loader' ]
},
],
},
}