@vadimcomanescu/nadicode-design-system 2.0.0 → 2.0.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1,3217 @@
1
+ {
2
+ "version": "2.0.1",
3
+ "generatedAt": "2026-03-22T21:15:55.941Z",
4
+ "components": {
5
+ "Accordion": {
6
+ "file": "src/components/ui/Accordion.tsx",
7
+ "exportPath": "./accordion",
8
+ "tier": 1,
9
+ "category": "Display",
10
+ "lib": "react-accordion",
11
+ "subComponents": [
12
+ "AccordionItem",
13
+ "AccordionTrigger",
14
+ "AccordionContent"
15
+ ],
16
+ "variants": {},
17
+ "notes": "Accordion, Item, Trigger, Content"
18
+ },
19
+ "AgentAvatar": {
20
+ "file": "src/components/ui/AgentAvatar.tsx",
21
+ "exportPath": "./agent-avatar",
22
+ "tier": 2,
23
+ "category": "AI / Voice",
24
+ "lib": null,
25
+ "subComponents": [],
26
+ "variants": {
27
+ "size": {
28
+ "options": [
29
+ "lg",
30
+ "xl",
31
+ "2xl"
32
+ ],
33
+ "default": "xl"
34
+ }
35
+ },
36
+ "notes": "AI agent avatar with idle/listening/speaking states"
37
+ },
38
+ "AgentMessageBubble": {
39
+ "file": "src/components/ui/AgentMessageBubble.tsx",
40
+ "exportPath": "./agent-message-bubble",
41
+ "tier": 2,
42
+ "category": "Agentic UI",
43
+ "lib": null,
44
+ "subComponents": [],
45
+ "variants": {
46
+ "role": {
47
+ "options": [
48
+ "user",
49
+ "agent",
50
+ "system"
51
+ ],
52
+ "default": "agent"
53
+ }
54
+ },
55
+ "notes": "Chat bubble with role-based styling"
56
+ },
57
+ "AgentMetricsCard": {
58
+ "file": "src/components/ui/AgentMetricsCard.tsx",
59
+ "exportPath": "./agent-metrics-card",
60
+ "tier": 2,
61
+ "category": "Agentic UI",
62
+ "lib": null,
63
+ "subComponents": [],
64
+ "variants": {
65
+ "layout": {
66
+ "options": [
67
+ "grid",
68
+ "row"
69
+ ],
70
+ "default": "grid"
71
+ }
72
+ },
73
+ "notes": "Agent performance metrics dashboard"
74
+ },
75
+ "AgentStatus": {
76
+ "file": "src/components/ui/AgentStatus.tsx",
77
+ "exportPath": "./agent-status",
78
+ "tier": 2,
79
+ "category": "AI / Voice",
80
+ "lib": null,
81
+ "subComponents": [],
82
+ "variants": {
83
+ "status": {
84
+ "options": [
85
+ "idle",
86
+ "thinking",
87
+ "streaming",
88
+ "error",
89
+ "complete"
90
+ ],
91
+ "default": "idle"
92
+ },
93
+ "size": {
94
+ "options": [
95
+ "sm",
96
+ "default",
97
+ "lg"
98
+ ],
99
+ "default": "default"
100
+ }
101
+ },
102
+ "notes": "Agent connection status indicator"
103
+ },
104
+ "AgentTeamPanel": {
105
+ "file": "src/components/ui/AgentTeamPanel.tsx",
106
+ "exportPath": "./agent-team-panel",
107
+ "tier": 2,
108
+ "category": "Agentic UI",
109
+ "lib": null,
110
+ "subComponents": [],
111
+ "variants": {
112
+ "size": {
113
+ "options": [
114
+ "compact",
115
+ "default"
116
+ ],
117
+ "default": "default"
118
+ }
119
+ },
120
+ "notes": "Agent team members and statuses"
121
+ },
122
+ "AgentTerminal": {
123
+ "file": "src/components/ui/AgentTerminal.tsx",
124
+ "exportPath": "./agent-terminal",
125
+ "tier": 2,
126
+ "category": "Agentic UI",
127
+ "lib": null,
128
+ "subComponents": [],
129
+ "variants": {},
130
+ "notes": "Terminal-style command output"
131
+ },
132
+ "AgentTimeline": {
133
+ "file": "src/components/ui/AgentTimeline.tsx",
134
+ "exportPath": "./agent-timeline",
135
+ "tier": 2,
136
+ "category": "Agentic UI",
137
+ "lib": null,
138
+ "subComponents": [],
139
+ "variants": {},
140
+ "notes": "Timeline of agent actions"
141
+ },
142
+ "Alert": {
143
+ "file": "src/components/ui/Alert.tsx",
144
+ "exportPath": "./alert",
145
+ "tier": 1,
146
+ "category": "Display",
147
+ "lib": null,
148
+ "subComponents": [
149
+ "AlertTitle",
150
+ "AlertDescription",
151
+ "AlertIcon"
152
+ ],
153
+ "variants": {
154
+ "variant": {
155
+ "options": [
156
+ "default",
157
+ "destructive",
158
+ "success",
159
+ "warning"
160
+ ],
161
+ "default": "default"
162
+ }
163
+ },
164
+ "notes": "variant: default, destructive"
165
+ },
166
+ "AlertDialog": {
167
+ "file": "src/components/ui/AlertDialog.tsx",
168
+ "exportPath": "./alert-dialog",
169
+ "tier": 1,
170
+ "category": "Display",
171
+ "lib": "react-alert-dialog",
172
+ "subComponents": [
173
+ "AlertDialogPortal",
174
+ "AlertDialogOverlay",
175
+ "AlertDialogTrigger",
176
+ "AlertDialogContent",
177
+ "AlertDialogHeader",
178
+ "AlertDialogFooter",
179
+ "AlertDialogTitle",
180
+ "AlertDialogDescription",
181
+ "AlertDialogAction",
182
+ "AlertDialogCancel"
183
+ ],
184
+ "variants": {},
185
+ "notes": "Full compound set with actions"
186
+ },
187
+ "AmbientGrid": {
188
+ "file": "src/components/ui/AmbientGrid.tsx",
189
+ "exportPath": "./ambient-grid",
190
+ "tier": 3,
191
+ "category": "Decorative Effects",
192
+ "lib": null,
193
+ "subComponents": [],
194
+ "variants": {},
195
+ "notes": "CSS grid overlay (24px cells, 0.06 opacity)"
196
+ },
197
+ "AnimatedBackground": {
198
+ "file": "src/components/ui/AnimatedBackground.tsx",
199
+ "exportPath": "./animated-background",
200
+ "tier": 3,
201
+ "category": "Decorative Effects",
202
+ "lib": null,
203
+ "subComponents": [],
204
+ "variants": {},
205
+ "notes": "CSS animated gradient background"
206
+ },
207
+ "AnimatedDialog": {
208
+ "file": "src/components/ui/AnimatedDialog.tsx",
209
+ "exportPath": "./animated-dialog",
210
+ "tier": 3,
211
+ "category": "Layout and Overlays",
212
+ "lib": "react-dialog",
213
+ "subComponents": [
214
+ "AnimatedDialogPortal",
215
+ "AnimatedDialogOverlay",
216
+ "AnimatedDialogClose",
217
+ "AnimatedDialogTrigger",
218
+ "AnimatedDialogContent",
219
+ "AnimatedDialogHeader",
220
+ "AnimatedDialogFooter",
221
+ "AnimatedDialogTitle",
222
+ "AnimatedDialogDescription"
223
+ ],
224
+ "variants": {},
225
+ "notes": "Dialog with motion spring animations"
226
+ },
227
+ "AnimatedSheet": {
228
+ "file": "src/components/ui/AnimatedSheet.tsx",
229
+ "exportPath": "./animated-sheet",
230
+ "tier": 3,
231
+ "category": "Layout and Overlays",
232
+ "lib": "react-dialog",
233
+ "subComponents": [
234
+ "AnimatedSheetPortal",
235
+ "AnimatedSheetOverlay",
236
+ "AnimatedSheetTrigger",
237
+ "AnimatedSheetClose",
238
+ "AnimatedSheetContent",
239
+ "AnimatedSheetHeader",
240
+ "AnimatedSheetFooter",
241
+ "AnimatedSheetTitle",
242
+ "AnimatedSheetDescription"
243
+ ],
244
+ "variants": {},
245
+ "notes": "Sheet with motion animations"
246
+ },
247
+ "AnimatedTabs": {
248
+ "file": "src/components/ui/AnimatedTabs.tsx",
249
+ "exportPath": "./animated-tabs",
250
+ "tier": 3,
251
+ "category": "Display",
252
+ "lib": null,
253
+ "subComponents": [
254
+ "AnimatedTabsList",
255
+ "AnimatedTabsTrigger",
256
+ "AnimatedTabsContent"
257
+ ],
258
+ "variants": {},
259
+ "notes": "Tabs with sliding indicator (layoutId)"
260
+ },
261
+ "AnnouncementBanner": {
262
+ "file": "src/components/ui/AnnouncementBanner.tsx",
263
+ "exportPath": "./announcement-banner",
264
+ "tier": 1,
265
+ "category": "Display",
266
+ "lib": null,
267
+ "subComponents": [],
268
+ "variants": {
269
+ "variant": {
270
+ "options": [
271
+ "info",
272
+ "warning",
273
+ "success",
274
+ "accent"
275
+ ],
276
+ "default": "accent"
277
+ }
278
+ },
279
+ "notes": "Top-of-page announcement"
280
+ },
281
+ "ApprovalCard": {
282
+ "file": "src/components/ui/ApprovalCard.tsx",
283
+ "exportPath": "./approval-card",
284
+ "tier": 2,
285
+ "category": "Agentic UI",
286
+ "lib": null,
287
+ "subComponents": [],
288
+ "variants": {
289
+ "riskLevel": {
290
+ "options": [
291
+ "low",
292
+ "medium",
293
+ "high"
294
+ ],
295
+ "default": "low"
296
+ }
297
+ },
298
+ "notes": "Human-in-the-loop approval/reject"
299
+ },
300
+ "ArtifactCard": {
301
+ "file": "src/components/ui/ArtifactCard.tsx",
302
+ "exportPath": "./artifact-card",
303
+ "tier": 2,
304
+ "category": "Agentic UI",
305
+ "lib": null,
306
+ "subComponents": [],
307
+ "variants": {
308
+ "type": {
309
+ "options": [
310
+ "code",
311
+ "markdown",
312
+ "table",
313
+ "image"
314
+ ],
315
+ "default": "code"
316
+ }
317
+ },
318
+ "notes": "Generated artifacts display"
319
+ },
320
+ "AspectRatio": {
321
+ "file": "src/components/ui/AspectRatio.tsx",
322
+ "exportPath": "./aspect-ratio",
323
+ "tier": 1,
324
+ "category": "Layout and Overlays",
325
+ "lib": "react-aspect-ratio",
326
+ "subComponents": [],
327
+ "variants": {},
328
+ "notes": "Fixed aspect ratio container"
329
+ },
330
+ "AudioWaveform": {
331
+ "file": "src/components/ui/AudioWaveform.tsx",
332
+ "exportPath": "./audio-waveform",
333
+ "tier": 2,
334
+ "category": "AI / Voice",
335
+ "lib": null,
336
+ "subComponents": [],
337
+ "variants": {
338
+ "variant": {
339
+ "options": [
340
+ "default",
341
+ "accent",
342
+ "success"
343
+ ],
344
+ "default": "default"
345
+ },
346
+ "size": {
347
+ "options": [
348
+ "sm",
349
+ "default",
350
+ "lg"
351
+ ],
352
+ "default": "default"
353
+ }
354
+ },
355
+ "notes": "Real-time audio visualization"
356
+ },
357
+ "AuroraEffect": {
358
+ "file": "src/components/ui/AuroraEffect.tsx",
359
+ "exportPath": "./aurora-effect",
360
+ "tier": 3,
361
+ "category": "Decorative Effects",
362
+ "lib": null,
363
+ "subComponents": [],
364
+ "variants": {},
365
+ "notes": "Animated gradient aurora background"
366
+ },
367
+ "Avatar": {
368
+ "file": "src/components/ui/Avatar.tsx",
369
+ "exportPath": "./avatar",
370
+ "tier": 1,
371
+ "category": "Display",
372
+ "lib": "react-avatar",
373
+ "subComponents": [
374
+ "AvatarImage",
375
+ "AvatarFallback"
376
+ ],
377
+ "variants": {},
378
+ "notes": "Avatar, AvatarImage, AvatarFallback"
379
+ },
380
+ "Avatar3D": {
381
+ "file": "src/components/ui/Avatar3D.tsx",
382
+ "exportPath": "./avatar3-d",
383
+ "tier": 2,
384
+ "category": "AI / Voice",
385
+ "lib": null,
386
+ "subComponents": [],
387
+ "variants": {
388
+ "size": {
389
+ "options": [
390
+ "md",
391
+ "lg",
392
+ "xl"
393
+ ],
394
+ "default": "lg"
395
+ }
396
+ },
397
+ "notes": "3D avatar with Three.js"
398
+ },
399
+ "AvatarUpload": {
400
+ "file": "src/components/ui/AvatarUpload.tsx",
401
+ "exportPath": "./avatar-upload",
402
+ "tier": 1,
403
+ "category": "Display",
404
+ "lib": null,
405
+ "subComponents": [],
406
+ "variants": {},
407
+ "notes": "Avatar with upload functionality"
408
+ },
409
+ "Badge": {
410
+ "file": "src/components/ui/Badge.tsx",
411
+ "exportPath": "./badge",
412
+ "tier": 1,
413
+ "category": "Display",
414
+ "lib": null,
415
+ "subComponents": [],
416
+ "variants": {
417
+ "variant": {
418
+ "options": [
419
+ "primary",
420
+ "secondary",
421
+ "destructive",
422
+ "outline",
423
+ "accent"
424
+ ],
425
+ "default": "primary"
426
+ }
427
+ },
428
+ "notes": "variant: primary, secondary, destructive, outline, accent"
429
+ },
430
+ "BentoGrid": {
431
+ "file": "src/components/ui/BentoGrid.tsx",
432
+ "exportPath": "./bento-grid",
433
+ "tier": 1,
434
+ "category": "Layout and Overlays",
435
+ "lib": null,
436
+ "subComponents": [],
437
+ "variants": {},
438
+ "notes": "CSS grid layout system"
439
+ },
440
+ "BrandIcons": {
441
+ "file": "src/components/ui/BrandIcons.tsx",
442
+ "exportPath": "./brand-icons",
443
+ "tier": 1,
444
+ "category": "Miscellaneous",
445
+ "lib": null,
446
+ "subComponents": [
447
+ "GoogleIcon",
448
+ "MicrosoftIcon",
449
+ "GitHubIcon",
450
+ "AppleIcon"
451
+ ],
452
+ "variants": {},
453
+ "notes": "Google, GitHub brand SVGs"
454
+ },
455
+ "Breadcrumb": {
456
+ "file": "src/components/ui/Breadcrumb.tsx",
457
+ "exportPath": "./breadcrumb",
458
+ "tier": 1,
459
+ "category": "Display",
460
+ "lib": null,
461
+ "subComponents": [
462
+ "BreadcrumbList",
463
+ "BreadcrumbItem",
464
+ "BreadcrumbLink",
465
+ "BreadcrumbPage",
466
+ "BreadcrumbSeparator",
467
+ "BreadcrumbEllipsis"
468
+ ],
469
+ "variants": {},
470
+ "notes": "Breadcrumb, List, Item, Link, Separator"
471
+ },
472
+ "Button": {
473
+ "file": "src/components/ui/Button.tsx",
474
+ "exportPath": "./button",
475
+ "tier": 1,
476
+ "category": "Form Controls",
477
+ "lib": "react-slot",
478
+ "subComponents": [],
479
+ "variants": {
480
+ "variant": {
481
+ "options": [
482
+ "primary",
483
+ "secondary",
484
+ "outline",
485
+ "ghost",
486
+ "link",
487
+ "destructive",
488
+ "accent",
489
+ "glass"
490
+ ],
491
+ "default": "primary"
492
+ },
493
+ "size": {
494
+ "options": [
495
+ "sm",
496
+ "default",
497
+ "lg",
498
+ "icon"
499
+ ],
500
+ "default": "default"
501
+ }
502
+ },
503
+ "notes": "8 variants (primary, secondary, outline, ghost, link, destructive, accent, glass), 4 sizes"
504
+ },
505
+ "ButtonGroup": {
506
+ "file": "src/components/ui/ButtonGroup.tsx",
507
+ "exportPath": "./button-group",
508
+ "tier": 4,
509
+ "category": "Miscellaneous",
510
+ "lib": null,
511
+ "subComponents": [],
512
+ "variants": {},
513
+ "notes": "Grouped button layout (use flex+gap)"
514
+ },
515
+ "Calendar": {
516
+ "file": "src/components/ui/Calendar.tsx",
517
+ "exportPath": "./calendar",
518
+ "tier": 1,
519
+ "category": "Form Controls",
520
+ "lib": "react-day-picker",
521
+ "subComponents": [],
522
+ "variants": {},
523
+ "notes": "Calendar grid primitive"
524
+ },
525
+ "Card": {
526
+ "file": "src/components/ui/Card.tsx",
527
+ "exportPath": "./card",
528
+ "tier": 1,
529
+ "category": "Display",
530
+ "lib": null,
531
+ "subComponents": [
532
+ "CardHeader",
533
+ "CardTitle",
534
+ "CardDescription",
535
+ "CardContent",
536
+ "CardFooter"
537
+ ],
538
+ "variants": {},
539
+ "notes": "Card, Header, Title, Description, Content, Footer"
540
+ },
541
+ "Carousel": {
542
+ "file": "src/components/ui/Carousel.tsx",
543
+ "exportPath": "./carousel",
544
+ "tier": 1,
545
+ "category": "Display",
546
+ "lib": "embla-carousel-react",
547
+ "subComponents": [
548
+ "CarouselContent",
549
+ "CarouselItem",
550
+ "CarouselPrevious",
551
+ "CarouselNext"
552
+ ],
553
+ "variants": {},
554
+ "notes": "Content, Item, Previous, Next"
555
+ },
556
+ "Chart": {
557
+ "file": "src/components/ui/Chart.tsx",
558
+ "exportPath": "./chart",
559
+ "tier": 2,
560
+ "category": "Charts",
561
+ "lib": null,
562
+ "subComponents": [
563
+ "ChartContainer",
564
+ "ChartTooltip",
565
+ "ChartTooltipContent",
566
+ "ChartLegend",
567
+ "ChartLegendContent",
568
+ "ChartStyle"
569
+ ],
570
+ "variants": {},
571
+ "notes": "Base config: ChartContainer, ChartTooltip, ChartLegend"
572
+ },
573
+ "ChartCard": {
574
+ "file": "src/components/ui/ChartCard.tsx",
575
+ "exportPath": "./chart-card",
576
+ "tier": 2,
577
+ "category": "Charts",
578
+ "lib": null,
579
+ "subComponents": [],
580
+ "variants": {},
581
+ "notes": "Card wrapper for chart display with title and description"
582
+ },
583
+ "CheckStatus": {
584
+ "file": "src/components/ui/CheckStatus.tsx",
585
+ "exportPath": "./check-status",
586
+ "tier": 2,
587
+ "category": "Display",
588
+ "lib": null,
589
+ "subComponents": [],
590
+ "variants": {
591
+ "status": {
592
+ "options": [
593
+ "passing",
594
+ "failing",
595
+ "pending",
596
+ "neutral"
597
+ ],
598
+ "default": "neutral"
599
+ }
600
+ },
601
+ "notes": "Status check indicator component"
602
+ },
603
+ "Checkbox": {
604
+ "file": "src/components/ui/Checkbox.tsx",
605
+ "exportPath": "./checkbox",
606
+ "tier": 1,
607
+ "category": "Form Controls",
608
+ "lib": "react-checkbox",
609
+ "subComponents": [],
610
+ "variants": {},
611
+ "notes": "With optional label"
612
+ },
613
+ "CheckoutForm": {
614
+ "file": "src/components/ui/CheckoutForm.tsx",
615
+ "exportPath": "./checkout-form",
616
+ "tier": 2,
617
+ "category": "Form Controls",
618
+ "lib": "@stripe/react-stripe-js",
619
+ "subComponents": [],
620
+ "variants": {},
621
+ "notes": "Stripe Elements checkout form"
622
+ },
623
+ "CheckoutFormDemo": {
624
+ "file": "src/components/ui/CheckoutFormDemo.tsx",
625
+ "exportPath": "./checkout-form-demo",
626
+ "tier": 2,
627
+ "category": "Form Controls",
628
+ "lib": "@stripe/react-stripe-js",
629
+ "subComponents": [],
630
+ "variants": {},
631
+ "notes": "Demo checkout with pre-wired state"
632
+ },
633
+ "CodeDiffViewer": {
634
+ "file": "src/components/ui/CodeDiffViewer.tsx",
635
+ "exportPath": "./code-diff-viewer",
636
+ "tier": 2,
637
+ "category": "Agentic UI",
638
+ "lib": null,
639
+ "subComponents": [],
640
+ "variants": {},
641
+ "notes": "Side-by-side or unified diff view"
642
+ },
643
+ "Collapsible": {
644
+ "file": "src/components/ui/Collapsible.tsx",
645
+ "exportPath": "./collapsible",
646
+ "tier": 4,
647
+ "category": "Layout and Overlays",
648
+ "lib": "react-collapsible",
649
+ "subComponents": [
650
+ "CollapsibleTrigger",
651
+ "CollapsibleContent"
652
+ ],
653
+ "variants": {},
654
+ "notes": "Used by Sidebar internally"
655
+ },
656
+ "Combobox": {
657
+ "file": "src/components/ui/Combobox.tsx",
658
+ "exportPath": "./combobox",
659
+ "tier": 1,
660
+ "category": "Form Controls",
661
+ "lib": "cmdk",
662
+ "subComponents": [],
663
+ "variants": {},
664
+ "notes": "Searchable select"
665
+ },
666
+ "Command": {
667
+ "file": "src/components/ui/Command.tsx",
668
+ "exportPath": "./command",
669
+ "tier": 1,
670
+ "category": "Navigation",
671
+ "lib": "cmdk",
672
+ "subComponents": [
673
+ "CommandDialog",
674
+ "CommandInput",
675
+ "CommandList",
676
+ "CommandEmpty",
677
+ "CommandGroup",
678
+ "CommandItem",
679
+ "CommandShortcut",
680
+ "CommandSeparator"
681
+ ],
682
+ "variants": {},
683
+ "notes": "Command palette primitive"
684
+ },
685
+ "ConfettiBurst": {
686
+ "file": "src/components/ui/ConfettiBurst.tsx",
687
+ "exportPath": "./confetti-burst",
688
+ "tier": 1,
689
+ "category": "Animation Utilities",
690
+ "lib": null,
691
+ "subComponents": [],
692
+ "variants": {},
693
+ "notes": "Celebratory confetti animation"
694
+ },
695
+ "ContextMenu": {
696
+ "file": "src/components/ui/ContextMenu.tsx",
697
+ "exportPath": "./context-menu",
698
+ "tier": 4,
699
+ "category": "Navigation",
700
+ "lib": "react-context-menu",
701
+ "subComponents": [
702
+ "ContextMenuTrigger",
703
+ "ContextMenuContent",
704
+ "ContextMenuItem",
705
+ "ContextMenuCheckboxItem",
706
+ "ContextMenuRadioItem",
707
+ "ContextMenuLabel",
708
+ "ContextMenuSeparator",
709
+ "ContextMenuShortcut",
710
+ "ContextMenuGroup",
711
+ "ContextMenuPortal",
712
+ "ContextMenuSub",
713
+ "ContextMenuSubContent",
714
+ "ContextMenuSubTrigger",
715
+ "ContextMenuRadioGroup"
716
+ ],
717
+ "variants": {},
718
+ "notes": "Rarely needed"
719
+ },
720
+ "ContextMeter": {
721
+ "file": "src/components/ui/ContextMeter.tsx",
722
+ "exportPath": "./context-meter",
723
+ "tier": 2,
724
+ "category": "Agentic UI",
725
+ "lib": null,
726
+ "subComponents": [],
727
+ "variants": {
728
+ "size": {
729
+ "options": [
730
+ "compact",
731
+ "default",
732
+ "expanded"
733
+ ],
734
+ "default": "default"
735
+ }
736
+ },
737
+ "notes": "Context window usage visualization"
738
+ },
739
+ "ConversationThread": {
740
+ "file": "src/components/ui/ConversationThread.tsx",
741
+ "exportPath": "./conversation-thread",
742
+ "tier": 2,
743
+ "category": "AI / Voice",
744
+ "lib": null,
745
+ "subComponents": [],
746
+ "variants": {
747
+ "variant": {
748
+ "options": [
749
+ "default",
750
+ "compact",
751
+ "relaxed"
752
+ ],
753
+ "default": "default"
754
+ },
755
+ "role": {
756
+ "options": [
757
+ "user",
758
+ "assistant",
759
+ "system"
760
+ ],
761
+ "default": "user"
762
+ }
763
+ },
764
+ "notes": "Chat message thread"
765
+ },
766
+ "DataFreshness": {
767
+ "file": "src/components/ui/DataFreshness.tsx",
768
+ "exportPath": "./data-freshness",
769
+ "tier": 2,
770
+ "category": "Display",
771
+ "lib": null,
772
+ "subComponents": [],
773
+ "variants": {},
774
+ "notes": "Data freshness/staleness indicator"
775
+ },
776
+ "DataTable": {
777
+ "file": "src/components/ui/DataTable.tsx",
778
+ "exportPath": "./data-table",
779
+ "tier": 1,
780
+ "category": "Display",
781
+ "lib": "@tanstack/react-table",
782
+ "subComponents": [],
783
+ "variants": {},
784
+ "notes": "Full-featured with sorting/filtering"
785
+ },
786
+ "DatePicker": {
787
+ "file": "src/components/ui/DatePicker.tsx",
788
+ "exportPath": "./date-picker",
789
+ "tier": 1,
790
+ "category": "Form Controls",
791
+ "lib": "react-day-picker",
792
+ "subComponents": [],
793
+ "variants": {},
794
+ "notes": "Single date picker"
795
+ },
796
+ "DateRangePicker": {
797
+ "file": "src/components/ui/DateRangePicker.tsx",
798
+ "exportPath": "./date-range-picker",
799
+ "tier": 1,
800
+ "category": "Form Controls",
801
+ "lib": "react-day-picker",
802
+ "subComponents": [
803
+ "DatePickerWithRange"
804
+ ],
805
+ "variants": {},
806
+ "notes": "Date range selection"
807
+ },
808
+ "Dialog": {
809
+ "file": "src/components/ui/Dialog.tsx",
810
+ "exportPath": "./dialog",
811
+ "tier": 1,
812
+ "category": "Layout and Overlays",
813
+ "lib": "react-dialog",
814
+ "subComponents": [
815
+ "DialogPortal",
816
+ "DialogOverlay",
817
+ "DialogClose",
818
+ "DialogTrigger",
819
+ "DialogContent",
820
+ "DialogHeader",
821
+ "DialogFooter",
822
+ "DialogTitle",
823
+ "DialogDescription"
824
+ ],
825
+ "variants": {},
826
+ "notes": "Full compound set with close button"
827
+ },
828
+ "DiffStat": {
829
+ "file": "src/components/ui/DiffStat.tsx",
830
+ "exportPath": "./diff-stat",
831
+ "tier": 2,
832
+ "category": "Agentic UI",
833
+ "lib": null,
834
+ "subComponents": [],
835
+ "variants": {},
836
+ "notes": "Diff statistics display (additions/deletions)"
837
+ },
838
+ "Drawer": {
839
+ "file": "src/components/ui/Drawer.tsx",
840
+ "exportPath": "./drawer",
841
+ "tier": 1,
842
+ "category": "Layout and Overlays",
843
+ "lib": "vaul",
844
+ "subComponents": [
845
+ "DrawerPortal",
846
+ "DrawerOverlay",
847
+ "DrawerTrigger",
848
+ "DrawerClose",
849
+ "DrawerContent",
850
+ "DrawerHeader",
851
+ "DrawerFooter",
852
+ "DrawerTitle",
853
+ "DrawerDescription"
854
+ ],
855
+ "variants": {},
856
+ "notes": "Mobile-friendly bottom drawer"
857
+ },
858
+ "DropdownMenu": {
859
+ "file": "src/components/ui/DropdownMenu.tsx",
860
+ "exportPath": "./dropdown-menu",
861
+ "tier": 1,
862
+ "category": "Navigation",
863
+ "lib": "react-dropdown-menu",
864
+ "subComponents": [
865
+ "DropdownMenuTrigger",
866
+ "DropdownMenuContent",
867
+ "DropdownMenuItem",
868
+ "DropdownMenuCheckboxItem",
869
+ "DropdownMenuRadioItem",
870
+ "DropdownMenuLabel",
871
+ "DropdownMenuSeparator",
872
+ "DropdownMenuShortcut",
873
+ "DropdownMenuGroup",
874
+ "DropdownMenuPortal",
875
+ "DropdownMenuSub",
876
+ "DropdownMenuSubContent",
877
+ "DropdownMenuSubTrigger",
878
+ "DropdownMenuRadioGroup"
879
+ ],
880
+ "variants": {},
881
+ "notes": "Full compound set"
882
+ },
883
+ "Empty": {
884
+ "file": "src/components/ui/Empty.tsx",
885
+ "exportPath": "./empty",
886
+ "tier": 1,
887
+ "category": "Display",
888
+ "lib": null,
889
+ "subComponents": [
890
+ "EmptyIcon",
891
+ "EmptyTitle",
892
+ "EmptyDescription"
893
+ ],
894
+ "variants": {},
895
+ "notes": "Empty state placeholder"
896
+ },
897
+ "Field": {
898
+ "file": "src/components/ui/Field.tsx",
899
+ "exportPath": "./field",
900
+ "tier": 1,
901
+ "category": "Form Controls",
902
+ "lib": null,
903
+ "subComponents": [
904
+ "FieldSet",
905
+ "FieldLegend",
906
+ "FieldGroup",
907
+ "FieldContent",
908
+ "FieldLabel",
909
+ "FieldTitle",
910
+ "FieldDescription",
911
+ "FieldSeparator",
912
+ "FieldError"
913
+ ],
914
+ "variants": {
915
+ "orientation": {
916
+ "options": [
917
+ "vertical",
918
+ "horizontal",
919
+ "responsive"
920
+ ],
921
+ "default": "vertical"
922
+ }
923
+ },
924
+ "notes": "Generic field wrapper (label + error)"
925
+ },
926
+ "FileUpload": {
927
+ "file": "src/components/ui/FileUpload.tsx",
928
+ "exportPath": "./file-upload",
929
+ "tier": 1,
930
+ "category": "Form Controls",
931
+ "lib": null,
932
+ "subComponents": [],
933
+ "variants": {
934
+ "variant": {
935
+ "options": [
936
+ "default",
937
+ "active",
938
+ "error"
939
+ ],
940
+ "default": "default"
941
+ },
942
+ "size": {
943
+ "options": [
944
+ "sm",
945
+ "default",
946
+ "lg"
947
+ ],
948
+ "default": "default"
949
+ }
950
+ },
951
+ "notes": "Drag-and-drop file upload zone"
952
+ },
953
+ "FloatingDock": {
954
+ "file": "src/components/ui/FloatingDock.tsx",
955
+ "exportPath": "./floating-dock",
956
+ "tier": 4,
957
+ "category": "Navigation",
958
+ "lib": null,
959
+ "subComponents": [],
960
+ "variants": {},
961
+ "notes": "macOS-style floating dock"
962
+ },
963
+ "Form": {
964
+ "file": "src/components/ui/Form.tsx",
965
+ "exportPath": "./form",
966
+ "tier": 1,
967
+ "category": "Form Controls",
968
+ "lib": "react-hook-form",
969
+ "subComponents": [
970
+ "FormItem",
971
+ "FormLabel",
972
+ "FormControl",
973
+ "FormDescription",
974
+ "FormMessage",
975
+ "FormField"
976
+ ],
977
+ "variants": {},
978
+ "notes": "FormField, FormItem, FormLabel, FormControl, FormMessage"
979
+ },
980
+ "FormWizard": {
981
+ "file": "src/components/ui/FormWizard.tsx",
982
+ "exportPath": "./form-wizard",
983
+ "tier": 1,
984
+ "category": "Form Controls",
985
+ "lib": null,
986
+ "subComponents": [],
987
+ "variants": {
988
+ "variant": {
989
+ "options": [
990
+ "default",
991
+ "card"
992
+ ],
993
+ "default": "default"
994
+ },
995
+ "size": {
996
+ "options": [
997
+ "sm",
998
+ "default",
999
+ "lg"
1000
+ ],
1001
+ "default": "default"
1002
+ },
1003
+ "state": {
1004
+ "options": [
1005
+ "pending",
1006
+ "active",
1007
+ "complete"
1008
+ ],
1009
+ "default": "pending"
1010
+ }
1011
+ },
1012
+ "notes": "Multi-step form wizard"
1013
+ },
1014
+ "HandoffIndicator": {
1015
+ "file": "src/components/ui/HandoffIndicator.tsx",
1016
+ "exportPath": "./handoff-indicator",
1017
+ "tier": 2,
1018
+ "category": "Agentic UI",
1019
+ "lib": null,
1020
+ "subComponents": [],
1021
+ "variants": {},
1022
+ "notes": "Agent-to-agent task handoff"
1023
+ },
1024
+ "Heading": {
1025
+ "file": "src/components/ui/Heading.tsx",
1026
+ "exportPath": "./heading",
1027
+ "tier": 1,
1028
+ "category": "Display",
1029
+ "lib": null,
1030
+ "subComponents": [],
1031
+ "variants": {
1032
+ "size": {
1033
+ "options": [
1034
+ "display",
1035
+ "section",
1036
+ "subsection",
1037
+ "title",
1038
+ "label",
1039
+ "eyebrow"
1040
+ ],
1041
+ "default": null
1042
+ }
1043
+ },
1044
+ "notes": "Semantic headings with explicit level + visual size"
1045
+ },
1046
+ "HoverCard": {
1047
+ "file": "src/components/ui/HoverCard.tsx",
1048
+ "exportPath": "./hover-card",
1049
+ "tier": 4,
1050
+ "category": "Display",
1051
+ "lib": "react-hover-card",
1052
+ "subComponents": [
1053
+ "HoverCardTrigger",
1054
+ "HoverCardContent"
1055
+ ],
1056
+ "variants": {},
1057
+ "notes": "HoverCard, Trigger, Content"
1058
+ },
1059
+ "InfiniteSlider": {
1060
+ "file": "src/components/ui/InfiniteSlider.tsx",
1061
+ "exportPath": "./infinite-slider",
1062
+ "tier": 3,
1063
+ "category": "Decorative Effects",
1064
+ "lib": null,
1065
+ "subComponents": [],
1066
+ "variants": {},
1067
+ "notes": "Auto-scrolling content slider"
1068
+ },
1069
+ "Input": {
1070
+ "file": "src/components/ui/Input.tsx",
1071
+ "exportPath": "./input",
1072
+ "tier": 1,
1073
+ "category": "Form Controls",
1074
+ "lib": null,
1075
+ "subComponents": [],
1076
+ "variants": {
1077
+ "size": {
1078
+ "options": [
1079
+ "sm",
1080
+ "default",
1081
+ "lg"
1082
+ ],
1083
+ "default": "default"
1084
+ }
1085
+ },
1086
+ "notes": "size: sm/default/lg, props: label, error, startIcon, endIcon"
1087
+ },
1088
+ "InputGroup": {
1089
+ "file": "src/components/ui/InputGroup.tsx",
1090
+ "exportPath": "./input-group",
1091
+ "tier": 1,
1092
+ "category": "Form Controls",
1093
+ "lib": null,
1094
+ "subComponents": [
1095
+ "InputGroupAddon"
1096
+ ],
1097
+ "variants": {},
1098
+ "notes": "Input + addon composition"
1099
+ },
1100
+ "InputOTP": {
1101
+ "file": "src/components/ui/InputOTP.tsx",
1102
+ "exportPath": "./input-otp",
1103
+ "tier": 1,
1104
+ "category": "Form Controls",
1105
+ "lib": "input-otp",
1106
+ "subComponents": [
1107
+ "InputOTPGroup",
1108
+ "InputOTPSlot",
1109
+ "InputOTPSeparator"
1110
+ ],
1111
+ "variants": {},
1112
+ "notes": "OTP input with groups, slots, separators"
1113
+ },
1114
+ "Item": {
1115
+ "file": "src/components/ui/Item.tsx",
1116
+ "exportPath": "./item",
1117
+ "tier": 4,
1118
+ "category": "Miscellaneous",
1119
+ "lib": null,
1120
+ "subComponents": [
1121
+ "ItemGroup",
1122
+ "ItemSeparator",
1123
+ "ItemMedia",
1124
+ "ItemContent",
1125
+ "ItemTitle",
1126
+ "ItemDescription",
1127
+ "ItemActions",
1128
+ "ItemHeader",
1129
+ "ItemFooter"
1130
+ ],
1131
+ "variants": {
1132
+ "variant": {
1133
+ "options": [
1134
+ "default",
1135
+ "icon",
1136
+ "avatar",
1137
+ "image"
1138
+ ],
1139
+ "default": "default"
1140
+ },
1141
+ "size": {
1142
+ "options": [
1143
+ "default",
1144
+ "sm",
1145
+ "xs"
1146
+ ],
1147
+ "default": "default"
1148
+ }
1149
+ },
1150
+ "notes": "Generic list item (too generic)"
1151
+ },
1152
+ "KanbanBoard": {
1153
+ "file": "src/components/ui/KanbanBoard.tsx",
1154
+ "exportPath": "./kanban-board",
1155
+ "tier": 2,
1156
+ "category": "Display",
1157
+ "lib": null,
1158
+ "subComponents": [
1159
+ "KanbanColumn",
1160
+ "KanbanColumnHeader",
1161
+ "KanbanItem",
1162
+ "KanbanHandle"
1163
+ ],
1164
+ "variants": {},
1165
+ "notes": "Drag-and-drop kanban board component"
1166
+ },
1167
+ "Kbd": {
1168
+ "file": "src/components/ui/Kbd.tsx",
1169
+ "exportPath": "./kbd",
1170
+ "tier": 1,
1171
+ "category": "Display",
1172
+ "lib": null,
1173
+ "subComponents": [],
1174
+ "variants": {},
1175
+ "notes": "Keyboard shortcut display"
1176
+ },
1177
+ "Label": {
1178
+ "file": "src/components/ui/Label.tsx",
1179
+ "exportPath": "./label",
1180
+ "tier": 1,
1181
+ "category": "Form Controls",
1182
+ "lib": "react-label",
1183
+ "subComponents": [],
1184
+ "variants": {},
1185
+ "notes": "Accessible label"
1186
+ },
1187
+ "LanguageSwitcher": {
1188
+ "file": "src/components/ui/LanguageSwitcher.tsx",
1189
+ "exportPath": "./language-switcher",
1190
+ "tier": 2,
1191
+ "category": "Navigation",
1192
+ "lib": null,
1193
+ "subComponents": [],
1194
+ "variants": {},
1195
+ "notes": "Locale/language selection switcher"
1196
+ },
1197
+ "Logo": {
1198
+ "file": "src/components/ui/Logo.tsx",
1199
+ "exportPath": "./logo",
1200
+ "tier": 1,
1201
+ "category": "Miscellaneous",
1202
+ "lib": null,
1203
+ "subComponents": [
1204
+ "LogoIcon"
1205
+ ],
1206
+ "variants": {},
1207
+ "notes": "Brand logo component"
1208
+ },
1209
+ "MagneticElement": {
1210
+ "file": "src/components/ui/MagneticElement.tsx",
1211
+ "exportPath": "./magnetic-element",
1212
+ "tier": 3,
1213
+ "category": "Decorative Effects",
1214
+ "lib": null,
1215
+ "subComponents": [],
1216
+ "variants": {},
1217
+ "notes": "Magnetic cursor attraction"
1218
+ },
1219
+ "MemoryInspector": {
1220
+ "file": "src/components/ui/MemoryInspector.tsx",
1221
+ "exportPath": "./memory-inspector",
1222
+ "tier": 2,
1223
+ "category": "Agentic UI",
1224
+ "lib": null,
1225
+ "subComponents": [],
1226
+ "variants": {},
1227
+ "notes": "Agent memory/state inspector"
1228
+ },
1229
+ "Menubar": {
1230
+ "file": "src/components/ui/Menubar.tsx",
1231
+ "exportPath": "./menubar",
1232
+ "tier": 4,
1233
+ "category": "Navigation",
1234
+ "lib": "react-menubar",
1235
+ "subComponents": [
1236
+ "MenubarMenu",
1237
+ "MenubarTrigger",
1238
+ "MenubarContent",
1239
+ "MenubarItem",
1240
+ "MenubarSeparator",
1241
+ "MenubarLabel",
1242
+ "MenubarCheckboxItem",
1243
+ "MenubarRadioItem",
1244
+ "MenubarSubContent",
1245
+ "MenubarSubTrigger",
1246
+ "MenubarShortcut"
1247
+ ],
1248
+ "variants": {},
1249
+ "notes": "Rare in modern SaaS"
1250
+ },
1251
+ "MeteorShower": {
1252
+ "file": "src/components/ui/MeteorShower.tsx",
1253
+ "exportPath": "./meteor-shower",
1254
+ "tier": 3,
1255
+ "category": "Decorative Effects",
1256
+ "lib": null,
1257
+ "subComponents": [],
1258
+ "variants": {},
1259
+ "notes": "Falling meteor particles"
1260
+ },
1261
+ "MetricCard": {
1262
+ "file": "src/components/ui/MetricCard.tsx",
1263
+ "exportPath": "./metric-card",
1264
+ "tier": 2,
1265
+ "category": "Display",
1266
+ "lib": null,
1267
+ "subComponents": [],
1268
+ "variants": {
1269
+ "size": {
1270
+ "options": [
1271
+ "sm",
1272
+ "default",
1273
+ "lg"
1274
+ ],
1275
+ "default": "default"
1276
+ }
1277
+ },
1278
+ "notes": "Single metric display card with label, value, and trend"
1279
+ },
1280
+ "MouseEffect": {
1281
+ "file": "src/components/ui/MouseEffect.tsx",
1282
+ "exportPath": "./mouse-effect",
1283
+ "tier": 3,
1284
+ "category": "Decorative Effects",
1285
+ "lib": null,
1286
+ "subComponents": [
1287
+ "MouseGlow",
1288
+ "MouseSpotlight"
1289
+ ],
1290
+ "variants": {},
1291
+ "notes": "Mouse-tracking effects (MouseGlow, MouseSpotlight)"
1292
+ },
1293
+ "MovingBorder": {
1294
+ "file": "src/components/ui/MovingBorder.tsx",
1295
+ "exportPath": "./moving-border",
1296
+ "tier": 3,
1297
+ "category": "Decorative Effects",
1298
+ "lib": null,
1299
+ "subComponents": [],
1300
+ "variants": {},
1301
+ "notes": "Animated border rotation"
1302
+ },
1303
+ "NativeSelect": {
1304
+ "file": "src/components/ui/NativeSelect.tsx",
1305
+ "exportPath": "./native-select",
1306
+ "tier": 4,
1307
+ "category": "Form Controls",
1308
+ "lib": null,
1309
+ "subComponents": [],
1310
+ "variants": {},
1311
+ "notes": "Browser-native <select> styled"
1312
+ },
1313
+ "NavigationMenu": {
1314
+ "file": "src/components/ui/NavigationMenu.tsx",
1315
+ "exportPath": "./navigation-menu",
1316
+ "tier": 1,
1317
+ "category": "Navigation",
1318
+ "lib": "react-navigation-menu",
1319
+ "subComponents": [
1320
+ "NavigationMenuList",
1321
+ "NavigationMenuItem",
1322
+ "NavigationMenuContent",
1323
+ "NavigationMenuTrigger",
1324
+ "NavigationMenuLink",
1325
+ "NavigationMenuIndicator",
1326
+ "NavigationMenuViewport"
1327
+ ],
1328
+ "variants": {},
1329
+ "notes": "Menu, List, Item, Trigger, Content"
1330
+ },
1331
+ "NotificationCenter": {
1332
+ "file": "src/components/ui/NotificationCenter.tsx",
1333
+ "exportPath": "./notification-center",
1334
+ "tier": 4,
1335
+ "category": "Miscellaneous",
1336
+ "lib": null,
1337
+ "subComponents": [],
1338
+ "variants": {
1339
+ "type": {
1340
+ "options": [
1341
+ "default",
1342
+ "info",
1343
+ "success",
1344
+ "warning",
1345
+ "error"
1346
+ ],
1347
+ "default": "default"
1348
+ }
1349
+ },
1350
+ "notes": "Overlaps with Sonner/Toast"
1351
+ },
1352
+ "PageTransition": {
1353
+ "file": "src/components/ui/PageTransition.tsx",
1354
+ "exportPath": "./page-transition",
1355
+ "tier": 1,
1356
+ "category": "Animation Utilities",
1357
+ "lib": null,
1358
+ "subComponents": [],
1359
+ "variants": {},
1360
+ "notes": "Route transition wrapper (keyed on pathname)"
1361
+ },
1362
+ "Pagination": {
1363
+ "file": "src/components/ui/Pagination.tsx",
1364
+ "exportPath": "./pagination",
1365
+ "tier": 1,
1366
+ "category": "Navigation",
1367
+ "lib": null,
1368
+ "subComponents": [
1369
+ "PaginationContent",
1370
+ "PaginationEllipsis",
1371
+ "PaginationItem",
1372
+ "PaginationLink",
1373
+ "PaginationNext",
1374
+ "PaginationPrevious"
1375
+ ],
1376
+ "variants": {},
1377
+ "notes": "Content, Item, Previous, Next"
1378
+ },
1379
+ "PasswordInput": {
1380
+ "file": "src/components/ui/PasswordInput.tsx",
1381
+ "exportPath": "./password-input",
1382
+ "tier": 1,
1383
+ "category": "Form Controls",
1384
+ "lib": null,
1385
+ "subComponents": [],
1386
+ "variants": {},
1387
+ "notes": "Input with show/hide toggle"
1388
+ },
1389
+ "Popover": {
1390
+ "file": "src/components/ui/Popover.tsx",
1391
+ "exportPath": "./popover",
1392
+ "tier": 1,
1393
+ "category": "Display",
1394
+ "lib": "react-popover",
1395
+ "subComponents": [
1396
+ "PopoverTrigger",
1397
+ "PopoverContent"
1398
+ ],
1399
+ "variants": {},
1400
+ "notes": "Popover, Trigger, Content"
1401
+ },
1402
+ "Progress": {
1403
+ "file": "src/components/ui/Progress.tsx",
1404
+ "exportPath": "./progress",
1405
+ "tier": 1,
1406
+ "category": "Display",
1407
+ "lib": "react-progress",
1408
+ "subComponents": [],
1409
+ "variants": {},
1410
+ "notes": "Progress bar"
1411
+ },
1412
+ "ProgressRing": {
1413
+ "file": "src/components/ui/ProgressRing.tsx",
1414
+ "exportPath": "./progress-ring",
1415
+ "tier": 2,
1416
+ "category": "Display",
1417
+ "lib": null,
1418
+ "subComponents": [],
1419
+ "variants": {
1420
+ "size": {
1421
+ "options": [
1422
+ "sm",
1423
+ "md",
1424
+ "lg"
1425
+ ],
1426
+ "default": "md"
1427
+ }
1428
+ },
1429
+ "notes": "Circular progress ring indicator"
1430
+ },
1431
+ "ProgressiveBlur": {
1432
+ "file": "src/components/ui/ProgressiveBlur.tsx",
1433
+ "exportPath": "./progressive-blur",
1434
+ "tier": 3,
1435
+ "category": "Decorative Effects",
1436
+ "lib": null,
1437
+ "subComponents": [],
1438
+ "variants": {},
1439
+ "notes": "Gradient blur effect"
1440
+ },
1441
+ "PromoCard": {
1442
+ "file": "src/components/ui/PromoCard.tsx",
1443
+ "exportPath": "./promo-card",
1444
+ "tier": 4,
1445
+ "category": "Display",
1446
+ "lib": null,
1447
+ "subComponents": [],
1448
+ "variants": {},
1449
+ "notes": "Promotional card (Card + glass-floating may replace)"
1450
+ },
1451
+ "RadioGroup": {
1452
+ "file": "src/components/ui/RadioGroup.tsx",
1453
+ "exportPath": "./radio-group",
1454
+ "tier": 1,
1455
+ "category": "Form Controls",
1456
+ "lib": "react-radio-group",
1457
+ "subComponents": [
1458
+ "RadioGroupItem"
1459
+ ],
1460
+ "variants": {},
1461
+ "notes": "RadioGroup + RadioGroupItem"
1462
+ },
1463
+ "Resizable": {
1464
+ "file": "src/components/ui/Resizable.tsx",
1465
+ "exportPath": "./resizable",
1466
+ "tier": 1,
1467
+ "category": "Layout and Overlays",
1468
+ "lib": "react-resizable-panels",
1469
+ "subComponents": [
1470
+ "ResizablePanelGroup",
1471
+ "ResizablePanel",
1472
+ "ResizableHandle"
1473
+ ],
1474
+ "variants": {},
1475
+ "notes": "PanelGroup, Panel, Handle"
1476
+ },
1477
+ "RoleBadge": {
1478
+ "file": "src/components/ui/RoleBadge.tsx",
1479
+ "exportPath": "./role-badge",
1480
+ "tier": 4,
1481
+ "category": "Display",
1482
+ "lib": null,
1483
+ "subComponents": [],
1484
+ "variants": {
1485
+ "role": {
1486
+ "options": [
1487
+ "owner",
1488
+ "admin",
1489
+ "member",
1490
+ "guest"
1491
+ ],
1492
+ "default": "member"
1493
+ }
1494
+ },
1495
+ "notes": "Role-specific badge styling (merge into Badge)"
1496
+ },
1497
+ "ScrollArea": {
1498
+ "file": "src/components/ui/ScrollArea.tsx",
1499
+ "exportPath": "./scroll-area",
1500
+ "tier": 1,
1501
+ "category": "Layout and Overlays",
1502
+ "lib": "react-scroll-area",
1503
+ "subComponents": [
1504
+ "ScrollBar"
1505
+ ],
1506
+ "variants": {},
1507
+ "notes": "Custom scrollbar"
1508
+ },
1509
+ "ScrollFadeIn": {
1510
+ "file": "src/components/ui/ScrollFadeIn.tsx",
1511
+ "exportPath": "./scroll-fade-in",
1512
+ "tier": 1,
1513
+ "category": "Animation Utilities",
1514
+ "lib": null,
1515
+ "subComponents": [],
1516
+ "variants": {},
1517
+ "notes": "Fade in on scroll intersection"
1518
+ },
1519
+ "SearchCommand": {
1520
+ "file": "src/components/ui/SearchCommand.tsx",
1521
+ "exportPath": "./search-command",
1522
+ "tier": 1,
1523
+ "category": "Navigation",
1524
+ "lib": "cmdk",
1525
+ "subComponents": [],
1526
+ "variants": {
1527
+ "variant": {
1528
+ "options": [
1529
+ "default",
1530
+ "floating"
1531
+ ],
1532
+ "default": "default"
1533
+ },
1534
+ "size": {
1535
+ "options": [
1536
+ "sm",
1537
+ "default",
1538
+ "lg"
1539
+ ],
1540
+ "default": "default"
1541
+ }
1542
+ },
1543
+ "notes": "Cmd+K search dialog"
1544
+ },
1545
+ "Select": {
1546
+ "file": "src/components/ui/Select.tsx",
1547
+ "exportPath": "./select",
1548
+ "tier": 1,
1549
+ "category": "Form Controls",
1550
+ "lib": "react-select",
1551
+ "subComponents": [
1552
+ "SelectGroup",
1553
+ "SelectValue",
1554
+ "SelectTrigger",
1555
+ "SelectContent",
1556
+ "SelectLabel",
1557
+ "SelectItem",
1558
+ "SelectSeparator",
1559
+ "SelectScrollUpButton",
1560
+ "SelectScrollDownButton"
1561
+ ],
1562
+ "variants": {},
1563
+ "notes": "Compound: Trigger, Content, Item, Group, Separator"
1564
+ },
1565
+ "Separator": {
1566
+ "file": "src/components/ui/Separator.tsx",
1567
+ "exportPath": "./separator",
1568
+ "tier": 1,
1569
+ "category": "Layout and Overlays",
1570
+ "lib": "react-separator",
1571
+ "subComponents": [],
1572
+ "variants": {},
1573
+ "notes": "Horizontal/vertical divider"
1574
+ },
1575
+ "SettingsModal": {
1576
+ "file": "src/components/ui/SettingsModal.tsx",
1577
+ "exportPath": "./settings-modal",
1578
+ "tier": 2,
1579
+ "category": "Layout and Overlays",
1580
+ "lib": null,
1581
+ "subComponents": [],
1582
+ "variants": {},
1583
+ "notes": "Modal dialog for application settings"
1584
+ },
1585
+ "ShaderBackground": {
1586
+ "file": "src/components/ui/ShaderBackground.tsx",
1587
+ "exportPath": "./shader-background",
1588
+ "tier": 2,
1589
+ "category": "Decorative Effects",
1590
+ "lib": "@paper-design/shaders-react",
1591
+ "subComponents": [],
1592
+ "variants": {},
1593
+ "notes": "21 shader types with intent-based presets (hero, section, ambient, card)"
1594
+ },
1595
+ "Sheet": {
1596
+ "file": "src/components/ui/Sheet.tsx",
1597
+ "exportPath": "./sheet",
1598
+ "tier": 1,
1599
+ "category": "Layout and Overlays",
1600
+ "lib": "react-dialog",
1601
+ "subComponents": [
1602
+ "SheetPortal",
1603
+ "SheetOverlay",
1604
+ "SheetTrigger",
1605
+ "SheetClose",
1606
+ "SheetContent",
1607
+ "SheetHeader",
1608
+ "SheetFooter",
1609
+ "SheetTitle",
1610
+ "SheetDescription"
1611
+ ],
1612
+ "variants": {
1613
+ "side": {
1614
+ "options": [
1615
+ "top",
1616
+ "bottom",
1617
+ "left",
1618
+ "right"
1619
+ ],
1620
+ "default": "right"
1621
+ }
1622
+ },
1623
+ "notes": "Slide-in side panel"
1624
+ },
1625
+ "Sidebar": {
1626
+ "file": "src/components/ui/Sidebar.tsx",
1627
+ "exportPath": "./sidebar",
1628
+ "tier": 1,
1629
+ "category": "Navigation",
1630
+ "lib": null,
1631
+ "subComponents": [
1632
+ "SidebarContent",
1633
+ "SidebarFooter",
1634
+ "SidebarGroup",
1635
+ "SidebarGroupAction",
1636
+ "SidebarGroupContent",
1637
+ "SidebarGroupLabel",
1638
+ "SidebarHeader",
1639
+ "SidebarInput",
1640
+ "SidebarInset",
1641
+ "SidebarMenu",
1642
+ "SidebarMenuAction",
1643
+ "SidebarMenuBadge",
1644
+ "SidebarMenuButton",
1645
+ "SidebarMenuItem",
1646
+ "SidebarMenuSkeleton",
1647
+ "SidebarMenuStatus",
1648
+ "SidebarMenuSub",
1649
+ "SidebarMenuSubButton",
1650
+ "SidebarMenuSubItem",
1651
+ "SidebarProvider",
1652
+ "SidebarRail",
1653
+ "SidebarSeparator",
1654
+ "SidebarTrigger"
1655
+ ],
1656
+ "variants": {
1657
+ "variant": {
1658
+ "options": [
1659
+ "default",
1660
+ "outline"
1661
+ ],
1662
+ "default": "default"
1663
+ },
1664
+ "size": {
1665
+ "options": [
1666
+ "default",
1667
+ "sm",
1668
+ "lg"
1669
+ ],
1670
+ "default": "default"
1671
+ }
1672
+ },
1673
+ "notes": "Full system: Provider, Trigger, Content, Group, Menu"
1674
+ },
1675
+ "Skeleton": {
1676
+ "file": "src/components/ui/Skeleton.tsx",
1677
+ "exportPath": "./skeleton",
1678
+ "tier": 1,
1679
+ "category": "Display",
1680
+ "lib": null,
1681
+ "subComponents": [],
1682
+ "variants": {},
1683
+ "notes": "Loading placeholder"
1684
+ },
1685
+ "SkipNav": {
1686
+ "file": "src/components/ui/SkipNav.tsx",
1687
+ "exportPath": "./skip-nav",
1688
+ "tier": 1,
1689
+ "category": "Miscellaneous",
1690
+ "lib": null,
1691
+ "subComponents": [],
1692
+ "variants": {},
1693
+ "notes": "Accessibility skip navigation"
1694
+ },
1695
+ "Slider": {
1696
+ "file": "src/components/ui/Slider.tsx",
1697
+ "exportPath": "./slider",
1698
+ "tier": 1,
1699
+ "category": "Form Controls",
1700
+ "lib": "react-slider",
1701
+ "subComponents": [],
1702
+ "variants": {},
1703
+ "notes": "Range slider"
1704
+ },
1705
+ "Sonner": {
1706
+ "file": "src/components/ui/Sonner.tsx",
1707
+ "exportPath": "./sonner",
1708
+ "tier": 1,
1709
+ "category": "Miscellaneous",
1710
+ "lib": null,
1711
+ "subComponents": [],
1712
+ "variants": {},
1713
+ "notes": "Sonner toast integration"
1714
+ },
1715
+ "SourceCitation": {
1716
+ "file": "src/components/ui/SourceCitation.tsx",
1717
+ "exportPath": "./source-citation",
1718
+ "tier": 2,
1719
+ "category": "Agentic UI",
1720
+ "lib": null,
1721
+ "subComponents": [],
1722
+ "variants": {
1723
+ "size": {
1724
+ "options": [
1725
+ "inline",
1726
+ "default"
1727
+ ],
1728
+ "default": "default"
1729
+ }
1730
+ },
1731
+ "notes": "Cited sources with links"
1732
+ },
1733
+ "Spinner": {
1734
+ "file": "src/components/ui/Spinner.tsx",
1735
+ "exportPath": "./spinner",
1736
+ "tier": 1,
1737
+ "category": "Display",
1738
+ "lib": null,
1739
+ "subComponents": [],
1740
+ "variants": {},
1741
+ "notes": "Loading spinner"
1742
+ },
1743
+ "SpringHover": {
1744
+ "file": "src/components/ui/SpringHover.tsx",
1745
+ "exportPath": "./spring-hover",
1746
+ "tier": 3,
1747
+ "category": "Animation Utilities",
1748
+ "lib": null,
1749
+ "subComponents": [],
1750
+ "variants": {},
1751
+ "notes": "Spring-based hover effect wrapper"
1752
+ },
1753
+ "StaggerChildren": {
1754
+ "file": "src/components/ui/StaggerChildren.tsx",
1755
+ "exportPath": "./stagger-children",
1756
+ "tier": 1,
1757
+ "category": "Animation Utilities",
1758
+ "lib": null,
1759
+ "subComponents": [],
1760
+ "variants": {},
1761
+ "notes": "Stagger child element entrances"
1762
+ },
1763
+ "StaggeredEntrance": {
1764
+ "file": "src/components/ui/StaggeredEntrance.tsx",
1765
+ "exportPath": "./staggered-entrance",
1766
+ "tier": 3,
1767
+ "category": "Animation Utilities",
1768
+ "lib": null,
1769
+ "subComponents": [],
1770
+ "variants": {},
1771
+ "notes": "Sequential entrance animation"
1772
+ },
1773
+ "StatusDot": {
1774
+ "file": "src/components/ui/StatusDot.tsx",
1775
+ "exportPath": "./status-dot",
1776
+ "tier": 4,
1777
+ "category": "Display",
1778
+ "lib": null,
1779
+ "subComponents": [],
1780
+ "variants": {
1781
+ "status": {
1782
+ "options": [
1783
+ "online",
1784
+ "offline",
1785
+ "busy",
1786
+ "dnd"
1787
+ ],
1788
+ "default": "offline"
1789
+ },
1790
+ "size": {
1791
+ "options": [
1792
+ "sm",
1793
+ "default",
1794
+ "lg"
1795
+ ],
1796
+ "default": "default"
1797
+ }
1798
+ },
1799
+ "notes": "Status indicator dot (can be CSS utility)"
1800
+ },
1801
+ "StyleToggle": {
1802
+ "file": "src/components/ui/StyleToggle.tsx",
1803
+ "exportPath": "./style-toggle",
1804
+ "tier": 1,
1805
+ "category": "Miscellaneous",
1806
+ "lib": null,
1807
+ "subComponents": [],
1808
+ "variants": {},
1809
+ "notes": "Arctic/bloom style switcher"
1810
+ },
1811
+ "SuccessCheck": {
1812
+ "file": "src/components/ui/SuccessCheck.tsx",
1813
+ "exportPath": "./success-check",
1814
+ "tier": 1,
1815
+ "category": "Animation Utilities",
1816
+ "lib": null,
1817
+ "subComponents": [],
1818
+ "variants": {},
1819
+ "notes": "Animated success checkmark"
1820
+ },
1821
+ "Switch": {
1822
+ "file": "src/components/ui/Switch.tsx",
1823
+ "exportPath": "./switch",
1824
+ "tier": 1,
1825
+ "category": "Form Controls",
1826
+ "lib": "react-switch",
1827
+ "subComponents": [],
1828
+ "variants": {},
1829
+ "notes": "Toggle switch"
1830
+ },
1831
+ "Table": {
1832
+ "file": "src/components/ui/Table.tsx",
1833
+ "exportPath": "./table",
1834
+ "tier": 1,
1835
+ "category": "Display",
1836
+ "lib": null,
1837
+ "subComponents": [
1838
+ "TableHeader",
1839
+ "TableBody",
1840
+ "TableFooter",
1841
+ "TableHead",
1842
+ "TableRow",
1843
+ "TableCell",
1844
+ "TableCaption"
1845
+ ],
1846
+ "variants": {},
1847
+ "notes": "Table, Header, Body, Row, Head, Cell"
1848
+ },
1849
+ "Tabs": {
1850
+ "file": "src/components/ui/Tabs.tsx",
1851
+ "exportPath": "./tabs",
1852
+ "tier": 1,
1853
+ "category": "Display",
1854
+ "lib": "react-tabs",
1855
+ "subComponents": [
1856
+ "TabsList",
1857
+ "TabsTrigger",
1858
+ "TabsContent"
1859
+ ],
1860
+ "variants": {},
1861
+ "notes": "Tabs, TabsList, TabsTrigger, TabsContent"
1862
+ },
1863
+ "TagInput": {
1864
+ "file": "src/components/ui/TagInput.tsx",
1865
+ "exportPath": "./tag-input",
1866
+ "tier": 1,
1867
+ "category": "Form Controls",
1868
+ "lib": null,
1869
+ "subComponents": [],
1870
+ "variants": {},
1871
+ "notes": "Multi-value tag input"
1872
+ },
1873
+ "Textarea": {
1874
+ "file": "src/components/ui/Textarea.tsx",
1875
+ "exportPath": "./textarea",
1876
+ "tier": 1,
1877
+ "category": "Form Controls",
1878
+ "lib": null,
1879
+ "subComponents": [],
1880
+ "variants": {
1881
+ "size": {
1882
+ "options": [
1883
+ "sm",
1884
+ "default",
1885
+ "lg"
1886
+ ],
1887
+ "default": "default"
1888
+ }
1889
+ },
1890
+ "notes": "Auto-grow text area"
1891
+ },
1892
+ "ThemeToggle": {
1893
+ "file": "src/components/ui/ThemeToggle.tsx",
1894
+ "exportPath": "./theme-toggle",
1895
+ "tier": 1,
1896
+ "category": "Miscellaneous",
1897
+ "lib": null,
1898
+ "subComponents": [],
1899
+ "variants": {},
1900
+ "notes": "Light/dark/system theme switcher"
1901
+ },
1902
+ "ThinkingIndicator": {
1903
+ "file": "src/components/ui/ThinkingIndicator.tsx",
1904
+ "exportPath": "./thinking-indicator",
1905
+ "tier": 2,
1906
+ "category": "Agentic UI",
1907
+ "lib": null,
1908
+ "subComponents": [],
1909
+ "variants": {
1910
+ "size": {
1911
+ "options": [
1912
+ "sm",
1913
+ "default",
1914
+ "lg"
1915
+ ],
1916
+ "default": "default"
1917
+ }
1918
+ },
1919
+ "notes": "Animated \"thinking...\" for agent reasoning"
1920
+ },
1921
+ "TiltCard": {
1922
+ "file": "src/components/ui/TiltCard.tsx",
1923
+ "exportPath": "./tilt-card",
1924
+ "tier": 3,
1925
+ "category": "Decorative Effects",
1926
+ "lib": null,
1927
+ "subComponents": [],
1928
+ "variants": {},
1929
+ "notes": "3D perspective tilt on hover"
1930
+ },
1931
+ "Timeline": {
1932
+ "file": "src/components/ui/Timeline.tsx",
1933
+ "exportPath": "./timeline",
1934
+ "tier": 1,
1935
+ "category": "Display",
1936
+ "lib": null,
1937
+ "subComponents": [],
1938
+ "variants": {},
1939
+ "notes": "Vertical timeline"
1940
+ },
1941
+ "Toast": {
1942
+ "file": "src/components/ui/Toast.tsx",
1943
+ "exportPath": "./toast",
1944
+ "tier": 1,
1945
+ "category": "Miscellaneous",
1946
+ "lib": "react-toast",
1947
+ "subComponents": [
1948
+ "ToastProvider",
1949
+ "ToastViewport",
1950
+ "ToastTitle",
1951
+ "ToastDescription",
1952
+ "ToastClose",
1953
+ "ToastAction"
1954
+ ],
1955
+ "variants": {
1956
+ "variant": {
1957
+ "options": [
1958
+ "default",
1959
+ "destructive"
1960
+ ],
1961
+ "default": "default"
1962
+ }
1963
+ },
1964
+ "notes": "Toast notification primitive"
1965
+ },
1966
+ "Toaster": {
1967
+ "file": "src/components/ui/Toaster.tsx",
1968
+ "exportPath": "./toaster",
1969
+ "tier": 1,
1970
+ "category": "Miscellaneous",
1971
+ "lib": "react-toast",
1972
+ "subComponents": [],
1973
+ "variants": {},
1974
+ "notes": "Toast container and renderer"
1975
+ },
1976
+ "Toggle": {
1977
+ "file": "src/components/ui/Toggle.tsx",
1978
+ "exportPath": "./toggle",
1979
+ "tier": 4,
1980
+ "category": "Layout and Overlays",
1981
+ "lib": "react-toggle",
1982
+ "subComponents": [],
1983
+ "variants": {
1984
+ "variant": {
1985
+ "options": [
1986
+ "default",
1987
+ "outline"
1988
+ ],
1989
+ "default": "default"
1990
+ },
1991
+ "size": {
1992
+ "options": [
1993
+ "default",
1994
+ "sm",
1995
+ "lg"
1996
+ ],
1997
+ "default": "default"
1998
+ }
1999
+ },
2000
+ "notes": "variant: default, outline"
2001
+ },
2002
+ "ToggleGroup": {
2003
+ "file": "src/components/ui/ToggleGroup.tsx",
2004
+ "exportPath": "./toggle-group",
2005
+ "tier": 4,
2006
+ "category": "Layout and Overlays",
2007
+ "lib": "react-toggle-group",
2008
+ "subComponents": [
2009
+ "ToggleGroupItem"
2010
+ ],
2011
+ "variants": {},
2012
+ "notes": "Group of toggles"
2013
+ },
2014
+ "ToolCallCard": {
2015
+ "file": "src/components/ui/ToolCallCard.tsx",
2016
+ "exportPath": "./tool-call-card",
2017
+ "tier": 2,
2018
+ "category": "Agentic UI",
2019
+ "lib": null,
2020
+ "subComponents": [],
2021
+ "variants": {
2022
+ "status": {
2023
+ "options": [
2024
+ "pending",
2025
+ "running",
2026
+ "complete",
2027
+ "error"
2028
+ ],
2029
+ "default": "pending"
2030
+ }
2031
+ },
2032
+ "notes": "Tool invocation with name, args, status, result"
2033
+ },
2034
+ "Tooltip": {
2035
+ "file": "src/components/ui/Tooltip.tsx",
2036
+ "exportPath": "./tooltip",
2037
+ "tier": 1,
2038
+ "category": "Display",
2039
+ "lib": "react-tooltip",
2040
+ "subComponents": [
2041
+ "TooltipTrigger",
2042
+ "TooltipContent",
2043
+ "TooltipProvider"
2044
+ ],
2045
+ "variants": {},
2046
+ "notes": "Provider, Tooltip, Trigger, Content"
2047
+ },
2048
+ "TreeView": {
2049
+ "file": "src/components/ui/TreeView.tsx",
2050
+ "exportPath": "./tree-view",
2051
+ "tier": 1,
2052
+ "category": "Navigation",
2053
+ "lib": null,
2054
+ "subComponents": [],
2055
+ "variants": {},
2056
+ "notes": "Recursive collapsible tree with keyboard nav"
2057
+ },
2058
+ "TrendIndicator": {
2059
+ "file": "src/components/ui/TrendIndicator.tsx",
2060
+ "exportPath": "./trend-indicator",
2061
+ "tier": 2,
2062
+ "category": "Display",
2063
+ "lib": null,
2064
+ "subComponents": [],
2065
+ "variants": {},
2066
+ "notes": "Trend direction indicator (up/down/neutral)"
2067
+ },
2068
+ "Typography": {
2069
+ "file": "src/components/ui/Typography.tsx",
2070
+ "exportPath": "./typography",
2071
+ "tier": 1,
2072
+ "category": "Display",
2073
+ "lib": null,
2074
+ "subComponents": [],
2075
+ "variants": {
2076
+ "variant": {
2077
+ "options": [
2078
+ "h1",
2079
+ "h2",
2080
+ "h3",
2081
+ "h4",
2082
+ "body",
2083
+ "small",
2084
+ "muted"
2085
+ ],
2086
+ "default": "body"
2087
+ }
2088
+ },
2089
+ "notes": "Body, small, and muted text only"
2090
+ },
2091
+ "VisuallyHidden": {
2092
+ "file": "src/components/ui/VisuallyHidden.tsx",
2093
+ "exportPath": "./visually-hidden",
2094
+ "tier": 1,
2095
+ "category": "Miscellaneous",
2096
+ "lib": null,
2097
+ "subComponents": [],
2098
+ "variants": {},
2099
+ "notes": "Screen-reader-only content"
2100
+ },
2101
+ "WorkflowGraph": {
2102
+ "file": "src/components/ui/WorkflowGraph.tsx",
2103
+ "exportPath": "./workflow-graph",
2104
+ "tier": 2,
2105
+ "category": "Agentic UI",
2106
+ "lib": null,
2107
+ "subComponents": [],
2108
+ "variants": {},
2109
+ "notes": "Visual graph of workflow steps"
2110
+ },
2111
+ "AreaChart": {
2112
+ "file": "src/components/ui/charts/AreaChart.tsx",
2113
+ "exportPath": "./charts/area-chart",
2114
+ "tier": 2,
2115
+ "category": "Charts",
2116
+ "lib": null,
2117
+ "subComponents": [],
2118
+ "variants": {},
2119
+ "notes": "Recharts area chart"
2120
+ },
2121
+ "BarChart": {
2122
+ "file": "src/components/ui/charts/BarChart.tsx",
2123
+ "exportPath": "./charts/bar-chart",
2124
+ "tier": 2,
2125
+ "category": "Charts",
2126
+ "lib": null,
2127
+ "subComponents": [],
2128
+ "variants": {},
2129
+ "notes": "Recharts bar chart"
2130
+ },
2131
+ "HeatmapChart": {
2132
+ "file": "src/components/ui/charts/HeatmapChart.tsx",
2133
+ "exportPath": "./charts/heatmap-chart",
2134
+ "tier": 2,
2135
+ "category": "Charts",
2136
+ "lib": null,
2137
+ "subComponents": [],
2138
+ "variants": {},
2139
+ "notes": "Custom heatmap visualization"
2140
+ },
2141
+ "LineChart": {
2142
+ "file": "src/components/ui/charts/LineChart.tsx",
2143
+ "exportPath": "./charts/line-chart",
2144
+ "tier": 2,
2145
+ "category": "Charts",
2146
+ "lib": null,
2147
+ "subComponents": [],
2148
+ "variants": {},
2149
+ "notes": "Recharts line chart"
2150
+ },
2151
+ "PieChart": {
2152
+ "file": "src/components/ui/charts/PieChart.tsx",
2153
+ "exportPath": "./charts/pie-chart",
2154
+ "tier": 2,
2155
+ "category": "Charts",
2156
+ "lib": null,
2157
+ "subComponents": [],
2158
+ "variants": {},
2159
+ "notes": "Recharts pie/donut chart"
2160
+ },
2161
+ "RadarChart": {
2162
+ "file": "src/components/ui/charts/RadarChart.tsx",
2163
+ "exportPath": "./charts/radar-chart",
2164
+ "tier": 2,
2165
+ "category": "Charts",
2166
+ "lib": null,
2167
+ "subComponents": [],
2168
+ "variants": {},
2169
+ "notes": "Recharts radar chart"
2170
+ },
2171
+ "RadialBarChart": {
2172
+ "file": "src/components/ui/charts/RadialBarChart.tsx",
2173
+ "exportPath": "./charts/radial-bar-chart",
2174
+ "tier": 2,
2175
+ "category": "Charts",
2176
+ "lib": null,
2177
+ "subComponents": [],
2178
+ "variants": {},
2179
+ "notes": "Recharts radial bar chart"
2180
+ },
2181
+ "Sparkline": {
2182
+ "file": "src/components/ui/charts/Sparkline.tsx",
2183
+ "exportPath": "./charts/sparkline",
2184
+ "tier": 2,
2185
+ "category": "Charts",
2186
+ "lib": null,
2187
+ "subComponents": [],
2188
+ "variants": {},
2189
+ "notes": "Inline sparkline chart for compact trend display"
2190
+ },
2191
+ "AnimatedGradientText": {
2192
+ "file": "src/components/ui/text-effects/AnimatedGradientText.tsx",
2193
+ "exportPath": "./text-effects/animated-gradient-text",
2194
+ "tier": 3,
2195
+ "category": "Text Effects",
2196
+ "lib": null,
2197
+ "subComponents": [],
2198
+ "variants": {},
2199
+ "notes": "Animated gradient sweep on text"
2200
+ },
2201
+ "CountingNumber": {
2202
+ "file": "src/components/ui/text-effects/CountingNumber.tsx",
2203
+ "exportPath": "./text-effects/counting-number",
2204
+ "tier": 3,
2205
+ "category": "Text Effects",
2206
+ "lib": null,
2207
+ "subComponents": [],
2208
+ "variants": {},
2209
+ "notes": "Animated number counter (also used in dashboard)"
2210
+ },
2211
+ "FlipWords": {
2212
+ "file": "src/components/ui/text-effects/FlipWords.tsx",
2213
+ "exportPath": "./text-effects/flip-words",
2214
+ "tier": 3,
2215
+ "category": "Text Effects",
2216
+ "lib": null,
2217
+ "subComponents": [],
2218
+ "variants": {},
2219
+ "notes": "Word cycling with flip animation"
2220
+ },
2221
+ "HighlightText": {
2222
+ "file": "src/components/ui/text-effects/HighlightText.tsx",
2223
+ "exportPath": "./text-effects/highlight-text",
2224
+ "tier": 3,
2225
+ "category": "Text Effects",
2226
+ "lib": null,
2227
+ "subComponents": [],
2228
+ "variants": {},
2229
+ "notes": "Animated highlight marker"
2230
+ },
2231
+ "MorphingText": {
2232
+ "file": "src/components/ui/text-effects/MorphingText.tsx",
2233
+ "exportPath": "./text-effects/morphing-text",
2234
+ "tier": 3,
2235
+ "category": "Text Effects",
2236
+ "lib": null,
2237
+ "subComponents": [],
2238
+ "variants": {},
2239
+ "notes": "SVG text morphing transitions"
2240
+ },
2241
+ "ShimmeringText": {
2242
+ "file": "src/components/ui/text-effects/ShimmeringText.tsx",
2243
+ "exportPath": "./text-effects/shimmering-text",
2244
+ "tier": 3,
2245
+ "category": "Text Effects",
2246
+ "lib": null,
2247
+ "subComponents": [],
2248
+ "variants": {},
2249
+ "notes": "Shimmer highlight sweep"
2250
+ },
2251
+ "SlidingNumber": {
2252
+ "file": "src/components/ui/text-effects/SlidingNumber.tsx",
2253
+ "exportPath": "./text-effects/sliding-number",
2254
+ "tier": 3,
2255
+ "category": "Text Effects",
2256
+ "lib": null,
2257
+ "subComponents": [],
2258
+ "variants": {},
2259
+ "notes": "Digit-by-digit sliding animation"
2260
+ },
2261
+ "StreamingText": {
2262
+ "file": "src/components/ui/text-effects/StreamingText.tsx",
2263
+ "exportPath": "./text-effects/streaming-text",
2264
+ "tier": 3,
2265
+ "category": "Text Effects",
2266
+ "lib": null,
2267
+ "subComponents": [],
2268
+ "variants": {
2269
+ "variant": {
2270
+ "options": [
2271
+ "default",
2272
+ "muted",
2273
+ "accent"
2274
+ ],
2275
+ "default": "default"
2276
+ },
2277
+ "size": {
2278
+ "options": [
2279
+ "sm",
2280
+ "default",
2281
+ "lg"
2282
+ ],
2283
+ "default": "default"
2284
+ },
2285
+ "cursorStyle": {
2286
+ "options": [
2287
+ "block",
2288
+ "line",
2289
+ "underscore"
2290
+ ],
2291
+ "default": "line"
2292
+ }
2293
+ },
2294
+ "notes": "ChatGPT-style streaming output"
2295
+ },
2296
+ "TextReveal": {
2297
+ "file": "src/components/ui/text-effects/TextReveal.tsx",
2298
+ "exportPath": "./text-effects/text-reveal",
2299
+ "tier": 3,
2300
+ "category": "Text Effects",
2301
+ "lib": null,
2302
+ "subComponents": [],
2303
+ "variants": {},
2304
+ "notes": "Scroll-triggered text reveal"
2305
+ },
2306
+ "Step": {
2307
+ "file": "src/components/ui/stepper/step.tsx",
2308
+ "exportPath": "./stepper/step",
2309
+ "tier": 1,
2310
+ "category": "Multi-Step / Stepper",
2311
+ "lib": null,
2312
+ "subComponents": [
2313
+ "Step"
2314
+ ],
2315
+ "variants": {},
2316
+ "notes": "Individual step"
2317
+ },
2318
+ "Stepper": {
2319
+ "file": "src/components/ui/stepper/stepper.tsx",
2320
+ "exportPath": "./stepper/stepper",
2321
+ "tier": 1,
2322
+ "category": "Multi-Step / Stepper",
2323
+ "lib": null,
2324
+ "subComponents": [
2325
+ "Stepper"
2326
+ ],
2327
+ "variants": {},
2328
+ "notes": "Root stepper, exports useStepper hook"
2329
+ },
2330
+ "Grid": {
2331
+ "file": "src/components/layout/Grid.tsx",
2332
+ "exportPath": "./layout/grid",
2333
+ "tier": 1,
2334
+ "category": "Layout and Overlays",
2335
+ "lib": null,
2336
+ "subComponents": [
2337
+ "Container"
2338
+ ],
2339
+ "variants": {},
2340
+ "notes": "CSS Grid wrapper"
2341
+ },
2342
+ "GridSystem": {
2343
+ "file": "src/components/layout/GridSystem.tsx",
2344
+ "exportPath": "./layout/grid-system",
2345
+ "tier": 2,
2346
+ "category": "Layout and Overlays",
2347
+ "lib": null,
2348
+ "subComponents": [],
2349
+ "variants": {},
2350
+ "notes": "Extended grid system with responsive column and gap utilities"
2351
+ }
2352
+ },
2353
+ "blocks": {
2354
+ "AccountLockedBlock": {
2355
+ "file": "src/components/blocks/AccountLockedBlock.tsx",
2356
+ "exportPath": "./account-locked-block",
2357
+ "tier": 2,
2358
+ "category": "Auth Flow",
2359
+ "lib": null,
2360
+ "subComponents": [],
2361
+ "variants": {},
2362
+ "notes": "Account locked notification",
2363
+ "keyProps": [
2364
+ "reason",
2365
+ "unlockMinutes",
2366
+ "onContactSupport",
2367
+ "onBackToLogin",
2368
+ "title",
2369
+ "description"
2370
+ ]
2371
+ },
2372
+ "ActivityFeedBlock": {
2373
+ "file": "src/components/blocks/ActivityFeedBlock.tsx",
2374
+ "exportPath": "./activity-feed-block",
2375
+ "tier": 2,
2376
+ "category": "Dashboard & Data",
2377
+ "lib": null,
2378
+ "subComponents": [],
2379
+ "variants": {},
2380
+ "notes": "Activity/event timeline",
2381
+ "keyProps": [
2382
+ "activities",
2383
+ "title"
2384
+ ]
2385
+ },
2386
+ "AgentConversationBlock": {
2387
+ "file": "src/components/blocks/AgentConversationBlock.tsx",
2388
+ "exportPath": "./agent-conversation-block",
2389
+ "tier": 2,
2390
+ "category": "Agentic",
2391
+ "lib": null,
2392
+ "subComponents": [],
2393
+ "variants": {},
2394
+ "notes": "Agent conversation UI (messages, tool calls, thinking)",
2395
+ "keyProps": []
2396
+ },
2397
+ "AgentProfileGridBlock": {
2398
+ "file": "src/components/blocks/AgentProfileGridBlock.tsx",
2399
+ "exportPath": "./agent-profile-grid-block",
2400
+ "tier": 2,
2401
+ "category": "Marketing",
2402
+ "lib": null,
2403
+ "subComponents": [],
2404
+ "variants": {},
2405
+ "notes": "Agent/worker profile card grid (\"Meet your AI team\")",
2406
+ "keyProps": [
2407
+ "title",
2408
+ "description",
2409
+ "agents",
2410
+ "columns"
2411
+ ]
2412
+ },
2413
+ "AgentRunOverviewBlock": {
2414
+ "file": "src/components/blocks/AgentRunOverviewBlock.tsx",
2415
+ "exportPath": "./agent-run-overview-block",
2416
+ "tier": 2,
2417
+ "category": "Agentic",
2418
+ "lib": null,
2419
+ "subComponents": [],
2420
+ "variants": {},
2421
+ "notes": "Agent run summary with status, duration, and output",
2422
+ "keyProps": []
2423
+ },
2424
+ "AgentWorkbenchBlock": {
2425
+ "file": "src/components/blocks/AgentWorkbenchBlock.tsx",
2426
+ "exportPath": "./agent-workbench-block",
2427
+ "tier": 2,
2428
+ "category": "Agentic",
2429
+ "lib": null,
2430
+ "subComponents": [],
2431
+ "variants": {},
2432
+ "notes": "Agent workbench layout with tool panels and conversation",
2433
+ "keyProps": []
2434
+ },
2435
+ "AudioVisualizerBlock": {
2436
+ "file": "src/components/blocks/AudioVisualizerBlock.tsx",
2437
+ "exportPath": "./audio-visualizer-block",
2438
+ "tier": 2,
2439
+ "category": "Content & Media",
2440
+ "lib": null,
2441
+ "subComponents": [
2442
+ "AudioVisualizer"
2443
+ ],
2444
+ "variants": {},
2445
+ "notes": "Audio visualization display",
2446
+ "keyProps": []
2447
+ },
2448
+ "AuthLayout": {
2449
+ "file": "src/components/blocks/AuthLayout.tsx",
2450
+ "exportPath": "./auth-layout",
2451
+ "tier": 2,
2452
+ "category": "Auth Flow",
2453
+ "lib": null,
2454
+ "subComponents": [],
2455
+ "variants": {},
2456
+ "notes": "Split-screen auth layout wrapper",
2457
+ "keyProps": [
2458
+ "mode",
2459
+ "action",
2460
+ "error",
2461
+ "googleAction",
2462
+ "labels"
2463
+ ]
2464
+ },
2465
+ "AuthSuccessBlock": {
2466
+ "file": "src/components/blocks/AuthSuccessBlock.tsx",
2467
+ "exportPath": "./auth-success-block",
2468
+ "tier": 2,
2469
+ "category": "Auth Flow",
2470
+ "lib": null,
2471
+ "subComponents": [],
2472
+ "variants": {},
2473
+ "notes": "Generic auth success state",
2474
+ "keyProps": [
2475
+ "icon",
2476
+ "title",
2477
+ "description",
2478
+ "buttonText",
2479
+ "onContinue",
2480
+ "autoRedirectSeconds"
2481
+ ]
2482
+ },
2483
+ "BannerBlock": {
2484
+ "file": "src/components/blocks/BannerBlock.tsx",
2485
+ "exportPath": "./banner-block",
2486
+ "tier": 2,
2487
+ "category": "Navigation",
2488
+ "lib": null,
2489
+ "subComponents": [],
2490
+ "variants": {},
2491
+ "notes": "Top-of-page promotional banner",
2492
+ "keyProps": [
2493
+ "variant",
2494
+ "dismissible",
2495
+ "onDismiss"
2496
+ ]
2497
+ },
2498
+ "BarChartBlock": {
2499
+ "file": "src/components/blocks/BarChartBlock.tsx",
2500
+ "exportPath": "./bar-chart-block",
2501
+ "tier": 2,
2502
+ "category": "Dashboard & Data",
2503
+ "lib": null,
2504
+ "subComponents": [
2505
+ "BarChart"
2506
+ ],
2507
+ "variants": {},
2508
+ "notes": "Pre-configured bar chart",
2509
+ "keyProps": []
2510
+ },
2511
+ "CallToActionBlock": {
2512
+ "file": "src/components/blocks/CallToActionBlock.tsx",
2513
+ "exportPath": "./call-to-action-block",
2514
+ "tier": 2,
2515
+ "category": "Marketing",
2516
+ "lib": null,
2517
+ "subComponents": [
2518
+ "CallToAction"
2519
+ ],
2520
+ "variants": {},
2521
+ "notes": "Call-to-action section",
2522
+ "keyProps": []
2523
+ },
2524
+ "ChangelogBlock": {
2525
+ "file": "src/components/blocks/ChangelogBlock.tsx",
2526
+ "exportPath": "./changelog-block",
2527
+ "tier": 2,
2528
+ "category": "Application",
2529
+ "lib": null,
2530
+ "subComponents": [],
2531
+ "variants": {},
2532
+ "notes": "Version changelog display",
2533
+ "keyProps": [
2534
+ "entries",
2535
+ "title"
2536
+ ]
2537
+ },
2538
+ "ChartBlock": {
2539
+ "file": "src/components/blocks/ChartBlock.tsx",
2540
+ "exportPath": "./chart-block",
2541
+ "tier": 2,
2542
+ "category": "Dashboard & Data",
2543
+ "lib": null,
2544
+ "subComponents": [],
2545
+ "variants": {},
2546
+ "notes": "Single chart container",
2547
+ "keyProps": [
2548
+ "data",
2549
+ "config",
2550
+ "title",
2551
+ "description"
2552
+ ]
2553
+ },
2554
+ "ChartCollectionBlock": {
2555
+ "file": "src/components/blocks/ChartCollectionBlock.tsx",
2556
+ "exportPath": "./chart-collection-block",
2557
+ "tier": 2,
2558
+ "category": "Dashboard & Data",
2559
+ "lib": null,
2560
+ "subComponents": [],
2561
+ "variants": {},
2562
+ "notes": "Multiple chart grid",
2563
+ "keyProps": []
2564
+ },
2565
+ "ChatLayout": {
2566
+ "file": "src/components/blocks/ChatLayout.tsx",
2567
+ "exportPath": "./chat-layout",
2568
+ "tier": 2,
2569
+ "category": "Application",
2570
+ "lib": null,
2571
+ "subComponents": [],
2572
+ "variants": {},
2573
+ "notes": "Chat application layout",
2574
+ "keyProps": [
2575
+ "initialMessages",
2576
+ "assistantName",
2577
+ "assistantStatus",
2578
+ "placeholder"
2579
+ ]
2580
+ },
2581
+ "CodeBlock": {
2582
+ "file": "src/components/blocks/CodeBlock.tsx",
2583
+ "exportPath": "./code-block",
2584
+ "tier": 2,
2585
+ "category": "Dashboard & Data",
2586
+ "lib": null,
2587
+ "subComponents": [],
2588
+ "variants": {},
2589
+ "notes": "Syntax-highlighted code display",
2590
+ "keyProps": []
2591
+ },
2592
+ "ComparisonBlock": {
2593
+ "file": "src/components/blocks/ComparisonBlock.tsx",
2594
+ "exportPath": "./comparison-block",
2595
+ "tier": 2,
2596
+ "category": "Marketing",
2597
+ "lib": null,
2598
+ "subComponents": [],
2599
+ "variants": {},
2600
+ "notes": "Side-by-side feature comparison",
2601
+ "keyProps": [
2602
+ "plans",
2603
+ "title",
2604
+ "description"
2605
+ ]
2606
+ },
2607
+ "ContactBlock": {
2608
+ "file": "src/components/blocks/ContactBlock.tsx",
2609
+ "exportPath": "./contact-block",
2610
+ "tier": 2,
2611
+ "category": "Application",
2612
+ "lib": null,
2613
+ "subComponents": [],
2614
+ "variants": {},
2615
+ "notes": "Contact form",
2616
+ "keyProps": [
2617
+ "onSubmit",
2618
+ "title",
2619
+ "description",
2620
+ "namePlaceholder",
2621
+ "emailPlaceholder",
2622
+ "messagePlaceholder",
2623
+ "successTitle",
2624
+ "submitLabel"
2625
+ ]
2626
+ },
2627
+ "CreateBlock": {
2628
+ "file": "src/components/blocks/CreateBlock.tsx",
2629
+ "exportPath": "./create-block",
2630
+ "tier": 2,
2631
+ "category": "Application",
2632
+ "lib": null,
2633
+ "subComponents": [],
2634
+ "variants": {},
2635
+ "notes": "Entity creation form",
2636
+ "keyProps": [
2637
+ "title",
2638
+ "description",
2639
+ "submitLabel",
2640
+ "onSubmit"
2641
+ ]
2642
+ },
2643
+ "DataGridBlock": {
2644
+ "file": "src/components/blocks/DataGridBlock.tsx",
2645
+ "exportPath": "./data-grid-block",
2646
+ "tier": 2,
2647
+ "category": "Dashboard & Data",
2648
+ "lib": null,
2649
+ "subComponents": [],
2650
+ "variants": {},
2651
+ "notes": "Data grid/table block",
2652
+ "keyProps": [
2653
+ "data",
2654
+ "columns",
2655
+ "title",
2656
+ "description"
2657
+ ]
2658
+ },
2659
+ "DirectoryBlock": {
2660
+ "file": "src/components/blocks/DirectoryBlock.tsx",
2661
+ "exportPath": "./directory-block",
2662
+ "tier": 2,
2663
+ "category": "Application",
2664
+ "lib": null,
2665
+ "subComponents": [],
2666
+ "variants": {},
2667
+ "notes": "User/item directory with search",
2668
+ "keyProps": [
2669
+ "navItems",
2670
+ "projects"
2671
+ ]
2672
+ },
2673
+ "FAQBlock": {
2674
+ "file": "src/components/blocks/FAQBlock.tsx",
2675
+ "exportPath": "./faq-block",
2676
+ "tier": 2,
2677
+ "category": "Marketing",
2678
+ "lib": null,
2679
+ "subComponents": [],
2680
+ "variants": {},
2681
+ "notes": "FAQ accordion",
2682
+ "keyProps": [
2683
+ "items",
2684
+ "title",
2685
+ "description"
2686
+ ]
2687
+ },
2688
+ "FeatureBlock": {
2689
+ "file": "src/components/blocks/FeatureBlock.tsx",
2690
+ "exportPath": "./feature-block",
2691
+ "tier": 2,
2692
+ "category": "Marketing",
2693
+ "lib": null,
2694
+ "subComponents": [
2695
+ "FeatureGrid",
2696
+ "FeatureList"
2697
+ ],
2698
+ "variants": {},
2699
+ "notes": "Single feature showcase",
2700
+ "keyProps": []
2701
+ },
2702
+ "FeatureGridBlock": {
2703
+ "file": "src/components/blocks/FeatureGridBlock.tsx",
2704
+ "exportPath": "./feature-grid-block",
2705
+ "tier": 2,
2706
+ "category": "Marketing",
2707
+ "lib": null,
2708
+ "subComponents": [
2709
+ "Features"
2710
+ ],
2711
+ "variants": {},
2712
+ "notes": "Multi-feature grid layout",
2713
+ "keyProps": []
2714
+ },
2715
+ "FooterBlock": {
2716
+ "file": "src/components/blocks/FooterBlock.tsx",
2717
+ "exportPath": "./footer-block",
2718
+ "tier": 2,
2719
+ "category": "Navigation",
2720
+ "lib": null,
2721
+ "subComponents": [
2722
+ "Footer"
2723
+ ],
2724
+ "variants": {},
2725
+ "notes": "Site footer with link columns",
2726
+ "keyProps": []
2727
+ },
2728
+ "GalleryBlock": {
2729
+ "file": "src/components/blocks/GalleryBlock.tsx",
2730
+ "exportPath": "./gallery-block",
2731
+ "tier": 2,
2732
+ "category": "Content & Media",
2733
+ "lib": null,
2734
+ "subComponents": [],
2735
+ "variants": {},
2736
+ "notes": "Image/media gallery grid",
2737
+ "keyProps": [
2738
+ "images",
2739
+ "columns",
2740
+ "title"
2741
+ ]
2742
+ },
2743
+ "HeaderBlock": {
2744
+ "file": "src/components/blocks/HeaderBlock.tsx",
2745
+ "exportPath": "./header-block",
2746
+ "tier": 2,
2747
+ "category": "Navigation",
2748
+ "lib": null,
2749
+ "subComponents": [
2750
+ "HeroHeader"
2751
+ ],
2752
+ "variants": {},
2753
+ "notes": "Site header with nav links",
2754
+ "keyProps": []
2755
+ },
2756
+ "HeatmapChartBlock": {
2757
+ "file": "src/components/blocks/HeatmapChartBlock.tsx",
2758
+ "exportPath": "./heatmap-chart-block",
2759
+ "tier": 2,
2760
+ "category": "Dashboard & Data",
2761
+ "lib": null,
2762
+ "subComponents": [
2763
+ "HeatmapBlock"
2764
+ ],
2765
+ "variants": {},
2766
+ "notes": "Heatmap visualization",
2767
+ "keyProps": []
2768
+ },
2769
+ "HeroBlock": {
2770
+ "file": "src/components/blocks/HeroBlock.tsx",
2771
+ "exportPath": "./hero-block",
2772
+ "tier": 2,
2773
+ "category": "Marketing",
2774
+ "lib": null,
2775
+ "subComponents": [
2776
+ "HeroCentered",
2777
+ "HeroSplit"
2778
+ ],
2779
+ "variants": {},
2780
+ "notes": "Full hero with gradient text",
2781
+ "keyProps": []
2782
+ },
2783
+ "HeroSectionBlock": {
2784
+ "file": "src/components/blocks/HeroSectionBlock.tsx",
2785
+ "exportPath": "./hero-section-block",
2786
+ "tier": 2,
2787
+ "category": "Marketing",
2788
+ "lib": null,
2789
+ "subComponents": [
2790
+ "HeroSection"
2791
+ ],
2792
+ "variants": {},
2793
+ "notes": "Alternate hero layout",
2794
+ "keyProps": []
2795
+ },
2796
+ "IntegrationsBlock": {
2797
+ "file": "src/components/blocks/IntegrationsBlock.tsx",
2798
+ "exportPath": "./integrations-block",
2799
+ "tier": 2,
2800
+ "category": "Application",
2801
+ "lib": null,
2802
+ "subComponents": [
2803
+ "IntegrationsSection"
2804
+ ],
2805
+ "variants": {},
2806
+ "notes": "Integration marketplace grid",
2807
+ "keyProps": []
2808
+ },
2809
+ "InteractiveAreaChartBlock": {
2810
+ "file": "src/components/blocks/InteractiveAreaChartBlock.tsx",
2811
+ "exportPath": "./interactive-area-chart-block",
2812
+ "tier": 2,
2813
+ "category": "Dashboard & Data",
2814
+ "lib": null,
2815
+ "subComponents": [
2816
+ "InteractiveAreaChart"
2817
+ ],
2818
+ "variants": {},
2819
+ "notes": "Zoomable/interactive area chart",
2820
+ "keyProps": []
2821
+ },
2822
+ "KanbanDemoBlock": {
2823
+ "file": "src/components/blocks/KanbanDemoBlock.tsx",
2824
+ "exportPath": "./kanban-demo-block",
2825
+ "tier": 2,
2826
+ "category": "Application",
2827
+ "lib": null,
2828
+ "subComponents": [],
2829
+ "variants": {},
2830
+ "notes": "Kanban board demo with sample data",
2831
+ "keyProps": []
2832
+ },
2833
+ "LoginBlock": {
2834
+ "file": "src/components/blocks/LoginBlock.tsx",
2835
+ "exportPath": "./login-block",
2836
+ "tier": 2,
2837
+ "category": "Auth Flow",
2838
+ "lib": null,
2839
+ "subComponents": [],
2840
+ "variants": {},
2841
+ "notes": "Email/password login with social OAuth",
2842
+ "keyProps": [
2843
+ "type",
2844
+ "showSocial",
2845
+ "labels",
2846
+ "action",
2847
+ "error",
2848
+ "onLogin",
2849
+ "googleAction",
2850
+ "forgotPasswordHref",
2851
+ "signUpHref",
2852
+ "signInHref"
2853
+ ]
2854
+ },
2855
+ "LogoCloud": {
2856
+ "file": "src/components/blocks/LogoCloud.tsx",
2857
+ "exportPath": "./logo-cloud",
2858
+ "tier": 2,
2859
+ "category": "Marketing",
2860
+ "lib": null,
2861
+ "subComponents": [],
2862
+ "variants": {},
2863
+ "notes": "Partner/client logo grid",
2864
+ "keyProps": [
2865
+ "title",
2866
+ "logos"
2867
+ ]
2868
+ },
2869
+ "NavUser": {
2870
+ "file": "src/components/blocks/NavUser.tsx",
2871
+ "exportPath": "./nav-user",
2872
+ "tier": 2,
2873
+ "category": "Navigation",
2874
+ "lib": null,
2875
+ "subComponents": [],
2876
+ "variants": {},
2877
+ "notes": "Sidebar user menu with dropdown",
2878
+ "keyProps": [
2879
+ "user",
2880
+ "name",
2881
+ "email",
2882
+ "avatar",
2883
+ "items",
2884
+ "footer"
2885
+ ]
2886
+ },
2887
+ "NewsletterBlock": {
2888
+ "file": "src/components/blocks/NewsletterBlock.tsx",
2889
+ "exportPath": "./newsletter-block",
2890
+ "tier": 2,
2891
+ "category": "Content & Media",
2892
+ "lib": null,
2893
+ "subComponents": [],
2894
+ "variants": {},
2895
+ "notes": "Email newsletter signup",
2896
+ "keyProps": [
2897
+ "onSubscribe",
2898
+ "title",
2899
+ "description"
2900
+ ]
2901
+ },
2902
+ "NotFoundBlock": {
2903
+ "file": "src/components/blocks/NotFoundBlock.tsx",
2904
+ "exportPath": "./not-found-block",
2905
+ "tier": 2,
2906
+ "category": "Navigation",
2907
+ "lib": null,
2908
+ "subComponents": [],
2909
+ "variants": {},
2910
+ "notes": "404 page content",
2911
+ "keyProps": [
2912
+ "title",
2913
+ "description",
2914
+ "backHref",
2915
+ "backLabel"
2916
+ ]
2917
+ },
2918
+ "OnboardingBlock": {
2919
+ "file": "src/components/blocks/OnboardingBlock.tsx",
2920
+ "exportPath": "./onboarding-block",
2921
+ "tier": 2,
2922
+ "category": "Application",
2923
+ "lib": null,
2924
+ "subComponents": [],
2925
+ "variants": {},
2926
+ "notes": "Multi-step onboarding wizard",
2927
+ "keyProps": [
2928
+ "steps",
2929
+ "title",
2930
+ "onToggle"
2931
+ ]
2932
+ },
2933
+ "PasswordRecoveryBlock": {
2934
+ "file": "src/components/blocks/PasswordRecoveryBlock.tsx",
2935
+ "exportPath": "./password-recovery-block",
2936
+ "tier": 2,
2937
+ "category": "Auth Flow",
2938
+ "lib": null,
2939
+ "subComponents": [],
2940
+ "variants": {},
2941
+ "notes": "Password reset request",
2942
+ "keyProps": [
2943
+ "mode",
2944
+ "onSubmit",
2945
+ "onBackToLogin",
2946
+ "title",
2947
+ "description",
2948
+ "buttonText",
2949
+ "successTitle"
2950
+ ]
2951
+ },
2952
+ "PricingBlock": {
2953
+ "file": "src/components/blocks/PricingBlock.tsx",
2954
+ "exportPath": "./pricing-block",
2955
+ "tier": 2,
2956
+ "category": "Marketing",
2957
+ "lib": null,
2958
+ "subComponents": [
2959
+ "PricingTable"
2960
+ ],
2961
+ "variants": {},
2962
+ "notes": "Pricing cards comparison",
2963
+ "keyProps": []
2964
+ },
2965
+ "ProcessFlowBlock": {
2966
+ "file": "src/components/blocks/ProcessFlowBlock.tsx",
2967
+ "exportPath": "./process-flow-block",
2968
+ "tier": 2,
2969
+ "category": "Marketing",
2970
+ "lib": null,
2971
+ "subComponents": [],
2972
+ "variants": {},
2973
+ "notes": "\"How it works\" numbered step sequence",
2974
+ "keyProps": [
2975
+ "title",
2976
+ "description",
2977
+ "badge",
2978
+ "steps"
2979
+ ]
2980
+ },
2981
+ "ResetPasswordBlock": {
2982
+ "file": "src/components/blocks/ResetPasswordBlock.tsx",
2983
+ "exportPath": "./reset-password-block",
2984
+ "tier": 2,
2985
+ "category": "Auth Flow",
2986
+ "lib": null,
2987
+ "subComponents": [],
2988
+ "variants": {},
2989
+ "notes": "New password entry (from email link)",
2990
+ "keyProps": [
2991
+ "onSubmit",
2992
+ "onBackToLogin",
2993
+ "title",
2994
+ "description"
2995
+ ]
2996
+ },
2997
+ "SettingsLayout": {
2998
+ "file": "src/components/blocks/SettingsLayout.tsx",
2999
+ "exportPath": "./settings-layout",
3000
+ "tier": 2,
3001
+ "category": "Application",
3002
+ "lib": null,
3003
+ "subComponents": [],
3004
+ "variants": {},
3005
+ "notes": "Settings page with nav sidebar",
3006
+ "keyProps": [
3007
+ "links",
3008
+ "title",
3009
+ "subtitle",
3010
+ "defaultActive",
3011
+ "renderContent"
3012
+ ]
3013
+ },
3014
+ "SignUpBlock": {
3015
+ "file": "src/components/blocks/SignUpBlock.tsx",
3016
+ "exportPath": "./sign-up-block",
3017
+ "tier": 2,
3018
+ "category": "Auth Flow",
3019
+ "lib": null,
3020
+ "subComponents": [
3021
+ "LoginPage"
3022
+ ],
3023
+ "variants": {},
3024
+ "notes": "Registration form",
3025
+ "keyProps": [
3026
+ "title",
3027
+ "description",
3028
+ "showSocial",
3029
+ "signInHref",
3030
+ "onSubmit"
3031
+ ]
3032
+ },
3033
+ "SocialProofBlock": {
3034
+ "file": "src/components/blocks/SocialProofBlock.tsx",
3035
+ "exportPath": "./social-proof-block",
3036
+ "tier": 2,
3037
+ "category": "Marketing",
3038
+ "lib": null,
3039
+ "subComponents": [
3040
+ "LogoCloud",
3041
+ "Testimonials"
3042
+ ],
3043
+ "variants": {},
3044
+ "notes": "Social proof metrics/logos",
3045
+ "keyProps": []
3046
+ },
3047
+ "SolutionShowcaseBlock": {
3048
+ "file": "src/components/blocks/SolutionShowcaseBlock.tsx",
3049
+ "exportPath": "./solution-showcase-block",
3050
+ "tier": 2,
3051
+ "category": "Marketing",
3052
+ "lib": null,
3053
+ "subComponents": [],
3054
+ "variants": {},
3055
+ "notes": "Problem -> Solution -> Output narrative with color-coded arc",
3056
+ "keyProps": [
3057
+ "title",
3058
+ "description",
3059
+ "badge",
3060
+ "sections"
3061
+ ]
3062
+ },
3063
+ "StatsBlock": {
3064
+ "file": "src/components/blocks/StatsBlock.tsx",
3065
+ "exportPath": "./stats-block",
3066
+ "tier": 2,
3067
+ "category": "Dashboard & Data",
3068
+ "lib": null,
3069
+ "subComponents": [
3070
+ "StatsGeneric"
3071
+ ],
3072
+ "variants": {},
3073
+ "notes": "KPI statistics cards",
3074
+ "keyProps": []
3075
+ },
3076
+ "StatsMarketingBlock": {
3077
+ "file": "src/components/blocks/StatsMarketingBlock.tsx",
3078
+ "exportPath": "./stats-marketing-block",
3079
+ "tier": 2,
3080
+ "category": "Marketing",
3081
+ "lib": null,
3082
+ "subComponents": [
3083
+ "StatsSection"
3084
+ ],
3085
+ "variants": {},
3086
+ "notes": "Marketing statistics display",
3087
+ "keyProps": []
3088
+ },
3089
+ "TeamBlock": {
3090
+ "file": "src/components/blocks/TeamBlock.tsx",
3091
+ "exportPath": "./team-block",
3092
+ "tier": 2,
3093
+ "category": "User",
3094
+ "lib": null,
3095
+ "subComponents": [
3096
+ "TeamSection"
3097
+ ],
3098
+ "variants": {},
3099
+ "notes": "Team members grid with roles/avatars",
3100
+ "keyProps": []
3101
+ },
3102
+ "TestimonialsBlock": {
3103
+ "file": "src/components/blocks/TestimonialsBlock.tsx",
3104
+ "exportPath": "./testimonials-block",
3105
+ "tier": 2,
3106
+ "category": "Marketing",
3107
+ "lib": null,
3108
+ "subComponents": [
3109
+ "Testimonials"
3110
+ ],
3111
+ "variants": {},
3112
+ "notes": "Customer testimonial carousel/grid",
3113
+ "keyProps": []
3114
+ },
3115
+ "TwoFactorChallengeBlock": {
3116
+ "file": "src/components/blocks/TwoFactorChallengeBlock.tsx",
3117
+ "exportPath": "./two-factor-challenge-block",
3118
+ "tier": 2,
3119
+ "category": "Auth Flow",
3120
+ "lib": null,
3121
+ "subComponents": [],
3122
+ "variants": {},
3123
+ "notes": "2FA code entry challenge",
3124
+ "keyProps": [
3125
+ "onVerify",
3126
+ "onUseBackupCode",
3127
+ "onBackToLogin",
3128
+ "error",
3129
+ "title",
3130
+ "description",
3131
+ "backupCodeLabel"
3132
+ ]
3133
+ },
3134
+ "TwoFactorSetupBlock": {
3135
+ "file": "src/components/blocks/TwoFactorSetupBlock.tsx",
3136
+ "exportPath": "./two-factor-setup-block",
3137
+ "tier": 2,
3138
+ "category": "Auth Flow",
3139
+ "lib": null,
3140
+ "subComponents": [],
3141
+ "variants": {},
3142
+ "notes": "2FA setup with QR code",
3143
+ "keyProps": [
3144
+ "qrCodeUrl",
3145
+ "secret",
3146
+ "backupCodes",
3147
+ "onVerify",
3148
+ "onComplete",
3149
+ "title",
3150
+ "description"
3151
+ ]
3152
+ },
3153
+ "UsageDonutBlock": {
3154
+ "file": "src/components/blocks/UsageDonutBlock.tsx",
3155
+ "exportPath": "./usage-donut-block",
3156
+ "tier": 2,
3157
+ "category": "Dashboard & Data",
3158
+ "lib": null,
3159
+ "subComponents": [
3160
+ "UsageDonut"
3161
+ ],
3162
+ "variants": {},
3163
+ "notes": "Usage/quota donut chart",
3164
+ "keyProps": []
3165
+ },
3166
+ "VoiceAgentCard": {
3167
+ "file": "src/components/blocks/VoiceAgentCard.tsx",
3168
+ "exportPath": "./voice-agent-card",
3169
+ "tier": 2,
3170
+ "category": "AI/Voice",
3171
+ "lib": null,
3172
+ "subComponents": [],
3173
+ "variants": {},
3174
+ "notes": "AI voice agent interface card",
3175
+ "keyProps": [
3176
+ "agent",
3177
+ "state",
3178
+ "selected",
3179
+ "onSelect"
3180
+ ]
3181
+ },
3182
+ "WizardBlock": {
3183
+ "file": "src/components/blocks/WizardBlock.tsx",
3184
+ "exportPath": "./wizard-block",
3185
+ "tier": 2,
3186
+ "category": "Application",
3187
+ "lib": null,
3188
+ "subComponents": [],
3189
+ "variants": {},
3190
+ "notes": "Generic step-by-step wizard",
3191
+ "keyProps": [
3192
+ "title",
3193
+ "description",
3194
+ "steps",
3195
+ "onFinish"
3196
+ ]
3197
+ }
3198
+ },
3199
+ "tiers": {
3200
+ "1": {
3201
+ "label": "Core",
3202
+ "count": 76
3203
+ },
3204
+ "2": {
3205
+ "label": "Domain",
3206
+ "count": 43
3207
+ },
3208
+ "3": {
3209
+ "label": "Decorative",
3210
+ "count": 24
3211
+ },
3212
+ "4": {
3213
+ "label": "Deprecation",
3214
+ "count": 14
3215
+ }
3216
+ }
3217
+ }