Files
8f4591f7-3bdb-444d-bf6d-def…/src/components/ui/ScrollReveal.tsx
2026-06-14 11:12:29 +00:00

45 lines
963 B
TypeScript

"use client";
import { motion } from "motion/react";
type Variant = "slide-up" | "fade-blur" | "fade";
interface ScrollRevealProps {
children: React.ReactNode;
variant: Variant;
delay?: number;
className?: string;
}
const VARIANTS = {
"slide-up": {
hidden: { opacity: 0, y: 20 },
visible: { opacity: 1, y: 0 },
},
"fade-blur": {
hidden: { opacity: 0, filter: "blur(10px)" },
visible: { opacity: 1, filter: "blur(0px)" },
},
"fade": {
hidden: { opacity: 0 },
visible: { opacity: 1 },
},
};
const ScrollReveal = ({ children, variant, delay = 0, className = "" }: ScrollRevealProps) => {
return (
<motion.div
initial="hidden"
whileInView="visible"
viewport={{ once: true, margin: "-20%" }}
variants={VARIANTS[variant]}
transition={{ duration: 0.6, delay, ease: "easeOut" }}
className={className}
>
{children}
</motion.div>
);
};
export default ScrollReveal;