Skip to content

Instantly share code, notes, and snippets.

@PascalAOMS
Created January 24, 2017 16:54
Show Gist options
  • Save PascalAOMS/a861a98e2381b0909c6cde56775ec3a7 to your computer and use it in GitHub Desktop.
Save PascalAOMS/a861a98e2381b0909c6cde56775ec3a7 to your computer and use it in GitHub Desktop.
const path = require('path')
const webpack = require('webpack')
const process = require('process')
const merge = require('webpack-merge');
const NotifierPlugin = require('webpack-notifier')
const WriteFilePlugin = require('write-file-webpack-plugin')
const app = require('./project.config').app
const wp = require('./project.config').wp
const ENV = process.env.NODE_ENV
////////////////////////////////////////////////////////////////
// DEVELOPMENT
let commonDev = {
entry: {
main: ['./src/js/main.js']
},
output: {
filename: '[name].js',
chunkFilename: '[name].js',
path: path.join(__dirname, 'build/js'),
publicPath: '/js/'
},
resolve: {
alias: {
'vue$': 'vue/dist/vue.js',
'assets': path.join(__dirname, 'build/assets'),
}
},
devtool: 'eval-source-map',
module: {
rules: [{
test: /\.js$/,
exclude: /node_modules|vue\/src|vue-router\//,
loader: 'babel',
},
{
test: /\.svg/,
loader: 'svg-url-loader'
},
{
test: /\.(png|jpe?g|gif)(\?.*)?$/,
loader: 'url',
options: { limit: 10000, name: 'assets/img/[name].[ext]' }
},
{
test: /\.vue$/,
loader: 'vue-loader'
}]
},
plugins: [
new WriteFilePlugin({ test: /(^\w*)(\.\w{3})?(\.js$)/, log: false } ),
new webpack.NoErrorsPlugin(),
new NotifierPlugin({
contentImage: ''
}),
new webpack.optimize.CommonsChunkPlugin({
name: 'vendor',
minChunks: ({ resource }) => /node_modules/.test(resource)
})
]
}
////////////////////////////////
if( wp || app ) {
commonDev.plugins.push(
new webpack.optimize.CommonsChunkPlugin({
name: 'manifest',
chunks: ['vendor']
})
)
}
////////////////////////////////
if( app && ENV !== 'production' ) {
module.exports = merge(commonDev, {
entry: {
main: ['webpack/hot/dev-server', 'webpack-hot-middleware/client']
},
plugins: [
new webpack.HotModuleReplacementPlugin(),
]
})
}
else if( ENV !== 'production' ) module.exports = commonDev
////////////////////////////////////////////////////////////////
// PRODUCTION
let output =
wp || app ? {
filename: '[name].[chunkhash:3].js',
chunkFilename: '[name].[chunkhash:3].js',
path: path.join(__dirname, 'build/js'),
}
: {
filename: '[name].js',
path: path.join(__dirname, 'build/js')
}
////////////////////////////////
const commonProduction = {
output,
devtool: 'source-map',
plugins: [
new webpack.DefinePlugin({
'process.env': {
NODE_ENV: '"production"'
}
}),
new webpack.optimize.UglifyJsPlugin({
drop_console: true,
compress: { warnings: false },
sourceMap: true
})
]
}
////////////////////////////////
if( ENV === 'production' ) {
module.exports = merge(commonDev, commonProduction)
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment