2 * Webpack 4 configuration file
3 * see https://webpack.js.org/configuration/
4 * see https://webpack.js.org/configuration/dev-server/
9 const path = require("path");
10 const webpack = require("webpack");
11 const autoprefixer = require('autoprefixer');
12 const CopyWebpackPlugin = require("copy-webpack-plugin");
13 const TerserPlugin = require('terser-webpack-plugin');
15 // const __dirname = (path => path.replace(/^([a-z]\:)/, c => c.toUpperCase()))(process.__dirname());
17 module.exports = (env) => {
18 const distPath = path.resolve(__dirname, env === "release" ? "." : "../..", "dist");
19 const frameworkPath = path.resolve(__dirname, env === "release" ? "../../framework" : "../..", "dist");
23 mode: "none", //disable default behavior
27 context: path.resolve(__dirname, "src"),
30 helpApp: ["./plugin.tsx"]
33 devtool: env === "release" ? false : "source-map",
36 extensions: [".ts", ".tsx", ".js", ".jsx"]
41 filename: "[name].js",
43 libraryTarget: "umd2",
44 chunkFilename: "[name].js"
49 exclude: /node_modules/,
51 loader: "babel-loader"
57 exclude: /node_modules/,
59 loader: "babel-loader"
64 loader: 'style-loader'
69 localIdentName: env !== "release" ? '[name]_[local]_[hash:base64:5]' : '[hash]'
72 loader: 'postcss-loader',
74 plugins: () => [autoprefixer]
82 namedModules: env !== "release",
83 minimize: env === "release",
84 minimizer: env !== "release" ? [] : [new TerserPlugin({
86 warnings: false, // false, true, "verbose"
96 new webpack.DllReferencePlugin({
97 context: path.resolve(__dirname, "../../framework/src"),
98 manifest: require(path.resolve(frameworkPath, "vendor-manifest.json")),
101 new webpack.DllReferencePlugin({
102 context: path.resolve(__dirname, "../../framework/src"),
103 manifest: require(path.resolve(frameworkPath, "app-manifest.json")),
106 ...(env === "release") ? [
107 new webpack.DefinePlugin({
109 NODE_ENV: "'production'",
110 VERSION: JSON.stringify(require("./package.json").version)
114 new webpack.DefinePlugin({
116 NODE_ENV: "'development'",
117 VERSION: JSON.stringify(require("./package.json").version)
120 new CopyWebpackPlugin([{
127 public: "http://localhost:3100",
128 contentBase: frameworkPath,
132 "Access-Control-Allow-Origin": "*"
136 disableHostCheck: true,
137 historyApiFallback: true,
146 target: "http://localhost:3000",
150 target: "http://localhost:3000",
154 target: "http://localhost:3000",
158 target: "http://localhost:3000",
162 target: "http://localhost:3000",