mirror of
https://github.com/a-nyx/maputnik-with-pmtiles.git
synced 2024-12-27 09:15:29 +01:00
94 lines
2.3 KiB
JavaScript
94 lines
2.3 KiB
JavaScript
|
|
var webpack = require('webpack');
|
|
var path = require('path');
|
|
var loaders = require('./webpack.loaders');
|
|
var ExtractTextPlugin = require('extract-text-webpack-plugin');
|
|
var HtmlWebpackPlugin = require('html-webpack-plugin');
|
|
var WebpackCleanupPlugin = require('webpack-cleanup-plugin');
|
|
var BundleAnalyzerPlugin = require('webpack-bundle-analyzer').BundleAnalyzerPlugin;
|
|
var CopyWebpackPlugin = require('copy-webpack-plugin');
|
|
var UglifyJsPlugin = require('uglifyjs-webpack-plugin');
|
|
|
|
var OUTPATH;
|
|
if(process.env.CIRCLE_ARTIFACTS) {
|
|
OUTPATH = path.join(process.env.CIRCLE_ARTIFACTS, "build");
|
|
}
|
|
else {
|
|
OUTPATH = path.join(__dirname, '..', 'public');
|
|
}
|
|
|
|
module.exports = {
|
|
entry: {
|
|
app: './src/index.jsx',
|
|
vendor: [
|
|
'file-saver',
|
|
'mapbox-gl/dist/mapbox-gl.js',
|
|
"lodash.clonedeep",
|
|
"lodash.throttle",
|
|
'color',
|
|
'react',
|
|
"react-dom",
|
|
"react-color",
|
|
"react-file-reader-input",
|
|
"react-collapse",
|
|
"react-height",
|
|
"react-icon-base",
|
|
"react-motion",
|
|
"react-sortable-hoc",
|
|
"request",
|
|
//TODO: Icons raise multi vendor errors?
|
|
//"react-icons",
|
|
]
|
|
},
|
|
output: {
|
|
path: OUTPATH,
|
|
filename: '[name].[chunkhash].js',
|
|
chunkFilename: '[chunkhash].js'
|
|
},
|
|
resolve: {
|
|
extensions: ['.js', '.jsx']
|
|
},
|
|
module: {
|
|
noParse: [
|
|
/mapbox-gl\/dist\/mapbox-gl.js/
|
|
],
|
|
loaders
|
|
},
|
|
node: {
|
|
fs: "empty",
|
|
net: 'empty',
|
|
tls: 'empty'
|
|
},
|
|
plugins: [
|
|
new webpack.NoEmitOnErrorsPlugin(),
|
|
new webpack.optimize.CommonsChunkPlugin({ name: 'vendor', filename: '[chunkhash].vendor.js' }),
|
|
new WebpackCleanupPlugin(),
|
|
new webpack.DefinePlugin({
|
|
'process.env': {
|
|
NODE_ENV: '"production"'
|
|
}
|
|
}),
|
|
new UglifyJsPlugin(),
|
|
new ExtractTextPlugin('[contenthash].css', {
|
|
allChunks: true
|
|
}),
|
|
new HtmlWebpackPlugin({
|
|
template: './src/template.html',
|
|
title: 'Maputnik'
|
|
}),
|
|
new CopyWebpackPlugin([
|
|
{
|
|
from: './src/manifest.json',
|
|
to: 'manifest.json'
|
|
}
|
|
]),
|
|
new BundleAnalyzerPlugin({
|
|
analyzerMode: 'static',
|
|
defaultSizes: 'gzip',
|
|
openAnalyzer: false,
|
|
generateStatsFile: true,
|
|
reportFilename: 'bundle-stats.html',
|
|
statsFilename: 'bundle-stats.json',
|
|
})
|
|
]
|
|
};
|