diff --git a/package-lock.json b/package-lock.json index 9673378..f0649db 100644 --- a/package-lock.json +++ b/package-lock.json @@ -18,6 +18,7 @@ "@prisma/client": "^5.19.0", "@stream-io/node-sdk": "^0.7.56", "@stream-io/video-react-sdk": "^1.35.2", + "@vercel/speed-insights": "^2.0.0", "bcryptjs": "^3.0.2", "cloudinary": "^2.8.0", "clsx": "^2.1.1", @@ -5813,6 +5814,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/abort-controller": { "version": "3.0.0", "resolved": "https://registry.npmjs.org/abort-controller/-/abort-controller-3.0.0.tgz", diff --git a/package.json b/package.json index 3de4047..602bd21 100644 --- a/package.json +++ b/package.json @@ -21,6 +21,7 @@ "@prisma/client": "^5.19.0", "@stream-io/node-sdk": "^0.7.56", "@stream-io/video-react-sdk": "^1.35.2", + "@vercel/speed-insights": "^2.0.0", "bcryptjs": "^3.0.2", "cloudinary": "^2.8.0", "clsx": "^2.1.1", diff --git a/src/app/layout.tsx b/src/app/layout.tsx index 9334337..1f5012f 100644 --- a/src/app/layout.tsx +++ b/src/app/layout.tsx @@ -4,6 +4,7 @@ import Providers from "@/components/Providers"; import TopNav from "@/components/navbar/TopNav"; import { auth } from "@/auth"; import { getUserInfoForNav } from "@/app/actions/userActions"; +import { SpeedInsights } from "@vercel/speed-insights/next"; export const metadata: Metadata = { title: "Match Vault", @@ -41,6 +42,7 @@ export default async function RootLayout({ + );