oliverdavies.uk/webpack.config.js

49 lines
1.2 KiB
JavaScript
Raw Normal View History

2018-01-05 22:08:06 +00:00
var Encore = require('@symfony/webpack-encore');
2018-01-16 08:14:20 +00:00
var tailwindcss = require('tailwindcss');
var glob = require('glob-all');
var path = require('path');
var PurgecssPlugin = require('purgecss-webpack-plugin');
/**
* Custom PurgeCSS Extractor
* https://github.com/FullHuman/purgecss
* https://github.com/FullHuman/purgecss-webpack-plugin
*/
class TailwindExtractor {
static extract(content) {
return content.match(/[A-z0-9-:\/]+/g);
}
}
2018-01-05 22:08:06 +00:00
Encore
2018-01-16 08:14:20 +00:00
.cleanupOutputBeforeBuild()
2018-01-05 22:08:06 +00:00
.setOutputPath('source/build/')
.setPublicPath('/build')
.enableLessLoader()
.addEntry('js/site', './assets/js/main.js')
.addStyleEntry('css/site', './assets/less/main.less')
.enablePostCssLoader(function(options) {
options.config = {
2018-01-16 08:14:20 +00:00
path: 'postcss.config.js'
2018-01-05 22:08:06 +00:00
};
})
.enableSourceMaps(!Encore.isProduction())
;
2018-01-16 08:14:20 +00:00
// PurgeCSS
Encore.addPlugin(
new PurgecssPlugin({
paths: glob.sync([
path.join(__dirname, "source/**/*.{twig,html,md}")
]),
extractors: [
{
extractor: TailwindExtractor,
extensions: ['twig', 'html', 'md']
}
]
})
);
2018-01-05 22:08:06 +00:00
module.exports = Encore.getWebpackConfig();