webpack.common.js 6.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165
  1. /* global __dirname, module, process */
  2. const HTMLWebpackPlugin = require('html-webpack-plugin');
  3. const minimist = require('minimist');
  4. const path = require('path');
  5. const webpack = require('webpack');
  6. const config = {
  7. output: {
  8. path: path.resolve(__dirname, 'dist'), // Output path for generated bundles
  9. publicPath: '/dist/', // URL base path for all assets
  10. chunkFilename: '[name].js'
  11. },
  12. entry: path.resolve(__dirname, 'src/converse.js'),
  13. externals: [{
  14. "window": "window"
  15. }],
  16. watchOptions: {
  17. ignored: [/dist/, /spec/, /.*\~/]
  18. },
  19. module: {
  20. rules: [
  21. {
  22. test: path.resolve(__dirname, "node_modules/backbone.vdomview/backbone.vdomview"),
  23. use: 'imports-loader?backbone.nativeview'
  24. },
  25. {
  26. test: path.resolve(__dirname, "node_modules/xss/dist/xss"),
  27. use: "exports-loader?filterXSS,filterCSS"
  28. },
  29. {
  30. test: /\.(html|svg)$/,
  31. exclude: /node_modules/,
  32. use: [{
  33. loader: 'lodash-template-webpack-loader',
  34. options: {
  35. "escape": /\{\{\{([\s\S]+?)\}\}\}/g,
  36. "evaluate": /\{\[([\s\S]+?)\]\}/g,
  37. "interpolate": /\{\{([\s\S]+?)\}\}/g,
  38. // By default, template places the values from your data in the
  39. // local scope via the with statement. However, you can specify
  40. // a single variable name with the variable setting. This can
  41. // significantly improve the speed at which a template is able
  42. // to render.
  43. "variable": 'o',
  44. "prependFilenameComment": __dirname
  45. }
  46. }]
  47. }, {
  48. test: /LC_MESSAGES\/converse.po$/,
  49. type: "json",
  50. use: [
  51. {
  52. loader: 'po-loader',
  53. options: {
  54. 'format': 'jed',
  55. 'domain': 'converse'
  56. }
  57. }
  58. ]
  59. }, {
  60. test: /webfonts\/.*\.(woff(2)?|ttf|eot|truetype|svg)(\?v=\d+\.\d+\.\d+)?$/,
  61. use: [
  62. {
  63. loader: 'file-loader',
  64. options: {
  65. name: '[name].[ext]',
  66. outputPath: 'webfonts/'
  67. }
  68. }
  69. ]
  70. }, {
  71. test: /\.scss$/,
  72. use: [
  73. 'style-loader',
  74. {
  75. loader: 'css-loader',
  76. options: {
  77. sourceMap: true
  78. }
  79. },
  80. 'postcss-loader',
  81. {
  82. loader: 'sass-loader',
  83. options: {
  84. includePaths: [
  85. path.resolve(__dirname, 'node_modules/'),
  86. ],
  87. sourceMap: true
  88. }
  89. }
  90. ]
  91. }, {
  92. test: /\.js$/,
  93. exclude: /(node_modules|spec|mockup)/,
  94. use: {
  95. loader: 'babel-loader',
  96. options: {
  97. presets: [
  98. ["@babel/preset-env", {
  99. "targets": {
  100. "browsers": [">1%", "not ie 11", "not op_mini all"]
  101. }
  102. }]
  103. ],
  104. plugins: ['@babel/plugin-syntax-dynamic-import']
  105. }
  106. }
  107. }, {
  108. test: /bootstrap\.native/,
  109. use: {
  110. loader: 'bootstrap.native-loader',
  111. options: {
  112. bs_version: 4,
  113. ignore: ['carousel', 'scrollspy']
  114. }
  115. }
  116. }],
  117. },
  118. resolve: {
  119. extensions: ['.js'],
  120. modules: [
  121. 'node_modules',
  122. path.resolve(__dirname, "src")
  123. ],
  124. alias: {
  125. "IPv6": path.resolve(__dirname, "node_modules/urijs/src/IPv6"),
  126. "SecondLevelDomains": path.resolve(__dirname, "node_modules/urijs/src/SecondLevelDomains"),
  127. "formdata-polyfill": path.resolve(__dirname, "node_modules/formdata-polyfill/FormData"),
  128. "jquery": path.resolve(__dirname, "src/jquery-stub"),
  129. "punycode": path.resolve(__dirname, "node_modules/urijs/src/punycode"),
  130. "snabbdom": path.resolve(__dirname, "node_modules/snabbdom/dist/snabbdom"),
  131. "snabbdom-attributes": path.resolve(__dirname, "node_modules/snabbdom/dist/snabbdom-attributes"),
  132. "snabbdom-class": path.resolve(__dirname, "node_modules/snabbdom/dist/snabbdom-class"),
  133. "snabbdom-dataset": path.resolve(__dirname, "node_modules/snabbdom/dist/snabbdom-dataset"),
  134. "snabbdom-eventlisteners": path.resolve(__dirname, "node_modules/snabbdom/dist/snabbdom-eventlisteners"),
  135. "snabbdom-props": path.resolve(__dirname, "node_modules/snabbdom/dist/snabbdom-props"),
  136. "snabbdom-style": path.resolve(__dirname, "node_modules/snabbdom/dist/snabbdom-style"),
  137. "tovnode": path.resolve(__dirname, "node_modules/snabbdom/dist/tovnode"),
  138. "underscore": path.resolve(__dirname, "src/underscore-shim")
  139. }
  140. }
  141. }
  142. function extend (o1, o2) {
  143. for (var i in o2) {
  144. if (Object.prototype.hasOwnProperty.call(o2, i)) {
  145. o1[i] = o2[i];
  146. }
  147. }
  148. }
  149. function parameterize () {
  150. const type = minimist(process.argv.slice(2)).type;
  151. const mode = minimist(process.argv.slice(2)).mode;
  152. const lang = minimist(process.argv.slice(2)).lang;
  153. if (type === 'headless') {
  154. console.log("Making a headless build");
  155. config.entry = "@converse/headless/headless.js";
  156. config.output.filename = 'converse-headless.js';
  157. }
  158. }
  159. parameterize();
  160. module.exports = config;