@etus/ui 0.1.1 → 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 -4305
  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 -154
  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,1286 +0,0 @@
1
- # Select
2
-
3
- ## Visão Geral
4
-
5
- O **Select** e um componente compound de selecao do Design System ETUS, usado para apresentar uma lista de opcoes ao usuario em um dropdown. Baseado no Radix UI Select, oferece acessibilidade completa, navegacao por teclado e suporte a grupos de opcoes.
6
-
7
- ### Casos de Uso
8
-
9
- - Selecao de uma opcao entre varias alternativas
10
- - Formularios com campos de escolha unica
11
- - Filtros e configuracoes
12
- - Selecao de pais, estado, categoria, etc.
13
- - Menus de navegacao com opcoes predefinidas
14
-
15
- ### Classificacao
16
-
17
- **Categoria:** Organism (Compound Component)
18
- **Dependencias:** `@radix-ui/react-select`, `lucide-react`
19
-
20
- ---
21
-
22
- ## Design Specs
23
-
24
- ### Partes do Componente
25
-
26
- | Parte | Funcao | data-slot |
27
- | ------------------------ | ------------------------------- | --------------------------- |
28
- | `Select` | Container root, gerencia estado | `select` |
29
- | `SelectTrigger` | Botao que abre o dropdown | `select-trigger` |
30
- | `SelectValue` | Exibe o valor selecionado | `select-value` |
31
- | `SelectContent` | Container do dropdown | `select-content` |
32
- | `SelectGroup` | Agrupa itens relacionados | `select-group` |
33
- | `SelectLabel` | Rotulo para grupos | `select-label` |
34
- | `SelectItem` | Item selecionavel | `select-item` |
35
- | `SelectSeparator` | Divisor entre grupos | `select-separator` |
36
- | `SelectScrollUpButton` | Botao de scroll para cima | `select-scroll-up-button` |
37
- | `SelectScrollDownButton` | Botao de scroll para baixo | `select-scroll-down-button` |
38
-
39
- ### Tamanhos (`size`) - SelectTrigger
40
-
41
- | Tamanho | Altura | Uso |
42
- | --------- | ------------ | ------------------------------------------ |
43
- | `sm` | `h-8` (32px) | Espacos compactos, tabelas, filtros inline |
44
- | `default` | `h-9` (36px) | Uso geral em formularios |
45
-
46
- ### Estados
47
-
48
- | Estado | Classes/Atributos | Comportamento |
49
- | ----------- | ------------------------------------------ | --------------------------------- |
50
- | Default | - | Aparencia base |
51
- | Hover | `hover:bg-input/50` | Leve destaque no fundo |
52
- | Focus | `focus-visible:ring-[3px]` | Ring de 3px com `ring-ring/50` |
53
- | Open | `data-[state=open]` | Animacao de entrada do content |
54
- | Disabled | `disabled:opacity-50` | 50% opacidade, sem pointer events |
55
- | Invalid | `aria-invalid:ring-destructive/20` | Ring vermelho para erro |
56
- | Placeholder | `data-[placeholder]:text-muted-foreground` | Texto em cor secundaria |
57
-
58
- ### Tokens Utilizados
59
-
60
- ```css
61
- /* Cores */
62
- --input /* Borda do trigger */
63
- --background /* Fundo do trigger */
64
- --popover /* Fundo do content */
65
- --popover-foreground
66
- --muted-foreground /* Placeholder, labels */
67
- --accent /* Hover nos items */
68
- --accent-foreground
69
- --ring /* Focus ring */
70
- --border /* Borda do content, separador */
71
- --destructive /* Estado de erro */
72
-
73
- /* Espacamento */
74
- gap-2 /* Entre icone e texto */
75
- px-3 py-2 /* Padding do trigger */
76
- p-1 /* Padding do viewport */
77
-
78
- /* Tipografia */
79
- text-sm /* 14px */
80
- text-xs /* Labels de grupo */
81
-
82
- /* Bordas */
83
- rounded-md /* var(--radius) */
84
- rounded-sm /* Items */
85
-
86
- /* Sombras */
87
- shadow-xs /* Trigger */
88
- shadow-md /* Content */
89
-
90
- /* Animacoes */
91
- animate-in/out /* Fade e zoom no content */
92
- slide-in-from-* /* Direcao baseada em side */
93
- ```
94
-
95
- ### Posicionamento
96
-
97
- | Prop | Valores | Padrao | Descricao |
98
- | ---------- | ---------------------------------- | ---------- | ---------------------- |
99
- | `position` | `"popper"` \| `"item-aligned"` | `"popper"` | Modo de posicionamento |
100
- | `align` | `"start"` \| `"center"` \| `"end"` | `"center"` | Alinhamento horizontal |
101
- | `side` | `"top"` \| `"bottom"` | `"bottom"` | Lado de abertura |
102
-
103
- ### Padrão de Tokens com Tailwind v4
104
-
105
- O componente Select utiliza tokens de design definidos em `@etus/tokens`. No Tailwind v4, variáveis CSS que contêm cores OKLCH precisam do prefixo `color:` para serem interpretadas corretamente.
106
-
107
- #### Tokens Disponíveis
108
-
109
- ```css
110
- /* Gerados em packages/tokens/styles/tokens.css */
111
- /* Trigger */
112
- --select-trigger-padding-x-sm
113
- --select-trigger-padding-x-md
114
- --select-trigger-padding-x-lg
115
- --select-trigger-padding-y-sm
116
- --select-trigger-padding-y-md
117
- --select-trigger-padding-y-lg
118
- --select-trigger-height-sm
119
- --select-trigger-height-md
120
- --select-trigger-height-lg
121
- --select-trigger-text-sm
122
- --select-trigger-text-md
123
- --select-trigger-text-lg
124
-
125
- /* Content */
126
- --select-content-bg
127
- --select-content-fg
128
- --select-content-border
129
- --select-content-radius
130
- --select-content-min-width
131
-
132
- /* Item */
133
- --select-item-padding-y
134
- --select-item-padding-r
135
- --select-item-padding-l
136
- --select-item-radius
137
- --select-item-text
138
- --select-item-focus-bg
139
- --select-item-focus-fg
140
- ```
141
-
142
- #### Sintaxe Tailwind v4
143
-
144
- ```tsx
145
- // ✅ CORRETO - cores precisam do prefixo color:
146
- bg-[color:var(--select-content-bg)]
147
- text-[color:var(--select-content-fg)]
148
- border-[color:var(--select-content-border)]
149
- bg-[color:var(--select-item-focus-bg)]
150
- text-[color:var(--select-item-focus-fg)]
151
-
152
- // ✅ CORRETO - dimensões não precisam de prefixo
153
- h-[var(--select-trigger-height-md)]
154
- px-[var(--select-trigger-padding-x-md)]
155
- rounded-[var(--select-content-radius)]
156
-
157
- // ✅ CORRETO - font-size precisa do prefixo length:
158
- text-[length:var(--select-trigger-text-md)]
159
- text-[length:var(--select-item-text)]
160
-
161
- // ❌ INCORRETO - nunca usar hsl() ou omitir prefixo para cores
162
- bg-[hsl(var(--select-content-bg))]
163
- bg-[var(--select-content-bg)]
164
- ```
165
-
166
- #### Por que usar `color:` e `length:`?
167
-
168
- Os tokens de cor do Seven usam OKLCH (e.g., `oklch(81.06% 0.2032 150.12)`). O Tailwind v4 precisa do type hint `color:` para cores e `length:` para font-size quando usando a classe `text-[]`.
169
-
170
- ---
171
-
172
- ## API
173
-
174
- ### Select (Root)
175
-
176
- | Prop | Tipo | Padrao | Descricao |
177
- | --------------- | ------------------------- | ------- | ---------------------------- |
178
- | `value` | `string` | - | Valor controlado |
179
- | `defaultValue` | `string` | - | Valor inicial nao-controlado |
180
- | `onValueChange` | `(value: string) => void` | - | Callback quando valor muda |
181
- | `open` | `boolean` | - | Estado aberto controlado |
182
- | `defaultOpen` | `boolean` | `false` | Estado inicial aberto |
183
- | `onOpenChange` | `(open: boolean) => void` | - | Callback quando abre/fecha |
184
- | `disabled` | `boolean` | `false` | Desabilita o select |
185
- | `required` | `boolean` | `false` | Campo obrigatorio |
186
- | `name` | `string` | - | Nome para formularios |
187
-
188
- ### SelectTrigger
189
-
190
- | Prop | Tipo | Padrao | Descricao |
191
- | ----------- | ------------------------ | ----------- | --------------------------------- |
192
- | `size` | `"sm"` \| `"default"` | `"default"` | Tamanho do trigger |
193
- | `className` | `string` | - | Classes CSS adicionais |
194
- | `children` | `ReactNode` | - | Conteudo (geralmente SelectValue) |
195
- | `ref` | `Ref<HTMLButtonElement>` | - | Referencia ao elemento DOM |
196
-
197
- > Herda todas as props de `React.ComponentProps<typeof SelectPrimitive.Trigger>`
198
-
199
- ### SelectValue
200
-
201
- | Prop | Tipo | Padrao | Descricao |
202
- | ------------- | -------- | ------ | ------------------------------------- |
203
- | `placeholder` | `string` | - | Texto quando nenhum valor selecionado |
204
-
205
- ### SelectContent
206
-
207
- | Prop | Tipo | Padrao | Descricao |
208
- | ------------ | ---------------------------------- | ---------- | ---------------------- |
209
- | `position` | `"popper"` \| `"item-aligned"` | `"popper"` | Modo de posicionamento |
210
- | `align` | `"start"` \| `"center"` \| `"end"` | `"center"` | Alinhamento |
211
- | `side` | `"top"` \| `"bottom"` | - | Lado preferido |
212
- | `sideOffset` | `number` | - | Offset do trigger |
213
- | `className` | `string` | - | Classes CSS adicionais |
214
-
215
- ### SelectItem
216
-
217
- | Prop | Tipo | Padrao | Descricao |
218
- | ----------- | ----------- | --------------- | ---------------------- |
219
- | `value` | `string` | **obrigatorio** | Valor do item |
220
- | `disabled` | `boolean` | `false` | Desabilita o item |
221
- | `textValue` | `string` | - | Texto para typeahead |
222
- | `className` | `string` | - | Classes CSS adicionais |
223
- | `children` | `ReactNode` | - | Conteudo do item |
224
-
225
- ### SelectGroup & SelectLabel
226
-
227
- ```tsx
228
- // SelectGroup agrupa itens relacionados
229
- // SelectLabel adiciona rotulo ao grupo
230
- <SelectGroup>
231
- <SelectLabel>Frutas</SelectLabel>
232
- <SelectItem value="apple">Maca</SelectItem>
233
- <SelectItem value="banana">Banana</SelectItem>
234
- </SelectGroup>
235
- ```
236
-
237
- ### TypeScript
238
-
239
- ```typescript
240
- import * as SelectPrimitive from "@radix-ui/react-select";
241
-
242
- // Props do Trigger com size customizado
243
- type SelectTriggerProps = React.ComponentProps<
244
- typeof SelectPrimitive.Trigger
245
- > & {
246
- size?: "sm" | "default";
247
- };
248
-
249
- // Props do Content
250
- type SelectContentProps = React.ComponentProps<typeof SelectPrimitive.Content>;
251
-
252
- // Props do Item
253
- type SelectItemProps = React.ComponentProps<typeof SelectPrimitive.Item>;
254
- ```
255
-
256
- ### Comparativo com Design Systems de Referencia
257
-
258
- #### Matriz de Features (14 Design Systems)
259
-
260
- | Feature | ETUS | Shadcn | Radix | React Aria | Chakra | MUI | Mantine | AntD | NextUI | Headless | Ariakit | Fluent | Carbon | Blueprint | PrimeReact |
261
- | ------------------ | :--: | :----: | :---: | :--------: | :----: | :-: | :-----: | :--: | :----: | :------: | :-----: | :----: | :----: | :-------: | :--------: |
262
- | **Compound** | ✓ | ✓ | ✓ | ✓ | - | - | - | - | - | ✓ | ✓ | - | - | - | - |
263
- | **Controlled** | ✓ | ✓ | ✓ | ✓ | ✓ | ✓ | ✓ | ✓ | ✓ | ✓ | ✓ | ✓ | ✓ | ✓ | ✓ |
264
- | **Groups** | ✓ | ✓ | ✓ | ✓ | - | ✓ | ✓ | ✓ | ✓ | ✓ | ✓ | ✓ | ✓ | ✓ | ✓ |
265
- | **Searchable** | - | - | - | ✓ | - | ✓ | ✓ | ✓ | - | - | ✓ | ✓ | ✓ | ✓ | ✓ |
266
- | **Multi-select** | - | - | - | ✓ | ✓ | ✓ | ✓ | ✓ | ✓ | ✓ | ✓ | ✓ | ✓ | ✓ | ✓ |
267
- | **Async loading** | - | - | - | ✓ | - | - | - | ✓ | - | - | - | - | - | - | ✓ |
268
- | **Virtualization** | - | - | - | - | - | - | ✓ | ✓ | - | - | - | - | - | - | ✓ |
269
- | **clearable** | - | - | - | - | ✓ | - | ✓ | ✓ | - | - | - | - | - | - | ✓ |
270
- | **Custom render** | ✓ | ✓ | ✓ | ✓ | - | ✓ | ✓ | ✓ | ✓ | ✓ | ✓ | - | - | ✓ | ✓ |
271
- | **Portal** | ✓ | ✓ | ✓ | ✓ | ✓ | ✓ | ✓ | ✓ | ✓ | ✓ | ✓ | ✓ | ✓ | ✓ | ✓ |
272
- | **Typeahead** | ✓ | ✓ | ✓ | ✓ | - | - | ✓ | - | - | ✓ | ✓ | ✓ | - | ✓ | - |
273
- | **data-slot** | ✓ | ✓ | - | - | - | - | - | - | ✓ | - | - | - | - | - | - |
274
-
275
- #### Comparativo de Arquitetura
276
-
277
- | Design System | Arquitetura | Nota |
278
- | --------------- | --------------------------- | ---------------------------------- |
279
- | **ETUS/Shadcn** | Compound components (Radix) | Maximo controle, mais verboso |
280
- | **Radix UI** | Primitivos compostos | Base para Shadcn, sem estilos |
281
- | **React Aria** | Hooks + componentes | Maximo a11y, flexivel |
282
- | **Chakra UI** | Monolitico com props | Simples, menos flexivel |
283
- | **MUI** | Monolitico + slots | Sistema de slots para customizacao |
284
- | **Mantine** | Monolitico + data | Muito configuravel via props |
285
- | **Ant Design** | Monolitico enterprise | Muitas features built-in |
286
- | **NextUI** | Compound (React Aria) | Herda a11y do React Aria |
287
- | **Headless UI** | Renderless + compound | Tailwind-friendly |
288
- | **Ariakit** | Compound + hooks | Muito flexivel |
289
- | **Fluent UI** | Monolitico Microsoft | Tokens complexos |
290
- | **Carbon** | Monolitico IBM | Foco em data |
291
- | **Blueprint** | Monolitico Palantir | Data-dense UIs |
292
- | **PrimeReact** | Monolitico enterprise | Muito completo |
293
-
294
- #### Comparativo de Props por Design System
295
-
296
- | Prop | ETUS | Chakra | MUI | Mantine | AntD | NextUI |
297
- | ------------- | :-------------: | :----------: | :-----: | :-----: | :----------: | :-----------------: |
298
- | `value` | ✓ | ✓ | ✓ | ✓ | ✓ | ✓ |
299
- | `onChange` | `onValueChange` | ✓ | ✓ | ✓ | ✓ | `onSelectionChange` |
300
- | `disabled` | ✓ | `isDisabled` | ✓ | ✓ | ✓ | `isDisabled` |
301
- | `placeholder` | ✓ | ✓ | - | ✓ | ✓ | ✓ |
302
- | `size` | ✓ | ✓ | ✓ | ✓ | ✓ | ✓ |
303
- | `variant` | - | ✓ | ✓ | ✓ | - | ✓ |
304
- | `multiple` | - | - | ✓ | - | `mode` | `selectionMode` |
305
- | `searchable` | - | - | - | ✓ | `showSearch` | - |
306
- | `clearable` | - | ✓ | - | ✓ | `allowClear` | - |
307
- | `loading` | - | - | - | - | ✓ | - |
308
- | `error` | - | `isInvalid` | `error` | `error` | `status` | `isInvalid` |
309
-
310
- ---
311
-
312
- ## Acessibilidade (A11y)
313
-
314
- ### ARIA Attributes
315
-
316
- | Atributo | Elemento | Descricao |
317
- | ------------------------- | -------- | ---------------------------- |
318
- | `role="combobox"` | Trigger | Identifica como combobox |
319
- | `role="listbox"` | Content | Container de opcoes |
320
- | `role="option"` | Item | Opcao selecionavel |
321
- | `role="group"` | Group | Agrupa opcoes relacionadas |
322
- | `aria-expanded` | Trigger | Estado aberto/fechado |
323
- | `aria-haspopup="listbox"` | Trigger | Indica que abre listbox |
324
- | `aria-activedescendant` | Trigger | Item atualmente focado |
325
- | `aria-selected` | Item | Indica item selecionado |
326
- | `aria-disabled` | Item | Indica item desabilitado |
327
- | `aria-labelledby` | Group | Referencia ao label do grupo |
328
-
329
- ### Suporte a Teclado
330
-
331
- | Tecla | Contexto | Acao |
332
- | ----------------- | --------------- | ------------------------------------------ |
333
- | `Space` / `Enter` | Trigger fechado | Abre o dropdown |
334
- | `Space` / `Enter` | Item focado | Seleciona e fecha |
335
- | `ArrowDown` | Trigger fechado | Abre e foca primeiro item |
336
- | `ArrowDown` | Content aberto | Move foco para proximo item |
337
- | `ArrowUp` | Trigger fechado | Abre e foca ultimo item |
338
- | `ArrowUp` | Content aberto | Move foco para item anterior |
339
- | `Home` | Content aberto | Move foco para primeiro item |
340
- | `End` | Content aberto | Move foco para ultimo item |
341
- | `Escape` | Content aberto | Fecha sem selecionar |
342
- | `Tab` | Content aberto | Fecha e move foco |
343
- | `A-Z` | Content aberto | Typeahead - foca item que comeca com letra |
344
-
345
- ### Focus Management
346
-
347
- ```tsx
348
- // Focus visible no trigger
349
- focus-visible:border-ring
350
- focus-visible:ring-ring/50
351
- focus-visible:ring-[3px]
352
-
353
- // Focus nos items
354
- focus:bg-accent
355
- focus:text-accent-foreground
356
- ```
357
-
358
- ### Contraste de Cores (WCAG 2.1 AA)
359
-
360
- | Elemento | Foreground | Background | Ratio |
361
- | ------------ | ---------------------- | -------------- | -------- |
362
- | Trigger | `--foreground` | `--background` | >= 4.5:1 |
363
- | Placeholder | `--muted-foreground` | `--background` | >= 4.5:1 |
364
- | Item | `--popover-foreground` | `--popover` | >= 4.5:1 |
365
- | Item focused | `--accent-foreground` | `--accent` | >= 4.5:1 |
366
- | Label | `--muted-foreground` | `--popover` | >= 4.5:1 |
367
-
368
- ### Screen Readers
369
-
370
- - Anuncia "combobox, collapsed/expanded"
371
- - Anuncia opcao selecionada
372
- - Anuncia numero de opcoes disponiveis
373
- - Anuncia grupos e labels
374
- - Anuncia estado disabled de items
375
-
376
- ### Comparativo A11y (14 Design Systems)
377
-
378
- | Feature | ETUS | React Aria | Radix | Ariakit | Headless | Chakra | MUI | Mantine | AntD | NextUI | Fluent | Carbon | Blueprint | PrimeReact |
379
- | ------------------------- | :--: | :--------: | :---: | :-----: | :------: | :----: | :-: | :-----: | :--: | :----: | :----: | :----: | :-------: | :--------: |
380
- | **WAI-ARIA 1.2** | ✓ | ✓ | ✓ | ✓ | ✓ | ~ | ~ | ~ | ~ | ✓ | ✓ | ✓ | ~ | ~ |
381
- | **Keyboard nav** | ✓ | ✓ | ✓ | ✓ | ✓ | ✓ | ✓ | ✓ | ✓ | ✓ | ✓ | ✓ | ✓ | ✓ |
382
- | **Typeahead** | ✓ | ✓ | ✓ | ✓ | ✓ | - | - | ✓ | - | - | ✓ | - | ✓ | - |
383
- | **Focus trap** | ✓ | ✓ | ✓ | ✓ | ✓ | ✓ | ✓ | ✓ | ~ | ✓ | ✓ | ✓ | ✓ | ~ |
384
- | **aria-activedescendant** | ✓ | ✓ | ✓ | ✓ | ✓ | - | ✓ | ✓ | - | ✓ | ✓ | ✓ | ✓ | ~ |
385
- | **Screen reader tested** | ~ | ✓ | ✓ | ✓ | ✓ | ~ | ✓ | ~ | ~ | ✓ | ✓ | ✓ | ~ | ~ |
386
- | **RTL support** | - | ✓ | - | - | - | ✓ | ✓ | ✓ | ✓ | - | ✓ | ✓ | - | ✓ |
387
- | **High contrast** | - | ✓ | - | - | - | - | - | - | - | - | ✓ | ✓ | - | - |
388
-
389
- **Legenda:** ✓ = Suporte completo | ~ = Parcial/Manual | - = Nao suportado
390
-
391
- ---
392
-
393
- ## Exemplos
394
-
395
- ### Uso Basico
396
-
397
- ```tsx
398
- import {
399
- Select,
400
- SelectContent,
401
- SelectItem,
402
- SelectTrigger,
403
- SelectValue,
404
- } from "@etus/ui";
405
-
406
- function Example() {
407
- return (
408
- <Select>
409
- <SelectTrigger className="w-[200px]">
410
- <SelectValue placeholder="Selecione uma opcao" />
411
- </SelectTrigger>
412
- <SelectContent>
413
- <SelectItem value="opcao1">Opcao 1</SelectItem>
414
- <SelectItem value="opcao2">Opcao 2</SelectItem>
415
- <SelectItem value="opcao3">Opcao 3</SelectItem>
416
- </SelectContent>
417
- </Select>
418
- );
419
- }
420
- ```
421
-
422
- ### Controlado
423
-
424
- ```tsx
425
- import { useState } from "react";
426
-
427
- function ControlledExample() {
428
- const [value, setValue] = useState<string>("");
429
-
430
- return (
431
- <Select value={value} onValueChange={setValue}>
432
- <SelectTrigger className="w-[200px]">
433
- <SelectValue placeholder="Selecione..." />
434
- </SelectTrigger>
435
- <SelectContent>
436
- <SelectItem value="react">React</SelectItem>
437
- <SelectItem value="vue">Vue</SelectItem>
438
- <SelectItem value="angular">Angular</SelectItem>
439
- </SelectContent>
440
- </Select>
441
- );
442
- }
443
- ```
444
-
445
- ### Com Grupos
446
-
447
- ```tsx
448
- import {
449
- Select,
450
- SelectContent,
451
- SelectGroup,
452
- SelectItem,
453
- SelectLabel,
454
- SelectSeparator,
455
- SelectTrigger,
456
- SelectValue,
457
- } from "@etus/ui";
458
-
459
- function GroupedExample() {
460
- return (
461
- <Select>
462
- <SelectTrigger className="w-[240px]">
463
- <SelectValue placeholder="Selecione um framework" />
464
- </SelectTrigger>
465
- <SelectContent>
466
- <SelectGroup>
467
- <SelectLabel>Frontend</SelectLabel>
468
- <SelectItem value="react">React</SelectItem>
469
- <SelectItem value="vue">Vue</SelectItem>
470
- <SelectItem value="angular">Angular</SelectItem>
471
- </SelectGroup>
472
- <SelectSeparator />
473
- <SelectGroup>
474
- <SelectLabel>Backend</SelectLabel>
475
- <SelectItem value="node">Node.js</SelectItem>
476
- <SelectItem value="python">Python</SelectItem>
477
- <SelectItem value="go">Go</SelectItem>
478
- </SelectGroup>
479
- </SelectContent>
480
- </Select>
481
- );
482
- }
483
- ```
484
-
485
- ### Tamanhos
486
-
487
- ```tsx
488
- // Tamanho padrao (h-9)
489
- <Select>
490
- <SelectTrigger className="w-[200px]">
491
- <SelectValue placeholder="Default" />
492
- </SelectTrigger>
493
- <SelectContent>
494
- <SelectItem value="1">Item 1</SelectItem>
495
- </SelectContent>
496
- </Select>
497
-
498
- // Tamanho pequeno (h-8)
499
- <Select>
500
- <SelectTrigger size="sm" className="w-[200px]">
501
- <SelectValue placeholder="Small" />
502
- </SelectTrigger>
503
- <SelectContent>
504
- <SelectItem value="1">Item 1</SelectItem>
505
- </SelectContent>
506
- </Select>
507
- ```
508
-
509
- ### Com Icones nos Items
510
-
511
- ```tsx
512
- import { Apple, Banana, Cherry } from "lucide-react";
513
-
514
- function IconsExample() {
515
- return (
516
- <Select>
517
- <SelectTrigger className="w-[200px]">
518
- <SelectValue placeholder="Selecione uma fruta" />
519
- </SelectTrigger>
520
- <SelectContent>
521
- <SelectItem value="apple">
522
- <Apple className="size-4" />
523
- Maca
524
- </SelectItem>
525
- <SelectItem value="banana">
526
- <Banana className="size-4" />
527
- Banana
528
- </SelectItem>
529
- <SelectItem value="cherry">
530
- <Cherry className="size-4" />
531
- Cereja
532
- </SelectItem>
533
- </SelectContent>
534
- </Select>
535
- );
536
- }
537
- ```
538
-
539
- ### Item Desabilitado
540
-
541
- ```tsx
542
- <Select>
543
- <SelectTrigger className="w-[200px]">
544
- <SelectValue placeholder="Selecione..." />
545
- </SelectTrigger>
546
- <SelectContent>
547
- <SelectItem value="available">Disponivel</SelectItem>
548
- <SelectItem value="unavailable" disabled>
549
- Indisponivel
550
- </SelectItem>
551
- <SelectItem value="coming">Em breve</SelectItem>
552
- </SelectContent>
553
- </Select>
554
- ```
555
-
556
- ### Em Formulario com React Hook Form
557
-
558
- ```tsx
559
- import { useForm, Controller } from "react-hook-form";
560
- import { zodResolver } from "@hookform/resolvers/zod";
561
- import { z } from "zod";
562
-
563
- const schema = z.object({
564
- country: z.string().min(1, "Selecione um pais"),
565
- });
566
-
567
- function FormExample() {
568
- const {
569
- control,
570
- handleSubmit,
571
- formState: { errors },
572
- } = useForm({
573
- resolver: zodResolver(schema),
574
- defaultValues: { country: "" },
575
- });
576
-
577
- return (
578
- <form onSubmit={handleSubmit(onSubmit)}>
579
- <Controller
580
- name="country"
581
- control={control}
582
- render={({ field }) => (
583
- <Select value={field.value} onValueChange={field.onChange}>
584
- <SelectTrigger
585
- className="w-[200px]"
586
- aria-invalid={!!errors.country}
587
- >
588
- <SelectValue placeholder="Selecione um pais" />
589
- </SelectTrigger>
590
- <SelectContent>
591
- <SelectItem value="br">Brasil</SelectItem>
592
- <SelectItem value="us">Estados Unidos</SelectItem>
593
- <SelectItem value="pt">Portugal</SelectItem>
594
- </SelectContent>
595
- </Select>
596
- )}
597
- />
598
- {errors.country && (
599
- <p className="text-sm text-destructive mt-1">
600
- {errors.country.message}
601
- </p>
602
- )}
603
- </form>
604
- );
605
- }
606
- ```
607
-
608
- ### Responsivo
609
-
610
- ```tsx
611
- // Largura responsiva
612
- <Select>
613
- <SelectTrigger className="w-full sm:w-[200px] md:w-[300px]">
614
- <SelectValue placeholder="Selecione..." />
615
- </SelectTrigger>
616
- <SelectContent>
617
- <SelectItem value="1">Item 1</SelectItem>
618
- </SelectContent>
619
- </Select>
620
- ```
621
-
622
- ### Com Label e Field
623
-
624
- ```tsx
625
- import { Label } from "@etus/ui";
626
-
627
- function FieldExample() {
628
- return (
629
- <div className="grid gap-2">
630
- <Label htmlFor="framework">Framework</Label>
631
- <Select>
632
- <SelectTrigger id="framework" className="w-[200px]">
633
- <SelectValue placeholder="Selecione..." />
634
- </SelectTrigger>
635
- <SelectContent>
636
- <SelectItem value="react">React</SelectItem>
637
- <SelectItem value="vue">Vue</SelectItem>
638
- </SelectContent>
639
- </Select>
640
- </div>
641
- );
642
- }
643
- ```
644
-
645
- ---
646
-
647
- ## Testes
648
-
649
- ### Testes Unitarios
650
-
651
- ```tsx
652
- // Select.test.tsx
653
- import { render, screen } from "@testing-library/react";
654
- import userEvent from "@testing-library/user-event";
655
- import { describe, expect, it, vi } from "vitest";
656
- import {
657
- Select,
658
- SelectContent,
659
- SelectItem,
660
- SelectTrigger,
661
- SelectValue,
662
- } from "./Select";
663
-
664
- describe("Select", () => {
665
- it("renders trigger with placeholder", () => {
666
- render(
667
- <Select>
668
- <SelectTrigger>
669
- <SelectValue placeholder="Selecione..." />
670
- </SelectTrigger>
671
- <SelectContent>
672
- <SelectItem value="1">Item 1</SelectItem>
673
- </SelectContent>
674
- </Select>,
675
- );
676
-
677
- expect(screen.getByRole("combobox")).toBeInTheDocument();
678
- expect(screen.getByText("Selecione...")).toBeInTheDocument();
679
- });
680
-
681
- it("has data-slot attribute", () => {
682
- render(
683
- <Select>
684
- <SelectTrigger>
685
- <SelectValue placeholder="Test" />
686
- </SelectTrigger>
687
- <SelectContent>
688
- <SelectItem value="1">Item 1</SelectItem>
689
- </SelectContent>
690
- </Select>,
691
- );
692
-
693
- expect(screen.getByRole("combobox")).toHaveAttribute(
694
- "data-slot",
695
- "select-trigger",
696
- );
697
- });
698
-
699
- it("applies size class", () => {
700
- render(
701
- <Select>
702
- <SelectTrigger size="sm">
703
- <SelectValue placeholder="Small" />
704
- </SelectTrigger>
705
- <SelectContent>
706
- <SelectItem value="1">Item 1</SelectItem>
707
- </SelectContent>
708
- </Select>,
709
- );
710
-
711
- expect(screen.getByRole("combobox")).toHaveAttribute("data-size", "sm");
712
- });
713
- });
714
- ```
715
-
716
- ### Testes de Interacao
717
-
718
- ```tsx
719
- describe("Select interactions", () => {
720
- it("opens on click", async () => {
721
- const user = userEvent.setup();
722
-
723
- render(
724
- <Select>
725
- <SelectTrigger>
726
- <SelectValue placeholder="Selecione..." />
727
- </SelectTrigger>
728
- <SelectContent>
729
- <SelectItem value="1">Item 1</SelectItem>
730
- </SelectContent>
731
- </Select>,
732
- );
733
-
734
- await user.click(screen.getByRole("combobox"));
735
-
736
- expect(screen.getByRole("listbox")).toBeInTheDocument();
737
- expect(screen.getByRole("option", { name: "Item 1" })).toBeInTheDocument();
738
- });
739
-
740
- it("selects item and closes", async () => {
741
- const user = userEvent.setup();
742
- const onValueChange = vi.fn();
743
-
744
- render(
745
- <Select onValueChange={onValueChange}>
746
- <SelectTrigger>
747
- <SelectValue placeholder="Selecione..." />
748
- </SelectTrigger>
749
- <SelectContent>
750
- <SelectItem value="item1">Item 1</SelectItem>
751
- <SelectItem value="item2">Item 2</SelectItem>
752
- </SelectContent>
753
- </Select>,
754
- );
755
-
756
- await user.click(screen.getByRole("combobox"));
757
- await user.click(screen.getByRole("option", { name: "Item 1" }));
758
-
759
- expect(onValueChange).toHaveBeenCalledWith("item1");
760
- expect(screen.queryByRole("listbox")).not.toBeInTheDocument();
761
- });
762
-
763
- it("shows selected value", async () => {
764
- const user = userEvent.setup();
765
-
766
- render(
767
- <Select defaultValue="item1">
768
- <SelectTrigger>
769
- <SelectValue />
770
- </SelectTrigger>
771
- <SelectContent>
772
- <SelectItem value="item1">Item 1</SelectItem>
773
- </SelectContent>
774
- </Select>,
775
- );
776
-
777
- expect(screen.getByText("Item 1")).toBeInTheDocument();
778
- });
779
-
780
- it("does not select disabled item", async () => {
781
- const user = userEvent.setup();
782
- const onValueChange = vi.fn();
783
-
784
- render(
785
- <Select onValueChange={onValueChange}>
786
- <SelectTrigger>
787
- <SelectValue placeholder="Selecione..." />
788
- </SelectTrigger>
789
- <SelectContent>
790
- <SelectItem value="item1" disabled>
791
- Disabled
792
- </SelectItem>
793
- <SelectItem value="item2">Enabled</SelectItem>
794
- </SelectContent>
795
- </Select>,
796
- );
797
-
798
- await user.click(screen.getByRole("combobox"));
799
- await user.click(screen.getByRole("option", { name: "Disabled" }));
800
-
801
- expect(onValueChange).not.toHaveBeenCalled();
802
- });
803
- });
804
- ```
805
-
806
- ### Testes de Teclado
807
-
808
- ```tsx
809
- describe("Select keyboard navigation", () => {
810
- it("opens with Enter key", async () => {
811
- const user = userEvent.setup();
812
-
813
- render(
814
- <Select>
815
- <SelectTrigger>
816
- <SelectValue placeholder="Selecione..." />
817
- </SelectTrigger>
818
- <SelectContent>
819
- <SelectItem value="1">Item 1</SelectItem>
820
- </SelectContent>
821
- </Select>,
822
- );
823
-
824
- screen.getByRole("combobox").focus();
825
- await user.keyboard("{Enter}");
826
-
827
- expect(screen.getByRole("listbox")).toBeInTheDocument();
828
- });
829
-
830
- it("navigates with arrow keys", async () => {
831
- const user = userEvent.setup();
832
-
833
- render(
834
- <Select>
835
- <SelectTrigger>
836
- <SelectValue placeholder="Selecione..." />
837
- </SelectTrigger>
838
- <SelectContent>
839
- <SelectItem value="1">Item 1</SelectItem>
840
- <SelectItem value="2">Item 2</SelectItem>
841
- <SelectItem value="3">Item 3</SelectItem>
842
- </SelectContent>
843
- </Select>,
844
- );
845
-
846
- screen.getByRole("combobox").focus();
847
- await user.keyboard("{ArrowDown}");
848
-
849
- // Primeiro item deve estar focado
850
- expect(screen.getByRole("option", { name: "Item 1" })).toHaveFocus();
851
-
852
- await user.keyboard("{ArrowDown}");
853
- expect(screen.getByRole("option", { name: "Item 2" })).toHaveFocus();
854
- });
855
-
856
- it("closes with Escape", async () => {
857
- const user = userEvent.setup();
858
-
859
- render(
860
- <Select>
861
- <SelectTrigger>
862
- <SelectValue placeholder="Selecione..." />
863
- </SelectTrigger>
864
- <SelectContent>
865
- <SelectItem value="1">Item 1</SelectItem>
866
- </SelectContent>
867
- </Select>,
868
- );
869
-
870
- await user.click(screen.getByRole("combobox"));
871
- expect(screen.getByRole("listbox")).toBeInTheDocument();
872
-
873
- await user.keyboard("{Escape}");
874
- expect(screen.queryByRole("listbox")).not.toBeInTheDocument();
875
- });
876
-
877
- it("supports typeahead", async () => {
878
- const user = userEvent.setup();
879
-
880
- render(
881
- <Select>
882
- <SelectTrigger>
883
- <SelectValue placeholder="Selecione..." />
884
- </SelectTrigger>
885
- <SelectContent>
886
- <SelectItem value="apple">Apple</SelectItem>
887
- <SelectItem value="banana">Banana</SelectItem>
888
- <SelectItem value="cherry">Cherry</SelectItem>
889
- </SelectContent>
890
- </Select>,
891
- );
892
-
893
- await user.click(screen.getByRole("combobox"));
894
- await user.keyboard("b");
895
-
896
- expect(screen.getByRole("option", { name: "Banana" })).toHaveFocus();
897
- });
898
- });
899
- ```
900
-
901
- ### Testes de Acessibilidade
902
-
903
- ```tsx
904
- import { axe, toHaveNoViolations } from "jest-axe";
905
-
906
- expect.extend(toHaveNoViolations);
907
-
908
- describe("Select accessibility", () => {
909
- it("has no accessibility violations", async () => {
910
- const { container } = render(
911
- <Select>
912
- <SelectTrigger aria-label="Selecione uma opcao">
913
- <SelectValue placeholder="Selecione..." />
914
- </SelectTrigger>
915
- <SelectContent>
916
- <SelectItem value="1">Item 1</SelectItem>
917
- </SelectContent>
918
- </Select>,
919
- );
920
-
921
- const results = await axe(container);
922
- expect(results).toHaveNoViolations();
923
- });
924
-
925
- it("has proper ARIA attributes on trigger", () => {
926
- render(
927
- <Select>
928
- <SelectTrigger>
929
- <SelectValue placeholder="Selecione..." />
930
- </SelectTrigger>
931
- <SelectContent>
932
- <SelectItem value="1">Item 1</SelectItem>
933
- </SelectContent>
934
- </Select>,
935
- );
936
-
937
- const trigger = screen.getByRole("combobox");
938
- expect(trigger).toHaveAttribute("aria-expanded", "false");
939
- expect(trigger).toHaveAttribute("aria-haspopup", "listbox");
940
- });
941
-
942
- it("updates aria-expanded when opened", async () => {
943
- const user = userEvent.setup();
944
-
945
- render(
946
- <Select>
947
- <SelectTrigger>
948
- <SelectValue placeholder="Selecione..." />
949
- </SelectTrigger>
950
- <SelectContent>
951
- <SelectItem value="1">Item 1</SelectItem>
952
- </SelectContent>
953
- </Select>,
954
- );
955
-
956
- const trigger = screen.getByRole("combobox");
957
- expect(trigger).toHaveAttribute("aria-expanded", "false");
958
-
959
- await user.click(trigger);
960
- expect(trigger).toHaveAttribute("aria-expanded", "true");
961
- });
962
-
963
- it("items have proper roles", async () => {
964
- const user = userEvent.setup();
965
-
966
- render(
967
- <Select>
968
- <SelectTrigger>
969
- <SelectValue placeholder="Selecione..." />
970
- </SelectTrigger>
971
- <SelectContent>
972
- <SelectItem value="1">Item 1</SelectItem>
973
- <SelectItem value="2">Item 2</SelectItem>
974
- </SelectContent>
975
- </Select>,
976
- );
977
-
978
- await user.click(screen.getByRole("combobox"));
979
-
980
- const items = screen.getAllByRole("option");
981
- expect(items).toHaveLength(2);
982
- });
983
-
984
- it("groups have proper labelling", async () => {
985
- const user = userEvent.setup();
986
-
987
- render(
988
- <Select>
989
- <SelectTrigger>
990
- <SelectValue placeholder="Selecione..." />
991
- </SelectTrigger>
992
- <SelectContent>
993
- <SelectGroup>
994
- <SelectLabel>Grupo 1</SelectLabel>
995
- <SelectItem value="1">Item 1</SelectItem>
996
- </SelectGroup>
997
- </SelectContent>
998
- </Select>,
999
- );
1000
-
1001
- await user.click(screen.getByRole("combobox"));
1002
-
1003
- expect(screen.getByRole("group")).toBeInTheDocument();
1004
- expect(screen.getByText("Grupo 1")).toBeInTheDocument();
1005
- });
1006
- });
1007
- ```
1008
-
1009
- ### Cenarios Criticos
1010
-
1011
- ```tsx
1012
- describe("Select edge cases", () => {
1013
- it("works with controlled value", async () => {
1014
- const user = userEvent.setup();
1015
-
1016
- function ControlledSelect() {
1017
- const [value, setValue] = useState("");
1018
- return (
1019
- <>
1020
- <Select value={value} onValueChange={setValue}>
1021
- <SelectTrigger>
1022
- <SelectValue placeholder="Selecione..." />
1023
- </SelectTrigger>
1024
- <SelectContent>
1025
- <SelectItem value="1">Item 1</SelectItem>
1026
- <SelectItem value="2">Item 2</SelectItem>
1027
- </SelectContent>
1028
- </Select>
1029
- <span data-testid="value">{value}</span>
1030
- </>
1031
- );
1032
- }
1033
-
1034
- render(<ControlledSelect />);
1035
-
1036
- await user.click(screen.getByRole("combobox"));
1037
- await user.click(screen.getByRole("option", { name: "Item 1" }));
1038
-
1039
- expect(screen.getByTestId("value")).toHaveTextContent("1");
1040
- });
1041
-
1042
- it("handles empty options gracefully", async () => {
1043
- const user = userEvent.setup();
1044
-
1045
- render(
1046
- <Select>
1047
- <SelectTrigger>
1048
- <SelectValue placeholder="Sem opcoes" />
1049
- </SelectTrigger>
1050
- <SelectContent>{/* Sem items */}</SelectContent>
1051
- </Select>,
1052
- );
1053
-
1054
- await user.click(screen.getByRole("combobox"));
1055
- expect(screen.getByRole("listbox")).toBeInTheDocument();
1056
- });
1057
-
1058
- it("preserves custom className", () => {
1059
- render(
1060
- <Select>
1061
- <SelectTrigger className="custom-class">
1062
- <SelectValue placeholder="Test" />
1063
- </SelectTrigger>
1064
- <SelectContent>
1065
- <SelectItem value="1">Item 1</SelectItem>
1066
- </SelectContent>
1067
- </Select>,
1068
- );
1069
-
1070
- expect(screen.getByRole("combobox")).toHaveClass("custom-class");
1071
- });
1072
- });
1073
- ```
1074
-
1075
- ---
1076
-
1077
- ## Roadmap / Features Futuras
1078
-
1079
- Baseado na analise comparativa com 14 design systems, as seguintes features sao candidatas para implementacao futura:
1080
-
1081
- ### Prioridade Alta
1082
-
1083
- #### `searchable`
1084
-
1085
- Filtro de busca nos items do dropdown.
1086
-
1087
- ```tsx
1088
- // Proposta de API
1089
- interface SelectProps {
1090
- searchable?: boolean;
1091
- searchPlaceholder?: string;
1092
- onSearch?: (query: string) => void;
1093
- }
1094
-
1095
- // Uso
1096
- <Select searchable searchPlaceholder="Buscar...">
1097
- <SelectTrigger>
1098
- <SelectValue placeholder="Selecione..." />
1099
- </SelectTrigger>
1100
- <SelectContent>{/* items filtrados */}</SelectContent>
1101
- </Select>;
1102
- ```
1103
-
1104
- **Referencias:** MUI (Autocomplete), Mantine (`searchable`), AntD (`showSearch`), Ariakit
1105
-
1106
- #### `multi-select`
1107
-
1108
- Selecao de multiplos valores.
1109
-
1110
- ```tsx
1111
- // Proposta de API
1112
- interface SelectProps {
1113
- multiple?: boolean;
1114
- value?: string[];
1115
- onValueChange?: (values: string[]) => void;
1116
- maxSelections?: number;
1117
- }
1118
-
1119
- // Uso
1120
- <Select multiple value={selected} onValueChange={setSelected}>
1121
- <SelectTrigger>
1122
- <SelectValue placeholder="Selecione multiplos..." />
1123
- </SelectTrigger>
1124
- <SelectContent>
1125
- <SelectItem value="1">Item 1</SelectItem>
1126
- <SelectItem value="2">Item 2</SelectItem>
1127
- </SelectContent>
1128
- </Select>;
1129
- ```
1130
-
1131
- **Referencias:** Chakra, MUI, Mantine, AntD (`mode="multiple"`), NextUI (`selectionMode="multiple"`)
1132
-
1133
- ### Prioridade Media
1134
-
1135
- #### `clearable`
1136
-
1137
- Botao para limpar selecao.
1138
-
1139
- ```tsx
1140
- // Proposta de API
1141
- interface SelectTriggerProps {
1142
- clearable?: boolean;
1143
- onClear?: () => void;
1144
- }
1145
-
1146
- // Uso
1147
- <SelectTrigger clearable>
1148
- <SelectValue placeholder="Selecione..." />
1149
- </SelectTrigger>;
1150
- ```
1151
-
1152
- **Referencias:** Chakra, Mantine (`clearable`), AntD (`allowClear`)
1153
-
1154
- #### `loading`
1155
-
1156
- Estado de carregamento para async data.
1157
-
1158
- ```tsx
1159
- // Proposta de API
1160
- interface SelectContentProps {
1161
- loading?: boolean;
1162
- loadingText?: string;
1163
- }
1164
-
1165
- // Uso
1166
- <SelectContent loading loadingText="Carregando opcoes...">
1167
- {items.map((item) => (
1168
- <SelectItem key={item.value} value={item.value}>
1169
- {item.label}
1170
- </SelectItem>
1171
- ))}
1172
- </SelectContent>;
1173
- ```
1174
-
1175
- **Referencias:** AntD (`loading`), PrimeReact
1176
-
1177
- #### `variant`
1178
-
1179
- Variantes visuais do trigger.
1180
-
1181
- ```tsx
1182
- // Proposta de API
1183
- interface SelectTriggerProps {
1184
- variant?: "default" | "outline" | "filled" | "flushed";
1185
- }
1186
-
1187
- // Uso
1188
- <SelectTrigger variant="filled">
1189
- <SelectValue placeholder="Filled variant" />
1190
- </SelectTrigger>;
1191
- ```
1192
-
1193
- **Referencias:** Chakra, MUI, NextUI
1194
-
1195
- ### Prioridade Baixa
1196
-
1197
- #### `virtualized`
1198
-
1199
- Virtualizacao para listas grandes.
1200
-
1201
- ```tsx
1202
- // Proposta de API
1203
- interface SelectContentProps {
1204
- virtualized?: boolean;
1205
- itemHeight?: number;
1206
- }
1207
-
1208
- // Uso com milhares de items
1209
- <SelectContent virtualized itemHeight={36}>
1210
- {largeDataset.map((item) => (
1211
- <SelectItem key={item.id} value={item.id}>
1212
- {item.label}
1213
- </SelectItem>
1214
- ))}
1215
- </SelectContent>;
1216
- ```
1217
-
1218
- **Referencias:** Mantine, AntD, PrimeReact
1219
-
1220
- #### `creatable`
1221
-
1222
- Permitir criar novas opcoes.
1223
-
1224
- ```tsx
1225
- // Proposta de API
1226
- interface SelectProps {
1227
- creatable?: boolean;
1228
- onCreate?: (value: string) => void;
1229
- createLabel?: (query: string) => string;
1230
- }
1231
-
1232
- // Uso
1233
- <Select creatable onCreate={handleCreate}>
1234
- ...
1235
- </Select>;
1236
- ```
1237
-
1238
- **Referencias:** React Select, Mantine
1239
-
1240
- ### Decisoes de Design
1241
-
1242
- | Feature | Recomendacao | Justificativa |
1243
- | ------------- | ------------- | ------------------------------------------- |
1244
- | `searchable` | ✓ Implementar | Alta demanda, UX melhor para listas grandes |
1245
- | `multiple` | ✓ Implementar | Caso de uso muito comum |
1246
- | `clearable` | ✓ Implementar | UX basica esperada |
1247
- | `loading` | ✓ Implementar | Essencial para async |
1248
- | `variant` | ⚠️ Avaliar | Pode usar className |
1249
- | `virtualized` | ⚠️ Avaliar | Complexidade vs. uso |
1250
- | `creatable` | ❌ Evitar | Melhor como componente separado (Combobox) |
1251
-
1252
- ---
1253
-
1254
- ## Referências
1255
-
1256
- ### Design Systems Analisados
1257
-
1258
- | Design System | Documentacao Select | GitHub |
1259
- | --------------- | ------------------------------------------------------------------------------- | ----------------------------------------------------------------------------- |
1260
- | **Shadcn/ui** | [Select](https://ui.shadcn.com/docs/components/select) | [shadcn-ui/ui](https://github.com/shadcn-ui/ui) |
1261
- | **Radix UI** | [Select](https://www.radix-ui.com/primitives/docs/components/select) | [radix-ui/primitives](https://github.com/radix-ui/primitives) |
1262
- | **React Aria** | [Select](https://react-spectrum.adobe.com/react-aria/Select.html) | [adobe/react-spectrum](https://github.com/adobe/react-spectrum) |
1263
- | **Chakra UI** | [Select](https://chakra-ui.com/docs/components/select) | [chakra-ui/chakra-ui](https://github.com/chakra-ui/chakra-ui) |
1264
- | **MUI** | [Select](https://mui.com/material-ui/react-select/) | [mui/material-ui](https://github.com/mui/material-ui) |
1265
- | **Mantine** | [Select](https://mantine.dev/core/select/) | [mantinedev/mantine](https://github.com/mantinedev/mantine) |
1266
- | **Ant Design** | [Select](https://ant.design/components/select) | [ant-design/ant-design](https://github.com/ant-design/ant-design) |
1267
- | **NextUI** | [Select](https://nextui.org/docs/components/select) | [nextui-org/nextui](https://github.com/nextui-org/nextui) |
1268
- | **Headless UI** | [Listbox](https://headlessui.com/react/listbox) | [tailwindlabs/headlessui](https://github.com/tailwindlabs/headlessui) |
1269
- | **Ariakit** | [Select](https://ariakit.org/components/select) | [ariakit/ariakit](https://github.com/ariakit/ariakit) |
1270
- | **Fluent UI** | [Dropdown](https://react.fluentui.dev/?path=/docs/components-dropdown--default) | [microsoft/fluentui](https://github.com/microsoft/fluentui) |
1271
- | **Carbon** | [Dropdown](https://carbondesignsystem.com/components/dropdown/usage/) | [carbon-design-system/carbon](https://github.com/carbon-design-system/carbon) |
1272
- | **Blueprint** | [Select](https://blueprintjs.com/docs/#select) | [palantir/blueprint](https://github.com/palantir/blueprint) |
1273
- | **PrimeReact** | [Dropdown](https://primereact.org/dropdown/) | [primefaces/primereact](https://github.com/primefaces/primereact) |
1274
-
1275
- ### Especificacoes e Padroes
1276
-
1277
- - [WAI-ARIA APG - Listbox Pattern](https://www.w3.org/WAI/ARIA/apg/patterns/listbox/)
1278
- - [WAI-ARIA APG - Combobox Pattern](https://www.w3.org/WAI/ARIA/apg/patterns/combobox/)
1279
- - [WCAG 2.1 Success Criteria](https://www.w3.org/WAI/WCAG21/quickref/)
1280
- - [MDN - Select Element](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/select)
1281
-
1282
- ### Ferramentas Utilizadas
1283
-
1284
- - [Radix UI Select](https://www.radix-ui.com/primitives/docs/components/select)
1285
- - [Tailwind CSS](https://tailwindcss.com/docs)
1286
- - [Lucide Icons](https://lucide.dev/icons/)