-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathwebpack.dev.mjs
More file actions
executable file
·153 lines (151 loc) · 5.77 KB
/
Copy pathwebpack.dev.mjs
File metadata and controls
executable file
·153 lines (151 loc) · 5.77 KB
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
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
import webpack from 'webpack'
import path, { dirname } from 'path'
import { fileURLToPath } from 'url'
import { setupMiddlewares } from './demo/server/main.js'
import MiniCssExtractPlugin from 'mini-css-extract-plugin'
import CopyPlugin from 'copy-webpack-plugin'
import dotenv from 'dotenv'
const __dirname = dirname(fileURLToPath(import.meta.url))
dotenv.config({ path: path.join(__dirname, './.env'), quiet: true })
export default {
mode: 'development',
target: ['web', 'es5'],
devtool: [
// produce a source-map to aid debugging
{ type: 'javascript', use: 'source-map' }
],
entry: {
index: path.join(__dirname, 'demo/js/index.js'),
draw: path.join(__dirname, 'demo/js/draw.js'),
'draw-ol': path.join(__dirname, 'demo/js/draw-ol.js'),
farming: path.join(__dirname, 'demo/js/farming.js'),
planning: path.join(__dirname, 'demo/js/planning.js'),
'planning-ol': path.join(__dirname, 'demo/js/planning-ol.js'),
gep: path.join(__dirname, 'demo/js/gep.js'),
'ml-datasets': path.join(__dirname, 'demo/js/ml-datasets.js'),
esm: path.join(__dirname, 'demo/js/esm.js'),
multimap: path.join(__dirname, 'demo/js/multimap.js')
},
output: {
path: path.resolve(__dirname, 'public'),
filename: '[name].js',
clean: true
},
resolve: {
extensions: ['.tsx', '.ts', '.jsx', '.js'],
alias: {
// Redirect react imports to preact/compat so the dev build is consistent
// with the ESM dist, which externalises preact and aliases react at build time.
// Without this, the ESM dist chunks run on preact while the rest of the app
// runs on React — two incompatible reconcilers sharing one component tree.
react: path.resolve(__dirname, 'node_modules/preact/compat'),
'react-dom/client': path.resolve(__dirname, 'node_modules/preact/compat/client'),
'react-dom': path.resolve(__dirname, 'node_modules/preact/compat'),
'react/jsx-runtime': path.resolve(__dirname, 'node_modules/preact/jsx-runtime'),
// Force these to resolve from root node_modules, preventing nested copies
// inside geojson-rbush and mapbox-gl-snap from being bundled separately.
'@turf/meta': path.resolve(__dirname, 'node_modules/@turf/meta'),
'@turf/helpers': path.resolve(__dirname, 'node_modules/@turf/helpers'),
'robust-predicates': path.resolve(__dirname, 'node_modules/robust-predicates')
}
},
plugins: [
new MiniCssExtractPlugin({
filename: '[name].css'
}),
new CopyPlugin({
patterns: [
{
from: 'node_modules/govuk-frontend/dist/govuk/govuk-frontend.min.css',
to: 'assets/govuk-frontend.min.css'
},
{
from: 'node_modules/govuk-frontend/dist/govuk/assets',
to: 'assets'
}
]
}),
new webpack.DefinePlugin({
'process.env': {
// OS Open Zoomstack
OZS_OUTDOOR_URL: JSON.stringify(process.env.OZS_OUTDOOR_URL),
OZS_NIGHT_URL: JSON.stringify(process.env.OZS_NIGHT_URL),
OZS_DEUTERANOPIA_URL: JSON.stringify(process.env.OZS_DEUTERANOPIA_URL),
OZS_TRITANOPIA_URL: JSON.stringify(process.env.OZS_TRITANOPIA_URL),
// OS Vector Tile API (3857)
VTS_OUTDOOR_URL: JSON.stringify(process.env.VTS_OUTDOOR_URL),
VTS_DARK_URL: JSON.stringify(process.env.VTS_DARK_URL),
VTS_BLACK_AND_WHITE_URL: JSON.stringify(process.env.VTS_BLACK_AND_WHITE_URL),
// OS Vector Tile API (27700)
VTS_OUTDOOR_URL_27700: JSON.stringify(process.env.VTS_OUTDOOR_URL_27700),
VTS_DARK_URL_27700: JSON.stringify(process.env.VTS_DARK_URL_27700),
VTS_BLACK_AND_WHITE_URL_27700: JSON.stringify(process.env.VTS_BLACK_AND_WHITE_URL_27700),
// OS NGD Tiles API (OGC, 27700)
NGD_OUTDOOR_URL_27700: JSON.stringify(process.env.NGD_OUTDOOR_URL_27700),
NGD_BLACK_AND_WHITE_URL_27700: JSON.stringify(process.env.NGD_BLACK_AND_WHITE_URL_27700),
// Aerial photography
AERIAL_URL: JSON.stringify(process.env.AERIAL_URL),
APGB_WMS_URL: JSON.stringify(process.env.APGB_WMS_URL),
// OS Maps API (27700 raster)
MAPS_OUTDOOR_URL: JSON.stringify(process.env.MAPS_OUTDOOR_URL),
MAPS_ROAD_URL: JSON.stringify(process.env.MAPS_ROAD_URL),
MAPS_LIGHT_URL: JSON.stringify(process.env.MAPS_LIGHT_URL),
// OS Auth
OS_CLIENT_ID: JSON.stringify(process.env.OS_CLIENT_ID),
OS_CLIENT_SECRET: JSON.stringify(process.env.OS_CLIENT_SECRET),
// OS Names API
OS_NAMES_URL: JSON.stringify(process.env.OS_NAMES_URL),
OS_NEAREST_URL: JSON.stringify(process.env.OS_NEAREST_URL),
// Data services
FARMING_TILE_SERVICE_URL: JSON.stringify(process.env.FARMING_TILE_SERVICE_URL),
FARMING_API_URL: JSON.stringify(process.env.FARMING_API_URL)
}
})
],
module: {
rules: [
{
test: /\.jsx?$/,
loader: 'babel-loader',
exclude: /node_modules/
}, {
test: /\.s[ac]ss$/i,
use: [MiniCssExtractPlugin.loader, 'css-loader', 'sass-loader']
}, {
test: /\.css$/i,
use: [MiniCssExtractPlugin.loader, 'css-loader']
}
]
},
devServer: {
static: [
{
directory: path.join(__dirname, 'demo')
},
{
directory: path.join(__dirname, 'public')
},
{
directory: path.join(__dirname, 'assets'),
publicPath: '/assets' // Images served from here as used in both demo and prototype kit plugin
},
{
directory: __dirname,
watch: false // serve built dist files (e.g. dist/umd/) without watching for changes
}
],
compress: true,
port: 8080,
open: true,
hot: true,
setupMiddlewares
},
optimization: {
chunkIds: 'named',
splitChunks: {
chunks () {
return false
}
}
}
}