| 
									
										
										
										
											2025-04-17 15:12:28 +02:00
										 |  |  | import { cn } from "@/lib/utils" | 
					
						
							|  |  |  | import type { ComponentPropsWithoutRef } from "react" | 
					
						
							| 
									
										
										
										
											2025-04-17 11:05:22 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | interface MarqueeProps extends ComponentPropsWithoutRef<"div"> { | 
					
						
							| 
									
										
										
										
											2025-04-17 15:12:28 +02:00
										 |  |  | 	/** | 
					
						
							|  |  |  | 	 * Optional CSS class name to apply custom styles | 
					
						
							|  |  |  | 	 */ | 
					
						
							|  |  |  | 	className?: string | 
					
						
							|  |  |  | 	/** | 
					
						
							|  |  |  | 	 * Whether to reverse the animation direction | 
					
						
							|  |  |  | 	 * @default false | 
					
						
							|  |  |  | 	 */ | 
					
						
							|  |  |  | 	reverse?: boolean | 
					
						
							|  |  |  | 	/** | 
					
						
							|  |  |  | 	 * Whether to pause the animation on hover | 
					
						
							|  |  |  | 	 * @default false | 
					
						
							|  |  |  | 	 */ | 
					
						
							|  |  |  | 	pauseOnHover?: boolean | 
					
						
							|  |  |  | 	/** | 
					
						
							|  |  |  | 	 * Content to be displayed in the marquee | 
					
						
							|  |  |  | 	 */ | 
					
						
							|  |  |  | 	children: React.ReactNode | 
					
						
							|  |  |  | 	/** | 
					
						
							|  |  |  | 	 * Whether to animate vertically instead of horizontally | 
					
						
							|  |  |  | 	 * @default false | 
					
						
							|  |  |  | 	 */ | 
					
						
							|  |  |  | 	vertical?: boolean | 
					
						
							|  |  |  | 	/** | 
					
						
							|  |  |  | 	 * Number of times to repeat the content | 
					
						
							|  |  |  | 	 * @default 4 | 
					
						
							|  |  |  | 	 */ | 
					
						
							|  |  |  | 	repeat?: number | 
					
						
							| 
									
										
										
										
											2025-04-17 11:05:22 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | export function Marquee({ | 
					
						
							| 
									
										
										
										
											2025-04-17 15:12:28 +02:00
										 |  |  | 	className, | 
					
						
							|  |  |  | 	reverse = false, | 
					
						
							|  |  |  | 	pauseOnHover = false, | 
					
						
							|  |  |  | 	children, | 
					
						
							|  |  |  | 	vertical = false, | 
					
						
							|  |  |  | 	repeat = 4, | 
					
						
							|  |  |  | 	...props | 
					
						
							| 
									
										
										
										
											2025-04-17 11:05:22 +02:00
										 |  |  | }: MarqueeProps) { | 
					
						
							| 
									
										
										
										
											2025-04-17 15:12:28 +02:00
										 |  |  | 	return ( | 
					
						
							|  |  |  | 		<div | 
					
						
							|  |  |  | 			{...props} | 
					
						
							|  |  |  | 			className={cn( | 
					
						
							|  |  |  | 				"group flex overflow-hidden p-2 [--duration:40s] [--gap:1rem] [gap:var(--gap)]", | 
					
						
							|  |  |  | 				{ | 
					
						
							|  |  |  | 					"flex-row": !vertical, | 
					
						
							|  |  |  | 					"flex-col": vertical, | 
					
						
							|  |  |  | 				}, | 
					
						
							|  |  |  | 				className, | 
					
						
							|  |  |  | 			)} | 
					
						
							|  |  |  | 		> | 
					
						
							|  |  |  | 			{Array(repeat) | 
					
						
							|  |  |  | 				.fill(0) | 
					
						
							|  |  |  | 				.map((_, i) => ( | 
					
						
							|  |  |  | 					<div | 
					
						
							|  |  |  | 						key={i} | 
					
						
							|  |  |  | 						className={cn("flex shrink-0 justify-around [gap:var(--gap)]", { | 
					
						
							|  |  |  | 							"animate-marquee flex-row": !vertical, | 
					
						
							|  |  |  | 							"animate-marquee-vertical flex-col": vertical, | 
					
						
							|  |  |  | 							"group-hover:[animation-play-state:paused]": pauseOnHover, | 
					
						
							|  |  |  | 							"[animation-direction:reverse]": reverse, | 
					
						
							|  |  |  | 						})} | 
					
						
							|  |  |  | 					> | 
					
						
							|  |  |  | 						{children} | 
					
						
							|  |  |  | 					</div> | 
					
						
							|  |  |  | 				))} | 
					
						
							|  |  |  | 		</div> | 
					
						
							|  |  |  | 	) | 
					
						
							| 
									
										
										
										
											2025-04-17 11:05:22 +02:00
										 |  |  | } |