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({
+