db523ab871
Initialize shadcn/ui (radix-nova, Tailwind v4) in client/ and rebuild the M1 interface on the design language: - Token layer recolored in index.css: light "calm command center" content surface, rationed indigo brand, the deep-indigo sidebar, the load-bearing seat-state triad (--color-seat-human slate / -open amber / -ai indigo) + teal "approved" / amber "held", Hanken Grotesk (variable) as the production font. - App shell: deep-indigo sidebar (Board / Cartable / Org-chart-soon nav + sign out) on a light content area; StatusDot uses the seat-state tokens. - LoginPage: Card-based sign-in / first-owner bootstrap, toast (sonner) errors. - BoardPage: shadcn Card columns (backlog→in progress→in review→done), Badge task types, Select to move, Avatar/Assign-to-me, and the cartable panel — wired to the M1 API. - Path alias @ -> src (tsconfig paths + vite); dropped baseUrl (deprecated in TS 6). Components added via the shadcn CLI: button, card, badge, input, label, select, separator, avatar, skeleton, sonner. Client `npm run build` is green (tsc + vite). Still pending a live click-through. Co-Authored-By: Claude Opus 4.8 <noreply@anthropic.com>
18 lines
484 B
TypeScript
18 lines
484 B
TypeScript
import { cn } from '@/lib/utils'
|
|
|
|
const TONES = {
|
|
human: 'bg-seat-human',
|
|
open: 'bg-seat-open',
|
|
ai: 'bg-seat-ai',
|
|
approved: 'bg-approved',
|
|
held: 'bg-held',
|
|
destructive: 'bg-destructive',
|
|
idle: 'bg-muted-foreground/40',
|
|
} as const
|
|
|
|
export type DotTone = keyof typeof TONES
|
|
|
|
export function StatusDot({ tone, className }: { tone: DotTone; className?: string }) {
|
|
return <span className={cn('inline-block size-2.5 rounded-full', TONES[tone], className)} aria-hidden />
|
|
}
|