Newer
Older
var BundleTracker = require('webpack-bundle-tracker');
var CleanWebpackPlugin = require('clean-webpack-plugin');
var ExtractTextPlugin = require("extract-text-webpack-plugin");
var glob = require("glob");
var path_bundles = __dirname + '/static_bundles/bundles';
module.exports = {
context: __dirname,
entry: {
main: [
"./scipost/static/scipost/assets/js/scripts.js",
"./scipost/static/scipost/assets/css/style.scss"
],
bootstrap: [
'bootstrap-loader'
],
tooltip: "./scipost/static/scipost/assets/js/tooltip.js",
modal: "./scipost/static/scipost/assets/js/modal.js",
},
output: {
path: path_bundles,
publicPath: '/static/bundles/',
filename: "js/[name]-[hash].js",
},
module: {
loaders: [
{
test: /\.css$/,
loader: ExtractTextPlugin.extract({
fallbackLoader: "style-loader",
loader: "css-loader"
})
loader: ExtractTextPlugin.extract({
fallbackLoader: "style-loader",
loader: "css-loader!less-loader"
})
},
{
test: /\.scss$/,
loader: ExtractTextPlugin.extract({
fallbackLoader: "style-loader",
loader: "css-loader!sass-loader",
})
}
new webpack.ProvidePlugin({
$: "jquery",
jQuery: "jquery",
"window.jQuery": "jquery",
Tether: "tether",
"window.Tether": "tether",
Alert: "exports-loader?Alert!bootstrap/js/dist/alert",
Collapse: "exports-loader?Collapse!bootstrap/js/dist/collapse",
Util: "exports-loader?Util!bootstrap/js/dist/util",
}),
new BundleTracker({
filename: './webpack-stats.json'
}),
new ExtractTextPlugin('css/[name]-[hash].css'),
new CleanWebpackPlugin(['css', 'js'], {
root: path_bundles,
verbose: true,
dry: false,
exclude: []
})