Files
opencode/packages/ui/src/components/checkbox.tsx
2025-11-08 01:59:02 +00:00

45 lines
1.6 KiB
TypeScript

import { Checkbox as Kobalte } from "@kobalte/core/checkbox"
import { children, Show, splitProps } from "solid-js"
import type { ComponentProps, JSX, ParentProps } from "solid-js"
export interface CheckboxProps extends ParentProps<ComponentProps<typeof Kobalte>> {
hideLabel?: boolean
description?: string
icon?: JSX.Element
}
export function Checkbox(props: CheckboxProps) {
const [local, others] = splitProps(props, ["children", "class", "label", "hideLabel", "description", "icon"])
const resolved = children(() => local.children)
return (
<Kobalte {...others} data-component="checkbox">
<Kobalte.Input data-slot="checkbox-input" />
<Kobalte.Control data-slot="checkbox-control">
<Kobalte.Indicator data-slot="checkbox-indicator">
{local.icon || (
<svg viewBox="0 0 12 12" fill="none" xmlns="http://www.w3.org/2000/svg">
<path
d="M3 7.17905L5.02703 8.85135L9 3.5"
stroke="currentColor"
stroke-width="1.5"
stroke-linecap="square"
/>
</svg>
)}
</Kobalte.Indicator>
</Kobalte.Control>
<div data-slot="checkbox-content">
<Show when={resolved()}>
<Kobalte.Label data-slot="checkbox-label" classList={{ "sr-only": local.hideLabel }}>
{resolved()}
</Kobalte.Label>
</Show>
<Show when={local.description}>
<Kobalte.Description data-slot="checkbox-description">{local.description}</Kobalte.Description>
</Show>
<Kobalte.ErrorMessage data-slot="checkbox-error" />
</div>
</Kobalte>
)
}