Skip to main content

Checkbox

Code

components/Checkbox/index.tsx
import type { FC, ReactNode } from 'react'
import classnames from 'classnames'

export interface Props {
checked: boolean
onChange: (checked: boolean) => void
label: ReactNode
className?: string
}

const Checkbox: FC<Props> = ({ checked, onChange, label, className }) => {
return (
<label className="mb-0 cursor-pointer">
<input
onChange={(e) => onChange(e.target.checked)}
type="checkbox"
checked={checked}
/>
<span className={classnames('ml-1.5 text-sm text-gray-600', className)}>
{label}
</span>
</label>
)
}

export default Checkbox

Props

NameTypeDefault
checked*boolean
onChange*function
label*string

Example