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 3.3KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133
  1. /* eslint-disable camelcase */
  2. const { merge } = require('webpack-merge')
  3. const { VueLoaderPlugin } = require('vue-loader')
  4. const path = require('path')
  5. const BabelLoaderExcludeNodeModulesExcept = require('babel-loader-exclude-node-modules-except')
  6. const ESLintPlugin = require('eslint-webpack-plugin')
  7. const accessibility = require('./apps/accessibility/webpack')
  8. const comments = require('./apps/comments/webpack')
  9. const core = require('./core/webpack')
  10. const dashboard = require('./apps/dashboard/webpack')
  11. const dav = require('./apps/dav/webpack')
  12. const files = require('./apps/files/webpack')
  13. const files_sharing = require('./apps/files_sharing/webpack')
  14. const files_trashbin = require('./apps/files_trashbin/webpack')
  15. const files_versions = require('./apps/files_versions/webpack')
  16. const oauth2 = require('./apps/oauth2/webpack')
  17. const settings = require('./apps/settings/webpack')
  18. const systemtags = require('./apps/systemtags/webpack')
  19. const user_status = require('./apps/user_status/webpack')
  20. const weather_status = require('./apps/weather_status/webpack')
  21. const twofactor_backupscodes = require('./apps/twofactor_backupcodes/webpack')
  22. const updatenotification = require('./apps/updatenotification/webpack')
  23. const workflowengine = require('./apps/workflowengine/webpack')
  24. const modules = {
  25. accessibility,
  26. comments,
  27. core,
  28. dashboard,
  29. dav,
  30. files,
  31. files_sharing,
  32. files_trashbin,
  33. files_versions,
  34. oauth2,
  35. settings,
  36. systemtags,
  37. user_status,
  38. weather_status,
  39. twofactor_backupscodes,
  40. updatenotification,
  41. workflowengine,
  42. }
  43. const modulesToBuild = () => {
  44. const MODULE = process.env.MODULE
  45. if (MODULE) {
  46. if (!modules[MODULE]) {
  47. throw new Error(`No module "${MODULE}" found`)
  48. }
  49. return [modules[MODULE]]
  50. }
  51. return Object.values(modules)
  52. }
  53. module.exports = []
  54. .concat(
  55. ...modulesToBuild()
  56. )
  57. .map(config => merge({
  58. module: {
  59. rules: [
  60. {
  61. test: /\.css$/,
  62. use: ['style-loader', 'css-loader'],
  63. },
  64. {
  65. test: /\.scss$/,
  66. use: ['style-loader', 'css-loader', 'sass-loader'],
  67. },
  68. {
  69. test: /\.vue$/,
  70. loader: 'vue-loader',
  71. exclude: BabelLoaderExcludeNodeModulesExcept([
  72. 'vue-material-design-icons',
  73. ]),
  74. },
  75. {
  76. test: /\.js$/,
  77. loader: 'babel-loader',
  78. // automatically detect necessary packages to
  79. // transpile in the node_modules folder
  80. exclude: BabelLoaderExcludeNodeModulesExcept([
  81. '@nextcloud/dialogs',
  82. '@nextcloud/event-bus',
  83. '@nextcloud/vue-dashboard',
  84. 'davclient.js',
  85. 'nextcloud-vue-collections',
  86. 'p-finally',
  87. 'p-limit',
  88. 'p-locate',
  89. 'p-queue',
  90. 'p-timeout',
  91. 'p-try',
  92. 'semver',
  93. 'striptags',
  94. 'toastify-js',
  95. 'v-tooltip',
  96. 'yocto-queue',
  97. ]),
  98. },
  99. {
  100. test: /\.(png|jpg|gif)$/,
  101. loader: 'url-loader',
  102. options: {
  103. name: '[name].[ext]?[hash]',
  104. limit: 8192,
  105. },
  106. },
  107. {
  108. test: /\.handlebars/,
  109. loader: 'handlebars-loader',
  110. query: {
  111. extensions: '.handlebars',
  112. },
  113. },
  114. ],
  115. },
  116. plugins: [new VueLoaderPlugin(), new ESLintPlugin()],
  117. resolve: {
  118. alias: {
  119. OC: path.resolve(__dirname, './core/src/OC'),
  120. OCA: path.resolve(__dirname, './core/src/OCA'),
  121. // make sure to use the handlebar runtime when importing
  122. handlebars: 'handlebars/runtime',
  123. },
  124. extensions: ['*', '.js', '.vue'],
  125. symlinks: false,
  126. },
  127. }, config))