webpack.config.js 6.9 KB

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