Vercel/src/components/ChecklistRow.tsx
2024-06-20 19:25:15 -05:00

52 lines
1.1 KiB
TypeScript

import { ReactNode } from 'react';
import { clsx } from 'clsx/lite';
import StatusIcon from './StatusIcon';
import ExperimentalBadge from './ExperimentalBadge';
export default function ChecklistRow({
title,
status,
isPending,
optional,
showWarning,
experimental,
children,
}: {
title: string
status: boolean
isPending?: boolean
optional?: boolean
showWarning?: boolean
experimental?: boolean
children: ReactNode
}) {
return (
<div className={clsx(
'flex gap-2.5',
'px-4 pt-2 pb-2.5',
)}>
<StatusIcon
type={status
? 'checked'
: showWarning
? 'warning'
: optional ? 'optional' : 'missing'}
loading={isPending}
/>
<div className="flex flex-col min-w-0 flex-grow">
<div className={clsx(
'flex flex-wrap items-center gap-2 pb-0.5',
'font-bold dark:text-gray-300',
)}>
{title}
{experimental &&
<ExperimentalBadge className="translate-y-[-0.5px]" />}
</div>
<div>
{children}
</div>
</div>
</div>
);
}