diff --git a/package-lock.json b/package-lock.json index aa7c395..9e105ad 100644 --- a/package-lock.json +++ b/package-lock.json @@ -10,6 +10,7 @@ "dependencies": { "@supabase/supabase-js": "^2.45.0", "@vercel/analytics": "^1.6.1", + "@vercel/speed-insights": "^1.3.1", "next": "14.2.35", "nodemailer": "^6.9.16", "react": "^18.3.1", @@ -1242,6 +1243,40 @@ } } }, + "node_modules/@vercel/speed-insights": { + "version": "1.3.1", + "resolved": "https://registry.npmjs.org/@vercel/speed-insights/-/speed-insights-1.3.1.tgz", + "integrity": "sha512-PbEr7FrMkUrGYvlcLHGkXdCkxnylCWePx7lPxxq36DNdfo9mcUjLOmqOyPDHAOgnfqgGGdmE3XI9L/4+5fr+vQ==", + "license": "Apache-2.0", + "peerDependencies": { + "@sveltejs/kit": "^1 || ^2", + "next": ">= 13", + "react": "^18 || ^19 || ^19.0.0-rc", + "svelte": ">= 4", + "vue": "^3", + "vue-router": "^4" + }, + "peerDependenciesMeta": { + "@sveltejs/kit": { + "optional": true + }, + "next": { + "optional": true + }, + "react": { + "optional": true + }, + "svelte": { + "optional": true + }, + "vue": { + "optional": true + }, + "vue-router": { + "optional": true + } + } + }, "node_modules/acorn": { "version": "8.15.0", "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.15.0.tgz", diff --git a/package.json b/package.json index d579f5c..8a8e4bb 100644 --- a/package.json +++ b/package.json @@ -11,6 +11,7 @@ "dependencies": { "@supabase/supabase-js": "^2.45.0", "@vercel/analytics": "^1.6.1", + "@vercel/speed-insights": "^1.3.1", "next": "14.2.35", "nodemailer": "^6.9.16", "react": "^18.3.1", diff --git a/src/app/layout.tsx b/src/app/layout.tsx index 75ad93f..d806cf9 100644 --- a/src/app/layout.tsx +++ b/src/app/layout.tsx @@ -1,6 +1,7 @@ import type { Metadata } from "next"; import { Outfit } from "next/font/google"; import { Analytics } from "@vercel/analytics/next"; +import { SpeedInsights } from "@vercel/speed-insights/next"; import "./globals.css"; const outfit = Outfit({ @@ -25,6 +26,7 @@ export default function RootLayout({
{children}