-
Notifications
You must be signed in to change notification settings - Fork 9
/
webpack.config.js
79 lines (73 loc) · 2.1 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
/**
* WebPack Configuration for CAWeb Theme
*
* @link https://webpack.js.org/configuration/
*/
const fs = require('fs'); // File System
const path = require('path'); // File System
const MiniCssExtractPlugin = require("mini-css-extract-plugin");
let entries = {
'caweb-core':[
'./src/styles/frontend.scss',
'./src/scripts/google/',
'./src/scripts/custom/',
'./src/scripts/a11y/'
],
'caweb-admin':[
'./src/styles/admin/index.scss',
'./src/scripts/admin/',
],
'caweb-customizer': [
'./src/scripts/wp/theme-customizer/bindings/',
],
'caweb-customizer-controls': [
'./src/scripts/wp/theme-customizer/controls/',
]
};
fs.readdirSync('./src/').filter(file => file.toString().startsWith('version-') ).forEach((version) => {
var ver = version.substring(version.indexOf('-') + 1);
// add entries for each colorscheme
fs.readdirSync(`./src/${version}/colorscheme` ).forEach( (color) => {
var scheme = color.substring(0, color.indexOf('.')).replace(' ', '');
entries[`${scheme}-${ver}`] = [
`./src/${version}/cagov.core.css`,
`./src/${version}/colorscheme/${color}`,
//`./src/${version}/cagov.core.js`,
]
})
})
module.exports = {
mode: 'none',
plugins: [new MiniCssExtractPlugin({
linkType: "text/css",
})],
entry: entries,
output: {
path: path.resolve( process.cwd(), 'build' ),
clean: true
},
module:{
rules: [
{
test: /\.[s]?css$/i,
use: [
MiniCssExtractPlugin.loader,
//'style-loader', // Adds CSS to the DOM by injecting a `<style>` tag
'css-loader', // Interprets `@import` and `url()` like `import/require()` and will resolve them
{
// Loader for webpack to process CSS with PostCSS
loader: 'postcss-loader',
options: {
postcssOptions: {
plugins: () => [
autoprefixer
]
}
}
},
'sass-loader', // Loads a SASS/SCSS file and compiles it to CSS
]
}
],
}
}