@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,1174 +0,0 @@
1
- # Avatar
2
-
3
- ## Visão Geral
4
-
5
- O **Avatar** e um componente compound do Design System ETUS usado para representar usuarios, entidades ou objetos atraves de imagens ou iniciais. Como elemento atomico, serve de base para composicoes como listas de usuarios, cabecalhos de perfil e indicadores de presenca.
6
-
7
- ### Casos de Uso
8
-
9
- - Representacao visual de usuarios em listas e comentarios
10
- - Cabecalhos de perfil e menus de conta
11
- - Indicadores de autoria em cards e posts
12
- - Grupos de colaboradores (avatar stacks)
13
- - Placeholders enquanto imagens carregam
14
-
15
- ### Classificacao
16
-
17
- **Categoria:** Atom (Primitivo)
18
- **Dependencias:** `@radix-ui/react-avatar`
19
-
20
- ---
21
-
22
- ## Design Specs
23
-
24
- ### Estrutura Compound
25
-
26
- O Avatar utiliza o padrao compound component com multiplas partes:
27
-
28
- | Componente | Slot | Descricao |
29
- | ------------------ | -------------------- | --------------------------------------------------- |
30
- | `Avatar` | `avatar` | Container raiz, define tamanho e forma |
31
- | `AvatarImage` | `avatar-image` | Imagem do avatar, carrega assincronamente |
32
- | `AvatarFallback` | `avatar-fallback` | Conteudo exibido enquanto imagem carrega ou em erro |
33
- | `AvatarStatus` | `avatar-status` | Indicador de presenca (online/offline/busy/away) |
34
- | `AvatarBadge` | `avatar-badge` | Badge de verificacao (company/verified) |
35
- | `AvatarGroup` | `avatar-group` | Agrupa multiplos avatares com overlap |
36
- | `AvatarLabelGroup` | `avatar-label-group` | Avatar com nome e descricao |
37
- | `AvatarAddButton` | `avatar-add-button` | Botao para adicionar usuarios |
38
-
39
- ### Tamanhos (via prop `size`)
40
-
41
- O componente suporta tamanhos pre-definidos via prop `size`:
42
-
43
- | Tamanho | Prop | Dimensao | Uso |
44
- | ----------- | ---------------- | -------- | ------------------------- |
45
- | Extra Small | `size="xs"` | 24px | Listas compactas, badges |
46
- | Small | `size="sm"` | 32px | Comentarios |
47
- | Default | `size="default"` | 40px | **Padrao**, cards, listas |
48
- | Large | `size="lg"` | 48px | Headers de perfil |
49
- | Extra Large | `size="xl"` | 56px | Paginas de perfil |
50
- | 2X Large | `size="2xl"` | 64px | Hero sections |
51
-
52
- ### Formas (via prop `shape`)
53
-
54
- | Forma | Prop | Uso |
55
- | ------ | ---------------- | -------------------- |
56
- | Circle | `shape="circle"` | **Padrao**, usuarios |
57
- | Square | `shape="square"` | Organizacoes, apps |
58
-
59
- ### Variantes
60
-
61
- | Variante | Prop | Descricao |
62
- | --------------- | ---------------- | ---------------------------------------------------------------- |
63
- | Bordered | `bordered` | Borda branca (ring-2 ring-background) para grupos |
64
- | Interactive | `interactive` | Hover scale + focus ring para avatares clicaveis |
65
- | Contrast Border | `contrastBorder` | Borda sutil (0.5-0.75px) para definir bordas em fundos similares |
66
-
67
- ### Estados
68
-
69
- | Estado | Comportamento | Implementacao |
70
- | -------- | -------------- | --------------------- |
71
- | Loading | Exibe Fallback | Automatico via Radix |
72
- | Loaded | Exibe Image | Transicao suave |
73
- | Error | Exibe Fallback | Automatico via Radix |
74
- | Fallback | Iniciais/Icone | Conteudo customizavel |
75
-
76
- ### Padrão de Tokens com Tailwind v4
77
-
78
- O Avatar usa tokens de componente definidos em `@etus/tokens`. Estes tokens são CSS custom properties que devem ser usadas com a sintaxe correta do Tailwind v4.
79
-
80
- #### Tokens Disponíveis
81
-
82
- | Token | Valor | Uso |
83
- | ---------------------------------- | ---------------- | --------------------------- |
84
- | `--avatar-size-xs` | 24px | Tamanho extra pequeno |
85
- | `--avatar-size-sm` | 32px | Tamanho pequeno |
86
- | `--avatar-size-default` | 40px | Tamanho padrão |
87
- | `--avatar-size-lg` | 48px | Tamanho grande |
88
- | `--avatar-size-xl` | 56px | Tamanho extra grande |
89
- | `--avatar-size-2xl` | 64px | Tamanho 2x grande |
90
- | `--avatar-text-xs` | 0.75rem | Fonte para xs |
91
- | `--avatar-text-sm` | 0.875rem | Fonte para sm |
92
- | `--avatar-text-default` | 1rem | Fonte para default |
93
- | `--avatar-text-lg` | 1.125rem | Fonte para lg |
94
- | `--avatar-text-xl` | 1.25rem | Fonte para xl |
95
- | `--avatar-text-2xl` | 1.5rem | Fonte para 2xl |
96
- | `--avatar-radius-circle` | 9999px | Raio circular |
97
- | `--avatar-radius-square` | 0.375rem | Raio quadrado |
98
- | `--avatar-border-contrast` | rgba(0,0,0,0.08) | Borda de contraste |
99
- | `--avatar-fallback-bg-default` | OKLCH | Fundo fallback default |
100
- | `--avatar-fallback-bg-primary` | OKLCH | Fundo fallback primary |
101
- | `--avatar-fallback-bg-secondary` | OKLCH | Fundo fallback secondary |
102
- | `--avatar-fallback-bg-success` | OKLCH | Fundo fallback success |
103
- | `--avatar-fallback-bg-warning` | OKLCH | Fundo fallback warning |
104
- | `--avatar-fallback-bg-destructive` | OKLCH | Fundo fallback destructive |
105
- | `--avatar-fallback-text-*` | OKLCH | Texto para cada colorScheme |
106
-
107
- #### Sintaxe Tailwind v4
108
-
109
- ```tsx
110
- // ✅ CORRETO - Dimensões (não precisam de type hint)
111
- size-[var(--avatar-size-xs)]
112
- rounded-[var(--avatar-radius-circle)]
113
-
114
- // ✅ CORRETO - Font-size (precisa de length:)
115
- text-[length:var(--avatar-text-sm)]
116
-
117
- // ✅ CORRETO - Cores (precisam de color:)
118
- bg-[color:var(--avatar-fallback-bg-default)]
119
- text-[color:var(--avatar-fallback-text-default)]
120
- border-[color:var(--avatar-border-contrast)]
121
-
122
- // ❌ INCORRETO - Cores sem type hint
123
- bg-[var(--avatar-fallback-bg-default)]
124
- text-[var(--avatar-fallback-text-default)]
125
-
126
- // ❌ INCORRETO - Nunca usar hsl() com OKLCH
127
- bg-[hsl(var(--avatar-fallback-bg-default))]
128
- ```
129
-
130
- #### Por que usar `color:` para cores?
131
-
132
- No Tailwind CSS v4, quando você usa valores arbitrários com CSS variables:
133
-
134
- 1. **Dimensões** (`h-`, `w-`, `p-`, `m-`, `rounded-`, `size-`) funcionam sem type hint
135
- 2. **Font-size** (`text-[length:...]`) precisa de `length:` para diferenciar de cor
136
- 3. **Cores** (`bg-`, `text-` para cor, `border-`) precisam de `color:` para que o Tailwind interprete corretamente
137
-
138
- Os tokens de cor do Seven usam OKLCH e são valores completos, não precisam de função wrapper.
139
-
140
- ### Tokens Semânticos (Status e Badge)
141
-
142
- Para componentes compostos como AvatarStatus e AvatarBadge, use tokens semânticos:
143
-
144
- ```css
145
- /* Status */
146
- --success /* Status online (verde) */
147
- --destructive /* Status busy (vermelho) */
148
- --warning /* Status away (amarelo) */
149
- --muted /* Status offline (cinza) */
150
-
151
- /* Badge */
152
- --brius-500 /* Badge company (roxo brand) */
153
- --sevends-blue-600 /* Badge verified (azul brand) */
154
- ```
155
-
156
- > **IMPORTANTE:** Nunca use cores hardcoded como `bg-green-500` ou `bg-blue-500`. Sempre use tokens para garantir consistência com o design system.
157
-
158
- ### data-slot
159
-
160
- ```html
161
- <span data-slot="avatar">
162
- <img data-slot="avatar-image" />
163
- <span data-slot="avatar-fallback">AB</span>
164
- </span>
165
- ```
166
-
167
- ---
168
-
169
- ## API
170
-
171
- ### Props - Avatar (Root)
172
-
173
- | Prop | Tipo | Padrao | Descricao |
174
- | ----------- | ----------- | ------ | ------------------------------- |
175
- | `className` | `string` | - | Classes CSS adicionais |
176
- | `children` | `ReactNode` | - | AvatarImage e/ou AvatarFallback |
177
-
178
- > Herda todas as props de `React.ComponentProps<typeof AvatarPrimitive.Root>`
179
-
180
- ### Props - AvatarImage
181
-
182
- | Prop | Tipo | Padrao | Descricao |
183
- | ----------------------- | -------------------------------------------------------------- | ------ | ----------------------------------------- |
184
- | `src` | `string` | - | URL da imagem |
185
- | `alt` | `string` | - | Texto alternativo (obrigatorio para a11y) |
186
- | `className` | `string` | - | Classes CSS adicionais |
187
- | `onLoadingStatusChange` | `(status: 'idle' \| 'loading' \| 'loaded' \| 'error') => void` | - | Callback de status |
188
-
189
- > Herda todas as props de `React.ComponentProps<typeof AvatarPrimitive.Image>`
190
-
191
- ### Props - AvatarFallback
192
-
193
- | Prop | Tipo | Padrao | Descricao |
194
- | ----------- | ----------- | ------ | -------------------------------------- |
195
- | `delayMs` | `number` | - | Delay antes de exibir fallback |
196
- | `className` | `string` | - | Classes CSS adicionais |
197
- | `children` | `ReactNode` | - | Conteudo do fallback (iniciais, icone) |
198
-
199
- > Herda todas as props de `React.ComponentProps<typeof AvatarPrimitive.Fallback>`
200
-
201
- ### Callbacks
202
-
203
- | Callback | Componente | Tipo | Descricao |
204
- | ----------------------- | ----------- | ------------------ | --------------------------------- |
205
- | `onLoadingStatusChange` | AvatarImage | `(status) => void` | Notifica mudancas no carregamento |
206
-
207
- ### TypeScript
208
-
209
- ```typescript
210
- import * as AvatarPrimitive from "@radix-ui/react-avatar";
211
-
212
- // Props dos componentes
213
- type AvatarProps = React.ComponentProps<typeof AvatarPrimitive.Root>;
214
- type AvatarImageProps = React.ComponentProps<typeof AvatarPrimitive.Image>;
215
- type AvatarFallbackProps = React.ComponentProps<
216
- typeof AvatarPrimitive.Fallback
217
- >;
218
-
219
- // Tipo para status de carregamento
220
- type ImageLoadingStatus = "idle" | "loading" | "loaded" | "error";
221
- ```
222
-
223
- ### Comparativo com Design Systems de Referencia
224
-
225
- #### Matriz de Features (14 Design Systems)
226
-
227
- | Feature | ETUS | Shadcn | Radix | React Aria | Chakra | MUI | Mantine | AntD | NextUI | Headless | Ariakit | Fluent | Carbon | Blueprint |
228
- | ----------------- | :--: | :----: | :---: | :--------: | :----: | :-: | :-----: | :--: | :----: | :------: | :-----: | :----: | :----: | :-------: |
229
- | **Compound** | ✓ | ✓ | ✓ | - | - | - | - | - | - | - | - | - | - | - |
230
- | **Fallback auto** | ✓ | ✓ | ✓ | - | ✓ | ✓ | ✓ | ✓ | ✓ | - | - | ✓ | ✓ | - |
231
- | **Sizes prop** | ✓ | - | - | - | ✓ | - | ✓ | ✓ | ✓ | - | - | ✓ | ✓ | - |
232
- | **Shape/radius** | ✓ | ~ | - | - | - | ✓ | ✓ | ✓ | ✓ | - | - | ✓ | - | - |
233
- | **Badge/Status** | ✓ | - | - | - | - | - | ✓ | ✓ | - | - | - | ✓ | - | - |
234
- | **AvatarGroup** | ✓ | - | - | - | ✓ | ✓ | ✓ | ✓ | ✓ | - | - | ✓ | - | - |
235
- | **Loading state** | ✓ | ✓ | ✓ | - | - | - | - | ✓ | ✓ | - | - | - | ✓ | - |
236
- | **Initials auto** | ✓ | - | - | - | ✓ | - | - | - | ✓ | - | - | ✓ | ✓ | - |
237
- | **Color scheme** | - | - | - | - | ✓ | - | ✓ | - | ✓ | - | - | ✓ | - | - |
238
- | **data-slot** | ✓ | ✓ | - | - | - | - | - | - | ✓ | - | - | - | - | - |
239
- | **Bordered** | ✓ | - | - | - | - | - | - | - | ✓ | - | - | - | - | - |
240
- | **Interactive** | ✓ | - | - | - | - | - | - | - | ✓ | - | - | - | - | - |
241
-
242
- **Legenda:** ✓ = Suporte completo | ~ = Via className | - = Nao suportado
243
-
244
- #### Comparativo de Props por Design System
245
-
246
- | Prop | ETUS | Chakra | MUI | Mantine | AntD | NextUI | Fluent |
247
- | -------------- | :-------: | :----: | :-------: | :-----: | :-----: | :----: | :-----: |
248
- | `src` | Image | ✓ | ✓ | ✓ | ✓ | ✓ | `image` |
249
- | `alt` | Image | ✓ | ✓ | ✓ | ✓ | ✓ | ✓ |
250
- | `name` | - | ✓ | - | - | - | ✓ | ✓ |
251
- | `size` | className | ✓ | - | ✓ | ✓ | ✓ | ✓ |
252
- | `radius` | className | - | `variant` | ✓ | `shape` | ✓ | `shape` |
253
- | `color` | className | ✓ | - | ✓ | - | ✓ | ✓ |
254
- | `bordered` | className | - | - | - | - | ✓ | - |
255
- | `fallback` | children | ✓ | ✓ | ✓ | `icon` | ✓ | ✓ |
256
- | `showFallback` | - | - | - | - | - | ✓ | - |
257
- | `getInitials` | - | ✓ | - | - | - | ✓ | - |
258
-
259
- #### Abordagens por Categoria
260
-
261
- **Headless/Primitivos (maxima flexibilidade):**
262
-
263
- - **Radix UI** - Compound component, loading states automaticos, zero estilos
264
- - **Headless UI** - Nao possui Avatar dedicado
265
- - **React Aria** - Nao possui Avatar dedicado
266
-
267
- **Styled/Opinionated (produtividade):**
268
-
269
- - **Chakra UI** - `name` prop gera iniciais, `colorScheme` automatico
270
- - **MUI** - Variantes `circular`/`rounded`/`square`, integracao com Badge
271
- - **Mantine** - `radius` e `color` granulares, `Avatar.Group` built-in
272
- - **Ant Design** - `shape`, `icon`, integracao com Badge e Tooltip
273
-
274
- **Hybrid (meio-termo):**
275
-
276
- - **Shadcn/ui** - Compound pattern, customizacao via className
277
- - **NextUI** - Props ergonomicas + Tailwind, `isBordered`, `isZoomed`
278
- - **ETUS** - Baseado em Shadcn, compound pattern, data-slot
279
-
280
- **Enterprise:**
281
-
282
- - **Fluent UI** - `presence` indicator, `activeAppearance`, tokens Microsoft
283
- - **Carbon** - IBM design, skeleton loading, focus states
284
-
285
- ---
286
-
287
- ## Acessibilidade (A11y)
288
-
289
- ### ARIA Attributes
290
-
291
- | Atributo | Uso | Implementacao |
292
- | ------------- | ------------------------- | ------------------------------ |
293
- | `role="img"` | Implicito no `<img>` | Automatico |
294
- | `alt` | Descricao da imagem | **Obrigatorio** em AvatarImage |
295
- | `aria-label` | Quando sem imagem | Usar no Avatar root |
296
- | `aria-hidden` | Para avatares decorativos | `aria-hidden="true"` |
297
-
298
- ### Texto Alternativo (alt)
299
-
300
- ```tsx
301
- // ✓ CORRETO: Alt descritivo
302
- <AvatarImage src={url} alt="Foto de perfil de Maria Silva" />
303
-
304
- // ✓ CORRETO: Avatar decorativo
305
- <Avatar aria-hidden="true">
306
- <AvatarImage src={url} alt="" />
307
- </Avatar>
308
-
309
- // ✗ INCORRETO: Alt generico
310
- <AvatarImage src={url} alt="avatar" />
311
- <AvatarImage src={url} alt="user" />
312
- ```
313
-
314
- ### Suporte a Teclado
315
-
316
- O Avatar nao e interativo por padrao. Quando usado como botao:
317
-
318
- | Tecla | Acao |
319
- | ------- | -------------------------------------- |
320
- | `Tab` | Move foco para o avatar (se focusable) |
321
- | `Enter` | Ativa a acao (se botao) |
322
- | `Space` | Ativa a acao (se botao) |
323
-
324
- ### Focus Management
325
-
326
- ```tsx
327
- // Avatar como botao - adicionar focus styles
328
- <button className="rounded-full focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2">
329
- <Avatar>
330
- <AvatarImage src={url} alt="Abrir perfil de Maria" />
331
- <AvatarFallback>MS</AvatarFallback>
332
- </Avatar>
333
- </button>
334
- ```
335
-
336
- ### Contraste de Cores
337
-
338
- | Elemento | Foreground | Background | Ratio Minimo |
339
- | ------------- | -------------------- | ---------- | ------------ |
340
- | Fallback text | `--foreground` | `--muted` | >= 4.5:1 |
341
- | Fallback icon | `--muted-foreground` | `--muted` | >= 3:1 |
342
-
343
- ### Screen Readers
344
-
345
- - Sempre fornecer `alt` descritivo para AvatarImage
346
- - Usar `aria-label` no container quando necessario contexto adicional
347
- - Fallback com texto deve ser legivel (iniciais claras)
348
- - Anunciar status de presenca se implementado
349
-
350
- ### Comparativo A11y (14 Design Systems)
351
-
352
- | Feature | ETUS | React Aria | Radix | Chakra | MUI | Mantine | AntD | NextUI | Fluent | Carbon |
353
- | ------------------- | :--: | :--------: | :---: | :----: | :-: | :-----: | :--: | :----: | :----: | :----: |
354
- | **alt obrigatorio** | ~ | - | ~ | ✓ | ~ | ~ | ~ | ~ | ✓ | ✓ |
355
- | **aria-label** | ~ | - | ~ | ✓ | ~ | ~ | ~ | ✓ | ✓ | ✓ |
356
- | **role="img"** | ✓ | - | ✓ | ✓ | ✓ | ✓ | ✓ | ✓ | ✓ | ✓ |
357
- | **Focus visible** | ~ | - | - | ✓ | ✓ | ✓ | - | ✓ | ✓ | ✓ |
358
- | **High contrast** | - | - | - | - | - | - | - | - | ✓ | ✓ |
359
-
360
- **Legenda:** ✓ = Built-in | ~ = Manual/Via props | - = Nao aplicavel
361
-
362
- ---
363
-
364
- ## Exemplos
365
-
366
- ### Uso Basico
367
-
368
- ```tsx
369
- import { Avatar, AvatarImage, AvatarFallback } from "@etus/ui";
370
-
371
- function Example() {
372
- return (
373
- <Avatar>
374
- <AvatarImage src="https://github.com/shadcn.png" alt="@shadcn" />
375
- <AvatarFallback>CN</AvatarFallback>
376
- </Avatar>
377
- );
378
- }
379
- ```
380
-
381
- ### Tamanhos
382
-
383
- ```tsx
384
- // Extra small (24px)
385
- <Avatar className="size-6">
386
- <AvatarImage src={url} alt="Usuario" />
387
- <AvatarFallback className="text-xs">AB</AvatarFallback>
388
- </Avatar>
389
-
390
- // Small (32px) - Padrao
391
- <Avatar>
392
- <AvatarImage src={url} alt="Usuario" />
393
- <AvatarFallback>AB</AvatarFallback>
394
- </Avatar>
395
-
396
- // Medium (40px)
397
- <Avatar className="size-10">
398
- <AvatarImage src={url} alt="Usuario" />
399
- <AvatarFallback>AB</AvatarFallback>
400
- </Avatar>
401
-
402
- // Large (48px)
403
- <Avatar className="size-12">
404
- <AvatarImage src={url} alt="Usuario" />
405
- <AvatarFallback className="text-lg">AB</AvatarFallback>
406
- </Avatar>
407
-
408
- // Extra large (64px)
409
- <Avatar className="size-16">
410
- <AvatarImage src={url} alt="Usuario" />
411
- <AvatarFallback className="text-xl">AB</AvatarFallback>
412
- </Avatar>
413
- ```
414
-
415
- ### Formas
416
-
417
- ```tsx
418
- // Circular (padrao)
419
- <Avatar>
420
- <AvatarImage src={url} alt="Usuario" />
421
- <AvatarFallback>AB</AvatarFallback>
422
- </Avatar>
423
-
424
- // Quadrado com bordas arredondadas
425
- <Avatar className="rounded-md">
426
- <AvatarImage src={url} alt="Organizacao" />
427
- <AvatarFallback className="rounded-md">ORG</AvatarFallback>
428
- </Avatar>
429
-
430
- // Quadrado
431
- <Avatar className="rounded-none">
432
- <AvatarImage src={url} alt="App" />
433
- <AvatarFallback className="rounded-none">APP</AvatarFallback>
434
- </Avatar>
435
- ```
436
-
437
- ### Fallback com Icone
438
-
439
- ```tsx
440
- import { User } from "lucide-react";
441
-
442
- <Avatar>
443
- <AvatarImage src={url} alt="Usuario" />
444
- <AvatarFallback>
445
- <User className="size-4" />
446
- </AvatarFallback>
447
- </Avatar>;
448
- ```
449
-
450
- ### Fallback com Iniciais Customizadas
451
-
452
- ```tsx
453
- function getInitials(name: string): string {
454
- return name
455
- .split(' ')
456
- .map(word => word[0])
457
- .join('')
458
- .toUpperCase()
459
- .slice(0, 2)
460
- }
461
-
462
- function UserAvatar({ name, src }: { name: string; src?: string }) {
463
- return (
464
- <Avatar>
465
- <AvatarImage src={src} alt={`Foto de ${name}`} />
466
- <AvatarFallback>{getInitials(name)}</AvatarFallback>
467
- </Avatar>
468
- )
469
- }
470
-
471
- // Uso
472
- <UserAvatar name="Maria Silva" src={url} /> // Fallback: "MS"
473
- <UserAvatar name="Joao" /> // Fallback: "JO"
474
- ```
475
-
476
- ### Com Borda
477
-
478
- ```tsx
479
- <Avatar className="ring-2 ring-primary ring-offset-2 ring-offset-background">
480
- <AvatarImage src={url} alt="Usuario" />
481
- <AvatarFallback>AB</AvatarFallback>
482
- </Avatar>
483
- ```
484
-
485
- ### Avatar Group (Stack)
486
-
487
- ```tsx
488
- function AvatarGroup({ users, max = 4 }: { users: User[]; max?: number }) {
489
- const visible = users.slice(0, max);
490
- const remaining = users.length - max;
491
-
492
- return (
493
- <div className="flex -space-x-3">
494
- {visible.map((user) => (
495
- <Avatar key={user.id} className="ring-2 ring-background">
496
- <AvatarImage src={user.avatar} alt={user.name} />
497
- <AvatarFallback>{user.initials}</AvatarFallback>
498
- </Avatar>
499
- ))}
500
- {remaining > 0 && (
501
- <Avatar className="ring-2 ring-background">
502
- <AvatarFallback className="bg-muted text-muted-foreground text-xs">
503
- +{remaining}
504
- </AvatarFallback>
505
- </Avatar>
506
- )}
507
- </div>
508
- );
509
- }
510
- ```
511
-
512
- ### Com Status/Presenca
513
-
514
- ```tsx
515
- // Usando o componente AvatarStatus (recomendado)
516
- import { Avatar, AvatarImage, AvatarFallback, AvatarStatus } from "@etus/ui";
517
-
518
- <div className="relative">
519
- <Avatar>
520
- <AvatarImage src={url} alt="Usuario" />
521
- <AvatarFallback>AB</AvatarFallback>
522
- </Avatar>
523
- <AvatarStatus status="online" />
524
- </div>;
525
-
526
- // Ou manualmente com tokens semanticos
527
- function AvatarWithStatus({
528
- src,
529
- alt,
530
- status,
531
- }: {
532
- src: string;
533
- alt: string;
534
- status: "online" | "offline" | "busy" | "away";
535
- }) {
536
- // Usar tokens semanticos - NUNCA hardcode cores!
537
- const statusColors = {
538
- online: "bg-success", // --success token
539
- offline: "bg-muted", // --muted token
540
- busy: "bg-destructive", // --destructive token
541
- away: "bg-warning", // --warning token
542
- };
543
-
544
- return (
545
- <div className="relative">
546
- <Avatar>
547
- <AvatarImage src={src} alt={alt} />
548
- <AvatarFallback>AB</AvatarFallback>
549
- </Avatar>
550
- <span
551
- className={cn(
552
- "absolute bottom-0 right-0 size-3 rounded-full ring-2 ring-background",
553
- statusColors[status],
554
- )}
555
- aria-label={`Status: ${status}`}
556
- />
557
- </div>
558
- );
559
- }
560
- ```
561
-
562
- ### Avatar como Botao
563
-
564
- ```tsx
565
- import { Button } from "@etus/ui"
566
-
567
- // Usando asChild
568
- <Button variant="ghost" size="icon" className="rounded-full" asChild>
569
- <button aria-label="Abrir menu do usuario">
570
- <Avatar>
571
- <AvatarImage src={url} alt="" />
572
- <AvatarFallback>AB</AvatarFallback>
573
- </Avatar>
574
- </button>
575
- </Button>
576
-
577
- // Ou wrapper simples
578
- <button
579
- className="rounded-full focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring"
580
- aria-label="Abrir perfil"
581
- >
582
- <Avatar>
583
- <AvatarImage src={url} alt="" />
584
- <AvatarFallback>AB</AvatarFallback>
585
- </Avatar>
586
- </button>
587
- ```
588
-
589
- ### Monitorando Status de Carregamento
590
-
591
- ```tsx
592
- function AvatarWithLoadingState({ src, alt }: { src: string; alt: string }) {
593
- const [status, setStatus] = React.useState<
594
- "idle" | "loading" | "loaded" | "error"
595
- >("idle");
596
-
597
- return (
598
- <div>
599
- <Avatar>
600
- <AvatarImage src={src} alt={alt} onLoadingStatusChange={setStatus} />
601
- <AvatarFallback delayMs={600}>
602
- {status === "loading" ? <Spinner /> : "AB"}
603
- </AvatarFallback>
604
- </Avatar>
605
- {status === "error" && (
606
- <span className="text-sm text-destructive">
607
- Erro ao carregar imagem
608
- </span>
609
- )}
610
- </div>
611
- );
612
- }
613
- ```
614
-
615
- ### Responsividade
616
-
617
- ```tsx
618
- // Tamanho responsivo
619
- <Avatar className="size-8 md:size-10 lg:size-12">
620
- <AvatarImage src={url} alt="Usuario" />
621
- <AvatarFallback className="text-xs md:text-sm lg:text-base">
622
- AB
623
- </AvatarFallback>
624
- </Avatar>
625
- ```
626
-
627
- ### Com Container Queries
628
-
629
- ```tsx
630
- <div className="@container">
631
- <Avatar className="size-8 @sm:size-10 @md:size-12">
632
- <AvatarImage src={url} alt="Usuario" />
633
- <AvatarFallback>AB</AvatarFallback>
634
- </Avatar>
635
- </div>
636
- ```
637
-
638
- ---
639
-
640
- ## Testes
641
-
642
- ### Testes Unitarios
643
-
644
- ```tsx
645
- // Avatar.test.tsx
646
- import { render, screen } from "@testing-library/react";
647
- import { describe, expect, it } from "vitest";
648
- import { Avatar, AvatarImage, AvatarFallback } from "./Avatar";
649
-
650
- describe("Avatar", () => {
651
- it("renders avatar container", () => {
652
- render(
653
- <Avatar data-testid="avatar">
654
- <AvatarFallback>AB</AvatarFallback>
655
- </Avatar>,
656
- );
657
- expect(screen.getByTestId("avatar")).toBeInTheDocument();
658
- });
659
-
660
- it("has data-slot attribute", () => {
661
- render(
662
- <Avatar data-testid="avatar">
663
- <AvatarFallback>AB</AvatarFallback>
664
- </Avatar>,
665
- );
666
- expect(screen.getByTestId("avatar")).toHaveAttribute("data-slot", "avatar");
667
- });
668
-
669
- it("applies custom className", () => {
670
- render(
671
- <Avatar className="size-16" data-testid="avatar">
672
- <AvatarFallback>AB</AvatarFallback>
673
- </Avatar>,
674
- );
675
- expect(screen.getByTestId("avatar")).toHaveClass("size-16");
676
- });
677
-
678
- it("maintains default classes with custom className", () => {
679
- render(
680
- <Avatar className="custom-class" data-testid="avatar">
681
- <AvatarFallback>AB</AvatarFallback>
682
- </Avatar>,
683
- );
684
- const avatar = screen.getByTestId("avatar");
685
- expect(avatar).toHaveClass("rounded-full");
686
- expect(avatar).toHaveClass("custom-class");
687
- });
688
- });
689
- ```
690
-
691
- ### Testes de AvatarImage
692
-
693
- ```tsx
694
- describe("AvatarImage", () => {
695
- it("renders image with src and alt", () => {
696
- render(
697
- <Avatar>
698
- <AvatarImage src="test.jpg" alt="Test user" />
699
- <AvatarFallback>TU</AvatarFallback>
700
- </Avatar>,
701
- );
702
- const img = screen.getByRole("img");
703
- expect(img).toHaveAttribute("src", "test.jpg");
704
- expect(img).toHaveAttribute("alt", "Test user");
705
- });
706
-
707
- it("has data-slot attribute", () => {
708
- render(
709
- <Avatar>
710
- <AvatarImage src="test.jpg" alt="Test" data-testid="avatar-image" />
711
- <AvatarFallback>T</AvatarFallback>
712
- </Avatar>,
713
- );
714
- // Note: Radix may not render image immediately
715
- const img = screen.queryByTestId("avatar-image");
716
- if (img) {
717
- expect(img).toHaveAttribute("data-slot", "avatar-image");
718
- }
719
- });
720
- });
721
- ```
722
-
723
- ### Testes de AvatarFallback
724
-
725
- ```tsx
726
- describe("AvatarFallback", () => {
727
- it("renders fallback content", () => {
728
- render(
729
- <Avatar>
730
- <AvatarFallback>AB</AvatarFallback>
731
- </Avatar>,
732
- );
733
- expect(screen.getByText("AB")).toBeInTheDocument();
734
- });
735
-
736
- it("renders icon as fallback", () => {
737
- render(
738
- <Avatar>
739
- <AvatarFallback data-testid="fallback">
740
- <svg data-testid="icon" />
741
- </AvatarFallback>
742
- </Avatar>,
743
- );
744
- expect(screen.getByTestId("icon")).toBeInTheDocument();
745
- });
746
-
747
- it("has data-slot attribute", () => {
748
- render(
749
- <Avatar>
750
- <AvatarFallback data-testid="fallback">AB</AvatarFallback>
751
- </Avatar>,
752
- );
753
- expect(screen.getByTestId("fallback")).toHaveAttribute(
754
- "data-slot",
755
- "avatar-fallback",
756
- );
757
- });
758
-
759
- it("applies custom className", () => {
760
- render(
761
- <Avatar>
762
- <AvatarFallback className="bg-primary" data-testid="fallback">
763
- AB
764
- </AvatarFallback>
765
- </Avatar>,
766
- );
767
- expect(screen.getByTestId("fallback")).toHaveClass("bg-primary");
768
- });
769
- });
770
- ```
771
-
772
- ### Testes de Acessibilidade
773
-
774
- ```tsx
775
- import { axe, toHaveNoViolations } from "jest-axe";
776
-
777
- expect.extend(toHaveNoViolations);
778
-
779
- describe("Avatar accessibility", () => {
780
- it("has no accessibility violations with proper alt", async () => {
781
- const { container } = render(
782
- <Avatar>
783
- <AvatarImage src="test.jpg" alt="Profile photo of John Doe" />
784
- <AvatarFallback>JD</AvatarFallback>
785
- </Avatar>,
786
- );
787
- const results = await axe(container);
788
- expect(results).toHaveNoViolations();
789
- });
790
-
791
- it("decorative avatar has no violations", async () => {
792
- const { container } = render(
793
- <Avatar aria-hidden="true">
794
- <AvatarImage src="test.jpg" alt="" />
795
- <AvatarFallback>JD</AvatarFallback>
796
- </Avatar>,
797
- );
798
- const results = await axe(container);
799
- expect(results).toHaveNoViolations();
800
- });
801
-
802
- it("avatar button has no violations", async () => {
803
- const { container } = render(
804
- <button aria-label="Open user menu">
805
- <Avatar>
806
- <AvatarImage src="test.jpg" alt="" />
807
- <AvatarFallback>JD</AvatarFallback>
808
- </Avatar>
809
- </button>,
810
- );
811
- const results = await axe(container);
812
- expect(results).toHaveNoViolations();
813
- });
814
- });
815
- ```
816
-
817
- ### Testes de Composicao
818
-
819
- ```tsx
820
- describe("Avatar composition", () => {
821
- it("renders avatar group correctly", () => {
822
- render(
823
- <div className="flex -space-x-3" data-testid="avatar-group">
824
- <Avatar>
825
- <AvatarFallback>A1</AvatarFallback>
826
- </Avatar>
827
- <Avatar>
828
- <AvatarFallback>A2</AvatarFallback>
829
- </Avatar>
830
- <Avatar>
831
- <AvatarFallback>+3</AvatarFallback>
832
- </Avatar>
833
- </div>,
834
- );
835
- expect(screen.getByText("A1")).toBeInTheDocument();
836
- expect(screen.getByText("A2")).toBeInTheDocument();
837
- expect(screen.getByText("+3")).toBeInTheDocument();
838
- });
839
-
840
- it("renders with status indicator", () => {
841
- render(
842
- <div className="relative">
843
- <Avatar>
844
- <AvatarFallback>AB</AvatarFallback>
845
- </Avatar>
846
- <span
847
- data-testid="status"
848
- className="bg-green-500"
849
- aria-label="Online"
850
- />
851
- </div>,
852
- );
853
- expect(screen.getByTestId("status")).toBeInTheDocument();
854
- expect(screen.getByLabelText("Online")).toBeInTheDocument();
855
- });
856
- });
857
- ```
858
-
859
- ### Cenarios Criticos
860
-
861
- ```tsx
862
- describe("Avatar edge cases", () => {
863
- it("handles missing image gracefully", () => {
864
- render(
865
- <Avatar>
866
- <AvatarImage src="" alt="Missing" />
867
- <AvatarFallback>FB</AvatarFallback>
868
- </Avatar>,
869
- );
870
- // Fallback should be visible when image fails
871
- expect(screen.getByText("FB")).toBeInTheDocument();
872
- });
873
-
874
- it("handles long initials", () => {
875
- render(
876
- <Avatar>
877
- <AvatarFallback>ABCDEF</AvatarFallback>
878
- </Avatar>,
879
- );
880
- expect(screen.getByText("ABCDEF")).toBeInTheDocument();
881
- });
882
-
883
- it("handles empty fallback", () => {
884
- render(
885
- <Avatar data-testid="avatar">
886
- <AvatarFallback data-testid="fallback" />
887
- </Avatar>,
888
- );
889
- expect(screen.getByTestId("fallback")).toBeInTheDocument();
890
- });
891
- });
892
- ```
893
-
894
- ---
895
-
896
- ## Features Implementadas
897
-
898
- Todas as features de alta prioridade foram implementadas:
899
-
900
- ### ✅ Prop `size`
901
-
902
- ```tsx
903
- <Avatar size="lg">...</Avatar>
904
- // Tamanhos: xs (24px), sm (32px), default (40px), lg (48px), xl (56px), 2xl (64px)
905
- ```
906
-
907
- ### ✅ Prop `shape`
908
-
909
- ```tsx
910
- <Avatar shape="square">...</Avatar>
911
- // Formas: circle (padrao), square
912
- ```
913
-
914
- ### ✅ Props `bordered`, `interactive`, `contrastBorder`
915
-
916
- ```tsx
917
- <Avatar bordered interactive contrastBorder>
918
- ...
919
- </Avatar>
920
- ```
921
-
922
- ### ✅ `AvatarStatus`
923
-
924
- ```tsx
925
- <Avatar>
926
- <AvatarImage src={url} alt="User" />
927
- <AvatarFallback>AB</AvatarFallback>
928
- <AvatarStatus status="online" size="default" />
929
- </Avatar>
930
- // Status: online, offline, busy, away
931
- ```
932
-
933
- ### ✅ `AvatarBadge`
934
-
935
- ```tsx
936
- <Avatar>
937
- <AvatarImage src={url} alt="User" />
938
- <AvatarFallback>AB</AvatarFallback>
939
- <AvatarBadge variant="verified" size="default" />
940
- </Avatar>
941
- // Variantes: company (purple), verified (blue)
942
- ```
943
-
944
- ### ✅ `AvatarGroup`
945
-
946
- ```tsx
947
- <AvatarGroup max={4} size="default" bordered>
948
- <Avatar>...</Avatar>
949
- <Avatar>...</Avatar>
950
- <Avatar>...</Avatar>
951
- <Avatar>...</Avatar>
952
- <Avatar>...</Avatar>
953
- </AvatarGroup>
954
- // Renderiza 4 avatares + "+1"
955
- ```
956
-
957
- ### ✅ `AvatarLabelGroup`
958
-
959
- ```tsx
960
- // Uso basico com status
961
- <AvatarLabelGroup
962
- src={url}
963
- name="Maria Silva"
964
- description="Software Engineer"
965
- status="online"
966
- size="default"
967
- />
968
- // Gera iniciais automaticamente: "MS"
969
-
970
- // Com badge de verificacao (company ou verified)
971
- <AvatarLabelGroup
972
- src={url}
973
- name="ETUS Corp"
974
- description="Empresa verificada"
975
- badge="company"
976
- size="default"
977
- />
978
-
979
- // Modo interativo (hover/focus states, clicavel)
980
- <AvatarLabelGroup
981
- src={url}
982
- name="Maria Silva"
983
- description="Clique para ver perfil"
984
- interactive
985
- onClick={(e) => console.log("Avatar clicado!")}
986
- />
987
- ```
988
-
989
- **Props disponiveis:**
990
-
991
- | Prop | Tipo | Padrao | Descricao |
992
- | ------------- | ---------------------------------------------------- | ----------- | ---------------------------------------------------- |
993
- | `name` | `string` | - | Nome (obrigatorio, usado para iniciais) |
994
- | `src` | `string` | - | URL da imagem |
995
- | `alt` | `string` | - | Texto alternativo (usa `name` se omitido) |
996
- | `description` | `string` | - | Texto secundario abaixo do nome |
997
- | `size` | `"xs" \| "sm" \| "default" \| "lg" \| "xl" \| "2xl"` | `"default"` | Tamanho do avatar |
998
- | `status` | `"online" \| "offline" \| "busy" \| "away"` | - | Indicador de presenca |
999
- | `badge` | `"company" \| "verified"` | - | Badge de verificacao (nao pode ser usado com status) |
1000
- | `interactive` | `boolean` | `false` | Habilita hover/focus states |
1001
- | `onClick` | `(e: MouseEvent) => void` | - | Handler de clique (usado com interactive) |
1002
- | `tooltip` | `string \| boolean` | - | Tooltip (true = usa name + description) |
1003
-
1004
- > **Nota:** `status` e `badge` sao mutuamente exclusivos. Se ambos forem fornecidos, `status` tem prioridade.
1005
-
1006
- ### ✅ `AvatarAddButton`
1007
-
1008
- ```tsx
1009
- <AvatarGroup>
1010
- <Avatar>...</Avatar>
1011
- <AvatarAddButton size="default" onClick={handleAdd} />
1012
- </AvatarGroup>
1013
- ```
1014
-
1015
- ### ✅ `colorScheme` (AvatarFallback)
1016
-
1017
- Customiza as cores do fallback usando tokens semanticos:
1018
-
1019
- ```tsx
1020
- <Avatar>
1021
- <AvatarImage src={url} alt="User" />
1022
- <AvatarFallback colorScheme="primary">AB</AvatarFallback>
1023
- </Avatar>
1024
-
1025
- // Todas as opcoes disponiveis
1026
- <AvatarFallback colorScheme="default">AB</AvatarFallback> // bg-muted (padrao)
1027
- <AvatarFallback colorScheme="primary">AB</AvatarFallback> // bg-primary
1028
- <AvatarFallback colorScheme="secondary">AB</AvatarFallback> // bg-secondary
1029
- <AvatarFallback colorScheme="success">AB</AvatarFallback> // bg-success
1030
- <AvatarFallback colorScheme="warning">AB</AvatarFallback> // bg-warning
1031
- <AvatarFallback colorScheme="destructive">AB</AvatarFallback> // bg-destructive
1032
- ```
1033
-
1034
- ### ✅ `tooltip` (Avatar e AvatarLabelGroup)
1035
-
1036
- Adiciona tooltip ao avatar ou label group:
1037
-
1038
- ```tsx
1039
- // Avatar com tooltip customizado
1040
- <Avatar tooltip="Maria Silva - Software Engineer">
1041
- <AvatarImage src={url} alt="Maria" />
1042
- <AvatarFallback>MS</AvatarFallback>
1043
- </Avatar>
1044
-
1045
- // AvatarLabelGroup com tooltip automatico (usa name + description)
1046
- <AvatarLabelGroup
1047
- name="Maria Silva"
1048
- description="Software Engineer"
1049
- tooltip // exibe "Maria Silva - Software Engineer"
1050
- />
1051
-
1052
- // AvatarLabelGroup com tooltip customizado
1053
- <AvatarLabelGroup
1054
- name="Maria Silva"
1055
- description="Software Engineer"
1056
- tooltip="Clique para ver perfil completo"
1057
- />
1058
- ```
1059
-
1060
- ### ✅ `AvatarSkeleton` e `AvatarLabelGroupSkeleton`
1061
-
1062
- Skeletons para loading states:
1063
-
1064
- ```tsx
1065
- import { AvatarSkeleton, AvatarLabelGroupSkeleton } from "@etus/ui";
1066
-
1067
- // Skeleton simples para Avatar
1068
- {
1069
- isLoading ? (
1070
- <AvatarSkeleton size="lg" shape="circle" />
1071
- ) : (
1072
- <Avatar size="lg">...</Avatar>
1073
- );
1074
- }
1075
-
1076
- // Skeleton para AvatarLabelGroup (inclui linhas de texto)
1077
- {
1078
- isLoading ? (
1079
- <AvatarLabelGroupSkeleton size="default" />
1080
- ) : (
1081
- <AvatarLabelGroup name="Maria Silva" description="Engineer" />
1082
- );
1083
- }
1084
-
1085
- // Em grupos
1086
- <AvatarGroup>
1087
- <AvatarSkeleton />
1088
- <AvatarSkeleton />
1089
- <AvatarSkeleton />
1090
- </AvatarGroup>;
1091
- ```
1092
-
1093
- ### ✅ Lazy Loading (Imagens)
1094
-
1095
- Use o atributo nativo `loading="lazy"` para otimizar listas longas:
1096
-
1097
- ```tsx
1098
- // Avatar com lazy loading
1099
- <Avatar>
1100
- <AvatarImage src={url} alt="User" loading="lazy" />
1101
- <AvatarFallback>AB</AvatarFallback>
1102
- </Avatar>;
1103
-
1104
- // Em listas longas (recomendado)
1105
- {
1106
- users.map((user) => (
1107
- <Avatar key={user.id}>
1108
- <AvatarImage
1109
- src={user.avatar}
1110
- alt={user.name}
1111
- loading="lazy" // carrega apenas quando visivel
1112
- />
1113
- <AvatarFallback>{getInitials(user.name)}</AvatarFallback>
1114
- </Avatar>
1115
- ));
1116
- }
1117
- ```
1118
-
1119
- > **Nota:** `loading="lazy"` e suportado nativamente em browsers modernos (Chrome 77+, Firefox 75+, Safari 15.4+).
1120
-
1121
- ## Roadmap / Features Futuras
1122
-
1123
- ### Implementado Recentemente
1124
-
1125
- | Feature | Versao | Descricao |
1126
- | ------------------------------ | ------ | ----------------------------------------------------- |
1127
- | `colorScheme` prop | v1.2 | Customizacao de cores do fallback |
1128
- | `tooltip` prop | v1.2 | Tooltip integrado em Avatar e AvatarLabelGroup |
1129
- | `AvatarSkeleton` | v1.2 | Skeleton loading para Avatar |
1130
- | `AvatarLabelGroupSkeleton` | v1.2 | Skeleton loading para AvatarLabelGroup |
1131
- | Lazy loading docs | v1.2 | Documentacao de loading="lazy" nativo |
1132
- | AvatarLabelGroup `badge` prop | v1.1 | Suporte a badge company/verified no label group |
1133
- | AvatarLabelGroup `interactive` | v1.1 | Modo interativo com hover/focus states |
1134
- | Tokens semanticos | v1.1 | Migracao para tokens (bg-success, bg-brius-500, etc.) |
1135
- | Contrast border | v1.0 | Borda sutil para definicao em fundos similares |
1136
-
1137
- ### Pendente
1138
-
1139
- | Feature | Prioridade | Justificativa |
1140
- | ------------------ | ---------- | -------------------------------------------------------- |
1141
- | Custom badge icons | P2 | Icones personalizados no badge (ja suporta via children) |
1142
-
1143
- **Legenda:** P1 = Alta | P2 = Media | P3 = Baixa
1144
-
1145
- ---
1146
-
1147
- ## Referências
1148
-
1149
- ### Design Systems Analisados
1150
-
1151
- | Design System | Documentacao Avatar | GitHub |
1152
- | -------------- | --------------------------------------------------------------------------- | ----------------------------------------------------------------------------- |
1153
- | **Shadcn/ui** | [Avatar](https://ui.shadcn.com/docs/components/avatar) | [shadcn-ui/ui](https://github.com/shadcn-ui/ui) |
1154
- | **Radix UI** | [Avatar](https://www.radix-ui.com/primitives/docs/components/avatar) | [radix-ui/primitives](https://github.com/radix-ui/primitives) |
1155
- | **Chakra UI** | [Avatar](https://chakra-ui.com/docs/components/avatar) | [chakra-ui/chakra-ui](https://github.com/chakra-ui/chakra-ui) |
1156
- | **MUI** | [Avatar](https://mui.com/material-ui/react-avatar/) | [mui/material-ui](https://github.com/mui/material-ui) |
1157
- | **Mantine** | [Avatar](https://mantine.dev/core/avatar/) | [mantinedev/mantine](https://github.com/mantinedev/mantine) |
1158
- | **Ant Design** | [Avatar](https://ant.design/components/avatar) | [ant-design/ant-design](https://github.com/ant-design/ant-design) |
1159
- | **NextUI** | [Avatar](https://nextui.org/docs/components/avatar) | [nextui-org/nextui](https://github.com/nextui-org/nextui) |
1160
- | **Fluent UI** | [Avatar](https://react.fluentui.dev/?path=/docs/components-avatar--default) | [microsoft/fluentui](https://github.com/microsoft/fluentui) |
1161
- | **Carbon** | [Avatar](https://carbondesignsystem.com/components/avatar/usage/) | [carbon-design-system/carbon](https://github.com/carbon-design-system/carbon) |
1162
-
1163
- ### Especificacoes e Padroes
1164
-
1165
- - [WAI-ARIA - Images](https://www.w3.org/WAI/tutorials/images/)
1166
- - [WCAG 2.1 - Non-text Content](https://www.w3.org/WAI/WCAG21/Understanding/non-text-content.html)
1167
- - [MDN - img Element](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/img)
1168
- - [Radix Avatar Primitive](https://www.radix-ui.com/primitives/docs/components/avatar)
1169
-
1170
- ### Ferramentas Utilizadas
1171
-
1172
- - [Radix UI Avatar](https://www.radix-ui.com/primitives/docs/components/avatar)
1173
- - [Tailwind CSS](https://tailwindcss.com/docs)
1174
- - [Lucide Icons](https://lucide.dev/icons/)