webpack.prod.js 2.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960
  1. /* global __dirname, module, process */
  2. const common = require("./webpack.common.js");
  3. const merge = require("webpack-merge");
  4. const path = require('path');
  5. const webpack = require('webpack');
  6. const { CleanWebpackPlugin } = require('clean-webpack-plugin');
  7. const MiniCssExtractPlugin = require('mini-css-extract-plugin');
  8. const CopyWebpackPlugin = require('copy-webpack-plugin');
  9. const ASSET_PATH = process.env.ASSET_PATH || '/dist/'; // eslint-disable-line no-process-env
  10. module.exports = merge(common, {
  11. output: {
  12. publicPath: ASSET_PATH,
  13. filename: 'converse.min.js',
  14. },
  15. plugins: [
  16. new CleanWebpackPlugin({
  17. cleanStaleWebpackAssets: false // resolves conflict with CopyWebpackPlugin
  18. }),
  19. new MiniCssExtractPlugin({filename: '../dist/converse.min.css'}),
  20. new CopyWebpackPlugin([
  21. {from: 'sounds'},
  22. {from: 'images/favicon.ico'},
  23. {from: 'images/custom_emojis', to: 'custom_emojis'},
  24. {from: 'sass/webfonts', to: 'webfonts'}
  25. ]),
  26. new webpack.DefinePlugin({ // This makes it possible for us to safely use env vars on our code
  27. 'process.env.ASSET_PATH': JSON.stringify(ASSET_PATH)
  28. })
  29. ],
  30. mode: "production",
  31. devtool: "source-map",
  32. module: {
  33. rules: [{
  34. test: /\.scss$/,
  35. use: [
  36. MiniCssExtractPlugin.loader,
  37. {
  38. loader: 'css-loader',
  39. options: {
  40. url: false,
  41. sourceMap: true
  42. }
  43. },
  44. 'postcss-loader',
  45. {
  46. loader: 'sass-loader',
  47. options: {
  48. includePaths: [
  49. path.resolve(__dirname, 'node_modules/')
  50. ],
  51. sourceMap: true
  52. }
  53. }
  54. ]
  55. }]
  56. }
  57. });