42 lines
1.1 KiB
TypeScript
42 lines
1.1 KiB
TypeScript
import React from 'react'
|
|
import styled from '@emotion/styled'
|
|
import { CheckIcon } from '@heroicons/react/solid'
|
|
|
|
const HiddenCheckbox = styled.input`
|
|
border: 0;
|
|
clip: rect(0 0 0 0);
|
|
clippath: inset(50%);
|
|
height: 1px;
|
|
margin: -1px;
|
|
overflow: hidden;
|
|
padding: 0;
|
|
position: absolute;
|
|
white-space: nowrap;
|
|
width: 1px;
|
|
`
|
|
|
|
const Checkbox = ({ checked, children, disabled = false, ...props }) => (
|
|
<label className="cursor-pointer default-transition flex items-center text-th-fgd-3 hover:text-th-fgd-1">
|
|
<HiddenCheckbox
|
|
checked={checked}
|
|
{...props}
|
|
disabled={disabled}
|
|
type="checkbox"
|
|
/>
|
|
<div
|
|
className={`${
|
|
checked && !disabled ? 'border-th-primary' : 'border-th-fgd-4'
|
|
} border cursor-pointer default-transition flex items-center justify-center rounded h-4 w-4`}
|
|
>
|
|
<CheckIcon
|
|
className={`${checked ? 'block' : 'hidden'} h-4 w-4 ${
|
|
disabled ? 'text-th-fgd-4' : 'text-th-primary'
|
|
}`}
|
|
/>
|
|
</div>
|
|
<span className="ml-2 text-xs">{children}</span>
|
|
</label>
|
|
)
|
|
|
|
export default Checkbox
|