diff --git a/package-lock.json b/package-lock.json index 4f4d931..cf4103d 100644 --- a/package-lock.json +++ b/package-lock.json @@ -13,6 +13,7 @@ "@ai-sdk/react": "^3.0.88", "@pinecone-database/pinecone": "^7.0.0", "@types/glob": "^8.1.0", + "@vercel/analytics": "^1.6.1", "ai": "^6.0.86", "clsx": "^2.1.1", "cytoscape": "^3.33.1", @@ -3133,6 +3134,44 @@ "win32" ] }, + "node_modules/@vercel/analytics": { + "version": "1.6.1", + "resolved": "https://registry.npmjs.org/@vercel/analytics/-/analytics-1.6.1.tgz", + "integrity": "sha512-oH9He/bEM+6oKlv3chWuOOcp8Y6fo6/PSro8hEkgCW3pu9/OiCXiUpRUogDh3Fs3LH2sosDrx8CxeOLBEE+afg==", + "license": "MPL-2.0", + "peerDependencies": { + "@remix-run/react": "^2", + "@sveltejs/kit": "^1 || ^2", + "next": ">= 13", + "react": "^18 || ^19 || ^19.0.0-rc", + "svelte": ">= 4", + "vue": "^3", + "vue-router": "^4" + }, + "peerDependenciesMeta": { + "@remix-run/react": { + "optional": true + }, + "@sveltejs/kit": { + "optional": true + }, + "next": { + "optional": true + }, + "react": { + "optional": true + }, + "svelte": { + "optional": true + }, + "vue": { + "optional": true + }, + "vue-router": { + "optional": true + } + } + }, "node_modules/@vercel/oidc": { "version": "3.1.0", "resolved": "https://registry.npmjs.org/@vercel/oidc/-/oidc-3.1.0.tgz", diff --git a/package.json b/package.json index 092f215..bcd3b73 100644 --- a/package.json +++ b/package.json @@ -31,6 +31,7 @@ "@ai-sdk/react": "^3.0.88", "@pinecone-database/pinecone": "^7.0.0", "@types/glob": "^8.1.0", + "@vercel/analytics": "^1.6.1", "ai": "^6.0.86", "clsx": "^2.1.1", "cytoscape": "^3.33.1", diff --git a/src/app/layout.tsx b/src/app/layout.tsx index 8f9eeb8..9a5364f 100644 --- a/src/app/layout.tsx +++ b/src/app/layout.tsx @@ -1,6 +1,7 @@ import type { Metadata, Viewport } from "next"; import { Inter, JetBrains_Mono, DM_Serif_Display } from "next/font/google"; import { ThemeProvider } from "next-themes"; +import { Analytics } from "@vercel/analytics/next"; import { ArticlePanelProvider } from "@/contexts/article-panel-context"; import { SlideOutPanel } from "@/components/article/slide-out-panel"; import { QuickAddFab } from "@/components/workspace/quick-add-fab"; @@ -102,6 +103,7 @@ export default function RootLayout({ +