'use client'; import { useEffect, useRef, useState } from 'react'; import clsx from 'clsx'; interface ScrollRevealProps { children: React.ReactNode; className?: string; once?: boolean; } export function ScrollReveal({ children, className, once = true }: ScrollRevealProps) { const ref = useRef(null); const [visible, setVisible] = useState(false); useEffect(() => { const el = ref.current; if (!el) return; const observer = new IntersectionObserver( (entries) => { entries.forEach((entry) => { if (entry.isIntersecting) { setVisible(true); if (once) observer.unobserve(entry.target); } else if (!once) { setVisible(false); } }); }, { threshold: 0.15 } ); observer.observe(el); return () => observer.disconnect(); }, [once]); return (
{children}
); }