23 lines
		
	
	
		
			578 B
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			23 lines
		
	
	
		
			578 B
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| import { clsx, type ClassValue } from "clsx";
 | |
| import { twMerge } from "tailwind-merge";
 | |
| 
 | |
| export function cn(...inputs: ClassValue[]) {
 | |
|   return twMerge(clsx(inputs));
 | |
| }
 | |
| 
 | |
| export function generateSlug(title: string) {
 | |
|   return title.toLowerCase().replace(/\s+/g, "-");
 | |
| }
 | |
| 
 | |
| export function debounce<T extends (...args: any[]) => void>(
 | |
|   func: T,
 | |
|   delay: number,
 | |
| ): (...args: Parameters<T>) => void {
 | |
|   let timeoutId: ReturnType<typeof setTimeout>;
 | |
| 
 | |
|   return (...args: Parameters<T>) => {
 | |
|     clearTimeout(timeoutId);
 | |
|     timeoutId = setTimeout(() => func(...args), delay);
 | |
|   };
 | |
| }
 |