webpack.config.js 7.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203
  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 MiniCssExtractPlugin = require('mini-css-extract-plugin');
  7. const config = {
  8. entry: path.resolve(__dirname, 'src/converse.js'),
  9. externals: [{
  10. "window": "window"
  11. }],
  12. output: {
  13. path: path.resolve(__dirname, 'dist'),
  14. filename: 'converse.js'
  15. },
  16. devtool: 'source-map',
  17. plugins: [
  18. new MiniCssExtractPlugin({filename: '../css/converse.css'}),
  19. new webpack.IgnorePlugin(/^\.\/locale$/, /moment$/)
  20. ],
  21. module: {
  22. rules: [
  23. {
  24. test: path.resolve(__dirname, "node_modules/backbone.overview/backbone.orderedlistview"),
  25. use: 'imports-loader?backbone.nativeview'
  26. },
  27. {
  28. test: path.resolve(__dirname, "node_modules/backbone.overview/backbone.overview"),
  29. use: 'imports-loader?backbone.nativeview'
  30. },
  31. {
  32. test: path.resolve(__dirname, "node_modules/backbone.vdomview/backbone.vdomview"),
  33. use: 'imports-loader?backbone.nativeview'
  34. },
  35. {
  36. test: path.resolve(__dirname, "node_modules/xss/dist/xss"),
  37. use: "exports-loader?filterXSS,filterCSS"
  38. },
  39. {
  40. test: /templates\/.*\.(html|svg)$/,
  41. exclude: /node_modules/,
  42. use: [{
  43. loader: 'lodash-template-webpack-loader',
  44. options: {
  45. "escape": /\{\{\{([\s\S]+?)\}\}\}/g,
  46. "evaluate": /\{\[([\s\S]+?)\]\}/g,
  47. "interpolate": /\{\{([\s\S]+?)\}\}/g,
  48. // By default, template places the values from your data in the
  49. // local scope via the with statement. However, you can specify
  50. // a single variable name with the variable setting. This can
  51. // significantly improve the speed at which a template is able
  52. // to render.
  53. "variable": 'o',
  54. "prependFilenameComment": __dirname
  55. }
  56. }]
  57. },
  58. {
  59. test: /webfonts\/.*\.(woff(2)?|ttf|eot|truetype|svg)(\?v=\d+\.\d+\.\d+)?$/,
  60. use: [
  61. {
  62. loader: 'file-loader',
  63. options: {
  64. name: '[path][name].[ext]',
  65. outputPath: '../'
  66. }
  67. }
  68. ]
  69. }, {
  70. test: /\.scss$/,
  71. use: [
  72. 'style-loader',
  73. MiniCssExtractPlugin.loader, {
  74. loader: 'css-loader',
  75. options: {
  76. sourceMap: true
  77. }
  78. }, {
  79. loader: 'sass-loader',
  80. options: {
  81. includePaths: [
  82. path.resolve(__dirname, 'node_modules/')
  83. ],
  84. sourceMap: true
  85. }
  86. }]
  87. }, {
  88. test: /\.js$/,
  89. exclude: /(node_modules|spec|mockup)/,
  90. use: {
  91. loader: 'babel-loader',
  92. options: {
  93. presets: [
  94. ["@babel/preset-env", {
  95. "targets": {
  96. "browsers": [">1%", "not ie 11", "not op_mini all"]
  97. }
  98. }]
  99. ]
  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. "xss": path.resolve(__dirname, "node_modules/xss/dist/xss")
  135. }
  136. }
  137. }
  138. function extend (o1, o2) {
  139. for (var i in o2) {
  140. if (Object.prototype.hasOwnProperty.call(o2, i)) {
  141. o1[i] = o2[i];
  142. }
  143. }
  144. }
  145. function parameterize () {
  146. const type = minimist(process.argv.slice(2)).type;
  147. const mode = minimist(process.argv.slice(2)).mode;
  148. const lang = minimist(process.argv.slice(2)).lang;
  149. if (type === 'headless') {
  150. console.log("Making a headless build");
  151. extend(config, {
  152. entry: "@converse/headless/headless.js",
  153. output: {
  154. path: path.resolve(__dirname, 'src/headless/dist'),
  155. filename: 'converse-headless.js'
  156. },
  157. });
  158. }
  159. if (type === 'nodeps') {
  160. console.log("Making a build without 3rd party dependencies");
  161. extend(config, {
  162. entry: path.resolve(__dirname, 'src/converse.js'),
  163. externals: [{
  164. "backbone.browserStorage": "backbone.browserStorage",
  165. "backbone.overview": "backbone.overview",
  166. "es6-promise": "es6-promise",
  167. "lodash": "lodash",
  168. "lodash.converter": "lodash.converter",
  169. "lodash.noconflict": "lodash.noconflict",
  170. "moment": "moment",
  171. "strophe": "strophe",
  172. "strophe.ping": "strophe.ping",
  173. "strophe.rsm": "strophe.rsm",
  174. "window": "window"
  175. }],
  176. output: {
  177. path: path.resolve(__dirname, 'dist'),
  178. filename: 'converse-no-dependencies.js'
  179. },
  180. });
  181. }
  182. if (type === 'css') {
  183. console.log("Building only CSS");
  184. const fn = config.output.filename;
  185. config.entry = path.resolve(__dirname, 'sass/converse.scss');
  186. }
  187. if (mode === 'production') {
  188. console.log("Making a production build");
  189. const fn = config.output.filename;
  190. config.output.filename = `${fn.replace(/\.js$/, '')}.min.js`;
  191. }
  192. }
  193. parameterize();
  194. module.exports = config;