2021-09-16 21:06:46 +02:00
|
|
|
/*
|
|
|
|
* Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one
|
|
|
|
* or more contributor license agreements. Licensed under the Elastic License
|
|
|
|
* 2.0 and the Server Side Public License, v 1; you may not use this file except
|
|
|
|
* in compliance with, at your election, the Elastic License 2.0 or the Server
|
|
|
|
* Side Public License, v 1.
|
|
|
|
*/
|
|
|
|
|
|
|
|
const Path = require('path');
|
|
|
|
const webpack = require('webpack');
|
|
|
|
const { CleanWebpackPlugin } = require('clean-webpack-plugin');
|
|
|
|
const MiniCssExtractPlugin = require('mini-css-extract-plugin');
|
|
|
|
|
|
|
|
const UiSharedDepsNpm = require('./src/index');
|
|
|
|
|
|
|
|
const MOMENT_SRC = require.resolve('moment/min/moment-with-locales.js');
|
|
|
|
const WEBPACK_SRC = require.resolve('webpack');
|
|
|
|
|
2021-10-13 03:50:49 +02:00
|
|
|
const REPO_ROOT = Path.resolve(__dirname, '..', '..');
|
|
|
|
|
2021-09-16 21:06:46 +02:00
|
|
|
module.exports = (_, argv) => {
|
|
|
|
const outputPath = argv.outputPath ? Path.resolve(argv.outputPath) : UiSharedDepsNpm.distDir;
|
|
|
|
|
|
|
|
return {
|
|
|
|
node: {
|
|
|
|
child_process: 'empty',
|
|
|
|
fs: 'empty',
|
|
|
|
},
|
|
|
|
externals: {
|
|
|
|
module: 'module',
|
|
|
|
},
|
|
|
|
mode: 'production',
|
|
|
|
entry: {
|
|
|
|
'kbn-ui-shared-deps-npm': [
|
|
|
|
// polyfill code
|
|
|
|
'core-js/stable',
|
|
|
|
'regenerator-runtime/runtime',
|
|
|
|
'whatwg-fetch',
|
|
|
|
'symbol-observable',
|
|
|
|
|
|
|
|
// modules from npm
|
|
|
|
'@elastic/charts',
|
|
|
|
'@elastic/eui',
|
|
|
|
'@elastic/eui/dist/eui_charts_theme',
|
|
|
|
'@elastic/eui/lib/services',
|
|
|
|
'@elastic/eui/lib/services/format',
|
|
|
|
'@elastic/eui/dist/eui_theme_light.json',
|
|
|
|
'@elastic/eui/dist/eui_theme_dark.json',
|
|
|
|
'@elastic/eui/dist/eui_theme_amsterdam_light.json',
|
|
|
|
'@elastic/eui/dist/eui_theme_amsterdam_dark.json',
|
|
|
|
'@elastic/numeral',
|
|
|
|
'@emotion/react',
|
|
|
|
'classnames',
|
|
|
|
'fflate',
|
|
|
|
'history',
|
|
|
|
'jquery',
|
|
|
|
'lodash',
|
|
|
|
'lodash/fp',
|
|
|
|
'moment-timezone/moment-timezone',
|
|
|
|
'moment-timezone/data/packed/latest.json',
|
|
|
|
'moment',
|
|
|
|
'react-beautiful-dnd',
|
|
|
|
'react-dom',
|
|
|
|
'react-dom/server',
|
|
|
|
'react-router-dom',
|
|
|
|
'react-router',
|
|
|
|
'react',
|
|
|
|
'rison-node',
|
|
|
|
'rxjs',
|
|
|
|
'rxjs/operators',
|
|
|
|
'styled-components',
|
|
|
|
'tslib',
|
|
|
|
],
|
|
|
|
'kbn-ui-shared-deps-npm.v7.dark': ['@elastic/eui/dist/eui_theme_dark.css'],
|
|
|
|
'kbn-ui-shared-deps-npm.v7.light': ['@elastic/eui/dist/eui_theme_light.css'],
|
|
|
|
'kbn-ui-shared-deps-npm.v8.dark': ['@elastic/eui/dist/eui_theme_amsterdam_dark.css'],
|
|
|
|
'kbn-ui-shared-deps-npm.v8.light': ['@elastic/eui/dist/eui_theme_amsterdam_light.css'],
|
|
|
|
},
|
|
|
|
context: __dirname,
|
|
|
|
devtool: 'cheap-source-map',
|
|
|
|
output: {
|
|
|
|
path: outputPath,
|
|
|
|
filename: '[name].dll.js',
|
|
|
|
chunkFilename: 'kbn-ui-shared-deps-npm.chunk.[id].js',
|
|
|
|
devtoolModuleFilenameTemplate: (info) =>
|
|
|
|
`kbn-ui-shared-deps-npm/${Path.relative(REPO_ROOT, info.absoluteResourcePath)}`,
|
|
|
|
library: '__kbnSharedDeps_npm__',
|
|
|
|
futureEmitAssets: true,
|
|
|
|
},
|
|
|
|
|
|
|
|
module: {
|
|
|
|
noParse: [MOMENT_SRC, WEBPACK_SRC],
|
|
|
|
rules: [
|
|
|
|
{
|
|
|
|
include: [require.resolve('jquery')],
|
|
|
|
use: [
|
|
|
|
{
|
|
|
|
loader: UiSharedDepsNpm.publicPathLoader,
|
|
|
|
options: {
|
|
|
|
key: 'kbn-ui-shared-deps-npm',
|
|
|
|
},
|
|
|
|
},
|
|
|
|
],
|
|
|
|
},
|
|
|
|
{
|
|
|
|
test: /\.css$/,
|
|
|
|
use: [MiniCssExtractPlugin.loader, 'css-loader'],
|
|
|
|
},
|
|
|
|
{
|
|
|
|
test: /[\\\/]@elastic[\\\/]eui[\\\/].*\.js$/,
|
|
|
|
use: [
|
|
|
|
{
|
|
|
|
loader: 'babel-loader',
|
|
|
|
options: {
|
|
|
|
plugins: [
|
|
|
|
[
|
|
|
|
require.resolve('babel-plugin-transform-react-remove-prop-types'),
|
|
|
|
{
|
|
|
|
mode: 'remove',
|
|
|
|
removeImport: true,
|
|
|
|
},
|
|
|
|
],
|
|
|
|
],
|
|
|
|
},
|
|
|
|
},
|
|
|
|
],
|
|
|
|
},
|
|
|
|
],
|
|
|
|
},
|
|
|
|
|
|
|
|
resolve: {
|
|
|
|
alias: {
|
|
|
|
moment: MOMENT_SRC,
|
|
|
|
// NOTE: Used to include react profiling on bundles
|
|
|
|
// https://gist.github.com/bvaughn/25e6233aeb1b4f0cdb8d8366e54a3977#webpack-4
|
|
|
|
'react-dom$': 'react-dom/profiling',
|
|
|
|
'scheduler/tracing': 'scheduler/tracing-profiling',
|
|
|
|
},
|
|
|
|
extensions: ['.js', '.ts'],
|
|
|
|
symlinks: false,
|
|
|
|
},
|
|
|
|
|
|
|
|
optimization: {
|
|
|
|
minimize: false,
|
|
|
|
noEmitOnErrors: true,
|
|
|
|
},
|
|
|
|
|
|
|
|
performance: {
|
|
|
|
// NOTE: we are disabling this as those hints
|
|
|
|
// are more tailored for the final bundles result
|
|
|
|
// and not for the webpack compilations performance itself
|
|
|
|
hints: false,
|
|
|
|
},
|
|
|
|
|
|
|
|
plugins: [
|
|
|
|
new CleanWebpackPlugin({
|
|
|
|
protectWebpackAssets: false,
|
|
|
|
cleanAfterEveryBuildPatterns: [
|
|
|
|
'kbn-ui-shared-deps-npm.{v7,v8}.{dark,light}.{dll.js,dll.js.map}',
|
|
|
|
'kbn-ui-shared-deps-npm.{v7,v8}.{dark,light}-manifest.json',
|
|
|
|
],
|
|
|
|
}),
|
|
|
|
new MiniCssExtractPlugin({
|
|
|
|
filename: '[name].css',
|
|
|
|
}),
|
|
|
|
new webpack.DllPlugin({
|
|
|
|
context: REPO_ROOT,
|
|
|
|
path: Path.resolve(outputPath, '[name]-manifest.json'),
|
|
|
|
name: '__kbnSharedDeps_npm__',
|
|
|
|
}),
|
|
|
|
],
|
|
|
|
};
|
|
|
|
};
|