2
0

webpack.config.js 9.0 KB

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