PascalAOMS
1/24/2017 - 4:54 PM

webpack.config.js

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)
}