'use client'; import { useState } from 'react'; import { PaletteGrid } from '@/components/pastel/PaletteGrid'; import { ExportMenu } from '@/components/pastel/ExportMenu'; import { Button } from '@/components/ui/button'; import { Input } from '@/components/ui/input'; import { Select, SelectContent, SelectItem, SelectTrigger, SelectValue, } from '@/components/ui/select'; import { Card, CardContent, CardHeader, CardTitle } from '@/components/ui/card'; import { useGenerateDistinct } from '@/lib/pastel/api/queries'; import { Loader2 } from 'lucide-react'; import { toast } from 'sonner'; export default function DistinctPage() { const [count, setCount] = useState(8); const [metric, setMetric] = useState<'cie76' | 'ciede2000'>('ciede2000'); const [colors, setColors] = useState([]); const generateMutation = useGenerateDistinct(); const handleGenerate = async () => { try { const result = await generateMutation.mutateAsync({ count, metric, }); setColors(result.colors); toast.success(`Generated ${result.colors.length} distinct colors`); } catch (error) { toast.error('Failed to generate distinct colors'); } }; return (

Distinct Colors Generator

Generate visually distinct colors using simulated annealing

{/* Controls */}
Settings
setCount(parseInt(e.target.value))} />

Higher counts take longer to generate

{generateMutation.isPending && (
This may take a few moments..
)}
{/* Results */}
Generated Colors {colors.length > 0 && `(${colors.length})`} {colors.length > 0 && ( )}
); }