diff --git a/package-lock.json b/package-lock.json index 05ddefa..ffa458e 100644 --- a/package-lock.json +++ b/package-lock.json @@ -54,6 +54,7 @@ "@trpc/server": "^11.4.3", "@trpc/tanstack-react-query": "^11.4.3", "@types/http-proxy": "^1.17.17", + "@vercel/speed-insights": "^2.0.0", "class-variance-authority": "^0.7.1", "client-only": "^0.0.1", "clsx": "^2.1.1", @@ -6680,6 +6681,44 @@ "win32" ] }, + "node_modules/@vercel/speed-insights": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/@vercel/speed-insights/-/speed-insights-2.0.0.tgz", + "integrity": "sha512-jwkNcrTeafWxjmWq4AHBaptSqZiJkYU5adLC9QBSqeim0GcqDMgN5Ievh8OG1rJ6W3A4l1oiP7qr9CWxGuzu3w==", + "license": "Apache-2.0", + "peerDependencies": { + "@sveltejs/kit": "^1 || ^2", + "next": ">= 13", + "nuxt": ">= 3", + "react": "^18 || ^19 || ^19.0.0-rc", + "svelte": ">= 4", + "vue": "^3", + "vue-router": "^4" + }, + "peerDependenciesMeta": { + "@sveltejs/kit": { + "optional": true + }, + "next": { + "optional": true + }, + "nuxt": { + "optional": true + }, + "react": { + "optional": true + }, + "svelte": { + "optional": true + }, + "vue": { + "optional": true + }, + "vue-router": { + "optional": true + } + } + }, "node_modules/accepts": { "version": "2.0.0", "resolved": "https://registry.npmjs.org/accepts/-/accepts-2.0.0.tgz", diff --git a/package.json b/package.json index 25c3fae..9087faa 100644 --- a/package.json +++ b/package.json @@ -64,6 +64,7 @@ "@trpc/server": "^11.4.3", "@trpc/tanstack-react-query": "^11.4.3", "@types/http-proxy": "^1.17.17", + "@vercel/speed-insights": "^2.0.0", "class-variance-authority": "^0.7.1", "client-only": "^0.0.1", "clsx": "^2.1.1", diff --git a/src/app/layout.tsx b/src/app/layout.tsx index a563de4..d76c3dc 100644 --- a/src/app/layout.tsx +++ b/src/app/layout.tsx @@ -15,6 +15,7 @@ import { SiteHeader } from "@/components/site-header"; import { BackendWarmup } from "@/components/backend-warmup"; import { SettingsProvider } from "@/contexts/settings-context"; import { getSiteUrl } from "@/lib/site-url"; +import { SpeedInsights } from "@vercel/speed-insights/next"; const geistSans = Geist({ variable: "--font-geist-sans", @@ -150,6 +151,7 @@ export default function RootLayout({ +