vsts-extension-color-control/webpack.prod.config.js

56 строки
1.7 KiB
JavaScript

const path = require("path");
const fs = require("fs");
// const webpack = require("webpack");
const CopyWebpackPlugin = require("copy-webpack-plugin");
module.exports = {
mode: "production",
target: "web",
entry: {
app: "./scripts/app.ts"
},
output: {
filename: "scripts/[name].js",
publicPath: "./dist",
libraryTarget: "amd"
},
externals: [
/^VSS\/.*/, /^TFS\/.*/, /^q$/
],
resolve: {
extensions: [".ts", ".tsx", ".js"],
alias: {
"vss-web-extension-sdk": path.resolve(__dirname, "node_modules/vss-web-extension-sdk/lib/VSS.SDK")
},
modules: [path.resolve("."), "node_modules"]
},
module: {
rules: [
{
test: /\.tsx?$/,
use: "ts-loader"
},
{
test: /\.css$/,
use: ["style-loader", "css-loader"]
},
{
test: /\.(png|svg|jpg|gif|html)$/,
use: "file-loader"
}
]
},
plugins: [
new CopyWebpackPlugin({
patterns: [
{ from: "./node_modules/vss-web-extension-sdk/lib/VSS.SDK.min.js", to: "./dist/VSS.SDK.min.js" },
{ from: "**/*.css", to: "./styles", context: "styles" },
{ from: "*.html", to: "./", context: "." },
{ from: "**/*", to: "./img", context: "img" },
{ from: "**/*", to: "./images", context: "images" },
{ from: "./azure-devops-extension.json", to: "azure-devops-extension.json" },
{ from: "./readme.md", to: "readme.md" }
]
})
]
};