mirror of
				https://github.com/r-freeman/portfolio.git
				synced 2025-11-04 06:31:11 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			37 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			37 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
import Link from 'next/link'
 | 
						|
import clsx from 'clsx'
 | 
						|
import {ReactNode} from 'react'
 | 
						|
 | 
						|
type VariantStyles = {
 | 
						|
    primary: string
 | 
						|
    secondary: string
 | 
						|
}
 | 
						|
 | 
						|
type Button = {
 | 
						|
    variant?: string
 | 
						|
    className: string
 | 
						|
    href?: string
 | 
						|
    children: ReactNode
 | 
						|
}
 | 
						|
 | 
						|
const variantStyles: VariantStyles = {
 | 
						|
    primary:
 | 
						|
        'bg-zinc-800 font-semibold text-zinc-100 hover:bg-zinc-700 active:bg-zinc-800 active:text-zinc-100/70 dark:bg-zinc-700 dark:hover:bg-zinc-600 dark:active:bg-zinc-700 dark:active:text-zinc-100/70',
 | 
						|
    secondary:
 | 
						|
        'bg-zinc-50 font-medium text-zinc-900 hover:bg-zinc-100 active:bg-zinc-100 active:text-zinc-900/60 dark:bg-zinc-800/50 dark:text-zinc-300 dark:hover:bg-indigo-700 dark:hover:text-zinc-50 dark:active:bg-zinc-800/50 dark:active:text-zinc-50/70',
 | 
						|
}
 | 
						|
 | 
						|
export function Button({variant = 'primary', className, href, ...props}: Button) {
 | 
						|
    className = clsx(
 | 
						|
        'inline-flex items-center gap-2 justify-center rounded-md py-2 px-3 text-sm outline-offset-2 transition active:transition-none',
 | 
						|
        variantStyles[variant as keyof VariantStyles],
 | 
						|
        className
 | 
						|
    )
 | 
						|
 | 
						|
    return href ? (
 | 
						|
        <Link href={href} className={className} {...props} />
 | 
						|
    ) : (
 | 
						|
        <button type="submit" className={className} {...props} />
 | 
						|
    )
 | 
						|
}
 |