webpack.common.js 2.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576
  1. const webpack = require('webpack');
  2. const helpers = require('./helpers');
  3. /*
  4. * Webpack Plugins
  5. */
  6. // problem with copy-webpack-plugin
  7. const AssetsPlugin = require('assets-webpack-plugin');
  8. const CommonsChunkPlugin = require('webpack/lib/optimize/CommonsChunkPlugin');
  9. /*
  10. * Webpack configuration
  11. *
  12. * See: http://webpack.github.io/docs/configuration.html#cli
  13. */
  14. module.exports = function (options) {
  15. isProd = options.env === 'production';
  16. return {
  17. entry: {
  18. 'app': './resource/js/app',
  19. 'legacy': './resource/js/legacy/crowi',
  20. 'legacy-form': './resource/js/legacy/crowi-form',
  21. 'legacy-admin': './resource/js/legacy/crowi-admin',
  22. 'legacy-presentation': './resource/js/legacy/crowi-presentation',
  23. 'plugin': './resource/js/plugin',
  24. 'style': './resource/styles',
  25. },
  26. resolve: {
  27. extensions: ['.js', '.json'],
  28. modules: [helpers.root('src'), helpers.root('node_modules')],
  29. },
  30. module: {
  31. rules: [
  32. {
  33. test: /.jsx?$/,
  34. exclude: /node_modules/,
  35. use: [{
  36. loader: 'babel-loader?cacheDirectory',
  37. }]
  38. },
  39. /*
  40. * File loader for supporting images, for example, in CSS files.
  41. */
  42. {
  43. test: /\.(jpg|png|gif)$/,
  44. use: 'file-loader',
  45. },
  46. /* File loader for supporting fonts, for example, in CSS files.
  47. */
  48. {
  49. test: /\.(eot|woff2?|svg|ttf)([\?]?.*)$/,
  50. use: 'file-loader',
  51. }
  52. ]
  53. },
  54. plugins: [
  55. new AssetsPlugin({
  56. path: helpers.root('public/js'),
  57. filename: 'webpack-assets.json',
  58. prettyPrint: true,
  59. }),
  60. new CommonsChunkPlugin({
  61. name: 'commons',
  62. chunks: ['app', 'legacy', 'legacy-form', 'legacy-admin', 'legacy-presentation'],
  63. minChunks: module => /node_modules/.test(module.resource),
  64. }),
  65. new webpack.ProvidePlugin({
  66. jQuery: "jquery",
  67. $: "jquery",
  68. }),
  69. ]
  70. };
  71. }