1
0
mirror of https://github.com/Pomax/BezierInfo-2.git synced 2025-02-24 09:33:19 +01:00
BezierInfo-2/webpack.config.js
2016-01-12 18:55:20 -08:00

54 lines
1.3 KiB
JavaScript

var webpack = require('webpack');
// Bundle entry point
var entry = ['./components/App.jsx'];
// Necessary webpack loaders for converting our content:
var webpackLoaders = [
'babel-loader',
'eslint',
__dirname + '/lib/latex-loader',
__dirname + '/lib/pre-loader',
__dirname + '/lib/p-loader'
];
var plugins = [];
// Dev mode: make certain concessions to speed up dev work.
if(process.argv.indexOf("--prod") === -1 && process.argv.indexOf("--lint")) {
// use the webpack hot Reload server:
entry.push('webpack/hot/dev-server');
// allow code in textareas when in dev mode:
webpackLoaders.push(__dirname + '/lib/textarea-loader');
}
// Prod mode: make sure to minify the bundle
else if(process.argv.indexOf("--prod") > -1) {
plugins.push(new webpack.optimize.UglifyJsPlugin());
}
// And the final config that webpack will read in.
module.exports = {
entry: entry,
output: {
path: __dirname,
filename: 'article.js'
},
module: {
loaders: [
{ test: /\.(png|gif)$/, loader: "file?name=images/packed/[hash].[ext]" },
{ test: /\.less$/, loader: "style!css!less" },
{ test: /\.json$/, loader: "json" },
{
test: /.jsx?$/,
include: /components/,
loaders: webpackLoaders
}
]
},
plugins: plugins,
eslint: {
configFile: __dirname + '/.eslintrc'
}
};