webpack.prod.js 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119
  1. /**
  2. * @author: Yuki Takei <yuki@weseek.co.jp>
  3. */
  4. const helpers = require('./helpers');
  5. const webpack = require('webpack');
  6. const webpackMerge = require('webpack-merge'); // used to merge webpack configs
  7. const commonConfig = require('./webpack.common.js'); // the settings that are common to prod and dev
  8. /**
  9. * Webpack Plugins
  10. */
  11. const ExtractTextPlugin = require('extract-text-webpack-plugin');
  12. const UglifyJsPlugin = require('webpack/lib/optimize/UglifyJsPlugin');
  13. const OptimizeJsPlugin = require('optimize-js-plugin');
  14. const BundleAnalyzerPlugin = require('webpack-bundle-analyzer').BundleAnalyzerPlugin;
  15. /**
  16. * Webpack Constants
  17. */
  18. const ANALYZE = process.env.ANALYZE;
  19. const ENV = process.env.NODE_ENV = process.env.ENV = 'production';
  20. module.exports = function(env) {
  21. return webpackMerge(commonConfig({ env: ENV }), {
  22. devtool: undefined,
  23. output: {
  24. path: helpers.root('public/js'),
  25. publicPath: '/js/',
  26. filename: '[name].[chunkhash].bundle.js',
  27. sourceMapFilename: '[name].[chunkhash].bundle.map',
  28. chunkFilename: '[id].[chunkhash].chunk.js'
  29. },
  30. module: {
  31. rules: [
  32. {
  33. test: /\.scss$/,
  34. use: ExtractTextPlugin.extract({
  35. fallback: 'style-loader',
  36. use: [
  37. { loader: 'css-loader', options: {
  38. sourceMap: false,
  39. minimize: true
  40. } },
  41. { loader: 'postcss-loader', options: {
  42. sourceMap: false,
  43. plugins: (loader) => [
  44. require('autoprefixer')()
  45. ]
  46. } },
  47. { loader: 'sass-loader', options: { sourceMap: false } }
  48. ]
  49. }),
  50. include: [helpers.root('resource/styles/scss')]
  51. }
  52. ]
  53. },
  54. plugins: [
  55. new webpack.DefinePlugin({
  56. 'process.env': {
  57. NODE_ENV: JSON.stringify(ENV),
  58. }
  59. }),
  60. new ExtractTextPlugin('[name].[contenthash].css'),
  61. new OptimizeJsPlugin({
  62. sourceMap: false
  63. }),
  64. new UglifyJsPlugin({
  65. // beautify: true, //debug
  66. // mangle: false, //debug
  67. // dead_code: false, //debug
  68. // unused: false, //debug
  69. // deadCode: false, //debug
  70. // compress: {
  71. // screw_ie8: true,
  72. // keep_fnames: true,
  73. // drop_debugger: false,
  74. // dead_code: false,
  75. // unused: false
  76. // }, // debug
  77. // comments: true, //debug
  78. beautify: false, //prod
  79. output: {
  80. comments: false
  81. }, //prod
  82. mangle: {
  83. screw_ie8: true
  84. }, //prod
  85. compress: {
  86. screw_ie8: true,
  87. warnings: false,
  88. conditionals: true,
  89. unused: true,
  90. comparisons: true,
  91. sequences: true,
  92. dead_code: true,
  93. evaluate: true,
  94. if_return: true,
  95. join_vars: true,
  96. negate_iife: false // we need this for lazy v8
  97. },
  98. }),
  99. new BundleAnalyzerPlugin({
  100. analyzerMode: ANALYZE ? 'static' : 'disabled',
  101. reportFilename: helpers.root('report/bundle-analyzer.html'),
  102. openAnalyzer: false,
  103. }),
  104. ],
  105. });
  106. };