-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathnext.config.js
48 lines (42 loc) · 1.35 KB
/
next.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
const path = require('path');
const withBundleAnalyzer = require('@next/bundle-analyzer')({
enabled: process.env.ANALYZE === 'true'
});
const WasmPackPlugin = require('@wasm-tool/wasm-pack-plugin');
module.exports = withBundleAnalyzer({
webpack(config, { isServer, dev }) {
config.experiments = {
asyncWebAssembly: true,
layers: true
};
// Plugin appends hashes to output chunk file names
config.plugins.push(
new WasmPackPlugin({
crateDirectory: path.resolve(__dirname, './mandelbrot-generator'),
args: '--log-level warn'
})
);
if (!dev && isServer) {
config.output.webassemblyModuleFilename = 'chunks/[id].wasm';
config.plugins.push(new WasmChunksFixPlugin());
}
return config;
}
});
class WasmChunksFixPlugin {
apply(compiler) {
compiler.hooks.thisCompilation.tap('WasmChunksFixPlugin', compilation => {
compilation.hooks.processAssets.tap(
{ name: 'WasmChunksFixPlugin' },
assets =>
Object.entries(assets).forEach(([pathname, source]) => {
if (!pathname.match(/\.wasm$/)) return;
compilation.deleteAsset(pathname);
const name = pathname.split('/')[1];
const info = compilation.assetsInfo.get(pathname);
compilation.emitAsset(name, source, info);
})
);
});
}
}