2
0
mirror of https://github.com/tenrok/vue-form-wizard.git synced 2026-05-28 18:14:04 +03:00
Files
vue-form-wizard/webpack.build.config.js
T
2017-04-15 21:54:32 +03:00

74 lines
1.5 KiB
JavaScript

var webpack = require("webpack");
var version = require("./package.json").version;
var banner = "/**\n" + " * vue-form-generator v" + version + "\n" + " * https://github.com/icebob/vue-form-generator\n" + " * Released under the MIT License.\n" + " */\n";
var ExtractTextPlugin = require("extract-text-webpack-plugin");
var StatsPlugin = require("stats-webpack-plugin");
var loaders = [
{
"test": /\.js?$/,
"exclude": /node_modules/,
"loader": "babel"
},
{
"test": /\.vue?$/,
"loader": "vue"
}
];
var cssFileName;
if (process.env.FULL_BUNDLE) {
cssFileName = "vfg.css";
} else {
cssFileName = "vfg-core.css";
}
module.exports = [
{
entry: "./src/index.js",
output: {
path: "./dist",
filename: "vfg.js",
library: "VueFormGenerator",
libraryTarget: "umd"
},
plugins: [
new webpack.DefinePlugin({
"process.env" : {
NODE_ENV : JSON.stringify("production")
}
}),
new webpack.optimize.UglifyJsPlugin({
compress: {
warnings: false
}
}),
new webpack.optimize.DedupePlugin(),
new webpack.BannerPlugin(banner, {
raw: true
}),
new ExtractTextPlugin(cssFileName, { allChunks: true }),
new StatsPlugin("../stats.json", {
chunkModules: true
//exclude: [/node_modules[\\\/]react/]
})
],
module: {
loaders
},
vue: {
loaders: {
css: ExtractTextPlugin.extract("css"),
postcss: ExtractTextPlugin.extract("css"),
sass: ExtractTextPlugin.extract("css!sass"),
}
},
resolve: {
packageAlias: "browser"
}
}
];