42 lines
1.7 KiB
TypeScript
42 lines
1.7 KiB
TypeScript
|
import type { ButtonHTMLAttributes } from "react";
|
||
|
import clsx from "clsx";
|
||
|
|
||
|
const baseStyles = {
|
||
|
solid: "group inline-flex items-center justify-center rounded-full py-2 px-4 text-sm font-semibold focus:outline-none focus-visible:outline-2 focus-visible:outline-offset-2",
|
||
|
outline: "group inline-flex ring-1 items-center justify-center rounded-full py-2 px-4 text-sm focus:outline-none",
|
||
|
};
|
||
|
|
||
|
const variantStyles = {
|
||
|
solid: {
|
||
|
slate: "bg-slate-900 text-white hover:bg-slate-700 hover:text-slate-100 active:bg-slate-800 active:text-slate-300 focus-visible:outline-slate-900",
|
||
|
primary:
|
||
|
"bg-primary-600 text-white hover:text-slate-100 hover:bg-primary-500 active:bg-primary-800 active:text-primary-100 focus-visible:outline-primary-600",
|
||
|
white: "bg-white text-slate-900 hover:bg-primary-50 active:bg-primary-200 active:text-slate-600 focus-visible:outline-white",
|
||
|
},
|
||
|
outline: {
|
||
|
slate: "ring-slate-200 text-slate-700 hover:text-slate-900 hover:ring-slate-300 active:bg-slate-100 active:text-slate-600 focus-visible:outline-primary-600 focus-visible:ring-slate-300",
|
||
|
white: "ring-slate-700 text-white hover:ring-slate-500 active:ring-slate-700 active:text-slate-400 focus-visible:outline-white",
|
||
|
},
|
||
|
};
|
||
|
|
||
|
type Props = ButtonHTMLAttributes<HTMLButtonElement> &
|
||
|
(
|
||
|
| {
|
||
|
variant: "solid";
|
||
|
color: "slate" | "primary" | "white";
|
||
|
}
|
||
|
| {
|
||
|
variant: "outline";
|
||
|
color: "slate" | "white";
|
||
|
}
|
||
|
) & {
|
||
|
className?: string;
|
||
|
};
|
||
|
|
||
|
export default function Button({ variant, color, className, ...props }: Props) {
|
||
|
// @ts-ignore
|
||
|
const fullClassName = clsx(baseStyles[variant], variantStyles[variant][color], className);
|
||
|
|
||
|
return <button className={fullClassName} {...props} />;
|
||
|
}
|