diff --git a/packages/frontend/package-lock.json b/packages/frontend/package-lock.json index 6a19d0c..165be81 100644 --- a/packages/frontend/package-lock.json +++ b/packages/frontend/package-lock.json @@ -18,6 +18,7 @@ "@rainbow-me/rainbowkit": "^2.1.0", "@tailwindcss/postcss": "^4.2.4", "@tanstack/react-query": "^5.100.7", + "@vercel/analytics": "^2.0.1", "class-variance-authority": "^0.7.1", "clsx": "^2.1.1", "framer-motion": "^12.38.0", @@ -6168,6 +6169,48 @@ "@vanilla-extract/css": "^1.0.0" } }, + "node_modules/@vercel/analytics": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/@vercel/analytics/-/analytics-2.0.1.tgz", + "integrity": "sha512-MTQG6V9qQrt1tsDeF+2Uoo5aPjqbVPys1xvnIftXSJYG2SrwXRHnqEvVoYID7BTruDz4lCd2Z7rM1BdkUehk2g==", + "license": "MIT", + "peerDependencies": { + "@remix-run/react": "^2", + "@sveltejs/kit": "^1 || ^2", + "next": ">= 13", + "nuxt": ">= 3", + "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 + }, + "nuxt": { + "optional": true + }, + "react": { + "optional": true + }, + "svelte": { + "optional": true + }, + "vue": { + "optional": true + }, + "vue-router": { + "optional": true + } + } + }, "node_modules/@vitejs/plugin-react": { "version": "6.0.1", "resolved": "https://registry.npmjs.org/@vitejs/plugin-react/-/plugin-react-6.0.1.tgz", diff --git a/packages/frontend/package.json b/packages/frontend/package.json index 6694fe2..812b648 100644 --- a/packages/frontend/package.json +++ b/packages/frontend/package.json @@ -21,6 +21,7 @@ "@rainbow-me/rainbowkit": "^2.1.0", "@tailwindcss/postcss": "^4.2.4", "@tanstack/react-query": "^5.100.7", + "@vercel/analytics": "^2.0.1", "class-variance-authority": "^0.7.1", "clsx": "^2.1.1", "framer-motion": "^12.38.0", diff --git a/packages/frontend/src/app/layout.tsx b/packages/frontend/src/app/layout.tsx index 10eb0cf..aba6704 100644 --- a/packages/frontend/src/app/layout.tsx +++ b/packages/frontend/src/app/layout.tsx @@ -1,6 +1,7 @@ import type { Metadata } from "next"; import { Inter, JetBrains_Mono } from "next/font/google"; import { Providers } from "@/components/providers"; +import { Analytics } from "@vercel/analytics/next"; import "./globals.css"; const inter = Inter({ @@ -37,6 +38,7 @@ export default function RootLayout({