feat: clean up RotatingWord component styles
This commit is contained in:
@@ -0,0 +1,41 @@
|
|||||||
|
"use client";
|
||||||
|
|
||||||
|
import { useEffect, useState } from "react";
|
||||||
|
|
||||||
|
type RotatingWordProps = {
|
||||||
|
items: string[];
|
||||||
|
intervalSeconds?: number;
|
||||||
|
};
|
||||||
|
|
||||||
|
export default function RotatingWord({
|
||||||
|
items,
|
||||||
|
intervalSeconds = 2.5,
|
||||||
|
}: RotatingWordProps) {
|
||||||
|
const [activeIndex, setActiveIndex] = useState(0);
|
||||||
|
|
||||||
|
useEffect(() => {
|
||||||
|
if (items.length <= 1) return;
|
||||||
|
const id = setInterval(() => {
|
||||||
|
setActiveIndex((i) => (i + 1) % items.length);
|
||||||
|
}, intervalSeconds * 1000);
|
||||||
|
return () => clearInterval(id);
|
||||||
|
}, [items.length, intervalSeconds]);
|
||||||
|
|
||||||
|
return (
|
||||||
|
<span className="relative inline-block align-baseline">
|
||||||
|
{items.map((word, i) => (
|
||||||
|
<span
|
||||||
|
key={word}
|
||||||
|
aria-hidden={i !== activeIndex}
|
||||||
|
className={`transition-all ease-out ${
|
||||||
|
i === activeIndex
|
||||||
|
? "opacity-100 translate-y-0 scale-100 duration-1200"
|
||||||
|
: "absolute top-0 left-0 opacity-0 pointer-events-none duration-0"
|
||||||
|
}`}
|
||||||
|
>
|
||||||
|
{word}
|
||||||
|
</span>
|
||||||
|
))}
|
||||||
|
</span>
|
||||||
|
);
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user