splatoon2.ink/webpack.config.js
2017-08-02 09:58:58 -07:00

111 lines
3.8 KiB
JavaScript

const path = require('path');
const glob = require('glob');
const CleanWebpackPlugin = require('clean-webpack-plugin');
const ExtractTextPlugin = require('extract-text-webpack-plugin');
const PurifyCSSPlugin = require('purifycss-webpack');
const HtmlWebpackPlugin = require('html-webpack-plugin');
const FaviconsWebpackPlugin = require('favicons-webpack-plugin')
module.exports = function(env) {
const production = (env === 'production');
return {
entry: {
main: [
'./src/js/main.js',
'./src/css/main.scss',
],
},
output: {
path: path.resolve(__dirname, './public'),
filename: 'assets/js/[name].[chunkhash].js',
},
devtool: (production) ? false : 'inline-source-map',
module: {
loaders: [
{
test: /\.js$/,
exclude: /node_modules/,
loader: 'babel-loader'
},
{
test: /\.vue$/,
loader: 'vue-loader',
},
{
test: /\.scss$/,
use: ExtractTextPlugin.extract({
fallback: 'style-loader',
publicPath: '../../',
use: [
{
loader: 'css-loader',
options: { sourceMap: !production },
},
{
loader: 'sass-loader',
options: { sourceMap: !production },
},
],
}),
},
{
test: /\.woff2?$|\.ttf$|\.eot$|\.svg$/,
loader: 'file-loader?name=assets/fonts/[name].[hash].[ext]',
},
{
test: /\.(png|jpe?g|gif)$/,
loader: 'file-loader?name=assets/img/[name].[hash].[ext]',
},
{
test:/^favicon\.ico$/,
loader: 'file-loader?name=favicon.ico',
}
],
},
plugins: [
// Remove old files
new CleanWebpackPlugin([
'public/assets/css/*',
'public/assets/js/*',
]),
// Extract CSS to a separate file
new ExtractTextPlugin('assets/css/[name].[contenthash].css'),
// Remove unused CSS styles
new PurifyCSSPlugin({
paths: [
...glob.sync(path.join(__dirname, 'src/html/*.html')),
...glob.sync(path.join(__dirname, 'src/js/components/*.vue')),
],
minimize: production,
purifyOptions: {
//whitelist: ['.tooltip'],
},
}),
// Favicon
// new FaviconsWebpackPlugin({
// logo: './src/img/1f389.svg',
// prefix: 'assets/icons/[hash:5]/',
// background: '#333',
// icons: {
// 'android': true,
// 'appleIcon': { offset: 15 },
// 'appleStartup': false,
// 'coast': false,
// 'favicons': true,
// 'firefox': false,
// 'windows': true,
// 'yandex': false,
// }
// }),
// Build HTML
new HtmlWebpackPlugin({
filename: 'index.html',
template: 'src/html/index.html',
minify: { collapseWhitespace: true },
}),
],
}
}