forked from visgl/deck.gl
-
Notifications
You must be signed in to change notification settings - Fork 0
/
webpack.config.js
57 lines (48 loc) · 1.63 KB
/
webpack.config.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
// NOTE: To use this example standalone (e.g. outside of deck.gl repo)
// delete the local development overrides at the bottom of this file
// avoid destructuring for older Node version support
const resolve = require('path').resolve;
const webpack = require('webpack');
const CONFIG = {
mode: 'development',
devtool: 'source-map',
// bundle app.js and everything it imports, recursively.
entry: {
app: resolve('./src')
},
resolve: {
// Make src files outside of this dir resolve modules in our node_modules folder
modules: [resolve(__dirname, '.'), resolve(__dirname, 'node_modules'), 'node_modules'],
alias: {
// From mapbox-gl-js README. Required for non-browserify bundlers (e.g. webpack):
'mapbox-gl$': resolve('./node_modules/mapbox-gl/dist/mapbox-gl.js')
}
},
module: {
rules: [
{
// Remove if your app does not use JSX or you don't need to support old browsers
test: /\.js$/,
loader: 'babel-loader',
exclude: [/node_modules/],
options: {
presets: ['@babel/preset-react']
}
}
// ,
// {
// // The example has some JSON data
// test: /\.json$/,
// loader: 'json-loader',
// exclude: [/node_modules/]
// }
]
},
node: {
fs: 'empty'
},
// Optional: Enables reading mapbox token from environment variable
plugins: [new webpack.EnvironmentPlugin(['MapboxAccessToken'])]
};
// This line enables bundling against src in this repo rather than installed deck.gl module
module.exports = env => (env ? require('../webpack.config.local')(CONFIG, __dirname)(env) : CONFIG);