webpack.prod.js 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102
  1. /**
  2. * @author: Yuki Takei <yuki@weseek.co.jp>
  3. */
  4. const helpers = require('./helpers');
  5. const webpackMerge = require('webpack-merge'); // used to merge webpack configs
  6. const commonConfig = require('./webpack.common.js'); // the settings that are common to prod and dev
  7. /**
  8. * Webpack Plugins
  9. */
  10. const ExtractTextPlugin = require('extract-text-webpack-plugin');
  11. const IgnorePlugin = require('webpack/lib/IgnorePlugin');
  12. const UglifyJsPlugin = require('webpack/lib/optimize/UglifyJsPlugin');
  13. const OptimizeJsPlugin = require('optimize-js-plugin');
  14. /**
  15. * Webpack Constants
  16. */
  17. const ENV = process.env.NODE_ENV = process.env.ENV = 'production';
  18. const HOST = process.env.HOST || 'localhost';
  19. const PORT = process.env.PORT || 3000;
  20. module.exports = function (env) {
  21. return webpackMerge(commonConfig({ env: ENV }), {
  22. devtool: 'source-map',
  23. output: {
  24. path: helpers.root('public/js'),
  25. filename: '[name].[chunkhash].bundle.js',
  26. sourceMapFilename: '[name].[chunkhash].bundle.map',
  27. chunkFilename: '[id].[chunkhash].chunk.js'
  28. },
  29. module: {
  30. rules: [
  31. /*
  32. * to string and css loader support for *.css files (from Angular components)
  33. * Returns file content as string
  34. */
  35. {
  36. test: /\.css$/,
  37. use: ['to-string-loader', 'css-loader'],
  38. include: [helpers.root('resource')]
  39. },
  40. /*
  41. * to string and sass loader support for *.scss files (from Angular components)
  42. * Returns compiled css content as string
  43. */
  44. {
  45. test: /\.scss$/,
  46. use: ['to-string-loader', 'css-loader', 'sass-loader'],
  47. include: [helpers.root('resource')]
  48. },
  49. ]
  50. },
  51. plugins: [
  52. new OptimizeJsPlugin({
  53. sourceMap: false
  54. }),
  55. new UglifyJsPlugin({
  56. // beautify: true, //debug
  57. // mangle: false, //debug
  58. // dead_code: false, //debug
  59. // unused: false, //debug
  60. // deadCode: false, //debug
  61. // compress: {
  62. // screw_ie8: true,
  63. // keep_fnames: true,
  64. // drop_debugger: false,
  65. // dead_code: false,
  66. // unused: false
  67. // }, // debug
  68. // comments: true, //debug
  69. beautify: false, //prod
  70. output: {
  71. comments: false
  72. }, //prod
  73. mangle: {
  74. screw_ie8: true
  75. }, //prod
  76. compress: {
  77. screw_ie8: true,
  78. warnings: false,
  79. conditionals: true,
  80. unused: true,
  81. comparisons: true,
  82. sequences: true,
  83. dead_code: true,
  84. evaluate: true,
  85. if_return: true,
  86. join_vars: true,
  87. negate_iife: false // we need this for lazy v8
  88. },
  89. }),
  90. ],
  91. });
  92. }