2017-08-16 15:20:15 +12:00
|
|
|
const Path = require('path');
|
2021-03-04 17:05:55 +13:00
|
|
|
const dir = require('node-dir');
|
2017-08-16 15:20:15 +12:00
|
|
|
// Import the core config
|
|
|
|
const webpackConfig = require('@silverstripe/webpack-config');
|
2020-12-08 14:56:47 +13:00
|
|
|
const CopyWebpackPlugin = require('copy-webpack-plugin');
|
2017-08-16 15:20:15 +12:00
|
|
|
const {
|
|
|
|
resolveJS,
|
|
|
|
externalJS,
|
|
|
|
moduleJS,
|
|
|
|
pluginJS,
|
|
|
|
moduleCSS,
|
|
|
|
pluginCSS,
|
|
|
|
} = webpackConfig;
|
|
|
|
|
|
|
|
const ENV = process.env.NODE_ENV;
|
|
|
|
const PATHS = {
|
|
|
|
MODULES: 'node_modules',
|
2021-03-04 17:05:55 +13:00
|
|
|
MODULES_ABS: Path.resolve('node_modules'),
|
2017-08-16 15:20:15 +12:00
|
|
|
FILES_PATH: '../',
|
|
|
|
ROOT: Path.resolve(),
|
|
|
|
SRC: Path.resolve('client/src'),
|
|
|
|
DIST: Path.resolve('client/dist'),
|
2021-03-04 17:05:55 +13:00
|
|
|
DIST_JS: Path.resolve('client/dist/js'),
|
2017-08-16 15:20:15 +12:00
|
|
|
THIRDPARTY: Path.resolve('thirdparty'),
|
|
|
|
};
|
|
|
|
|
2021-03-04 17:05:55 +13:00
|
|
|
const copyData = [
|
|
|
|
{
|
|
|
|
from: 'client/src/images',
|
|
|
|
to: 'images'
|
|
|
|
},
|
|
|
|
{
|
|
|
|
from: PATHS.MODULES + '/jquery/dist/jquery.min.js',
|
|
|
|
to: PATHS.DIST_JS
|
|
|
|
},
|
|
|
|
{
|
|
|
|
from: PATHS.MODULES + '/jquery.are-you-sure/jquery.are-you-sure.js',
|
|
|
|
to: PATHS.DIST_JS + '/jquery.are-you-sure/jquery.are-you-sure.js'
|
|
|
|
},
|
|
|
|
];
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Builds a list of files matching the `*.min.js` pattern to copy from a source
|
|
|
|
* directory to a dist directory.
|
|
|
|
*/
|
|
|
|
const addMinFiles = (from, to) => {
|
|
|
|
const sourceDir = PATHS.MODULES_ABS + from;
|
|
|
|
dir.files(sourceDir, (err, files) => {
|
|
|
|
if (err) throw err;
|
|
|
|
files.forEach(file => {
|
|
|
|
filename = file.replace(sourceDir, '');
|
|
|
|
if (!filename.match(/\.min\.js$/)) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
copyData.push({
|
|
|
|
from: PATHS.MODULES + from + filename,
|
|
|
|
to: PATHS.DIST_JS + to + filename
|
|
|
|
})
|
|
|
|
});
|
|
|
|
});
|
|
|
|
};
|
|
|
|
|
|
|
|
addMinFiles('/jquery-validation/dist', '/jquery-validation');
|
|
|
|
|
|
|
|
|
2017-08-16 15:20:15 +12:00
|
|
|
const config = [
|
|
|
|
{
|
|
|
|
name: 'js-frontend',
|
|
|
|
entry: {
|
|
|
|
userforms: `${PATHS.SRC}/bundles/bundle.js`,
|
|
|
|
},
|
|
|
|
output: {
|
|
|
|
path: PATHS.DIST,
|
|
|
|
filename: 'js/[name].js',
|
|
|
|
},
|
|
|
|
devtool: (ENV !== 'production') ? 'source-map' : '',
|
|
|
|
resolve: resolveJS(ENV, PATHS),
|
2017-11-20 15:16:03 +13:00
|
|
|
externals: externalJS(ENV, PATHS),
|
2017-08-16 15:20:15 +12:00
|
|
|
module: moduleJS(ENV, PATHS),
|
|
|
|
plugins: pluginJS(ENV, PATHS),
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: 'js-cms',
|
|
|
|
entry: {
|
|
|
|
'userforms-cms': `${PATHS.SRC}/bundles/bundle-cms.js`,
|
|
|
|
},
|
|
|
|
output: {
|
|
|
|
path: PATHS.DIST,
|
|
|
|
filename: 'js/[name].js',
|
|
|
|
},
|
|
|
|
devtool: (ENV !== 'production') ? 'source-map' : '',
|
|
|
|
resolve: resolveJS(ENV, PATHS),
|
|
|
|
externals: externalJS(ENV, PATHS),
|
|
|
|
module: moduleJS(ENV, PATHS),
|
2020-12-08 14:56:47 +13:00
|
|
|
plugins: pluginJS(ENV, PATHS).concat([
|
2021-03-04 17:05:55 +13:00
|
|
|
new CopyWebpackPlugin(copyData)
|
2020-12-08 14:56:47 +13:00
|
|
|
])
|
2017-08-16 15:20:15 +12:00
|
|
|
},
|
|
|
|
{
|
|
|
|
name: 'css',
|
|
|
|
entry: {
|
2017-08-21 12:13:19 +12:00
|
|
|
userforms: `${PATHS.SRC}/styles/bundle.scss`,
|
|
|
|
'userforms-cms': `${PATHS.SRC}/styles/bundle-cms.scss`,
|
2017-08-16 15:20:15 +12:00
|
|
|
},
|
|
|
|
output: {
|
|
|
|
path: PATHS.DIST,
|
|
|
|
filename: 'styles/[name].css'
|
|
|
|
},
|
|
|
|
devtool: (ENV !== 'production') ? 'source-map' : '',
|
|
|
|
module: moduleCSS(ENV, PATHS),
|
|
|
|
plugins: pluginCSS(ENV, PATHS),
|
|
|
|
},
|
|
|
|
];
|
|
|
|
|
|
|
|
module.exports = config;
|