portfolio/components/ui/Button.tsx

37 lines
1.2 KiB
TypeScript
Raw Permalink Normal View History

2023-01-14 19:31:05 +00:00
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
2023-02-04 22:32:01 +00:00
href?: string
2023-01-14 19:31:05 +00:00
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} />
) : (
2023-02-05 21:52:03 +00:00
<button type="submit" className={className} {...props} />
2023-01-14 19:31:05 +00:00
)
}