import path from "path"; import type { NextConfig } from "next"; const nextConfig: NextConfig = { output: "standalone", devIndicators: false, experimental: { optimizePackageImports: ["recharts", "date-fns"], }, transpilePackages: [ "@planarchy/api", "@planarchy/db", "@planarchy/engine", "@planarchy/shared", "@planarchy/staffing", "@planarchy/ui", ], typedRoutes: true, async headers() { return [ { source: "/(.*)", headers: [ { key: "X-Frame-Options", value: "DENY" }, { key: "X-Content-Type-Options", value: "nosniff" }, { key: "Referrer-Policy", value: "strict-origin-when-cross-origin" }, { key: "Permissions-Policy", value: "camera=(), microphone=(), geolocation=()" }, ], }, ]; }, // Webpack config (used by `next build` and `next dev` without --turbo) webpack(config) { config.resolve.alias = { ...config.resolve.alias, "~": path.resolve(__dirname, "src"), }; // Resolve .js imports to .ts/.tsx (TypeScript ESM convention) config.resolve.extensionAlias = { ...config.resolve.extensionAlias, ".js": [".ts", ".tsx", ".js"], ".jsx": [".tsx", ".jsx"], }; return config; }, }; // Only wrap with Sentry in production — the worker.js crash in dev mode // (vendor-chunks/lib/worker.js MODULE_NOT_FOUND) makes the dev server unstable // Sentry only in production — dynamic import avoids side effects in dev let exportedConfig: NextConfig = nextConfig; if (process.env.NODE_ENV === "production") { try { const { withSentryConfig } = require("@sentry/nextjs"); exportedConfig = withSentryConfig(nextConfig, { silent: true, sourcemaps: { disable: true }, telemetry: false, }); } catch { // Sentry not available — use raw config } } export default exportedConfig;