webpack.common.js 6.7 KB

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