You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

webpack.common.js 2.8KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114
  1. /* eslint-disable camelcase */
  2. const path = require('path')
  3. const merge = require('webpack-merge')
  4. const { VueLoaderPlugin } = require('vue-loader')
  5. const core = require('./core/webpack')
  6. const accessibility = require('./apps/accessibility/webpack')
  7. const comments = require('./apps/comments/webpack')
  8. const files_sharing = require('./apps/files_sharing/webpack')
  9. const files_trashbin = require('./apps/files_trashbin/webpack')
  10. const files_versions = require('./apps/files_versions/webpack')
  11. const oauth2 = require('./apps/oauth2/webpack')
  12. const settings = require('./apps/settings/webpack')
  13. const systemtags = require('./apps/systemtags/webpack')
  14. const twofactor_backupscodes = require('./apps/twofactor_backupcodes/webpack')
  15. const updatenotifications = require('./apps/updatenotification/webpack')
  16. const workflowengine = require('./apps/workflowengine/webpack')
  17. const modules = {
  18. core,
  19. settings,
  20. accessibility,
  21. comments,
  22. files_sharing,
  23. files_trashbin,
  24. files_versions,
  25. oauth2,
  26. systemtags,
  27. twofactor_backupscodes,
  28. updatenotifications,
  29. workflowengine
  30. }
  31. const modulesToBuild = () => {
  32. const MODULE = process.env.MODULE
  33. if (MODULE) {
  34. if (!modules[MODULE]) {
  35. throw new Error(`No module "${MODULE}" found`)
  36. }
  37. return [ modules[MODULE] ]
  38. }
  39. return Object.values(modules)
  40. }
  41. module.exports = []
  42. .concat(
  43. ...modulesToBuild()
  44. )
  45. .map(config => merge.smart({
  46. module: {
  47. rules: [
  48. {
  49. test: /\.css$/,
  50. use: ['vue-style-loader', 'css-loader']
  51. },
  52. {
  53. test: /\.scss$/,
  54. use: ['vue-style-loader', 'css-loader', 'sass-loader']
  55. },
  56. {
  57. test: /\.(js|vue)$/,
  58. loader: 'eslint-loader',
  59. // no checks against vendors, modules or handlebar compiled files
  60. exclude: /node_modules|vendor|templates\.js/,
  61. enforce: 'pre',
  62. options: {
  63. // we cannot simply use the eslint binary as we
  64. // don't want to parse all the js files so let's
  65. // use it from within webpack and only check
  66. // against our compiled files
  67. fix: process.env.ESLINT_FIX === 'true'
  68. }
  69. },
  70. {
  71. test: /\.vue$/,
  72. loader: 'vue-loader',
  73. exclude: /node_modules/
  74. },
  75. {
  76. test: /\.js$/,
  77. loader: 'babel-loader',
  78. exclude: /node_modules/
  79. },
  80. {
  81. test: /\.(png|jpg|gif)$/,
  82. loader: 'url-loader',
  83. options: {
  84. name: '[name].[ext]?[hash]',
  85. limit: 8192
  86. }
  87. },
  88. {
  89. test: /\.handlebars/,
  90. loader: 'handlebars-loader',
  91. query: {
  92. extensions: '.handlebars'
  93. }
  94. }
  95. ]
  96. },
  97. plugins: [new VueLoaderPlugin()],
  98. resolve: {
  99. alias: {
  100. OC: path.resolve(__dirname, './core/src/OC'),
  101. OCA: path.resolve(__dirname, './core/src/OCA'),
  102. // make sure to use the handlebar runtime when importing
  103. handlebars: 'handlebars/runtime'
  104. },
  105. extensions: ['*', '.js', '.vue'],
  106. symlinks: false
  107. }
  108. }, config))