scratch-www/webpack.config.js

126 lines
3.7 KiB
JavaScript
Raw Normal View History

var autoprefixer = require('autoprefixer');
2015-11-10 13:38:28 -05:00
var CopyWebpackPlugin = require('copy-webpack-plugin');
2016-04-28 15:40:50 -04:00
var gitsha = require('git-bundle-sha');
var MustacheRendererPlugin = require('./mustache-renderer-webpack-plugin');
2015-09-02 15:08:58 -04:00
var path = require('path');
var webpack = require('webpack');
var routes = require('./src/routes.json');
2016-04-12 08:23:43 -04:00
2016-05-11 18:44:54 -04:00
if (process.env.NODE_ENV !== 'production') {
routes = routes.concat(require('./src/routes-dev.json'));
}
2016-04-28 15:40:50 -04:00
var VersionPlugin = function (options) {
this.options = options || {};
return this;
};
VersionPlugin.prototype.apply = function (compiler) {
var addVersion = function (compilation, versionId, callback) {
compilation.assets['version.txt'] = {
source: function () {return versionId;},
size: function () {return versionId.length;}
};
callback();
};
var plugin = this;
compiler.plugin('emit', function (compilation, callback) {
var sha = process.env.WWW_VERSION;
if (!sha) {
gitsha(plugin.options, function (err, sha) {
if (err) return callback(err);
return addVersion(compilation, sha, callback);
});
} else {
return addVersion(compilation, sha, callback);
}
});
};
// Prepare all entry points
var entry = {
common: [
// Vendor
'raven-js',
'react',
'react-dom',
'react-intl',
'redux',
// Init
'./src/init.js'
]
};
routes.forEach(function (route) {
2016-04-09 13:07:21 -04:00
if (!route.redirect) {
entry[route.name] = './src/views/' + route.view + '.jsx';
2016-04-09 13:07:21 -04:00
}
});
// Config
2015-09-02 15:08:58 -04:00
module.exports = {
entry: entry,
devtool: 'eval',
2015-09-02 15:08:58 -04:00
output: {
2015-11-10 13:38:28 -05:00
path: path.resolve(__dirname, 'build'),
filename: 'js/[name].bundle.js'
2015-09-02 15:08:58 -04:00
},
module: {
loaders: [
{
test: /\.jsx$/,
loader: 'jsx-loader',
include: path.resolve(__dirname, 'src')
},
{
test: /\.json$/,
loader: 'json-loader'
2015-09-02 15:08:58 -04:00
},
{
test: /\.scss$/,
loader: 'style!css!postcss-loader!sass'
2015-09-08 14:56:28 -04:00
},
2016-06-02 15:25:02 -04:00
{
test: /\.css$/,
loader: 'style!css!postcss-loader'
},
2015-09-08 14:56:28 -04:00
{
test: /\.(png|jpg|gif|eot|svg|ttf|woff)$/,
loader: 'url-loader'
2015-09-02 15:08:58 -04:00
}
2016-06-02 15:25:02 -04:00
],
noParse: /node_modules\/google-libphonenumber\/dist/
2015-09-02 16:33:31 -04:00
},
postcss: function () {
return [autoprefixer({browsers: ['last 3 versions']})];
},
node: {
fs: 'empty'
},
2015-09-02 16:33:31 -04:00
plugins: [
2016-04-28 15:40:50 -04:00
new VersionPlugin({length: 5}),
new MustacheRendererPlugin({
templatePath: path.resolve(__dirname, './src/template.html'),
routes: routes,
config: require('./src/template-config.js')
2016-04-12 08:23:43 -04:00
}),
2015-11-10 13:38:28 -05:00
new CopyWebpackPlugin([
{from: 'static'},
{from: 'intl', to: 'js'}
2015-11-10 13:38:28 -05:00
]),
2015-09-02 16:33:31 -04:00
new webpack.optimize.UglifyJsPlugin({
compress: {
warnings: false
}
}),
new webpack.DefinePlugin({
'process.env.NODE_ENV': '"' + (process.env.NODE_ENV || 'development') + '"',
2016-06-06 10:10:27 -04:00
'process.env.SENTRY_DSN': '"' + (process.env.SENTRY_DSN || '') + '"',
'process.env.API_HOST': '"' + (process.env.API_HOST || 'https://api.scratch.mit.edu') + '"',
2016-06-30 18:06:17 -04:00
'process.env.SMARTY_STREETS_API_KEY': '"' + (process.env.SMARTY_STREETS_API_KEY || '') + '"',
'process.env.SCRATCH_ENV': '"'+ (process.env.SCRATCH_ENV || 'development') + '"'
}),
new webpack.optimize.CommonsChunkPlugin('common', 'js/common.bundle.js'),
new webpack.optimize.OccurenceOrderPlugin()
2015-09-02 16:33:31 -04:00
]
2015-09-02 15:08:58 -04:00
};