-
Notifications
You must be signed in to change notification settings - Fork 0
/
next.config.js
72 lines (67 loc) · 2.03 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
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
const withOffline = require('next-offline');
const withCSS = require('@zeit/next-css');
const withPlugins = require('next-compose-plugins');
const nextConfig = {
// devSwSrc: './public/service-worker.js',
// generateSw: true,
generateInDevMode: true,
transformManifest: manifest => ['/'].concat(manifest), // add the homepage to the cache
workboxOpts: {
swDest: '../public/service-worker.js',
runtimeCaching: [
{
urlPattern: /^https?.*/,
handler: 'NetworkFirst',
options: {
cacheName: 'https-calls',
networkTimeoutSeconds: 10,
expiration: {
maxEntries: 150,
maxAgeSeconds: 30 * 24 * 60 * 60, // 1 month
},
cacheableResponse: {
statuses: [0, 200],
},
},
},
],
},
webpack: (config, { buildId, dev, isServer, defaultLoaders, webpack }) => {
/**
Note: we provide webpack above so you should not `require` it
Perform customizations to webpack config
Important: return the modified config
*/
config.module.rules.push(
{
test: /\.wasm$/,
loader: 'wasm-loader',
},
{
test: /\.(eot|woff|woff2|ttf|svg|png|jpg|gif)$/,
use: {
loader: 'url-loader',
options: {
limit: 100000,
name: '[name].[ext]',
},
},
}
);
return config;
},
webpackDevMiddleware: config => {
/**
Perform customizations to webpack dev middleware config
Important: return the modified config
*/
return config;
},
};
module.exports = withPlugins(
[
withCSS,
// { cssModules: true }
],
withOffline(nextConfig)
);