import { useState, useRef, useEffect } from "react"; import { cn } from "@/lib/utils"; interface LazyImageProps { src: string; alt: string; className?: string; placeholder?: string; onLoad?: () => void; onError?: () => void; } export default function LazyImage({ src, alt, className, placeholder = "", onLoad, onError }: LazyImageProps) { const [isLoaded, setIsLoaded] = useState(false); const [isInView, setIsInView] = useState(false); const [hasError, setHasError] = useState(false); const imgRef = useRef(null); useEffect(() => { const observer = new IntersectionObserver( ([entry]) => { if (entry.isIntersecting) { setIsInView(true); observer.disconnect(); } }, { threshold: 0.1, rootMargin: '50px' } ); if (imgRef.current) { observer.observe(imgRef.current); } return () => observer.disconnect(); }, []); const handleLoad = () => { setIsLoaded(true); onLoad?.(); }; const handleError = () => { setHasError(true); onError?.(); }; return (
{alt}
); }