@etus/ui 0.1.0 → 0.1.2

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.
Files changed (1080) hide show
  1. package/dist/chunk-UP2VWCW5.js +38 -0
  2. package/dist/chunk-UP2VWCW5.js.map +1 -0
  3. package/dist/index.d.ts +1177 -228
  4. package/dist/index.js +9506 -4308
  5. package/dist/index.js.map +1 -1
  6. package/dist/jspdf.node.min-CTWP225M.js +39344 -0
  7. package/dist/jspdf.node.min-CTWP225M.js.map +1 -0
  8. package/dist/jspdf.plugin.autotable-AAE7PZKA.js +1908 -0
  9. package/dist/jspdf.plugin.autotable-AAE7PZKA.js.map +1 -0
  10. package/dist/lib/utils.js +1 -0
  11. package/dist/xlsx-PWHBQ6NK.js +31945 -0
  12. package/dist/xlsx-PWHBQ6NK.js.map +1 -0
  13. package/package.json +12 -6
  14. package/styles.css +1 -0
  15. package/src/components/CLAUDE.md +0 -66
  16. package/src/components/advanced/AssetManager/AssetManager.test.tsx +0 -624
  17. package/src/components/advanced/AssetManager/AssetManager.tsx +0 -928
  18. package/src/components/advanced/AssetManager/AssetManager.types.ts +0 -248
  19. package/src/components/advanced/AssetManager/AssetManager.variants.ts +0 -284
  20. package/src/components/advanced/AssetManager/README.md +0 -246
  21. package/src/components/advanced/AssetManager/index.ts +0 -4
  22. package/src/components/advanced/CLAUDE.md +0 -77
  23. package/src/components/advanced/Calendar/Calendar.test.tsx +0 -718
  24. package/src/components/advanced/Calendar/Calendar.tsx +0 -264
  25. package/src/components/advanced/Calendar/Calendar.types.ts +0 -62
  26. package/src/components/advanced/Calendar/Calendar.variants.ts +0 -154
  27. package/src/components/advanced/Calendar/README.md +0 -389
  28. package/src/components/advanced/Calendar/index.ts +0 -3
  29. package/src/components/advanced/Command/Command.test.tsx +0 -1014
  30. package/src/components/advanced/Command/Command.tsx +0 -330
  31. package/src/components/advanced/Command/Command.types.ts +0 -238
  32. package/src/components/advanced/Command/Command.variants.ts +0 -300
  33. package/src/components/advanced/Command/README.md +0 -1259
  34. package/src/components/advanced/Command/index.ts +0 -45
  35. package/src/components/advanced/DragAndDrop/DragAndDrop.test.tsx +0 -573
  36. package/src/components/advanced/DragAndDrop/DragAndDrop.tsx +0 -495
  37. package/src/components/advanced/DragAndDrop/DragAndDrop.types.ts +0 -237
  38. package/src/components/advanced/DragAndDrop/DragAndDrop.variants.ts +0 -156
  39. package/src/components/advanced/DragAndDrop/README.md +0 -284
  40. package/src/components/advanced/DragAndDrop/index.ts +0 -4
  41. package/src/components/advanced/ErrorBoundary/ErrorBoundary.test.tsx +0 -372
  42. package/src/components/advanced/ErrorBoundary/ErrorBoundary.tsx +0 -184
  43. package/src/components/advanced/ErrorBoundary/ErrorBoundary.types.ts +0 -73
  44. package/src/components/advanced/ErrorBoundary/ErrorBoundary.variants.ts +0 -153
  45. package/src/components/advanced/ErrorBoundary/README.md +0 -296
  46. package/src/components/advanced/ErrorBoundary/index.ts +0 -18
  47. package/src/components/advanced/EventCalendar/EventCalendar.test.tsx +0 -535
  48. package/src/components/advanced/EventCalendar/EventCalendar.tsx +0 -1066
  49. package/src/components/advanced/EventCalendar/EventCalendar.types.ts +0 -232
  50. package/src/components/advanced/EventCalendar/EventCalendar.variants.ts +0 -222
  51. package/src/components/advanced/EventCalendar/README.md +0 -330
  52. package/src/components/advanced/EventCalendar/index.ts +0 -35
  53. package/src/components/advanced/FileDropzone/FileDropzone.test.tsx +0 -344
  54. package/src/components/advanced/FileDropzone/FileDropzone.tsx +0 -188
  55. package/src/components/advanced/FileDropzone/FileDropzone.types.ts +0 -47
  56. package/src/components/advanced/FileDropzone/FileDropzone.variants.ts +0 -46
  57. package/src/components/advanced/FileDropzone/README.md +0 -359
  58. package/src/components/advanced/FileDropzone/index.ts +0 -7
  59. package/src/components/advanced/FilePreview/FilePreview.test.tsx +0 -503
  60. package/src/components/advanced/FilePreview/FilePreview.tsx +0 -385
  61. package/src/components/advanced/FilePreview/FilePreview.types.ts +0 -90
  62. package/src/components/advanced/FilePreview/FilePreview.variants.ts +0 -234
  63. package/src/components/advanced/FilePreview/README.md +0 -318
  64. package/src/components/advanced/FilePreview/index.ts +0 -25
  65. package/src/components/advanced/FileUpload/FileUpload.test.tsx +0 -676
  66. package/src/components/advanced/FileUpload/FileUpload.tsx +0 -845
  67. package/src/components/advanced/FileUpload/FileUpload.types.ts +0 -270
  68. package/src/components/advanced/FileUpload/FileUpload.variants.ts +0 -216
  69. package/src/components/advanced/FileUpload/README.md +0 -380
  70. package/src/components/advanced/FileUpload/index.ts +0 -39
  71. package/src/components/advanced/FilterBuilder/FilterBuilder.test.tsx +0 -644
  72. package/src/components/advanced/FilterBuilder/FilterBuilder.tsx +0 -881
  73. package/src/components/advanced/FilterBuilder/FilterBuilder.types.ts +0 -249
  74. package/src/components/advanced/FilterBuilder/FilterBuilder.variants.ts +0 -307
  75. package/src/components/advanced/FilterBuilder/README.md +0 -383
  76. package/src/components/advanced/FilterBuilder/index.ts +0 -48
  77. package/src/components/advanced/MarkdownEditor/MarkdownEditor.test.tsx +0 -468
  78. package/src/components/advanced/MarkdownEditor/MarkdownEditor.tsx +0 -556
  79. package/src/components/advanced/MarkdownEditor/MarkdownEditor.types.ts +0 -108
  80. package/src/components/advanced/MarkdownEditor/MarkdownEditor.variants.ts +0 -62
  81. package/src/components/advanced/MarkdownEditor/README.md +0 -352
  82. package/src/components/advanced/MarkdownEditor/index.ts +0 -15
  83. package/src/components/advanced/Portal/Portal.test.tsx +0 -406
  84. package/src/components/advanced/Portal/Portal.tsx +0 -77
  85. package/src/components/advanced/Portal/Portal.types.ts +0 -28
  86. package/src/components/advanced/Portal/Portal.variants.ts +0 -95
  87. package/src/components/advanced/Portal/README.md +0 -326
  88. package/src/components/advanced/Portal/index.ts +0 -9
  89. package/src/components/advanced/RichTextEditor/README.md +0 -383
  90. package/src/components/advanced/RichTextEditor/RichTextEditor.test.tsx +0 -394
  91. package/src/components/advanced/RichTextEditor/RichTextEditor.tsx +0 -651
  92. package/src/components/advanced/RichTextEditor/RichTextEditor.types.ts +0 -77
  93. package/src/components/advanced/RichTextEditor/RichTextEditor.variants.ts +0 -151
  94. package/src/components/advanced/RichTextEditor/index.ts +0 -24
  95. package/src/components/advanced/Search/README.md +0 -391
  96. package/src/components/advanced/Search/Search.test.tsx +0 -567
  97. package/src/components/advanced/Search/Search.tsx +0 -829
  98. package/src/components/advanced/Search/Search.types.ts +0 -243
  99. package/src/components/advanced/Search/Search.variants.ts +0 -358
  100. package/src/components/advanced/Search/index.ts +0 -52
  101. package/src/components/advanced/SortableList/README.md +0 -448
  102. package/src/components/advanced/SortableList/SortableList.test.tsx +0 -317
  103. package/src/components/advanced/SortableList/SortableList.tsx +0 -392
  104. package/src/components/advanced/SortableList/SortableList.types.ts +0 -122
  105. package/src/components/advanced/SortableList/SortableList.variants.ts +0 -141
  106. package/src/components/advanced/SortableList/index.ts +0 -33
  107. package/src/components/advanced/VersionControl/README.md +0 -440
  108. package/src/components/advanced/VersionControl/VersionControl.test.tsx +0 -517
  109. package/src/components/advanced/VersionControl/VersionControl.tsx +0 -758
  110. package/src/components/advanced/VersionControl/VersionControl.types.ts +0 -176
  111. package/src/components/advanced/VersionControl/VersionControl.variants.ts +0 -203
  112. package/src/components/advanced/VersionControl/index.ts +0 -33
  113. package/src/components/advanced/index.ts +0 -17
  114. package/src/components/data-display/Accordion/Accordion.test.tsx +0 -519
  115. package/src/components/data-display/Accordion/Accordion.tsx +0 -164
  116. package/src/components/data-display/Accordion/Accordion.types.ts +0 -37
  117. package/src/components/data-display/Accordion/Accordion.variants.ts +0 -112
  118. package/src/components/data-display/Accordion/README.md +0 -976
  119. package/src/components/data-display/Accordion/index.ts +0 -31
  120. package/src/components/data-display/AreaChart/AreaChart.test.tsx +0 -529
  121. package/src/components/data-display/AreaChart/AreaChart.tsx +0 -318
  122. package/src/components/data-display/AreaChart/AreaChart.types.ts +0 -169
  123. package/src/components/data-display/AreaChart/AreaChart.variants.ts +0 -45
  124. package/src/components/data-display/AreaChart/README.md +0 -229
  125. package/src/components/data-display/AreaChart/index.ts +0 -2
  126. package/src/components/data-display/Banner/Banner.test.tsx +0 -648
  127. package/src/components/data-display/Banner/Banner.tsx +0 -111
  128. package/src/components/data-display/Banner/Banner.types.ts +0 -51
  129. package/src/components/data-display/Banner/Banner.variants.ts +0 -37
  130. package/src/components/data-display/Banner/README.md +0 -351
  131. package/src/components/data-display/Banner/index.ts +0 -2
  132. package/src/components/data-display/BarChart/BarChart.test.tsx +0 -536
  133. package/src/components/data-display/BarChart/BarChart.tsx +0 -305
  134. package/src/components/data-display/BarChart/BarChart.types.ts +0 -145
  135. package/src/components/data-display/BarChart/BarChart.variants.ts +0 -61
  136. package/src/components/data-display/BarChart/README.md +0 -205
  137. package/src/components/data-display/BarChart/index.ts +0 -2
  138. package/src/components/data-display/BarList/BarList.tsx +0 -172
  139. package/src/components/data-display/BarList/BarList.types.ts +0 -69
  140. package/src/components/data-display/BarList/BarList.variants.ts +0 -63
  141. package/src/components/data-display/BarList/index.ts +0 -2
  142. package/src/components/data-display/CLAUDE.md +0 -90
  143. package/src/components/data-display/Callout/Callout.test.tsx +0 -516
  144. package/src/components/data-display/Callout/Callout.tsx +0 -112
  145. package/src/components/data-display/Callout/Callout.types.ts +0 -37
  146. package/src/components/data-display/Callout/Callout.variants.ts +0 -48
  147. package/src/components/data-display/Callout/README.md +0 -341
  148. package/src/components/data-display/Callout/index.ts +0 -2
  149. package/src/components/data-display/Carousel/Carousel.test.tsx +0 -386
  150. package/src/components/data-display/Carousel/Carousel.tsx +0 -241
  151. package/src/components/data-display/Carousel/Carousel.types.ts +0 -20
  152. package/src/components/data-display/Carousel/Carousel.variants.ts +0 -125
  153. package/src/components/data-display/Carousel/README.md +0 -711
  154. package/src/components/data-display/Carousel/index.ts +0 -1
  155. package/src/components/data-display/CategoryBar/CategoryBar.tsx +0 -220
  156. package/src/components/data-display/CategoryBar/CategoryBar.types.ts +0 -80
  157. package/src/components/data-display/CategoryBar/CategoryBar.variants.ts +0 -85
  158. package/src/components/data-display/CategoryBar/index.ts +0 -2
  159. package/src/components/data-display/Chart/Chart.test.tsx +0 -432
  160. package/src/components/data-display/Chart/Chart.tsx +0 -476
  161. package/src/components/data-display/Chart/Chart.types.ts +0 -24
  162. package/src/components/data-display/Chart/Chart.variants.ts +0 -106
  163. package/src/components/data-display/Chart/README.md +0 -674
  164. package/src/components/data-display/Chart/index.ts +0 -1
  165. package/src/components/data-display/ChartCard/ChartCard.test.tsx +0 -327
  166. package/src/components/data-display/ChartCard/ChartCard.tsx +0 -201
  167. package/src/components/data-display/ChartCard/ChartCard.types.ts +0 -68
  168. package/src/components/data-display/ChartCard/ChartCard.variants.ts +0 -63
  169. package/src/components/data-display/ChartCard/index.ts +0 -17
  170. package/src/components/data-display/ChartLegend/ChartLegend.test.tsx +0 -165
  171. package/src/components/data-display/ChartLegend/ChartLegend.types.ts +0 -88
  172. package/src/components/data-display/ChartLegend/README.md +0 -317
  173. package/src/components/data-display/ChartLegend/index.ts +0 -22
  174. package/src/components/data-display/ComboChart/ComboChart.tsx +0 -380
  175. package/src/components/data-display/ComboChart/ComboChart.types.ts +0 -224
  176. package/src/components/data-display/ComboChart/index.ts +0 -2
  177. package/src/components/data-display/DashboardCard/DashboardCard.test.tsx +0 -289
  178. package/src/components/data-display/DashboardCard/DashboardCard.tsx +0 -285
  179. package/src/components/data-display/DashboardCard/DashboardCard.types.ts +0 -74
  180. package/src/components/data-display/DashboardCard/DashboardCard.variants.ts +0 -67
  181. package/src/components/data-display/DashboardCard/index.ts +0 -25
  182. package/src/components/data-display/DashboardFilterbar/DashboardFilterbar.tsx +0 -151
  183. package/src/components/data-display/DashboardFilterbar/DashboardFilterbar.types.ts +0 -39
  184. package/src/components/data-display/DashboardFilterbar/DashboardFilterbar.variants.ts +0 -30
  185. package/src/components/data-display/DashboardFilterbar/index.ts +0 -10
  186. package/src/components/data-display/DataTable/DataTable.test.tsx +0 -654
  187. package/src/components/data-display/DataTable/DataTable.tsx +0 -529
  188. package/src/components/data-display/DataTable/DataTable.types.ts +0 -190
  189. package/src/components/data-display/DataTable/DataTable.variants.ts +0 -79
  190. package/src/components/data-display/DataTable/README.md +0 -447
  191. package/src/components/data-display/DataTable/index.ts +0 -2
  192. package/src/components/data-display/DeltaBar/DeltaBar.tsx +0 -100
  193. package/src/components/data-display/DeltaBar/DeltaBar.types.ts +0 -57
  194. package/src/components/data-display/DeltaBar/DeltaBar.variants.ts +0 -40
  195. package/src/components/data-display/DeltaBar/index.ts +0 -2
  196. package/src/components/data-display/EmptyState/EmptyState.test.tsx +0 -368
  197. package/src/components/data-display/EmptyState/EmptyState.tsx +0 -91
  198. package/src/components/data-display/EmptyState/EmptyState.types.ts +0 -9
  199. package/src/components/data-display/EmptyState/EmptyState.variants.ts +0 -28
  200. package/src/components/data-display/EmptyState/README.md +0 -746
  201. package/src/components/data-display/EmptyState/index.ts +0 -1
  202. package/src/components/data-display/Feed/Feed.test.tsx +0 -668
  203. package/src/components/data-display/Feed/Feed.tsx +0 -290
  204. package/src/components/data-display/Feed/Feed.types.ts +0 -104
  205. package/src/components/data-display/Feed/Feed.variants.ts +0 -64
  206. package/src/components/data-display/Feed/README.md +0 -326
  207. package/src/components/data-display/Feed/index.ts +0 -17
  208. package/src/components/data-display/FunnelChart/FunnelChart.tsx +0 -177
  209. package/src/components/data-display/FunnelChart/FunnelChart.types.ts +0 -145
  210. package/src/components/data-display/FunnelChart/index.ts +0 -2
  211. package/src/components/data-display/GaugeChart/GaugeChart.test.tsx +0 -129
  212. package/src/components/data-display/GaugeChart/GaugeChart.tsx +0 -332
  213. package/src/components/data-display/GaugeChart/GaugeChart.types.ts +0 -53
  214. package/src/components/data-display/GaugeChart/GaugeChart.variants.ts +0 -56
  215. package/src/components/data-display/GaugeChart/README.md +0 -305
  216. package/src/components/data-display/GaugeChart/index.ts +0 -3
  217. package/src/components/data-display/Heatmap/Heatmap.test.tsx +0 -630
  218. package/src/components/data-display/Heatmap/Heatmap.tsx +0 -569
  219. package/src/components/data-display/Heatmap/Heatmap.types.ts +0 -120
  220. package/src/components/data-display/Heatmap/Heatmap.variants.ts +0 -72
  221. package/src/components/data-display/Heatmap/README.md +0 -321
  222. package/src/components/data-display/Heatmap/index.ts +0 -2
  223. package/src/components/data-display/HoverCard/HoverCard.test.tsx +0 -314
  224. package/src/components/data-display/HoverCard/HoverCard.tsx +0 -40
  225. package/src/components/data-display/HoverCard/HoverCard.types.ts +0 -21
  226. package/src/components/data-display/HoverCard/HoverCard.variants.ts +0 -29
  227. package/src/components/data-display/HoverCard/README.md +0 -624
  228. package/src/components/data-display/HoverCard/index.ts +0 -1
  229. package/src/components/data-display/ImageGallery/ImageGallery.test.tsx +0 -519
  230. package/src/components/data-display/ImageGallery/ImageGallery.tsx +0 -733
  231. package/src/components/data-display/ImageGallery/ImageGallery.types.ts +0 -109
  232. package/src/components/data-display/ImageGallery/ImageGallery.variants.ts +0 -58
  233. package/src/components/data-display/ImageGallery/README.md +0 -352
  234. package/src/components/data-display/ImageGallery/index.ts +0 -9
  235. package/src/components/data-display/Item/Item.test.tsx +0 -476
  236. package/src/components/data-display/Item/Item.tsx +0 -195
  237. package/src/components/data-display/Item/Item.types.ts +0 -23
  238. package/src/components/data-display/Item/Item.variants.ts +0 -51
  239. package/src/components/data-display/Item/README.md +0 -759
  240. package/src/components/data-display/Item/index.ts +0 -1
  241. package/src/components/data-display/KPICard/KPICard.test.tsx +0 -445
  242. package/src/components/data-display/KPICard/KPICard.tsx +0 -203
  243. package/src/components/data-display/KPICard/KPICard.types.ts +0 -32
  244. package/src/components/data-display/KPICard/KPICard.variants.ts +0 -64
  245. package/src/components/data-display/KPICard/README.md +0 -380
  246. package/src/components/data-display/KPICard/index.ts +0 -7
  247. package/src/components/data-display/Lightbox/Lightbox.test.tsx +0 -574
  248. package/src/components/data-display/Lightbox/Lightbox.tsx +0 -466
  249. package/src/components/data-display/Lightbox/Lightbox.types.ts +0 -53
  250. package/src/components/data-display/Lightbox/Lightbox.variants.ts +0 -99
  251. package/src/components/data-display/Lightbox/README.md +0 -397
  252. package/src/components/data-display/Lightbox/index.ts +0 -2
  253. package/src/components/data-display/LineChart/LineChart.test.tsx +0 -654
  254. package/src/components/data-display/LineChart/LineChart.tsx +0 -295
  255. package/src/components/data-display/LineChart/LineChart.types.ts +0 -168
  256. package/src/components/data-display/LineChart/LineChart.variants.ts +0 -52
  257. package/src/components/data-display/LineChart/README.md +0 -242
  258. package/src/components/data-display/LineChart/index.ts +0 -8
  259. package/src/components/data-display/List/List.test.tsx +0 -756
  260. package/src/components/data-display/List/List.tsx +0 -455
  261. package/src/components/data-display/List/List.types.ts +0 -67
  262. package/src/components/data-display/List/List.variants.ts +0 -69
  263. package/src/components/data-display/List/README.md +0 -374
  264. package/src/components/data-display/List/index.ts +0 -9
  265. package/src/components/data-display/MarkerBar/MarkerBar.tsx +0 -130
  266. package/src/components/data-display/MarkerBar/MarkerBar.types.ts +0 -67
  267. package/src/components/data-display/MarkerBar/MarkerBar.variants.ts +0 -75
  268. package/src/components/data-display/MarkerBar/index.ts +0 -3
  269. package/src/components/data-display/PieChart/PieChart.test.tsx +0 -655
  270. package/src/components/data-display/PieChart/PieChart.tsx +0 -327
  271. package/src/components/data-display/PieChart/PieChart.types.ts +0 -134
  272. package/src/components/data-display/PieChart/PieChart.variants.ts +0 -49
  273. package/src/components/data-display/PieChart/README.md +0 -261
  274. package/src/components/data-display/PieChart/index.ts +0 -2
  275. package/src/components/data-display/ScatterChart/ScatterChart.tsx +0 -310
  276. package/src/components/data-display/ScatterChart/ScatterChart.types.ts +0 -272
  277. package/src/components/data-display/ScatterChart/index.ts +0 -2
  278. package/src/components/data-display/SingleStat/README.md +0 -363
  279. package/src/components/data-display/SingleStat/SingleStat.test.tsx +0 -223
  280. package/src/components/data-display/SingleStat/SingleStat.tsx +0 -251
  281. package/src/components/data-display/SingleStat/SingleStat.types.ts +0 -71
  282. package/src/components/data-display/SingleStat/SingleStat.variants.ts +0 -51
  283. package/src/components/data-display/SingleStat/index.ts +0 -6
  284. package/src/components/data-display/Sparkline/README.md +0 -321
  285. package/src/components/data-display/Sparkline/Sparkline.test.tsx +0 -276
  286. package/src/components/data-display/Sparkline/Sparkline.tsx +0 -971
  287. package/src/components/data-display/Sparkline/Sparkline.types.ts +0 -147
  288. package/src/components/data-display/Sparkline/Sparkline.variants.ts +0 -52
  289. package/src/components/data-display/Sparkline/index.ts +0 -9
  290. package/src/components/data-display/Table/README.md +0 -821
  291. package/src/components/data-display/Table/Table.test.tsx +0 -732
  292. package/src/components/data-display/Table/Table.tsx +0 -123
  293. package/src/components/data-display/Table/Table.types.ts +0 -20
  294. package/src/components/data-display/Table/Table.variants.ts +0 -123
  295. package/src/components/data-display/Table/index.ts +0 -1
  296. package/src/components/data-display/Timeline/README.md +0 -366
  297. package/src/components/data-display/Timeline/Timeline.test.tsx +0 -701
  298. package/src/components/data-display/Timeline/Timeline.tsx +0 -328
  299. package/src/components/data-display/Timeline/Timeline.types.ts +0 -59
  300. package/src/components/data-display/Timeline/Timeline.variants.ts +0 -152
  301. package/src/components/data-display/Timeline/index.ts +0 -15
  302. package/src/components/data-display/Tracker/Tracker.tsx +0 -105
  303. package/src/components/data-display/Tracker/Tracker.types.ts +0 -45
  304. package/src/components/data-display/Tracker/Tracker.variants.ts +0 -24
  305. package/src/components/data-display/Tracker/index.ts +0 -2
  306. package/src/components/data-display/VirtualTable/README.md +0 -383
  307. package/src/components/data-display/VirtualTable/VirtualTable.test.tsx +0 -295
  308. package/src/components/data-display/VirtualTable/VirtualTable.tsx +0 -354
  309. package/src/components/data-display/VirtualTable/VirtualTable.types.ts +0 -62
  310. package/src/components/data-display/VirtualTable/VirtualTable.variants.ts +0 -61
  311. package/src/components/data-display/VirtualTable/index.ts +0 -2
  312. package/src/components/data-display/index.ts +0 -35
  313. package/src/components/feedback/Alert/Alert.test.tsx +0 -614
  314. package/src/components/feedback/Alert/Alert.tsx +0 -48
  315. package/src/components/feedback/Alert/Alert.types.ts +0 -42
  316. package/src/components/feedback/Alert/Alert.variants.ts +0 -20
  317. package/src/components/feedback/Alert/README.md +0 -522
  318. package/src/components/feedback/Alert/index.ts +0 -3
  319. package/src/components/feedback/AlertDialog/AlertDialog.test.tsx +0 -1237
  320. package/src/components/feedback/AlertDialog/AlertDialog.tsx +0 -160
  321. package/src/components/feedback/AlertDialog/AlertDialog.types.ts +0 -139
  322. package/src/components/feedback/AlertDialog/README.md +0 -723
  323. package/src/components/feedback/AlertDialog/index.ts +0 -2
  324. package/src/components/feedback/CLAUDE.md +0 -87
  325. package/src/components/feedback/ConfirmModal/ConfirmModal.test.tsx +0 -404
  326. package/src/components/feedback/ConfirmModal/ConfirmModal.tsx +0 -139
  327. package/src/components/feedback/ConfirmModal/ConfirmModal.types.ts +0 -117
  328. package/src/components/feedback/ConfirmModal/README.md +0 -546
  329. package/src/components/feedback/ConfirmModal/index.ts +0 -2
  330. package/src/components/feedback/Dialog/Dialog.test.tsx +0 -1070
  331. package/src/components/feedback/Dialog/Dialog.tsx +0 -137
  332. package/src/components/feedback/Dialog/Dialog.types.ts +0 -119
  333. package/src/components/feedback/Dialog/README.md +0 -770
  334. package/src/components/feedback/Dialog/index.ts +0 -2
  335. package/src/components/feedback/ErrorPage/ErrorPage.test.tsx +0 -338
  336. package/src/components/feedback/ErrorPage/ErrorPage.tsx +0 -232
  337. package/src/components/feedback/ErrorPage/ErrorPage.types.ts +0 -95
  338. package/src/components/feedback/ErrorPage/README.md +0 -573
  339. package/src/components/feedback/ErrorPage/index.ts +0 -6
  340. package/src/components/feedback/FocusTrap/FocusTrap.test.tsx +0 -378
  341. package/src/components/feedback/FocusTrap/FocusTrap.tsx +0 -115
  342. package/src/components/feedback/FocusTrap/FocusTrap.types.ts +0 -119
  343. package/src/components/feedback/FocusTrap/README.md +0 -571
  344. package/src/components/feedback/FocusTrap/index.ts +0 -2
  345. package/src/components/feedback/Message/Message.test.tsx +0 -143
  346. package/src/components/feedback/Message/Message.tsx +0 -66
  347. package/src/components/feedback/Message/Message.types.ts +0 -44
  348. package/src/components/feedback/Message/Message.variants.ts +0 -24
  349. package/src/components/feedback/Message/README.md +0 -522
  350. package/src/components/feedback/Message/index.ts +0 -2
  351. package/src/components/feedback/Modal/Modal.test.tsx +0 -475
  352. package/src/components/feedback/Modal/Modal.tsx +0 -168
  353. package/src/components/feedback/Modal/Modal.types.ts +0 -91
  354. package/src/components/feedback/Modal/README.md +0 -517
  355. package/src/components/feedback/Modal/index.ts +0 -2
  356. package/src/components/feedback/Notification/Notification.test.tsx +0 -908
  357. package/src/components/feedback/Notification/Notification.tsx +0 -222
  358. package/src/components/feedback/Notification/Notification.types.ts +0 -90
  359. package/src/components/feedback/Notification/Notification.variants.ts +0 -54
  360. package/src/components/feedback/Notification/README.md +0 -602
  361. package/src/components/feedback/Notification/index.ts +0 -11
  362. package/src/components/feedback/Popover/Popover.test.tsx +0 -901
  363. package/src/components/feedback/Popover/Popover.tsx +0 -60
  364. package/src/components/feedback/Popover/Popover.types.ts +0 -158
  365. package/src/components/feedback/Popover/Popover.variants.ts +0 -27
  366. package/src/components/feedback/Popover/README.md +0 -700
  367. package/src/components/feedback/Popover/index.ts +0 -2
  368. package/src/components/feedback/Toast/README.md +0 -613
  369. package/src/components/feedback/Toast/Toast.test.tsx +0 -1116
  370. package/src/components/feedback/Toast/Toast.tsx +0 -44
  371. package/src/components/feedback/Toast/Toast.types.ts +0 -156
  372. package/src/components/feedback/Toast/index.ts +0 -1
  373. package/src/components/feedback/Tooltip/README.md +0 -671
  374. package/src/components/feedback/Tooltip/Tooltip.test.tsx +0 -413
  375. package/src/components/feedback/Tooltip/Tooltip.tsx +0 -110
  376. package/src/components/feedback/Tooltip/Tooltip.types.ts +0 -138
  377. package/src/components/feedback/Tooltip/Tooltip.variants.ts +0 -54
  378. package/src/components/feedback/Tooltip/index.ts +0 -3
  379. package/src/components/feedback/index.ts +0 -13
  380. package/src/components/forms/Autocomplete/Autocomplete.test.tsx +0 -2351
  381. package/src/components/forms/Autocomplete/Autocomplete.tsx +0 -696
  382. package/src/components/forms/Autocomplete/Autocomplete.types.ts +0 -211
  383. package/src/components/forms/Autocomplete/Autocomplete.variants.ts +0 -154
  384. package/src/components/forms/Autocomplete/README.md +0 -919
  385. package/src/components/forms/Autocomplete/index.ts +0 -7
  386. package/src/components/forms/CLAUDE.md +0 -124
  387. package/src/components/forms/Checkbox/Checkbox.test.tsx +0 -475
  388. package/src/components/forms/Checkbox/Checkbox.tsx +0 -35
  389. package/src/components/forms/Checkbox/Checkbox.types.ts +0 -24
  390. package/src/components/forms/Checkbox/Checkbox.variants.ts +0 -46
  391. package/src/components/forms/Checkbox/README.md +0 -861
  392. package/src/components/forms/Checkbox/index.ts +0 -3
  393. package/src/components/forms/CheckboxGroup/CheckboxGroup.test.tsx +0 -338
  394. package/src/components/forms/CheckboxGroup/CheckboxGroup.tsx +0 -212
  395. package/src/components/forms/CheckboxGroup/CheckboxGroup.types.ts +0 -150
  396. package/src/components/forms/CheckboxGroup/CheckboxGroup.variants.ts +0 -85
  397. package/src/components/forms/CheckboxGroup/README.md +0 -124
  398. package/src/components/forms/CheckboxGroup/index.ts +0 -21
  399. package/src/components/forms/ColorPicker/ColorPicker.test.tsx +0 -916
  400. package/src/components/forms/ColorPicker/ColorPicker.tsx +0 -282
  401. package/src/components/forms/ColorPicker/ColorPicker.types.ts +0 -99
  402. package/src/components/forms/ColorPicker/ColorPicker.variants.ts +0 -84
  403. package/src/components/forms/ColorPicker/README.md +0 -809
  404. package/src/components/forms/ColorPicker/index.ts +0 -14
  405. package/src/components/forms/Combobox/Combobox.test.tsx +0 -975
  406. package/src/components/forms/Combobox/Combobox.tsx +0 -194
  407. package/src/components/forms/Combobox/Combobox.types.ts +0 -113
  408. package/src/components/forms/Combobox/Combobox.variants.ts +0 -108
  409. package/src/components/forms/Combobox/README.md +0 -923
  410. package/src/components/forms/Combobox/index.ts +0 -7
  411. package/src/components/forms/DatePicker/DatePicker.test.tsx +0 -1181
  412. package/src/components/forms/DatePicker/DatePicker.tsx +0 -503
  413. package/src/components/forms/DatePicker/DatePicker.types.ts +0 -196
  414. package/src/components/forms/DatePicker/DatePicker.variants.ts +0 -38
  415. package/src/components/forms/DatePicker/README.md +0 -821
  416. package/src/components/forms/DatePicker/index.ts +0 -8
  417. package/src/components/forms/DateRangePicker/DateRangeInput.tsx +0 -139
  418. package/src/components/forms/DateRangePicker/DateRangePicker.test.tsx +0 -1684
  419. package/src/components/forms/DateRangePicker/DateRangePicker.tsx +0 -375
  420. package/src/components/forms/DateRangePicker/DateRangePicker.types.ts +0 -145
  421. package/src/components/forms/DateRangePicker/DateRangePicker.variants.ts +0 -133
  422. package/src/components/forms/DateRangePicker/DateRangePresets.tsx +0 -44
  423. package/src/components/forms/DateRangePicker/index.ts +0 -25
  424. package/src/components/forms/DateRangePicker/presets.ts +0 -104
  425. package/src/components/forms/EmailInput/EmailInput.test.tsx +0 -562
  426. package/src/components/forms/EmailInput/EmailInput.tsx +0 -59
  427. package/src/components/forms/EmailInput/EmailInput.types.ts +0 -46
  428. package/src/components/forms/EmailInput/EmailInput.variants.ts +0 -30
  429. package/src/components/forms/EmailInput/README.md +0 -708
  430. package/src/components/forms/EmailInput/index.ts +0 -6
  431. package/src/components/forms/ErrorMessage/ErrorMessage.test.tsx +0 -457
  432. package/src/components/forms/ErrorMessage/ErrorMessage.tsx +0 -128
  433. package/src/components/forms/ErrorMessage/ErrorMessage.types.ts +0 -54
  434. package/src/components/forms/ErrorMessage/ErrorMessage.variants.ts +0 -78
  435. package/src/components/forms/ErrorMessage/README.md +0 -855
  436. package/src/components/forms/ErrorMessage/index.ts +0 -4
  437. package/src/components/forms/Field/Field.test.tsx +0 -811
  438. package/src/components/forms/Field/Field.tsx +0 -195
  439. package/src/components/forms/Field/Field.types.ts +0 -94
  440. package/src/components/forms/Field/Field.variants.ts +0 -114
  441. package/src/components/forms/Field/README.md +0 -931
  442. package/src/components/forms/Field/index.ts +0 -3
  443. package/src/components/forms/FloatLabel/FloatLabel.test.tsx +0 -248
  444. package/src/components/forms/FloatLabel/FloatLabel.tsx +0 -110
  445. package/src/components/forms/FloatLabel/FloatLabel.types.ts +0 -37
  446. package/src/components/forms/FloatLabel/index.ts +0 -2
  447. package/src/components/forms/Form/Form.test.tsx +0 -1167
  448. package/src/components/forms/Form/Form.tsx +0 -170
  449. package/src/components/forms/Form/Form.types.ts +0 -126
  450. package/src/components/forms/Form/Form.variants.ts +0 -81
  451. package/src/components/forms/Form/README.md +0 -787
  452. package/src/components/forms/Form/index.ts +0 -3
  453. package/src/components/forms/FormValidation/FormValidation.test.tsx +0 -376
  454. package/src/components/forms/FormValidation/FormValidation.tsx +0 -99
  455. package/src/components/forms/FormValidation/FormValidation.types.ts +0 -37
  456. package/src/components/forms/FormValidation/FormValidation.variants.ts +0 -24
  457. package/src/components/forms/FormValidation/README.md +0 -592
  458. package/src/components/forms/FormValidation/index.ts +0 -4
  459. package/src/components/forms/HelpText/HelpText.test.tsx +0 -558
  460. package/src/components/forms/HelpText/HelpText.tsx +0 -111
  461. package/src/components/forms/HelpText/HelpText.types.ts +0 -51
  462. package/src/components/forms/HelpText/HelpText.variants.ts +0 -54
  463. package/src/components/forms/HelpText/README.md +0 -739
  464. package/src/components/forms/HelpText/index.ts +0 -4
  465. package/src/components/forms/IftaLabel/IftaLabel.test.tsx +0 -193
  466. package/src/components/forms/IftaLabel/IftaLabel.tsx +0 -72
  467. package/src/components/forms/IftaLabel/IftaLabel.types.ts +0 -18
  468. package/src/components/forms/IftaLabel/index.ts +0 -2
  469. package/src/components/forms/InputGroup/InputGroup.test.tsx +0 -782
  470. package/src/components/forms/InputGroup/InputGroup.tsx +0 -128
  471. package/src/components/forms/InputGroup/InputGroup.types.ts +0 -66
  472. package/src/components/forms/InputGroup/InputGroup.variants.ts +0 -102
  473. package/src/components/forms/InputGroup/README.md +0 -845
  474. package/src/components/forms/InputGroup/index.ts +0 -24
  475. package/src/components/forms/InputOTP/InputOTP.test.tsx +0 -793
  476. package/src/components/forms/InputOTP/InputOTP.tsx +0 -90
  477. package/src/components/forms/InputOTP/InputOTP.types.ts +0 -74
  478. package/src/components/forms/InputOTP/InputOTP.variants.ts +0 -64
  479. package/src/components/forms/InputOTP/README.md +0 -1149
  480. package/src/components/forms/InputOTP/index.ts +0 -18
  481. package/src/components/forms/InputOTPField/InputOTPField.test.tsx +0 -220
  482. package/src/components/forms/InputOTPField/InputOTPField.tsx +0 -148
  483. package/src/components/forms/InputOTPField/InputOTPField.types.ts +0 -91
  484. package/src/components/forms/InputOTPField/InputOTPField.variants.ts +0 -83
  485. package/src/components/forms/InputOTPField/README.md +0 -195
  486. package/src/components/forms/InputOTPField/index.ts +0 -12
  487. package/src/components/forms/MultiSelect/MultiSelect.test.tsx +0 -1036
  488. package/src/components/forms/MultiSelect/MultiSelect.tsx +0 -291
  489. package/src/components/forms/MultiSelect/MultiSelect.types.ts +0 -147
  490. package/src/components/forms/MultiSelect/MultiSelect.variants.ts +0 -132
  491. package/src/components/forms/MultiSelect/README.md +0 -897
  492. package/src/components/forms/MultiSelect/index.ts +0 -7
  493. package/src/components/forms/NativeSelect/NativeSelect.test.tsx +0 -856
  494. package/src/components/forms/NativeSelect/NativeSelect.tsx +0 -75
  495. package/src/components/forms/NativeSelect/NativeSelect.types.ts +0 -17
  496. package/src/components/forms/NativeSelect/NativeSelect.variants.ts +0 -106
  497. package/src/components/forms/NativeSelect/README.md +0 -1033
  498. package/src/components/forms/NativeSelect/index.ts +0 -3
  499. package/src/components/forms/NumberInput/NumberInput.test.tsx +0 -636
  500. package/src/components/forms/NumberInput/NumberInput.tsx +0 -131
  501. package/src/components/forms/NumberInput/NumberInput.types.ts +0 -45
  502. package/src/components/forms/NumberInput/NumberInput.variants.ts +0 -85
  503. package/src/components/forms/NumberInput/README.md +0 -766
  504. package/src/components/forms/NumberInput/index.ts +0 -9
  505. package/src/components/forms/PasswordInput/PasswordInput.test.tsx +0 -525
  506. package/src/components/forms/PasswordInput/PasswordInput.tsx +0 -67
  507. package/src/components/forms/PasswordInput/PasswordInput.types.ts +0 -35
  508. package/src/components/forms/PasswordInput/PasswordInput.variants.ts +0 -34
  509. package/src/components/forms/PasswordInput/README.md +0 -698
  510. package/src/components/forms/PasswordInput/index.ts +0 -6
  511. package/src/components/forms/PaymentInput/PaymentInput.test.tsx +0 -252
  512. package/src/components/forms/PaymentInput/PaymentInput.tsx +0 -178
  513. package/src/components/forms/PaymentInput/PaymentInput.types.ts +0 -69
  514. package/src/components/forms/PaymentInput/PaymentInput.variants.ts +0 -81
  515. package/src/components/forms/PaymentInput/README.md +0 -263
  516. package/src/components/forms/PaymentInput/card-utils.ts +0 -219
  517. package/src/components/forms/PaymentInput/index.ts +0 -23
  518. package/src/components/forms/PhoneInput/PhoneInput.test.tsx +0 -270
  519. package/src/components/forms/PhoneInput/PhoneInput.tsx +0 -215
  520. package/src/components/forms/PhoneInput/PhoneInput.types.ts +0 -74
  521. package/src/components/forms/PhoneInput/PhoneInput.variants.ts +0 -103
  522. package/src/components/forms/PhoneInput/README.md +0 -258
  523. package/src/components/forms/PhoneInput/countries.ts +0 -134
  524. package/src/components/forms/PhoneInput/index.ts +0 -22
  525. package/src/components/forms/RadioButton/README.md +0 -832
  526. package/src/components/forms/RadioButton/RadioButton.test.tsx +0 -583
  527. package/src/components/forms/RadioButton/RadioButton.tsx +0 -82
  528. package/src/components/forms/RadioButton/RadioButton.types.ts +0 -23
  529. package/src/components/forms/RadioButton/RadioButton.variants.ts +0 -80
  530. package/src/components/forms/RadioButton/index.ts +0 -15
  531. package/src/components/forms/RadioCardGroup/RadioCardGroup.tsx +0 -130
  532. package/src/components/forms/RadioCardGroup/RadioCardGroup.types.ts +0 -66
  533. package/src/components/forms/RadioCardGroup/RadioCardGroup.variants.ts +0 -131
  534. package/src/components/forms/RadioCardGroup/index.ts +0 -3
  535. package/src/components/forms/RadioGroup/README.md +0 -908
  536. package/src/components/forms/RadioGroup/RadioGroup.test.tsx +0 -764
  537. package/src/components/forms/RadioGroup/RadioGroup.tsx +0 -75
  538. package/src/components/forms/RadioGroup/RadioGroup.types.ts +0 -36
  539. package/src/components/forms/RadioGroup/RadioGroup.variants.ts +0 -58
  540. package/src/components/forms/RadioGroup/index.ts +0 -15
  541. package/src/components/forms/Rating/README.md +0 -729
  542. package/src/components/forms/Rating/Rating.test.tsx +0 -729
  543. package/src/components/forms/Rating/Rating.tsx +0 -258
  544. package/src/components/forms/Rating/Rating.types.ts +0 -89
  545. package/src/components/forms/Rating/Rating.variants.ts +0 -56
  546. package/src/components/forms/Rating/index.ts +0 -8
  547. package/src/components/forms/SearchInput/README.md +0 -729
  548. package/src/components/forms/SearchInput/SearchInput.test.tsx +0 -579
  549. package/src/components/forms/SearchInput/SearchInput.tsx +0 -103
  550. package/src/components/forms/SearchInput/SearchInput.types.ts +0 -40
  551. package/src/components/forms/SearchInput/SearchInput.variants.ts +0 -51
  552. package/src/components/forms/SearchInput/index.ts +0 -8
  553. package/src/components/forms/Select/README.md +0 -1286
  554. package/src/components/forms/Select/Select.test.tsx +0 -1136
  555. package/src/components/forms/Select/Select.tsx +0 -170
  556. package/src/components/forms/Select/Select.types.ts +0 -75
  557. package/src/components/forms/Select/Select.variants.ts +0 -133
  558. package/src/components/forms/Select/index.ts +0 -3
  559. package/src/components/forms/Slider/README.md +0 -1246
  560. package/src/components/forms/Slider/Slider.test.tsx +0 -731
  561. package/src/components/forms/Slider/Slider.tsx +0 -235
  562. package/src/components/forms/Slider/Slider.types.ts +0 -90
  563. package/src/components/forms/Slider/Slider.variants.ts +0 -239
  564. package/src/components/forms/Slider/index.ts +0 -34
  565. package/src/components/forms/SuccessMessage/README.md +0 -534
  566. package/src/components/forms/SuccessMessage/SuccessMessage.test.tsx +0 -257
  567. package/src/components/forms/SuccessMessage/SuccessMessage.tsx +0 -43
  568. package/src/components/forms/SuccessMessage/SuccessMessage.types.ts +0 -11
  569. package/src/components/forms/SuccessMessage/SuccessMessage.variants.ts +0 -15
  570. package/src/components/forms/SuccessMessage/index.ts +0 -4
  571. package/src/components/forms/Switch/README.md +0 -785
  572. package/src/components/forms/Switch/Switch.test.tsx +0 -636
  573. package/src/components/forms/Switch/Switch.tsx +0 -28
  574. package/src/components/forms/Switch/Switch.types.ts +0 -24
  575. package/src/components/forms/Switch/Switch.variants.ts +0 -49
  576. package/src/components/forms/Switch/index.ts +0 -3
  577. package/src/components/forms/TagsInput/README.md +0 -216
  578. package/src/components/forms/TagsInput/TagsInput.test.tsx +0 -308
  579. package/src/components/forms/TagsInput/TagsInput.tsx +0 -189
  580. package/src/components/forms/TagsInput/TagsInput.types.ts +0 -85
  581. package/src/components/forms/TagsInput/TagsInput.variants.ts +0 -58
  582. package/src/components/forms/TagsInput/index.ts +0 -12
  583. package/src/components/forms/TextInput/README.md +0 -871
  584. package/src/components/forms/TextInput/TextInput.test.tsx +0 -484
  585. package/src/components/forms/TextInput/TextInput.tsx +0 -76
  586. package/src/components/forms/TextInput/TextInput.types.ts +0 -61
  587. package/src/components/forms/TextInput/TextInput.variants.ts +0 -117
  588. package/src/components/forms/TextInput/index.ts +0 -14
  589. package/src/components/forms/Textarea/README.md +0 -905
  590. package/src/components/forms/Textarea/Textarea.test.tsx +0 -482
  591. package/src/components/forms/Textarea/Textarea.tsx +0 -24
  592. package/src/components/forms/Textarea/Textarea.types.ts +0 -39
  593. package/src/components/forms/Textarea/Textarea.variants.ts +0 -48
  594. package/src/components/forms/Textarea/index.ts +0 -3
  595. package/src/components/forms/TextareaField/README.md +0 -172
  596. package/src/components/forms/TextareaField/TextareaField.test.tsx +0 -260
  597. package/src/components/forms/TextareaField/TextareaField.tsx +0 -73
  598. package/src/components/forms/TextareaField/TextareaField.types.ts +0 -37
  599. package/src/components/forms/TextareaField/TextareaField.variants.ts +0 -83
  600. package/src/components/forms/TextareaField/index.ts +0 -12
  601. package/src/components/forms/TimePicker/README.md +0 -750
  602. package/src/components/forms/TimePicker/TimePicker.test.tsx +0 -780
  603. package/src/components/forms/TimePicker/TimePicker.tsx +0 -383
  604. package/src/components/forms/TimePicker/TimePicker.types.ts +0 -94
  605. package/src/components/forms/TimePicker/TimePicker.variants.ts +0 -83
  606. package/src/components/forms/TimePicker/index.ts +0 -14
  607. package/src/components/forms/ToggleGroup/README.md +0 -870
  608. package/src/components/forms/ToggleGroup/ToggleGroup.test.tsx +0 -941
  609. package/src/components/forms/ToggleGroup/ToggleGroup.tsx +0 -5
  610. package/src/components/forms/ToggleGroup/ToggleGroup.types.ts +0 -17
  611. package/src/components/forms/ToggleGroup/ToggleGroup.variants.ts +0 -42
  612. package/src/components/forms/ToggleGroup/index.ts +0 -9
  613. package/src/components/forms/URLInput/README.md +0 -701
  614. package/src/components/forms/URLInput/URLInput.test.tsx +0 -602
  615. package/src/components/forms/URLInput/URLInput.tsx +0 -71
  616. package/src/components/forms/URLInput/URLInput.types.ts +0 -51
  617. package/src/components/forms/URLInput/URLInput.variants.ts +0 -52
  618. package/src/components/forms/URLInput/index.ts +0 -8
  619. package/src/components/forms/index.ts +0 -44
  620. package/src/components/index.ts +0 -26
  621. package/src/components/layout/AppContent/AppContent.test.tsx +0 -34
  622. package/src/components/layout/AppContent/AppContent.tsx +0 -23
  623. package/src/components/layout/AppContent/AppContent.variants.ts +0 -23
  624. package/src/components/layout/AppContent/index.ts +0 -2
  625. package/src/components/layout/AppHeader/AppHeader.test.tsx +0 -26
  626. package/src/components/layout/AppHeader/AppHeader.tsx +0 -17
  627. package/src/components/layout/AppHeader/AppHeader.variants.ts +0 -21
  628. package/src/components/layout/AppHeader/AppHeaderActions.tsx +0 -13
  629. package/src/components/layout/AppHeader/AppHeaderNav.tsx +0 -13
  630. package/src/components/layout/AppHeader/AppHeaderTitle.tsx +0 -13
  631. package/src/components/layout/AppHeader/index.ts +0 -5
  632. package/src/components/layout/AppRail/AppRail.test.tsx +0 -50
  633. package/src/components/layout/AppRail/AppRail.tsx +0 -24
  634. package/src/components/layout/AppRail/AppRail.variants.ts +0 -31
  635. package/src/components/layout/AppRail/AppRailFooter.tsx +0 -13
  636. package/src/components/layout/AppRail/AppRailGroup.tsx +0 -13
  637. package/src/components/layout/AppRail/AppRailHeader.tsx +0 -13
  638. package/src/components/layout/AppRail/AppRailItem.tsx +0 -57
  639. package/src/components/layout/AppRail/index.ts +0 -5
  640. package/src/components/layout/AppShell/AppShell.context.tsx +0 -34
  641. package/src/components/layout/AppShell/AppShell.test.tsx +0 -61
  642. package/src/components/layout/AppShell/AppShell.tsx +0 -91
  643. package/src/components/layout/AppShell/AppShell.variants.ts +0 -21
  644. package/src/components/layout/AppShell/index.ts +0 -2
  645. package/src/components/layout/AppSidebar/AppSidebar.test.tsx +0 -69
  646. package/src/components/layout/AppSidebar/AppSidebar.tsx +0 -58
  647. package/src/components/layout/AppSidebar/AppSidebar.variants.ts +0 -41
  648. package/src/components/layout/AppSidebar/AppSidebarContent.tsx +0 -18
  649. package/src/components/layout/AppSidebar/AppSidebarFooter.tsx +0 -13
  650. package/src/components/layout/AppSidebar/AppSidebarGroup.tsx +0 -22
  651. package/src/components/layout/AppSidebar/AppSidebarHeader.tsx +0 -13
  652. package/src/components/layout/AppSidebar/AppSidebarItem.tsx +0 -54
  653. package/src/components/layout/AppSidebar/AppSidebarTrigger.tsx +0 -25
  654. package/src/components/layout/AppSidebar/index.ts +0 -7
  655. package/src/components/layout/CLAUDE.md +0 -112
  656. package/src/components/layout/Card/Card.test.tsx +0 -339
  657. package/src/components/layout/Card/Card.tsx +0 -102
  658. package/src/components/layout/Card/Card.types.ts +0 -52
  659. package/src/components/layout/Card/Card.variants.ts +0 -85
  660. package/src/components/layout/Card/README.md +0 -994
  661. package/src/components/layout/Card/index.ts +0 -3
  662. package/src/components/layout/Collapsible/Collapsible.test.tsx +0 -491
  663. package/src/components/layout/Collapsible/Collapsible.tsx +0 -50
  664. package/src/components/layout/Collapsible/Collapsible.types.ts +0 -26
  665. package/src/components/layout/Collapsible/Collapsible.variants.ts +0 -52
  666. package/src/components/layout/Collapsible/README.md +0 -885
  667. package/src/components/layout/Collapsible/index.ts +0 -3
  668. package/src/components/layout/Container/Container.test.tsx +0 -283
  669. package/src/components/layout/Container/Container.tsx +0 -25
  670. package/src/components/layout/Container/Container.types.ts +0 -36
  671. package/src/components/layout/Container/Container.variants.ts +0 -59
  672. package/src/components/layout/Container/README.md +0 -700
  673. package/src/components/layout/Container/index.ts +0 -3
  674. package/src/components/layout/Flex/Flex.test.tsx +0 -545
  675. package/src/components/layout/Flex/Flex.tsx +0 -52
  676. package/src/components/layout/Flex/Flex.types.ts +0 -61
  677. package/src/components/layout/Flex/Flex.variants.ts +0 -98
  678. package/src/components/layout/Flex/README.md +0 -812
  679. package/src/components/layout/Flex/index.ts +0 -3
  680. package/src/components/layout/Grid/Grid.test.tsx +0 -601
  681. package/src/components/layout/Grid/Grid.tsx +0 -61
  682. package/src/components/layout/Grid/Grid.types.ts +0 -47
  683. package/src/components/layout/Grid/Grid.variants.ts +0 -100
  684. package/src/components/layout/Grid/README.md +0 -762
  685. package/src/components/layout/Grid/index.ts +0 -3
  686. package/src/components/layout/PageContent/PageContent.tsx +0 -13
  687. package/src/components/layout/PageContent/index.ts +0 -1
  688. package/src/components/layout/PageHeader/PageHeader.tsx +0 -43
  689. package/src/components/layout/PageHeader/index.ts +0 -1
  690. package/src/components/layout/PageSection/PageSection.tsx +0 -28
  691. package/src/components/layout/PageSection/index.ts +0 -1
  692. package/src/components/layout/Panel/Panel.test.tsx +0 -427
  693. package/src/components/layout/Panel/Panel.tsx +0 -75
  694. package/src/components/layout/Panel/Panel.types.ts +0 -59
  695. package/src/components/layout/Panel/Panel.variants.ts +0 -94
  696. package/src/components/layout/Panel/README.md +0 -861
  697. package/src/components/layout/Panel/index.ts +0 -3
  698. package/src/components/layout/ResizablePanels/README.md +0 -369
  699. package/src/components/layout/ResizablePanels/ResizablePanels.test.tsx +0 -506
  700. package/src/components/layout/ResizablePanels/ResizablePanels.tsx +0 -64
  701. package/src/components/layout/ResizablePanels/ResizablePanels.types.ts +0 -41
  702. package/src/components/layout/ResizablePanels/ResizablePanels.variants.ts +0 -67
  703. package/src/components/layout/ResizablePanels/index.ts +0 -3
  704. package/src/components/layout/ResponsiveContainer/README.md +0 -267
  705. package/src/components/layout/ResponsiveContainer/ResponsiveContainer.test.tsx +0 -386
  706. package/src/components/layout/ResponsiveContainer/ResponsiveContainer.tsx +0 -54
  707. package/src/components/layout/ResponsiveContainer/ResponsiveContainer.types.ts +0 -43
  708. package/src/components/layout/ResponsiveContainer/ResponsiveContainer.variants.ts +0 -106
  709. package/src/components/layout/ResponsiveContainer/index.ts +0 -3
  710. package/src/components/layout/ScrollArea/README.md +0 -278
  711. package/src/components/layout/ScrollArea/ScrollArea.test.tsx +0 -352
  712. package/src/components/layout/ScrollArea/ScrollArea.tsx +0 -61
  713. package/src/components/layout/ScrollArea/ScrollArea.types.ts +0 -36
  714. package/src/components/layout/ScrollArea/ScrollArea.variants.ts +0 -85
  715. package/src/components/layout/ScrollArea/index.ts +0 -3
  716. package/src/components/layout/Section/README.md +0 -315
  717. package/src/components/layout/Section/Section.test.tsx +0 -293
  718. package/src/components/layout/Section/Section.tsx +0 -60
  719. package/src/components/layout/Section/Section.types.ts +0 -38
  720. package/src/components/layout/Section/Section.variants.ts +0 -45
  721. package/src/components/layout/Section/index.ts +0 -3
  722. package/src/components/layout/Sheet/README.md +0 -533
  723. package/src/components/layout/Sheet/Sheet.test.tsx +0 -702
  724. package/src/components/layout/Sheet/Sheet.tsx +0 -142
  725. package/src/components/layout/Sheet/Sheet.types.ts +0 -92
  726. package/src/components/layout/Sheet/Sheet.variants.ts +0 -98
  727. package/src/components/layout/Sheet/index.ts +0 -3
  728. package/src/components/layout/Stack/README.md +0 -346
  729. package/src/components/layout/Stack/Stack.test.tsx +0 -492
  730. package/src/components/layout/Stack/Stack.tsx +0 -58
  731. package/src/components/layout/Stack/Stack.types.ts +0 -58
  732. package/src/components/layout/Stack/Stack.variants.ts +0 -77
  733. package/src/components/layout/Stack/index.ts +0 -3
  734. package/src/components/layout/index.ts +0 -21
  735. package/src/components/navigation/Breadcrumb/Breadcrumb.test.tsx +0 -875
  736. package/src/components/navigation/Breadcrumb/Breadcrumb.tsx +0 -183
  737. package/src/components/navigation/Breadcrumb/Breadcrumb.types.ts +0 -49
  738. package/src/components/navigation/Breadcrumb/Breadcrumb.variants.ts +0 -63
  739. package/src/components/navigation/Breadcrumb/README.md +0 -608
  740. package/src/components/navigation/Breadcrumb/index.ts +0 -24
  741. package/src/components/navigation/CLAUDE.md +0 -118
  742. package/src/components/navigation/ContextMenu/ContextMenu.test.tsx +0 -881
  743. package/src/components/navigation/ContextMenu/ContextMenu.tsx +0 -304
  744. package/src/components/navigation/ContextMenu/ContextMenu.types.ts +0 -119
  745. package/src/components/navigation/ContextMenu/ContextMenu.variants.ts +0 -167
  746. package/src/components/navigation/ContextMenu/README.md +0 -660
  747. package/src/components/navigation/ContextMenu/index.ts +0 -34
  748. package/src/components/navigation/Drawer/Drawer.test.tsx +0 -721
  749. package/src/components/navigation/Drawer/Drawer.tsx +0 -178
  750. package/src/components/navigation/Drawer/Drawer.types.ts +0 -66
  751. package/src/components/navigation/Drawer/Drawer.variants.ts +0 -121
  752. package/src/components/navigation/Drawer/README.md +0 -723
  753. package/src/components/navigation/Drawer/index.ts +0 -24
  754. package/src/components/navigation/DropdownMenu/DropdownMenu.test.tsx +0 -881
  755. package/src/components/navigation/DropdownMenu/DropdownMenu.tsx +0 -305
  756. package/src/components/navigation/DropdownMenu/DropdownMenu.types.ts +0 -98
  757. package/src/components/navigation/DropdownMenu/DropdownMenu.variants.ts +0 -168
  758. package/src/components/navigation/DropdownMenu/README.md +0 -676
  759. package/src/components/navigation/DropdownMenu/index.ts +0 -33
  760. package/src/components/navigation/Header/Header.test.tsx +0 -418
  761. package/src/components/navigation/Header/Header.tsx +0 -133
  762. package/src/components/navigation/Header/Header.types.ts +0 -41
  763. package/src/components/navigation/Header/Header.variants.ts +0 -91
  764. package/src/components/navigation/Header/README.md +0 -567
  765. package/src/components/navigation/Header/index.ts +0 -14
  766. package/src/components/navigation/Menu/Menu.test.tsx +0 -658
  767. package/src/components/navigation/Menu/Menu.tsx +0 -247
  768. package/src/components/navigation/Menu/Menu.types.ts +0 -51
  769. package/src/components/navigation/Menu/Menu.variants.ts +0 -105
  770. package/src/components/navigation/Menu/README.md +0 -599
  771. package/src/components/navigation/Menu/index.ts +0 -17
  772. package/src/components/navigation/Menubar/Menubar.test.tsx +0 -1028
  773. package/src/components/navigation/Menubar/Menubar.tsx +0 -308
  774. package/src/components/navigation/Menubar/Menubar.types.ts +0 -104
  775. package/src/components/navigation/Menubar/Menubar.variants.ts +0 -182
  776. package/src/components/navigation/Menubar/README.md +0 -641
  777. package/src/components/navigation/Menubar/index.ts +0 -36
  778. package/src/components/navigation/MobileSidebar/MobileSidebar.test.tsx +0 -255
  779. package/src/components/navigation/MobileSidebar/MobileSidebar.tsx +0 -187
  780. package/src/components/navigation/MobileSidebar/MobileSidebar.types.ts +0 -62
  781. package/src/components/navigation/MobileSidebar/MobileSidebar.variants.ts +0 -79
  782. package/src/components/navigation/MobileSidebar/index.ts +0 -17
  783. package/src/components/navigation/Navbar/Navbar.test.tsx +0 -621
  784. package/src/components/navigation/Navbar/Navbar.tsx +0 -238
  785. package/src/components/navigation/Navbar/Navbar.types.ts +0 -69
  786. package/src/components/navigation/Navbar/Navbar.variants.ts +0 -176
  787. package/src/components/navigation/Navbar/README.md +0 -670
  788. package/src/components/navigation/Navbar/index.ts +0 -20
  789. package/src/components/navigation/NavigationMenu/NavigationMenu.test.tsx +0 -701
  790. package/src/components/navigation/NavigationMenu/NavigationMenu.tsx +0 -211
  791. package/src/components/navigation/NavigationMenu/NavigationMenu.types.ts +0 -52
  792. package/src/components/navigation/NavigationMenu/NavigationMenu.variants.ts +0 -122
  793. package/src/components/navigation/NavigationMenu/README.md +0 -697
  794. package/src/components/navigation/NavigationMenu/index.ts +0 -23
  795. package/src/components/navigation/Pagination/Pagination.test.tsx +0 -619
  796. package/src/components/navigation/Pagination/Pagination.tsx +0 -185
  797. package/src/components/navigation/Pagination/Pagination.types.ts +0 -42
  798. package/src/components/navigation/Pagination/Pagination.variants.ts +0 -36
  799. package/src/components/navigation/Pagination/README.md +0 -635
  800. package/src/components/navigation/Pagination/index.ts +0 -17
  801. package/src/components/navigation/Sidebar/README.md +0 -628
  802. package/src/components/navigation/Sidebar/Sidebar.test.tsx +0 -1169
  803. package/src/components/navigation/Sidebar/Sidebar.tsx +0 -761
  804. package/src/components/navigation/Sidebar/Sidebar.types.ts +0 -168
  805. package/src/components/navigation/Sidebar/Sidebar.variants.ts +0 -302
  806. package/src/components/navigation/Sidebar/index.ts +0 -59
  807. package/src/components/navigation/SkipLinks/README.md +0 -512
  808. package/src/components/navigation/SkipLinks/SkipLinks.test.tsx +0 -445
  809. package/src/components/navigation/SkipLinks/SkipLinks.tsx +0 -103
  810. package/src/components/navigation/SkipLinks/SkipLinks.types.ts +0 -39
  811. package/src/components/navigation/SkipLinks/SkipLinks.variants.ts +0 -102
  812. package/src/components/navigation/SkipLinks/index.ts +0 -12
  813. package/src/components/navigation/TabNavigation/TabNavigation.tsx +0 -196
  814. package/src/components/navigation/TabNavigation/TabNavigation.types.ts +0 -85
  815. package/src/components/navigation/TabNavigation/TabNavigation.variants.ts +0 -95
  816. package/src/components/navigation/TabNavigation/index.ts +0 -10
  817. package/src/components/navigation/TabPanel/README.md +0 -437
  818. package/src/components/navigation/TabPanel/TabPanel.test.tsx +0 -566
  819. package/src/components/navigation/TabPanel/TabPanel.tsx +0 -95
  820. package/src/components/navigation/TabPanel/TabPanel.types.ts +0 -29
  821. package/src/components/navigation/TabPanel/TabPanel.variants.ts +0 -61
  822. package/src/components/navigation/TabPanel/index.ts +0 -13
  823. package/src/components/navigation/Tabs/README.md +0 -669
  824. package/src/components/navigation/Tabs/Tabs.test.tsx +0 -500
  825. package/src/components/navigation/Tabs/Tabs.tsx +0 -112
  826. package/src/components/navigation/Tabs/Tabs.types.ts +0 -38
  827. package/src/components/navigation/Tabs/Tabs.variants.ts +0 -80
  828. package/src/components/navigation/Tabs/index.ts +0 -14
  829. package/src/components/navigation/Toolbar/README.md +0 -650
  830. package/src/components/navigation/Toolbar/Toolbar.test.tsx +0 -620
  831. package/src/components/navigation/Toolbar/Toolbar.tsx +0 -133
  832. package/src/components/navigation/Toolbar/Toolbar.types.ts +0 -42
  833. package/src/components/navigation/Toolbar/Toolbar.variants.ts +0 -95
  834. package/src/components/navigation/Toolbar/index.ts +0 -17
  835. package/src/components/navigation/UserProfileDropdown/UserProfileDropdown.test.tsx +0 -257
  836. package/src/components/navigation/UserProfileDropdown/UserProfileDropdown.tsx +0 -267
  837. package/src/components/navigation/UserProfileDropdown/UserProfileDropdown.types.ts +0 -84
  838. package/src/components/navigation/UserProfileDropdown/UserProfileDropdown.variants.ts +0 -77
  839. package/src/components/navigation/UserProfileDropdown/index.ts +0 -17
  840. package/src/components/navigation/WorkspaceDropdown/WorkspaceDropdown.tsx +0 -190
  841. package/src/components/navigation/WorkspaceDropdown/WorkspaceDropdown.types.ts +0 -56
  842. package/src/components/navigation/WorkspaceDropdown/WorkspaceDropdown.variants.ts +0 -82
  843. package/src/components/navigation/WorkspaceDropdown/index.ts +0 -20
  844. package/src/components/navigation/index.ts +0 -17
  845. package/src/components/primitives/ArrowAnimated/ArrowAnimated.test.tsx +0 -240
  846. package/src/components/primitives/ArrowAnimated/ArrowAnimated.tsx +0 -96
  847. package/src/components/primitives/ArrowAnimated/ArrowAnimated.types.ts +0 -16
  848. package/src/components/primitives/ArrowAnimated/ArrowAnimated.variants.ts +0 -43
  849. package/src/components/primitives/ArrowAnimated/index.ts +0 -9
  850. package/src/components/primitives/AspectRatio/AspectRatio.test.tsx +0 -306
  851. package/src/components/primitives/AspectRatio/AspectRatio.tsx +0 -11
  852. package/src/components/primitives/AspectRatio/AspectRatio.types.ts +0 -57
  853. package/src/components/primitives/AspectRatio/AspectRatio.variants.ts +0 -110
  854. package/src/components/primitives/AspectRatio/README.md +0 -914
  855. package/src/components/primitives/AspectRatio/index.ts +0 -7
  856. package/src/components/primitives/Avatar/Avatar.test.tsx +0 -1311
  857. package/src/components/primitives/Avatar/Avatar.tsx +0 -159
  858. package/src/components/primitives/Avatar/Avatar.types.ts +0 -70
  859. package/src/components/primitives/Avatar/AvatarAddButton.tsx +0 -59
  860. package/src/components/primitives/Avatar/AvatarBadge.tsx +0 -84
  861. package/src/components/primitives/Avatar/AvatarGroup.test.tsx +0 -1377
  862. package/src/components/primitives/Avatar/AvatarGroup.tsx +0 -101
  863. package/src/components/primitives/Avatar/AvatarLabelGroup.tsx +0 -160
  864. package/src/components/primitives/Avatar/AvatarSkeleton.tsx +0 -76
  865. package/src/components/primitives/Avatar/AvatarStatus.tsx +0 -71
  866. package/src/components/primitives/Avatar/README.md +0 -1174
  867. package/src/components/primitives/Avatar/index.ts +0 -8
  868. package/src/components/primitives/Badge/Badge.test.tsx +0 -1146
  869. package/src/components/primitives/Badge/Badge.tsx +0 -389
  870. package/src/components/primitives/Badge/Badge.types.ts +0 -102
  871. package/src/components/primitives/Badge/README.md +0 -814
  872. package/src/components/primitives/Badge/index.ts +0 -2
  873. package/src/components/primitives/Button/Button.test.tsx +0 -626
  874. package/src/components/primitives/Button/Button.tsx +0 -299
  875. package/src/components/primitives/Button/Button.types.ts +0 -137
  876. package/src/components/primitives/Button/README.md +0 -1112
  877. package/src/components/primitives/Button/index.ts +0 -8
  878. package/src/components/primitives/ButtonGroup/ButtonGroup.test.tsx +0 -945
  879. package/src/components/primitives/ButtonGroup/ButtonGroup.tsx +0 -224
  880. package/src/components/primitives/ButtonGroup/ButtonGroup.types.ts +0 -133
  881. package/src/components/primitives/ButtonGroup/README.md +0 -945
  882. package/src/components/primitives/ButtonGroup/index.ts +0 -12
  883. package/src/components/primitives/CLAUDE.md +0 -108
  884. package/src/components/primitives/ConfirmButton/ConfirmButton.test.tsx +0 -929
  885. package/src/components/primitives/ConfirmButton/ConfirmButton.tsx +0 -298
  886. package/src/components/primitives/ConfirmButton/ConfirmButton.types.ts +0 -116
  887. package/src/components/primitives/ConfirmButton/README.md +0 -1059
  888. package/src/components/primitives/ConfirmButton/index.ts +0 -6
  889. package/src/components/primitives/Divider/Divider.test.tsx +0 -304
  890. package/src/components/primitives/Divider/Divider.tsx +0 -209
  891. package/src/components/primitives/Divider/Divider.types.ts +0 -74
  892. package/src/components/primitives/Divider/README.md +0 -839
  893. package/src/components/primitives/Divider/index.ts +0 -8
  894. package/src/components/primitives/Heading/Heading.test.tsx +0 -611
  895. package/src/components/primitives/Heading/Heading.tsx +0 -120
  896. package/src/components/primitives/Heading/Heading.types.ts +0 -61
  897. package/src/components/primitives/Heading/README.md +0 -820
  898. package/src/components/primitives/Heading/index.ts +0 -2
  899. package/src/components/primitives/Icon/Icon.test.tsx +0 -466
  900. package/src/components/primitives/Icon/Icon.tsx +0 -74
  901. package/src/components/primitives/Icon/Icon.types.ts +0 -61
  902. package/src/components/primitives/Icon/README.md +0 -759
  903. package/src/components/primitives/Icon/index.ts +0 -8
  904. package/src/components/primitives/Image/Image.test.tsx +0 -734
  905. package/src/components/primitives/Image/Image.tsx +0 -239
  906. package/src/components/primitives/Image/Image.types.ts +0 -75
  907. package/src/components/primitives/Image/README.md +0 -863
  908. package/src/components/primitives/Image/index.ts +0 -8
  909. package/src/components/primitives/Kbd/Kbd.test.tsx +0 -432
  910. package/src/components/primitives/Kbd/Kbd.tsx +0 -53
  911. package/src/components/primitives/Kbd/Kbd.types.ts +0 -55
  912. package/src/components/primitives/Kbd/Kbd.variants.ts +0 -33
  913. package/src/components/primitives/Kbd/README.md +0 -659
  914. package/src/components/primitives/Kbd/index.ts +0 -3
  915. package/src/components/primitives/Label/Label.test.tsx +0 -311
  916. package/src/components/primitives/Label/Label.tsx +0 -46
  917. package/src/components/primitives/Label/Label.types.ts +0 -28
  918. package/src/components/primitives/Label/README.md +0 -816
  919. package/src/components/primitives/Label/index.ts +0 -2
  920. package/src/components/primitives/Link/Link.test.tsx +0 -764
  921. package/src/components/primitives/Link/Link.tsx +0 -143
  922. package/src/components/primitives/Link/Link.types.ts +0 -85
  923. package/src/components/primitives/Link/README.md +0 -954
  924. package/src/components/primitives/Link/index.ts +0 -8
  925. package/src/components/primitives/Paragraph/Paragraph.test.tsx +0 -463
  926. package/src/components/primitives/Paragraph/Paragraph.tsx +0 -119
  927. package/src/components/primitives/Paragraph/Paragraph.types.ts +0 -81
  928. package/src/components/primitives/Paragraph/README.md +0 -812
  929. package/src/components/primitives/Paragraph/index.ts +0 -2
  930. package/src/components/primitives/ProgressBar/ProgressBar.test.tsx +0 -598
  931. package/src/components/primitives/ProgressBar/ProgressBar.tsx +0 -268
  932. package/src/components/primitives/ProgressBar/ProgressBar.types.ts +0 -127
  933. package/src/components/primitives/ProgressBar/ProgressBar.variants.ts +0 -111
  934. package/src/components/primitives/ProgressBar/README.md +0 -772
  935. package/src/components/primitives/ProgressBar/index.ts +0 -3
  936. package/src/components/primitives/ProgressCircle/ProgressCircle.test.tsx +0 -219
  937. package/src/components/primitives/ProgressCircle/ProgressCircle.tsx +0 -264
  938. package/src/components/primitives/ProgressCircle/ProgressCircle.types.ts +0 -152
  939. package/src/components/primitives/ProgressCircle/ProgressCircle.variants.ts +0 -140
  940. package/src/components/primitives/ProgressCircle/README.md +0 -763
  941. package/src/components/primitives/ProgressCircle/index.ts +0 -3
  942. package/src/components/primitives/SkeletonLoader/README.md +0 -792
  943. package/src/components/primitives/SkeletonLoader/SkeletonLoader.test.tsx +0 -382
  944. package/src/components/primitives/SkeletonLoader/SkeletonLoader.tsx +0 -45
  945. package/src/components/primitives/SkeletonLoader/SkeletonLoader.types.ts +0 -56
  946. package/src/components/primitives/SkeletonLoader/SkeletonLoader.variants.ts +0 -87
  947. package/src/components/primitives/SkeletonLoader/index.ts +0 -3
  948. package/src/components/primitives/Spacer/README.md +0 -804
  949. package/src/components/primitives/Spacer/Spacer.test.tsx +0 -363
  950. package/src/components/primitives/Spacer/Spacer.tsx +0 -147
  951. package/src/components/primitives/Spacer/Spacer.types.ts +0 -72
  952. package/src/components/primitives/Spacer/index.ts +0 -9
  953. package/src/components/primitives/Spinner/README.md +0 -767
  954. package/src/components/primitives/Spinner/Spinner.test.tsx +0 -289
  955. package/src/components/primitives/Spinner/Spinner.tsx +0 -101
  956. package/src/components/primitives/Spinner/Spinner.types.ts +0 -62
  957. package/src/components/primitives/Spinner/Spinner.variants.ts +0 -50
  958. package/src/components/primitives/Spinner/index.ts +0 -3
  959. package/src/components/primitives/SplitButton/README.md +0 -1142
  960. package/src/components/primitives/SplitButton/SplitButton.test.tsx +0 -1020
  961. package/src/components/primitives/SplitButton/SplitButton.tsx +0 -215
  962. package/src/components/primitives/SplitButton/SplitButton.types.ts +0 -114
  963. package/src/components/primitives/SplitButton/index.ts +0 -8
  964. package/src/components/primitives/StatusIndicator/README.md +0 -730
  965. package/src/components/primitives/StatusIndicator/StatusIndicator.test.tsx +0 -446
  966. package/src/components/primitives/StatusIndicator/StatusIndicator.tsx +0 -100
  967. package/src/components/primitives/StatusIndicator/StatusIndicator.types.ts +0 -39
  968. package/src/components/primitives/StatusIndicator/index.ts +0 -2
  969. package/src/components/primitives/Tag/README.md +0 -793
  970. package/src/components/primitives/Tag/Tag.test.tsx +0 -410
  971. package/src/components/primitives/Tag/Tag.tsx +0 -302
  972. package/src/components/primitives/Tag/Tag.types.ts +0 -112
  973. package/src/components/primitives/Tag/Tag.variants.ts +0 -144
  974. package/src/components/primitives/Tag/TagGroup.tsx +0 -89
  975. package/src/components/primitives/Tag/index.ts +0 -15
  976. package/src/components/primitives/Text/README.md +0 -849
  977. package/src/components/primitives/Text/Text.test.tsx +0 -371
  978. package/src/components/primitives/Text/Text.tsx +0 -89
  979. package/src/components/primitives/Text/Text.types.ts +0 -21
  980. package/src/components/primitives/Text/index.ts +0 -2
  981. package/src/components/primitives/Thumbnail/README.md +0 -800
  982. package/src/components/primitives/Thumbnail/Thumbnail.test.tsx +0 -657
  983. package/src/components/primitives/Thumbnail/Thumbnail.tsx +0 -141
  984. package/src/components/primitives/Thumbnail/Thumbnail.types.ts +0 -102
  985. package/src/components/primitives/Thumbnail/index.ts +0 -9
  986. package/src/components/primitives/Toggle/README.md +0 -232
  987. package/src/components/primitives/Toggle/Toggle.test.tsx +0 -630
  988. package/src/components/primitives/Toggle/Toggle.tsx +0 -174
  989. package/src/components/primitives/Toggle/Toggle.types.ts +0 -161
  990. package/src/components/primitives/Toggle/index.ts +0 -2
  991. package/src/components/primitives/index.ts +0 -26
  992. package/src/components/workflow/ApprovalFlow/ApprovalFlow.test.tsx +0 -607
  993. package/src/components/workflow/ApprovalFlow/ApprovalFlow.tsx +0 -522
  994. package/src/components/workflow/ApprovalFlow/ApprovalFlow.types.ts +0 -233
  995. package/src/components/workflow/ApprovalFlow/ApprovalFlow.variants.ts +0 -207
  996. package/src/components/workflow/ApprovalFlow/README.md +0 -450
  997. package/src/components/workflow/ApprovalFlow/index.ts +0 -38
  998. package/src/components/workflow/ApprovalStatus/ApprovalStatus.test.tsx +0 -316
  999. package/src/components/workflow/ApprovalStatus/ApprovalStatus.tsx +0 -342
  1000. package/src/components/workflow/ApprovalStatus/ApprovalStatus.types.ts +0 -68
  1001. package/src/components/workflow/ApprovalStatus/ApprovalStatus.variants.ts +0 -60
  1002. package/src/components/workflow/ApprovalStatus/README.md +0 -359
  1003. package/src/components/workflow/ApprovalStatus/index.ts +0 -7
  1004. package/src/components/workflow/CLAUDE.md +0 -118
  1005. package/src/components/workflow/CommentSystem/CommentSystem.test.tsx +0 -901
  1006. package/src/components/workflow/CommentSystem/CommentSystem.tsx +0 -1014
  1007. package/src/components/workflow/CommentSystem/CommentSystem.types.ts +0 -290
  1008. package/src/components/workflow/CommentSystem/CommentSystem.variants.ts +0 -307
  1009. package/src/components/workflow/CommentSystem/README.md +0 -478
  1010. package/src/components/workflow/CommentSystem/index.ts +0 -37
  1011. package/src/components/workflow/Dashboard/Dashboard.test.tsx +0 -586
  1012. package/src/components/workflow/Dashboard/Dashboard.tsx +0 -447
  1013. package/src/components/workflow/Dashboard/Dashboard.types.ts +0 -232
  1014. package/src/components/workflow/Dashboard/Dashboard.variants.ts +0 -241
  1015. package/src/components/workflow/Dashboard/README.md +0 -445
  1016. package/src/components/workflow/Dashboard/index.ts +0 -39
  1017. package/src/components/workflow/DashboardBuilder/DashboardBuilder.test.tsx +0 -460
  1018. package/src/components/workflow/DashboardBuilder/DashboardBuilder.tsx +0 -944
  1019. package/src/components/workflow/DashboardBuilder/DashboardBuilder.types.ts +0 -389
  1020. package/src/components/workflow/DashboardBuilder/DashboardBuilder.variants.ts +0 -264
  1021. package/src/components/workflow/DashboardBuilder/README.md +0 -489
  1022. package/src/components/workflow/DashboardBuilder/index.ts +0 -61
  1023. package/src/components/workflow/KanbanBoard/KanbanBoard.test.tsx +0 -445
  1024. package/src/components/workflow/KanbanBoard/KanbanBoard.tsx +0 -806
  1025. package/src/components/workflow/KanbanBoard/KanbanBoard.types.ts +0 -183
  1026. package/src/components/workflow/KanbanBoard/KanbanBoard.variants.ts +0 -311
  1027. package/src/components/workflow/KanbanBoard/README.md +0 -495
  1028. package/src/components/workflow/KanbanBoard/index.ts +0 -40
  1029. package/src/components/workflow/ProgressSteps/ProgressSteps.test.tsx +0 -318
  1030. package/src/components/workflow/ProgressSteps/ProgressSteps.tsx +0 -350
  1031. package/src/components/workflow/ProgressSteps/ProgressSteps.types.ts +0 -84
  1032. package/src/components/workflow/ProgressSteps/ProgressSteps.variants.ts +0 -315
  1033. package/src/components/workflow/ProgressSteps/README.md +0 -412
  1034. package/src/components/workflow/ProgressSteps/index.ts +0 -20
  1035. package/src/components/workflow/ReportGenerator/README.md +0 -530
  1036. package/src/components/workflow/ReportGenerator/ReportGenerator.test.tsx +0 -723
  1037. package/src/components/workflow/ReportGenerator/ReportGenerator.tsx +0 -889
  1038. package/src/components/workflow/ReportGenerator/ReportGenerator.types.ts +0 -321
  1039. package/src/components/workflow/ReportGenerator/ReportGenerator.variants.ts +0 -378
  1040. package/src/components/workflow/ReportGenerator/index.ts +0 -44
  1041. package/src/components/workflow/Stepper/README.md +0 -390
  1042. package/src/components/workflow/Stepper/Stepper.test.tsx +0 -376
  1043. package/src/components/workflow/Stepper/Stepper.tsx +0 -301
  1044. package/src/components/workflow/Stepper/Stepper.types.ts +0 -73
  1045. package/src/components/workflow/Stepper/Stepper.variants.ts +0 -194
  1046. package/src/components/workflow/Stepper/index.ts +0 -16
  1047. package/src/components/workflow/TaskCard/README.md +0 -343
  1048. package/src/components/workflow/TaskCard/TaskCard.test.tsx +0 -375
  1049. package/src/components/workflow/TaskCard/TaskCard.tsx +0 -312
  1050. package/src/components/workflow/TaskCard/TaskCard.types.ts +0 -55
  1051. package/src/components/workflow/TaskCard/TaskCard.variants.ts +0 -64
  1052. package/src/components/workflow/TaskCard/index.ts +0 -14
  1053. package/src/components/workflow/TaskList/README.md +0 -317
  1054. package/src/components/workflow/TaskList/TaskList.test.tsx +0 -318
  1055. package/src/components/workflow/TaskList/TaskList.tsx +0 -556
  1056. package/src/components/workflow/TaskList/TaskList.types.ts +0 -78
  1057. package/src/components/workflow/TaskList/TaskList.variants.ts +0 -143
  1058. package/src/components/workflow/TaskList/index.ts +0 -19
  1059. package/src/components/workflow/TaskStatus/README.md +0 -358
  1060. package/src/components/workflow/TaskStatus/TaskStatus.test.tsx +0 -299
  1061. package/src/components/workflow/TaskStatus/TaskStatus.tsx +0 -246
  1062. package/src/components/workflow/TaskStatus/TaskStatus.types.ts +0 -65
  1063. package/src/components/workflow/TaskStatus/TaskStatus.variants.ts +0 -145
  1064. package/src/components/workflow/TaskStatus/index.ts +0 -24
  1065. package/src/components/workflow/Wizard/README.md +0 -440
  1066. package/src/components/workflow/Wizard/Wizard.test.tsx +0 -432
  1067. package/src/components/workflow/Wizard/Wizard.tsx +0 -279
  1068. package/src/components/workflow/Wizard/Wizard.types.ts +0 -61
  1069. package/src/components/workflow/Wizard/Wizard.variants.ts +0 -105
  1070. package/src/components/workflow/Wizard/index.ts +0 -9
  1071. package/src/components/workflow/index.ts +0 -14
  1072. package/src/hooks/index.ts +0 -4
  1073. package/src/hooks/use-media-query.ts +0 -24
  1074. package/src/hooks/use-mobile.ts +0 -30
  1075. package/src/hooks/use-on-window-resize.ts +0 -27
  1076. package/src/index.ts +0 -22
  1077. package/src/lib/chart-colors.ts +0 -195
  1078. package/src/lib/utils.ts +0 -6
  1079. package/src/test/setup.ts +0 -125
  1080. package/src/test/vitest.d.ts +0 -13
@@ -1,1259 +0,0 @@
1
- # Command
2
-
3
- ## Visão Geral
4
-
5
- O **Command** é um componente avançado de menu de comandos e combobox acessível do Design System ETUS. Baseado na biblioteca [cmdk](https://cmdk.paco.me), fornece uma interface de busca rápida estilo ⌘K para navegação, execução de ações e seleção de itens. Como organismo, combina múltiplos elementos (input, lista, grupos, itens) em uma experiência de busca e navegação coesa.
6
-
7
- ### Casos de Uso
8
-
9
- - Command palettes (menus ⌘K/Ctrl+K)
10
- - Busca global em aplicações
11
- - Navegação rápida entre páginas/recursos
12
- - Seleção de ações com filtro automático
13
- - Comboboxes acessíveis com autocomplete
14
- - Lançadores de aplicações/shortcuts
15
-
16
- ### Classificação
17
-
18
- **Categoria:** Organism (Advanced)
19
- **Dependências:** `cmdk`, `@/components/feedback/Dialog`, `lucide-react`
20
-
21
- ---
22
-
23
- ## Design Specs
24
-
25
- ### Compound Components
26
-
27
- O Command é um sistema de compound components com as seguintes partes:
28
-
29
- | Componente | Descrição | data-slot |
30
- |------------|-----------|-----------|
31
- | `Command` | Container raiz do menu | `command` |
32
- | `CommandDialog` | Wrapper com Dialog modal | - |
33
- | `CommandInput` | Campo de busca com ícone | `command-input` |
34
- | `CommandList` | Container scrollável de itens | `command-list` |
35
- | `CommandEmpty` | Estado vazio quando sem resultados | `command-empty` |
36
- | `CommandGroup` | Agrupa itens com heading | `command-group` |
37
- | `CommandItem` | Item selecionável | `command-item` |
38
- | `CommandSeparator` | Linha divisória entre grupos | `command-separator` |
39
- | `CommandShortcut` | Exibe atalho de teclado | `command-shortcut` |
40
-
41
- ### Estados
42
-
43
- | Estado | Classes/Atributos | Comportamento |
44
- |--------|-------------------|---------------|
45
- | Default | - | Aparência base |
46
- | Selected | `data-selected="true"` | Background `bg-accent` no item |
47
- | Disabled | `data-disabled="true"` | 50% opacidade, sem pointer events |
48
- | Empty | - | Exibe `CommandEmpty` |
49
- | Loading | - | Exibe indicador de loading |
50
-
51
- ### Tokens Utilizados
52
-
53
- ```css
54
- /* Cores */
55
- --popover /* Fundo do Command */
56
- --popover-foreground /* Texto principal */
57
- --accent /* Background item selecionado */
58
- --accent-foreground /* Texto item selecionado */
59
- --muted-foreground /* Texto secundário, ícones, placeholders */
60
- --border /* Borda inferior do input */
61
-
62
- /* Espaçamento */
63
- px-2, px-3 /* Padding horizontal items/input */
64
- py-1.5, py-3, py-6 /* Padding vertical items/empty */
65
- gap-2 /* Entre ícone e texto */
66
-
67
- /* Tipografia */
68
- text-sm /* 14px - items e input */
69
- text-xs /* 12px - group headings, shortcuts */
70
- font-medium /* 500 - group headings */
71
-
72
- /* Bordas */
73
- rounded-md /* var(--radius) */
74
- rounded-sm /* Items */
75
-
76
- /* Dimensões */
77
- h-9, h-12 /* Altura do input wrapper */
78
- max-h-[300px] /* Altura máxima da lista */
79
- size-4, size-5 /* Tamanho dos ícones */
80
- ```
81
-
82
- ### data-slot
83
-
84
- ```html
85
- <div data-slot="command">
86
- <div data-slot="command-input-wrapper">
87
- <input data-slot="command-input" />
88
- </div>
89
- <div data-slot="command-list">
90
- <div data-slot="command-group">
91
- <div data-slot="command-item">
92
- <span data-slot="command-shortcut">⌘K</span>
93
- </div>
94
- </div>
95
- <div data-slot="command-separator" />
96
- <div data-slot="command-empty">No results.</div>
97
- </div>
98
- </div>
99
- ```
100
-
101
- ---
102
-
103
- ## API
104
-
105
- ### Command (Root)
106
-
107
- | Prop | Tipo | Padrão | Descrição |
108
- |------|------|--------|-----------|
109
- | `className` | `string` | - | Classes CSS adicionais |
110
- | `shouldFilter` | `boolean` | `true` | Habilita filtro automático |
111
- | `filter` | `(value: string, search: string) => number` | - | Função de filtro customizada |
112
- | `value` | `string` | - | Item selecionado (controlado) |
113
- | `onValueChange` | `(value: string) => void` | - | Callback de seleção |
114
- | `loop` | `boolean` | `false` | Navegação circular no teclado |
115
- | `children` | `ReactNode` | - | Conteúdo do command |
116
-
117
- > Herda todas as props de `React.ComponentProps<typeof CommandPrimitive>`
118
-
119
- ### CommandDialog
120
-
121
- | Prop | Tipo | Padrão | Descrição |
122
- |------|------|--------|-----------|
123
- | `open` | `boolean` | - | Estado de abertura (controlado) |
124
- | `onOpenChange` | `(open: boolean) => void` | - | Callback de abertura/fechamento |
125
- | `title` | `string` | `"Command Palette"` | Título acessível do dialog |
126
- | `description` | `string` | `"Search for a command..."` | Descrição acessível |
127
- | `showCloseButton` | `boolean` | `true` | Exibe botão de fechar |
128
- | `className` | `string` | - | Classes CSS adicionais |
129
- | `children` | `ReactNode` | - | Conteúdo do dialog |
130
-
131
- > Herda todas as props de `Dialog`
132
-
133
- ### CommandInput
134
-
135
- | Prop | Tipo | Padrão | Descrição |
136
- |------|------|--------|-----------|
137
- | `placeholder` | `string` | - | Placeholder do input |
138
- | `value` | `string` | - | Valor do input (controlado) |
139
- | `onValueChange` | `(value: string) => void` | - | Callback de digitação |
140
- | `className` | `string` | - | Classes CSS adicionais |
141
-
142
- > Herda todas as props de `React.ComponentProps<typeof CommandPrimitive.Input>`
143
-
144
- ### CommandList
145
-
146
- | Prop | Tipo | Padrão | Descrição |
147
- |------|------|--------|-----------|
148
- | `className` | `string` | - | Classes CSS adicionais |
149
- | `children` | `ReactNode` | - | Grupos e items |
150
-
151
- > Expõe CSS variable `--cmdk-list-height` para animação
152
-
153
- ### CommandEmpty
154
-
155
- | Prop | Tipo | Padrão | Descrição |
156
- |------|------|--------|-----------|
157
- | `children` | `ReactNode` | - | Mensagem de estado vazio |
158
-
159
- ### CommandGroup
160
-
161
- | Prop | Tipo | Padrão | Descrição |
162
- |------|------|--------|-----------|
163
- | `heading` | `string` | - | Título do grupo |
164
- | `className` | `string` | - | Classes CSS adicionais |
165
- | `children` | `ReactNode` | - | Items do grupo |
166
-
167
- ### CommandItem
168
-
169
- | Prop | Tipo | Padrão | Descrição |
170
- |------|------|--------|-----------|
171
- | `value` | `string` | - | Valor para filtro/seleção |
172
- | `keywords` | `string[]` | - | Palavras-chave adicionais para busca |
173
- | `disabled` | `boolean` | `false` | Desabilita o item |
174
- | `onSelect` | `(value: string) => void` | - | Callback de seleção |
175
- | `className` | `string` | - | Classes CSS adicionais |
176
- | `children` | `ReactNode` | - | Conteúdo do item |
177
-
178
- ### CommandShortcut
179
-
180
- | Prop | Tipo | Padrão | Descrição |
181
- |------|------|--------|-----------|
182
- | `children` | `ReactNode` | - | Texto do atalho (ex: `⌘K`) |
183
- | `className` | `string` | - | Classes CSS adicionais |
184
-
185
- ### CommandSeparator
186
-
187
- | Prop | Tipo | Padrão | Descrição |
188
- |------|------|--------|-----------|
189
- | `className` | `string` | - | Classes CSS adicionais |
190
-
191
- ### TypeScript
192
-
193
- ```typescript
194
- import type { ComponentProps } from "react"
195
- import type { Command as CommandPrimitive } from "cmdk"
196
- import type { Dialog } from "@/components/feedback/Dialog"
197
-
198
- // Props dos componentes
199
- type CommandProps = ComponentProps<typeof CommandPrimitive>
200
-
201
- type CommandDialogProps = ComponentProps<typeof Dialog> & {
202
- title?: string
203
- description?: string
204
- className?: string
205
- showCloseButton?: boolean
206
- }
207
-
208
- type CommandInputProps = ComponentProps<typeof CommandPrimitive.Input>
209
- type CommandListProps = ComponentProps<typeof CommandPrimitive.List>
210
- type CommandEmptyProps = ComponentProps<typeof CommandPrimitive.Empty>
211
- type CommandGroupProps = ComponentProps<typeof CommandPrimitive.Group>
212
- type CommandItemProps = ComponentProps<typeof CommandPrimitive.Item>
213
- type CommandSeparatorProps = ComponentProps<typeof CommandPrimitive.Separator>
214
- type CommandShortcutProps = ComponentProps<"span">
215
- ```
216
-
217
- ### Comparativo com Design Systems de Referência
218
-
219
- #### Matriz de Features (12 Design Systems)
220
-
221
- | Feature | ETUS | Shadcn | Mantine | MUI | Chakra | AntD | NextUI | Headless | Ariakit | Fluent | Carbon | Blueprint |
222
- |---------|:----:|:------:|:-------:|:---:|:------:|:----:|:------:|:--------:|:-------:|:------:|:------:|:---------:|
223
- | **Command Palette** | ✓ | ✓ | ✓ | - | - | - | - | ✓ | ✓ | ✓ | - | ✓ |
224
- | **Combobox Mode** | ✓ | ✓ | ✓ | ✓ | ✓ | ✓ | ✓ | ✓ | ✓ | ✓ | ✓ | ✓ |
225
- | **Auto Filter** | ✓ | ✓ | ✓ | ✓ | - | ✓ | ✓ | - | ✓ | ✓ | ✓ | ✓ |
226
- | **Groups** | ✓ | ✓ | ✓ | ✓ | - | ✓ | ✓ | - | ✓ | ✓ | ✓ | ✓ |
227
- | **Keyboard Nav** | ✓ | ✓ | ✓ | ✓ | ✓ | ✓ | ✓ | ✓ | ✓ | ✓ | ✓ | ✓ |
228
- | **Dialog Mode** | ✓ | ✓ | ✓ | - | - | - | - | ✓ | ✓ | ✓ | - | ✓ |
229
- | **Shortcuts Display** | ✓ | ✓ | ✓ | - | - | - | - | - | - | ✓ | - | ✓ |
230
- | **Loading State** | ~ | ~ | ✓ | ✓ | - | ✓ | ✓ | - | - | ✓ | ✓ | ✓ |
231
- | **Async Items** | ✓ | ✓ | ✓ | ✓ | - | ✓ | ✓ | - | ✓ | ✓ | ✓ | ✓ |
232
- | **Custom Filter** | ✓ | ✓ | ✓ | ✓ | - | ✓ | ✓ | - | ✓ | ✓ | ✓ | ✓ |
233
- | **Virtualization** | - | - | ✓ | ✓ | - | ✓ | ✓ | - | - | ✓ | ✓ | - |
234
- | **data-slot** | ✓ | ✓ | - | - | - | - | - | - | - | - | - | - |
235
-
236
- **Legenda:** ✓ = Suporte completo | ~ = Parcial/Manual | - = Não suportado
237
-
238
- #### Componentes Equivalentes por Design System
239
-
240
- | Design System | Componente | Notas |
241
- |---------------|------------|-------|
242
- | **ETUS** | `Command`, `CommandDialog` | Baseado em cmdk |
243
- | **Shadcn/ui** | `Command` | Baseado em cmdk |
244
- | **Mantine** | `Spotlight` | Modal de busca global |
245
- | **MUI** | `Autocomplete` | Combobox, sem command palette |
246
- | **Chakra UI** | `Menu` + custom | Requer composição manual |
247
- | **Ant Design** | `AutoComplete` | Combobox, sem command palette |
248
- | **NextUI** | `Autocomplete` | Combobox, sem command palette |
249
- | **Headless UI** | `Combobox` | Primitivo headless |
250
- | **Ariakit** | `Combobox` | Primitivo composable |
251
- | **Fluent UI** | `SearchBox` + `Menu` | Requer composição |
252
- | **Carbon** | `ComboBox` | Combobox, sem command palette |
253
- | **Blueprint** | `Omnibar` | Command palette completo |
254
-
255
- #### Comparativo de Props por Design System
256
-
257
- | Prop | ETUS | Shadcn | Mantine Spotlight | MUI Autocomplete | Ariakit |
258
- |------|:----:|:------:|:-----------------:|:----------------:|:-------:|
259
- | `shouldFilter` | ✓ | ✓ | `filter` | `filterOptions` | - |
260
- | `value` | ✓ | ✓ | `query` | `value` | `value` |
261
- | `onValueChange` | ✓ | ✓ | `onQueryChange` | `onChange` | `setValue` |
262
- | `loop` | ✓ | ✓ | - | - | `focusLoop` |
263
- | `onSelect` (item) | ✓ | ✓ | `onActionClick` | `onChange` | `onItemClick` |
264
- | `keywords` | ✓ | ✓ | `keywords` | - | - |
265
- | `disabled` | ✓ | ✓ | `disabled` | `disabled` | `disabled` |
266
-
267
- ---
268
-
269
- ## Acessibilidade (A11y)
270
-
271
- ### ARIA Attributes
272
-
273
- | Atributo | Elemento | Uso |
274
- |----------|----------|-----|
275
- | `role="combobox"` | Input | Identifica como combobox |
276
- | `role="listbox"` | List | Identifica lista de opções |
277
- | `role="option"` | Item | Identifica item selecionável |
278
- | `role="group"` | Group | Agrupa opções relacionadas |
279
- | `aria-expanded` | Input | Estado de expansão da lista |
280
- | `aria-activedescendant` | Input | Item atualmente focado |
281
- | `aria-selected` | Item | Item selecionado |
282
- | `aria-disabled` | Item | Item desabilitado |
283
- | `aria-label` | Dialog | Título acessível do modal |
284
- | `aria-describedby` | Dialog | Descrição do modal |
285
-
286
- ### Suporte a Teclado
287
-
288
- | Tecla | Ação |
289
- |-------|------|
290
- | `↓` / `↑` | Navega entre items |
291
- | `Enter` | Seleciona item focado |
292
- | `Escape` | Fecha dialog / limpa busca |
293
- | `Home` | Vai para primeiro item |
294
- | `End` | Vai para último item |
295
- | `Tab` | Move foco (comportamento padrão) |
296
-
297
- ### Focus Management
298
-
299
- ```tsx
300
- // Focus automático no input ao abrir
301
- <CommandDialog>
302
- <CommandInput /> // Auto-focus
303
-
304
- // Focus visible nos items
305
- [&_[cmdk-item]]:focus-visible:ring-2
306
- ```
307
-
308
- ### Contraste de Cores
309
-
310
- Todos os pares de cores seguem WCAG 2.1 AA (mínimo 4.5:1):
311
-
312
- | Elemento | Foreground | Background | Ratio |
313
- |----------|------------|------------|-------|
314
- | Input text | `--popover-foreground` | `--popover` | ≥ 4.5:1 |
315
- | Item default | `--foreground` | `--popover` | ≥ 4.5:1 |
316
- | Item selected | `--accent-foreground` | `--accent` | ≥ 4.5:1 |
317
- | Placeholder | `--muted-foreground` | `--popover` | ≥ 4.5:1 |
318
-
319
- ### Screen Readers
320
-
321
- - `CommandDialog` usa Dialog acessível com título/descrição sr-only
322
- - Items anunciam label e estado (selecionado, desabilitado)
323
- - Grupos anunciam heading antes dos items
324
- - Estado vazio é anunciado automaticamente
325
-
326
- ### Reduced Motion
327
-
328
- ```tsx
329
- // Respeitar preferência do usuário
330
- motion-reduce:transition-none
331
- ```
332
-
333
- ### Comparativo A11y (12 Design Systems)
334
-
335
- | Feature | ETUS | React Aria | Radix | Ariakit | Headless | Mantine | MUI | Fluent | Carbon |
336
- |---------|:----:|:----------:|:-----:|:-------:|:--------:|:-------:|:---:|:------:|:------:|
337
- | **ARIA combobox** | ✓ | ✓ | - | ✓ | ✓ | ✓ | ✓ | ✓ | ✓ |
338
- | **Keyboard nav** | ✓ | ✓ | - | ✓ | ✓ | ✓ | ✓ | ✓ | ✓ |
339
- | **Focus management** | ✓ | ✓ | - | ✓ | ✓ | ✓ | ✓ | ✓ | ✓ |
340
- | **aria-activedescendant** | ✓ | ✓ | - | ✓ | ✓ | ✓ | ✓ | ✓ | ✓ |
341
- | **Group labels** | ✓ | ✓ | - | ✓ | ✓ | ✓ | ✓ | ✓ | ✓ |
342
- | **Screen reader tested** | ~ | ✓ | - | ✓ | ✓ | ~ | ✓ | ✓ | ✓ |
343
- | **Reduced motion** | ~ | ✓ | - | - | - | ✓ | ✓ | ✓ | ✓ |
344
- | **High contrast** | - | ✓ | - | - | - | - | - | ✓ | ✓ |
345
-
346
- **Legenda:** ✓ = Suporte completo | ~ = Parcial/Manual | - = Não suportado
347
-
348
- ---
349
-
350
- ## Exemplos
351
-
352
- ### Uso Básico
353
-
354
- ```tsx
355
- import {
356
- Command,
357
- CommandEmpty,
358
- CommandGroup,
359
- CommandInput,
360
- CommandItem,
361
- CommandList,
362
- } from "@etus/ui"
363
-
364
- function Example() {
365
- return (
366
- <Command className="rounded-lg border shadow-md">
367
- <CommandInput placeholder="Buscar..." />
368
- <CommandList>
369
- <CommandEmpty>Nenhum resultado encontrado.</CommandEmpty>
370
- <CommandGroup heading="Sugestões">
371
- <CommandItem>Calendário</CommandItem>
372
- <CommandItem>Configurações</CommandItem>
373
- <CommandItem>Perfil</CommandItem>
374
- </CommandGroup>
375
- </CommandList>
376
- </Command>
377
- )
378
- }
379
- ```
380
-
381
- ### Command Dialog (⌘K Menu)
382
-
383
- ```tsx
384
- import { useEffect, useState } from "react"
385
- import {
386
- CommandDialog,
387
- CommandEmpty,
388
- CommandGroup,
389
- CommandInput,
390
- CommandItem,
391
- CommandList,
392
- CommandShortcut,
393
- } from "@etus/ui"
394
- import { Calculator, Calendar, CreditCard, Settings, User } from "lucide-react"
395
-
396
- function CommandMenu() {
397
- const [open, setOpen] = useState(false)
398
-
399
- useEffect(() => {
400
- const down = (e: KeyboardEvent) => {
401
- if (e.key === "k" && (e.metaKey || e.ctrlKey)) {
402
- e.preventDefault()
403
- setOpen((open) => !open)
404
- }
405
- }
406
-
407
- document.addEventListener("keydown", down)
408
- return () => document.removeEventListener("keydown", down)
409
- }, [])
410
-
411
- return (
412
- <CommandDialog open={open} onOpenChange={setOpen}>
413
- <CommandInput placeholder="Digite um comando ou busque..." />
414
- <CommandList>
415
- <CommandEmpty>Nenhum resultado encontrado.</CommandEmpty>
416
- <CommandGroup heading="Sugestões">
417
- <CommandItem onSelect={() => setOpen(false)}>
418
- <Calendar className="mr-2 h-4 w-4" />
419
- <span>Calendário</span>
420
- </CommandItem>
421
- <CommandItem onSelect={() => setOpen(false)}>
422
- <User className="mr-2 h-4 w-4" />
423
- <span>Perfil</span>
424
- <CommandShortcut>⌘P</CommandShortcut>
425
- </CommandItem>
426
- <CommandItem onSelect={() => setOpen(false)}>
427
- <Settings className="mr-2 h-4 w-4" />
428
- <span>Configurações</span>
429
- <CommandShortcut>⌘S</CommandShortcut>
430
- </CommandItem>
431
- </CommandGroup>
432
- <CommandGroup heading="Ferramentas">
433
- <CommandItem>
434
- <Calculator className="mr-2 h-4 w-4" />
435
- <span>Calculadora</span>
436
- </CommandItem>
437
- <CommandItem>
438
- <CreditCard className="mr-2 h-4 w-4" />
439
- <span>Pagamentos</span>
440
- </CommandItem>
441
- </CommandGroup>
442
- </CommandList>
443
- </CommandDialog>
444
- )
445
- }
446
- ```
447
-
448
- ### Com Ícones e Shortcuts
449
-
450
- ```tsx
451
- import { File, FileText, Image, Music, Video } from "lucide-react"
452
-
453
- <Command>
454
- <CommandInput placeholder="Buscar arquivos..." />
455
- <CommandList>
456
- <CommandGroup heading="Arquivos Recentes">
457
- <CommandItem>
458
- <FileText className="mr-2 h-4 w-4" />
459
- <span>Documento.pdf</span>
460
- <CommandShortcut>⌘1</CommandShortcut>
461
- </CommandItem>
462
- <CommandItem>
463
- <Image className="mr-2 h-4 w-4" />
464
- <span>Foto.jpg</span>
465
- <CommandShortcut>⌘2</CommandShortcut>
466
- </CommandItem>
467
- <CommandItem>
468
- <Video className="mr-2 h-4 w-4" />
469
- <span>Video.mp4</span>
470
- <CommandShortcut>⌘3</CommandShortcut>
471
- </CommandItem>
472
- <CommandItem>
473
- <Music className="mr-2 h-4 w-4" />
474
- <span>Audio.mp3</span>
475
- <CommandShortcut>⌘4</CommandShortcut>
476
- </CommandItem>
477
- </CommandGroup>
478
- </CommandList>
479
- </Command>
480
- ```
481
-
482
- ### Com Grupos e Separadores
483
-
484
- ```tsx
485
- import { CommandSeparator } from "@etus/ui"
486
- import { Home, LogOut, Settings, User } from "lucide-react"
487
-
488
- <Command>
489
- <CommandInput placeholder="Buscar..." />
490
- <CommandList>
491
- <CommandGroup heading="Navegação">
492
- <CommandItem>
493
- <Home className="mr-2 h-4 w-4" />
494
- <span>Início</span>
495
- </CommandItem>
496
- <CommandItem>
497
- <User className="mr-2 h-4 w-4" />
498
- <span>Perfil</span>
499
- </CommandItem>
500
- </CommandGroup>
501
- <CommandSeparator />
502
- <CommandGroup heading="Configurações">
503
- <CommandItem>
504
- <Settings className="mr-2 h-4 w-4" />
505
- <span>Preferências</span>
506
- </CommandItem>
507
- </CommandGroup>
508
- <CommandSeparator />
509
- <CommandItem>
510
- <LogOut className="mr-2 h-4 w-4" />
511
- <span>Sair</span>
512
- </CommandItem>
513
- </CommandList>
514
- </Command>
515
- ```
516
-
517
- ### Items Desabilitados
518
-
519
- ```tsx
520
- <Command>
521
- <CommandInput placeholder="Buscar ações..." />
522
- <CommandList>
523
- <CommandGroup heading="Ações">
524
- <CommandItem>
525
- <span>Salvar</span>
526
- <CommandShortcut>⌘S</CommandShortcut>
527
- </CommandItem>
528
- <CommandItem disabled>
529
- <span>Excluir</span>
530
- <CommandShortcut>⌘D</CommandShortcut>
531
- </CommandItem>
532
- <CommandItem>
533
- <span>Exportar</span>
534
- <CommandShortcut>⌘E</CommandShortcut>
535
- </CommandItem>
536
- </CommandGroup>
537
- </CommandList>
538
- </Command>
539
- ```
540
-
541
- ### Com Filtro Customizado
542
-
543
- ```tsx
544
- <Command
545
- shouldFilter={false}
546
- filter={(value, search) => {
547
- // Filtro customizado: apenas matches exatos
548
- if (value.toLowerCase() === search.toLowerCase()) return 1
549
- if (value.toLowerCase().includes(search.toLowerCase())) return 0.5
550
- return 0
551
- }}
552
- >
553
- <CommandInput placeholder="Busca exata..." />
554
- <CommandList>
555
- <CommandGroup>
556
- <CommandItem value="react">React</CommandItem>
557
- <CommandItem value="react-dom">React DOM</CommandItem>
558
- <CommandItem value="react-native">React Native</CommandItem>
559
- </CommandGroup>
560
- </CommandList>
561
- </Command>
562
- ```
563
-
564
- ### Com Keywords para Busca
565
-
566
- ```tsx
567
- <Command>
568
- <CommandInput placeholder="Buscar configurações..." />
569
- <CommandList>
570
- <CommandGroup heading="Configurações">
571
- <CommandItem keywords={["dark", "light", "appearance"]}>
572
- <span>Tema</span>
573
- </CommandItem>
574
- <CommandItem keywords={["language", "locale", "i18n"]}>
575
- <span>Idioma</span>
576
- </CommandItem>
577
- <CommandItem keywords={["password", "security", "2fa"]}>
578
- <span>Segurança</span>
579
- </CommandItem>
580
- </CommandGroup>
581
- </CommandList>
582
- </Command>
583
- ```
584
-
585
- ### Com Loading Assíncrono
586
-
587
- ```tsx
588
- import { useEffect, useState } from "react"
589
- import { Loader2 } from "lucide-react"
590
-
591
- function AsyncCommand() {
592
- const [loading, setLoading] = useState(false)
593
- const [items, setItems] = useState<string[]>([])
594
- const [search, setSearch] = useState("")
595
-
596
- useEffect(() => {
597
- if (!search) {
598
- setItems([])
599
- return
600
- }
601
-
602
- setLoading(true)
603
- const timeout = setTimeout(async () => {
604
- // Simula API call
605
- const results = await fetchResults(search)
606
- setItems(results)
607
- setLoading(false)
608
- }, 300)
609
-
610
- return () => clearTimeout(timeout)
611
- }, [search])
612
-
613
- return (
614
- <Command shouldFilter={false}>
615
- <CommandInput
616
- placeholder="Buscar usuários..."
617
- value={search}
618
- onValueChange={setSearch}
619
- />
620
- <CommandList>
621
- {loading ? (
622
- <div className="flex items-center justify-center py-6">
623
- <Loader2 className="h-6 w-6 animate-spin" />
624
- </div>
625
- ) : items.length === 0 && search ? (
626
- <CommandEmpty>Nenhum usuário encontrado.</CommandEmpty>
627
- ) : (
628
- <CommandGroup heading="Usuários">
629
- {items.map((item) => (
630
- <CommandItem key={item} value={item}>
631
- {item}
632
- </CommandItem>
633
- ))}
634
- </CommandGroup>
635
- )}
636
- </CommandList>
637
- </Command>
638
- )
639
- }
640
- ```
641
-
642
- ### Navegação com Router
643
-
644
- ```tsx
645
- import { useNavigate } from "@tanstack/react-router"
646
- import { File, Home, Settings, User } from "lucide-react"
647
-
648
- function NavigationCommand() {
649
- const [open, setOpen] = useState(false)
650
- const navigate = useNavigate()
651
-
652
- const handleSelect = (path: string) => {
653
- navigate({ to: path })
654
- setOpen(false)
655
- }
656
-
657
- return (
658
- <CommandDialog open={open} onOpenChange={setOpen}>
659
- <CommandInput placeholder="Ir para..." />
660
- <CommandList>
661
- <CommandGroup heading="Páginas">
662
- <CommandItem onSelect={() => handleSelect("/")}>
663
- <Home className="mr-2 h-4 w-4" />
664
- Início
665
- </CommandItem>
666
- <CommandItem onSelect={() => handleSelect("/profile")}>
667
- <User className="mr-2 h-4 w-4" />
668
- Perfil
669
- </CommandItem>
670
- <CommandItem onSelect={() => handleSelect("/settings")}>
671
- <Settings className="mr-2 h-4 w-4" />
672
- Configurações
673
- </CommandItem>
674
- <CommandItem onSelect={() => handleSelect("/documents")}>
675
- <File className="mr-2 h-4 w-4" />
676
- Documentos
677
- </CommandItem>
678
- </CommandGroup>
679
- </CommandList>
680
- </CommandDialog>
681
- )
682
- }
683
- ```
684
-
685
- ### Dentro de Popover (Combobox)
686
-
687
- ```tsx
688
- import { Popover, PopoverContent, PopoverTrigger } from "@etus/ui"
689
- import { Button } from "@etus/ui"
690
- import { ChevronsUpDown } from "lucide-react"
691
-
692
- function ComboboxExample() {
693
- const [open, setOpen] = useState(false)
694
- const [value, setValue] = useState("")
695
-
696
- const frameworks = [
697
- { value: "next", label: "Next.js" },
698
- { value: "remix", label: "Remix" },
699
- { value: "astro", label: "Astro" },
700
- { value: "nuxt", label: "Nuxt" },
701
- ]
702
-
703
- return (
704
- <Popover open={open} onOpenChange={setOpen}>
705
- <PopoverTrigger asChild>
706
- <Button variant="outline" className="w-[200px] justify-between">
707
- {value
708
- ? frameworks.find((f) => f.value === value)?.label
709
- : "Selecione..."}
710
- <ChevronsUpDown className="ml-2 h-4 w-4 opacity-50" />
711
- </Button>
712
- </PopoverTrigger>
713
- <PopoverContent className="w-[200px] p-0">
714
- <Command>
715
- <CommandInput placeholder="Buscar framework..." />
716
- <CommandList>
717
- <CommandEmpty>Nenhum framework encontrado.</CommandEmpty>
718
- <CommandGroup>
719
- {frameworks.map((framework) => (
720
- <CommandItem
721
- key={framework.value}
722
- value={framework.value}
723
- onSelect={(currentValue) => {
724
- setValue(currentValue === value ? "" : currentValue)
725
- setOpen(false)
726
- }}
727
- >
728
- {framework.label}
729
- </CommandItem>
730
- ))}
731
- </CommandGroup>
732
- </CommandList>
733
- </Command>
734
- </PopoverContent>
735
- </Popover>
736
- )
737
- }
738
- ```
739
-
740
- ---
741
-
742
- ## Testes
743
-
744
- ### Testes Unitários
745
-
746
- ```tsx
747
- // Command.test.tsx
748
- import { render, screen } from "@testing-library/react"
749
- import userEvent from "@testing-library/user-event"
750
- import { describe, expect, it, vi } from "vitest"
751
- import {
752
- Command,
753
- CommandEmpty,
754
- CommandGroup,
755
- CommandInput,
756
- CommandItem,
757
- CommandList,
758
- } from "./Command"
759
-
760
- describe("Command", () => {
761
- it("renders input and items correctly", () => {
762
- render(
763
- <Command>
764
- <CommandInput placeholder="Search..." />
765
- <CommandList>
766
- <CommandGroup>
767
- <CommandItem>Item 1</CommandItem>
768
- <CommandItem>Item 2</CommandItem>
769
- </CommandGroup>
770
- </CommandList>
771
- </Command>
772
- )
773
-
774
- expect(screen.getByPlaceholderText("Search...")).toBeInTheDocument()
775
- expect(screen.getByText("Item 1")).toBeInTheDocument()
776
- expect(screen.getByText("Item 2")).toBeInTheDocument()
777
- })
778
-
779
- it("has data-slot attribute on root", () => {
780
- render(
781
- <Command data-testid="command">
782
- <CommandInput />
783
- <CommandList />
784
- </Command>
785
- )
786
-
787
- expect(screen.getByTestId("command")).toHaveAttribute("data-slot", "command")
788
- })
789
-
790
- it("filters items based on search input", async () => {
791
- const user = userEvent.setup()
792
-
793
- render(
794
- <Command>
795
- <CommandInput placeholder="Search..." />
796
- <CommandList>
797
- <CommandGroup>
798
- <CommandItem value="apple">Apple</CommandItem>
799
- <CommandItem value="banana">Banana</CommandItem>
800
- <CommandItem value="cherry">Cherry</CommandItem>
801
- </CommandGroup>
802
- </CommandList>
803
- </Command>
804
- )
805
-
806
- const input = screen.getByPlaceholderText("Search...")
807
- await user.type(input, "ban")
808
-
809
- expect(screen.getByText("Banana")).toBeVisible()
810
- expect(screen.queryByText("Apple")).not.toBeVisible()
811
- expect(screen.queryByText("Cherry")).not.toBeVisible()
812
- })
813
-
814
- it("shows empty state when no results", async () => {
815
- const user = userEvent.setup()
816
-
817
- render(
818
- <Command>
819
- <CommandInput placeholder="Search..." />
820
- <CommandList>
821
- <CommandEmpty>No results found.</CommandEmpty>
822
- <CommandGroup>
823
- <CommandItem value="apple">Apple</CommandItem>
824
- </CommandGroup>
825
- </CommandList>
826
- </Command>
827
- )
828
-
829
- const input = screen.getByPlaceholderText("Search...")
830
- await user.type(input, "xyz")
831
-
832
- expect(screen.getByText("No results found.")).toBeVisible()
833
- })
834
- })
835
- ```
836
-
837
- ### Testes de Interação
838
-
839
- ```tsx
840
- describe("Command interactions", () => {
841
- it("calls onSelect when item is clicked", async () => {
842
- const user = userEvent.setup()
843
- const handleSelect = vi.fn()
844
-
845
- render(
846
- <Command>
847
- <CommandInput />
848
- <CommandList>
849
- <CommandGroup>
850
- <CommandItem value="test" onSelect={handleSelect}>
851
- Test Item
852
- </CommandItem>
853
- </CommandGroup>
854
- </CommandList>
855
- </Command>
856
- )
857
-
858
- await user.click(screen.getByText("Test Item"))
859
- expect(handleSelect).toHaveBeenCalledWith("test")
860
- })
861
-
862
- it("navigates with arrow keys", async () => {
863
- const user = userEvent.setup()
864
-
865
- render(
866
- <Command>
867
- <CommandInput placeholder="Search..." />
868
- <CommandList>
869
- <CommandGroup>
870
- <CommandItem value="first">First</CommandItem>
871
- <CommandItem value="second">Second</CommandItem>
872
- <CommandItem value="third">Third</CommandItem>
873
- </CommandGroup>
874
- </CommandList>
875
- </Command>
876
- )
877
-
878
- const input = screen.getByPlaceholderText("Search...")
879
- await user.click(input)
880
- await user.keyboard("{ArrowDown}")
881
- await user.keyboard("{ArrowDown}")
882
-
883
- const secondItem = screen.getByText("Second").closest("[cmdk-item]")
884
- expect(secondItem).toHaveAttribute("data-selected", "true")
885
- })
886
-
887
- it("selects item with Enter key", async () => {
888
- const user = userEvent.setup()
889
- const handleSelect = vi.fn()
890
-
891
- render(
892
- <Command>
893
- <CommandInput placeholder="Search..." />
894
- <CommandList>
895
- <CommandGroup>
896
- <CommandItem value="test" onSelect={handleSelect}>
897
- Test
898
- </CommandItem>
899
- </CommandGroup>
900
- </CommandList>
901
- </Command>
902
- )
903
-
904
- const input = screen.getByPlaceholderText("Search...")
905
- await user.click(input)
906
- await user.keyboard("{ArrowDown}")
907
- await user.keyboard("{Enter}")
908
-
909
- expect(handleSelect).toHaveBeenCalledWith("test")
910
- })
911
-
912
- it("does not call onSelect for disabled items", async () => {
913
- const user = userEvent.setup()
914
- const handleSelect = vi.fn()
915
-
916
- render(
917
- <Command>
918
- <CommandInput />
919
- <CommandList>
920
- <CommandGroup>
921
- <CommandItem value="test" disabled onSelect={handleSelect}>
922
- Disabled Item
923
- </CommandItem>
924
- </CommandGroup>
925
- </CommandList>
926
- </Command>
927
- )
928
-
929
- await user.click(screen.getByText("Disabled Item"))
930
- expect(handleSelect).not.toHaveBeenCalled()
931
- })
932
- })
933
- ```
934
-
935
- ### Testes de Acessibilidade
936
-
937
- ```tsx
938
- import { axe, toHaveNoViolations } from "jest-axe"
939
-
940
- expect.extend(toHaveNoViolations)
941
-
942
- describe("Command accessibility", () => {
943
- it("has no accessibility violations", async () => {
944
- const { container } = render(
945
- <Command>
946
- <CommandInput placeholder="Search..." />
947
- <CommandList>
948
- <CommandGroup heading="Options">
949
- <CommandItem>Option 1</CommandItem>
950
- <CommandItem>Option 2</CommandItem>
951
- </CommandGroup>
952
- </CommandList>
953
- </Command>
954
- )
955
-
956
- const results = await axe(container)
957
- expect(results).toHaveNoViolations()
958
- })
959
-
960
- it("input has combobox role", () => {
961
- render(
962
- <Command>
963
- <CommandInput placeholder="Search..." />
964
- <CommandList />
965
- </Command>
966
- )
967
-
968
- expect(screen.getByRole("combobox")).toBeInTheDocument()
969
- })
970
-
971
- it("list has listbox role", () => {
972
- render(
973
- <Command>
974
- <CommandInput />
975
- <CommandList data-testid="list">
976
- <CommandGroup>
977
- <CommandItem>Item</CommandItem>
978
- </CommandGroup>
979
- </CommandList>
980
- </Command>
981
- )
982
-
983
- expect(screen.getByRole("listbox")).toBeInTheDocument()
984
- })
985
-
986
- it("items have option role", () => {
987
- render(
988
- <Command>
989
- <CommandInput />
990
- <CommandList>
991
- <CommandGroup>
992
- <CommandItem>Item</CommandItem>
993
- </CommandGroup>
994
- </CommandList>
995
- </Command>
996
- )
997
-
998
- expect(screen.getByRole("option")).toBeInTheDocument()
999
- })
1000
-
1001
- it("is keyboard navigable", async () => {
1002
- const user = userEvent.setup()
1003
-
1004
- render(
1005
- <Command>
1006
- <CommandInput placeholder="Search..." />
1007
- <CommandList>
1008
- <CommandGroup>
1009
- <CommandItem>Item 1</CommandItem>
1010
- <CommandItem>Item 2</CommandItem>
1011
- </CommandGroup>
1012
- </CommandList>
1013
- </Command>
1014
- )
1015
-
1016
- const input = screen.getByPlaceholderText("Search...")
1017
- input.focus()
1018
- expect(input).toHaveFocus()
1019
-
1020
- await user.keyboard("{ArrowDown}")
1021
- // First item should be selected
1022
- expect(screen.getByText("Item 1").closest("[cmdk-item]")).toHaveAttribute(
1023
- "data-selected",
1024
- "true"
1025
- )
1026
- })
1027
- })
1028
- ```
1029
-
1030
- ### Testes de Composição (Dialog)
1031
-
1032
- ```tsx
1033
- describe("CommandDialog", () => {
1034
- it("opens and closes correctly", async () => {
1035
- const user = userEvent.setup()
1036
- const handleOpenChange = vi.fn()
1037
-
1038
- render(
1039
- <CommandDialog open={true} onOpenChange={handleOpenChange}>
1040
- <CommandInput placeholder="Search..." />
1041
- <CommandList>
1042
- <CommandGroup>
1043
- <CommandItem>Item</CommandItem>
1044
- </CommandGroup>
1045
- </CommandList>
1046
- </CommandDialog>
1047
- )
1048
-
1049
- expect(screen.getByPlaceholderText("Search...")).toBeInTheDocument()
1050
-
1051
- await user.keyboard("{Escape}")
1052
- expect(handleOpenChange).toHaveBeenCalledWith(false)
1053
- })
1054
-
1055
- it("auto-focuses input when opened", () => {
1056
- render(
1057
- <CommandDialog open={true} onOpenChange={() => {}}>
1058
- <CommandInput placeholder="Search..." />
1059
- <CommandList />
1060
- </CommandDialog>
1061
- )
1062
-
1063
- expect(screen.getByPlaceholderText("Search...")).toHaveFocus()
1064
- })
1065
-
1066
- it("has accessible title and description", () => {
1067
- render(
1068
- <CommandDialog
1069
- open={true}
1070
- onOpenChange={() => {}}
1071
- title="Command Menu"
1072
- description="Search for commands"
1073
- >
1074
- <CommandInput />
1075
- <CommandList />
1076
- </CommandDialog>
1077
- )
1078
-
1079
- expect(screen.getByText("Command Menu")).toBeInTheDocument()
1080
- expect(screen.getByText("Search for commands")).toBeInTheDocument()
1081
- })
1082
- })
1083
- ```
1084
-
1085
- ---
1086
-
1087
- ## Roadmap / Features Futuras
1088
-
1089
- Baseado na análise comparativa com 14 design systems, as seguintes features são candidatas para implementação futura:
1090
-
1091
- ### Prioridade Alta
1092
-
1093
- #### Virtualização para Listas Grandes
1094
-
1095
- Suporte a listas com milhares de items sem perda de performance.
1096
-
1097
- ```tsx
1098
- // Proposta de API
1099
- interface CommandListProps {
1100
- virtualized?: boolean
1101
- itemHeight?: number
1102
- overscan?: number
1103
- }
1104
-
1105
- // Uso
1106
- <CommandList virtualized itemHeight={40}>
1107
- {/* 10,000+ items */}
1108
- </CommandList>
1109
- ```
1110
-
1111
- **Referências:** Mantine (`virtualizedItems`), MUI (`ListboxComponent`), AntD (`virtual`)
1112
-
1113
- #### Loading State Nativo
1114
-
1115
- Estado de carregamento com componente dedicado.
1116
-
1117
- ```tsx
1118
- // Proposta de API (já suportado pelo cmdk)
1119
- import { Command } from "cmdk"
1120
-
1121
- <Command.Loading>
1122
- <Spinner /> Loading...
1123
- </Command.Loading>
1124
-
1125
- // Wrapper ETUS
1126
- <CommandLoading>Carregando...</CommandLoading>
1127
- ```
1128
-
1129
- **Referências:** cmdk (`Command.Loading`), Mantine (`loading`), MUI (`loading`)
1130
-
1131
- ### Prioridade Média
1132
-
1133
- #### Highlight de Match
1134
-
1135
- Destaque visual do texto que matcheia a busca.
1136
-
1137
- ```tsx
1138
- // Proposta de API
1139
- interface CommandItemProps {
1140
- highlightMatch?: boolean
1141
- highlightClassName?: string
1142
- }
1143
-
1144
- // Uso
1145
- <CommandItem highlightMatch>
1146
- React Native {/* "nat" seria destacado */}
1147
- </CommandItem>
1148
- ```
1149
-
1150
- **Referências:** Blueprint Omnibar, Algolia InstantSearch
1151
-
1152
- #### Footer com Ações
1153
-
1154
- Área fixa no rodapé para ações ou dicas de atalho.
1155
-
1156
- ```tsx
1157
- // Proposta de API
1158
- <Command>
1159
- <CommandInput />
1160
- <CommandList />
1161
- <CommandFooter>
1162
- <span>↑↓ para navegar</span>
1163
- <span>↵ para selecionar</span>
1164
- <span>esc para fechar</span>
1165
- </CommandFooter>
1166
- </Command>
1167
- ```
1168
-
1169
- **Referências:** Spotlight (Mantine), Linear, Vercel
1170
-
1171
- ### Prioridade Baixa
1172
-
1173
- #### Recent Items
1174
-
1175
- Seção de items recentes com persistência.
1176
-
1177
- ```tsx
1178
- // Proposta de API
1179
- <Command>
1180
- <CommandInput />
1181
- <CommandList>
1182
- <CommandRecents max={5} />
1183
- <CommandGroup heading="Todos">
1184
- {/* items */}
1185
- </CommandGroup>
1186
- </CommandList>
1187
- </Command>
1188
- ```
1189
-
1190
- **Referências:** Spotlight (Mantine), Raycast
1191
-
1192
- #### Multiple Selection
1193
-
1194
- Seleção múltipla de items.
1195
-
1196
- ```tsx
1197
- // Proposta de API
1198
- interface CommandProps {
1199
- multiple?: boolean
1200
- value?: string[]
1201
- onValueChange?: (value: string[]) => void
1202
- }
1203
-
1204
- // Uso
1205
- <Command multiple value={selected} onValueChange={setSelected}>
1206
- <CommandItem value="a">
1207
- <Checkbox checked={selected.includes("a")} />
1208
- Item A
1209
- </CommandItem>
1210
- </Command>
1211
- ```
1212
-
1213
- **Referências:** MUI Autocomplete (`multiple`), Mantine MultiSelect
1214
-
1215
- ### Decisões de Design
1216
-
1217
- | Feature | Recomendação | Justificativa |
1218
- |---------|--------------|---------------|
1219
- | `virtualized` | ✅ Implementar | Performance crítica para listas grandes |
1220
- | `CommandLoading` | ✅ Implementar | Já suportado pelo cmdk, apenas wrapper |
1221
- | `highlightMatch` | ⚠️ Avaliar | Útil mas complexo de implementar |
1222
- | `CommandFooter` | ⚠️ Avaliar | Bom UX, pode ser feito via composição |
1223
- | `CommandRecents` | ❌ Evitar | Muito específico, melhor via composição |
1224
- | `multiple` | ❌ Evitar | Muda natureza do componente, usar MultiSelect |
1225
-
1226
- ---
1227
-
1228
- ## Referências
1229
-
1230
- ### Design Systems Analisados
1231
-
1232
- | Design System | Documentação | GitHub |
1233
- |---------------|--------------|--------|
1234
- | **Shadcn/ui** | [Command](https://ui.shadcn.com/docs/components/command) | [shadcn-ui/ui](https://github.com/shadcn-ui/ui) |
1235
- | **cmdk** | [Documentation](https://cmdk.paco.me) | [pacocoursey/cmdk](https://github.com/pacocoursey/cmdk) |
1236
- | **Mantine** | [Spotlight](https://mantine.dev/x/spotlight/) | [mantinedev/mantine](https://github.com/mantinedev/mantine) |
1237
- | **MUI** | [Autocomplete](https://mui.com/material-ui/react-autocomplete/) | [mui/material-ui](https://github.com/mui/material-ui) |
1238
- | **Chakra UI** | [Menu](https://chakra-ui.com/docs/components/menu) | [chakra-ui/chakra-ui](https://github.com/chakra-ui/chakra-ui) |
1239
- | **Ant Design** | [AutoComplete](https://ant.design/components/auto-complete) | [ant-design/ant-design](https://github.com/ant-design/ant-design) |
1240
- | **NextUI** | [Autocomplete](https://nextui.org/docs/components/autocomplete) | [nextui-org/nextui](https://github.com/nextui-org/nextui) |
1241
- | **Headless UI** | [Combobox](https://headlessui.com/react/combobox) | [tailwindlabs/headlessui](https://github.com/tailwindlabs/headlessui) |
1242
- | **Ariakit** | [Combobox](https://ariakit.org/components/combobox) | [ariakit/ariakit](https://github.com/ariakit/ariakit) |
1243
- | **Fluent UI** | [SearchBox](https://react.fluentui.dev/?path=/docs/components-searchbox--default) | [microsoft/fluentui](https://github.com/microsoft/fluentui) |
1244
- | **Carbon** | [ComboBox](https://carbondesignsystem.com/components/combo-box/usage/) | [carbon-design-system/carbon](https://github.com/carbon-design-system/carbon) |
1245
- | **Blueprint** | [Omnibar](https://blueprintjs.com/docs/#select/omnibar) | [palantir/blueprint](https://github.com/palantir/blueprint) |
1246
-
1247
- ### Especificações e Padrões
1248
-
1249
- - [WAI-ARIA APG - Combobox Pattern](https://www.w3.org/WAI/ARIA/apg/patterns/combobox/)
1250
- - [WAI-ARIA APG - Listbox Pattern](https://www.w3.org/WAI/ARIA/apg/patterns/listbox/)
1251
- - [WCAG 2.1 Success Criteria](https://www.w3.org/WAI/WCAG21/quickref/)
1252
- - [MDN - ARIA: combobox role](https://developer.mozilla.org/en-US/docs/Web/Accessibility/ARIA/Roles/combobox_role)
1253
-
1254
- ### Ferramentas Utilizadas
1255
-
1256
- - [cmdk](https://cmdk.paco.me) - Command menu primitivo
1257
- - [Tailwind CSS](https://tailwindcss.com/docs)
1258
- - [Radix Dialog](https://www.radix-ui.com/primitives/docs/components/dialog)
1259
- - [Lucide Icons](https://lucide.dev/icons/)