MBO-Tech-IT-Webseite/components/ScrollReveal.tsx

48 lines
1.1 KiB
TypeScript

// components/ScrollReveal.tsx
"use client";
import { useEffect, useRef, useState } from "react";
interface ScrollRevealProps {
children: React.ReactNode;
delay?: number;
className?: string;
}
export default function ScrollReveal({ children, delay = 0, className = "" }: ScrollRevealProps) {
const ref = useRef<HTMLDivElement>(null);
const [visible, setVisible] = useState(false);
useEffect(() => {
const el = ref.current;
if (!el) return;
const observer = new IntersectionObserver(
([entry]) => {
if (entry.isIntersecting) {
setVisible(true);
observer.disconnect();
}
},
{ threshold: 0.1 }
);
observer.observe(el);
return () => observer.disconnect();
}, []);
return (
<div
ref={ref}
className={className}
style={{
opacity: visible ? 1 : 0,
transform: visible ? "translateY(0)" : "translateY(24px)",
transition: `opacity 500ms ease-out ${delay}ms, transform 500ms ease-out ${delay}ms`,
}}
>
{children}
</div>
);
}