'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; if (!('IntersectionObserver' in window)) { setVisible(true); return; } let cancelled = false; const observer = new IntersectionObserver( (entries) => { entries.forEach((entry) => { if (entry.isIntersecting) { if (!cancelled) setVisible(true); if (once) observer.unobserve(entry.target); } else if (!once) { if (!cancelled) setVisible(false); } }); }, { threshold: 0.05, rootMargin: '0px 0px -20% 0px' } ); observer.observe(el); const fallback = window.setTimeout(() => { if (!cancelled) setVisible(true); }, 500); return () => { cancelled = true; observer.disconnect(); window.clearTimeout(fallback); }; }, [once]); return (
{children}
); }