"use client"; import { IconBrandDiscord, IconBrandGithub, IconMenu2, IconX } from "@tabler/icons-react"; import { AnimatePresence, motion } from "motion/react"; import Link from "next/link"; import React, { useEffect, useState } from "react"; import { Logo } from "@/components/Logo"; import { ThemeTogglerComponent } from "@/components/theme/theme-toggle"; import { cn } from "@/lib/utils"; export const Navbar = () => { const [isScrolled, setIsScrolled] = useState(false); const navItems = [ { name: "Home", link: "/" }, { name: "Pricing", link: "/pricing" }, { name: "Sign In", link: "/login" }, { name: "Docs", link: "/docs" }, ]; useEffect(() => { const handleScroll = () => { setIsScrolled(window.scrollY > 20); }; window.addEventListener("scroll", handleScroll); return () => window.removeEventListener("scroll", handleScroll); }, []); return (
); }; const DesktopNav = ({ navItems, isScrolled }: any) => { const [hovered, setHovered] = useState(null); return ( { setHovered(null); }} className={cn( "mx-auto hidden w-full max-w-7xl flex-row items-center justify-between self-start rounded-full px-4 py-2 lg:flex transition-all duration-300", isScrolled ? "bg-white/80 backdrop-blur-md border border-white/20 shadow-lg dark:bg-neutral-950/80 dark:border-neutral-800/50" : "bg-transparent border border-transparent" )} >
SurfSense
{navItems.map((navItem: any, idx: number) => ( setHovered(idx)} className="relative px-4 py-2 text-neutral-600 dark:text-neutral-300" key={`link=${idx}`} href={navItem.link} > {hovered === idx && ( )} {navItem.name} ))}
8.3k Book a call
); }; const MobileNav = ({ navItems, isScrolled }: any) => { const [open, setOpen] = useState(false); return ( <>
SurfSense
{open ? ( setOpen(!open)} /> ) : ( setOpen(!open)} /> )}
{open && ( {navItems.map((navItem: any, idx: number) => ( {navItem.name} ))}
8.3k
)}
); };