-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathnext.config.js
75 lines (59 loc) · 2 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
73
74
75
/* eslint-disable @typescript-eslint/no-var-requires */
const SentryWebpackPlugin = require('@sentry/webpack-plugin');
const withSourceMaps = require('@zeit/next-source-maps');
const withPlugins = require('next-compose-plugins');
if (!process.env.SENTRY_DSN) { // Only if envs empty
require('dotenv').config();
}
const { SENTRY_DSN, SENTRY_ORG, SENTRY_PROJECT, AMPLITUDE_KEY, SEGMENT_PROD, SEGMENT_DEV, NODE_ENV } = process.env;
const publicEnvs = {
SENTRY_DSN, SENTRY_ORG, SENTRY_PROJECT, // sentry error logging
AMPLITUDE_KEY, SEGMENT_PROD, SEGMENT_DEV, // amplitude and segment
}
// next.js configuration
const nextConfig = {
publicRuntimeConfig: publicEnvs,
env: publicEnvs,
exportPathMap: function () {
return {
'/': { page: '/' },
};
},
webpack: (config, { isServer }) => {
if (!isServer) {
config.resolve.alias['@sentry/node'] = '@sentry/browser'
}
// ESlint plugin
config.module.rules.push(
{
test: /\.js$/,
enforce: 'pre',
exclude: /node_modules/,
loader: 'eslint-loader',
},
);
// When all the Sentry configuration env variables are available/configured
// The Sentry webpack plugin gets pushed to the webpack plugins to build
// and upload the source maps to sentry.
// This is an alternative to manually uploading the source maps
if (SENTRY_DSN && SENTRY_ORG && SENTRY_PROJECT) {
// Do not upload source map on dev
if (NODE_ENV != 'development') {
config.plugins.push(
new SentryWebpackPlugin({
include: '.next',
ignore: ['node_modules'],
urlPrefix: '~/_next',
})
)
}
}
return config;
},
};
module.exports = withPlugins(
[
withSourceMaps,
],
nextConfig
);