app-vibrant-gecko-yawn/components/testimonial-column-containe...

44 lines
962 B
TypeScript

"use client";
import { cn } from "@/lib/utils";
import { useEffect, useRef, useState } from "react";
export function TestimonialColumnContainer({
className,
shift = 0,
children,
}: {
className?: string;
shift?: number;
children: React.ReactNode;
}) {
let columnRef = useRef<React.ElementRef<"div">>(null);
let [columnHeight, setColumnHeight] = useState(0);
let duration = `${columnHeight * shift}ms`;
useEffect(() => {
if (!columnRef.current) {
return;
}
let resizeObserver = new window.ResizeObserver(() => {
setColumnHeight(columnRef.current?.offsetHeight ?? 0);
});
resizeObserver.observe(columnRef.current);
return () => {
resizeObserver.disconnect();
};
}, []);
return (
<div
ref={columnRef}
className={cn("animate-marquee space-y-8 py-4", className)}
style={{ "--marquee-duration": duration } as React.CSSProperties}
>
{children}
</div>
);
}