jiti-meet/webpack.config.js

345 lines
11 KiB
JavaScript
Raw Normal View History

/* global __dirname */
const CircularDependencyPlugin = require('circular-dependency-plugin');
const process = require('process');
const webpack = require('webpack');
const { BundleAnalyzerPlugin } = require('webpack-bundle-analyzer');
2016-09-22 05:57:22 +00:00
2016-12-09 01:17:49 +00:00
/**
* The URL of the Jitsi Meet deployment to be proxy to in the context of
* development with webpack-dev-server.
*/
const devServerProxyTarget
= process.env.WEBPACK_DEV_SERVER_PROXY_TARGET || 'https://alpha.jitsi.net';
2016-12-09 01:17:49 +00:00
const analyzeBundle = process.argv.indexOf('--analyze-bundle') !== -1;
const detectCircularDeps = process.argv.indexOf('--detect-circular-deps') !== -1;
const minimize
2016-11-29 02:06:23 +00:00
= process.argv.indexOf('-p') !== -1
|| process.argv.indexOf('--optimize-minimize') !== -1;
/**
* Build a Performance configuration object for the given size.
* See: https://webpack.js.org/configuration/performance/
*/
function getPerformanceHints(size) {
return {
hints: minimize && !analyzeBundle ? 'error' : false,
maxAssetSize: size,
maxEntrypointSize: size
};
}
/**
* Build a BundleAnalyzerPlugin plugin instance for the given bundle name.
*/
function getBundleAnalyzerPlugin(name) {
if (!analyzeBundle) {
return [];
}
return [ new BundleAnalyzerPlugin({
analyzerMode: 'disabled',
generateStatsFile: true,
statsFilename: `${name}-stats.json`
}) ];
}
2016-09-22 05:57:22 +00:00
// The base Webpack configuration to bundle the JavaScript artifacts of
// jitsi-meet such as app.bundle.js and external_api.js.
const config = {
2016-12-09 01:17:49 +00:00
devServer: {
https: true,
host: '127.0.0.1',
2016-12-09 01:17:49 +00:00
inline: true,
proxy: {
'/': {
bypass: devServerProxyBypass,
secure: false,
target: devServerProxyTarget,
headers: {
'Host': new URL(devServerProxyTarget).host
}
2016-12-09 01:17:49 +00:00
}
}
},
2016-09-22 05:57:22 +00:00
devtool: 'source-map',
2018-12-21 15:30:22 +00:00
mode: minimize ? 'production' : 'development',
2016-09-22 05:57:22 +00:00
module: {
2017-01-30 18:45:08 +00:00
rules: [ {
// Transpile ES2015 (aka ES6) to ES5. Accept the JSX syntax by React
// as well.
2017-02-07 21:44:37 +00:00
loader: 'babel-loader',
2017-01-30 18:45:08 +00:00
options: {
// Avoid loading babel.config.js, since we only use it for React Native.
configFile: false,
2016-11-24 06:42:07 +00:00
// XXX The require.resolve bellow solves failures to locate the
// presets when lib-jitsi-meet, for example, is npm linked in
2018-10-02 11:19:16 +00:00
// jitsi-meet.
plugins: [
require.resolve('@babel/plugin-transform-flow-strip-types'),
require.resolve('@babel/plugin-proposal-class-properties'),
require.resolve('@babel/plugin-proposal-export-default-from'),
require.resolve('@babel/plugin-proposal-export-namespace-from'),
require.resolve('@babel/plugin-proposal-nullish-coalescing-operator'),
require.resolve('@babel/plugin-proposal-optional-chaining')
2018-10-02 11:19:16 +00:00
],
presets: [
2017-01-30 18:45:08 +00:00
[
2018-10-02 11:19:16 +00:00
require.resolve('@babel/preset-env'),
2017-01-30 18:45:08 +00:00
// Tell babel to avoid compiling imports into CommonJS
// so that webpack may do tree shaking.
2019-04-08 11:18:35 +00:00
{
modules: false,
// Specify our target browsers so no transpiling is
// done unnecessarily. For browsers not specified
// here, the ES2015+ profile will be used.
targets: {
chrome: 58,
electron: 2,
firefox: 54,
safari: 11
}
}
2017-01-30 18:45:08 +00:00
],
2018-10-02 11:19:16 +00:00
require.resolve('@babel/preset-flow'),
require.resolve('@babel/preset-react')
2017-01-30 18:45:08 +00:00
]
},
test: /\.jsx?$/
2016-11-29 02:06:23 +00:00
}, {
2016-09-22 05:57:22 +00:00
// Expose jquery as the globals $ and jQuery because it is expected
// to be available in such a form by multiple jitsi-meet
2017-11-28 02:29:00 +00:00
// dependencies including lib-jitsi-meet.
2016-09-22 05:57:22 +00:00
2017-02-07 21:44:37 +00:00
loader: 'expose-loader?$!expose-loader?jQuery',
test: /[/\\]node_modules[/\\]jquery[/\\].*\.js$/
2016-11-29 02:06:23 +00:00
}, {
2016-09-22 05:57:22 +00:00
// Allow CSS to be imported into JavaScript.
2017-01-30 18:45:08 +00:00
test: /\.css$/,
use: [
2017-02-07 21:44:37 +00:00
'style-loader',
'css-loader'
2017-01-30 18:45:08 +00:00
]
2019-08-15 15:49:40 +00:00
}, {
test: /\/node_modules\/@atlaskit\/modal-dialog\/.*\.js$/,
resolve: {
alias: {
2021-01-14 16:12:08 +00:00
'react-focus-lock': `${__dirname}/react/features/base/util/react-focus-lock-wrapper.js`,
'../styled/Modal': `${__dirname}/react/features/base/dialog/components/web/ThemedDialog.js`
2019-08-15 15:49:40 +00:00
}
}
}, {
test: /\/react\/features\/base\/util\/react-focus-lock-wrapper.js$/,
resolve: {
alias: {
'react-focus-lock': `${__dirname}/node_modules/react-focus-lock`
}
}
2019-08-30 16:39:06 +00:00
}, {
test: /\.svg$/,
use: [ {
loader: '@svgr/webpack',
options: {
dimensions: false,
expandProps: 'start'
}
} ]
} ]
2016-09-22 05:57:22 +00:00
},
node: {
// Allow the use of the real filename of the module being executed. By
// default Webpack does not leak path-related information and provides a
// value that is a mock (/index.js).
__filename: true,
// Provide some empty Node modules (required by olm).
crypto: 'empty',
fs: 'empty'
2016-09-22 05:57:22 +00:00
},
2018-12-03 13:39:37 +00:00
optimization: {
concatenateModules: minimize,
minimize
},
2016-09-22 05:57:22 +00:00
output: {
filename: `[name]${minimize ? '.min' : ''}.js`,
path: `${__dirname}/build`,
2016-12-09 01:17:49 +00:00
publicPath: '/libs/',
sourceMapFilename: `[name].${minimize ? 'min' : 'js'}.map`
2016-09-22 05:57:22 +00:00
},
plugins: [
detectCircularDeps
&& new CircularDependencyPlugin({
allowAsyncCycles: false,
exclude: /node_modules/,
failOnError: false
})
].filter(Boolean),
2016-09-22 05:57:22 +00:00
resolve: {
alias: {
'focus-visible': 'focus-visible/dist/focus-visible.min.js',
jquery: `jquery/dist/jquery${minimize ? '.min' : ''}.js`
2016-09-22 05:57:22 +00:00
},
2017-01-30 18:45:08 +00:00
aliasFields: [
'browser'
],
extensions: [
'.web.js',
// Webpack defaults:
'.js',
'.json'
]
2016-09-22 05:57:22 +00:00
}
};
2017-06-16 03:47:04 +00:00
module.exports = [
Object.assign({}, config, {
entry: {
'app.bundle': './app.js'
},
plugins: [
...config.plugins,
...getBundleAnalyzerPlugin('app'),
new webpack.IgnorePlugin(/^\.\/locale$/, /moment$/)
],
performance: getPerformanceHints(4 * 1024 * 1024)
}),
Object.assign({}, config, {
entry: {
'alwaysontop': './react/features/always-on-top/index.js'
},
plugins: [
...config.plugins,
...getBundleAnalyzerPlugin('alwaysontop')
],
performance: getPerformanceHints(800 * 1024)
}),
Object.assign({}, config, {
entry: {
'dial_in_info_bundle': './react/features/invite/components/dial-in-info-page'
},
plugins: [
...config.plugins,
...getBundleAnalyzerPlugin('dial_in_info'),
new webpack.IgnorePlugin(/^\.\/locale$/, /moment$/)
],
performance: getPerformanceHints(500 * 1024)
}),
Object.assign({}, config, {
entry: {
'do_external_connect': './connection_optimization/do_external_connect.js'
},
plugins: [
...config.plugins,
...getBundleAnalyzerPlugin('do_external_connect')
],
performance: getPerformanceHints(5 * 1024)
}),
Object.assign({}, config, {
entry: {
'flacEncodeWorker': './react/features/local-recording/recording/flac/flacEncodeWorker.js'
},
plugins: [
...config.plugins,
...getBundleAnalyzerPlugin('flacEncodeWorker')
],
performance: getPerformanceHints(5 * 1024)
}),
Object.assign({}, config, {
entry: {
'analytics-ga': './react/features/analytics/handlers/GoogleAnalyticsHandler.js'
},
plugins: [
...config.plugins,
...getBundleAnalyzerPlugin('analytics-ga')
],
performance: getPerformanceHints(5 * 1024)
}),
Object.assign({}, config, {
entry: {
'close3': './static/close3.js'
},
plugins: [
...config.plugins,
...getBundleAnalyzerPlugin('close3')
],
performance: getPerformanceHints(128 * 1024)
}),
Object.assign({}, config, {
entry: {
'external_api': './modules/API/external/index.js'
},
output: Object.assign({}, config.output, {
2017-06-16 03:47:04 +00:00
library: 'JitsiMeetExternalAPI',
libraryTarget: 'umd'
}),
plugins: [
...config.plugins,
...getBundleAnalyzerPlugin('external_api')
],
performance: getPerformanceHints(35 * 1024)
})
];
2016-12-09 01:17:49 +00:00
/**
* Determines whether a specific (HTTP) request is to bypass the proxy of
* webpack-dev-server (i.e. is to be handled by the proxy target) and, if not,
* which local file is to be served in response to the request.
*
* @param {Object} request - The (HTTP) request received by the proxy.
* @returns {string|undefined} If the request is to be served by the proxy
* target, undefined; otherwise, the path to the local file to be served.
*/
function devServerProxyBypass({ path }) {
if (path.startsWith('/css/') || path.startsWith('/doc/')
|| path.startsWith('/fonts/')
|| path.startsWith('/images/')
2020-05-19 09:58:21 +00:00
|| path.startsWith('/lang/')
|| path.startsWith('/sounds/')
|| path.startsWith('/static/')
2019-11-06 09:25:08 +00:00
|| path.endsWith('.wasm')) {
2016-12-09 01:17:49 +00:00
return path;
}
const configs = module.exports;
/* eslint-disable array-callback-return, indent */
if ((Array.isArray(configs) ? configs : Array(configs)).some(c => {
if (path.startsWith(c.output.publicPath)) {
2016-12-09 01:17:49 +00:00
if (!minimize) {
// Since webpack-dev-server is serving non-minimized
// artifacts, serve them even if the minimized ones are
// requested.
2019-09-09 15:43:30 +00:00
return Object.keys(c.entry).some(e => {
const name = `${e}.min.js`;
2016-12-09 01:17:49 +00:00
if (path.indexOf(name) !== -1) {
// eslint-disable-next-line no-param-reassign
path = path.replace(name, `${e}.js`);
2016-12-09 01:17:49 +00:00
return true;
}
});
}
}
})) {
return path;
2016-12-09 01:17:49 +00:00
}
2019-10-09 08:27:45 +00:00
if (path.startsWith('/libs/')) {
return path;
}
2016-12-09 01:17:49 +00:00
}