mirror of
https://github.com/aljazceru/opencode.git
synced 2025-12-25 11:44:22 +01:00
34 lines
1009 B
TypeScript
34 lines
1009 B
TypeScript
import { Button as Kobalte } from "@kobalte/core/button"
|
|
import { type ComponentProps, Show, splitProps } from "solid-js"
|
|
import { Icon, IconProps } from "./icon"
|
|
|
|
export interface ButtonProps
|
|
extends ComponentProps<typeof Kobalte>,
|
|
Pick<ComponentProps<"button">, "class" | "classList" | "children"> {
|
|
size?: "normal" | "large"
|
|
variant?: "primary" | "secondary" | "ghost"
|
|
icon?: IconProps["name"]
|
|
}
|
|
|
|
export function Button(props: ButtonProps) {
|
|
const [split, rest] = splitProps(props, ["variant", "size", "icon", "class", "classList"])
|
|
return (
|
|
<Kobalte
|
|
{...rest}
|
|
data-component="button"
|
|
data-size={split.size || "normal"}
|
|
data-variant={split.variant || "secondary"}
|
|
data-icon={split.icon}
|
|
classList={{
|
|
...(split.classList ?? {}),
|
|
[split.class ?? ""]: !!split.class,
|
|
}}
|
|
>
|
|
<Show when={split.icon}>
|
|
<Icon data-slot="icon" name={split.icon!} size="small" />
|
|
</Show>
|
|
{props.children}
|
|
</Kobalte>
|
|
)
|
|
}
|