Spaces:
Build error
Build error
File size: 1,194 Bytes
75fefa7 |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 |
"use client";
import { motion, TargetAndTransition, Transition } from "motion/react";
import { useEffect, useRef, useState } from "react";
type AnimatedWidthProps = {
children: React.ReactNode;
animate?: TargetAndTransition;
initial?: TargetAndTransition;
transition?: Transition;
};
export default function AnimatedWidth({
children,
...attrs
}: AnimatedWidthProps) {
const containerRef = useRef<HTMLDivElement>(null);
const [width, setWidth] = useState<number | "auto">("auto");
useEffect(() => {
const child = containerRef.current?.children[0] as Element;
const updateWidth = () => {
if (!child) return;
setWidth(child.clientWidth);
};
updateWidth();
const resizeObserver = new ResizeObserver(updateWidth);
resizeObserver.observe(child);
return () => resizeObserver.disconnect();
}, []);
return (
<motion.div
{...attrs}
animate={{
width,
...attrs.animate,
}}
className="overflow-hidden"
initial={{
width,
...attrs.initial,
}}
ref={containerRef}
>
<div className="w-max whitespace-nowrap">{children}</div>
</motion.div>
);
}
|