button.tsx 1016 B

123456789101112131415161718192021222324252627282930313233
  1. import { Button as Kobalte } from "@kobalte/core/button"
  2. import { type ComponentProps, Show, splitProps } from "solid-js"
  3. import { Icon, IconProps } from "./icon"
  4. export interface ButtonProps
  5. extends ComponentProps<typeof Kobalte>,
  6. Pick<ComponentProps<"button">, "class" | "classList" | "children"> {
  7. size?: "normal" | "large"
  8. variant?: "primary" | "secondary" | "ghost"
  9. icon?: IconProps["name"]
  10. }
  11. export function Button(props: ButtonProps) {
  12. const [split, rest] = splitProps(props, ["variant", "size", "icon", "class", "classList"])
  13. return (
  14. <Kobalte
  15. {...rest}
  16. data-component="button"
  17. data-size={split.size || "normal"}
  18. data-variant={split.variant || "secondary"}
  19. data-icon={split.icon}
  20. classList={{
  21. ...(split.classList ?? {}),
  22. [split.class ?? ""]: !!split.class,
  23. }}
  24. >
  25. <Show when={split.icon}>
  26. <Icon data-slot="button-icon" name={split.icon!} size="small" />
  27. </Show>
  28. {props.children}
  29. </Kobalte>
  30. )
  31. }