40 lines
872 B
TypeScript
40 lines
872 B
TypeScript
import { ReactNode } from 'react';
|
|
import { clsx } from 'clsx/lite';
|
|
|
|
export default function Checklist({
|
|
title,
|
|
icon,
|
|
optional,
|
|
children,
|
|
}: {
|
|
title: string
|
|
icon?: ReactNode
|
|
optional?: boolean
|
|
children: ReactNode
|
|
}) {
|
|
return (
|
|
<div>
|
|
<div className={clsx(
|
|
'flex items-center gap-3',
|
|
'text-gray-600 dark:text-gray-300',
|
|
'pl-[18px] mb-3 text-lg',
|
|
)}>
|
|
{icon}
|
|
<div className="flex gap-1.5">
|
|
<div>{title}</div>
|
|
{optional &&
|
|
<div className="text-dim">(Optional)</div>}
|
|
</div>
|
|
</div>
|
|
<div className={clsx(
|
|
'bg-white dark:bg-black',
|
|
'dark:text-gray-400',
|
|
'border border-gray-200 dark:border-gray-800 rounded-md',
|
|
'divide-y divide-gray-200 dark:divide-gray-800',
|
|
)}>
|
|
{children}
|
|
</div>
|
|
</div>
|
|
);
|
|
}
|