chronograf/ui/webpack/devConfig.js

88 lines
2.3 KiB
JavaScript
Raw Normal View History

var webpack = require('webpack');
var path = require('path');
var ExtractTextPlugin = require("extract-text-webpack-plugin");
var HtmlWebpackPlugin = require("html-webpack-plugin");
2016-09-30 20:16:24 +00:00
var package = require('../package.json');
var dependencies = package.dependencies;
module.exports = {
devtool: 'source-map',
entry: {
app: path.resolve(__dirname, '..', 'src', 'index.js'),
2016-09-30 20:16:24 +00:00
vendor: Object.keys(dependencies),
},
output: {
publicPath: '/',
path: path.resolve(__dirname, '../build'),
2016-09-30 21:23:15 +00:00
filename: '[name].[chunkhash].dev.js',
},
resolve: {
alias: {
src: path.resolve(__dirname, '..', 'src'),
shared: path.resolve(__dirname, '..', 'src', 'shared'),
style: path.resolve(__dirname, '..', 'src', 'style'),
utils: path.resolve(__dirname, '..', 'src', 'utils'),
},
},
module: {
preLoaders: [
{
test: /\.js$/,
exclude: /node_modules/,
loader: 'eslint-loader',
},
],
loaders: [
{
test: /\.json$/,
loader: 'json',
},
{
test: /\.scss$/,
loader: ExtractTextPlugin.extract('style-loader', 'css-loader!sass-loader!resolve-url!sass?sourceMap'),
},
{
test: /\.css$/,
loader: ExtractTextPlugin.extract('style-loader', 'css-loader!postcss-loader'),
},
{
test : /\.(ico|png|jpg|ttf|eot|svg|woff(2)?)(\?[a-z0-9]+)?$/,
loader : 'file',
},
{
test: /\.js$/,
exclude: /node_modules/,
loader: 'babel',
query: {
presets: ['es2015', 'react'],
cacheDirectory: true, // use a cache directory to speed up compilation
},
},
],
},
sassLoader: {
includePaths: [path.resolve(__dirname, "node_modules")],
},
eslint: {
failOnWarning: false,
failOnError: false,
},
plugins: [
2016-09-30 20:16:24 +00:00
new webpack.ProvidePlugin({
$: "jquery",
jQuery: "jquery",
}),
new ExtractTextPlugin("style.css"),
new HtmlWebpackPlugin({
template: path.resolve(__dirname, '..', 'src', 'index.template.html'),
inject: 'body',
favicon: 'assets/images/favicon.ico',
}),
2016-09-30 20:16:24 +00:00
new webpack.optimize.CommonsChunkPlugin({
names: ['vendor', 'manifest'],
}),
],
postcss: require('./postcss'),
target: 'web',
};