@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
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sources":["../../../src/components/Menu/index.tsx"],"sourcesContent":["'use client';\n\nimport * as React from 'react';\nimport { Menu as BaseMenu } from '@base-ui/react/menu';\nimport styles from './Menu.module.scss';\n\n// ============================================\n// Types\n// ============================================\n\nexport interface MenuProps {\n children: React.ReactNode;\n open?: boolean;\n defaultOpen?: boolean;\n onOpenChange?: (open: boolean) => void;\n modal?: boolean;\n}\n\nexport interface MenuTriggerProps extends React.ButtonHTMLAttributes<HTMLButtonElement> {\n children: React.ReactNode;\n asChild?: boolean;\n}\n\nexport interface MenuContentProps extends React.HTMLAttributes<HTMLDivElement> {\n children: React.ReactNode;\n side?: 'top' | 'bottom' | 'left' | 'right';\n align?: 'start' | 'center' | 'end';\n sideOffset?: number;\n}\n\nexport interface MenuItemProps extends Omit<React.HTMLAttributes<HTMLElement>, 'children' | 'onSelect'> {\n children: React.ReactNode;\n disabled?: boolean;\n danger?: boolean;\n onSelect?: (...args: any[]) => void;\n icon?: React.ReactNode;\n shortcut?: string;\n /** When passed, renders a check indicator. `true` shows a checkmark, `false` reserves space. */\n checked?: boolean;\n}\n\nexport interface MenuCheckboxItemProps extends Omit<React.HTMLAttributes<HTMLElement>, 'children' | 'onChange'> {\n children: React.ReactNode;\n checked?: boolean;\n defaultChecked?: boolean;\n onCheckedChange?: (checked: boolean) => void;\n disabled?: boolean;\n}\n\nexport interface MenuRadioGroupProps {\n children: React.ReactNode;\n value?: string;\n defaultValue?: string;\n onValueChange?: (value: string) => void;\n}\n\nexport interface MenuRadioItemProps extends Omit<React.HTMLAttributes<HTMLElement>, 'children'> {\n children: React.ReactNode;\n value: string;\n disabled?: boolean;\n}\n\nexport interface MenuGroupProps extends React.HTMLAttributes<HTMLElement> {\n children: React.ReactNode;\n}\n\nexport interface MenuGroupLabelProps extends React.HTMLAttributes<HTMLElement> {\n children: React.ReactNode;\n}\n\nexport interface MenuSeparatorProps extends React.HTMLAttributes<HTMLElement> {}\n\nexport interface MenuSubmenuProps {\n children: React.ReactNode;\n open?: boolean;\n defaultOpen?: boolean;\n onOpenChange?: (open: boolean) => void;\n}\n\nexport interface MenuSubmenuTriggerProps extends React.HTMLAttributes<HTMLElement> {\n children: React.ReactNode;\n disabled?: boolean;\n icon?: React.ReactNode;\n}\n\n// ============================================\n// Icons\n// ============================================\n\nfunction CheckmarkIcon() {\n return (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n width=\"14\"\n height=\"14\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n strokeWidth={3}\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n aria-hidden=\"true\"\n >\n <path d=\"M5 13l4 4L19 7\" />\n </svg>\n );\n}\n\nfunction DotIcon() {\n return (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n width=\"12\"\n height=\"12\"\n viewBox=\"0 0 24 24\"\n fill=\"currentColor\"\n aria-hidden=\"true\"\n >\n <circle cx=\"12\" cy=\"12\" r=\"5\" />\n </svg>\n );\n}\n\n// ============================================\n// Components\n// ============================================\n\nfunction MenuRoot({\n children,\n open,\n defaultOpen,\n onOpenChange,\n modal = true,\n}: MenuProps) {\n return (\n <BaseMenu.Root\n open={open}\n defaultOpen={defaultOpen}\n onOpenChange={onOpenChange}\n modal={modal}\n >\n {children}\n </BaseMenu.Root>\n );\n}\n\nfunction MenuTrigger({ children, asChild, className, ...htmlProps }: MenuTriggerProps) {\n if (asChild) {\n return (\n <BaseMenu.Trigger {...htmlProps} className={className} render={children as React.ReactElement}>\n {null}\n </BaseMenu.Trigger>\n );\n }\n\n return (\n <BaseMenu.Trigger {...htmlProps} className={className}>\n {children}\n </BaseMenu.Trigger>\n );\n}\n\nfunction MenuContent({\n children,\n className,\n side = 'bottom',\n align = 'start',\n sideOffset = 4,\n ...htmlProps\n}: MenuContentProps) {\n const popupClasses = [styles.popup, className].filter(Boolean).join(' ');\n\n return (\n <BaseMenu.Portal>\n <BaseMenu.Positioner\n side={side}\n align={align}\n sideOffset={sideOffset}\n className={styles.positioner}\n >\n <BaseMenu.Popup {...htmlProps} className={popupClasses}>\n {children}\n </BaseMenu.Popup>\n </BaseMenu.Positioner>\n </BaseMenu.Portal>\n );\n}\n\nfunction MenuItem({\n children,\n disabled,\n danger,\n onSelect,\n className,\n icon,\n shortcut,\n checked,\n ...htmlProps\n}: MenuItemProps) {\n const handleClick = React.useCallback(\n (event: React.MouseEvent<HTMLElement>) => {\n (htmlProps.onClick as React.MouseEventHandler<HTMLElement> | undefined)?.(event);\n onSelect?.(event);\n },\n [htmlProps, onSelect],\n );\n\n const hasChecked = checked !== undefined;\n const classes = [\n styles.item,\n danger && styles.itemDanger,\n className,\n ].filter(Boolean).join(' ');\n\n return (\n <BaseMenu.Item\n {...htmlProps}\n disabled={disabled}\n onClick={handleClick as any}\n className={classes}\n >\n {hasChecked && (\n <span className={styles.checkIndicator}>\n {checked ? <CheckmarkIcon /> : null}\n </span>\n )}\n {icon && <span className={styles.itemIcon}>{icon}</span>}\n <span className={styles.itemLabel}>{children}</span>\n {shortcut && <span className={styles.itemShortcut}>{shortcut}</span>}\n </BaseMenu.Item>\n );\n}\n\nfunction MenuCheckboxItem({\n children,\n checked: checkedProp,\n defaultChecked,\n onCheckedChange,\n disabled,\n className,\n ...htmlProps\n}: MenuCheckboxItemProps) {\n const isControlled = checkedProp !== undefined;\n const [internalChecked, setInternalChecked] = React.useState(defaultChecked ?? false);\n const visualChecked = isControlled ? checkedProp : internalChecked;\n\n const handleCheckedChange = React.useCallback(\n (value: boolean) => {\n if (!isControlled) setInternalChecked(value);\n onCheckedChange?.(value);\n },\n [isControlled, onCheckedChange],\n );\n\n const classes = [styles.item, styles.checkboxItem, className]\n .filter(Boolean)\n .join(' ');\n\n return (\n <BaseMenu.CheckboxItem\n {...htmlProps}\n checked={checkedProp}\n defaultChecked={defaultChecked}\n onCheckedChange={handleCheckedChange}\n disabled={disabled}\n className={classes}\n >\n <span className={styles.checkIndicator}>\n {visualChecked ? <CheckmarkIcon /> : null}\n </span>\n <span className={styles.itemLabel}>{children}</span>\n </BaseMenu.CheckboxItem>\n );\n}\n\nfunction MenuRadioGroup({\n children,\n value,\n defaultValue,\n onValueChange,\n}: MenuRadioGroupProps) {\n return (\n <BaseMenu.RadioGroup\n value={value}\n defaultValue={defaultValue}\n onValueChange={onValueChange}\n >\n {children}\n </BaseMenu.RadioGroup>\n );\n}\n\nfunction MenuRadioItem({\n children,\n value,\n disabled,\n className,\n ...htmlProps\n}: MenuRadioItemProps) {\n const classes = [styles.item, styles.radioItem, className]\n .filter(Boolean)\n .join(' ');\n\n return (\n <BaseMenu.RadioItem {...htmlProps} value={value} disabled={disabled} className={classes}>\n <span className={styles.radioIndicator}>\n <DotIcon />\n </span>\n <span className={styles.itemLabel}>{children}</span>\n </BaseMenu.RadioItem>\n );\n}\n\nfunction MenuGroup({ children, className, ...htmlProps }: MenuGroupProps) {\n const classes = [styles.group, className].filter(Boolean).join(' ');\n return <BaseMenu.Group {...htmlProps} className={classes}>{children}</BaseMenu.Group>;\n}\n\nfunction MenuGroupLabel({ children, className, ...htmlProps }: MenuGroupLabelProps) {\n const classes = [styles.groupLabel, className].filter(Boolean).join(' ');\n return <BaseMenu.GroupLabel {...htmlProps} className={classes}>{children}</BaseMenu.GroupLabel>;\n}\n\nfunction MenuSeparator({ className, ...htmlProps }: MenuSeparatorProps) {\n const classes = [styles.separator, className].filter(Boolean).join(' ');\n return <BaseMenu.Separator {...htmlProps} className={classes} />;\n}\n\nfunction MenuSubmenu({\n children,\n open,\n defaultOpen,\n onOpenChange,\n}: MenuSubmenuProps) {\n return (\n <BaseMenu.SubmenuRoot\n open={open}\n defaultOpen={defaultOpen}\n onOpenChange={onOpenChange as any}\n >\n {children}\n </BaseMenu.SubmenuRoot>\n );\n}\n\nfunction MenuSubmenuTrigger({\n children,\n disabled,\n className,\n icon,\n ...htmlProps\n}: MenuSubmenuTriggerProps) {\n const classes = [styles.item, styles.submenuTrigger, className]\n .filter(Boolean)\n .join(' ');\n\n return (\n <BaseMenu.SubmenuTrigger {...htmlProps} disabled={disabled} className={classes}>\n {icon && <span className={styles.itemIcon}>{icon}</span>}\n <span className={styles.itemLabel}>{children}</span>\n </BaseMenu.SubmenuTrigger>\n );\n}\n\n// ============================================\n// Export compound component\n// ============================================\n\nexport const Menu = Object.assign(MenuRoot, {\n Trigger: MenuTrigger,\n Content: MenuContent,\n Item: MenuItem,\n CheckboxItem: MenuCheckboxItem,\n RadioGroup: MenuRadioGroup,\n RadioItem: MenuRadioItem,\n Group: MenuGroup,\n GroupLabel: MenuGroupLabel,\n Separator: MenuSeparator,\n Submenu: MenuSubmenu,\n SubmenuTrigger: MenuSubmenuTrigger,\n});\n\n// Re-export individual components\nexport {\n MenuRoot,\n MenuTrigger,\n MenuContent,\n MenuItem,\n MenuCheckboxItem,\n MenuRadioGroup,\n MenuRadioItem,\n MenuGroup,\n MenuGroupLabel,\n MenuSeparator,\n MenuSubmenu,\n MenuSubmenuTrigger,\n};\n"],"names":["BaseMenu"],"mappings":"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"}
1
+ {"version":3,"file":"index.js","sources":["../../../src/components/Menu/index.tsx"],"sourcesContent":["'use client';\n\nimport * as React from 'react';\nimport { Menu as BaseMenu } from '@base-ui/react/menu';\nimport styles from './Menu.module.scss';\n\n// ============================================\n// Types\n// ============================================\n\nexport interface MenuProps {\n children: React.ReactNode;\n open?: boolean;\n defaultOpen?: boolean;\n onOpenChange?: (open: boolean) => void;\n modal?: boolean;\n}\n\ntype MenuTriggerAsButtonProps = React.ButtonHTMLAttributes<HTMLButtonElement> & {\n children: React.ReactNode;\n asChild?: false;\n};\ntype MenuTriggerAsChildProps = Omit<React.HTMLAttributes<HTMLElement>, 'children'> & {\n children: React.ReactElement;\n asChild: true;\n};\nexport type MenuTriggerProps = MenuTriggerAsButtonProps | MenuTriggerAsChildProps;\n\nexport interface MenuContentProps extends React.HTMLAttributes<HTMLDivElement> {\n children: React.ReactNode;\n side?: 'top' | 'bottom' | 'left' | 'right';\n align?: 'start' | 'center' | 'end';\n sideOffset?: number;\n}\n\nexport interface MenuItemProps extends Omit<React.HTMLAttributes<HTMLElement>, 'children' | 'onSelect'> {\n children: React.ReactNode;\n disabled?: boolean;\n danger?: boolean;\n onSelect?: (event: React.MouseEvent<HTMLElement>) => void;\n icon?: React.ReactNode;\n shortcut?: string;\n /** When passed, renders a check indicator. `true` shows a checkmark, `false` reserves space. */\n checked?: boolean;\n}\n\nexport interface MenuCheckboxItemProps extends Omit<React.HTMLAttributes<HTMLElement>, 'children' | 'onChange'> {\n children: React.ReactNode;\n checked?: boolean;\n defaultChecked?: boolean;\n onCheckedChange?: (checked: boolean) => void;\n disabled?: boolean;\n}\n\nexport interface MenuRadioGroupProps {\n children: React.ReactNode;\n value?: string;\n defaultValue?: string;\n onValueChange?: (value: string) => void;\n}\n\nexport interface MenuRadioItemProps extends Omit<React.HTMLAttributes<HTMLElement>, 'children'> {\n children: React.ReactNode;\n value: string;\n disabled?: boolean;\n}\n\nexport interface MenuGroupProps extends React.HTMLAttributes<HTMLElement> {\n children: React.ReactNode;\n}\n\nexport interface MenuGroupLabelProps extends React.HTMLAttributes<HTMLElement> {\n children: React.ReactNode;\n}\n\nexport interface MenuSeparatorProps extends React.HTMLAttributes<HTMLElement> {}\n\nexport interface MenuSubmenuProps {\n children: React.ReactNode;\n open?: boolean;\n defaultOpen?: boolean;\n onOpenChange?: (open: boolean) => void;\n}\n\nexport interface MenuSubmenuTriggerProps extends React.HTMLAttributes<HTMLElement> {\n children: React.ReactNode;\n disabled?: boolean;\n icon?: React.ReactNode;\n}\n\n// ============================================\n// Icons\n// ============================================\n\nfunction CheckmarkIcon() {\n return (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n width=\"14\"\n height=\"14\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n strokeWidth={3}\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n aria-hidden=\"true\"\n >\n <path d=\"M5 13l4 4L19 7\" />\n </svg>\n );\n}\n\nfunction DotIcon() {\n return (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n width=\"12\"\n height=\"12\"\n viewBox=\"0 0 24 24\"\n fill=\"currentColor\"\n aria-hidden=\"true\"\n >\n <circle cx=\"12\" cy=\"12\" r=\"5\" />\n </svg>\n );\n}\n\n// ============================================\n// Components\n// ============================================\n\nfunction MenuRoot({\n children,\n open,\n defaultOpen,\n onOpenChange,\n modal = true,\n}: MenuProps) {\n return (\n <BaseMenu.Root\n open={open}\n defaultOpen={defaultOpen}\n onOpenChange={onOpenChange}\n modal={modal}\n >\n {children}\n </BaseMenu.Root>\n );\n}\n\nfunction MenuTrigger({ children, asChild, className, ...htmlProps }: MenuTriggerProps) {\n if (asChild) {\n if (!React.isValidElement(children)) {\n throw new Error('Menu.Trigger with asChild requires a single valid React element child.');\n }\n return (\n <BaseMenu.Trigger {...htmlProps} className={className} render={children as React.ReactElement}>\n {null}\n </BaseMenu.Trigger>\n );\n }\n\n return (\n <BaseMenu.Trigger\n {...htmlProps}\n type={(htmlProps as React.ButtonHTMLAttributes<HTMLButtonElement>).type ?? 'button'}\n className={className}\n >\n {children}\n </BaseMenu.Trigger>\n );\n}\n\nfunction MenuContent({\n children,\n className,\n side = 'bottom',\n align = 'start',\n sideOffset = 4,\n ...htmlProps\n}: MenuContentProps) {\n const popupClasses = [styles.popup, className].filter(Boolean).join(' ');\n\n return (\n <BaseMenu.Portal>\n <BaseMenu.Positioner\n side={side}\n align={align}\n sideOffset={sideOffset}\n className={styles.positioner}\n >\n <BaseMenu.Popup {...htmlProps} className={popupClasses}>\n {children}\n </BaseMenu.Popup>\n </BaseMenu.Positioner>\n </BaseMenu.Portal>\n );\n}\n\nfunction MenuItem({\n children,\n disabled,\n danger,\n onSelect,\n className,\n icon,\n shortcut,\n checked,\n ...htmlProps\n}: MenuItemProps) {\n const handleClick = React.useCallback(\n (event: React.MouseEvent<HTMLElement>) => {\n (htmlProps.onClick as React.MouseEventHandler<HTMLElement> | undefined)?.(event);\n onSelect?.(event);\n },\n [htmlProps, onSelect],\n );\n\n const hasChecked = checked !== undefined;\n const classes = [\n styles.item,\n danger && styles.itemDanger,\n className,\n ].filter(Boolean).join(' ');\n\n return (\n <BaseMenu.Item\n {...htmlProps}\n disabled={disabled}\n onClick={handleClick as React.MouseEventHandler<HTMLElement>}\n className={classes}\n >\n {hasChecked && (\n <span className={styles.checkIndicator}>\n {checked ? <CheckmarkIcon /> : null}\n </span>\n )}\n {icon && <span className={styles.itemIcon}>{icon}</span>}\n <span className={styles.itemLabel}>{children}</span>\n {shortcut && <span className={styles.itemShortcut}>{shortcut}</span>}\n </BaseMenu.Item>\n );\n}\n\nfunction MenuCheckboxItem({\n children,\n checked: checkedProp,\n defaultChecked,\n onCheckedChange,\n disabled,\n className,\n ...htmlProps\n}: MenuCheckboxItemProps) {\n const isControlled = checkedProp !== undefined;\n const [internalChecked, setInternalChecked] = React.useState(defaultChecked ?? false);\n const visualChecked = isControlled ? checkedProp : internalChecked;\n\n const handleCheckedChange = React.useCallback(\n (value: boolean) => {\n if (!isControlled) setInternalChecked(value);\n onCheckedChange?.(value);\n },\n [isControlled, onCheckedChange],\n );\n\n const classes = [styles.item, styles.checkboxItem, className]\n .filter(Boolean)\n .join(' ');\n\n return (\n <BaseMenu.CheckboxItem\n {...htmlProps}\n checked={checkedProp}\n defaultChecked={defaultChecked}\n onCheckedChange={handleCheckedChange}\n disabled={disabled}\n className={classes}\n >\n <span className={styles.checkIndicator}>\n {visualChecked ? <CheckmarkIcon /> : null}\n </span>\n <span className={styles.itemLabel}>{children}</span>\n </BaseMenu.CheckboxItem>\n );\n}\n\nfunction MenuRadioGroup({\n children,\n value,\n defaultValue,\n onValueChange,\n}: MenuRadioGroupProps) {\n return (\n <BaseMenu.RadioGroup\n value={value}\n defaultValue={defaultValue}\n onValueChange={onValueChange}\n >\n {children}\n </BaseMenu.RadioGroup>\n );\n}\n\nfunction MenuRadioItem({\n children,\n value,\n disabled,\n className,\n ...htmlProps\n}: MenuRadioItemProps) {\n const classes = [styles.item, styles.radioItem, className]\n .filter(Boolean)\n .join(' ');\n\n return (\n <BaseMenu.RadioItem {...htmlProps} value={value} disabled={disabled} className={classes}>\n <span className={styles.radioIndicator}>\n <DotIcon />\n </span>\n <span className={styles.itemLabel}>{children}</span>\n </BaseMenu.RadioItem>\n );\n}\n\nfunction MenuGroup({ children, className, ...htmlProps }: MenuGroupProps) {\n const classes = [styles.group, className].filter(Boolean).join(' ');\n return <BaseMenu.Group {...htmlProps} className={classes}>{children}</BaseMenu.Group>;\n}\n\nfunction MenuGroupLabel({ children, className, ...htmlProps }: MenuGroupLabelProps) {\n const classes = [styles.groupLabel, className].filter(Boolean).join(' ');\n return <BaseMenu.GroupLabel {...htmlProps} className={classes}>{children}</BaseMenu.GroupLabel>;\n}\n\nfunction MenuSeparator({ className, ...htmlProps }: MenuSeparatorProps) {\n const classes = [styles.separator, className].filter(Boolean).join(' ');\n return <BaseMenu.Separator {...htmlProps} className={classes} />;\n}\n\nfunction MenuSubmenu({\n children,\n open,\n defaultOpen,\n onOpenChange,\n}: MenuSubmenuProps) {\n return (\n <BaseMenu.SubmenuRoot\n open={open}\n defaultOpen={defaultOpen}\n onOpenChange={onOpenChange}\n >\n {children}\n </BaseMenu.SubmenuRoot>\n );\n}\n\nfunction MenuSubmenuTrigger({\n children,\n disabled,\n className,\n icon,\n ...htmlProps\n}: MenuSubmenuTriggerProps) {\n const classes = [styles.item, styles.submenuTrigger, className]\n .filter(Boolean)\n .join(' ');\n\n return (\n <BaseMenu.SubmenuTrigger {...htmlProps} disabled={disabled} className={classes}>\n {icon && <span className={styles.itemIcon}>{icon}</span>}\n <span className={styles.itemLabel}>{children}</span>\n </BaseMenu.SubmenuTrigger>\n );\n}\n\n// ============================================\n// Export compound component\n// ============================================\n\nexport const Menu = Object.assign(MenuRoot, {\n Trigger: MenuTrigger,\n Content: MenuContent,\n Item: MenuItem,\n CheckboxItem: MenuCheckboxItem,\n RadioGroup: MenuRadioGroup,\n RadioItem: MenuRadioItem,\n Group: MenuGroup,\n GroupLabel: MenuGroupLabel,\n Separator: MenuSeparator,\n Submenu: MenuSubmenu,\n SubmenuTrigger: MenuSubmenuTrigger,\n});\n\n// Re-export individual components\nexport {\n MenuRoot,\n MenuTrigger,\n MenuContent,\n MenuItem,\n MenuCheckboxItem,\n MenuRadioGroup,\n MenuRadioItem,\n MenuGroup,\n MenuGroupLabel,\n MenuSeparator,\n MenuSubmenu,\n MenuSubmenuTrigger,\n};\n"],"names":["BaseMenu"],"mappings":";;;;AA8FA,SAAS,gBAAgB;AACvB,SACE;AAAA,IAAC;AAAA,IAAA;AAAA,MACC,OAAM;AAAA,MACN,OAAM;AAAA,MACN,QAAO;AAAA,MACP,SAAQ;AAAA,MACR,MAAK;AAAA,MACL,QAAO;AAAA,MACP,aAAa;AAAA,MACb,eAAc;AAAA,MACd,gBAAe;AAAA,MACf,eAAY;AAAA,MAEZ,UAAA,oBAAC,QAAA,EAAK,GAAE,iBAAA,CAAiB;AAAA,IAAA;AAAA,EAAA;AAG/B;AAEA,SAAS,UAAU;AACjB,SACE;AAAA,IAAC;AAAA,IAAA;AAAA,MACC,OAAM;AAAA,MACN,OAAM;AAAA,MACN,QAAO;AAAA,MACP,SAAQ;AAAA,MACR,MAAK;AAAA,MACL,eAAY;AAAA,MAEZ,8BAAC,UAAA,EAAO,IAAG,MAAK,IAAG,MAAK,GAAE,IAAA,CAAI;AAAA,IAAA;AAAA,EAAA;AAGpC;AAMA,SAAS,SAAS;AAAA,EAChB;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA,QAAQ;AACV,GAAc;AACZ,SACE;AAAA,IAACA,OAAS;AAAA,IAAT;AAAA,MACC;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MAEC;AAAA,IAAA;AAAA,EAAA;AAGP;AAEA,SAAS,YAAY,EAAE,UAAU,SAAS,WAAW,GAAG,aAA+B;AACrF,MAAI,SAAS;AACX,QAAI,CAAC,MAAM,eAAe,QAAQ,GAAG;AACnC,YAAM,IAAI,MAAM,wEAAwE;AAAA,IAC1F;AACA,WACE,oBAACA,OAAS,SAAT,EAAkB,GAAG,WAAW,WAAsB,QAAQ,UAC5D,UAAA,KAAA,CACH;AAAA,EAEJ;AAEA,SACE;AAAA,IAACA,OAAS;AAAA,IAAT;AAAA,MACE,GAAG;AAAA,MACJ,MAAO,UAA4D,QAAQ;AAAA,MAC3E;AAAA,MAEC;AAAA,IAAA;AAAA,EAAA;AAGP;AAEA,SAAS,YAAY;AAAA,EACnB;AAAA,EACA;AAAA,EACA,OAAO;AAAA,EACP,QAAQ;AAAA,EACR,aAAa;AAAA,EACb,GAAG;AACL,GAAqB;AACnB,QAAM,eAAe,CAAC,OAAO,OAAO,SAAS,EAAE,OAAO,OAAO,EAAE,KAAK,GAAG;AAEvE,SACE,oBAACA,OAAS,QAAT,EACC,UAAA;AAAA,IAACA,OAAS;AAAA,IAAT;AAAA,MACC;AAAA,MACA;AAAA,MACA;AAAA,MACA,WAAW,OAAO;AAAA,MAElB,UAAA,oBAACA,OAAS,OAAT,EAAgB,GAAG,WAAW,WAAW,cACvC,SAAA,CACH;AAAA,IAAA;AAAA,EAAA,GAEJ;AAEJ;AAEA,SAAS,SAAS;AAAA,EAChB;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA,GAAG;AACL,GAAkB;AAChB,QAAM,cAAc,MAAM;AAAA,IACxB,CAAC,UAAyC;;AACvC,sBAAU,YAAV,mCAAyE;AAC1E,2CAAW;AAAA,IACb;AAAA,IACA,CAAC,WAAW,QAAQ;AAAA,EAAA;AAGtB,QAAM,aAAa,YAAY;AAC/B,QAAM,UAAU;AAAA,IACd,OAAO;AAAA,IACP,UAAU,OAAO;AAAA,IACjB;AAAA,EAAA,EACA,OAAO,OAAO,EAAE,KAAK,GAAG;AAE1B,SACE;AAAA,IAACA,OAAS;AAAA,IAAT;AAAA,MACE,GAAG;AAAA,MACJ;AAAA,MACA,SAAS;AAAA,MACT,WAAW;AAAA,MAEV,UAAA;AAAA,QAAA,cACC,oBAAC,UAAK,WAAW,OAAO,gBACrB,UAAA,UAAU,oBAAC,eAAA,CAAA,CAAc,IAAK,KAAA,CACjC;AAAA,QAED,QAAQ,oBAAC,QAAA,EAAK,WAAW,OAAO,UAAW,UAAA,MAAK;AAAA,QACjD,oBAAC,QAAA,EAAK,WAAW,OAAO,WAAY,UAAS;AAAA,QAC5C,YAAY,oBAAC,QAAA,EAAK,WAAW,OAAO,cAAe,UAAA,SAAA,CAAS;AAAA,MAAA;AAAA,IAAA;AAAA,EAAA;AAGnE;AAEA,SAAS,iBAAiB;AAAA,EACxB;AAAA,EACA,SAAS;AAAA,EACT;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA,GAAG;AACL,GAA0B;AACxB,QAAM,eAAe,gBAAgB;AACrC,QAAM,CAAC,iBAAiB,kBAAkB,IAAI,MAAM,SAAS,kBAAkB,KAAK;AACpF,QAAM,gBAAgB,eAAe,cAAc;AAEnD,QAAM,sBAAsB,MAAM;AAAA,IAChC,CAAC,UAAmB;AAClB,UAAI,CAAC,aAAc,oBAAmB,KAAK;AAC3C,yDAAkB;AAAA,IACpB;AAAA,IACA,CAAC,cAAc,eAAe;AAAA,EAAA;AAGhC,QAAM,UAAU,CAAC,OAAO,MAAM,OAAO,cAAc,SAAS,EACzD,OAAO,OAAO,EACd,KAAK,GAAG;AAEX,SACE;AAAA,IAACA,OAAS;AAAA,IAAT;AAAA,MACE,GAAG;AAAA,MACJ,SAAS;AAAA,MACT;AAAA,MACA,iBAAiB;AAAA,MACjB;AAAA,MACA,WAAW;AAAA,MAEX,UAAA;AAAA,QAAA,oBAAC,QAAA,EAAK,WAAW,OAAO,gBACrB,0BAAgB,oBAAC,eAAA,EAAc,IAAK,KAAA,CACvC;AAAA,QACA,oBAAC,QAAA,EAAK,WAAW,OAAO,WAAY,SAAA,CAAS;AAAA,MAAA;AAAA,IAAA;AAAA,EAAA;AAGnD;AAEA,SAAS,eAAe;AAAA,EACtB;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACF,GAAwB;AACtB,SACE;AAAA,IAACA,OAAS;AAAA,IAAT;AAAA,MACC;AAAA,MACA;AAAA,MACA;AAAA,MAEC;AAAA,IAAA;AAAA,EAAA;AAGP;AAEA,SAAS,cAAc;AAAA,EACrB;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA,GAAG;AACL,GAAuB;AACrB,QAAM,UAAU,CAAC,OAAO,MAAM,OAAO,WAAW,SAAS,EACtD,OAAO,OAAO,EACd,KAAK,GAAG;AAEX,SACE,qBAACA,OAAS,WAAT,EAAoB,GAAG,WAAW,OAAc,UAAoB,WAAW,SAC9E,UAAA;AAAA,IAAA,oBAAC,UAAK,WAAW,OAAO,gBACtB,UAAA,oBAAC,WAAQ,GACX;AAAA,IACA,oBAAC,QAAA,EAAK,WAAW,OAAO,WAAY,SAAA,CAAS;AAAA,EAAA,GAC/C;AAEJ;AAEA,SAAS,UAAU,EAAE,UAAU,WAAW,GAAG,aAA6B;AACxE,QAAM,UAAU,CAAC,OAAO,OAAO,SAAS,EAAE,OAAO,OAAO,EAAE,KAAK,GAAG;AAClE,SAAO,oBAACA,OAAS,OAAT,EAAgB,GAAG,WAAW,WAAW,SAAU,UAAS;AACtE;AAEA,SAAS,eAAe,EAAE,UAAU,WAAW,GAAG,aAAkC;AAClF,QAAM,UAAU,CAAC,OAAO,YAAY,SAAS,EAAE,OAAO,OAAO,EAAE,KAAK,GAAG;AACvE,SAAO,oBAACA,OAAS,YAAT,EAAqB,GAAG,WAAW,WAAW,SAAU,UAAS;AAC3E;AAEA,SAAS,cAAc,EAAE,WAAW,GAAG,aAAiC;AACtE,QAAM,UAAU,CAAC,OAAO,WAAW,SAAS,EAAE,OAAO,OAAO,EAAE,KAAK,GAAG;AACtE,6BAAQA,OAAS,WAAT,EAAoB,GAAG,WAAW,WAAW,SAAS;AAChE;AAEA,SAAS,YAAY;AAAA,EACnB;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACF,GAAqB;AACnB,SACE;AAAA,IAACA,OAAS;AAAA,IAAT;AAAA,MACC;AAAA,MACA;AAAA,MACA;AAAA,MAEC;AAAA,IAAA;AAAA,EAAA;AAGP;AAEA,SAAS,mBAAmB;AAAA,EAC1B;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA,GAAG;AACL,GAA4B;AAC1B,QAAM,UAAU,CAAC,OAAO,MAAM,OAAO,gBAAgB,SAAS,EAC3D,OAAO,OAAO,EACd,KAAK,GAAG;AAEX,SACE,qBAACA,OAAS,gBAAT,EAAyB,GAAG,WAAW,UAAoB,WAAW,SACpE,UAAA;AAAA,IAAA,QAAQ,oBAAC,QAAA,EAAK,WAAW,OAAO,UAAW,UAAA,MAAK;AAAA,IACjD,oBAAC,QAAA,EAAK,WAAW,OAAO,WAAY,SAAA,CAAS;AAAA,EAAA,GAC/C;AAEJ;AAMO,MAAM,OAAO,OAAO,OAAO,UAAU;AAAA,EAC1C,SAAS;AAAA,EACT,SAAS;AAAA,EACT,MAAM;AAAA,EACN,cAAc;AAAA,EACd,YAAY;AAAA,EACZ,WAAW;AAAA,EACX,OAAO;AAAA,EACP,YAAY;AAAA,EACZ,WAAW;AAAA,EACX,SAAS;AAAA,EACT,gBAAgB;AAClB,CAAC;"}
@@ -1,23 +1,23 @@
1
1
  "use strict";
2
2
  Object.defineProperties(exports, { __esModule: { value: true }, [Symbol.toStringTag]: { value: "Module" } });
3
- const message = "_message_1052q_1";
4
- const actions = "_actions_1052q_8";
5
- const user = "_user_1052q_15";
6
- const body = "_body_1052q_19";
7
- const content = "_content_1052q_22";
8
- const assistant = "_assistant_1052q_27";
9
- const system = "_system_1052q_32";
10
- const avatar = "_avatar_1052q_42";
11
- const error = "_error_1052q_46";
12
- const sending = "_sending_1052q_52";
13
- const avatarUser = "_avatarUser_1052q_72";
14
- const avatarAssistant = "_avatarAssistant_1052q_77";
15
- const avatarSystem = "_avatarSystem_1052q_82";
16
- const avatarImage = "_avatarImage_1052q_87";
17
- const avatarImg = "_avatarImg_1052q_92";
18
- const streaming = "_streaming_1052q_148";
19
- const blink = "_blink_1052q_1";
20
- const timestamp = "_timestamp_1052q_174";
3
+ const message = "_message_7tbia_1";
4
+ const actions = "_actions_7tbia_8";
5
+ const user = "_user_7tbia_15";
6
+ const body = "_body_7tbia_19";
7
+ const content = "_content_7tbia_22";
8
+ const assistant = "_assistant_7tbia_27";
9
+ const system = "_system_7tbia_32";
10
+ const avatar = "_avatar_7tbia_42";
11
+ const error = "_error_7tbia_46";
12
+ const sending = "_sending_7tbia_52";
13
+ const avatarUser = "_avatarUser_7tbia_72";
14
+ const avatarAssistant = "_avatarAssistant_7tbia_77";
15
+ const avatarSystem = "_avatarSystem_7tbia_82";
16
+ const avatarImage = "_avatarImage_7tbia_87";
17
+ const avatarImg = "_avatarImg_7tbia_92";
18
+ const streaming = "_streaming_7tbia_148";
19
+ const blink = "_blink_7tbia_1";
20
+ const timestamp = "_timestamp_7tbia_174";
21
21
  const styles = {
22
22
  message,
23
23
  actions,
@@ -1,21 +1,21 @@
1
- const message = "_message_1052q_1";
2
- const actions = "_actions_1052q_8";
3
- const user = "_user_1052q_15";
4
- const body = "_body_1052q_19";
5
- const content = "_content_1052q_22";
6
- const assistant = "_assistant_1052q_27";
7
- const system = "_system_1052q_32";
8
- const avatar = "_avatar_1052q_42";
9
- const error = "_error_1052q_46";
10
- const sending = "_sending_1052q_52";
11
- const avatarUser = "_avatarUser_1052q_72";
12
- const avatarAssistant = "_avatarAssistant_1052q_77";
13
- const avatarSystem = "_avatarSystem_1052q_82";
14
- const avatarImage = "_avatarImage_1052q_87";
15
- const avatarImg = "_avatarImg_1052q_92";
16
- const streaming = "_streaming_1052q_148";
17
- const blink = "_blink_1052q_1";
18
- const timestamp = "_timestamp_1052q_174";
1
+ const message = "_message_7tbia_1";
2
+ const actions = "_actions_7tbia_8";
3
+ const user = "_user_7tbia_15";
4
+ const body = "_body_7tbia_19";
5
+ const content = "_content_7tbia_22";
6
+ const assistant = "_assistant_7tbia_27";
7
+ const system = "_system_7tbia_32";
8
+ const avatar = "_avatar_7tbia_42";
9
+ const error = "_error_7tbia_46";
10
+ const sending = "_sending_7tbia_52";
11
+ const avatarUser = "_avatarUser_7tbia_72";
12
+ const avatarAssistant = "_avatarAssistant_7tbia_77";
13
+ const avatarSystem = "_avatarSystem_7tbia_82";
14
+ const avatarImage = "_avatarImage_7tbia_87";
15
+ const avatarImg = "_avatarImg_7tbia_92";
16
+ const streaming = "_streaming_7tbia_148";
17
+ const blink = "_blink_7tbia_1";
18
+ const timestamp = "_timestamp_7tbia_174";
19
19
  const styles = {
20
20
  message,
21
21
  actions,
@@ -1,33 +1,33 @@
1
1
  "use strict";
2
2
  Object.defineProperties(exports, { __esModule: { value: true }, [Symbol.toStringTag]: { value: "Module" } });
3
- const root = "_root_1sabn_1";
4
- const rootVertical = "_rootVertical_1sabn_7";
5
- const list = "_list_1sabn_12";
6
- const listVertical = "_listVertical_1sabn_26";
7
- const trigger = "_trigger_1sabn_31";
8
- const triggerChevron = "_triggerChevron_1sabn_83";
9
- const content = "_content_1sabn_91";
10
- const link = "_link_1sabn_150";
11
- const linkActive = "_linkActive_1sabn_176";
12
- const linkStructured = "_linkStructured_1sabn_186";
13
- const linkIcon = "_linkIcon_1sabn_198";
14
- const linkBody = "_linkBody_1sabn_209";
15
- const linkTitle = "_linkTitle_1sabn_216";
16
- const linkDescription = "_linkDescription_1sabn_223";
17
- const linkFeatured = "_linkFeatured_1sabn_229";
18
- const indicator = "_indicator_1sabn_238";
19
- const viewport = "_viewport_1sabn_248";
20
- const hamburger = "_hamburger_1sabn_278";
21
- const drawerBackdrop = "_drawerBackdrop_1sabn_325";
22
- const drawer = "_drawer_1sabn_325";
23
- const drawerHeader = "_drawerHeader_1sabn_359";
24
- const drawerClose = "_drawerClose_1sabn_368";
25
- const drawerBody = "_drawerBody_1sabn_406";
26
- const drawerNav = "_drawerNav_1sabn_412";
27
- const drawerLink = "_drawerLink_1sabn_417";
28
- const drawerSectionLabel = "_drawerSectionLabel_1sabn_451";
29
- const drawerCollapsibleTrigger = "_drawerCollapsibleTrigger_1sabn_462";
30
- const drawerCollapsibleContent = "_drawerCollapsibleContent_1sabn_505";
3
+ const root = "_root_djefa_1";
4
+ const rootVertical = "_rootVertical_djefa_7";
5
+ const list = "_list_djefa_12";
6
+ const listVertical = "_listVertical_djefa_26";
7
+ const trigger = "_trigger_djefa_31";
8
+ const triggerChevron = "_triggerChevron_djefa_83";
9
+ const content = "_content_djefa_91";
10
+ const link = "_link_djefa_150";
11
+ const linkActive = "_linkActive_djefa_176";
12
+ const linkStructured = "_linkStructured_djefa_186";
13
+ const linkIcon = "_linkIcon_djefa_198";
14
+ const linkBody = "_linkBody_djefa_209";
15
+ const linkTitle = "_linkTitle_djefa_216";
16
+ const linkDescription = "_linkDescription_djefa_223";
17
+ const linkFeatured = "_linkFeatured_djefa_229";
18
+ const indicator = "_indicator_djefa_238";
19
+ const viewport = "_viewport_djefa_248";
20
+ const hamburger = "_hamburger_djefa_278";
21
+ const drawerBackdrop = "_drawerBackdrop_djefa_325";
22
+ const drawer = "_drawer_djefa_325";
23
+ const drawerHeader = "_drawerHeader_djefa_359";
24
+ const drawerClose = "_drawerClose_djefa_368";
25
+ const drawerBody = "_drawerBody_djefa_406";
26
+ const drawerNav = "_drawerNav_djefa_412";
27
+ const drawerLink = "_drawerLink_djefa_417";
28
+ const drawerSectionLabel = "_drawerSectionLabel_djefa_451";
29
+ const drawerCollapsibleTrigger = "_drawerCollapsibleTrigger_djefa_462";
30
+ const drawerCollapsibleContent = "_drawerCollapsibleContent_djefa_505";
31
31
  const styles = {
32
32
  root,
33
33
  rootVertical,
@@ -1,31 +1,31 @@
1
- const root = "_root_1sabn_1";
2
- const rootVertical = "_rootVertical_1sabn_7";
3
- const list = "_list_1sabn_12";
4
- const listVertical = "_listVertical_1sabn_26";
5
- const trigger = "_trigger_1sabn_31";
6
- const triggerChevron = "_triggerChevron_1sabn_83";
7
- const content = "_content_1sabn_91";
8
- const link = "_link_1sabn_150";
9
- const linkActive = "_linkActive_1sabn_176";
10
- const linkStructured = "_linkStructured_1sabn_186";
11
- const linkIcon = "_linkIcon_1sabn_198";
12
- const linkBody = "_linkBody_1sabn_209";
13
- const linkTitle = "_linkTitle_1sabn_216";
14
- const linkDescription = "_linkDescription_1sabn_223";
15
- const linkFeatured = "_linkFeatured_1sabn_229";
16
- const indicator = "_indicator_1sabn_238";
17
- const viewport = "_viewport_1sabn_248";
18
- const hamburger = "_hamburger_1sabn_278";
19
- const drawerBackdrop = "_drawerBackdrop_1sabn_325";
20
- const drawer = "_drawer_1sabn_325";
21
- const drawerHeader = "_drawerHeader_1sabn_359";
22
- const drawerClose = "_drawerClose_1sabn_368";
23
- const drawerBody = "_drawerBody_1sabn_406";
24
- const drawerNav = "_drawerNav_1sabn_412";
25
- const drawerLink = "_drawerLink_1sabn_417";
26
- const drawerSectionLabel = "_drawerSectionLabel_1sabn_451";
27
- const drawerCollapsibleTrigger = "_drawerCollapsibleTrigger_1sabn_462";
28
- const drawerCollapsibleContent = "_drawerCollapsibleContent_1sabn_505";
1
+ const root = "_root_djefa_1";
2
+ const rootVertical = "_rootVertical_djefa_7";
3
+ const list = "_list_djefa_12";
4
+ const listVertical = "_listVertical_djefa_26";
5
+ const trigger = "_trigger_djefa_31";
6
+ const triggerChevron = "_triggerChevron_djefa_83";
7
+ const content = "_content_djefa_91";
8
+ const link = "_link_djefa_150";
9
+ const linkActive = "_linkActive_djefa_176";
10
+ const linkStructured = "_linkStructured_djefa_186";
11
+ const linkIcon = "_linkIcon_djefa_198";
12
+ const linkBody = "_linkBody_djefa_209";
13
+ const linkTitle = "_linkTitle_djefa_216";
14
+ const linkDescription = "_linkDescription_djefa_223";
15
+ const linkFeatured = "_linkFeatured_djefa_229";
16
+ const indicator = "_indicator_djefa_238";
17
+ const viewport = "_viewport_djefa_248";
18
+ const hamburger = "_hamburger_djefa_278";
19
+ const drawerBackdrop = "_drawerBackdrop_djefa_325";
20
+ const drawer = "_drawer_djefa_325";
21
+ const drawerHeader = "_drawerHeader_djefa_359";
22
+ const drawerClose = "_drawerClose_djefa_368";
23
+ const drawerBody = "_drawerBody_djefa_406";
24
+ const drawerNav = "_drawerNav_djefa_412";
25
+ const drawerLink = "_drawerLink_djefa_417";
26
+ const drawerSectionLabel = "_drawerSectionLabel_djefa_451";
27
+ const drawerCollapsibleTrigger = "_drawerCollapsibleTrigger_djefa_462";
28
+ const drawerCollapsibleContent = "_drawerCollapsibleContent_djefa_505";
29
29
  const styles = {
30
30
  root,
31
31
  rootVertical,
@@ -1 +1 @@
1
- {"version":3,"file":"NavigationMenuContext.cjs","sources":["../../../src/components/NavigationMenu/NavigationMenuContext.ts"],"sourcesContent":["'use client';\n\nimport * as React from 'react';\n\n// ============================================\n// Item Info (for mobile drawer auto-conversion)\n// ============================================\n\nexport interface NavigationMenuItemInfo {\n value: string;\n triggerLabel: string;\n contentChildren: React.ReactNode;\n linkHref?: string;\n}\n\n// ============================================\n// Root Context\n// ============================================\n\nexport interface NavigationMenuContextValue {\n value: string;\n setValue: (value: string) => void;\n orientation: 'horizontal' | 'vertical';\n delayDuration: number;\n skipDelayDuration: number;\n\n // Timer refs\n openTimerRef: React.MutableRefObject<ReturnType<typeof setTimeout> | null>;\n closeTimerRef: React.MutableRefObject<ReturnType<typeof setTimeout> | null>;\n isRecentlyOpenRef: React.MutableRefObject<boolean>;\n skipDelayTimerRef: React.MutableRefObject<ReturnType<typeof setTimeout> | null>;\n\n // Trigger registry for keyboard nav + indicator\n triggerRefs: React.MutableRefObject<Map<string, HTMLButtonElement>>;\n triggerOrder: React.MutableRefObject<string[]>;\n\n // Full item order (includes items without triggers)\n itemOrder: React.MutableRefObject<string[]>;\n\n // Item info registry (for mobile drawer)\n itemInfoMap: React.MutableRefObject<Map<string, NavigationMenuItemInfo>>;\n\n // Viewport size for animated transitions\n viewportSize: { width: number; height: number };\n setViewportSize: (size: { width: number; height: number }) => void;\n\n // Viewport ref for portal\n viewportRef: React.RefObject<HTMLDivElement | null>;\n\n // Track previous value for motion direction\n previousValue: React.MutableRefObject<string>;\n\n // Mobile state\n isMobile: boolean;\n mobileOpen: boolean;\n setMobileOpen: (open: boolean) => void;\n mobileContentChildren: React.ReactNode;\n setMobileContentChildren: (children: React.ReactNode) => void;\n mobileBrandChildren: React.ReactNode;\n setMobileBrandChildren: (children: React.ReactNode) => void;\n\n // Root nav id\n rootId: string;\n}\n\nexport const NavigationMenuContext = React.createContext<NavigationMenuContextValue | null>(null);\n\nexport function useNavigationMenuContext(): NavigationMenuContextValue {\n const ctx = React.useContext(NavigationMenuContext);\n if (!ctx) {\n throw new Error('NavigationMenu compound components must be used within NavigationMenu');\n }\n return ctx;\n}\n\n// ============================================\n// Item Context\n// ============================================\n\nexport interface NavigationMenuItemContextValue {\n value: string;\n triggerId: string;\n contentId: string;\n}\n\nexport const NavigationMenuItemContext = React.createContext<NavigationMenuItemContextValue | null>(null);\n\nexport function useNavigationMenuItemContext(): NavigationMenuItemContextValue {\n const ctx = React.useContext(NavigationMenuItemContext);\n if (!ctx) {\n throw new Error('NavigationMenu.Trigger/Content must be used within NavigationMenu.Item');\n }\n return ctx;\n}\n"],"names":["React"],"mappings":";;;;;;;;;;;;;;;;;;;;AAiEO,MAAM,wBAAwBA,iBAAM,cAAiD,IAAI;AAEzF,SAAS,2BAAuD;AACrE,QAAM,MAAMA,iBAAM,WAAW,qBAAqB;AAClD,MAAI,CAAC,KAAK;AACR,UAAM,IAAI,MAAM,uEAAuE;AAAA,EACzF;AACA,SAAO;AACT;AAYO,MAAM,4BAA4BA,iBAAM,cAAqD,IAAI;AAEjG,SAAS,+BAA+D;AAC7E,QAAM,MAAMA,iBAAM,WAAW,yBAAyB;AACtD,MAAI,CAAC,KAAK;AACR,UAAM,IAAI,MAAM,wEAAwE;AAAA,EAC1F;AACA,SAAO;AACT;;;;;"}
1
+ {"version":3,"file":"NavigationMenuContext.cjs","sources":["../../../src/components/NavigationMenu/NavigationMenuContext.ts"],"sourcesContent":["'use client';\n\nimport * as React from 'react';\n\n// ============================================\n// Item Info (for mobile drawer auto-conversion)\n// ============================================\n\nexport interface NavigationMenuItemInfo {\n value: string;\n triggerLabel: string;\n contentChildren: React.ReactNode;\n linkHref?: string;\n}\n\nexport interface NavigationMenuIconRenderState {\n slot: 'triggerChevron' | 'mobileMenu' | 'mobileClose' | 'drawerClose';\n open?: boolean;\n isMobile?: boolean;\n}\n\nexport type NavigationMenuIconSlot =\n | React.ReactNode\n | ((state: NavigationMenuIconRenderState) => React.ReactNode);\n\nexport type NavigationMenuIcons =\n Partial<Record<NavigationMenuIconRenderState['slot'], NavigationMenuIconSlot>>;\n\n// ============================================\n// Root Context\n// ============================================\n\nexport interface NavigationMenuContextValue {\n value: string;\n setValue: (value: string) => void;\n orientation: 'horizontal' | 'vertical';\n delayDuration: number;\n skipDelayDuration: number;\n\n // Timer refs\n openTimerRef: React.MutableRefObject<ReturnType<typeof setTimeout> | null>;\n closeTimerRef: React.MutableRefObject<ReturnType<typeof setTimeout> | null>;\n isRecentlyOpenRef: React.MutableRefObject<boolean>;\n skipDelayTimerRef: React.MutableRefObject<ReturnType<typeof setTimeout> | null>;\n\n // Trigger registry for keyboard nav + indicator\n triggerRefs: React.MutableRefObject<Map<string, HTMLButtonElement>>;\n triggerOrder: React.MutableRefObject<string[]>;\n\n // Full item order (includes items without triggers)\n itemOrder: React.MutableRefObject<string[]>;\n\n // Item info registry (for mobile drawer)\n itemInfoMap: React.MutableRefObject<Map<string, NavigationMenuItemInfo>>;\n\n // Viewport size for animated transitions\n viewportSize: { width: number; height: number };\n setViewportSize: (size: { width: number; height: number }) => void;\n\n // Viewport ref for portal\n viewportRef: React.RefObject<HTMLDivElement | null>;\n\n // Track previous value for motion direction\n previousValue: React.MutableRefObject<string>;\n\n // Mobile state\n isMobile: boolean;\n mobileOpen: boolean;\n setMobileOpen: (open: boolean) => void;\n mobileContentChildren: React.ReactNode;\n setMobileContentChildren: (children: React.ReactNode) => void;\n mobileBrandChildren: React.ReactNode;\n setMobileBrandChildren: (children: React.ReactNode) => void;\n\n // Root nav id\n rootId: string;\n icons?: NavigationMenuIcons;\n}\n\nexport const NavigationMenuContext = React.createContext<NavigationMenuContextValue | null>(null);\n\nexport function useNavigationMenuContext(): NavigationMenuContextValue {\n const ctx = React.useContext(NavigationMenuContext);\n if (!ctx) {\n throw new Error('NavigationMenu compound components must be used within NavigationMenu');\n }\n return ctx;\n}\n\n// ============================================\n// Item Context\n// ============================================\n\nexport interface NavigationMenuItemContextValue {\n value: string;\n triggerId: string;\n contentId: string;\n}\n\nexport const NavigationMenuItemContext = React.createContext<NavigationMenuItemContextValue | null>(null);\n\nexport function useNavigationMenuItemContext(): NavigationMenuItemContextValue {\n const ctx = React.useContext(NavigationMenuItemContext);\n if (!ctx) {\n throw new Error('NavigationMenu.Trigger/Content must be used within NavigationMenu.Item');\n }\n return ctx;\n}\n"],"names":["React"],"mappings":";;;;;;;;;;;;;;;;;;;;AA+EO,MAAM,wBAAwBA,iBAAM,cAAiD,IAAI;AAEzF,SAAS,2BAAuD;AACrE,QAAM,MAAMA,iBAAM,WAAW,qBAAqB;AAClD,MAAI,CAAC,KAAK;AACR,UAAM,IAAI,MAAM,uEAAuE;AAAA,EACzF;AACA,SAAO;AACT;AAYO,MAAM,4BAA4BA,iBAAM,cAAqD,IAAI;AAEjG,SAAS,+BAA+D;AAC7E,QAAM,MAAMA,iBAAM,WAAW,yBAAyB;AACtD,MAAI,CAAC,KAAK;AACR,UAAM,IAAI,MAAM,wEAAwE;AAAA,EAC1F;AACA,SAAO;AACT;;;;;"}
@@ -5,6 +5,13 @@ export interface NavigationMenuItemInfo {
5
5
  contentChildren: React.ReactNode;
6
6
  linkHref?: string;
7
7
  }
8
+ export interface NavigationMenuIconRenderState {
9
+ slot: 'triggerChevron' | 'mobileMenu' | 'mobileClose' | 'drawerClose';
10
+ open?: boolean;
11
+ isMobile?: boolean;
12
+ }
13
+ export type NavigationMenuIconSlot = React.ReactNode | ((state: NavigationMenuIconRenderState) => React.ReactNode);
14
+ export type NavigationMenuIcons = Partial<Record<NavigationMenuIconRenderState['slot'], NavigationMenuIconSlot>>;
8
15
  export interface NavigationMenuContextValue {
9
16
  value: string;
10
17
  setValue: (value: string) => void;
@@ -37,6 +44,7 @@ export interface NavigationMenuContextValue {
37
44
  mobileBrandChildren: React.ReactNode;
38
45
  setMobileBrandChildren: (children: React.ReactNode) => void;
39
46
  rootId: string;
47
+ icons?: NavigationMenuIcons;
40
48
  }
41
49
  export declare const NavigationMenuContext: React.Context<NavigationMenuContextValue | null>;
42
50
  export declare function useNavigationMenuContext(): NavigationMenuContextValue;
@@ -1 +1 @@
1
- {"version":3,"file":"NavigationMenuContext.d.ts","sourceRoot":"","sources":["../../../src/components/NavigationMenu/NavigationMenuContext.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAM/B,MAAM,WAAW,sBAAsB;IACrC,KAAK,EAAE,MAAM,CAAC;IACd,YAAY,EAAE,MAAM,CAAC;IACrB,eAAe,EAAE,KAAK,CAAC,SAAS,CAAC;IACjC,QAAQ,CAAC,EAAE,MAAM,CAAC;CACnB;AAMD,MAAM,WAAW,0BAA0B;IACzC,KAAK,EAAE,MAAM,CAAC;IACd,QAAQ,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;IAClC,WAAW,EAAE,YAAY,GAAG,UAAU,CAAC;IACvC,aAAa,EAAE,MAAM,CAAC;IACtB,iBAAiB,EAAE,MAAM,CAAC;IAG1B,YAAY,EAAE,KAAK,CAAC,gBAAgB,CAAC,UAAU,CAAC,OAAO,UAAU,CAAC,GAAG,IAAI,CAAC,CAAC;IAC3E,aAAa,EAAE,KAAK,CAAC,gBAAgB,CAAC,UAAU,CAAC,OAAO,UAAU,CAAC,GAAG,IAAI,CAAC,CAAC;IAC5E,iBAAiB,EAAE,KAAK,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC;IACnD,iBAAiB,EAAE,KAAK,CAAC,gBAAgB,CAAC,UAAU,CAAC,OAAO,UAAU,CAAC,GAAG,IAAI,CAAC,CAAC;IAGhF,WAAW,EAAE,KAAK,CAAC,gBAAgB,CAAC,GAAG,CAAC,MAAM,EAAE,iBAAiB,CAAC,CAAC,CAAC;IACpE,YAAY,EAAE,KAAK,CAAC,gBAAgB,CAAC,MAAM,EAAE,CAAC,CAAC;IAG/C,SAAS,EAAE,KAAK,CAAC,gBAAgB,CAAC,MAAM,EAAE,CAAC,CAAC;IAG5C,WAAW,EAAE,KAAK,CAAC,gBAAgB,CAAC,GAAG,CAAC,MAAM,EAAE,sBAAsB,CAAC,CAAC,CAAC;IAGzE,YAAY,EAAE;QAAE,KAAK,EAAE,MAAM,CAAC;QAAC,MAAM,EAAE,MAAM,CAAA;KAAE,CAAC;IAChD,eAAe,EAAE,CAAC,IAAI,EAAE;QAAE,KAAK,EAAE,MAAM,CAAC;QAAC,MAAM,EAAE,MAAM,CAAA;KAAE,KAAK,IAAI,CAAC;IAGnE,WAAW,EAAE,KAAK,CAAC,SAAS,CAAC,cAAc,GAAG,IAAI,CAAC,CAAC;IAGpD,aAAa,EAAE,KAAK,CAAC,gBAAgB,CAAC,MAAM,CAAC,CAAC;IAG9C,QAAQ,EAAE,OAAO,CAAC;IAClB,UAAU,EAAE,OAAO,CAAC;IACpB,aAAa,EAAE,CAAC,IAAI,EAAE,OAAO,KAAK,IAAI,CAAC;IACvC,qBAAqB,EAAE,KAAK,CAAC,SAAS,CAAC;IACvC,wBAAwB,EAAE,CAAC,QAAQ,EAAE,KAAK,CAAC,SAAS,KAAK,IAAI,CAAC;IAC9D,mBAAmB,EAAE,KAAK,CAAC,SAAS,CAAC;IACrC,sBAAsB,EAAE,CAAC,QAAQ,EAAE,KAAK,CAAC,SAAS,KAAK,IAAI,CAAC;IAG5D,MAAM,EAAE,MAAM,CAAC;CAChB;AAED,eAAO,MAAM,qBAAqB,kDAA+D,CAAC;AAElG,wBAAgB,wBAAwB,IAAI,0BAA0B,CAMrE;AAMD,MAAM,WAAW,8BAA8B;IAC7C,KAAK,EAAE,MAAM,CAAC;IACd,SAAS,EAAE,MAAM,CAAC;IAClB,SAAS,EAAE,MAAM,CAAC;CACnB;AAED,eAAO,MAAM,yBAAyB,sDAAmE,CAAC;AAE1G,wBAAgB,4BAA4B,IAAI,8BAA8B,CAM7E"}
1
+ {"version":3,"file":"NavigationMenuContext.d.ts","sourceRoot":"","sources":["../../../src/components/NavigationMenu/NavigationMenuContext.ts"],"names":[],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"NavigationMenuContext.js","sources":["../../../src/components/NavigationMenu/NavigationMenuContext.ts"],"sourcesContent":["'use client';\n\nimport * as React from 'react';\n\n// ============================================\n// Item Info (for mobile drawer auto-conversion)\n// ============================================\n\nexport interface NavigationMenuItemInfo {\n value: string;\n triggerLabel: string;\n contentChildren: React.ReactNode;\n linkHref?: string;\n}\n\n// ============================================\n// Root Context\n// ============================================\n\nexport interface NavigationMenuContextValue {\n value: string;\n setValue: (value: string) => void;\n orientation: 'horizontal' | 'vertical';\n delayDuration: number;\n skipDelayDuration: number;\n\n // Timer refs\n openTimerRef: React.MutableRefObject<ReturnType<typeof setTimeout> | null>;\n closeTimerRef: React.MutableRefObject<ReturnType<typeof setTimeout> | null>;\n isRecentlyOpenRef: React.MutableRefObject<boolean>;\n skipDelayTimerRef: React.MutableRefObject<ReturnType<typeof setTimeout> | null>;\n\n // Trigger registry for keyboard nav + indicator\n triggerRefs: React.MutableRefObject<Map<string, HTMLButtonElement>>;\n triggerOrder: React.MutableRefObject<string[]>;\n\n // Full item order (includes items without triggers)\n itemOrder: React.MutableRefObject<string[]>;\n\n // Item info registry (for mobile drawer)\n itemInfoMap: React.MutableRefObject<Map<string, NavigationMenuItemInfo>>;\n\n // Viewport size for animated transitions\n viewportSize: { width: number; height: number };\n setViewportSize: (size: { width: number; height: number }) => void;\n\n // Viewport ref for portal\n viewportRef: React.RefObject<HTMLDivElement | null>;\n\n // Track previous value for motion direction\n previousValue: React.MutableRefObject<string>;\n\n // Mobile state\n isMobile: boolean;\n mobileOpen: boolean;\n setMobileOpen: (open: boolean) => void;\n mobileContentChildren: React.ReactNode;\n setMobileContentChildren: (children: React.ReactNode) => void;\n mobileBrandChildren: React.ReactNode;\n setMobileBrandChildren: (children: React.ReactNode) => void;\n\n // Root nav id\n rootId: string;\n}\n\nexport const NavigationMenuContext = React.createContext<NavigationMenuContextValue | null>(null);\n\nexport function useNavigationMenuContext(): NavigationMenuContextValue {\n const ctx = React.useContext(NavigationMenuContext);\n if (!ctx) {\n throw new Error('NavigationMenu compound components must be used within NavigationMenu');\n }\n return ctx;\n}\n\n// ============================================\n// Item Context\n// ============================================\n\nexport interface NavigationMenuItemContextValue {\n value: string;\n triggerId: string;\n contentId: string;\n}\n\nexport const NavigationMenuItemContext = React.createContext<NavigationMenuItemContextValue | null>(null);\n\nexport function useNavigationMenuItemContext(): NavigationMenuItemContextValue {\n const ctx = React.useContext(NavigationMenuItemContext);\n if (!ctx) {\n throw new Error('NavigationMenu.Trigger/Content must be used within NavigationMenu.Item');\n }\n return ctx;\n}\n"],"names":[],"mappings":";AAiEO,MAAM,wBAAwB,MAAM,cAAiD,IAAI;AAEzF,SAAS,2BAAuD;AACrE,QAAM,MAAM,MAAM,WAAW,qBAAqB;AAClD,MAAI,CAAC,KAAK;AACR,UAAM,IAAI,MAAM,uEAAuE;AAAA,EACzF;AACA,SAAO;AACT;AAYO,MAAM,4BAA4B,MAAM,cAAqD,IAAI;AAEjG,SAAS,+BAA+D;AAC7E,QAAM,MAAM,MAAM,WAAW,yBAAyB;AACtD,MAAI,CAAC,KAAK;AACR,UAAM,IAAI,MAAM,wEAAwE;AAAA,EAC1F;AACA,SAAO;AACT;"}
1
+ {"version":3,"file":"NavigationMenuContext.js","sources":["../../../src/components/NavigationMenu/NavigationMenuContext.ts"],"sourcesContent":["'use client';\n\nimport * as React from 'react';\n\n// ============================================\n// Item Info (for mobile drawer auto-conversion)\n// ============================================\n\nexport interface NavigationMenuItemInfo {\n value: string;\n triggerLabel: string;\n contentChildren: React.ReactNode;\n linkHref?: string;\n}\n\nexport interface NavigationMenuIconRenderState {\n slot: 'triggerChevron' | 'mobileMenu' | 'mobileClose' | 'drawerClose';\n open?: boolean;\n isMobile?: boolean;\n}\n\nexport type NavigationMenuIconSlot =\n | React.ReactNode\n | ((state: NavigationMenuIconRenderState) => React.ReactNode);\n\nexport type NavigationMenuIcons =\n Partial<Record<NavigationMenuIconRenderState['slot'], NavigationMenuIconSlot>>;\n\n// ============================================\n// Root Context\n// ============================================\n\nexport interface NavigationMenuContextValue {\n value: string;\n setValue: (value: string) => void;\n orientation: 'horizontal' | 'vertical';\n delayDuration: number;\n skipDelayDuration: number;\n\n // Timer refs\n openTimerRef: React.MutableRefObject<ReturnType<typeof setTimeout> | null>;\n closeTimerRef: React.MutableRefObject<ReturnType<typeof setTimeout> | null>;\n isRecentlyOpenRef: React.MutableRefObject<boolean>;\n skipDelayTimerRef: React.MutableRefObject<ReturnType<typeof setTimeout> | null>;\n\n // Trigger registry for keyboard nav + indicator\n triggerRefs: React.MutableRefObject<Map<string, HTMLButtonElement>>;\n triggerOrder: React.MutableRefObject<string[]>;\n\n // Full item order (includes items without triggers)\n itemOrder: React.MutableRefObject<string[]>;\n\n // Item info registry (for mobile drawer)\n itemInfoMap: React.MutableRefObject<Map<string, NavigationMenuItemInfo>>;\n\n // Viewport size for animated transitions\n viewportSize: { width: number; height: number };\n setViewportSize: (size: { width: number; height: number }) => void;\n\n // Viewport ref for portal\n viewportRef: React.RefObject<HTMLDivElement | null>;\n\n // Track previous value for motion direction\n previousValue: React.MutableRefObject<string>;\n\n // Mobile state\n isMobile: boolean;\n mobileOpen: boolean;\n setMobileOpen: (open: boolean) => void;\n mobileContentChildren: React.ReactNode;\n setMobileContentChildren: (children: React.ReactNode) => void;\n mobileBrandChildren: React.ReactNode;\n setMobileBrandChildren: (children: React.ReactNode) => void;\n\n // Root nav id\n rootId: string;\n icons?: NavigationMenuIcons;\n}\n\nexport const NavigationMenuContext = React.createContext<NavigationMenuContextValue | null>(null);\n\nexport function useNavigationMenuContext(): NavigationMenuContextValue {\n const ctx = React.useContext(NavigationMenuContext);\n if (!ctx) {\n throw new Error('NavigationMenu compound components must be used within NavigationMenu');\n }\n return ctx;\n}\n\n// ============================================\n// Item Context\n// ============================================\n\nexport interface NavigationMenuItemContextValue {\n value: string;\n triggerId: string;\n contentId: string;\n}\n\nexport const NavigationMenuItemContext = React.createContext<NavigationMenuItemContextValue | null>(null);\n\nexport function useNavigationMenuItemContext(): NavigationMenuItemContextValue {\n const ctx = React.useContext(NavigationMenuItemContext);\n if (!ctx) {\n throw new Error('NavigationMenu.Trigger/Content must be used within NavigationMenu.Item');\n }\n return ctx;\n}\n"],"names":[],"mappings":";AA+EO,MAAM,wBAAwB,MAAM,cAAiD,IAAI;AAEzF,SAAS,2BAAuD;AACrE,QAAM,MAAM,MAAM,WAAW,qBAAqB;AAClD,MAAI,CAAC,KAAK;AACR,UAAM,IAAI,MAAM,uEAAuE;AAAA,EACzF;AACA,SAAO;AACT;AAYO,MAAM,4BAA4B,MAAM,cAAqD,IAAI;AAEjG,SAAS,+BAA+D;AAC7E,QAAM,MAAM,MAAM,WAAW,yBAAyB;AACtD,MAAI,CAAC,KAAK;AACR,UAAM,IAAI,MAAM,wEAAwE;AAAA,EAC1F;AACA,SAAO;AACT;"}
@@ -27,6 +27,13 @@ function _interopNamespaceDefault(e) {
27
27
  return Object.freeze(n);
28
28
  }
29
29
  const React__namespace = /* @__PURE__ */ _interopNamespaceDefault(React);
30
+ function composeNavMenuClickHandlers(childHandler, internalHandler) {
31
+ return (event) => {
32
+ childHandler == null ? void 0 : childHandler(event);
33
+ if (event.defaultPrevented) return;
34
+ internalHandler(event);
35
+ };
36
+ }
30
37
  function useIsMobile() {
31
38
  const [isMobile, setIsMobile] = React__namespace.useState(false);
32
39
  React__namespace.useEffect(() => {
@@ -39,6 +46,10 @@ function useIsMobile() {
39
46
  }, []);
40
47
  return isMobile;
41
48
  }
49
+ function renderNavigationMenuIcon(slot, state) {
50
+ if (slot === void 0) return void 0;
51
+ return typeof slot === "function" ? slot(state) : slot;
52
+ }
42
53
  function NavigationMenuRoot({
43
54
  children,
44
55
  value: controlledValue,
@@ -47,6 +58,7 @@ function NavigationMenuRoot({
47
58
  orientation = "horizontal",
48
59
  delayDuration = 200,
49
60
  skipDelayDuration = 300,
61
+ icons,
50
62
  className,
51
63
  "aria-label": ariaLabel = "Main navigation",
52
64
  ...htmlProps
@@ -70,9 +82,10 @@ function NavigationMenuRoot({
70
82
  ...state,
71
83
  orientation,
72
84
  isMobile,
73
- rootId
85
+ rootId,
86
+ icons
74
87
  }),
75
- [state, orientation, isMobile, rootId]
88
+ [state, orientation, isMobile, rootId, icons]
76
89
  );
77
90
  return /* @__PURE__ */ jsxRuntime.jsx(NavigationMenuContext.NavigationMenuContext.Provider, { value: contextValue, children: /* @__PURE__ */ jsxRuntime.jsxs("nav", { ...htmlProps, className: classes, "aria-label": ariaLabel, "data-orientation": orientation, children: [
78
91
  children,
@@ -150,6 +163,7 @@ function NavigationMenuItem({ children, value: valueProp, className }) {
150
163
  return /* @__PURE__ */ jsxRuntime.jsx(NavigationMenuContext.NavigationMenuItemContext.Provider, { value: itemCtx, children: /* @__PURE__ */ jsxRuntime.jsx("li", { className, children }) });
151
164
  }
152
165
  function NavigationMenuTrigger({ children, className }) {
166
+ var _a;
153
167
  const ctx = NavigationMenuContext.useNavigationMenuContext();
154
168
  const itemCtx = NavigationMenuContext.useNavigationMenuItemContext();
155
169
  const isOpen = ctx.value === itemCtx.value;
@@ -201,7 +215,7 @@ function NavigationMenuTrigger({ children, className }) {
201
215
  }, ctx.delayDuration);
202
216
  };
203
217
  const handleKeyDown = (e) => {
204
- var _a;
218
+ var _a2;
205
219
  if (e.key === "Enter" || e.key === " ") {
206
220
  e.preventDefault();
207
221
  ctx.setValue(isOpen ? "" : itemCtx.value);
@@ -209,10 +223,15 @@ function NavigationMenuTrigger({ children, className }) {
209
223
  if (e.key === "Escape" && isOpen) {
210
224
  e.preventDefault();
211
225
  ctx.setValue("");
212
- (_a = triggerRef.current) == null ? void 0 : _a.focus();
226
+ (_a2 = triggerRef.current) == null ? void 0 : _a2.focus();
213
227
  }
214
228
  };
215
229
  const classes = [NavigationMenu_module.default.trigger, className].filter(Boolean).join(" ");
230
+ const chevronOverride = renderNavigationMenuIcon((_a = ctx.icons) == null ? void 0 : _a.triggerChevron, {
231
+ slot: "triggerChevron",
232
+ open: isOpen,
233
+ isMobile: ctx.isMobile
234
+ });
216
235
  return /* @__PURE__ */ jsxRuntime.jsxs(
217
236
  "button",
218
237
  {
@@ -230,7 +249,7 @@ function NavigationMenuTrigger({ children, className }) {
230
249
  onKeyDown: handleKeyDown,
231
250
  children: [
232
251
  children,
233
- /* @__PURE__ */ jsxRuntime.jsx(react.CaretDown, { size: 12, className: NavigationMenu_module.default.triggerChevron, "aria-hidden": true })
252
+ chevronOverride ? /* @__PURE__ */ jsxRuntime.jsx("span", { className: NavigationMenu_module.default.triggerChevron, "aria-hidden": true, children: chevronOverride }) : /* @__PURE__ */ jsxRuntime.jsx(react.CaretDown, { size: 12, className: NavigationMenu_module.default.triggerChevron, "aria-hidden": true })
234
253
  ]
235
254
  }
236
255
  );
@@ -343,6 +362,7 @@ function NavigationMenuLink({
343
362
  }, [ctx, itemCtx, children, title, href]);
344
363
  const handleClick = (e) => {
345
364
  onClick == null ? void 0 : onClick(e);
365
+ if (e.defaultPrevented) return;
346
366
  if ((ctx == null ? void 0 : ctx.isMobile) && ctx.mobileOpen) {
347
367
  ctx.setMobileOpen(false);
348
368
  }
@@ -366,9 +386,11 @@ function NavigationMenuLink({
366
386
  onClick: handleClick
367
387
  };
368
388
  if (asChild && React__namespace.isValidElement(children)) {
389
+ const childProps = children.props;
369
390
  return React__namespace.cloneElement(children, {
370
391
  ...linkProps2,
371
- className: [classes2, children.props.className].filter(Boolean).join(" "),
392
+ onClick: composeNavMenuClickHandlers(childProps.onClick, handleClick),
393
+ className: [classes2, childProps.className].filter(Boolean).join(" "),
372
394
  children: /* @__PURE__ */ jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [
373
395
  icon && /* @__PURE__ */ jsxRuntime.jsx("span", { className: NavigationMenu_module.default.linkIcon, children: icon }),
374
396
  /* @__PURE__ */ jsxRuntime.jsxs("span", { className: NavigationMenu_module.default.linkBody, children: [
@@ -399,9 +421,11 @@ function NavigationMenuLink({
399
421
  onClick: handleClick
400
422
  };
401
423
  if (asChild && React__namespace.isValidElement(children)) {
424
+ const childProps = children.props;
402
425
  return React__namespace.cloneElement(children, {
403
426
  ...linkProps,
404
- className: [classes, children.props.className].filter(Boolean).join(" ")
427
+ onClick: composeNavMenuClickHandlers(childProps.onClick, handleClick),
428
+ className: [classes, childProps.className].filter(Boolean).join(" ")
405
429
  });
406
430
  }
407
431
  return /* @__PURE__ */ jsxRuntime.jsx("a", { ...linkProps, children });
@@ -498,7 +522,17 @@ function NavigationMenuMobileSection({ children, label }) {
498
522
  ] });
499
523
  }
500
524
  function MobileHamburger() {
501
- const { mobileOpen, setMobileOpen } = NavigationMenuContext.useNavigationMenuContext();
525
+ var _a, _b;
526
+ const ctx = NavigationMenuContext.useNavigationMenuContext();
527
+ const { mobileOpen, setMobileOpen } = ctx;
528
+ const iconOverride = renderNavigationMenuIcon(
529
+ mobileOpen ? (_a = ctx.icons) == null ? void 0 : _a.mobileClose : (_b = ctx.icons) == null ? void 0 : _b.mobileMenu,
530
+ {
531
+ slot: mobileOpen ? "mobileClose" : "mobileMenu",
532
+ open: mobileOpen,
533
+ isMobile: true
534
+ }
535
+ );
502
536
  return /* @__PURE__ */ jsxRuntime.jsx(
503
537
  "button",
504
538
  {
@@ -507,11 +541,12 @@ function MobileHamburger() {
507
541
  onClick: () => setMobileOpen(!mobileOpen),
508
542
  "aria-label": "Toggle navigation",
509
543
  "aria-expanded": mobileOpen,
510
- children: mobileOpen ? /* @__PURE__ */ jsxRuntime.jsx(react.X, { size: 24, "aria-hidden": true }) : /* @__PURE__ */ jsxRuntime.jsx(react.List, { size: 24, "aria-hidden": true })
544
+ children: iconOverride ?? (mobileOpen ? /* @__PURE__ */ jsxRuntime.jsx(react.X, { size: 24, "aria-hidden": true }) : /* @__PURE__ */ jsxRuntime.jsx(react.List, { size: 24, "aria-hidden": true }))
511
545
  }
512
546
  );
513
547
  }
514
548
  function MobileDrawer() {
549
+ var _a;
515
550
  const ctx = NavigationMenuContext.useNavigationMenuContext();
516
551
  const drawerRef = React__namespace.useRef(null);
517
552
  a11y.useFocusTrap(drawerRef, true);
@@ -565,7 +600,11 @@ function MobileDrawer() {
565
600
  className: NavigationMenu_module.default.drawerClose,
566
601
  onClick: () => ctx.setMobileOpen(false),
567
602
  "aria-label": "Close navigation",
568
- children: /* @__PURE__ */ jsxRuntime.jsx(react.X, { size: 20, "aria-hidden": true })
603
+ children: renderNavigationMenuIcon((_a = ctx.icons) == null ? void 0 : _a.drawerClose, {
604
+ slot: "drawerClose",
605
+ open: ctx.mobileOpen,
606
+ isMobile: true
607
+ }) ?? /* @__PURE__ */ jsxRuntime.jsx(react.X, { size: 20, "aria-hidden": true })
569
608
  }
570
609
  )
571
610
  ] }),