mirror of
https://github.com/projectstorm/react-diagrams.git
synced 2025-08-14 16:51:29 +08:00
41 lines
970 B
JavaScript
41 lines
970 B
JavaScript
const production = process.env.NODE_ENV === "production";
|
|
const TerserPlugin = require('terser-webpack-plugin');
|
|
const nodeExternals = require('webpack-node-externals');
|
|
const path = require('path');
|
|
|
|
module.exports = (directory) => {
|
|
return {
|
|
entry: path.join(directory, 'index.ts'),
|
|
output: {
|
|
filename: "index.js",
|
|
path: path.join(directory, 'dist'),
|
|
libraryTarget: "umd",
|
|
},
|
|
externals: [
|
|
nodeExternals({modulesDir: path.join(directory, 'node_modules')}),
|
|
nodeExternals({modulesDir: path.join(__dirname, 'node_modules')})
|
|
],
|
|
module: {
|
|
rules: [
|
|
{
|
|
enforce: "pre",
|
|
test: /\.js$/,
|
|
loader: "source-map-loader"
|
|
},
|
|
{
|
|
test: /\.tsx?$/,
|
|
loader: "ts-loader"
|
|
}
|
|
]
|
|
},
|
|
resolve: {
|
|
extensions: [".tsx", ".ts", ".js"]
|
|
},
|
|
devtool: production ? "source-map" : "cheap-module-source-map",
|
|
mode: production ? "production" : "development",
|
|
optimization: {
|
|
minimizer: [new TerserPlugin()],
|
|
}
|
|
}
|
|
};
|