diff --git a/package-lock.json b/package-lock.json index e2a4a97..8f4cae6 100644 --- a/package-lock.json +++ b/package-lock.json @@ -9,6 +9,7 @@ "version": "1.0.0", "dependencies": { "@fluentui/react-icons": "^2.0.320", + "@vercel/analytics": "^2.0.1", "fuse.js": "^7.1.0", "gray-matter": "^4.0.3", "next": "16.1.7", @@ -2631,6 +2632,7 @@ "version": "19.2.14", "resolved": "https://registry.npmjs.org/@types/react/-/react-19.2.14.tgz", "integrity": "sha512-ilcTH/UniCkMdtexkoCN0bI7pMcJDvmQFPvuPvmEaYA/NSfFTAgdUSLAoVjaRJm7+6PvcM+q1zYOwS4wTYMF9w==", + "dev": true, "license": "MIT", "dependencies": { "csstype": "^3.2.2" @@ -3222,6 +3224,48 @@ "win32" ] }, + "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/@vitest/coverage-v8": { "version": "4.0.18", "resolved": "https://registry.npmjs.org/@vitest/coverage-v8/-/coverage-v8-4.0.18.tgz", diff --git a/package.json b/package.json index 09057d6..85ddbb8 100644 --- a/package.json +++ b/package.json @@ -18,6 +18,7 @@ }, "dependencies": { "@fluentui/react-icons": "^2.0.320", + "@vercel/analytics": "^2.0.1", "fuse.js": "^7.1.0", "gray-matter": "^4.0.3", "next": "16.1.7", diff --git a/src/app/layout.tsx b/src/app/layout.tsx index f9a999d..21c8d4f 100644 --- a/src/app/layout.tsx +++ b/src/app/layout.tsx @@ -1,5 +1,6 @@ import type { Metadata } from "next"; import { ThemeProvider } from "next-themes"; +import { Analytics } from "@vercel/analytics/next"; import AppShell from "@/components/layout/AppShell"; import GoogleAnalytics from "@/components/analytics/GoogleAnalytics"; import CookieConsent from "@/components/ui/CookieConsent"; @@ -74,6 +75,7 @@ export default function RootLayout({ {children} + );