2
0

webpack.config.js 6.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166
  1. /*global path, __dirname, module, process */
  2. 'use strict'
  3. const minimist = require('minimist');
  4. const path = require('path');
  5. const webpack = require('webpack');
  6. const config = {
  7. entry: path.resolve(__dirname, 'src/converse.js'),
  8. externals: [{
  9. "window": "window"
  10. }],
  11. output: {
  12. path: path.resolve(__dirname, 'dist'),
  13. filename: 'converse.js'
  14. },
  15. devtool: 'source-map',
  16. plugins: [
  17. new webpack.IgnorePlugin(/^\.\/locale$/, /moment$/)
  18. ],
  19. module: {
  20. rules: [
  21. {
  22. test: path.resolve(__dirname, "node_modules/backbone.overview/backbone.orderedlistview"),
  23. use: 'imports-loader?backbone.nativeview'
  24. },
  25. {
  26. test: path.resolve(__dirname, "node_modules/backbone.overview/backbone.overview"),
  27. use: 'imports-loader?backbone.nativeview'
  28. },
  29. {
  30. test: path.resolve(__dirname, "node_modules/backbone.vdomview/backbone.vdomview"),
  31. use: 'imports-loader?backbone.nativeview'
  32. },
  33. {
  34. test: path.resolve(__dirname, "node_modules/awesomplete-avoid-xss/awesomplete"),
  35. use: "exports-loader?Awesomplete"
  36. },
  37. {
  38. test: path.resolve(__dirname, "node_modules/xss/dist/xss"),
  39. use: "exports-loader?filterXSS,filterCSS"
  40. },
  41. {
  42. test: /\.(html|svg)$/,
  43. exclude: /node_modules/,
  44. use: [{
  45. loader: 'lodash-template-webpack-loader',
  46. options: {
  47. "escape": /\{\{\{([\s\S]+?)\}\}\}/g,
  48. "evaluate": /\{\[([\s\S]+?)\]\}/g,
  49. "interpolate": /\{\{([\s\S]+?)\}\}/g,
  50. // By default, template places the values from your data in the
  51. // local scope via the with statement. However, you can specify
  52. // a single variable name with the variable setting. This can
  53. // significantly improve the speed at which a template is able
  54. // to render.
  55. "variable": 'o',
  56. "prependFilenameComment": __dirname
  57. }
  58. }]
  59. }, {
  60. test: /\.js$/,
  61. exclude: /(node_modules|spec|mockup)/,
  62. use: {
  63. loader: 'babel-loader',
  64. options: {
  65. presets: [
  66. ["@babel/preset-env", {
  67. "targets": {
  68. "browsers": [">1%", "not ie 11", "not op_mini all"]
  69. }
  70. }]
  71. ]
  72. }
  73. }
  74. }],
  75. },
  76. resolve: {
  77. extensions: ['.js'],
  78. modules: [
  79. 'node_modules',
  80. path.resolve(__dirname, "src")
  81. ],
  82. alias: {
  83. "IPv6": path.resolve(__dirname, "node_modules/urijs/src/IPv6"),
  84. "SecondLevelDomains": path.resolve(__dirname, "node_modules/urijs/src/SecondLevelDomains"),
  85. "awesomplete": path.resolve(__dirname, "node_modules/awesomplete-avoid-xss/awesomplete"),
  86. "bootstrap": path.resolve(__dirname, "node_modules/bootstrap.native/dist/bootstrap-native-v4"),
  87. "formdata-polyfill": path.resolve(__dirname, "node_modules/formdata-polyfill/FormData"),
  88. "jquery": path.resolve(__dirname, "src/jquery-stub"),
  89. "pluggable": path.resolve(__dirname, "node_modules/pluggable.js/dist/pluggable"),
  90. "punycode": path.resolve(__dirname, "node_modules/urijs/src/punycode"),
  91. "snabbdom": path.resolve(__dirname, "node_modules/snabbdom/dist/snabbdom"),
  92. "snabbdom-attributes": path.resolve(__dirname, "node_modules/snabbdom/dist/snabbdom-attributes"),
  93. "snabbdom-class": path.resolve(__dirname, "node_modules/snabbdom/dist/snabbdom-class"),
  94. "snabbdom-dataset": path.resolve(__dirname, "node_modules/snabbdom/dist/snabbdom-dataset"),
  95. "snabbdom-eventlisteners": path.resolve(__dirname, "node_modules/snabbdom/dist/snabbdom-eventlisteners"),
  96. "snabbdom-props": path.resolve(__dirname, "node_modules/snabbdom/dist/snabbdom-props"),
  97. "snabbdom-style": path.resolve(__dirname, "node_modules/snabbdom/dist/snabbdom-style"),
  98. "tovnode": path.resolve(__dirname, "node_modules/snabbdom/dist/tovnode"),
  99. "underscore": path.resolve(__dirname, "src/underscore-shim"),
  100. "uri": path.resolve(__dirname, "node_modules/urijs/src/URI"),
  101. "vdom-parser": path.resolve(__dirname, "node_modules/vdom-parser/dist"),
  102. "xss": path.resolve(__dirname, "node_modules/xss/dist/xss")
  103. }
  104. }
  105. }
  106. function extend (o1, o2) {
  107. for (var i in o2) {
  108. if (Object.prototype.hasOwnProperty.call(o2, i)) {
  109. o1[i] = o2[i];
  110. }
  111. }
  112. }
  113. function parameterize () {
  114. const type = minimist(process.argv.slice(2)).type;
  115. const mode = minimist(process.argv.slice(2)).mode;
  116. const lang = minimist(process.argv.slice(2)).lang;
  117. if (type === 'headless') {
  118. console.log("Making a headless build");
  119. extend(config, {
  120. entry: "@converse/headless/headless.js",
  121. output: {
  122. path: path.resolve(__dirname, 'dist'),
  123. filename: 'converse-headless.js'
  124. },
  125. });
  126. }
  127. if (type === 'nodeps') {
  128. console.log("Making a build without 3rd party dependencies");
  129. extend(config, {
  130. entry: path.resolve(__dirname, 'src/converse.js'),
  131. externals: [{
  132. "awesomplete": "awesomplete",
  133. "backbone.browserStorage": "backbone.browserStorage",
  134. "backbone.overview": "backbone.overview",
  135. "es6-promise": "es6-promise",
  136. "lodash": "lodash",
  137. "lodash.converter": "lodash.converter",
  138. "lodash.noconflict": "lodash.noconflict",
  139. "moment": "moment",
  140. "strophe": "strophe",
  141. "strophe.ping": "strophe.ping",
  142. "strophe.rsm": "strophe.rsm",
  143. "window": "window"
  144. }],
  145. output: {
  146. path: path.resolve(__dirname, 'dist'),
  147. filename: 'converse-no-dependencies.js'
  148. },
  149. });
  150. }
  151. if (mode === 'production') {
  152. console.log("Making a production build");
  153. const fn = config.output.filename;
  154. config.output.filename = `${fn.replace(/\.js$/, '')}.min.js`;
  155. }
  156. }
  157. parameterize();
  158. module.exports = config;