redash/webpack.config.js

128 lines
3.4 KiB
JavaScript
Raw Normal View History

2016-10-30 09:29:51 +00:00
/* eslint-disable */
var webpack = require('webpack');
var HtmlWebpackPlugin = require('html-webpack-plugin');
var ExtractTextPlugin = require("extract-text-webpack-plugin");
2016-11-24 20:08:17 +00:00
var WebpackBuildNotifierPlugin = require('webpack-build-notifier');
var path = require('path');
2016-10-30 09:29:51 +00:00
var redashBackend = process.env.REDASH_BACKEND || 'http://localhost:5000';
2016-10-30 09:29:51 +00:00
var config = {
entry: {
app: './client/app/index.js'
2016-10-30 09:29:51 +00:00
},
output: {
// path: process.env.NODE_ENV === 'production' ? './dist' : './dev',
path: './client/dist',
filename: '[name].[chunkhash].js',
2016-10-30 09:29:51 +00:00
},
plugins: [
2016-11-24 20:08:17 +00:00
new WebpackBuildNotifierPlugin({title: 'Redash'}),
2016-10-30 09:29:51 +00:00
new webpack.DefinePlugin({
ON_TEST: process.env.NODE_ENV === 'test'
}),
new webpack.optimize.DedupePlugin(),
new webpack.optimize.CommonsChunkPlugin({
name: 'vendor',
minChunks: function (module, count) {
// any required modules inside node_modules are extracted to vendor
return (
module.resource &&
/\.js$/.test(module.resource) &&
module.resource.indexOf(
path.join(__dirname, './node_modules')
) === 0
)
}
}),
// extract webpack runtime and module manifest to its own file in order to
// prevent vendor hash from being updated whenever app bundle is updated
new webpack.optimize.CommonsChunkPlugin({
name: 'manifest',
chunks: ['vendor']
}),
2016-10-30 09:29:51 +00:00
new HtmlWebpackPlugin({
// template: __dirname + '/app/' + 'index.html'
template: './client/app/index.html'
2016-10-30 09:29:51 +00:00
}),
new ExtractTextPlugin('styles.[chunkhash].css')
2016-10-30 09:29:51 +00:00
],
module: {
loaders: [
{test: /\.js$/, loader: 'ng-annotate!babel!eslint', exclude: /node_modules/},
{test: /\.html$/, loader: 'raw', exclude: [/node_modules/,/index\.html/]},
// {test: /\.css$/, loader: 'style!css', exclude: /node_modules/},
{test: /\.css$/, loader: ExtractTextPlugin.extract("css-loader") },
{test: /\.styl$/, loader: 'style!css!stylus', exclude: /node_modules/},
{
test: /\.(png|jpe?g|gif|svg)(\?.*)?$/,
loader: 'url',
query: {
limit: 10000,
name: 'img/[name].[hash:7].[ext]'
2016-10-30 09:29:51 +00:00
}
},
{
test: /\.(woff2?|eot|ttf|otf)(\?.*)?$/,
loader: 'url',
query: {
limit: 10000,
name: 'fonts/[name].[hash:7].[ext]'
2016-10-30 09:29:51 +00:00
}
}
]
},
2016-11-14 17:04:52 +00:00
// devtool: 'eval-source-map',
2016-11-22 12:27:11 +00:00
devtool: 'cheap-eval-source-map',
2016-10-30 09:29:51 +00:00
devServer: {
inline: true,
2016-10-31 22:40:46 +00:00
historyApiFallback: true,
2016-10-30 09:29:51 +00:00
proxy: {
'/login': {
target: redashBackend + '/',
secure: false
},
'/images': {
target: redashBackend + '/',
secure: false
},
'/js': {
target: redashBackend + '/',
secure: false
},
'/styles': {
target: redashBackend + '/',
secure: false
},
2016-11-02 10:56:44 +00:00
'/status.json': {
target: redashBackend + '/',
2016-11-02 10:56:44 +00:00
secure: false
},
'/api/admin': {
target: redashBackend + '/',
2016-11-02 10:56:44 +00:00
secure: false
},
2016-10-30 09:29:51 +00:00
'/api': {
target: redashBackend,
2016-10-30 09:29:51 +00:00
secure: false
}
}
}
};
if (process.env.DEV_SERVER_HOST) {
config.devServer.host = process.env.DEV_SERVER_HOST;
}
2016-10-30 09:29:51 +00:00
if (process.env.NODE_ENV === 'production') {
config.output.path = __dirname + '/client/dist';
2016-10-30 09:29:51 +00:00
config.plugins.push(new webpack.optimize.UglifyJsPlugin());
config.devtool = 'source-map';
}
module.exports = config;