'use client'; import * as React from 'react'; import { AnimatePresence, motion, type HTMLMotionProps, type Transition, } from 'motion/react'; import { cn } from '@workspace/ui/lib/utils'; type RotatingTextProps = { text: string | string[]; duration?: number; transition?: Transition; y?: number; containerClassName?: string; } & HTMLMotionProps<'div'>; function RotatingText({ text, y = -50, duration = 2000, transition = { duration: 0.3, ease: 'easeOut' }, containerClassName, ...props }: RotatingTextProps) { const [index, setIndex] = React.useState(0); React.useEffect(() => { if (!Array.isArray(text)) return; const interval = setInterval(() => { setIndex((prevIndex) => (prevIndex + 1) % text.length); }, duration); return () => clearInterval(interval); }, [text, duration]); const currentText = Array.isArray(text) ? text[index] : text; return (