-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathnext.config.js
117 lines (99 loc) · 3.51 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
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
import { fileURLToPath } from "node:url";
import { withSentryConfig } from "@sentry/nextjs";
import withSerwistInit from "@serwist/next";
import { createJiti } from "jiti";
import { withAxiom } from "next-axiom";
import ReactComponentName from "react-scan/react-component-name/webpack";
// @ts-check
const withSerwist = withSerwistInit({
swSrc: "src/sw.ts",
swDest: "public/sw.js",
});
const jiti = createJiti(fileURLToPath(import.meta.url));
/**
* Run `build` or `dev` with `SKIP_ENV_VALIDATION` to skip env validation. This is especially useful
* for Docker builds.
*/
await jiti.import("./src/env.ts");
/** @type {import("next").NextConfig} */
const baseConfig = withAxiom(
withSerwist({
transpilePackages: ["geist"],
experimental: {
reactCompiler: true,
},
async redirects() {
return [
{
source: "/github",
destination: "https://github.com/FleetAdmiralJakob/chat-io",
permanent: true,
},
];
},
async rewrites() {
return [
{
source: "/home",
destination: "/",
},
{
source: "/ingest/static/:path*",
destination: process.env.NEXT_PUBLIC_POSTHOG_HOST + "/static/:path*",
},
{
source: "/ingest/:path*",
destination: process.env.NEXT_PUBLIC_POSTHOG_HOST + "/:path*",
},
{
source: "/ingest/decide",
destination: process.env.NEXT_PUBLIC_POSTHOG_HOST + "/decide",
},
];
},
// This is required to support PostHog trailing slash API requests
skipTrailingSlashRedirect: true,
// Next.js being Next.js and not providing any type definitions for their own config
webpack: (config) => {
// eslint-disable-next-line @typescript-eslint/no-unsafe-call, @typescript-eslint/no-unsafe-member-access
config.plugins.push(ReactComponentName({}));
// eslint-disable-next-line @typescript-eslint/no-unsafe-return
return config;
},
}),
);
const config = withSentryConfig(baseConfig, {
// For all available options, see:
// https://github.com/getsentry/sentry-webpack-plugin#options
org: "jakob-rossner",
project: "chat-io",
// 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,
// Automatically annotate React components to show their full name in breadcrumbs and session replay
reactComponentAnnotation: {
enabled: 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,
sourcemaps: {
disable: false,
deleteSourcemapsAfterUpload: true,
},
});
export default config;