mirror of
https://github.com/documenso/documenso.git
synced 2025-11-14 08:42:12 +10:00
This change actually makes the authoring flow work for the most part by tying in emailing and more. We have also done a number of quality of life updates to simplify the codebase overall making it easier to continue work on the refresh.
57 lines
1.2 KiB
TypeScript
57 lines
1.2 KiB
TypeScript
import { HTMLAttributes } from 'react';
|
|
|
|
import { CheckCircle2, Clock, File } from 'lucide-react';
|
|
import type { LucideIcon } from 'lucide-react/dist/lucide-react';
|
|
|
|
import { DocumentStatus as InternalDocumentStatus } from '@documenso/prisma/client';
|
|
import { cn } from '@documenso/ui/lib/utils';
|
|
|
|
type FriendlyStatus = {
|
|
label: string;
|
|
icon: LucideIcon;
|
|
color: string;
|
|
};
|
|
|
|
const FRIENDLY_STATUS_MAP: Record<InternalDocumentStatus, FriendlyStatus> = {
|
|
DRAFT: {
|
|
label: 'Draft',
|
|
icon: File,
|
|
color: 'text-yellow-500',
|
|
},
|
|
PENDING: {
|
|
label: 'Pending',
|
|
icon: Clock,
|
|
color: 'text-blue-600',
|
|
},
|
|
COMPLETED: {
|
|
label: 'Completed',
|
|
icon: CheckCircle2,
|
|
color: 'text-green-500',
|
|
},
|
|
};
|
|
|
|
export type DocumentStatusProps = HTMLAttributes<HTMLSpanElement> & {
|
|
status: InternalDocumentStatus;
|
|
inheritColor?: boolean;
|
|
};
|
|
|
|
export const DocumentStatus = ({
|
|
className,
|
|
status,
|
|
inheritColor,
|
|
...props
|
|
}: DocumentStatusProps) => {
|
|
const { label, icon: Icon, color } = FRIENDLY_STATUS_MAP[status];
|
|
|
|
return (
|
|
<span className={cn('flex items-center', className)} {...props}>
|
|
<Icon
|
|
className={cn('mr-2 inline-block h-4 w-4', {
|
|
[color]: !inheritColor,
|
|
})}
|
|
/>
|
|
{label}
|
|
</span>
|
|
);
|
|
};
|