-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathnext.config.ts
126 lines (109 loc) · 3.45 KB
/
next.config.ts
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
import type { NextConfig } from 'next'
import withPWAInit from '@ducanh2912/next-pwa'
import { withSentryConfig } from '@sentry/nextjs'
import type { RuleSetRule } from 'webpack'
import { IS_PROD } from './config/constants/main'
const nextConfig: NextConfig = {
images: {
remotePatterns: [
{
protocol: 'https',
hostname: '**.googleusercontent.com', // Google
port: '',
pathname: '/**',
},
{
protocol: 'https',
hostname: '**.githubusercontent.com', // GitHub
port: '',
pathname: '/**',
},
],
},
webpack: (config) => {
// Grab the existing rule that handles SVG imports.
const fileLoaderRule = config.module.rules.find(
(rule: RuleSetRule) =>
rule.test instanceof RegExp && rule.test.test('.svg'),
)
config.module.rules.push(
// Reapply the existing rule, but only for svg imports ending in ?url
{
...fileLoaderRule,
test: /\.svg$/i,
resourceQuery: /url/, // *.svg?url
},
// Convert all other *.svg imports to React components.
{
test: /\.svg$/i,
issuer: fileLoaderRule.issuer,
resourceQuery: { not: [...fileLoaderRule.resourceQuery.not, /url/] }, // exclude if *.svg?url
use: ['@svgr/webpack'],
},
)
// Modify the file loader rule to ignore *.svg, since we have it handled now.
fileLoaderRule.exclude = /\.svg$/i
return config
},
experimental: {
turbo: {
resolveExtensions: [
'.mdx',
'.tsx',
'.ts',
'.jsx',
'.js',
'.mjs',
'.json',
],
},
optimizePackageImports: [
'@ducanh2912/next-pwa',
'@heroui/react',
'@sentry/nextjs',
'framer-motion',
'tailwind-merge',
'resend',
'next-themes',
'react-confetti',
'next13-progressbar',
'emoji-regex',
'emoji-picker-react',
'react-hot-toast',
],
},
}
const withPWA = withPWAInit({
dest: 'public',
cacheOnFrontEndNav: true,
aggressiveFrontEndNavCaching: true,
extendDefaultRuntimeCaching: true,
disable: !IS_PROD,
})
const sentryConfig = {
// For all available options, see:
// https://github.com/getsentry/sentry-webpack-plugin#options
org: 'explend-app',
project: 'explend-app',
// Only print logs for uploading source maps in CI.
silent: !process.env.CI,
// For all available options, see:
// https://docs.sentry.io/platforms/javascript/guides/nextjs/manual-setup/
// Upload a larger set of source maps for prettier stack traces (increases build time).
widenClientFileUpload: true,
// Route browser requests to Sentry through a Next.js rewrite to circumvent ad-blockers.
// This can increase your server load as well as your hosting bill.
// Note: Check that the configured route will not match with your Next.js middleware, otherwise reporting of client-
// side errors will fail.
// tunnelRoute: '/monitoring',
// Hides source maps from generated client bundles.
hideSourceMaps: true,
// Automatically tree-shake Sentry logger statements to reduce bundle size.
disableLogger: true,
// Enables automatic instrumentation of Vercel Cron Monitors. (Does not yet work with App Router route handlers.)
// See the following for more information:
// https://docs.sentry.io/product/crons/
// https://vercel.com/docs/cron-jobs
// automaticVercelMonitors: true,
}
export default withSentryConfig(withPWA(nextConfig), sentryConfig)