summaryrefslogtreecommitdiffstats
path: root/webpack.common.js
blob: 74fbef1aa9eef7d34eaa574765ef8e0bd9bbd9e4 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
/* eslint-disable camelcase */
const { VueLoaderPlugin } = require('vue-loader')
const path = require('path')

const BabelLoaderExcludeNodeModulesExcept = require('babel-loader-exclude-node-modules-except')
const ESLintPlugin = require('eslint-webpack-plugin')

const modules = require('./webpack.modules.js')

const modulesToBuild = () => {
	const MODULE = process.env.MODULE
	if (MODULE) {
		if (!modules[MODULE]) {
			throw new Error(`No module "${MODULE}" found`)
		}
		return modules[MODULE]
	}
	// merge all configs into one object
	return Object.assign({}, ...Object.values(modules))
}

module.exports = {
	entry: modulesToBuild(),
	output: {
		// Step away from the src folder and extract to the js folder
		path: path.join(__dirname),
		publicPath: '/dist/',
		filename: (chunkData) => {
			// Get relative path of the src folder
			const srcPath = chunkData.chunk.entryModule.context
			const relativePath = path.relative(__dirname, srcPath)

			// If this is a core source, output in core dist folder
			if (relativePath.indexOf('core/src') > -1) {
				return path.join('core/js/dist/', '[name].js?v=[contenthash]')
			}
			// Get out of the shared dist folder and output inside apps js folder
			return path.join(relativePath, '..', 'js') + '/[name].js?v=[contenthash]'
		},
		chunkFilename: 'dist/[name]-[id].js?v=[contenthash]',
	},

	module: {
		rules: [
			{
				test: /\.css$/,
				use: ['style-loader', 'css-loader'],
			},
			{
				test: /\.scss$/,
				use: ['style-loader', 'css-loader', 'sass-loader'],
			},
			{
				test: /\.vue$/,
				loader: 'vue-loader',
				exclude: BabelLoaderExcludeNodeModulesExcept([
					'vue-material-design-icons',
				]),
			},
			{
				test: /\.js$/,
				loader: 'babel-loader',
				// automatically detect necessary packages to
				// transpile in the node_modules folder
				exclude: BabelLoaderExcludeNodeModulesExcept([
					'@nextcloud/dialogs',
					'@nextcloud/event-bus',
					'@nextcloud/vue-dashboard',
					'davclient.js',
					'nextcloud-vue-collections',
					'p-finally',
					'p-limit',
					'p-locate',
					'p-queue',
					'p-timeout',
					'p-try',
					'semver',
					'striptags',
					'toastify-js',
					'v-tooltip',
					'yocto-queue',
				]),
			},
			{
				test: /\.(png|jpe?g|gif|svg|woff2?|eot|ttf)$/,
				loader: 'url-loader',
				options: {
					name: '[name].[ext]?[hash]',
				},
			},
			{
				test: /\.handlebars/,
				loader: 'handlebars-loader',
				query: {
					extensions: '.handlebars',
				},
			},

		],
	},

	optimization: {
		splitChunks: {
			automaticNameDelimiter: '-',
			cacheGroups: {
				vendors: {
					test: /[\\/]node_modules[\\/]/,
					enforce: true,
					name: 'nextcloud',
					chunks: 'all',
				},
			},
		},
	},

	plugins: [new VueLoaderPlugin(), new ESLintPlugin()],
	resolve: {
		alias: {
			OC: path.resolve(__dirname, './core/src/OC'),
			OCA: path.resolve(__dirname, './core/src/OCA'),
			// make sure to use the handlebar runtime when importing
			handlebars: 'handlebars/runtime',
		},
		extensions: ['*', '.js', '.vue'],
		symlinks: false,
	},
}