3. Button variants
Button UI
설치
pnpm add tailwind-merge clsx class-variance-authorityButton library 예시
import { VariantProps, cva } from 'class-variance-authority';
import { ComponentProps } from 'react';
import { cn } from '@/lib/utils';
const buttonVariants = cva(
'inline-flex items-center justify-center rounded-md text-sm font-medium transition-colors focus:outline-none focus:ring-2 focus:ring-slate-400 focus:ring-offset-2 disabled:opacity-50 disabled:pointer-events-none data-[state=open]:bg-slate-100',
{
variants: {
bgcolor: {
default: 'bg-slate-900 text-slate-50 hover:bg-slate-700',
pink: 'bg-pink-900 text-pink-50 hover:bg-pink-500',
},
outline: {
default: 'border border-transparent',
black: 'border-4 border-black',
},
size: {
default: 'h-10 py-2 px-4 text-sm',
sm: 'h-9 px-2 rounded-md text-xs',
lg: 'h-11 px-8 rounded-md text-base',
},
},
defaultVariants: {
bgcolor: 'default',
outline: 'default',
size: 'default',
},
}
);
interface ButtonProps extends ComponentProps<'button'>, VariantProps<typeof buttonVariants> {}
const Button = ({ className, bgcolor, outline, size, ...props }: ButtonProps) => {
return (
<button
className={cn(
buttonVariants({
bgcolor,
outline,
size,
className,
})
)}
{...props}
/>
);
};
export default Button;마지막 업데이트