Files
spacedrive/docs/snippets/FlowDiagram.mdx
2025-11-22 05:12:55 -08:00

49 lines
2.3 KiB
Plaintext

export const FlowDiagram = ({ steps = [] }) => {
return (
<div className="my-8 space-y-0">
{steps.map((step, index) => (
<div key={index} className="flex flex-col items-center">
<div className="w-full max-w-2xl rounded-lg border border-[#36A3FF]/20 bg-gradient-to-br from-[#36A3FF]/5 to-transparent p-6 shadow-sm backdrop-blur-sm transition-all hover:border-[#36A3FF]/40 hover:shadow-md">
<div className="flex items-start gap-4">
<div className="flex h-8 w-8 shrink-0 items-center justify-center rounded-full bg-[#36A3FF]/20 text-sm font-semibold text-[#36A3FF]">
{index + 1}
</div>
<div className="flex-1">
<h3 className="text-base font-semibold text-white mt-0">{step.title}</h3>
{step.description && (
<p className="text-sm leading-relaxed text-gray-300 mt-1">{step.description}</p>
)}
{step.items && Array.isArray(step.items) && (
<div className="mt-3 flex flex-wrap gap-2">
{step.items.map((item, i) => (
<span key={i} className="rounded-md border border-[#36A3FF]/30 bg-[#36A3FF]/10 px-2.5 py-1 text-xs text-gray-300">
{item}
</span>
))}
</div>
)}
{step.metrics && (
<div className="mt-3 flex flex-wrap gap-3 text-xs">
{Object.entries(step.metrics).map(([key, value]) => (
<div key={key} className="rounded-md bg-black/20 px-2.5 py-1.5 font-mono">
<span className="text-gray-400">{key}:</span>{' '}
<span className="font-semibold text-[#36A3FF]">{value}</span>
</div>
))}
</div>
)}
</div>
</div>
</div>
{index < steps.length - 1 && (
<div className="relative flex h-12 w-0.5 items-center justify-center">
<div className="h-full w-full bg-gradient-to-b from-[#36A3FF]/40 via-[#36A3FF]/20 to-[#36A3FF]/40" />
<div className="absolute h-2 w-2 rounded-full bg-[#36A3FF]/60" />
</div>
)}
</div>
))}
</div>
);
};