@fragments-sdk/ui 0.13.0 → 0.14.0

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 (656) hide show
  1. package/dist/assets/ui.css +1642 -1679
  2. package/dist/chart.cjs.map +1 -1
  3. package/dist/chart.js.map +1 -1
  4. package/dist/codeblock.cjs +26 -18
  5. package/dist/codeblock.cjs.map +1 -1
  6. package/dist/codeblock.js +26 -18
  7. package/dist/codeblock.js.map +1 -1
  8. package/dist/components/Accordion/Accordion.module.scss.cjs +8 -8
  9. package/dist/components/Accordion/Accordion.module.scss.js +8 -8
  10. package/dist/components/Accordion/index.cjs +7 -3
  11. package/dist/components/Accordion/index.cjs.map +1 -1
  12. package/dist/components/Accordion/index.d.ts +24 -11
  13. package/dist/components/Accordion/index.d.ts.map +1 -1
  14. package/dist/components/Accordion/index.js +7 -3
  15. package/dist/components/Accordion/index.js.map +1 -1
  16. package/dist/components/Alert/Alert.module.scss.cjs +12 -12
  17. package/dist/components/Alert/Alert.module.scss.js +12 -12
  18. package/dist/components/Alert/index.cjs +37 -15
  19. package/dist/components/Alert/index.cjs.map +1 -1
  20. package/dist/components/Alert/index.d.ts +15 -22
  21. package/dist/components/Alert/index.d.ts.map +1 -1
  22. package/dist/components/Alert/index.js +37 -15
  23. package/dist/components/Alert/index.js.map +1 -1
  24. package/dist/components/AppShell/AppShell.module.scss.cjs +14 -14
  25. package/dist/components/AppShell/AppShell.module.scss.js +14 -14
  26. package/dist/components/AppShell/index.cjs +3 -1
  27. package/dist/components/AppShell/index.cjs.map +1 -1
  28. package/dist/components/AppShell/index.d.ts.map +1 -1
  29. package/dist/components/AppShell/index.js +3 -1
  30. package/dist/components/AppShell/index.js.map +1 -1
  31. package/dist/components/Avatar/index.cjs +9 -1
  32. package/dist/components/Avatar/index.cjs.map +1 -1
  33. package/dist/components/Avatar/index.d.ts +2 -0
  34. package/dist/components/Avatar/index.d.ts.map +1 -1
  35. package/dist/components/Avatar/index.js +9 -1
  36. package/dist/components/Avatar/index.js.map +1 -1
  37. package/dist/components/Badge/index.cjs +4 -2
  38. package/dist/components/Badge/index.cjs.map +1 -1
  39. package/dist/components/Badge/index.d.ts +3 -0
  40. package/dist/components/Badge/index.d.ts.map +1 -1
  41. package/dist/components/Badge/index.js +4 -2
  42. package/dist/components/Badge/index.js.map +1 -1
  43. package/dist/components/BentoGrid/BentoGrid.module.scss.cjs +11 -11
  44. package/dist/components/BentoGrid/BentoGrid.module.scss.js +11 -11
  45. package/dist/components/BentoGrid/index.cjs +8 -5
  46. package/dist/components/BentoGrid/index.cjs.map +1 -1
  47. package/dist/components/BentoGrid/index.d.ts +2 -8
  48. package/dist/components/BentoGrid/index.d.ts.map +1 -1
  49. package/dist/components/BentoGrid/index.js +8 -5
  50. package/dist/components/BentoGrid/index.js.map +1 -1
  51. package/dist/components/Box/index.cjs +12 -2
  52. package/dist/components/Box/index.cjs.map +1 -1
  53. package/dist/components/Box/index.d.ts +1 -1
  54. package/dist/components/Box/index.d.ts.map +1 -1
  55. package/dist/components/Box/index.js +12 -2
  56. package/dist/components/Box/index.js.map +1 -1
  57. package/dist/components/Breadcrumbs/index.cjs +3 -1
  58. package/dist/components/Breadcrumbs/index.cjs.map +1 -1
  59. package/dist/components/Breadcrumbs/index.d.ts +3 -1
  60. package/dist/components/Breadcrumbs/index.d.ts.map +1 -1
  61. package/dist/components/Breadcrumbs/index.js +3 -1
  62. package/dist/components/Breadcrumbs/index.js.map +1 -1
  63. package/dist/components/Button/Button.module.scss.cjs +11 -11
  64. package/dist/components/Button/Button.module.scss.js +11 -11
  65. package/dist/components/Button/index.cjs +5 -2
  66. package/dist/components/Button/index.cjs.map +1 -1
  67. package/dist/components/Button/index.d.ts +3 -3
  68. package/dist/components/Button/index.d.ts.map +1 -1
  69. package/dist/components/Button/index.js +5 -2
  70. package/dist/components/Button/index.js.map +1 -1
  71. package/dist/components/ButtonGroup/index.cjs +3 -2
  72. package/dist/components/ButtonGroup/index.cjs.map +1 -1
  73. package/dist/components/ButtonGroup/index.d.ts +1 -2
  74. package/dist/components/ButtonGroup/index.d.ts.map +1 -1
  75. package/dist/components/ButtonGroup/index.js +3 -2
  76. package/dist/components/ButtonGroup/index.js.map +1 -1
  77. package/dist/components/Card/Card.module.scss.cjs +14 -14
  78. package/dist/components/Card/Card.module.scss.js +14 -14
  79. package/dist/components/Card/index.cjs +3 -22
  80. package/dist/components/Card/index.cjs.map +1 -1
  81. package/dist/components/Card/index.d.ts +6 -11
  82. package/dist/components/Card/index.d.ts.map +1 -1
  83. package/dist/components/Card/index.js +3 -22
  84. package/dist/components/Card/index.js.map +1 -1
  85. package/dist/components/Chart/Chart.module.scss.cjs +15 -15
  86. package/dist/components/Chart/Chart.module.scss.js +15 -15
  87. package/dist/components/Chart/index.d.ts +3 -3
  88. package/dist/components/Chart/index.d.ts.map +1 -1
  89. package/dist/components/Checkbox/Checkbox.module.scss.cjs +10 -10
  90. package/dist/components/Checkbox/Checkbox.module.scss.js +10 -10
  91. package/dist/components/Checkbox/index.cjs +11 -4
  92. package/dist/components/Checkbox/index.cjs.map +1 -1
  93. package/dist/components/Checkbox/index.d.ts +6 -0
  94. package/dist/components/Checkbox/index.d.ts.map +1 -1
  95. package/dist/components/Checkbox/index.js +11 -4
  96. package/dist/components/Checkbox/index.js.map +1 -1
  97. package/dist/components/Chip/index.cjs +11 -3
  98. package/dist/components/Chip/index.cjs.map +1 -1
  99. package/dist/components/Chip/index.d.ts +1 -2
  100. package/dist/components/Chip/index.d.ts.map +1 -1
  101. package/dist/components/Chip/index.js +11 -3
  102. package/dist/components/Chip/index.js.map +1 -1
  103. package/dist/components/CodeBlock/CodeBlock.module.scss.cjs +20 -20
  104. package/dist/components/CodeBlock/CodeBlock.module.scss.js +20 -20
  105. package/dist/components/CodeBlock/index.d.ts +8 -2
  106. package/dist/components/CodeBlock/index.d.ts.map +1 -1
  107. package/dist/components/Collapsible/Collapsible.module.scss.cjs +10 -10
  108. package/dist/components/Collapsible/Collapsible.module.scss.js +10 -10
  109. package/dist/components/Combobox/Combobox.module.scss.cjs +15 -15
  110. package/dist/components/Combobox/Combobox.module.scss.js +15 -15
  111. package/dist/components/Combobox/index.cjs +68 -18
  112. package/dist/components/Combobox/index.cjs.map +1 -1
  113. package/dist/components/Combobox/index.d.ts +32 -11
  114. package/dist/components/Combobox/index.d.ts.map +1 -1
  115. package/dist/components/Combobox/index.js +68 -18
  116. package/dist/components/Combobox/index.js.map +1 -1
  117. package/dist/components/Command/Command.module.scss.cjs +11 -11
  118. package/dist/components/Command/Command.module.scss.js +11 -11
  119. package/dist/components/Command/index.cjs +4 -4
  120. package/dist/components/Command/index.cjs.map +1 -1
  121. package/dist/components/Command/index.d.ts +1 -1
  122. package/dist/components/Command/index.d.ts.map +1 -1
  123. package/dist/components/Command/index.js +4 -4
  124. package/dist/components/Command/index.js.map +1 -1
  125. package/dist/components/ConversationList/ConversationList.module.scss.cjs +10 -10
  126. package/dist/components/ConversationList/ConversationList.module.scss.js +10 -10
  127. package/dist/components/ConversationList/index.cjs +6 -3
  128. package/dist/components/ConversationList/index.cjs.map +1 -1
  129. package/dist/components/ConversationList/index.d.ts +1 -1
  130. package/dist/components/ConversationList/index.d.ts.map +1 -1
  131. package/dist/components/ConversationList/index.js +6 -3
  132. package/dist/components/ConversationList/index.js.map +1 -1
  133. package/dist/components/DataTable/DataTable.module.scss.cjs +26 -26
  134. package/dist/components/DataTable/DataTable.module.scss.js +26 -26
  135. package/dist/components/DataTable/index.cjs +13 -4
  136. package/dist/components/DataTable/index.cjs.map +1 -1
  137. package/dist/components/DataTable/index.d.ts +7 -2
  138. package/dist/components/DataTable/index.d.ts.map +1 -1
  139. package/dist/components/DataTable/index.js +13 -4
  140. package/dist/components/DataTable/index.js.map +1 -1
  141. package/dist/components/DatePicker/DatePicker.module.scss.cjs +26 -26
  142. package/dist/components/DatePicker/DatePicker.module.scss.js +26 -26
  143. package/dist/components/DatePicker/index.d.ts +2 -2
  144. package/dist/components/DatePicker/index.d.ts.map +1 -1
  145. package/dist/components/Dialog/Dialog.module.scss.cjs +14 -14
  146. package/dist/components/Dialog/Dialog.module.scss.js +14 -14
  147. package/dist/components/Dialog/index.cjs +2 -1
  148. package/dist/components/Dialog/index.cjs.map +1 -1
  149. package/dist/components/Dialog/index.d.ts +20 -7
  150. package/dist/components/Dialog/index.d.ts.map +1 -1
  151. package/dist/components/Dialog/index.js +2 -1
  152. package/dist/components/Dialog/index.js.map +1 -1
  153. package/dist/components/Drawer/Drawer.module.scss.cjs +26 -26
  154. package/dist/components/Drawer/Drawer.module.scss.js +26 -26
  155. package/dist/components/Drawer/index.cjs +30 -3
  156. package/dist/components/Drawer/index.cjs.map +1 -1
  157. package/dist/components/Drawer/index.d.ts +3 -1
  158. package/dist/components/Drawer/index.d.ts.map +1 -1
  159. package/dist/components/Drawer/index.js +13 -3
  160. package/dist/components/Drawer/index.js.map +1 -1
  161. package/dist/components/Editor/Editor.module.scss.cjs +17 -17
  162. package/dist/components/Editor/Editor.module.scss.js +17 -17
  163. package/dist/components/Editor/index.cjs +32 -7
  164. package/dist/components/Editor/index.cjs.map +1 -1
  165. package/dist/components/Editor/index.d.ts +16 -3
  166. package/dist/components/Editor/index.d.ts.map +1 -1
  167. package/dist/components/Editor/index.js +32 -7
  168. package/dist/components/Editor/index.js.map +1 -1
  169. package/dist/components/EmptyState/EmptyState.module.scss.cjs +8 -8
  170. package/dist/components/EmptyState/EmptyState.module.scss.js +8 -8
  171. package/dist/components/EmptyState/index.cjs +12 -8
  172. package/dist/components/EmptyState/index.cjs.map +1 -1
  173. package/dist/components/EmptyState/index.d.ts +8 -12
  174. package/dist/components/EmptyState/index.d.ts.map +1 -1
  175. package/dist/components/EmptyState/index.js +12 -8
  176. package/dist/components/EmptyState/index.js.map +1 -1
  177. package/dist/components/Fieldset/index.cjs +2 -2
  178. package/dist/components/Fieldset/index.cjs.map +1 -1
  179. package/dist/components/Fieldset/index.d.ts +2 -3
  180. package/dist/components/Fieldset/index.d.ts.map +1 -1
  181. package/dist/components/Fieldset/index.js +2 -2
  182. package/dist/components/Fieldset/index.js.map +1 -1
  183. package/dist/components/Form/index.cjs +13 -13
  184. package/dist/components/Form/index.cjs.map +1 -1
  185. package/dist/components/Form/index.d.ts +5 -2
  186. package/dist/components/Form/index.d.ts.map +1 -1
  187. package/dist/components/Form/index.js +13 -13
  188. package/dist/components/Form/index.js.map +1 -1
  189. package/dist/components/Grid/Grid.module.scss.cjs +57 -57
  190. package/dist/components/Grid/Grid.module.scss.js +57 -57
  191. package/dist/components/Grid/index.cjs +7 -4
  192. package/dist/components/Grid/index.cjs.map +1 -1
  193. package/dist/components/Grid/index.d.ts +5 -3
  194. package/dist/components/Grid/index.d.ts.map +1 -1
  195. package/dist/components/Grid/index.js +7 -4
  196. package/dist/components/Grid/index.js.map +1 -1
  197. package/dist/components/Header/Header.module.scss.cjs +21 -21
  198. package/dist/components/Header/Header.module.scss.js +21 -21
  199. package/dist/components/Header/index.cjs +61 -23
  200. package/dist/components/Header/index.cjs.map +1 -1
  201. package/dist/components/Header/index.d.ts +27 -34
  202. package/dist/components/Header/index.d.ts.map +1 -1
  203. package/dist/components/Header/index.js +61 -23
  204. package/dist/components/Header/index.js.map +1 -1
  205. package/dist/components/Icon/index.cjs +11 -1
  206. package/dist/components/Icon/index.cjs.map +1 -1
  207. package/dist/components/Icon/index.d.ts +28 -9
  208. package/dist/components/Icon/index.d.ts.map +1 -1
  209. package/dist/components/Icon/index.js +11 -1
  210. package/dist/components/Icon/index.js.map +1 -1
  211. package/dist/components/Image/index.cjs +15 -4
  212. package/dist/components/Image/index.cjs.map +1 -1
  213. package/dist/components/Image/index.d.ts +7 -1
  214. package/dist/components/Image/index.d.ts.map +1 -1
  215. package/dist/components/Image/index.js +15 -4
  216. package/dist/components/Image/index.js.map +1 -1
  217. package/dist/components/Input/Input.module.scss.cjs +13 -13
  218. package/dist/components/Input/Input.module.scss.js +13 -13
  219. package/dist/components/Input/index.cjs +79 -31
  220. package/dist/components/Input/index.cjs.map +1 -1
  221. package/dist/components/Input/index.d.ts +17 -3
  222. package/dist/components/Input/index.d.ts.map +1 -1
  223. package/dist/components/Input/index.js +79 -31
  224. package/dist/components/Input/index.js.map +1 -1
  225. package/dist/components/Link/index.cjs +17 -0
  226. package/dist/components/Link/index.cjs.map +1 -1
  227. package/dist/components/Link/index.d.ts.map +1 -1
  228. package/dist/components/Link/index.js +17 -0
  229. package/dist/components/Link/index.js.map +1 -1
  230. package/dist/components/Listbox/Listbox.module.scss.cjs +8 -8
  231. package/dist/components/Listbox/Listbox.module.scss.js +8 -8
  232. package/dist/components/Listbox/index.cjs +10 -6
  233. package/dist/components/Listbox/index.cjs.map +1 -1
  234. package/dist/components/Listbox/index.d.ts +2 -2
  235. package/dist/components/Listbox/index.d.ts.map +1 -1
  236. package/dist/components/Listbox/index.js +10 -6
  237. package/dist/components/Listbox/index.js.map +1 -1
  238. package/dist/components/Markdown/Markdown.module.scss.cjs +1 -1
  239. package/dist/components/Markdown/Markdown.module.scss.js +1 -1
  240. package/dist/components/Markdown/index.d.ts +4 -2
  241. package/dist/components/Markdown/index.d.ts.map +1 -1
  242. package/dist/components/Menu/Menu.module.scss.cjs +13 -13
  243. package/dist/components/Menu/Menu.module.scss.js +13 -13
  244. package/dist/components/Menu/index.cjs +12 -1
  245. package/dist/components/Menu/index.cjs.map +1 -1
  246. package/dist/components/Menu/index.d.ts +9 -4
  247. package/dist/components/Menu/index.d.ts.map +1 -1
  248. package/dist/components/Menu/index.js +12 -1
  249. package/dist/components/Menu/index.js.map +1 -1
  250. package/dist/components/Message/Message.module.scss.cjs +18 -18
  251. package/dist/components/Message/Message.module.scss.js +18 -18
  252. package/dist/components/NavigationMenu/NavigationMenu.module.scss.cjs +28 -28
  253. package/dist/components/NavigationMenu/NavigationMenu.module.scss.js +28 -28
  254. package/dist/components/NavigationMenu/NavigationMenuContext.cjs.map +1 -1
  255. package/dist/components/NavigationMenu/NavigationMenuContext.d.ts +8 -0
  256. package/dist/components/NavigationMenu/NavigationMenuContext.d.ts.map +1 -1
  257. package/dist/components/NavigationMenu/NavigationMenuContext.js.map +1 -1
  258. package/dist/components/NavigationMenu/index.cjs +49 -10
  259. package/dist/components/NavigationMenu/index.cjs.map +1 -1
  260. package/dist/components/NavigationMenu/index.d.ts +5 -1
  261. package/dist/components/NavigationMenu/index.d.ts.map +1 -1
  262. package/dist/components/NavigationMenu/index.js +49 -10
  263. package/dist/components/NavigationMenu/index.js.map +1 -1
  264. package/dist/components/Pagination/index.cjs +37 -9
  265. package/dist/components/Pagination/index.cjs.map +1 -1
  266. package/dist/components/Pagination/index.d.ts +2 -3
  267. package/dist/components/Pagination/index.d.ts.map +1 -1
  268. package/dist/components/Pagination/index.js +37 -9
  269. package/dist/components/Pagination/index.js.map +1 -1
  270. package/dist/components/Popover/Popover.module.scss.cjs +10 -10
  271. package/dist/components/Popover/Popover.module.scss.js +10 -10
  272. package/dist/components/Popover/index.cjs +43 -2
  273. package/dist/components/Popover/index.cjs.map +1 -1
  274. package/dist/components/Popover/index.d.ts +16 -6
  275. package/dist/components/Popover/index.d.ts.map +1 -1
  276. package/dist/components/Popover/index.js +26 -2
  277. package/dist/components/Popover/index.js.map +1 -1
  278. package/dist/components/Progress/index.cjs +3 -1
  279. package/dist/components/Progress/index.cjs.map +1 -1
  280. package/dist/components/Progress/index.d.ts.map +1 -1
  281. package/dist/components/Progress/index.js +3 -1
  282. package/dist/components/Progress/index.js.map +1 -1
  283. package/dist/components/Prompt/Prompt.module.scss.cjs +14 -14
  284. package/dist/components/Prompt/Prompt.module.scss.js +14 -14
  285. package/dist/components/Prompt/index.cjs +14 -2
  286. package/dist/components/Prompt/index.cjs.map +1 -1
  287. package/dist/components/Prompt/index.d.ts +8 -5
  288. package/dist/components/Prompt/index.d.ts.map +1 -1
  289. package/dist/components/Prompt/index.js +14 -2
  290. package/dist/components/Prompt/index.js.map +1 -1
  291. package/dist/components/RadioGroup/index.cjs +14 -6
  292. package/dist/components/RadioGroup/index.cjs.map +1 -1
  293. package/dist/components/RadioGroup/index.d.ts +12 -2
  294. package/dist/components/RadioGroup/index.d.ts.map +1 -1
  295. package/dist/components/RadioGroup/index.js +14 -6
  296. package/dist/components/RadioGroup/index.js.map +1 -1
  297. package/dist/components/Select/Select.module.scss.cjs +10 -10
  298. package/dist/components/Select/Select.module.scss.js +10 -10
  299. package/dist/components/Select/index.cjs +37 -24
  300. package/dist/components/Select/index.cjs.map +1 -1
  301. package/dist/components/Select/index.d.ts +6 -2
  302. package/dist/components/Select/index.d.ts.map +1 -1
  303. package/dist/components/Select/index.js +37 -24
  304. package/dist/components/Select/index.js.map +1 -1
  305. package/dist/components/Sidebar/Sidebar.module.scss.cjs +42 -42
  306. package/dist/components/Sidebar/Sidebar.module.scss.js +42 -42
  307. package/dist/components/Sidebar/index.cjs +2 -2
  308. package/dist/components/Sidebar/index.cjs.map +1 -1
  309. package/dist/components/Sidebar/index.d.ts +3 -3
  310. package/dist/components/Sidebar/index.d.ts.map +1 -1
  311. package/dist/components/Sidebar/index.js +2 -2
  312. package/dist/components/Sidebar/index.js.map +1 -1
  313. package/dist/components/Skeleton/index.cjs +6 -3
  314. package/dist/components/Skeleton/index.cjs.map +1 -1
  315. package/dist/components/Skeleton/index.d.ts +3 -7
  316. package/dist/components/Skeleton/index.d.ts.map +1 -1
  317. package/dist/components/Skeleton/index.js +6 -3
  318. package/dist/components/Skeleton/index.js.map +1 -1
  319. package/dist/components/Slider/Slider.module.scss.cjs +13 -10
  320. package/dist/components/Slider/Slider.module.scss.cjs.map +1 -1
  321. package/dist/components/Slider/Slider.module.scss.js +13 -10
  322. package/dist/components/Slider/Slider.module.scss.js.map +1 -1
  323. package/dist/components/Slider/index.cjs +33 -1
  324. package/dist/components/Slider/index.cjs.map +1 -1
  325. package/dist/components/Slider/index.d.ts +2 -0
  326. package/dist/components/Slider/index.d.ts.map +1 -1
  327. package/dist/components/Slider/index.js +33 -1
  328. package/dist/components/Slider/index.js.map +1 -1
  329. package/dist/components/Stack/index.cjs +12 -2
  330. package/dist/components/Stack/index.cjs.map +1 -1
  331. package/dist/components/Stack/index.d.ts +3 -2
  332. package/dist/components/Stack/index.d.ts.map +1 -1
  333. package/dist/components/Stack/index.js +12 -2
  334. package/dist/components/Stack/index.js.map +1 -1
  335. package/dist/components/Table/Table.module.scss.cjs +16 -16
  336. package/dist/components/Table/Table.module.scss.js +16 -16
  337. package/dist/components/Table/index.d.ts +10 -4
  338. package/dist/components/Table/index.d.ts.map +1 -1
  339. package/dist/components/TableOfContents/index.cjs +8 -5
  340. package/dist/components/TableOfContents/index.cjs.map +1 -1
  341. package/dist/components/TableOfContents/index.d.ts +2 -2
  342. package/dist/components/TableOfContents/index.d.ts.map +1 -1
  343. package/dist/components/TableOfContents/index.js +8 -5
  344. package/dist/components/TableOfContents/index.js.map +1 -1
  345. package/dist/components/Tabs/Tabs.module.scss.cjs +9 -9
  346. package/dist/components/Tabs/Tabs.module.scss.js +9 -9
  347. package/dist/components/Tabs/index.cjs +9 -6
  348. package/dist/components/Tabs/index.cjs.map +1 -1
  349. package/dist/components/Tabs/index.d.ts +4 -1
  350. package/dist/components/Tabs/index.d.ts.map +1 -1
  351. package/dist/components/Tabs/index.js +9 -6
  352. package/dist/components/Tabs/index.js.map +1 -1
  353. package/dist/components/Textarea/index.cjs +61 -43
  354. package/dist/components/Textarea/index.cjs.map +1 -1
  355. package/dist/components/Textarea/index.d.ts +9 -1
  356. package/dist/components/Textarea/index.d.ts.map +1 -1
  357. package/dist/components/Textarea/index.js +61 -43
  358. package/dist/components/Textarea/index.js.map +1 -1
  359. package/dist/components/Theme/index.cjs +3 -1
  360. package/dist/components/Theme/index.cjs.map +1 -1
  361. package/dist/components/Theme/index.d.ts +2 -4
  362. package/dist/components/Theme/index.d.ts.map +1 -1
  363. package/dist/components/Theme/index.js +3 -1
  364. package/dist/components/Theme/index.js.map +1 -1
  365. package/dist/components/ThinkingIndicator/ThinkingIndicator.module.scss.cjs +22 -22
  366. package/dist/components/ThinkingIndicator/ThinkingIndicator.module.scss.js +22 -22
  367. package/dist/components/Toast/Toast.module.scss.cjs +20 -20
  368. package/dist/components/Toast/Toast.module.scss.js +20 -20
  369. package/dist/components/Toast/index.cjs +15 -14
  370. package/dist/components/Toast/index.cjs.map +1 -1
  371. package/dist/components/Toast/index.d.ts +9 -5
  372. package/dist/components/Toast/index.d.ts.map +1 -1
  373. package/dist/components/Toast/index.js +15 -14
  374. package/dist/components/Toast/index.js.map +1 -1
  375. package/dist/components/Toggle/Toggle.module.scss.cjs +11 -11
  376. package/dist/components/Toggle/Toggle.module.scss.js +11 -11
  377. package/dist/components/Toggle/index.cjs +1 -1
  378. package/dist/components/Toggle/index.cjs.map +1 -1
  379. package/dist/components/Toggle/index.js +1 -1
  380. package/dist/components/Toggle/index.js.map +1 -1
  381. package/dist/components/ToggleGroup/ToggleGroup.module.scss.cjs +17 -17
  382. package/dist/components/ToggleGroup/ToggleGroup.module.scss.js +17 -17
  383. package/dist/components/ToggleGroup/index.cjs +27 -8
  384. package/dist/components/ToggleGroup/index.cjs.map +1 -1
  385. package/dist/components/ToggleGroup/index.d.ts +8 -3
  386. package/dist/components/ToggleGroup/index.d.ts.map +1 -1
  387. package/dist/components/ToggleGroup/index.js +27 -8
  388. package/dist/components/ToggleGroup/index.js.map +1 -1
  389. package/dist/components/Tooltip/Tooltip.module.scss.cjs +3 -3
  390. package/dist/components/Tooltip/Tooltip.module.scss.js +3 -3
  391. package/dist/components/Tooltip/index.cjs +20 -4
  392. package/dist/components/Tooltip/index.cjs.map +1 -1
  393. package/dist/components/Tooltip/index.d.ts +3 -1
  394. package/dist/components/Tooltip/index.d.ts.map +1 -1
  395. package/dist/components/Tooltip/index.js +20 -4
  396. package/dist/components/Tooltip/index.js.map +1 -1
  397. package/dist/components/VisuallyHidden/index.cjs +10 -2
  398. package/dist/components/VisuallyHidden/index.cjs.map +1 -1
  399. package/dist/components/VisuallyHidden/index.d.ts +1 -1
  400. package/dist/components/VisuallyHidden/index.d.ts.map +1 -1
  401. package/dist/components/VisuallyHidden/index.js +10 -2
  402. package/dist/components/VisuallyHidden/index.js.map +1 -1
  403. package/dist/datepicker.cjs +8 -1
  404. package/dist/datepicker.cjs.map +1 -1
  405. package/dist/datepicker.js +8 -1
  406. package/dist/datepicker.js.map +1 -1
  407. package/dist/index.cjs.map +1 -1
  408. package/dist/index.d.ts +2 -1
  409. package/dist/index.d.ts.map +1 -1
  410. package/dist/index.js.map +1 -1
  411. package/dist/markdown.cjs +5 -5
  412. package/dist/markdown.cjs.map +1 -1
  413. package/dist/markdown.js +5 -5
  414. package/dist/markdown.js.map +1 -1
  415. package/dist/table.cjs +19 -3
  416. package/dist/table.cjs.map +1 -1
  417. package/dist/table.js +19 -3
  418. package/dist/table.js.map +1 -1
  419. package/fragments.json +1 -1
  420. package/package.json +2 -2
  421. package/src/blocks/AccountSettings.block.ts +1 -1
  422. package/src/blocks/ActivityFeed.block.ts +1 -1
  423. package/src/blocks/ActivityFeedSkeleton.block.ts +1 -1
  424. package/src/blocks/BlogEditor.block.ts +1 -1
  425. package/src/blocks/ChatInterface.block.ts +1 -1
  426. package/src/blocks/ChatMessages.block.ts +1 -1
  427. package/src/blocks/CheckoutForm.block.ts +1 -1
  428. package/src/blocks/CommandPalette.block.ts +1 -1
  429. package/src/blocks/ContactForm.block.ts +1 -1
  430. package/src/blocks/DashboardLayout.block.ts +1 -1
  431. package/src/blocks/DashboardPage.block.ts +1 -1
  432. package/src/blocks/DashboardSkeleton.block.ts +1 -1
  433. package/src/blocks/DataTable.block.ts +1 -1
  434. package/src/blocks/EmptyState.block.ts +1 -1
  435. package/src/blocks/FAQSection.block.ts +1 -1
  436. package/src/blocks/FeatureGrid.block.ts +1 -1
  437. package/src/blocks/HeroSection.block.ts +1 -1
  438. package/src/blocks/LoginForm.block.ts +1 -1
  439. package/src/blocks/NavigationHeader.block.ts +1 -1
  440. package/src/blocks/PaginatedTable.block.ts +1 -1
  441. package/src/blocks/PricingComparison.block.ts +1 -1
  442. package/src/blocks/ProductCard.block.ts +1 -1
  443. package/src/blocks/RegistrationForm.block.ts +1 -1
  444. package/src/blocks/SettingsDrawer.block.ts +1 -1
  445. package/src/blocks/SettingsPanel.block.ts +1 -1
  446. package/src/blocks/ShoppingCart.block.ts +1 -1
  447. package/src/blocks/StatsCard.block.ts +1 -1
  448. package/src/blocks/StatsCardSkeleton.block.ts +1 -1
  449. package/src/blocks/TableSkeleton.block.ts +1 -1
  450. package/src/blocks/ThinkingStates.block.ts +1 -1
  451. package/src/components/Accordion/Accordion.fragment.tsx +7 -7
  452. package/src/components/Accordion/Accordion.module.scss +2 -2
  453. package/src/components/Accordion/Accordion.test.tsx +8 -5
  454. package/src/components/Accordion/index.tsx +33 -13
  455. package/src/components/Alert/Alert.fragment.tsx +5 -1
  456. package/src/components/Alert/Alert.module.scss +1 -1
  457. package/src/components/Alert/Alert.test.tsx +25 -0
  458. package/src/components/Alert/index.tsx +49 -30
  459. package/src/components/AppShell/AppShell.fragment.tsx +1 -1
  460. package/src/components/AppShell/AppShell.module.scss +5 -5
  461. package/src/components/AppShell/AppShell.test.tsx +12 -0
  462. package/src/components/AppShell/index.tsx +2 -0
  463. package/src/components/Avatar/Avatar.fragment.tsx +7 -1
  464. package/src/components/Avatar/Avatar.test.tsx +24 -2
  465. package/src/components/Avatar/index.tsx +13 -1
  466. package/src/components/Badge/Badge.fragment.tsx +16 -1
  467. package/src/components/Badge/Badge.test.tsx +8 -1
  468. package/src/components/Badge/index.tsx +7 -2
  469. package/src/components/BentoGrid/BentoGrid.fragment.tsx +3 -1
  470. package/src/components/BentoGrid/BentoGrid.module.scss +52 -16
  471. package/src/components/BentoGrid/BentoGrid.test.tsx +20 -0
  472. package/src/components/BentoGrid/index.tsx +9 -12
  473. package/src/components/Box/Box.fragment.tsx +3 -1
  474. package/src/components/Box/Box.test.tsx +14 -0
  475. package/src/components/Box/index.tsx +8 -2
  476. package/src/components/Breadcrumbs/Breadcrumbs.fragment.tsx +19 -1
  477. package/src/components/Breadcrumbs/Breadcrumbs.test.tsx +13 -0
  478. package/src/components/Breadcrumbs/index.tsx +5 -1
  479. package/src/components/Button/Button.fragment.tsx +28 -6
  480. package/src/components/Button/Button.module.scss +3 -3
  481. package/src/components/Button/Button.test.tsx +11 -0
  482. package/src/components/Button/index.tsx +16 -6
  483. package/src/components/ButtonGroup/ButtonGroup.fragment.tsx +4 -2
  484. package/src/components/ButtonGroup/ButtonGroup.test.tsx +10 -0
  485. package/src/components/ButtonGroup/index.tsx +3 -3
  486. package/src/components/Card/Card.fragment.tsx +24 -9
  487. package/src/components/Card/Card.module.scss +8 -8
  488. package/src/components/Card/Card.test.tsx +4 -5
  489. package/src/components/Card/index.tsx +8 -38
  490. package/src/components/Chart/Chart.fragment.tsx +5 -3
  491. package/src/components/Chart/Chart.module.scss +1 -1
  492. package/src/components/Chart/index.tsx +12 -10
  493. package/src/components/Checkbox/Checkbox.fragment.tsx +27 -1
  494. package/src/components/Checkbox/Checkbox.module.scss +3 -3
  495. package/src/components/Checkbox/index.tsx +16 -3
  496. package/src/components/Chip/Chip.fragment.tsx +20 -3
  497. package/src/components/Chip/Chip.test.tsx +28 -0
  498. package/src/components/Chip/index.tsx +14 -6
  499. package/src/components/CodeBlock/CodeBlock.fragment.tsx +3 -1
  500. package/src/components/CodeBlock/CodeBlock.module.scss +9 -9
  501. package/src/components/CodeBlock/CodeBlock.test.tsx +21 -0
  502. package/src/components/CodeBlock/index.tsx +23 -9
  503. package/src/components/Collapsible/Collapsible.fragment.tsx +1 -1
  504. package/src/components/Collapsible/Collapsible.module.scss +1 -1
  505. package/src/components/ColorPicker/ColorPicker.fragment.tsx +1 -1
  506. package/src/components/Combobox/Combobox.fragment.tsx +63 -9
  507. package/src/components/Combobox/Combobox.module.scss +4 -7
  508. package/src/components/Combobox/Combobox.test.tsx +24 -3
  509. package/src/components/Combobox/index.tsx +117 -34
  510. package/src/components/Command/Command.fragment.tsx +3 -3
  511. package/src/components/Command/Command.module.scss +5 -5
  512. package/src/components/Command/Command.test.tsx +17 -0
  513. package/src/components/Command/index.tsx +8 -5
  514. package/src/components/ConversationList/ConversationList.fragment.tsx +4 -3
  515. package/src/components/ConversationList/ConversationList.module.scss +5 -5
  516. package/src/components/ConversationList/ConversationList.test.tsx +21 -0
  517. package/src/components/ConversationList/index.tsx +8 -4
  518. package/src/components/DataTable/DataTable.fragment.tsx +12 -2
  519. package/src/components/DataTable/DataTable.module.scss +3 -3
  520. package/src/components/DataTable/DataTable.test.tsx +23 -2
  521. package/src/components/DataTable/index.tsx +23 -5
  522. package/src/components/DatePicker/DatePicker.fragment.tsx +3 -1
  523. package/src/components/DatePicker/DatePicker.module.scss +1 -1
  524. package/src/components/DatePicker/DatePicker.test.tsx +17 -0
  525. package/src/components/DatePicker/index.tsx +9 -2
  526. package/src/components/Dialog/Dialog.fragment.tsx +28 -1
  527. package/src/components/Dialog/Dialog.module.scss +6 -6
  528. package/src/components/Dialog/index.tsx +25 -7
  529. package/src/components/Drawer/Drawer.fragment.tsx +4 -1
  530. package/src/components/Drawer/Drawer.module.scss +3 -3
  531. package/src/components/Drawer/Drawer.test.tsx +8 -0
  532. package/src/components/Drawer/index.tsx +15 -3
  533. package/src/components/Editor/Editor.fragment.tsx +10 -3
  534. package/src/components/Editor/Editor.module.scss +4 -4
  535. package/src/components/Editor/Editor.test.tsx +68 -1
  536. package/src/components/Editor/index.tsx +60 -9
  537. package/src/components/EmptyState/EmptyState.fragment.tsx +3 -1
  538. package/src/components/EmptyState/EmptyState.module.scss +3 -3
  539. package/src/components/EmptyState/EmptyState.test.tsx +18 -0
  540. package/src/components/EmptyState/index.tsx +16 -16
  541. package/src/components/Field/Field.fragment.tsx +1 -1
  542. package/src/components/Fieldset/Fieldset.fragment.tsx +3 -1
  543. package/src/components/Fieldset/Fieldset.test.tsx +14 -0
  544. package/src/components/Fieldset/index.tsx +3 -4
  545. package/src/components/Form/Form.fragment.tsx +12 -7
  546. package/src/components/Form/index.tsx +13 -17
  547. package/src/components/Grid/Grid.fragment.tsx +4 -3
  548. package/src/components/Grid/Grid.module.scss +3 -3
  549. package/src/components/Grid/index.tsx +11 -6
  550. package/src/components/Header/Header.fragment.tsx +31 -1
  551. package/src/components/Header/Header.module.scss +6 -6
  552. package/src/components/Header/Header.test.tsx +95 -1
  553. package/src/components/Header/index.tsx +95 -46
  554. package/src/components/Icon/Icon.fragment.tsx +21 -8
  555. package/src/components/Icon/Icon.test.tsx +27 -3
  556. package/src/components/Icon/index.tsx +39 -15
  557. package/src/components/Image/Image.fragment.tsx +15 -1
  558. package/src/components/Image/Image.test.tsx +32 -1
  559. package/src/components/Image/index.tsx +24 -4
  560. package/src/components/Input/Input.fragment.tsx +49 -1
  561. package/src/components/Input/Input.module.scss +4 -2
  562. package/src/components/Input/Input.test.tsx +3 -3
  563. package/src/components/Input/index.tsx +103 -37
  564. package/src/components/Link/Link.fragment.tsx +7 -6
  565. package/src/components/Link/Link.test.tsx +17 -1
  566. package/src/components/Link/index.tsx +22 -0
  567. package/src/components/List/List.fragment.tsx +1 -1
  568. package/src/components/Listbox/Listbox.fragment.tsx +3 -3
  569. package/src/components/Listbox/Listbox.module.scss +4 -4
  570. package/src/components/Listbox/Listbox.test.tsx +14 -0
  571. package/src/components/Listbox/index.tsx +12 -2
  572. package/src/components/Loading/Loading.fragment.tsx +1 -1
  573. package/src/components/Markdown/Markdown.fragment.tsx +5 -3
  574. package/src/components/Markdown/Markdown.module.scss +5 -5
  575. package/src/components/Markdown/Markdown.test.tsx +6 -0
  576. package/src/components/Markdown/index.tsx +12 -9
  577. package/src/components/Menu/Menu.fragment.tsx +19 -1
  578. package/src/components/Menu/Menu.module.scss +11 -11
  579. package/src/components/Menu/index.tsx +19 -7
  580. package/src/components/Message/Message.fragment.tsx +1 -1
  581. package/src/components/Message/Message.module.scss +3 -3
  582. package/src/components/NavigationMenu/NavigationMenu.fragment.tsx +9 -1
  583. package/src/components/NavigationMenu/NavigationMenu.module.scss +7 -7
  584. package/src/components/NavigationMenu/NavigationMenu.test.tsx +48 -0
  585. package/src/components/NavigationMenu/NavigationMenuContext.ts +14 -0
  586. package/src/components/NavigationMenu/index.tsx +70 -7
  587. package/src/components/Pagination/Pagination.fragment.tsx +4 -1
  588. package/src/components/Pagination/Pagination.test.tsx +39 -0
  589. package/src/components/Pagination/index.tsx +36 -10
  590. package/src/components/Popover/Popover.fragment.tsx +18 -1
  591. package/src/components/Popover/Popover.module.scss +13 -13
  592. package/src/components/Popover/index.tsx +33 -8
  593. package/src/components/Progress/Progress.fragment.tsx +3 -1
  594. package/src/components/Progress/Progress.test.tsx +8 -0
  595. package/src/components/Progress/index.tsx +9 -1
  596. package/src/components/Prompt/Prompt.fragment.tsx +4 -1
  597. package/src/components/Prompt/Prompt.module.scss +3 -3
  598. package/src/components/Prompt/Prompt.test.tsx +19 -0
  599. package/src/components/Prompt/index.tsx +24 -6
  600. package/src/components/RadioGroup/RadioGroup.fragment.tsx +31 -1
  601. package/src/components/RadioGroup/index.tsx +22 -3
  602. package/src/components/ScrollArea/ScrollArea.fragment.tsx +1 -1
  603. package/src/components/Select/Select.fragment.tsx +30 -3
  604. package/src/components/Select/Select.module.scss +3 -3
  605. package/src/components/Select/index.tsx +46 -33
  606. package/src/components/Separator/Separator.fragment.tsx +1 -1
  607. package/src/components/Sidebar/Sidebar.fragment.tsx +3 -1
  608. package/src/components/Sidebar/Sidebar.module.scss +20 -20
  609. package/src/components/Sidebar/Sidebar.test.tsx +25 -0
  610. package/src/components/Sidebar/index.tsx +7 -7
  611. package/src/components/Skeleton/Skeleton.fragment.tsx +3 -1
  612. package/src/components/Skeleton/Skeleton.test.tsx +12 -0
  613. package/src/components/Skeleton/index.tsx +6 -7
  614. package/src/components/Slider/Slider.fragment.tsx +21 -1
  615. package/src/components/Slider/Slider.module.scss +31 -0
  616. package/src/components/Slider/Slider.test.tsx +16 -0
  617. package/src/components/Slider/index.tsx +40 -1
  618. package/src/components/Stack/Stack.fragment.tsx +3 -1
  619. package/src/components/Stack/index.tsx +13 -6
  620. package/src/components/Table/Table.fragment.tsx +43 -2
  621. package/src/components/Table/Table.module.scss +2 -2
  622. package/src/components/Table/index.tsx +23 -5
  623. package/src/components/TableOfContents/TableOfContents.fragment.tsx +4 -2
  624. package/src/components/TableOfContents/TableOfContents.test.tsx +34 -9
  625. package/src/components/TableOfContents/index.tsx +9 -5
  626. package/src/components/Tabs/Tabs.fragment.tsx +33 -8
  627. package/src/components/Tabs/Tabs.module.scss +8 -8
  628. package/src/components/Tabs/index.tsx +22 -14
  629. package/src/components/Text/Text.fragment.tsx +1 -1
  630. package/src/components/Textarea/Textarea.fragment.tsx +27 -1
  631. package/src/components/Textarea/index.tsx +39 -14
  632. package/src/components/Theme/Theme.fragment.tsx +3 -1
  633. package/src/components/Theme/Theme.test.tsx +11 -0
  634. package/src/components/Theme/index.tsx +3 -3
  635. package/src/components/ThinkingIndicator/ThinkingIndicator.fragment.tsx +1 -1
  636. package/src/components/ThinkingIndicator/ThinkingIndicator.module.scss +1 -1
  637. package/src/components/Toast/Toast.fragment.tsx +6 -3
  638. package/src/components/Toast/Toast.module.scss +8 -6
  639. package/src/components/Toast/index.tsx +24 -20
  640. package/src/components/Toggle/Toggle.fragment.tsx +1 -1
  641. package/src/components/Toggle/Toggle.module.scss +61 -21
  642. package/src/components/Toggle/index.tsx +3 -3
  643. package/src/components/ToggleGroup/ToggleGroup.fragment.tsx +33 -8
  644. package/src/components/ToggleGroup/ToggleGroup.module.scss +3 -3
  645. package/src/components/ToggleGroup/index.tsx +29 -9
  646. package/src/components/Tooltip/Tooltip.fragment.tsx +16 -1
  647. package/src/components/Tooltip/Tooltip.module.scss +1 -1
  648. package/src/components/Tooltip/index.tsx +16 -1
  649. package/src/components/VisuallyHidden/VisuallyHidden.fragment.tsx +3 -1
  650. package/src/components/VisuallyHidden/VisuallyHidden.test.tsx +12 -0
  651. package/src/components/VisuallyHidden/index.tsx +7 -3
  652. package/src/index.ts +3 -2
  653. package/src/tokens/_computed.scss +1 -19
  654. package/src/tokens/_density.scss +0 -42
  655. package/src/tokens/_mixins.scss +4 -0
  656. package/src/tokens/_variables.scss +12 -114
@@ -7,10 +7,11 @@ function TableOfContentsRoot({
7
7
  title = "On This Page",
8
8
  hideTitle = false,
9
9
  className,
10
+ "aria-label": ariaLabel,
10
11
  ...htmlProps
11
12
  }) {
12
13
  const classes = [styles.root, className].filter(Boolean).join(" ");
13
- return /* @__PURE__ */ jsxs("nav", { "aria-label": label, className: classes, ...htmlProps, children: [
14
+ return /* @__PURE__ */ jsxs("nav", { ...htmlProps, "aria-label": ariaLabel ?? label, className: classes, children: [
14
15
  !hideTitle && /* @__PURE__ */ jsx(Text, { as: "p", variant: "section-label", className: styles.title, children: title }),
15
16
  /* @__PURE__ */ jsx("ul", { className: styles.list, children })
16
17
  ] });
@@ -22,6 +23,7 @@ function TableOfContentsItem({
22
23
  indent = false,
23
24
  className,
24
25
  onClick,
26
+ href: _href,
25
27
  ...htmlProps
26
28
  }) {
27
29
  const linkClasses = [
@@ -31,22 +33,23 @@ function TableOfContentsItem({
31
33
  className
32
34
  ].filter(Boolean).join(" ");
33
35
  const handleClick = (e) => {
36
+ onClick == null ? void 0 : onClick(e);
37
+ if (e.defaultPrevented) return;
34
38
  e.preventDefault();
35
39
  const el = document.getElementById(id);
36
40
  if (el) {
37
41
  el.scrollIntoView({ behavior: "smooth" });
38
- history.replaceState(null, "", `#${id}`);
42
+ window.history.replaceState(null, "", `#${id}`);
39
43
  }
40
- onClick == null ? void 0 : onClick(e);
41
44
  };
42
45
  return /* @__PURE__ */ jsx("li", { className: styles.item, children: /* @__PURE__ */ jsx(
43
46
  "a",
44
47
  {
48
+ ...htmlProps,
45
49
  href: `#${id}`,
46
50
  className: linkClasses,
47
51
  onClick: handleClick,
48
- "aria-current": active ? "true" : void 0,
49
- ...htmlProps,
52
+ "aria-current": active ? "location" : void 0,
50
53
  children
51
54
  }
52
55
  ) });
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sources":["../../../src/components/TableOfContents/index.tsx"],"sourcesContent":["'use client';\n\nimport * as React from 'react';\nimport styles from './TableOfContents.module.scss';\nimport { Text } from '../Text';\n\n// ============================================\n// Types\n// ============================================\n\nexport interface TableOfContentsProps extends React.HTMLAttributes<HTMLElement> {\n children: React.ReactNode;\n /** Label for the nav landmark (default: \"Table of contents\") */\n label?: string;\n /** Title displayed above the list (default: \"On This Page\") */\n title?: string;\n /** Hide the title */\n hideTitle?: boolean;\n}\n\nexport interface TableOfContentsItemProps extends Omit<React.AnchorHTMLAttributes<HTMLAnchorElement>, 'children'> {\n children: React.ReactNode;\n /** The heading ID to link to */\n id: string;\n /** Whether this item is currently active/visible */\n active?: boolean;\n /** Indent level — use for sub-headings (h3, h4, etc.) */\n indent?: boolean;\n}\n\n// ============================================\n// Components\n// ============================================\n\nfunction TableOfContentsRoot({\n children,\n label = 'Table of contents',\n title = 'On This Page',\n hideTitle = false,\n className,\n ...htmlProps\n}: TableOfContentsProps) {\n const classes = [styles.root, className].filter(Boolean).join(' ');\n\n return (\n <nav aria-label={label} className={classes} {...htmlProps}>\n {!hideTitle && (\n <Text as=\"p\" variant=\"section-label\" className={styles.title}>\n {title}\n </Text>\n )}\n <ul className={styles.list}>\n {children}\n </ul>\n </nav>\n );\n}\n\nfunction TableOfContentsItem({\n children,\n id,\n active = false,\n indent = false,\n className,\n onClick,\n ...htmlProps\n}: TableOfContentsItemProps) {\n const linkClasses = [\n styles.link,\n indent && styles.indent,\n active && styles.active,\n className,\n ].filter(Boolean).join(' ');\n\n const handleClick = (e: React.MouseEvent<HTMLAnchorElement>) => {\n e.preventDefault();\n const el = document.getElementById(id);\n if (el) {\n el.scrollIntoView({ behavior: 'smooth' });\n history.replaceState(null, '', `#${id}`);\n }\n onClick?.(e);\n };\n\n return (\n <li className={styles.item}>\n <a\n href={`#${id}`}\n className={linkClasses}\n onClick={handleClick}\n aria-current={active ? 'true' : undefined}\n {...htmlProps}\n >\n {children}\n </a>\n </li>\n );\n}\n\n// ============================================\n// Export compound component\n// ============================================\n\nexport const TableOfContents = Object.assign(TableOfContentsRoot, {\n Item: TableOfContentsItem,\n});\n\n// Re-export individual components\nexport { TableOfContentsRoot, TableOfContentsItem };\n"],"names":[],"mappings":";;;AAkCA,SAAS,oBAAoB;AAAA,EAC3B;AAAA,EACA,QAAQ;AAAA,EACR,QAAQ;AAAA,EACR,YAAY;AAAA,EACZ;AAAA,EACA,GAAG;AACL,GAAyB;AACvB,QAAM,UAAU,CAAC,OAAO,MAAM,SAAS,EAAE,OAAO,OAAO,EAAE,KAAK,GAAG;AAEjE,8BACG,OAAA,EAAI,cAAY,OAAO,WAAW,SAAU,GAAG,WAC7C,UAAA;AAAA,IAAA,CAAC,aACA,oBAAC,MAAA,EAAK,IAAG,KAAI,SAAQ,iBAAgB,WAAW,OAAO,OACpD,UAAA,MAAA,CACH;AAAA,IAEF,oBAAC,MAAA,EAAG,WAAW,OAAO,MACnB,SAAA,CACH;AAAA,EAAA,GACF;AAEJ;AAEA,SAAS,oBAAoB;AAAA,EAC3B;AAAA,EACA;AAAA,EACA,SAAS;AAAA,EACT,SAAS;AAAA,EACT;AAAA,EACA;AAAA,EACA,GAAG;AACL,GAA6B;AAC3B,QAAM,cAAc;AAAA,IAClB,OAAO;AAAA,IACP,UAAU,OAAO;AAAA,IACjB,UAAU,OAAO;AAAA,IACjB;AAAA,EAAA,EACA,OAAO,OAAO,EAAE,KAAK,GAAG;AAE1B,QAAM,cAAc,CAAC,MAA2C;AAC9D,MAAE,eAAA;AACF,UAAM,KAAK,SAAS,eAAe,EAAE;AACrC,QAAI,IAAI;AACN,SAAG,eAAe,EAAE,UAAU,SAAA,CAAU;AACxC,cAAQ,aAAa,MAAM,IAAI,IAAI,EAAE,EAAE;AAAA,IACzC;AACA,uCAAU;AAAA,EACZ;AAEA,SACE,oBAAC,MAAA,EAAG,WAAW,OAAO,MACpB,UAAA;AAAA,IAAC;AAAA,IAAA;AAAA,MACC,MAAM,IAAI,EAAE;AAAA,MACZ,WAAW;AAAA,MACX,SAAS;AAAA,MACT,gBAAc,SAAS,SAAS;AAAA,MAC/B,GAAG;AAAA,MAEH;AAAA,IAAA;AAAA,EAAA,GAEL;AAEJ;AAMO,MAAM,kBAAkB,OAAO,OAAO,qBAAqB;AAAA,EAChE,MAAM;AACR,CAAC;"}
1
+ {"version":3,"file":"index.js","sources":["../../../src/components/TableOfContents/index.tsx"],"sourcesContent":["'use client';\n\nimport * as React from 'react';\nimport styles from './TableOfContents.module.scss';\nimport { Text } from '../Text';\n\n// ============================================\n// Types\n// ============================================\n\nexport interface TableOfContentsProps extends React.HTMLAttributes<HTMLElement> {\n children: React.ReactNode;\n /** Label for the nav landmark (default: \"Table of contents\") */\n label?: string;\n /** Title displayed above the list (default: \"On This Page\") */\n title?: string;\n /** Hide the title */\n hideTitle?: boolean;\n}\n\nexport interface TableOfContentsItemProps extends Omit<React.AnchorHTMLAttributes<HTMLAnchorElement>, 'children'> {\n children: React.ReactNode;\n /** The heading ID to link to */\n id: string;\n /** Whether this item is currently active/visible */\n active?: boolean;\n /** Indent level — use for sub-headings (h3, h4, etc.) */\n indent?: boolean;\n}\n\n// ============================================\n// Components\n// ============================================\n\nfunction TableOfContentsRoot({\n children,\n label = 'Table of contents',\n title = 'On This Page',\n hideTitle = false,\n className,\n 'aria-label': ariaLabel,\n ...htmlProps\n}: TableOfContentsProps) {\n const classes = [styles.root, className].filter(Boolean).join(' ');\n\n return (\n <nav {...htmlProps} aria-label={ariaLabel ?? label} className={classes}>\n {!hideTitle && (\n <Text as=\"p\" variant=\"section-label\" className={styles.title}>\n {title}\n </Text>\n )}\n <ul className={styles.list}>\n {children}\n </ul>\n </nav>\n );\n}\n\nfunction TableOfContentsItem({\n children,\n id,\n active = false,\n indent = false,\n className,\n onClick,\n href: _href,\n ...htmlProps\n}: TableOfContentsItemProps) {\n const linkClasses = [\n styles.link,\n indent && styles.indent,\n active && styles.active,\n className,\n ].filter(Boolean).join(' ');\n\n const handleClick = (e: React.MouseEvent<HTMLAnchorElement>) => {\n onClick?.(e);\n if (e.defaultPrevented) return;\n\n e.preventDefault();\n const el = document.getElementById(id);\n if (el) {\n el.scrollIntoView({ behavior: 'smooth' });\n window.history.replaceState(null, '', `#${id}`);\n }\n };\n\n return (\n <li className={styles.item}>\n <a\n {...htmlProps}\n href={`#${id}`}\n className={linkClasses}\n onClick={handleClick}\n aria-current={active ? 'location' : undefined}\n >\n {children}\n </a>\n </li>\n );\n}\n\n// ============================================\n// Export compound component\n// ============================================\n\nexport const TableOfContents = Object.assign(TableOfContentsRoot, {\n Item: TableOfContentsItem,\n});\n\n// Re-export individual components\nexport { TableOfContentsRoot, TableOfContentsItem };\n"],"names":[],"mappings":";;;AAkCA,SAAS,oBAAoB;AAAA,EAC3B;AAAA,EACA,QAAQ;AAAA,EACR,QAAQ;AAAA,EACR,YAAY;AAAA,EACZ;AAAA,EACA,cAAc;AAAA,EACd,GAAG;AACL,GAAyB;AACvB,QAAM,UAAU,CAAC,OAAO,MAAM,SAAS,EAAE,OAAO,OAAO,EAAE,KAAK,GAAG;AAEjE,SACE,qBAAC,SAAK,GAAG,WAAW,cAAY,aAAa,OAAO,WAAW,SAC5D,UAAA;AAAA,IAAA,CAAC,aACA,oBAAC,MAAA,EAAK,IAAG,KAAI,SAAQ,iBAAgB,WAAW,OAAO,OACpD,UAAA,MAAA,CACH;AAAA,IAEF,oBAAC,MAAA,EAAG,WAAW,OAAO,MACnB,SAAA,CACH;AAAA,EAAA,GACF;AAEJ;AAEA,SAAS,oBAAoB;AAAA,EAC3B;AAAA,EACA;AAAA,EACA,SAAS;AAAA,EACT,SAAS;AAAA,EACT;AAAA,EACA;AAAA,EACA,MAAM;AAAA,EACN,GAAG;AACL,GAA6B;AAC3B,QAAM,cAAc;AAAA,IAClB,OAAO;AAAA,IACP,UAAU,OAAO;AAAA,IACjB,UAAU,OAAO;AAAA,IACjB;AAAA,EAAA,EACA,OAAO,OAAO,EAAE,KAAK,GAAG;AAE1B,QAAM,cAAc,CAAC,MAA2C;AAC9D,uCAAU;AACV,QAAI,EAAE,iBAAkB;AAExB,MAAE,eAAA;AACF,UAAM,KAAK,SAAS,eAAe,EAAE;AACrC,QAAI,IAAI;AACN,SAAG,eAAe,EAAE,UAAU,SAAA,CAAU;AACxC,aAAO,QAAQ,aAAa,MAAM,IAAI,IAAI,EAAE,EAAE;AAAA,IAChD;AAAA,EACF;AAEA,SACE,oBAAC,MAAA,EAAG,WAAW,OAAO,MACpB,UAAA;AAAA,IAAC;AAAA,IAAA;AAAA,MACE,GAAG;AAAA,MACJ,MAAM,IAAI,EAAE;AAAA,MACZ,WAAW;AAAA,MACX,SAAS;AAAA,MACT,gBAAc,SAAS,aAAa;AAAA,MAEnC;AAAA,IAAA;AAAA,EAAA,GAEL;AAEJ;AAMO,MAAM,kBAAkB,OAAO,OAAO,qBAAqB;AAAA,EAChE,MAAM;AACR,CAAC;"}
@@ -1,14 +1,14 @@
1
1
  "use strict";
2
2
  Object.defineProperties(exports, { __esModule: { value: true }, [Symbol.toStringTag]: { value: "Module" } });
3
- const root = "_root_165zt_1";
4
- const list = "_list_165zt_10";
5
- const listPills = "_listPills_165zt_26";
6
- const tab = "_tab_165zt_35";
7
- const tabUnderline = "_tabUnderline_165zt_83";
8
- const tabPills = "_tabPills_165zt_92";
9
- const indicator = "_indicator_165zt_106";
10
- const panel = "_panel_165zt_127";
11
- const panelFlush = "_panelFlush_165zt_140";
3
+ const root = "_root_1c6m7_1";
4
+ const list = "_list_1c6m7_10";
5
+ const listPills = "_listPills_1c6m7_26";
6
+ const tab = "_tab_1c6m7_35";
7
+ const tabUnderline = "_tabUnderline_1c6m7_83";
8
+ const tabPills = "_tabPills_1c6m7_92";
9
+ const indicator = "_indicator_1c6m7_106";
10
+ const panel = "_panel_1c6m7_127";
11
+ const panelFlush = "_panelFlush_1c6m7_140";
12
12
  const styles = {
13
13
  root,
14
14
  list,
@@ -1,12 +1,12 @@
1
- const root = "_root_165zt_1";
2
- const list = "_list_165zt_10";
3
- const listPills = "_listPills_165zt_26";
4
- const tab = "_tab_165zt_35";
5
- const tabUnderline = "_tabUnderline_165zt_83";
6
- const tabPills = "_tabPills_165zt_92";
7
- const indicator = "_indicator_165zt_106";
8
- const panel = "_panel_165zt_127";
9
- const panelFlush = "_panelFlush_165zt_140";
1
+ const root = "_root_1c6m7_1";
2
+ const list = "_list_1c6m7_10";
3
+ const listPills = "_listPills_1c6m7_26";
4
+ const tab = "_tab_1c6m7_35";
5
+ const tabUnderline = "_tabUnderline_1c6m7_83";
6
+ const tabPills = "_tabPills_1c6m7_92";
7
+ const indicator = "_indicator_1c6m7_106";
8
+ const panel = "_panel_1c6m7_127";
9
+ const panelFlush = "_panelFlush_1c6m7_140";
10
10
  const styles = {
11
11
  root,
12
12
  list,
@@ -28,11 +28,12 @@ function TabsRoot({
28
28
  value,
29
29
  onValueChange,
30
30
  orientation = "horizontal",
31
+ variant = "underline",
31
32
  className,
32
33
  ...htmlProps
33
34
  }) {
34
35
  const classes = [Tabs_module.default.root, className].filter(Boolean).join(" ");
35
- return /* @__PURE__ */ jsxRuntime.jsx(
36
+ return /* @__PURE__ */ jsxRuntime.jsx(TabsVariantContext.Provider, { value: variant, children: /* @__PURE__ */ jsxRuntime.jsx(
36
37
  tabs.Tabs.Root,
37
38
  {
38
39
  ...htmlProps,
@@ -43,19 +44,21 @@ function TabsRoot({
43
44
  className: classes,
44
45
  children
45
46
  }
46
- );
47
+ ) });
47
48
  }
48
49
  function TabsList({
49
50
  children,
50
- variant = "underline",
51
+ variant,
51
52
  className,
52
53
  ...htmlProps
53
54
  }) {
54
- const variantClass = variant === "pills" ? Tabs_module.default.listPills : Tabs_module.default.listUnderline;
55
+ const rootVariant = React__namespace.useContext(TabsVariantContext);
56
+ const resolvedVariant = variant ?? rootVariant;
57
+ const variantClass = resolvedVariant === "pills" ? Tabs_module.default.listPills : Tabs_module.default.listUnderline;
55
58
  const classes = [Tabs_module.default.list, variantClass, className].filter(Boolean).join(" ");
56
- return /* @__PURE__ */ jsxRuntime.jsx(TabsVariantContext.Provider, { value: variant, children: /* @__PURE__ */ jsxRuntime.jsxs(tabs.Tabs.List, { ...htmlProps, className: classes, children: [
59
+ return /* @__PURE__ */ jsxRuntime.jsx(TabsVariantContext.Provider, { value: resolvedVariant, children: /* @__PURE__ */ jsxRuntime.jsxs(tabs.Tabs.List, { ...htmlProps, className: classes, children: [
57
60
  children,
58
- variant === "underline" && /* @__PURE__ */ jsxRuntime.jsx(tabs.Tabs.Indicator, { className: Tabs_module.default.indicator })
61
+ resolvedVariant === "underline" && /* @__PURE__ */ jsxRuntime.jsx(tabs.Tabs.Indicator, { className: Tabs_module.default.indicator })
59
62
  ] }) });
60
63
  }
61
64
  function Tab({
@@ -1 +1 @@
1
- {"version":3,"file":"index.cjs","sources":["../../../src/components/Tabs/index.tsx"],"sourcesContent":["'use client';\n\nimport * as React from 'react';\nimport { Tabs as BaseTabs } from '@base-ui/react/tabs';\nimport styles from './Tabs.module.scss';\n\n// ============================================\n// Types\n// ============================================\n\nexport type TabValue = string;\n\n/**\n * Tabbed navigation for switching between content panels.\n * @see https://usefragments.com/components/tabs\n */\nexport interface TabsProps extends Omit<React.HTMLAttributes<HTMLDivElement>, 'defaultValue'> {\n children: React.ReactNode;\n /** Default active tab value (uncontrolled) */\n defaultValue?: TabValue;\n /** Controlled active tab value */\n value?: TabValue;\n /** Called when the active tab changes */\n onValueChange?: (value: TabValue) => void;\n /** Tab layout direction.\n * @default \"horizontal\" */\n orientation?: 'horizontal' | 'vertical';\n}\n\nexport interface TabsListProps extends React.HTMLAttributes<HTMLDivElement> {\n children: React.ReactNode;\n /** Tab list visual style.\n * @default \"underline\"\n * @see https://usefragments.com/components/tabs#variants */\n variant?: 'underline' | 'pills';\n}\n\nexport interface TabProps {\n children: React.ReactNode;\n value: TabValue;\n disabled?: boolean;\n className?: string;\n}\n\nexport interface TabsPanelProps extends React.HTMLAttributes<HTMLDivElement> {\n children: React.ReactNode;\n value: TabValue;\n keepMounted?: boolean;\n flush?: boolean;\n}\n\n// ============================================\n// Context for variant\n// ============================================\n\nconst TabsVariantContext = React.createContext<'underline' | 'pills'>('underline');\n\n// ============================================\n// Components\n// ============================================\n\nfunction TabsRoot({\n children,\n defaultValue,\n value,\n onValueChange,\n orientation = 'horizontal',\n className,\n ...htmlProps\n}: TabsProps) {\n const classes = [styles.root, className].filter(Boolean).join(' ');\n\n return (\n <BaseTabs.Root\n {...htmlProps}\n defaultValue={defaultValue}\n value={value}\n onValueChange={onValueChange}\n orientation={orientation}\n className={classes}\n >\n {children}\n </BaseTabs.Root>\n );\n}\n\nfunction TabsList({\n children,\n variant = 'underline',\n className,\n ...htmlProps\n}: TabsListProps) {\n const variantClass = variant === 'pills' ? styles.listPills : styles.listUnderline;\n const classes = [styles.list, variantClass, className].filter(Boolean).join(' ');\n\n return (\n <TabsVariantContext.Provider value={variant}>\n <BaseTabs.List {...htmlProps} className={classes}>\n {children}\n {variant === 'underline' && <BaseTabs.Indicator className={styles.indicator} />}\n </BaseTabs.List>\n </TabsVariantContext.Provider>\n );\n}\n\nfunction Tab({\n children,\n value,\n disabled,\n className,\n}: TabProps) {\n const variant = React.useContext(TabsVariantContext);\n const variantClass = variant === 'pills' ? styles.tabPills : styles.tabUnderline;\n const classes = [styles.tab, variantClass, className].filter(Boolean).join(' ');\n\n return (\n <BaseTabs.Tab value={value} disabled={disabled} className={classes}>\n {children}\n </BaseTabs.Tab>\n );\n}\n\nfunction TabsPanel({\n children,\n value,\n keepMounted = false,\n flush = false,\n className,\n ...htmlProps\n}: TabsPanelProps) {\n const classes = [\n styles.panel,\n flush && styles.panelFlush,\n className,\n ].filter(Boolean).join(' ');\n\n return (\n <BaseTabs.Panel {...htmlProps} value={value} keepMounted={keepMounted} className={classes}>\n {children}\n </BaseTabs.Panel>\n );\n}\n\n// ============================================\n// Export compound component\n// ============================================\n\nexport const Tabs = Object.assign(TabsRoot, {\n List: TabsList,\n Tab: Tab,\n Panel: TabsPanel,\n});\n\n// Re-export individual components\nexport { TabsRoot, TabsList, Tab, TabsPanel };\n"],"names":["React","styles","jsx","BaseTabs","jsxs"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;AAuDA,MAAM,qBAAqBA,iBAAM,cAAqC,WAAW;AAMjF,SAAS,SAAS;AAAA,EAChB;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA,cAAc;AAAA,EACd;AAAA,EACA,GAAG;AACL,GAAc;AACZ,QAAM,UAAU,CAACC,YAAAA,QAAO,MAAM,SAAS,EAAE,OAAO,OAAO,EAAE,KAAK,GAAG;AAEjE,SACEC,2BAAAA;AAAAA,IAACC,KAAAA,KAAS;AAAA,IAAT;AAAA,MACE,GAAG;AAAA,MACJ;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA,WAAW;AAAA,MAEV;AAAA,IAAA;AAAA,EAAA;AAGP;AAEA,SAAS,SAAS;AAAA,EAChB;AAAA,EACA,UAAU;AAAA,EACV;AAAA,EACA,GAAG;AACL,GAAkB;AAChB,QAAM,eAAe,YAAY,UAAUF,YAAAA,QAAO,YAAYA,YAAAA,QAAO;AACrE,QAAM,UAAU,CAACA,oBAAO,MAAM,cAAc,SAAS,EAAE,OAAO,OAAO,EAAE,KAAK,GAAG;AAE/E,SACEC,2BAAAA,IAAC,mBAAmB,UAAnB,EAA4B,OAAO,SAClC,UAAAE,2BAAAA,KAACD,KAAAA,KAAS,MAAT,EAAe,GAAG,WAAW,WAAW,SACtC,UAAA;AAAA,IAAA;AAAA,IACA,YAAY,eAAeD,2BAAAA,IAACC,KAAAA,KAAS,WAAT,EAAmB,WAAWF,YAAAA,QAAO,UAAA,CAAW;AAAA,EAAA,EAAA,CAC/E,EAAA,CACF;AAEJ;AAEA,SAAS,IAAI;AAAA,EACX;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACF,GAAa;AACX,QAAM,UAAUD,iBAAM,WAAW,kBAAkB;AACnD,QAAM,eAAe,YAAY,UAAUC,YAAAA,QAAO,WAAWA,YAAAA,QAAO;AACpE,QAAM,UAAU,CAACA,oBAAO,KAAK,cAAc,SAAS,EAAE,OAAO,OAAO,EAAE,KAAK,GAAG;AAE9E,SACEC,2BAAAA,IAACC,UAAS,KAAT,EAAa,OAAc,UAAoB,WAAW,SACxD,UACH;AAEJ;AAEA,SAAS,UAAU;AAAA,EACjB;AAAA,EACA;AAAA,EACA,cAAc;AAAA,EACd,QAAQ;AAAA,EACR;AAAA,EACA,GAAG;AACL,GAAmB;AACjB,QAAM,UAAU;AAAA,IACdF,YAAAA,QAAO;AAAA,IACP,SAASA,YAAAA,QAAO;AAAA,IAChB;AAAA,EAAA,EACA,OAAO,OAAO,EAAE,KAAK,GAAG;AAE1B,SACEC,+BAACC,KAAAA,KAAS,OAAT,EAAgB,GAAG,WAAW,OAAc,aAA0B,WAAW,SAC/E,SAAA,CACH;AAEJ;AAMO,MAAM,OAAO,OAAO,OAAO,UAAU;AAAA,EAC1C,MAAM;AAAA,EACN;AAAA,EACA,OAAO;AACT,CAAC;;;;;;"}
1
+ {"version":3,"file":"index.cjs","sources":["../../../src/components/Tabs/index.tsx"],"sourcesContent":["'use client';\n\nimport * as React from 'react';\nimport { Tabs as BaseTabs } from '@base-ui/react/tabs';\nimport styles from './Tabs.module.scss';\n\n// ============================================\n// Types\n// ============================================\n\nexport type TabValue = string;\n\n/**\n * Tabbed navigation for switching between content panels.\n * @see https://usefragments.com/components/tabs\n */\nexport interface TabsProps extends Omit<React.HTMLAttributes<HTMLDivElement>, 'defaultValue'> {\n children: React.ReactNode;\n /** Default active tab value (uncontrolled) */\n defaultValue?: TabValue;\n /** Controlled active tab value */\n value?: TabValue;\n /** Called when the active tab changes */\n onValueChange?: (value: TabValue) => void;\n /** Tab layout direction.\n * @default \"horizontal\" */\n orientation?: 'horizontal' | 'vertical';\n /** Tab list visual style (default for Tabs.List).\n * @default \"underline\" */\n variant?: 'underline' | 'pills';\n}\n\nexport interface TabsListProps extends React.HTMLAttributes<HTMLDivElement> {\n children: React.ReactNode;\n /** Tab list visual style.\n * @default \"underline\"\n * @see https://usefragments.com/components/tabs#variants */\n variant?: 'underline' | 'pills';\n}\n\nexport interface TabProps {\n children: React.ReactNode;\n value: TabValue;\n disabled?: boolean;\n className?: string;\n}\n\nexport interface TabsPanelProps extends React.HTMLAttributes<HTMLDivElement> {\n children: React.ReactNode;\n value: TabValue;\n keepMounted?: boolean;\n flush?: boolean;\n}\n\n// ============================================\n// Context for variant\n// ============================================\n\nconst TabsVariantContext = React.createContext<'underline' | 'pills'>('underline');\n\n// ============================================\n// Components\n// ============================================\n\nfunction TabsRoot({\n children,\n defaultValue,\n value,\n onValueChange,\n orientation = 'horizontal',\n variant = 'underline',\n className,\n ...htmlProps\n}: TabsProps) {\n const classes = [styles.root, className].filter(Boolean).join(' ');\n\n return (\n <TabsVariantContext.Provider value={variant}>\n <BaseTabs.Root\n {...htmlProps}\n defaultValue={defaultValue}\n value={value}\n onValueChange={onValueChange}\n orientation={orientation}\n className={classes}\n >\n {children}\n </BaseTabs.Root>\n </TabsVariantContext.Provider>\n );\n}\n\nfunction TabsList({\n children,\n variant,\n className,\n ...htmlProps\n}: TabsListProps) {\n const rootVariant = React.useContext(TabsVariantContext);\n const resolvedVariant = variant ?? rootVariant;\n const variantClass = resolvedVariant === 'pills' ? styles.listPills : styles.listUnderline;\n const classes = [styles.list, variantClass, className].filter(Boolean).join(' ');\n\n return (\n <TabsVariantContext.Provider value={resolvedVariant}>\n <BaseTabs.List {...htmlProps} className={classes}>\n {children}\n {resolvedVariant === 'underline' && <BaseTabs.Indicator className={styles.indicator} />}\n </BaseTabs.List>\n </TabsVariantContext.Provider>\n );\n}\n\nfunction Tab({\n children,\n value,\n disabled,\n className,\n}: TabProps) {\n const variant = React.useContext(TabsVariantContext);\n const variantClass = variant === 'pills' ? styles.tabPills : styles.tabUnderline;\n const classes = [styles.tab, variantClass, className].filter(Boolean).join(' ');\n\n return (\n <BaseTabs.Tab value={value} disabled={disabled} className={classes}>\n {children}\n </BaseTabs.Tab>\n );\n}\n\nfunction TabsPanel({\n children,\n value,\n keepMounted = false,\n flush = false,\n className,\n ...htmlProps\n}: TabsPanelProps) {\n const classes = [\n styles.panel,\n flush && styles.panelFlush,\n className,\n ].filter(Boolean).join(' ');\n\n return (\n <BaseTabs.Panel {...htmlProps} value={value} keepMounted={keepMounted} className={classes}>\n {children}\n </BaseTabs.Panel>\n );\n}\n\n// ============================================\n// Export compound component\n// ============================================\n\nexport const Tabs = Object.assign(TabsRoot, {\n List: TabsList,\n Tab: Tab,\n Panel: TabsPanel,\n});\n\n// Re-export individual components\nexport { TabsRoot, TabsList, Tab, TabsPanel };\n"],"names":["React","styles","jsx","BaseTabs","jsxs"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;AA0DA,MAAM,qBAAqBA,iBAAM,cAAqC,WAAW;AAMjF,SAAS,SAAS;AAAA,EAChB;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA,cAAc;AAAA,EACd,UAAU;AAAA,EACV;AAAA,EACA,GAAG;AACL,GAAc;AACZ,QAAM,UAAU,CAACC,YAAAA,QAAO,MAAM,SAAS,EAAE,OAAO,OAAO,EAAE,KAAK,GAAG;AAEjE,SACEC,2BAAAA,IAAC,mBAAmB,UAAnB,EAA4B,OAAO,SAClC,UAAAA,2BAAAA;AAAAA,IAACC,KAAAA,KAAS;AAAA,IAAT;AAAA,MACE,GAAG;AAAA,MACJ;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA,WAAW;AAAA,MAEV;AAAA,IAAA;AAAA,EAAA,GAEL;AAEJ;AAEA,SAAS,SAAS;AAAA,EAChB;AAAA,EACA;AAAA,EACA;AAAA,EACA,GAAG;AACL,GAAkB;AAChB,QAAM,cAAcH,iBAAM,WAAW,kBAAkB;AACvD,QAAM,kBAAkB,WAAW;AACnC,QAAM,eAAe,oBAAoB,UAAUC,YAAAA,QAAO,YAAYA,YAAAA,QAAO;AAC7E,QAAM,UAAU,CAACA,oBAAO,MAAM,cAAc,SAAS,EAAE,OAAO,OAAO,EAAE,KAAK,GAAG;AAE/E,SACEC,2BAAAA,IAAC,mBAAmB,UAAnB,EAA4B,OAAO,iBAClC,UAAAE,2BAAAA,KAACD,KAAAA,KAAS,MAAT,EAAe,GAAG,WAAW,WAAW,SACtC,UAAA;AAAA,IAAA;AAAA,IACA,oBAAoB,eAAeD,2BAAAA,IAACC,KAAAA,KAAS,WAAT,EAAmB,WAAWF,YAAAA,QAAO,UAAA,CAAW;AAAA,EAAA,EAAA,CACvF,EAAA,CACF;AAEJ;AAEA,SAAS,IAAI;AAAA,EACX;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACF,GAAa;AACX,QAAM,UAAUD,iBAAM,WAAW,kBAAkB;AACnD,QAAM,eAAe,YAAY,UAAUC,YAAAA,QAAO,WAAWA,YAAAA,QAAO;AACpE,QAAM,UAAU,CAACA,oBAAO,KAAK,cAAc,SAAS,EAAE,OAAO,OAAO,EAAE,KAAK,GAAG;AAE9E,SACEC,2BAAAA,IAACC,UAAS,KAAT,EAAa,OAAc,UAAoB,WAAW,SACxD,UACH;AAEJ;AAEA,SAAS,UAAU;AAAA,EACjB;AAAA,EACA;AAAA,EACA,cAAc;AAAA,EACd,QAAQ;AAAA,EACR;AAAA,EACA,GAAG;AACL,GAAmB;AACjB,QAAM,UAAU;AAAA,IACdF,YAAAA,QAAO;AAAA,IACP,SAASA,YAAAA,QAAO;AAAA,IAChB;AAAA,EAAA,EACA,OAAO,OAAO,EAAE,KAAK,GAAG;AAE1B,SACEC,+BAACC,KAAAA,KAAS,OAAT,EAAgB,GAAG,WAAW,OAAc,aAA0B,WAAW,SAC/E,SAAA,CACH;AAEJ;AAMO,MAAM,OAAO,OAAO,OAAO,UAAU;AAAA,EAC1C,MAAM;AAAA,EACN;AAAA,EACA,OAAO;AACT,CAAC;;;;;;"}
@@ -15,6 +15,9 @@ export interface TabsProps extends Omit<React.HTMLAttributes<HTMLDivElement>, 'd
15
15
  /** Tab layout direction.
16
16
  * @default "horizontal" */
17
17
  orientation?: 'horizontal' | 'vertical';
18
+ /** Tab list visual style (default for Tabs.List).
19
+ * @default "underline" */
20
+ variant?: 'underline' | 'pills';
18
21
  }
19
22
  export interface TabsListProps extends React.HTMLAttributes<HTMLDivElement> {
20
23
  children: React.ReactNode;
@@ -35,7 +38,7 @@ export interface TabsPanelProps extends React.HTMLAttributes<HTMLDivElement> {
35
38
  keepMounted?: boolean;
36
39
  flush?: boolean;
37
40
  }
38
- declare function TabsRoot({ children, defaultValue, value, onValueChange, orientation, className, ...htmlProps }: TabsProps): import("react/jsx-runtime").JSX.Element;
41
+ declare function TabsRoot({ children, defaultValue, value, onValueChange, orientation, variant, className, ...htmlProps }: TabsProps): import("react/jsx-runtime").JSX.Element;
39
42
  declare function TabsList({ children, variant, className, ...htmlProps }: TabsListProps): import("react/jsx-runtime").JSX.Element;
40
43
  declare function Tab({ children, value, disabled, className, }: TabProps): import("react/jsx-runtime").JSX.Element;
41
44
  declare function TabsPanel({ children, value, keepMounted, flush, className, ...htmlProps }: TabsPanelProps): import("react/jsx-runtime").JSX.Element;
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/components/Tabs/index.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAQ/B,MAAM,MAAM,QAAQ,GAAG,MAAM,CAAC;AAE9B;;;GAGG;AACH,MAAM,WAAW,SAAU,SAAQ,IAAI,CAAC,KAAK,CAAC,cAAc,CAAC,cAAc,CAAC,EAAE,cAAc,CAAC;IAC3F,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC;IAC1B,8CAA8C;IAC9C,YAAY,CAAC,EAAE,QAAQ,CAAC;IACxB,kCAAkC;IAClC,KAAK,CAAC,EAAE,QAAQ,CAAC;IACjB,yCAAyC;IACzC,aAAa,CAAC,EAAE,CAAC,KAAK,EAAE,QAAQ,KAAK,IAAI,CAAC;IAC1C;+BAC2B;IAC3B,WAAW,CAAC,EAAE,YAAY,GAAG,UAAU,CAAC;CACzC;AAED,MAAM,WAAW,aAAc,SAAQ,KAAK,CAAC,cAAc,CAAC,cAAc,CAAC;IACzE,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC;IAC1B;;gEAE4D;IAC5D,OAAO,CAAC,EAAE,WAAW,GAAG,OAAO,CAAC;CACjC;AAED,MAAM,WAAW,QAAQ;IACvB,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC;IAC1B,KAAK,EAAE,QAAQ,CAAC;IAChB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AAED,MAAM,WAAW,cAAe,SAAQ,KAAK,CAAC,cAAc,CAAC,cAAc,CAAC;IAC1E,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC;IAC1B,KAAK,EAAE,QAAQ,CAAC;IAChB,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,KAAK,CAAC,EAAE,OAAO,CAAC;CACjB;AAYD,iBAAS,QAAQ,CAAC,EAChB,QAAQ,EACR,YAAY,EACZ,KAAK,EACL,aAAa,EACb,WAA0B,EAC1B,SAAS,EACT,GAAG,SAAS,EACb,EAAE,SAAS,2CAeX;AAED,iBAAS,QAAQ,CAAC,EAChB,QAAQ,EACR,OAAqB,EACrB,SAAS,EACT,GAAG,SAAS,EACb,EAAE,aAAa,2CAYf;AAED,iBAAS,GAAG,CAAC,EACX,QAAQ,EACR,KAAK,EACL,QAAQ,EACR,SAAS,GACV,EAAE,QAAQ,2CAUV;AAED,iBAAS,SAAS,CAAC,EACjB,QAAQ,EACR,KAAK,EACL,WAAmB,EACnB,KAAa,EACb,SAAS,EACT,GAAG,SAAS,EACb,EAAE,cAAc,2CAYhB;AAMD,eAAO,MAAM,IAAI;;;;CAIf,CAAC;AAGH,OAAO,EAAE,QAAQ,EAAE,QAAQ,EAAE,GAAG,EAAE,SAAS,EAAE,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/components/Tabs/index.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAQ/B,MAAM,MAAM,QAAQ,GAAG,MAAM,CAAC;AAE9B;;;GAGG;AACH,MAAM,WAAW,SAAU,SAAQ,IAAI,CAAC,KAAK,CAAC,cAAc,CAAC,cAAc,CAAC,EAAE,cAAc,CAAC;IAC3F,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC;IAC1B,8CAA8C;IAC9C,YAAY,CAAC,EAAE,QAAQ,CAAC;IACxB,kCAAkC;IAClC,KAAK,CAAC,EAAE,QAAQ,CAAC;IACjB,yCAAyC;IACzC,aAAa,CAAC,EAAE,CAAC,KAAK,EAAE,QAAQ,KAAK,IAAI,CAAC;IAC1C;+BAC2B;IAC3B,WAAW,CAAC,EAAE,YAAY,GAAG,UAAU,CAAC;IACxC;8BAC0B;IAC1B,OAAO,CAAC,EAAE,WAAW,GAAG,OAAO,CAAC;CACjC;AAED,MAAM,WAAW,aAAc,SAAQ,KAAK,CAAC,cAAc,CAAC,cAAc,CAAC;IACzE,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC;IAC1B;;gEAE4D;IAC5D,OAAO,CAAC,EAAE,WAAW,GAAG,OAAO,CAAC;CACjC;AAED,MAAM,WAAW,QAAQ;IACvB,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC;IAC1B,KAAK,EAAE,QAAQ,CAAC;IAChB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AAED,MAAM,WAAW,cAAe,SAAQ,KAAK,CAAC,cAAc,CAAC,cAAc,CAAC;IAC1E,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC;IAC1B,KAAK,EAAE,QAAQ,CAAC;IAChB,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,KAAK,CAAC,EAAE,OAAO,CAAC;CACjB;AAYD,iBAAS,QAAQ,CAAC,EAChB,QAAQ,EACR,YAAY,EACZ,KAAK,EACL,aAAa,EACb,WAA0B,EAC1B,OAAqB,EACrB,SAAS,EACT,GAAG,SAAS,EACb,EAAE,SAAS,2CAiBX;AAED,iBAAS,QAAQ,CAAC,EAChB,QAAQ,EACR,OAAO,EACP,SAAS,EACT,GAAG,SAAS,EACb,EAAE,aAAa,2CAcf;AAED,iBAAS,GAAG,CAAC,EACX,QAAQ,EACR,KAAK,EACL,QAAQ,EACR,SAAS,GACV,EAAE,QAAQ,2CAUV;AAED,iBAAS,SAAS,CAAC,EACjB,QAAQ,EACR,KAAK,EACL,WAAmB,EACnB,KAAa,EACb,SAAS,EACT,GAAG,SAAS,EACb,EAAE,cAAc,2CAYhB;AAMD,eAAO,MAAM,IAAI;;;;CAIf,CAAC;AAGH,OAAO,EAAE,QAAQ,EAAE,QAAQ,EAAE,GAAG,EAAE,SAAS,EAAE,CAAC"}
@@ -9,11 +9,12 @@ function TabsRoot({
9
9
  value,
10
10
  onValueChange,
11
11
  orientation = "horizontal",
12
+ variant = "underline",
12
13
  className,
13
14
  ...htmlProps
14
15
  }) {
15
16
  const classes = [styles.root, className].filter(Boolean).join(" ");
16
- return /* @__PURE__ */ jsx(
17
+ return /* @__PURE__ */ jsx(TabsVariantContext.Provider, { value: variant, children: /* @__PURE__ */ jsx(
17
18
  Tabs$1.Root,
18
19
  {
19
20
  ...htmlProps,
@@ -24,19 +25,21 @@ function TabsRoot({
24
25
  className: classes,
25
26
  children
26
27
  }
27
- );
28
+ ) });
28
29
  }
29
30
  function TabsList({
30
31
  children,
31
- variant = "underline",
32
+ variant,
32
33
  className,
33
34
  ...htmlProps
34
35
  }) {
35
- const variantClass = variant === "pills" ? styles.listPills : styles.listUnderline;
36
+ const rootVariant = React.useContext(TabsVariantContext);
37
+ const resolvedVariant = variant ?? rootVariant;
38
+ const variantClass = resolvedVariant === "pills" ? styles.listPills : styles.listUnderline;
36
39
  const classes = [styles.list, variantClass, className].filter(Boolean).join(" ");
37
- return /* @__PURE__ */ jsx(TabsVariantContext.Provider, { value: variant, children: /* @__PURE__ */ jsxs(Tabs$1.List, { ...htmlProps, className: classes, children: [
40
+ return /* @__PURE__ */ jsx(TabsVariantContext.Provider, { value: resolvedVariant, children: /* @__PURE__ */ jsxs(Tabs$1.List, { ...htmlProps, className: classes, children: [
38
41
  children,
39
- variant === "underline" && /* @__PURE__ */ jsx(Tabs$1.Indicator, { className: styles.indicator })
42
+ resolvedVariant === "underline" && /* @__PURE__ */ jsx(Tabs$1.Indicator, { className: styles.indicator })
40
43
  ] }) });
41
44
  }
42
45
  function Tab({
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sources":["../../../src/components/Tabs/index.tsx"],"sourcesContent":["'use client';\n\nimport * as React from 'react';\nimport { Tabs as BaseTabs } from '@base-ui/react/tabs';\nimport styles from './Tabs.module.scss';\n\n// ============================================\n// Types\n// ============================================\n\nexport type TabValue = string;\n\n/**\n * Tabbed navigation for switching between content panels.\n * @see https://usefragments.com/components/tabs\n */\nexport interface TabsProps extends Omit<React.HTMLAttributes<HTMLDivElement>, 'defaultValue'> {\n children: React.ReactNode;\n /** Default active tab value (uncontrolled) */\n defaultValue?: TabValue;\n /** Controlled active tab value */\n value?: TabValue;\n /** Called when the active tab changes */\n onValueChange?: (value: TabValue) => void;\n /** Tab layout direction.\n * @default \"horizontal\" */\n orientation?: 'horizontal' | 'vertical';\n}\n\nexport interface TabsListProps extends React.HTMLAttributes<HTMLDivElement> {\n children: React.ReactNode;\n /** Tab list visual style.\n * @default \"underline\"\n * @see https://usefragments.com/components/tabs#variants */\n variant?: 'underline' | 'pills';\n}\n\nexport interface TabProps {\n children: React.ReactNode;\n value: TabValue;\n disabled?: boolean;\n className?: string;\n}\n\nexport interface TabsPanelProps extends React.HTMLAttributes<HTMLDivElement> {\n children: React.ReactNode;\n value: TabValue;\n keepMounted?: boolean;\n flush?: boolean;\n}\n\n// ============================================\n// Context for variant\n// ============================================\n\nconst TabsVariantContext = React.createContext<'underline' | 'pills'>('underline');\n\n// ============================================\n// Components\n// ============================================\n\nfunction TabsRoot({\n children,\n defaultValue,\n value,\n onValueChange,\n orientation = 'horizontal',\n className,\n ...htmlProps\n}: TabsProps) {\n const classes = [styles.root, className].filter(Boolean).join(' ');\n\n return (\n <BaseTabs.Root\n {...htmlProps}\n defaultValue={defaultValue}\n value={value}\n onValueChange={onValueChange}\n orientation={orientation}\n className={classes}\n >\n {children}\n </BaseTabs.Root>\n );\n}\n\nfunction TabsList({\n children,\n variant = 'underline',\n className,\n ...htmlProps\n}: TabsListProps) {\n const variantClass = variant === 'pills' ? styles.listPills : styles.listUnderline;\n const classes = [styles.list, variantClass, className].filter(Boolean).join(' ');\n\n return (\n <TabsVariantContext.Provider value={variant}>\n <BaseTabs.List {...htmlProps} className={classes}>\n {children}\n {variant === 'underline' && <BaseTabs.Indicator className={styles.indicator} />}\n </BaseTabs.List>\n </TabsVariantContext.Provider>\n );\n}\n\nfunction Tab({\n children,\n value,\n disabled,\n className,\n}: TabProps) {\n const variant = React.useContext(TabsVariantContext);\n const variantClass = variant === 'pills' ? styles.tabPills : styles.tabUnderline;\n const classes = [styles.tab, variantClass, className].filter(Boolean).join(' ');\n\n return (\n <BaseTabs.Tab value={value} disabled={disabled} className={classes}>\n {children}\n </BaseTabs.Tab>\n );\n}\n\nfunction TabsPanel({\n children,\n value,\n keepMounted = false,\n flush = false,\n className,\n ...htmlProps\n}: TabsPanelProps) {\n const classes = [\n styles.panel,\n flush && styles.panelFlush,\n className,\n ].filter(Boolean).join(' ');\n\n return (\n <BaseTabs.Panel {...htmlProps} value={value} keepMounted={keepMounted} className={classes}>\n {children}\n </BaseTabs.Panel>\n );\n}\n\n// ============================================\n// Export compound component\n// ============================================\n\nexport const Tabs = Object.assign(TabsRoot, {\n List: TabsList,\n Tab: Tab,\n Panel: TabsPanel,\n});\n\n// Re-export individual components\nexport { TabsRoot, TabsList, Tab, TabsPanel };\n"],"names":["BaseTabs"],"mappings":";;;;AAuDA,MAAM,qBAAqB,MAAM,cAAqC,WAAW;AAMjF,SAAS,SAAS;AAAA,EAChB;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA,cAAc;AAAA,EACd;AAAA,EACA,GAAG;AACL,GAAc;AACZ,QAAM,UAAU,CAAC,OAAO,MAAM,SAAS,EAAE,OAAO,OAAO,EAAE,KAAK,GAAG;AAEjE,SACE;AAAA,IAACA,OAAS;AAAA,IAAT;AAAA,MACE,GAAG;AAAA,MACJ;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA,WAAW;AAAA,MAEV;AAAA,IAAA;AAAA,EAAA;AAGP;AAEA,SAAS,SAAS;AAAA,EAChB;AAAA,EACA,UAAU;AAAA,EACV;AAAA,EACA,GAAG;AACL,GAAkB;AAChB,QAAM,eAAe,YAAY,UAAU,OAAO,YAAY,OAAO;AACrE,QAAM,UAAU,CAAC,OAAO,MAAM,cAAc,SAAS,EAAE,OAAO,OAAO,EAAE,KAAK,GAAG;AAE/E,SACE,oBAAC,mBAAmB,UAAnB,EAA4B,OAAO,SAClC,UAAA,qBAACA,OAAS,MAAT,EAAe,GAAG,WAAW,WAAW,SACtC,UAAA;AAAA,IAAA;AAAA,IACA,YAAY,eAAe,oBAACA,OAAS,WAAT,EAAmB,WAAW,OAAO,UAAA,CAAW;AAAA,EAAA,EAAA,CAC/E,EAAA,CACF;AAEJ;AAEA,SAAS,IAAI;AAAA,EACX;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACF,GAAa;AACX,QAAM,UAAU,MAAM,WAAW,kBAAkB;AACnD,QAAM,eAAe,YAAY,UAAU,OAAO,WAAW,OAAO;AACpE,QAAM,UAAU,CAAC,OAAO,KAAK,cAAc,SAAS,EAAE,OAAO,OAAO,EAAE,KAAK,GAAG;AAE9E,SACE,oBAACA,OAAS,KAAT,EAAa,OAAc,UAAoB,WAAW,SACxD,UACH;AAEJ;AAEA,SAAS,UAAU;AAAA,EACjB;AAAA,EACA;AAAA,EACA,cAAc;AAAA,EACd,QAAQ;AAAA,EACR;AAAA,EACA,GAAG;AACL,GAAmB;AACjB,QAAM,UAAU;AAAA,IACd,OAAO;AAAA,IACP,SAAS,OAAO;AAAA,IAChB;AAAA,EAAA,EACA,OAAO,OAAO,EAAE,KAAK,GAAG;AAE1B,SACE,oBAACA,OAAS,OAAT,EAAgB,GAAG,WAAW,OAAc,aAA0B,WAAW,SAC/E,SAAA,CACH;AAEJ;AAMO,MAAM,OAAO,OAAO,OAAO,UAAU;AAAA,EAC1C,MAAM;AAAA,EACN;AAAA,EACA,OAAO;AACT,CAAC;"}
1
+ {"version":3,"file":"index.js","sources":["../../../src/components/Tabs/index.tsx"],"sourcesContent":["'use client';\n\nimport * as React from 'react';\nimport { Tabs as BaseTabs } from '@base-ui/react/tabs';\nimport styles from './Tabs.module.scss';\n\n// ============================================\n// Types\n// ============================================\n\nexport type TabValue = string;\n\n/**\n * Tabbed navigation for switching between content panels.\n * @see https://usefragments.com/components/tabs\n */\nexport interface TabsProps extends Omit<React.HTMLAttributes<HTMLDivElement>, 'defaultValue'> {\n children: React.ReactNode;\n /** Default active tab value (uncontrolled) */\n defaultValue?: TabValue;\n /** Controlled active tab value */\n value?: TabValue;\n /** Called when the active tab changes */\n onValueChange?: (value: TabValue) => void;\n /** Tab layout direction.\n * @default \"horizontal\" */\n orientation?: 'horizontal' | 'vertical';\n /** Tab list visual style (default for Tabs.List).\n * @default \"underline\" */\n variant?: 'underline' | 'pills';\n}\n\nexport interface TabsListProps extends React.HTMLAttributes<HTMLDivElement> {\n children: React.ReactNode;\n /** Tab list visual style.\n * @default \"underline\"\n * @see https://usefragments.com/components/tabs#variants */\n variant?: 'underline' | 'pills';\n}\n\nexport interface TabProps {\n children: React.ReactNode;\n value: TabValue;\n disabled?: boolean;\n className?: string;\n}\n\nexport interface TabsPanelProps extends React.HTMLAttributes<HTMLDivElement> {\n children: React.ReactNode;\n value: TabValue;\n keepMounted?: boolean;\n flush?: boolean;\n}\n\n// ============================================\n// Context for variant\n// ============================================\n\nconst TabsVariantContext = React.createContext<'underline' | 'pills'>('underline');\n\n// ============================================\n// Components\n// ============================================\n\nfunction TabsRoot({\n children,\n defaultValue,\n value,\n onValueChange,\n orientation = 'horizontal',\n variant = 'underline',\n className,\n ...htmlProps\n}: TabsProps) {\n const classes = [styles.root, className].filter(Boolean).join(' ');\n\n return (\n <TabsVariantContext.Provider value={variant}>\n <BaseTabs.Root\n {...htmlProps}\n defaultValue={defaultValue}\n value={value}\n onValueChange={onValueChange}\n orientation={orientation}\n className={classes}\n >\n {children}\n </BaseTabs.Root>\n </TabsVariantContext.Provider>\n );\n}\n\nfunction TabsList({\n children,\n variant,\n className,\n ...htmlProps\n}: TabsListProps) {\n const rootVariant = React.useContext(TabsVariantContext);\n const resolvedVariant = variant ?? rootVariant;\n const variantClass = resolvedVariant === 'pills' ? styles.listPills : styles.listUnderline;\n const classes = [styles.list, variantClass, className].filter(Boolean).join(' ');\n\n return (\n <TabsVariantContext.Provider value={resolvedVariant}>\n <BaseTabs.List {...htmlProps} className={classes}>\n {children}\n {resolvedVariant === 'underline' && <BaseTabs.Indicator className={styles.indicator} />}\n </BaseTabs.List>\n </TabsVariantContext.Provider>\n );\n}\n\nfunction Tab({\n children,\n value,\n disabled,\n className,\n}: TabProps) {\n const variant = React.useContext(TabsVariantContext);\n const variantClass = variant === 'pills' ? styles.tabPills : styles.tabUnderline;\n const classes = [styles.tab, variantClass, className].filter(Boolean).join(' ');\n\n return (\n <BaseTabs.Tab value={value} disabled={disabled} className={classes}>\n {children}\n </BaseTabs.Tab>\n );\n}\n\nfunction TabsPanel({\n children,\n value,\n keepMounted = false,\n flush = false,\n className,\n ...htmlProps\n}: TabsPanelProps) {\n const classes = [\n styles.panel,\n flush && styles.panelFlush,\n className,\n ].filter(Boolean).join(' ');\n\n return (\n <BaseTabs.Panel {...htmlProps} value={value} keepMounted={keepMounted} className={classes}>\n {children}\n </BaseTabs.Panel>\n );\n}\n\n// ============================================\n// Export compound component\n// ============================================\n\nexport const Tabs = Object.assign(TabsRoot, {\n List: TabsList,\n Tab: Tab,\n Panel: TabsPanel,\n});\n\n// Re-export individual components\nexport { TabsRoot, TabsList, Tab, TabsPanel };\n"],"names":["BaseTabs"],"mappings":";;;;AA0DA,MAAM,qBAAqB,MAAM,cAAqC,WAAW;AAMjF,SAAS,SAAS;AAAA,EAChB;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA,cAAc;AAAA,EACd,UAAU;AAAA,EACV;AAAA,EACA,GAAG;AACL,GAAc;AACZ,QAAM,UAAU,CAAC,OAAO,MAAM,SAAS,EAAE,OAAO,OAAO,EAAE,KAAK,GAAG;AAEjE,SACE,oBAAC,mBAAmB,UAAnB,EAA4B,OAAO,SAClC,UAAA;AAAA,IAACA,OAAS;AAAA,IAAT;AAAA,MACE,GAAG;AAAA,MACJ;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA,WAAW;AAAA,MAEV;AAAA,IAAA;AAAA,EAAA,GAEL;AAEJ;AAEA,SAAS,SAAS;AAAA,EAChB;AAAA,EACA;AAAA,EACA;AAAA,EACA,GAAG;AACL,GAAkB;AAChB,QAAM,cAAc,MAAM,WAAW,kBAAkB;AACvD,QAAM,kBAAkB,WAAW;AACnC,QAAM,eAAe,oBAAoB,UAAU,OAAO,YAAY,OAAO;AAC7E,QAAM,UAAU,CAAC,OAAO,MAAM,cAAc,SAAS,EAAE,OAAO,OAAO,EAAE,KAAK,GAAG;AAE/E,SACE,oBAAC,mBAAmB,UAAnB,EAA4B,OAAO,iBAClC,UAAA,qBAACA,OAAS,MAAT,EAAe,GAAG,WAAW,WAAW,SACtC,UAAA;AAAA,IAAA;AAAA,IACA,oBAAoB,eAAe,oBAACA,OAAS,WAAT,EAAmB,WAAW,OAAO,UAAA,CAAW;AAAA,EAAA,EAAA,CACvF,EAAA,CACF;AAEJ;AAEA,SAAS,IAAI;AAAA,EACX;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACF,GAAa;AACX,QAAM,UAAU,MAAM,WAAW,kBAAkB;AACnD,QAAM,eAAe,YAAY,UAAU,OAAO,WAAW,OAAO;AACpE,QAAM,UAAU,CAAC,OAAO,KAAK,cAAc,SAAS,EAAE,OAAO,OAAO,EAAE,KAAK,GAAG;AAE9E,SACE,oBAACA,OAAS,KAAT,EAAa,OAAc,UAAoB,WAAW,SACxD,UACH;AAEJ;AAEA,SAAS,UAAU;AAAA,EACjB;AAAA,EACA;AAAA,EACA,cAAc;AAAA,EACd,QAAQ;AAAA,EACR;AAAA,EACA,GAAG;AACL,GAAmB;AACjB,QAAM,UAAU;AAAA,IACd,OAAO;AAAA,IACP,SAAS,OAAO;AAAA,IAChB;AAAA,EAAA,EACA,OAAO,OAAO,EAAE,KAAK,GAAG;AAE1B,SACE,oBAACA,OAAS,OAAT,EAAgB,GAAG,WAAW,OAAc,aAA0B,WAAW,SAC/E,SAAA,CACH;AAEJ;AAMO,MAAM,OAAO,OAAO,OAAO,UAAU;AAAA,EAC1C,MAAM;AAAA,EACN;AAAA,EACA,OAAO;AACT,CAAC;"}
@@ -38,18 +38,24 @@ const TextareaRoot = React__namespace.forwardRef(
38
38
  label,
39
39
  helperText,
40
40
  onChange,
41
+ onValueChange,
41
42
  onBlur,
43
+ rootProps,
42
44
  className,
43
- name,
44
- id,
45
- maxLength,
46
- required = false,
47
- "aria-label": ariaLabel,
48
- "aria-labelledby": ariaLabelledBy,
49
- "aria-describedby": ariaDescribedBy,
50
- ...htmlProps
45
+ style: wrapperStyle,
46
+ ...textareaProps
51
47
  }, ref) {
52
48
  const generatedId = React__namespace.useId();
49
+ const {
50
+ id,
51
+ name,
52
+ maxLength,
53
+ required = false,
54
+ "aria-label": ariaLabel,
55
+ "aria-labelledby": ariaLabelledBy,
56
+ "aria-describedby": ariaDescribedBy,
57
+ ...nativeTextareaProps
58
+ } = textareaProps;
53
59
  const textareaId = id || generatedId;
54
60
  const labelId = label ? `${textareaId}-label` : void 0;
55
61
  const helperId = `${textareaId}-helper`;
@@ -59,46 +65,58 @@ const TextareaRoot = React__namespace.forwardRef(
59
65
  Textarea_module.default[`resize-${resize}`]
60
66
  ].filter(Boolean).join(" ");
61
67
  const helperClasses = [Textarea_module.default.helper, error && Textarea_module.default.helperError].filter(Boolean).join(" ");
62
- const style = {};
68
+ const textareaInlineStyle = {};
63
69
  if (minRows) {
64
- style.minHeight = `calc(${minRows} * 1.5em + 1.5rem)`;
70
+ textareaInlineStyle.minHeight = `calc(${minRows} * 1.5em + 1.5rem)`;
65
71
  }
66
72
  if (maxRows) {
67
- style.maxHeight = `calc(${maxRows} * 1.5em + 1.5rem)`;
73
+ textareaInlineStyle.maxHeight = `calc(${maxRows} * 1.5em + 1.5rem)`;
68
74
  }
69
- return /* @__PURE__ */ jsxRuntime.jsxs("div", { ...htmlProps, className: [Textarea_module.default.wrapper, className].filter(Boolean).join(" "), children: [
70
- label && /* @__PURE__ */ jsxRuntime.jsxs("label", { id: labelId, htmlFor: textareaId, className: Textarea_module.default.label, children: [
71
- label,
72
- required && /* @__PURE__ */ jsxRuntime.jsx("span", { className: Textarea_module.default.required, children: "*" })
73
- ] }),
74
- /* @__PURE__ */ jsxRuntime.jsx(
75
- "textarea",
76
- {
77
- ref,
78
- id: textareaId,
79
- value,
80
- defaultValue,
81
- placeholder,
82
- rows,
83
- name,
84
- maxLength,
85
- disabled,
86
- required,
87
- "aria-label": ariaLabel,
88
- "aria-labelledby": mergeAriaIds(ariaLabelledBy, labelId),
89
- "aria-invalid": error || void 0,
90
- "aria-describedby": mergeAriaIds(
91
- ariaDescribedBy,
92
- helperText ? helperId : void 0
75
+ return /* @__PURE__ */ jsxRuntime.jsxs(
76
+ "div",
77
+ {
78
+ ...rootProps,
79
+ className: [Textarea_module.default.wrapper, rootProps == null ? void 0 : rootProps.className, className].filter(Boolean).join(" "),
80
+ style: { ...(rootProps == null ? void 0 : rootProps.style) ?? {}, ...wrapperStyle ?? {} },
81
+ children: [
82
+ label && /* @__PURE__ */ jsxRuntime.jsxs("label", { id: labelId, htmlFor: textareaId, className: Textarea_module.default.label, children: [
83
+ label,
84
+ required && /* @__PURE__ */ jsxRuntime.jsx("span", { className: Textarea_module.default.required, children: "*" })
85
+ ] }),
86
+ /* @__PURE__ */ jsxRuntime.jsx(
87
+ "textarea",
88
+ {
89
+ ref,
90
+ id: textareaId,
91
+ value,
92
+ defaultValue,
93
+ placeholder,
94
+ rows,
95
+ ...nativeTextareaProps,
96
+ name,
97
+ maxLength,
98
+ disabled,
99
+ required,
100
+ "aria-label": ariaLabel,
101
+ "aria-labelledby": mergeAriaIds(ariaLabelledBy, labelId),
102
+ "aria-invalid": error || void 0,
103
+ "aria-describedby": mergeAriaIds(
104
+ ariaDescribedBy,
105
+ helperText ? helperId : void 0
106
+ ),
107
+ onChange: (e) => {
108
+ onChange == null ? void 0 : onChange(e.target.value);
109
+ onValueChange == null ? void 0 : onValueChange(e.target.value);
110
+ },
111
+ onBlur: () => onBlur == null ? void 0 : onBlur(),
112
+ className: textareaClasses,
113
+ style: Object.keys(textareaInlineStyle).length > 0 ? textareaInlineStyle : void 0
114
+ }
93
115
  ),
94
- onChange: (e) => onChange == null ? void 0 : onChange(e.target.value),
95
- onBlur,
96
- className: textareaClasses,
97
- style: Object.keys(style).length > 0 ? style : void 0
98
- }
99
- ),
100
- helperText && /* @__PURE__ */ jsxRuntime.jsx("span", { id: helperId, className: helperClasses, children: helperText })
101
- ] });
116
+ helperText && /* @__PURE__ */ jsxRuntime.jsx("span", { id: helperId, className: helperClasses, children: helperText })
117
+ ]
118
+ }
119
+ );
102
120
  }
103
121
  );
104
122
  const Textarea = Object.assign(TextareaRoot, {
@@ -1 +1 @@
1
- {"version":3,"file":"index.cjs","sources":["../../../src/components/Textarea/index.tsx"],"sourcesContent":["import * as React from 'react';\nimport styles from './Textarea.module.scss';\n\nexport interface TextareaProps extends Omit<React.HTMLAttributes<HTMLDivElement>, 'onChange' | 'onBlur' | 'defaultValue'> {\n /** Controlled value */\n value?: string;\n /** Default value for uncontrolled usage */\n defaultValue?: string;\n /** Placeholder text */\n placeholder?: string;\n /** Number of visible text rows */\n rows?: number;\n /** Minimum number of rows (for auto-resize) */\n minRows?: number;\n /** Maximum number of rows (for auto-resize) */\n maxRows?: number;\n /** Allow user to resize the textarea */\n resize?: 'none' | 'vertical' | 'horizontal' | 'both';\n /** Disabled state */\n disabled?: boolean;\n /** Error state */\n error?: boolean;\n /** Label text above the textarea */\n label?: string;\n /** Helper text below the textarea */\n helperText?: string;\n /** Called when value changes */\n onChange?: (value: string) => void;\n /** Called when textarea loses focus */\n onBlur?: () => void;\n /** Form field name */\n name?: string;\n /** Maximum character length */\n maxLength?: number;\n /** Required field */\n required?: boolean;\n /** Accessible label for no-visible-label usage */\n 'aria-label'?: string;\n /** Accessible labelled-by relationship */\n 'aria-labelledby'?: string;\n /** Accessible described-by relationship */\n 'aria-describedby'?: string;\n}\n\nfunction mergeAriaIds(...ids: Array<string | undefined>): string | undefined {\n const merged = ids.filter(Boolean).join(' ').trim();\n return merged.length > 0 ? merged : undefined;\n}\n\nconst TextareaRoot = React.forwardRef<HTMLTextAreaElement, TextareaProps>(\n function Textarea(\n {\n value,\n defaultValue,\n placeholder,\n rows = 3,\n minRows,\n maxRows,\n resize = 'vertical',\n disabled = false,\n error = false,\n label,\n helperText,\n onChange,\n onBlur,\n className,\n name,\n id,\n maxLength,\n required = false,\n 'aria-label': ariaLabel,\n 'aria-labelledby': ariaLabelledBy,\n 'aria-describedby': ariaDescribedBy,\n ...htmlProps\n },\n ref\n ) {\n const generatedId = React.useId();\n const textareaId = id || generatedId;\n const labelId = label ? `${textareaId}-label` : undefined;\n const helperId = `${textareaId}-helper`;\n\n const textareaClasses = [\n styles.textarea,\n error && styles.error,\n styles[`resize-${resize}`],\n ]\n .filter(Boolean)\n .join(' ');\n\n const helperClasses = [styles.helper, error && styles.helperError]\n .filter(Boolean)\n .join(' ');\n\n // Calculate min/max height based on rows\n const style: React.CSSProperties = {};\n if (minRows) {\n style.minHeight = `calc(${minRows} * 1.5em + 1.5rem)`;\n }\n if (maxRows) {\n style.maxHeight = `calc(${maxRows} * 1.5em + 1.5rem)`;\n }\n\n return (\n <div {...htmlProps} className={[styles.wrapper, className].filter(Boolean).join(' ')}>\n {label && (\n <label id={labelId} htmlFor={textareaId} className={styles.label}>\n {label}\n {required && <span className={styles.required}>*</span>}\n </label>\n )}\n <textarea\n ref={ref}\n id={textareaId}\n value={value}\n defaultValue={defaultValue}\n placeholder={placeholder}\n rows={rows}\n name={name}\n maxLength={maxLength}\n disabled={disabled}\n required={required}\n aria-label={ariaLabel}\n aria-labelledby={mergeAriaIds(ariaLabelledBy, labelId)}\n aria-invalid={error || undefined}\n aria-describedby={mergeAriaIds(\n ariaDescribedBy,\n helperText ? helperId : undefined\n )}\n onChange={(e) => onChange?.(e.target.value)}\n onBlur={onBlur}\n className={textareaClasses}\n style={Object.keys(style).length > 0 ? style : undefined}\n />\n {helperText && (\n <span id={helperId} className={helperClasses}>\n {helperText}\n </span>\n )}\n </div>\n );\n }\n);\n\nexport const Textarea = Object.assign(TextareaRoot, {\n Root: TextareaRoot,\n});\n"],"names":["React","Textarea","styles","jsxs","jsx"],"mappings":";;;;;;;;;;;;;;;;;;;;;;AA4CA,SAAS,gBAAgB,KAAoD;AAC3E,QAAM,SAAS,IAAI,OAAO,OAAO,EAAE,KAAK,GAAG,EAAE,KAAA;AAC7C,SAAO,OAAO,SAAS,IAAI,SAAS;AACtC;AAEA,MAAM,eAAeA,iBAAM;AAAA,EACzB,SAASC,UACP;AAAA,IACE;AAAA,IACA;AAAA,IACA;AAAA,IACA,OAAO;AAAA,IACP;AAAA,IACA;AAAA,IACA,SAAS;AAAA,IACT,WAAW;AAAA,IACX,QAAQ;AAAA,IACR;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA,WAAW;AAAA,IACX,cAAc;AAAA,IACd,mBAAmB;AAAA,IACnB,oBAAoB;AAAA,IACpB,GAAG;AAAA,EAAA,GAEL,KACA;AACA,UAAM,cAAcD,iBAAM,MAAA;AAC1B,UAAM,aAAa,MAAM;AACzB,UAAM,UAAU,QAAQ,GAAG,UAAU,WAAW;AAChD,UAAM,WAAW,GAAG,UAAU;AAE9B,UAAM,kBAAkB;AAAA,MACtBE,gBAAAA,QAAO;AAAA,MACP,SAASA,gBAAAA,QAAO;AAAA,MAChBA,wBAAO,UAAU,MAAM,EAAE;AAAA,IAAA,EAExB,OAAO,OAAO,EACd,KAAK,GAAG;AAEX,UAAM,gBAAgB,CAACA,wBAAO,QAAQ,SAASA,gBAAAA,QAAO,WAAW,EAC9D,OAAO,OAAO,EACd,KAAK,GAAG;AAGX,UAAM,QAA6B,CAAA;AACnC,QAAI,SAAS;AACX,YAAM,YAAY,QAAQ,OAAO;AAAA,IACnC;AACA,QAAI,SAAS;AACX,YAAM,YAAY,QAAQ,OAAO;AAAA,IACnC;AAEA,WACEC,2BAAAA,KAAC,OAAA,EAAK,GAAG,WAAW,WAAW,CAACD,wBAAO,SAAS,SAAS,EAAE,OAAO,OAAO,EAAE,KAAK,GAAG,GAChF,UAAA;AAAA,MAAA,SACCC,2BAAAA,KAAC,WAAM,IAAI,SAAS,SAAS,YAAY,WAAWD,wBAAO,OACxD,UAAA;AAAA,QAAA;AAAA,QACA,YAAYE,2BAAAA,IAAC,QAAA,EAAK,WAAWF,gBAAAA,QAAO,UAAU,UAAA,IAAA,CAAC;AAAA,MAAA,GAClD;AAAA,MAEFE,2BAAAA;AAAAA,QAAC;AAAA,QAAA;AAAA,UACC;AAAA,UACA,IAAI;AAAA,UACJ;AAAA,UACA;AAAA,UACA;AAAA,UACA;AAAA,UACA;AAAA,UACA;AAAA,UACA;AAAA,UACA;AAAA,UACA,cAAY;AAAA,UACZ,mBAAiB,aAAa,gBAAgB,OAAO;AAAA,UACrD,gBAAc,SAAS;AAAA,UACvB,oBAAkB;AAAA,YAChB;AAAA,YACA,aAAa,WAAW;AAAA,UAAA;AAAA,UAE1B,UAAU,CAAC,MAAM,qCAAW,EAAE,OAAO;AAAA,UACrC;AAAA,UACA,WAAW;AAAA,UACX,OAAO,OAAO,KAAK,KAAK,EAAE,SAAS,IAAI,QAAQ;AAAA,QAAA;AAAA,MAAA;AAAA,MAEhD,cACCA,2BAAAA,IAAC,QAAA,EAAK,IAAI,UAAU,WAAW,eAC5B,UAAA,WAAA,CACH;AAAA,IAAA,GAEJ;AAAA,EAEJ;AACF;AAEO,MAAM,WAAW,OAAO,OAAO,cAAc;AAAA,EAClD,MAAM;AACR,CAAC;;"}
1
+ {"version":3,"file":"index.cjs","sources":["../../../src/components/Textarea/index.tsx"],"sourcesContent":["import * as React from 'react';\nimport styles from './Textarea.module.scss';\n\nexport interface TextareaProps extends Omit<\n React.TextareaHTMLAttributes<HTMLTextAreaElement>,\n 'onChange' | 'onBlur' | 'className' | 'style'\n> {\n /** Controlled value */\n value?: string;\n /** Default value for uncontrolled usage */\n defaultValue?: string;\n /** Placeholder text */\n placeholder?: string;\n /** Number of visible text rows */\n rows?: number;\n /** Minimum number of rows (for auto-resize) */\n minRows?: number;\n /** Maximum number of rows (for auto-resize) */\n maxRows?: number;\n /** Allow user to resize the textarea */\n resize?: 'none' | 'vertical' | 'horizontal' | 'both';\n /** Disabled state */\n disabled?: boolean;\n /** Error state */\n error?: boolean;\n /** Label text above the textarea */\n label?: string;\n /** Helper text below the textarea */\n helperText?: string;\n /** Called when value changes */\n onChange?: (value: string) => void;\n /** Alias for onChange (value-first callback) */\n onValueChange?: (value: string) => void;\n /** Called when textarea loses focus */\n onBlur?: () => void;\n /** Form field name */\n name?: string;\n /** Maximum character length */\n maxLength?: number;\n /** Required field */\n required?: boolean;\n /** Accessible label for no-visible-label usage */\n 'aria-label'?: string;\n /** Accessible labelled-by relationship */\n 'aria-labelledby'?: string;\n /** Accessible described-by relationship */\n 'aria-describedby'?: string;\n /** Props applied to the wrapper element */\n rootProps?: React.HTMLAttributes<HTMLDivElement>;\n /** Wrapper class name */\n className?: string;\n /** Wrapper styles */\n style?: React.CSSProperties;\n}\n\nfunction mergeAriaIds(...ids: Array<string | undefined>): string | undefined {\n const merged = ids.filter(Boolean).join(' ').trim();\n return merged.length > 0 ? merged : undefined;\n}\n\nconst TextareaRoot = React.forwardRef<HTMLTextAreaElement, TextareaProps>(\n function Textarea(\n {\n value,\n defaultValue,\n placeholder,\n rows = 3,\n minRows,\n maxRows,\n resize = 'vertical',\n disabled = false,\n error = false,\n label,\n helperText,\n onChange,\n onValueChange,\n onBlur,\n rootProps,\n className,\n style: wrapperStyle,\n ...textareaProps\n },\n ref\n ) {\n const generatedId = React.useId();\n const {\n id,\n name,\n maxLength,\n required = false,\n 'aria-label': ariaLabel,\n 'aria-labelledby': ariaLabelledBy,\n 'aria-describedby': ariaDescribedBy,\n ...nativeTextareaProps\n } = textareaProps;\n const textareaId = id || generatedId;\n const labelId = label ? `${textareaId}-label` : undefined;\n const helperId = `${textareaId}-helper`;\n\n const textareaClasses = [\n styles.textarea,\n error && styles.error,\n styles[`resize-${resize}`],\n ]\n .filter(Boolean)\n .join(' ');\n\n const helperClasses = [styles.helper, error && styles.helperError]\n .filter(Boolean)\n .join(' ');\n\n // Calculate min/max height based on rows\n const textareaInlineStyle: React.CSSProperties = {};\n if (minRows) {\n textareaInlineStyle.minHeight = `calc(${minRows} * 1.5em + 1.5rem)`;\n }\n if (maxRows) {\n textareaInlineStyle.maxHeight = `calc(${maxRows} * 1.5em + 1.5rem)`;\n }\n\n return (\n <div\n {...rootProps}\n className={[styles.wrapper, rootProps?.className, className].filter(Boolean).join(' ')}\n style={{ ...(rootProps?.style ?? {}), ...(wrapperStyle ?? {}) }}\n >\n {label && (\n <label id={labelId} htmlFor={textareaId} className={styles.label}>\n {label}\n {required && <span className={styles.required}>*</span>}\n </label>\n )}\n <textarea\n ref={ref}\n id={textareaId}\n value={value}\n defaultValue={defaultValue}\n placeholder={placeholder}\n rows={rows}\n {...nativeTextareaProps}\n name={name}\n maxLength={maxLength}\n disabled={disabled}\n required={required}\n aria-label={ariaLabel}\n aria-labelledby={mergeAriaIds(ariaLabelledBy, labelId)}\n aria-invalid={error || undefined}\n aria-describedby={mergeAriaIds(\n ariaDescribedBy,\n helperText ? helperId : undefined\n )}\n onChange={(e) => {\n onChange?.(e.target.value);\n onValueChange?.(e.target.value);\n }}\n onBlur={() => onBlur?.()}\n className={textareaClasses}\n style={Object.keys(textareaInlineStyle).length > 0 ? textareaInlineStyle : undefined}\n />\n {helperText && (\n <span id={helperId} className={helperClasses}>\n {helperText}\n </span>\n )}\n </div>\n );\n }\n);\n\nexport const Textarea = Object.assign(TextareaRoot, {\n Root: TextareaRoot,\n});\n"],"names":["React","Textarea","styles","jsxs","jsx"],"mappings":";;;;;;;;;;;;;;;;;;;;;;AAuDA,SAAS,gBAAgB,KAAoD;AAC3E,QAAM,SAAS,IAAI,OAAO,OAAO,EAAE,KAAK,GAAG,EAAE,KAAA;AAC7C,SAAO,OAAO,SAAS,IAAI,SAAS;AACtC;AAEA,MAAM,eAAeA,iBAAM;AAAA,EACzB,SAASC,UACP;AAAA,IACE;AAAA,IACA;AAAA,IACA;AAAA,IACA,OAAO;AAAA,IACP;AAAA,IACA;AAAA,IACA,SAAS;AAAA,IACT,WAAW;AAAA,IACX,QAAQ;AAAA,IACR;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA,OAAO;AAAA,IACP,GAAG;AAAA,EAAA,GAEL,KACA;AACA,UAAM,cAAcD,iBAAM,MAAA;AAC1B,UAAM;AAAA,MACJ;AAAA,MACA;AAAA,MACA;AAAA,MACA,WAAW;AAAA,MACX,cAAc;AAAA,MACd,mBAAmB;AAAA,MACnB,oBAAoB;AAAA,MACpB,GAAG;AAAA,IAAA,IACD;AACJ,UAAM,aAAa,MAAM;AACzB,UAAM,UAAU,QAAQ,GAAG,UAAU,WAAW;AAChD,UAAM,WAAW,GAAG,UAAU;AAE9B,UAAM,kBAAkB;AAAA,MACtBE,gBAAAA,QAAO;AAAA,MACP,SAASA,gBAAAA,QAAO;AAAA,MAChBA,wBAAO,UAAU,MAAM,EAAE;AAAA,IAAA,EAExB,OAAO,OAAO,EACd,KAAK,GAAG;AAEX,UAAM,gBAAgB,CAACA,wBAAO,QAAQ,SAASA,gBAAAA,QAAO,WAAW,EAC9D,OAAO,OAAO,EACd,KAAK,GAAG;AAGX,UAAM,sBAA2C,CAAA;AACjD,QAAI,SAAS;AACX,0BAAoB,YAAY,QAAQ,OAAO;AAAA,IACjD;AACA,QAAI,SAAS;AACX,0BAAoB,YAAY,QAAQ,OAAO;AAAA,IACjD;AAEA,WACEC,2BAAAA;AAAAA,MAAC;AAAA,MAAA;AAAA,QACE,GAAG;AAAA,QACJ,WAAW,CAACD,gBAAAA,QAAO,SAAS,uCAAW,WAAW,SAAS,EAAE,OAAO,OAAO,EAAE,KAAK,GAAG;AAAA,QACrF,OAAO,EAAE,IAAI,uCAAW,UAAS,CAAA,GAAK,GAAI,gBAAgB,GAAC;AAAA,QAE1D,UAAA;AAAA,UAAA,SACCC,2BAAAA,KAAC,WAAM,IAAI,SAAS,SAAS,YAAY,WAAWD,wBAAO,OACxD,UAAA;AAAA,YAAA;AAAA,YACA,YAAYE,2BAAAA,IAAC,QAAA,EAAK,WAAWF,gBAAAA,QAAO,UAAU,UAAA,IAAA,CAAC;AAAA,UAAA,GAClD;AAAA,UAEFE,2BAAAA;AAAAA,YAAC;AAAA,YAAA;AAAA,cACC;AAAA,cACA,IAAI;AAAA,cACJ;AAAA,cACA;AAAA,cACA;AAAA,cACA;AAAA,cACC,GAAG;AAAA,cACJ;AAAA,cACA;AAAA,cACA;AAAA,cACA;AAAA,cACA,cAAY;AAAA,cACZ,mBAAiB,aAAa,gBAAgB,OAAO;AAAA,cACrD,gBAAc,SAAS;AAAA,cACvB,oBAAkB;AAAA,gBAChB;AAAA,gBACA,aAAa,WAAW;AAAA,cAAA;AAAA,cAE1B,UAAU,CAAC,MAAM;AACf,qDAAW,EAAE,OAAO;AACpB,+DAAgB,EAAE,OAAO;AAAA,cAC3B;AAAA,cACA,QAAQ,MAAM;AAAA,cACd,WAAW;AAAA,cACX,OAAO,OAAO,KAAK,mBAAmB,EAAE,SAAS,IAAI,sBAAsB;AAAA,YAAA;AAAA,UAAA;AAAA,UAE5E,cACCA,2BAAAA,IAAC,QAAA,EAAK,IAAI,UAAU,WAAW,eAC5B,UAAA,WAAA,CACH;AAAA,QAAA;AAAA,MAAA;AAAA,IAAA;AAAA,EAIR;AACF;AAEO,MAAM,WAAW,OAAO,OAAO,cAAc;AAAA,EAClD,MAAM;AACR,CAAC;;"}
@@ -1,5 +1,5 @@
1
1
  import * as React from 'react';
2
- export interface TextareaProps extends Omit<React.HTMLAttributes<HTMLDivElement>, 'onChange' | 'onBlur' | 'defaultValue'> {
2
+ export interface TextareaProps extends Omit<React.TextareaHTMLAttributes<HTMLTextAreaElement>, 'onChange' | 'onBlur' | 'className' | 'style'> {
3
3
  /** Controlled value */
4
4
  value?: string;
5
5
  /** Default value for uncontrolled usage */
@@ -24,6 +24,8 @@ export interface TextareaProps extends Omit<React.HTMLAttributes<HTMLDivElement>
24
24
  helperText?: string;
25
25
  /** Called when value changes */
26
26
  onChange?: (value: string) => void;
27
+ /** Alias for onChange (value-first callback) */
28
+ onValueChange?: (value: string) => void;
27
29
  /** Called when textarea loses focus */
28
30
  onBlur?: () => void;
29
31
  /** Form field name */
@@ -38,6 +40,12 @@ export interface TextareaProps extends Omit<React.HTMLAttributes<HTMLDivElement>
38
40
  'aria-labelledby'?: string;
39
41
  /** Accessible described-by relationship */
40
42
  'aria-describedby'?: string;
43
+ /** Props applied to the wrapper element */
44
+ rootProps?: React.HTMLAttributes<HTMLDivElement>;
45
+ /** Wrapper class name */
46
+ className?: string;
47
+ /** Wrapper styles */
48
+ style?: React.CSSProperties;
41
49
  }
42
50
  export declare const Textarea: React.ForwardRefExoticComponent<TextareaProps & React.RefAttributes<HTMLTextAreaElement>> & {
43
51
  Root: React.ForwardRefExoticComponent<TextareaProps & React.RefAttributes<HTMLTextAreaElement>>;
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/components/Textarea/index.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAG/B,MAAM,WAAW,aAAc,SAAQ,IAAI,CAAC,KAAK,CAAC,cAAc,CAAC,cAAc,CAAC,EAAE,UAAU,GAAG,QAAQ,GAAG,cAAc,CAAC;IACvH,uBAAuB;IACvB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,2CAA2C;IAC3C,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,uBAAuB;IACvB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,kCAAkC;IAClC,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,+CAA+C;IAC/C,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,+CAA+C;IAC/C,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,wCAAwC;IACxC,MAAM,CAAC,EAAE,MAAM,GAAG,UAAU,GAAG,YAAY,GAAG,MAAM,CAAC;IACrD,qBAAqB;IACrB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,kBAAkB;IAClB,KAAK,CAAC,EAAE,OAAO,CAAC;IAChB,oCAAoC;IACpC,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,qCAAqC;IACrC,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,gCAAgC;IAChC,QAAQ,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;IACnC,uCAAuC;IACvC,MAAM,CAAC,EAAE,MAAM,IAAI,CAAC;IACpB,sBAAsB;IACtB,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,+BAA+B;IAC/B,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,qBAAqB;IACrB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,kDAAkD;IAClD,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,0CAA0C;IAC1C,iBAAiB,CAAC,EAAE,MAAM,CAAC;IAC3B,2CAA2C;IAC3C,kBAAkB,CAAC,EAAE,MAAM,CAAC;CAC7B;AAsGD,eAAO,MAAM,QAAQ;;CAEnB,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/components/Textarea/index.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAG/B,MAAM,WAAW,aAAc,SAAQ,IAAI,CACzC,KAAK,CAAC,sBAAsB,CAAC,mBAAmB,CAAC,EACjD,UAAU,GAAG,QAAQ,GAAG,WAAW,GAAG,OAAO,CAC9C;IACC,uBAAuB;IACvB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,2CAA2C;IAC3C,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,uBAAuB;IACvB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,kCAAkC;IAClC,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,+CAA+C;IAC/C,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,+CAA+C;IAC/C,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,wCAAwC;IACxC,MAAM,CAAC,EAAE,MAAM,GAAG,UAAU,GAAG,YAAY,GAAG,MAAM,CAAC;IACrD,qBAAqB;IACrB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,kBAAkB;IAClB,KAAK,CAAC,EAAE,OAAO,CAAC;IAChB,oCAAoC;IACpC,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,qCAAqC;IACrC,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,gCAAgC;IAChC,QAAQ,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;IACnC,gDAAgD;IAChD,aAAa,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;IACxC,uCAAuC;IACvC,MAAM,CAAC,EAAE,MAAM,IAAI,CAAC;IACpB,sBAAsB;IACtB,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,+BAA+B;IAC/B,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,qBAAqB;IACrB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,kDAAkD;IAClD,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,0CAA0C;IAC1C,iBAAiB,CAAC,EAAE,MAAM,CAAC;IAC3B,2CAA2C;IAC3C,kBAAkB,CAAC,EAAE,MAAM,CAAC;IAC5B,2CAA2C;IAC3C,SAAS,CAAC,EAAE,KAAK,CAAC,cAAc,CAAC,cAAc,CAAC,CAAC;IACjD,yBAAyB;IACzB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,qBAAqB;IACrB,KAAK,CAAC,EAAE,KAAK,CAAC,aAAa,CAAC;CAC7B;AAoHD,eAAO,MAAM,QAAQ;;CAEnB,CAAC"}