2024-10-04 18:25:37 +01:00
|
|
|
import { withSentryConfig } from "@sentry/nextjs";
|
|
|
|
import { format } from "@formkit/tempo";
|
2024-10-28 21:31:04 +00:00
|
|
|
import nextBundleAnalyzer from "@next/bundle-analyzer";
|
2024-10-26 14:58:44 +01:00
|
|
|
import type { NextConfig } from "next";
|
2024-10-28 22:14:00 +00:00
|
|
|
import { isProduction } from "@/common/website-utils";
|
2024-10-04 18:25:37 +01:00
|
|
|
|
2024-10-26 14:58:44 +01:00
|
|
|
const nextConfig: NextConfig = {
|
2024-10-23 16:30:53 +01:00
|
|
|
experimental: {
|
2024-10-27 10:59:41 +00:00
|
|
|
webpackMemoryOptimizations: true,
|
2024-10-23 16:30:53 +01:00
|
|
|
optimizePackageImports: ["@ssr/common", "@radix-ui/react-icons", "chart.js", "react-chartjs-2"],
|
|
|
|
},
|
2024-10-04 18:25:37 +01:00
|
|
|
images: {
|
2024-10-27 10:59:41 +00:00
|
|
|
unoptimized: true,
|
2024-10-04 18:25:37 +01:00
|
|
|
remotePatterns: [
|
|
|
|
{
|
|
|
|
protocol: "https",
|
|
|
|
hostname: "cdn.scoresaber.com",
|
|
|
|
port: "",
|
|
|
|
pathname: "/**",
|
|
|
|
},
|
|
|
|
],
|
|
|
|
},
|
|
|
|
env: {
|
2024-10-09 02:20:34 +01:00
|
|
|
HOSTNAME: "0.0.0.0",
|
2024-10-04 21:37:00 +01:00
|
|
|
NEXT_PUBLIC_BUILD_ID: process.env.GIT_REV || "dev",
|
2024-10-04 18:25:37 +01:00
|
|
|
NEXT_PUBLIC_BUILD_TIME: new Date().toLocaleDateString("en-US", {
|
|
|
|
year: "numeric",
|
|
|
|
month: "long",
|
|
|
|
day: "numeric",
|
|
|
|
hour: "numeric",
|
|
|
|
minute: "numeric",
|
|
|
|
timeZoneName: "short",
|
|
|
|
}),
|
|
|
|
NEXT_PUBLIC_BUILD_TIME_SHORT: format(new Date(), {
|
|
|
|
date: "short",
|
|
|
|
time: "short",
|
|
|
|
}),
|
|
|
|
},
|
|
|
|
};
|
|
|
|
|
2024-10-28 21:31:04 +00:00
|
|
|
const withBundleAnalyzer = nextBundleAnalyzer({
|
|
|
|
enabled: process.env.ANALYZE === "true",
|
2024-10-04 18:25:37 +01:00
|
|
|
});
|
2024-10-28 21:31:04 +00:00
|
|
|
|
2024-10-28 22:14:00 +00:00
|
|
|
const config = withBundleAnalyzer(nextConfig);
|
|
|
|
export default isProduction()
|
|
|
|
? withSentryConfig(config, {
|
|
|
|
org: "fascinatedcc",
|
|
|
|
project: "scoresaber-reloaded",
|
|
|
|
silent: !process.env.CI,
|
|
|
|
widenClientFileUpload: true,
|
|
|
|
reactComponentAnnotation: {
|
|
|
|
enabled: true,
|
|
|
|
},
|
|
|
|
hideSourceMaps: true,
|
|
|
|
disableLogger: true,
|
|
|
|
})
|
|
|
|
: config;
|