UI/button: init ghost variant

This commit is contained in:
Johannes Kirschbauer
2024-12-10 15:11:24 +01:00
parent 004feeedf6
commit 5f79f92dc5

View File

@@ -1,11 +1,13 @@
import { splitProps, type JSX } from "solid-js"; import { splitProps, type JSX } from "solid-js";
import cx from "classnames"; import cx from "classnames";
import { Typography } from "../Typography";
type Variants = "dark" | "light"; type Variants = "dark" | "light" | "ghost";
type Size = "default" | "s"; type Size = "default" | "s";
const variantColors: Record<Variants, string> = { const variantColors: Record<Variants, string> = {
dark: cx( dark: cx(
"border border-solid",
"border-secondary-950 bg-primary-900 text-white", "border-secondary-950 bg-primary-900 text-white",
"shadow-inner-primary", "shadow-inner-primary",
// Hover state // Hover state
@@ -18,6 +20,7 @@ const variantColors: Record<Variants, string> = {
"disabled:bg-secondary-200 disabled:text-secondary-700 disabled:border-secondary-300", "disabled:bg-secondary-200 disabled:text-secondary-700 disabled:border-secondary-300",
), ),
light: cx( light: cx(
"border border-solid",
"border-secondary-800 bg-secondary-100 text-secondary-800", "border-secondary-800 bg-secondary-100 text-secondary-800",
"shadow-inner-secondary", "shadow-inner-secondary",
// Hover state // Hover state
@@ -29,6 +32,17 @@ const variantColors: Record<Variants, string> = {
// Disabled // Disabled
"disabled:bg-secondary-50 disabled:text-secondary-200 disabled:border-secondary-700", "disabled:bg-secondary-50 disabled:text-secondary-200 disabled:border-secondary-700",
), ),
ghost: cx(
// "shadow-inner-secondary",
// Hover state
// Focus state
// Active state
"hover:bg-secondary-200 hover:text-secondary-900",
"focus:bg-secondary-200 focus:text-secondary-900",
"active:bg-secondary-200 active:text-secondary-950 active:shadow-inner-secondary-active",
// Disabled
"disabled:bg-secondary-50 disabled:text-secondary-200 disabled:border-secondary-700",
),
}; };
const sizePaddings: Record<Size, string> = { const sizePaddings: Record<Size, string> = {
@@ -36,6 +50,11 @@ const sizePaddings: Record<Size, string> = {
s: cx("rounded-sm py-[0.375rem] px-3"), s: cx("rounded-sm py-[0.375rem] px-3"),
}; };
const sizeFont: Record<Size, string> = {
default: cx("text-[0.8125rem]"),
s: cx("text-[0.75rem]"),
};
interface ButtonProps extends JSX.ButtonHTMLAttributes<HTMLButtonElement> { interface ButtonProps extends JSX.ButtonHTMLAttributes<HTMLButtonElement> {
variant?: Variants; variant?: Variants;
size?: Size; size?: Size;
@@ -60,11 +79,13 @@ export const Button = (props: ButtonProps) => {
// Layout // Layout
"inline-flex items-center flex-shrink gap-2 justify-center", "inline-flex items-center flex-shrink gap-2 justify-center",
// Styles // Styles
"border border-solid",
"p-4", "p-4",
sizePaddings[local.size || "default"], sizePaddings[local.size || "default"],
// Colors // Colors
variantColors[local.variant || "dark"], variantColors[local.variant || "dark"],
//Font
"leading-none font-semibold",
sizeFont[local.size || "default"],
)} )}
{...other} {...other}
> >