Category.tsx 995 B

12345678910111213141516171819202122232425262728293031323334
  1. import classNames from "classnames"
  2. export type CategoryProps = {
  3. onChange: (e: any) => void
  4. value: string
  5. currentValue?: string
  6. label: React.ReactNode
  7. }
  8. export const Category = ({ onChange, value, currentValue, label }: CategoryProps) => {
  9. return (
  10. <label
  11. className={classNames(
  12. "b3 block cursor-pointer whitespace-nowrap rounded-md border-2 md:p-4 p-3 text-center !font-semibold transition-all md:w-full",
  13. value === currentValue
  14. ? "border-blurple-500 bg-blurple-500 text-white hover:border-blurple-600 hover:bg-blurple-600 focus-visible-within:border-blurple-600 focus-visible-within:bg-blurple-600"
  15. : "border-blurple-500 bg-white text-blurple-500 hover:border-blurple-600 hover:text-blurple-600"
  16. )}
  17. >
  18. <input
  19. className="sr-only"
  20. type="radio"
  21. name="apps-selection"
  22. id=""
  23. value={value}
  24. onChange={onChange}
  25. />
  26. {label}
  27. </label>
  28. )
  29. }
  30. export default Category