ivt 0.4.5 → 0.4.6

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 (224) hide show
  1. package/dist/accordion/index.mjs +15 -14
  2. package/dist/accordion/index.mjs.map +1 -1
  3. package/dist/alert/index.mjs +2 -2
  4. package/dist/alert-dialog/index.mjs +17 -16
  5. package/dist/alert-dialog/index.mjs.map +1 -1
  6. package/dist/aspect-ratio/index.d.ts +7 -0
  7. package/dist/aspect-ratio/index.mjs +46 -0
  8. package/dist/aspect-ratio/index.mjs.map +1 -0
  9. package/dist/avatar/index.mjs +7 -7
  10. package/dist/badge/index.mjs +3 -3
  11. package/dist/base/index.mjs +37 -35
  12. package/dist/base/index.mjs.map +1 -1
  13. package/dist/breadcrumb/index.d.ts +14 -0
  14. package/dist/breadcrumb/index.mjs +71 -0
  15. package/dist/breadcrumb/index.mjs.map +1 -0
  16. package/dist/button/index.mjs +3 -3
  17. package/dist/calendar/index.mjs +8 -8
  18. package/dist/card/index.mjs +2 -2
  19. package/dist/carousel/index.d.ts +25 -0
  20. package/dist/carousel/index.mjs +1793 -0
  21. package/dist/carousel/index.mjs.map +1 -0
  22. package/dist/chart/index.mjs +4 -4
  23. package/dist/checkbox/index.mjs +13 -13
  24. package/dist/chunks/{Container-DVypwIQb.mjs → Container-sBmoUJ1A.mjs} +2 -2
  25. package/dist/chunks/{Container-DVypwIQb.mjs.map → Container-sBmoUJ1A.mjs.map} +1 -1
  26. package/dist/chunks/{_commonjsHelpers-DxUjvHAf.mjs → _commonjsHelpers-DMx7h_rP.mjs} +1 -1
  27. package/dist/chunks/_commonjsHelpers-DMx7h_rP.mjs.map +1 -0
  28. package/dist/chunks/{accordion-C-7WU65v.mjs → accordion-BEzCfjyX.mjs} +11 -133
  29. package/dist/chunks/accordion-BEzCfjyX.mjs.map +1 -0
  30. package/dist/chunks/{badge-FyqsRWpb.mjs → badge-poifvE-U.mjs} +2 -2
  31. package/dist/chunks/{badge-FyqsRWpb.mjs.map → badge-poifvE-U.mjs.map} +1 -1
  32. package/dist/chunks/{bundle-mjs--Uc0zBMR.mjs → bundle-mjs-8KEENQOJ.mjs} +1 -1
  33. package/dist/chunks/{bundle-mjs--Uc0zBMR.mjs.map → bundle-mjs-8KEENQOJ.mjs.map} +1 -1
  34. package/dist/chunks/{button-CkvbfoBC.mjs → button-TULRIYFO.mjs} +2 -2
  35. package/dist/chunks/{button-CkvbfoBC.mjs.map → button-TULRIYFO.mjs.map} +1 -1
  36. package/dist/chunks/{calendar-DthuUOQB.mjs → calendar-nJ5T1YgK.mjs} +6 -6
  37. package/dist/chunks/{calendar-DthuUOQB.mjs.map → calendar-nJ5T1YgK.mjs.map} +1 -1
  38. package/dist/chunks/{check-CEEnU7uo.mjs → check-DcPt24aD.mjs} +2 -2
  39. package/dist/chunks/{check-CEEnU7uo.mjs.map → check-DcPt24aD.mjs.map} +1 -1
  40. package/dist/chunks/{chevron-down-CdtWWCvB.mjs → chevron-down-BNw46No-.mjs} +2 -2
  41. package/dist/chunks/{chevron-down-CdtWWCvB.mjs.map → chevron-down-BNw46No-.mjs.map} +1 -1
  42. package/dist/chunks/{chevron-left-dKr4sXaL.mjs → chevron-left-B-ZN622G.mjs} +2 -2
  43. package/dist/chunks/{chevron-left-dKr4sXaL.mjs.map → chevron-left-B-ZN622G.mjs.map} +1 -1
  44. package/dist/chunks/{chevron-right-BJERqiST.mjs → chevron-right-Ddz8dCda.mjs} +2 -2
  45. package/dist/chunks/{chevron-right-BJERqiST.mjs.map → chevron-right-Ddz8dCda.mjs.map} +1 -1
  46. package/dist/chunks/{chevrons-up-down-CvLRAoM4.mjs → chevrons-up-down-ChXPuZd6.mjs} +2 -2
  47. package/dist/chunks/{chevrons-up-down-CvLRAoM4.mjs.map → chevrons-up-down-ChXPuZd6.mjs.map} +1 -1
  48. package/dist/chunks/{command-BT07aIMk.mjs → command-D6QS1LFL.mjs} +8 -8
  49. package/dist/chunks/{command-BT07aIMk.mjs.map → command-D6QS1LFL.mjs.map} +1 -1
  50. package/dist/chunks/{createLucideIcon-C-36jtLf.mjs → createLucideIcon-DOOu6ntc.mjs} +1 -1
  51. package/dist/chunks/{createLucideIcon-C-36jtLf.mjs.map → createLucideIcon-DOOu6ntc.mjs.map} +1 -1
  52. package/dist/chunks/{dialog-E_tuNVVP.mjs → dialog-BefJPh8X.mjs} +4 -4
  53. package/dist/chunks/{dialog-E_tuNVVP.mjs.map → dialog-BefJPh8X.mjs.map} +1 -1
  54. package/dist/chunks/ellipsis-Cwr1X9R2.mjs +35 -0
  55. package/dist/chunks/ellipsis-Cwr1X9R2.mjs.map +1 -0
  56. package/dist/chunks/{hover-card-BnkDAKKp.mjs → hover-card-CcNjcMZa.mjs} +11 -10
  57. package/dist/chunks/{hover-card-BnkDAKKp.mjs.map → hover-card-CcNjcMZa.mjs.map} +1 -1
  58. package/dist/chunks/{index-ypP8ZSEh.mjs → index-0fdTSdHQ.mjs} +6 -21
  59. package/dist/chunks/index-0fdTSdHQ.mjs.map +1 -0
  60. package/dist/chunks/{index-Cn5ihFPu.mjs → index-1tph_k2t.mjs} +1 -1
  61. package/dist/chunks/{index-Cn5ihFPu.mjs.map → index-1tph_k2t.mjs.map} +1 -1
  62. package/dist/chunks/{index-B63fbqEU.mjs → index-BCsiqIRL.mjs} +1 -1
  63. package/dist/chunks/{index-B63fbqEU.mjs.map → index-BCsiqIRL.mjs.map} +1 -1
  64. package/dist/chunks/index-Bb31UsVK.mjs +7 -0
  65. package/dist/chunks/index-Bb31UsVK.mjs.map +1 -0
  66. package/dist/chunks/index-BnNdF3Y6.mjs +133 -0
  67. package/dist/chunks/index-BnNdF3Y6.mjs.map +1 -0
  68. package/dist/chunks/{index-hd6oiDyZ.mjs → index-BwVg1Kb5.mjs} +1 -1
  69. package/dist/chunks/{index-hd6oiDyZ.mjs.map → index-BwVg1Kb5.mjs.map} +1 -1
  70. package/dist/chunks/{index-Cf5nP8Sx.mjs → index-CK9CWim6.mjs} +2 -2
  71. package/dist/chunks/{index-Cf5nP8Sx.mjs.map → index-CK9CWim6.mjs.map} +1 -1
  72. package/dist/chunks/{index-Bv_h_hMx.mjs → index-CQc8iXpK.mjs} +11 -10
  73. package/dist/chunks/{index-Bv_h_hMx.mjs.map → index-CQc8iXpK.mjs.map} +1 -1
  74. package/dist/chunks/{index-DfGdJ6wp.mjs → index-CSiM72Dy.mjs} +1 -1
  75. package/dist/chunks/{index-DfGdJ6wp.mjs.map → index-CSiM72Dy.mjs.map} +1 -1
  76. package/dist/chunks/{index-BIfMxNBh.mjs → index-CWMDV9qs.mjs} +2 -2
  77. package/dist/chunks/{index-BIfMxNBh.mjs.map → index-CWMDV9qs.mjs.map} +1 -1
  78. package/dist/chunks/{index-oRHhKb2z.mjs → index-CjtaP9C4.mjs} +1 -1
  79. package/dist/chunks/{index-oRHhKb2z.mjs.map → index-CjtaP9C4.mjs.map} +1 -1
  80. package/dist/chunks/index-Cl4mLFZO.mjs +21 -0
  81. package/dist/chunks/index-Cl4mLFZO.mjs.map +1 -0
  82. package/dist/chunks/{index-VGFs-gvq.mjs → index-D1qT_gBX.mjs} +1 -1
  83. package/dist/chunks/{index-VGFs-gvq.mjs.map → index-D1qT_gBX.mjs.map} +1 -1
  84. package/dist/chunks/{index-OeC6d8TA.mjs → index-D7B2_9g4.mjs} +2 -2
  85. package/dist/chunks/{index-OeC6d8TA.mjs.map → index-D7B2_9g4.mjs.map} +1 -1
  86. package/dist/chunks/{index-DujcHJqa.mjs → index-DDe3wbsL.mjs} +1 -1
  87. package/dist/chunks/{index-DujcHJqa.mjs.map → index-DDe3wbsL.mjs.map} +1 -1
  88. package/dist/chunks/{index-n6Vlh2qs.mjs → index-DSL6rasA.mjs} +9 -9
  89. package/dist/chunks/{index-n6Vlh2qs.mjs.map → index-DSL6rasA.mjs.map} +1 -1
  90. package/dist/chunks/{index-D7MXDvLR.mjs → index-DejfSFbY.mjs} +7 -7
  91. package/dist/chunks/{index-D7MXDvLR.mjs.map → index-DejfSFbY.mjs.map} +1 -1
  92. package/dist/chunks/{index-CiQJ7wod.mjs → index-DoRi3lh9.mjs} +2 -2
  93. package/dist/chunks/{index-CiQJ7wod.mjs.map → index-DoRi3lh9.mjs.map} +1 -1
  94. package/dist/chunks/{index-ZiahhVWN.mjs → index-DvLErdHO.mjs} +1 -1
  95. package/dist/chunks/{index-ZiahhVWN.mjs.map → index-DvLErdHO.mjs.map} +1 -1
  96. package/dist/chunks/{index-Bzi8Hpka.mjs → index-EfpXtubk.mjs} +5 -5
  97. package/dist/chunks/{index-Bzi8Hpka.mjs.map → index-EfpXtubk.mjs.map} +1 -1
  98. package/dist/chunks/{index-mnhyF3Xs.mjs → index-JyHiZGQv.mjs} +16 -15
  99. package/dist/chunks/{index-mnhyF3Xs.mjs.map → index-JyHiZGQv.mjs.map} +1 -1
  100. package/dist/chunks/{index-0tMmOuv1.mjs → index-P1gmXtXB.mjs} +3 -3
  101. package/dist/chunks/{index-0tMmOuv1.mjs.map → index-P1gmXtXB.mjs.map} +1 -1
  102. package/dist/chunks/{index-D1toVD_V.mjs → index-e34k5BX3.mjs} +1 -1
  103. package/dist/chunks/{index-D1toVD_V.mjs.map → index-e34k5BX3.mjs.map} +1 -1
  104. package/dist/chunks/{input-f9f7o4dl.mjs → input-CDsq1Xde.mjs} +2 -2
  105. package/dist/chunks/{input-f9f7o4dl.mjs.map → input-CDsq1Xde.mjs.map} +1 -1
  106. package/dist/chunks/{label-ClnI7CPw.mjs → label-BzGy6SRg.mjs} +3 -3
  107. package/dist/chunks/{label-ClnI7CPw.mjs.map → label-BzGy6SRg.mjs.map} +1 -1
  108. package/dist/chunks/{pagination-ByGWAyDY.mjs → pagination-CfFGN_ib.mjs} +6 -37
  109. package/dist/chunks/pagination-CfFGN_ib.mjs.map +1 -0
  110. package/dist/chunks/{popover-BP0h5od9.mjs → popover-BlSoIp_B.mjs} +13 -12
  111. package/dist/chunks/{popover-BP0h5od9.mjs.map → popover-BlSoIp_B.mjs.map} +1 -1
  112. package/dist/chunks/{progress-C36nV_EJ.mjs → progress-CIapbA26.mjs} +4 -4
  113. package/dist/chunks/{progress-C36nV_EJ.mjs.map → progress-CIapbA26.mjs.map} +1 -1
  114. package/dist/chunks/{pt-BR-B365hYCq.mjs → pt-BR-BCfQl1oP.mjs} +3 -3
  115. package/dist/chunks/{pt-BR-B365hYCq.mjs.map → pt-BR-BCfQl1oP.mjs.map} +1 -1
  116. package/dist/chunks/{scroll-area-BCPovfc9.mjs → scroll-area-BE1y6Igy.mjs} +11 -15
  117. package/dist/chunks/scroll-area-BE1y6Igy.mjs.map +1 -0
  118. package/dist/chunks/{select-DsHm4Ncw.mjs → select-BBb0ke76.mjs} +5 -5
  119. package/dist/chunks/{select-DsHm4Ncw.mjs.map → select-BBb0ke76.mjs.map} +1 -1
  120. package/dist/chunks/{separator-D5jBoFYi.mjs → separator-B1yL1lh8.mjs} +3 -3
  121. package/dist/chunks/{separator-D5jBoFYi.mjs.map → separator-B1yL1lh8.mjs.map} +1 -1
  122. package/dist/chunks/sheet-FhW-R397.mjs +80 -0
  123. package/dist/chunks/sheet-FhW-R397.mjs.map +1 -0
  124. package/dist/chunks/{skeleton-BW9vlu4U.mjs → skeleton-Cy2Kyc1R.mjs} +2 -2
  125. package/dist/chunks/{skeleton-BW9vlu4U.mjs.map → skeleton-Cy2Kyc1R.mjs.map} +1 -1
  126. package/dist/chunks/{sortable-DbjP8Kx8.mjs → sortable-qR5yOJD2.mjs} +3 -3
  127. package/dist/chunks/{sortable-DbjP8Kx8.mjs.map → sortable-qR5yOJD2.mjs.map} +1 -1
  128. package/dist/chunks/{table-BrJ_iN3j.mjs → table-QPbxZz58.mjs} +2 -2
  129. package/dist/chunks/{table-BrJ_iN3j.mjs.map → table-QPbxZz58.mjs.map} +1 -1
  130. package/dist/chunks/{toggle-BYDRoIw7.mjs → toggle-CoBW3Uqo.mjs} +5 -5
  131. package/dist/chunks/{toggle-BYDRoIw7.mjs.map → toggle-CoBW3Uqo.mjs.map} +1 -1
  132. package/dist/chunks/{tooltip-DnGcpocO.mjs → tooltip-DNfLTD30.mjs} +13 -12
  133. package/dist/chunks/{tooltip-DnGcpocO.mjs.map → tooltip-DNfLTD30.mjs.map} +1 -1
  134. package/dist/chunks/{trash-2-Ccqlx7cY.mjs → trash-2-D3X2krCW.mjs} +2 -2
  135. package/dist/chunks/{trash-2-Ccqlx7cY.mjs.map → trash-2-D3X2krCW.mjs.map} +1 -1
  136. package/dist/chunks/{tslib.es6-CZ32kgxs.mjs → tslib.es6-UJQ1U8uE.mjs} +1 -1
  137. package/dist/chunks/{tslib.es6-CZ32kgxs.mjs.map → tslib.es6-UJQ1U8uE.mjs.map} +1 -1
  138. package/dist/chunks/{utils-SWF3jXjy.mjs → utils-AmLv58nm.mjs} +2 -2
  139. package/dist/chunks/{utils-SWF3jXjy.mjs.map → utils-AmLv58nm.mjs.map} +1 -1
  140. package/dist/chunks/{x-B9_z9ee1.mjs → x-CENvqJg-.mjs} +2 -2
  141. package/dist/chunks/{x-B9_z9ee1.mjs.map → x-CENvqJg-.mjs.map} +1 -1
  142. package/dist/collapsible/index.d.ts +9 -0
  143. package/dist/collapsible/index.mjs +35 -0
  144. package/dist/collapsible/index.mjs.map +1 -0
  145. package/dist/combobox/index.mjs +26 -25
  146. package/dist/combobox/index.mjs.map +1 -1
  147. package/dist/command/index.mjs +20 -19
  148. package/dist/command/index.mjs.map +1 -1
  149. package/dist/context-menu/index.d.ts +28 -0
  150. package/dist/context-menu/index.mjs +460 -0
  151. package/dist/context-menu/index.mjs.map +1 -0
  152. package/dist/data-table/index.mjs +35 -33
  153. package/dist/data-table/index.mjs.map +1 -1
  154. package/dist/date-picker/index.mjs +25 -24
  155. package/dist/date-picker/index.mjs.map +1 -1
  156. package/dist/dialog/index.mjs +19 -18
  157. package/dist/dialog/index.mjs.map +1 -1
  158. package/dist/drawer/index.d.ts +16 -0
  159. package/dist/drawer/index.mjs +1704 -0
  160. package/dist/drawer/index.mjs.map +1 -0
  161. package/dist/dropdown-menu/index.mjs +23 -22
  162. package/dist/dropdown-menu/index.mjs.map +1 -1
  163. package/dist/dropzone/index.mjs +18 -17
  164. package/dist/dropzone/index.mjs.map +1 -1
  165. package/dist/form/index.mjs +4 -4
  166. package/dist/hover-card/index.mjs +15 -14
  167. package/dist/hover-card/index.mjs.map +1 -1
  168. package/dist/icon/index.mjs +1 -1
  169. package/dist/index.css +1 -1
  170. package/dist/input/index.mjs +3 -3
  171. package/dist/input-otp/index.d.ts +14 -0
  172. package/dist/input-otp/index.mjs +456 -0
  173. package/dist/input-otp/index.mjs.map +1 -0
  174. package/dist/ivt.css +1 -1
  175. package/dist/label/index.mjs +4 -4
  176. package/dist/layout/index.mjs +5 -5
  177. package/dist/menubar/index.mjs +23 -22
  178. package/dist/menubar/index.mjs.map +1 -1
  179. package/dist/multi-select/index.mjs +30 -29
  180. package/dist/multi-select/index.mjs.map +1 -1
  181. package/dist/navigation-menu/index.d.ts +18 -0
  182. package/dist/navigation-menu/index.mjs +868 -0
  183. package/dist/navigation-menu/index.mjs.map +1 -0
  184. package/dist/pagination/index.mjs +8 -7
  185. package/dist/pagination/index.mjs.map +1 -1
  186. package/dist/popover/index.mjs +18 -17
  187. package/dist/popover/index.mjs.map +1 -1
  188. package/dist/progress/index.mjs +5 -5
  189. package/dist/radio-group/index.mjs +17 -17
  190. package/dist/resizable/index.d.ts +11 -0
  191. package/dist/resizable/index.mjs +2166 -0
  192. package/dist/resizable/index.mjs.map +1 -0
  193. package/dist/scroll-area/index.mjs +12 -11
  194. package/dist/scroll-area/index.mjs.map +1 -1
  195. package/dist/select/index.mjs +6 -6
  196. package/dist/separator/index.mjs +4 -4
  197. package/dist/shared/index.mjs +5 -5
  198. package/dist/sheet/index.mjs +20 -93
  199. package/dist/sheet/index.mjs.map +1 -1
  200. package/dist/sidebar/index.d.ts +75 -0
  201. package/dist/sidebar/index.mjs +457 -0
  202. package/dist/sidebar/index.mjs.map +1 -0
  203. package/dist/skeleton/index.mjs +3 -3
  204. package/dist/skeleton-component/index.mjs +4 -4
  205. package/dist/slider/index.d.ts +7 -0
  206. package/dist/slider/index.mjs +594 -0
  207. package/dist/slider/index.mjs.map +1 -0
  208. package/dist/sortable/index.mjs +4 -4
  209. package/dist/switch/index.mjs +10 -10
  210. package/dist/table/index.mjs +3 -3
  211. package/dist/tabs/index.mjs +13 -13
  212. package/dist/textarea/index.mjs +2 -2
  213. package/dist/toast/index.mjs +15 -14
  214. package/dist/toast/index.mjs.map +1 -1
  215. package/dist/toggle/index.mjs +7 -7
  216. package/dist/toggle-group/index.mjs +13 -13
  217. package/dist/tooltip/index.mjs +17 -16
  218. package/dist/tooltip/index.mjs.map +1 -1
  219. package/package.json +59 -6
  220. package/dist/chunks/_commonjsHelpers-DxUjvHAf.mjs.map +0 -1
  221. package/dist/chunks/accordion-C-7WU65v.mjs.map +0 -1
  222. package/dist/chunks/index-ypP8ZSEh.mjs.map +0 -1
  223. package/dist/chunks/pagination-ByGWAyDY.mjs.map +0 -1
  224. package/dist/chunks/scroll-area-BCPovfc9.mjs.map +0 -1
@@ -0,0 +1,868 @@
1
+ import * as React from 'react';
2
+ import ReactDOM__default from 'react-dom';
3
+ import { c as createContextScope } from '../chunks/index-DvLErdHO.mjs';
4
+ import { c as composeEventHandlers } from '../chunks/index-D1qT_gBX.mjs';
5
+ import { P as Primitive, d as dispatchDiscreteCustomEvent } from '../chunks/index-DDe3wbsL.mjs';
6
+ import { u as useControllableState } from '../chunks/index-DoRi3lh9.mjs';
7
+ import { u as useComposedRefs, c as composeRefs } from '../chunks/index-CSiM72Dy.mjs';
8
+ import { u as useDirection } from '../chunks/index-CjtaP9C4.mjs';
9
+ import { P as Presence } from '../chunks/index-P1gmXtXB.mjs';
10
+ import { u as useId } from '../chunks/index-CWMDV9qs.mjs';
11
+ import { createCollection } from '@radix-ui/react-collection';
12
+ import { D as DismissableLayer } from '../chunks/index-0fdTSdHQ.mjs';
13
+ import { u as usePrevious } from '../chunks/index-1tph_k2t.mjs';
14
+ import { u as useLayoutEffect2 } from '../chunks/index-BwVg1Kb5.mjs';
15
+ import { u as useCallbackRef } from '../chunks/index-e34k5BX3.mjs';
16
+ import { R as Root } from '../chunks/index-D7B2_9g4.mjs';
17
+ import { jsx, jsxs, Fragment } from 'react/jsx-runtime';
18
+ import { cva } from 'class-variance-authority';
19
+ import { c as cn } from '../chunks/utils-AmLv58nm.mjs';
20
+ import { C as ChevronDown } from '../chunks/chevron-down-BNw46No-.mjs';
21
+ import '@radix-ui/react-slot';
22
+ import '../chunks/bundle-mjs-8KEENQOJ.mjs';
23
+ import '../chunks/createLucideIcon-DOOu6ntc.mjs';
24
+
25
+ var NAVIGATION_MENU_NAME = "NavigationMenu";
26
+ var [Collection, useCollection, createCollectionScope] = createCollection(NAVIGATION_MENU_NAME);
27
+ var [FocusGroupCollection, useFocusGroupCollection, createFocusGroupCollectionScope] = createCollection(NAVIGATION_MENU_NAME);
28
+ var [createNavigationMenuContext] = createContextScope(NAVIGATION_MENU_NAME, [
29
+ createCollectionScope,
30
+ createFocusGroupCollectionScope
31
+ ]);
32
+ var [NavigationMenuProviderImpl, useNavigationMenuContext] = createNavigationMenuContext(NAVIGATION_MENU_NAME);
33
+ var [ViewportContentProvider, useViewportContentContext] = createNavigationMenuContext(NAVIGATION_MENU_NAME);
34
+ var NavigationMenu$1 = React.forwardRef((props, forwardedRef)=>{
35
+ const { __scopeNavigationMenu, value: valueProp, onValueChange, defaultValue, delayDuration = 200, skipDelayDuration = 300, orientation = "horizontal", dir, ...NavigationMenuProps } = props;
36
+ const [navigationMenu, setNavigationMenu] = React.useState(null);
37
+ const composedRef = useComposedRefs(forwardedRef, (node)=>setNavigationMenu(node));
38
+ const direction = useDirection(dir);
39
+ const openTimerRef = React.useRef(0);
40
+ const closeTimerRef = React.useRef(0);
41
+ const skipDelayTimerRef = React.useRef(0);
42
+ const [isOpenDelayed, setIsOpenDelayed] = React.useState(true);
43
+ const [value, setValue] = useControllableState({
44
+ prop: valueProp,
45
+ onChange: (value2)=>{
46
+ const isOpen = value2 !== "";
47
+ const hasSkipDelayDuration = skipDelayDuration > 0;
48
+ if (isOpen) {
49
+ window.clearTimeout(skipDelayTimerRef.current);
50
+ if (hasSkipDelayDuration) setIsOpenDelayed(false);
51
+ } else {
52
+ window.clearTimeout(skipDelayTimerRef.current);
53
+ skipDelayTimerRef.current = window.setTimeout(()=>setIsOpenDelayed(true), skipDelayDuration);
54
+ }
55
+ onValueChange?.(value2);
56
+ },
57
+ defaultProp: defaultValue ?? "",
58
+ caller: NAVIGATION_MENU_NAME
59
+ });
60
+ const startCloseTimer = React.useCallback(()=>{
61
+ window.clearTimeout(closeTimerRef.current);
62
+ closeTimerRef.current = window.setTimeout(()=>setValue(""), 150);
63
+ }, [
64
+ setValue
65
+ ]);
66
+ const handleOpen = React.useCallback((itemValue)=>{
67
+ window.clearTimeout(closeTimerRef.current);
68
+ setValue(itemValue);
69
+ }, [
70
+ setValue
71
+ ]);
72
+ const handleDelayedOpen = React.useCallback((itemValue)=>{
73
+ const isOpenItem = value === itemValue;
74
+ if (isOpenItem) {
75
+ window.clearTimeout(closeTimerRef.current);
76
+ } else {
77
+ openTimerRef.current = window.setTimeout(()=>{
78
+ window.clearTimeout(closeTimerRef.current);
79
+ setValue(itemValue);
80
+ }, delayDuration);
81
+ }
82
+ }, [
83
+ value,
84
+ setValue,
85
+ delayDuration
86
+ ]);
87
+ React.useEffect(()=>{
88
+ return ()=>{
89
+ window.clearTimeout(openTimerRef.current);
90
+ window.clearTimeout(closeTimerRef.current);
91
+ window.clearTimeout(skipDelayTimerRef.current);
92
+ };
93
+ }, []);
94
+ return /* @__PURE__ */ jsx(NavigationMenuProvider, {
95
+ scope: __scopeNavigationMenu,
96
+ isRootMenu: true,
97
+ value,
98
+ dir: direction,
99
+ orientation,
100
+ rootNavigationMenu: navigationMenu,
101
+ onTriggerEnter: (itemValue)=>{
102
+ window.clearTimeout(openTimerRef.current);
103
+ if (isOpenDelayed) handleDelayedOpen(itemValue);
104
+ else handleOpen(itemValue);
105
+ },
106
+ onTriggerLeave: ()=>{
107
+ window.clearTimeout(openTimerRef.current);
108
+ startCloseTimer();
109
+ },
110
+ onContentEnter: ()=>window.clearTimeout(closeTimerRef.current),
111
+ onContentLeave: startCloseTimer,
112
+ onItemSelect: (itemValue)=>{
113
+ setValue((prevValue)=>prevValue === itemValue ? "" : itemValue);
114
+ },
115
+ onItemDismiss: ()=>setValue(""),
116
+ children: /* @__PURE__ */ jsx(Primitive.nav, {
117
+ "aria-label": "Main",
118
+ "data-orientation": orientation,
119
+ dir: direction,
120
+ ...NavigationMenuProps,
121
+ ref: composedRef
122
+ })
123
+ });
124
+ });
125
+ NavigationMenu$1.displayName = NAVIGATION_MENU_NAME;
126
+ var SUB_NAME = "NavigationMenuSub";
127
+ var NavigationMenuSub = React.forwardRef((props, forwardedRef)=>{
128
+ const { __scopeNavigationMenu, value: valueProp, onValueChange, defaultValue, orientation = "horizontal", ...subProps } = props;
129
+ const context = useNavigationMenuContext(SUB_NAME, __scopeNavigationMenu);
130
+ const [value, setValue] = useControllableState({
131
+ prop: valueProp,
132
+ onChange: onValueChange,
133
+ defaultProp: defaultValue ?? "",
134
+ caller: SUB_NAME
135
+ });
136
+ return /* @__PURE__ */ jsx(NavigationMenuProvider, {
137
+ scope: __scopeNavigationMenu,
138
+ isRootMenu: false,
139
+ value,
140
+ dir: context.dir,
141
+ orientation,
142
+ rootNavigationMenu: context.rootNavigationMenu,
143
+ onTriggerEnter: (itemValue)=>setValue(itemValue),
144
+ onItemSelect: (itemValue)=>setValue(itemValue),
145
+ onItemDismiss: ()=>setValue(""),
146
+ children: /* @__PURE__ */ jsx(Primitive.div, {
147
+ "data-orientation": orientation,
148
+ ...subProps,
149
+ ref: forwardedRef
150
+ })
151
+ });
152
+ });
153
+ NavigationMenuSub.displayName = SUB_NAME;
154
+ var NavigationMenuProvider = (props)=>{
155
+ const { scope, isRootMenu, rootNavigationMenu, dir, orientation, children, value, onItemSelect, onItemDismiss, onTriggerEnter, onTriggerLeave, onContentEnter, onContentLeave } = props;
156
+ const [viewport, setViewport] = React.useState(null);
157
+ const [viewportContent, setViewportContent] = React.useState(/* @__PURE__ */ new Map());
158
+ const [indicatorTrack, setIndicatorTrack] = React.useState(null);
159
+ return /* @__PURE__ */ jsx(NavigationMenuProviderImpl, {
160
+ scope,
161
+ isRootMenu,
162
+ rootNavigationMenu,
163
+ value,
164
+ previousValue: usePrevious(value),
165
+ baseId: useId(),
166
+ dir,
167
+ orientation,
168
+ viewport,
169
+ onViewportChange: setViewport,
170
+ indicatorTrack,
171
+ onIndicatorTrackChange: setIndicatorTrack,
172
+ onTriggerEnter: useCallbackRef(onTriggerEnter),
173
+ onTriggerLeave: useCallbackRef(onTriggerLeave),
174
+ onContentEnter: useCallbackRef(onContentEnter),
175
+ onContentLeave: useCallbackRef(onContentLeave),
176
+ onItemSelect: useCallbackRef(onItemSelect),
177
+ onItemDismiss: useCallbackRef(onItemDismiss),
178
+ onViewportContentChange: React.useCallback((contentValue, contentData)=>{
179
+ setViewportContent((prevContent)=>{
180
+ prevContent.set(contentValue, contentData);
181
+ return new Map(prevContent);
182
+ });
183
+ }, []),
184
+ onViewportContentRemove: React.useCallback((contentValue)=>{
185
+ setViewportContent((prevContent)=>{
186
+ if (!prevContent.has(contentValue)) return prevContent;
187
+ prevContent.delete(contentValue);
188
+ return new Map(prevContent);
189
+ });
190
+ }, []),
191
+ children: /* @__PURE__ */ jsx(Collection.Provider, {
192
+ scope,
193
+ children: /* @__PURE__ */ jsx(ViewportContentProvider, {
194
+ scope,
195
+ items: viewportContent,
196
+ children
197
+ })
198
+ })
199
+ });
200
+ };
201
+ var LIST_NAME = "NavigationMenuList";
202
+ var NavigationMenuList$1 = React.forwardRef((props, forwardedRef)=>{
203
+ const { __scopeNavigationMenu, ...listProps } = props;
204
+ const context = useNavigationMenuContext(LIST_NAME, __scopeNavigationMenu);
205
+ const list = /* @__PURE__ */ jsx(Primitive.ul, {
206
+ "data-orientation": context.orientation,
207
+ ...listProps,
208
+ ref: forwardedRef
209
+ });
210
+ return /* @__PURE__ */ jsx(Primitive.div, {
211
+ style: {
212
+ position: "relative"
213
+ },
214
+ ref: context.onIndicatorTrackChange,
215
+ children: /* @__PURE__ */ jsx(Collection.Slot, {
216
+ scope: __scopeNavigationMenu,
217
+ children: context.isRootMenu ? /* @__PURE__ */ jsx(FocusGroup, {
218
+ asChild: true,
219
+ children: list
220
+ }) : list
221
+ })
222
+ });
223
+ });
224
+ NavigationMenuList$1.displayName = LIST_NAME;
225
+ var ITEM_NAME = "NavigationMenuItem";
226
+ var [NavigationMenuItemContextProvider, useNavigationMenuItemContext] = createNavigationMenuContext(ITEM_NAME);
227
+ var NavigationMenuItem$1 = React.forwardRef((props, forwardedRef)=>{
228
+ const { __scopeNavigationMenu, value: valueProp, ...itemProps } = props;
229
+ const autoValue = useId();
230
+ const value = valueProp || autoValue || "LEGACY_REACT_AUTO_VALUE";
231
+ const contentRef = React.useRef(null);
232
+ const triggerRef = React.useRef(null);
233
+ const focusProxyRef = React.useRef(null);
234
+ const restoreContentTabOrderRef = React.useRef(()=>{});
235
+ const wasEscapeCloseRef = React.useRef(false);
236
+ const handleContentEntry = React.useCallback((side = "start")=>{
237
+ if (contentRef.current) {
238
+ restoreContentTabOrderRef.current();
239
+ const candidates = getTabbableCandidates(contentRef.current);
240
+ if (candidates.length) focusFirst(side === "start" ? candidates : candidates.reverse());
241
+ }
242
+ }, []);
243
+ const handleContentExit = React.useCallback(()=>{
244
+ if (contentRef.current) {
245
+ const candidates = getTabbableCandidates(contentRef.current);
246
+ if (candidates.length) restoreContentTabOrderRef.current = removeFromTabOrder(candidates);
247
+ }
248
+ }, []);
249
+ return /* @__PURE__ */ jsx(NavigationMenuItemContextProvider, {
250
+ scope: __scopeNavigationMenu,
251
+ value,
252
+ triggerRef,
253
+ contentRef,
254
+ focusProxyRef,
255
+ wasEscapeCloseRef,
256
+ onEntryKeyDown: handleContentEntry,
257
+ onFocusProxyEnter: handleContentEntry,
258
+ onRootContentClose: handleContentExit,
259
+ onContentFocusOutside: handleContentExit,
260
+ children: /* @__PURE__ */ jsx(Primitive.li, {
261
+ ...itemProps,
262
+ ref: forwardedRef
263
+ })
264
+ });
265
+ });
266
+ NavigationMenuItem$1.displayName = ITEM_NAME;
267
+ var TRIGGER_NAME = "NavigationMenuTrigger";
268
+ var NavigationMenuTrigger$1 = React.forwardRef((props, forwardedRef)=>{
269
+ const { __scopeNavigationMenu, disabled, ...triggerProps } = props;
270
+ const context = useNavigationMenuContext(TRIGGER_NAME, props.__scopeNavigationMenu);
271
+ const itemContext = useNavigationMenuItemContext(TRIGGER_NAME, props.__scopeNavigationMenu);
272
+ const ref = React.useRef(null);
273
+ const composedRefs = useComposedRefs(ref, itemContext.triggerRef, forwardedRef);
274
+ const triggerId = makeTriggerId(context.baseId, itemContext.value);
275
+ const contentId = makeContentId(context.baseId, itemContext.value);
276
+ const hasPointerMoveOpenedRef = React.useRef(false);
277
+ const wasClickCloseRef = React.useRef(false);
278
+ const open = itemContext.value === context.value;
279
+ return /* @__PURE__ */ jsxs(Fragment, {
280
+ children: [
281
+ /* @__PURE__ */ jsx(Collection.ItemSlot, {
282
+ scope: __scopeNavigationMenu,
283
+ value: itemContext.value,
284
+ children: /* @__PURE__ */ jsx(FocusGroupItem, {
285
+ asChild: true,
286
+ children: /* @__PURE__ */ jsx(Primitive.button, {
287
+ id: triggerId,
288
+ disabled,
289
+ "data-disabled": disabled ? "" : void 0,
290
+ "data-state": getOpenState(open),
291
+ "aria-expanded": open,
292
+ "aria-controls": contentId,
293
+ ...triggerProps,
294
+ ref: composedRefs,
295
+ onPointerEnter: composeEventHandlers(props.onPointerEnter, ()=>{
296
+ wasClickCloseRef.current = false;
297
+ itemContext.wasEscapeCloseRef.current = false;
298
+ }),
299
+ onPointerMove: composeEventHandlers(props.onPointerMove, whenMouse(()=>{
300
+ if (disabled || wasClickCloseRef.current || itemContext.wasEscapeCloseRef.current || hasPointerMoveOpenedRef.current) return;
301
+ context.onTriggerEnter(itemContext.value);
302
+ hasPointerMoveOpenedRef.current = true;
303
+ })),
304
+ onPointerLeave: composeEventHandlers(props.onPointerLeave, whenMouse(()=>{
305
+ if (disabled) return;
306
+ context.onTriggerLeave();
307
+ hasPointerMoveOpenedRef.current = false;
308
+ })),
309
+ onClick: composeEventHandlers(props.onClick, ()=>{
310
+ context.onItemSelect(itemContext.value);
311
+ wasClickCloseRef.current = open;
312
+ }),
313
+ onKeyDown: composeEventHandlers(props.onKeyDown, (event)=>{
314
+ const verticalEntryKey = context.dir === "rtl" ? "ArrowLeft" : "ArrowRight";
315
+ const entryKey = {
316
+ horizontal: "ArrowDown",
317
+ vertical: verticalEntryKey
318
+ }[context.orientation];
319
+ if (open && event.key === entryKey) {
320
+ itemContext.onEntryKeyDown();
321
+ event.preventDefault();
322
+ }
323
+ })
324
+ })
325
+ })
326
+ }),
327
+ open && /* @__PURE__ */ jsxs(Fragment, {
328
+ children: [
329
+ /* @__PURE__ */ jsx(Root, {
330
+ "aria-hidden": true,
331
+ tabIndex: 0,
332
+ ref: itemContext.focusProxyRef,
333
+ onFocus: (event)=>{
334
+ const content = itemContext.contentRef.current;
335
+ const prevFocusedElement = event.relatedTarget;
336
+ const wasTriggerFocused = prevFocusedElement === ref.current;
337
+ const wasFocusFromContent = content?.contains(prevFocusedElement);
338
+ if (wasTriggerFocused || !wasFocusFromContent) {
339
+ itemContext.onFocusProxyEnter(wasTriggerFocused ? "start" : "end");
340
+ }
341
+ }
342
+ }),
343
+ context.viewport && /* @__PURE__ */ jsx("span", {
344
+ "aria-owns": contentId
345
+ })
346
+ ]
347
+ })
348
+ ]
349
+ });
350
+ });
351
+ NavigationMenuTrigger$1.displayName = TRIGGER_NAME;
352
+ var LINK_NAME = "NavigationMenuLink";
353
+ var LINK_SELECT = "navigationMenu.linkSelect";
354
+ var NavigationMenuLink$1 = React.forwardRef((props, forwardedRef)=>{
355
+ const { __scopeNavigationMenu, active, onSelect, ...linkProps } = props;
356
+ return /* @__PURE__ */ jsx(FocusGroupItem, {
357
+ asChild: true,
358
+ children: /* @__PURE__ */ jsx(Primitive.a, {
359
+ "data-active": active ? "" : void 0,
360
+ "aria-current": active ? "page" : void 0,
361
+ ...linkProps,
362
+ ref: forwardedRef,
363
+ onClick: composeEventHandlers(props.onClick, (event)=>{
364
+ const target = event.target;
365
+ const linkSelectEvent = new CustomEvent(LINK_SELECT, {
366
+ bubbles: true,
367
+ cancelable: true
368
+ });
369
+ target.addEventListener(LINK_SELECT, (event2)=>onSelect?.(event2), {
370
+ once: true
371
+ });
372
+ dispatchDiscreteCustomEvent(target, linkSelectEvent);
373
+ if (!linkSelectEvent.defaultPrevented && !event.metaKey) {
374
+ const rootContentDismissEvent = new CustomEvent(ROOT_CONTENT_DISMISS, {
375
+ bubbles: true,
376
+ cancelable: true
377
+ });
378
+ dispatchDiscreteCustomEvent(target, rootContentDismissEvent);
379
+ }
380
+ }, {
381
+ checkForDefaultPrevented: false
382
+ })
383
+ })
384
+ });
385
+ });
386
+ NavigationMenuLink$1.displayName = LINK_NAME;
387
+ var INDICATOR_NAME = "NavigationMenuIndicator";
388
+ var NavigationMenuIndicator$1 = React.forwardRef((props, forwardedRef)=>{
389
+ const { forceMount, ...indicatorProps } = props;
390
+ const context = useNavigationMenuContext(INDICATOR_NAME, props.__scopeNavigationMenu);
391
+ const isVisible = Boolean(context.value);
392
+ return context.indicatorTrack ? ReactDOM__default.createPortal(/* @__PURE__ */ jsx(Presence, {
393
+ present: forceMount || isVisible,
394
+ children: /* @__PURE__ */ jsx(NavigationMenuIndicatorImpl, {
395
+ ...indicatorProps,
396
+ ref: forwardedRef
397
+ })
398
+ }), context.indicatorTrack) : null;
399
+ });
400
+ NavigationMenuIndicator$1.displayName = INDICATOR_NAME;
401
+ var NavigationMenuIndicatorImpl = React.forwardRef((props, forwardedRef)=>{
402
+ const { __scopeNavigationMenu, ...indicatorProps } = props;
403
+ const context = useNavigationMenuContext(INDICATOR_NAME, __scopeNavigationMenu);
404
+ const getItems = useCollection(__scopeNavigationMenu);
405
+ const [activeTrigger, setActiveTrigger] = React.useState(null);
406
+ const [position, setPosition] = React.useState(null);
407
+ const isHorizontal = context.orientation === "horizontal";
408
+ const isVisible = Boolean(context.value);
409
+ React.useEffect(()=>{
410
+ const items = getItems();
411
+ const triggerNode = items.find((item)=>item.value === context.value)?.ref.current;
412
+ if (triggerNode) setActiveTrigger(triggerNode);
413
+ }, [
414
+ getItems,
415
+ context.value
416
+ ]);
417
+ const handlePositionChange = ()=>{
418
+ if (activeTrigger) {
419
+ setPosition({
420
+ size: isHorizontal ? activeTrigger.offsetWidth : activeTrigger.offsetHeight,
421
+ offset: isHorizontal ? activeTrigger.offsetLeft : activeTrigger.offsetTop
422
+ });
423
+ }
424
+ };
425
+ useResizeObserver(activeTrigger, handlePositionChange);
426
+ useResizeObserver(context.indicatorTrack, handlePositionChange);
427
+ return position ? /* @__PURE__ */ jsx(Primitive.div, {
428
+ "aria-hidden": true,
429
+ "data-state": isVisible ? "visible" : "hidden",
430
+ "data-orientation": context.orientation,
431
+ ...indicatorProps,
432
+ ref: forwardedRef,
433
+ style: {
434
+ position: "absolute",
435
+ ...isHorizontal ? {
436
+ left: 0,
437
+ width: position.size + "px",
438
+ transform: `translateX(${position.offset}px)`
439
+ } : {
440
+ top: 0,
441
+ height: position.size + "px",
442
+ transform: `translateY(${position.offset}px)`
443
+ },
444
+ ...indicatorProps.style
445
+ }
446
+ }) : null;
447
+ });
448
+ var CONTENT_NAME = "NavigationMenuContent";
449
+ var NavigationMenuContent$1 = React.forwardRef((props, forwardedRef)=>{
450
+ const { forceMount, ...contentProps } = props;
451
+ const context = useNavigationMenuContext(CONTENT_NAME, props.__scopeNavigationMenu);
452
+ const itemContext = useNavigationMenuItemContext(CONTENT_NAME, props.__scopeNavigationMenu);
453
+ const composedRefs = useComposedRefs(itemContext.contentRef, forwardedRef);
454
+ const open = itemContext.value === context.value;
455
+ const commonProps = {
456
+ value: itemContext.value,
457
+ triggerRef: itemContext.triggerRef,
458
+ focusProxyRef: itemContext.focusProxyRef,
459
+ wasEscapeCloseRef: itemContext.wasEscapeCloseRef,
460
+ onContentFocusOutside: itemContext.onContentFocusOutside,
461
+ onRootContentClose: itemContext.onRootContentClose,
462
+ ...contentProps
463
+ };
464
+ return !context.viewport ? /* @__PURE__ */ jsx(Presence, {
465
+ present: forceMount || open,
466
+ children: /* @__PURE__ */ jsx(NavigationMenuContentImpl, {
467
+ "data-state": getOpenState(open),
468
+ ...commonProps,
469
+ ref: composedRefs,
470
+ onPointerEnter: composeEventHandlers(props.onPointerEnter, context.onContentEnter),
471
+ onPointerLeave: composeEventHandlers(props.onPointerLeave, whenMouse(context.onContentLeave)),
472
+ style: {
473
+ // Prevent interaction when animating out
474
+ pointerEvents: !open && context.isRootMenu ? "none" : void 0,
475
+ ...commonProps.style
476
+ }
477
+ })
478
+ }) : /* @__PURE__ */ jsx(ViewportContentMounter, {
479
+ forceMount,
480
+ ...commonProps,
481
+ ref: composedRefs
482
+ });
483
+ });
484
+ NavigationMenuContent$1.displayName = CONTENT_NAME;
485
+ var ViewportContentMounter = React.forwardRef((props, forwardedRef)=>{
486
+ const context = useNavigationMenuContext(CONTENT_NAME, props.__scopeNavigationMenu);
487
+ const { onViewportContentChange, onViewportContentRemove } = context;
488
+ useLayoutEffect2(()=>{
489
+ onViewportContentChange(props.value, {
490
+ ref: forwardedRef,
491
+ ...props
492
+ });
493
+ }, [
494
+ props,
495
+ forwardedRef,
496
+ onViewportContentChange
497
+ ]);
498
+ useLayoutEffect2(()=>{
499
+ return ()=>onViewportContentRemove(props.value);
500
+ }, [
501
+ props.value,
502
+ onViewportContentRemove
503
+ ]);
504
+ return null;
505
+ });
506
+ var ROOT_CONTENT_DISMISS = "navigationMenu.rootContentDismiss";
507
+ var NavigationMenuContentImpl = React.forwardRef((props, forwardedRef)=>{
508
+ const { __scopeNavigationMenu, value, triggerRef, focusProxyRef, wasEscapeCloseRef, onRootContentClose, onContentFocusOutside, ...contentProps } = props;
509
+ const context = useNavigationMenuContext(CONTENT_NAME, __scopeNavigationMenu);
510
+ const ref = React.useRef(null);
511
+ const composedRefs = useComposedRefs(ref, forwardedRef);
512
+ const triggerId = makeTriggerId(context.baseId, value);
513
+ const contentId = makeContentId(context.baseId, value);
514
+ const getItems = useCollection(__scopeNavigationMenu);
515
+ const prevMotionAttributeRef = React.useRef(null);
516
+ const { onItemDismiss } = context;
517
+ React.useEffect(()=>{
518
+ const content = ref.current;
519
+ if (context.isRootMenu && content) {
520
+ const handleClose = ()=>{
521
+ onItemDismiss();
522
+ onRootContentClose();
523
+ if (content.contains(document.activeElement)) triggerRef.current?.focus();
524
+ };
525
+ content.addEventListener(ROOT_CONTENT_DISMISS, handleClose);
526
+ return ()=>content.removeEventListener(ROOT_CONTENT_DISMISS, handleClose);
527
+ }
528
+ }, [
529
+ context.isRootMenu,
530
+ props.value,
531
+ triggerRef,
532
+ onItemDismiss,
533
+ onRootContentClose
534
+ ]);
535
+ const motionAttribute = React.useMemo(()=>{
536
+ const items = getItems();
537
+ const values = items.map((item)=>item.value);
538
+ if (context.dir === "rtl") values.reverse();
539
+ const index = values.indexOf(context.value);
540
+ const prevIndex = values.indexOf(context.previousValue);
541
+ const isSelected = value === context.value;
542
+ const wasSelected = prevIndex === values.indexOf(value);
543
+ if (!isSelected && !wasSelected) return prevMotionAttributeRef.current;
544
+ const attribute = (()=>{
545
+ if (index !== prevIndex) {
546
+ if (isSelected && prevIndex !== -1) return index > prevIndex ? "from-end" : "from-start";
547
+ if (wasSelected && index !== -1) return index > prevIndex ? "to-start" : "to-end";
548
+ }
549
+ return null;
550
+ })();
551
+ prevMotionAttributeRef.current = attribute;
552
+ return attribute;
553
+ }, [
554
+ context.previousValue,
555
+ context.value,
556
+ context.dir,
557
+ getItems,
558
+ value
559
+ ]);
560
+ return /* @__PURE__ */ jsx(FocusGroup, {
561
+ asChild: true,
562
+ children: /* @__PURE__ */ jsx(DismissableLayer, {
563
+ id: contentId,
564
+ "aria-labelledby": triggerId,
565
+ "data-motion": motionAttribute,
566
+ "data-orientation": context.orientation,
567
+ ...contentProps,
568
+ ref: composedRefs,
569
+ disableOutsidePointerEvents: false,
570
+ onDismiss: ()=>{
571
+ const rootContentDismissEvent = new Event(ROOT_CONTENT_DISMISS, {
572
+ bubbles: true,
573
+ cancelable: true
574
+ });
575
+ ref.current?.dispatchEvent(rootContentDismissEvent);
576
+ },
577
+ onFocusOutside: composeEventHandlers(props.onFocusOutside, (event)=>{
578
+ onContentFocusOutside();
579
+ const target = event.target;
580
+ if (context.rootNavigationMenu?.contains(target)) event.preventDefault();
581
+ }),
582
+ onPointerDownOutside: composeEventHandlers(props.onPointerDownOutside, (event)=>{
583
+ const target = event.target;
584
+ const isTrigger = getItems().some((item)=>item.ref.current?.contains(target));
585
+ const isRootViewport = context.isRootMenu && context.viewport?.contains(target);
586
+ if (isTrigger || isRootViewport || !context.isRootMenu) event.preventDefault();
587
+ }),
588
+ onKeyDown: composeEventHandlers(props.onKeyDown, (event)=>{
589
+ const isMetaKey = event.altKey || event.ctrlKey || event.metaKey;
590
+ const isTabKey = event.key === "Tab" && !isMetaKey;
591
+ if (isTabKey) {
592
+ const candidates = getTabbableCandidates(event.currentTarget);
593
+ const focusedElement = document.activeElement;
594
+ const index = candidates.findIndex((candidate)=>candidate === focusedElement);
595
+ const isMovingBackwards = event.shiftKey;
596
+ const nextCandidates = isMovingBackwards ? candidates.slice(0, index).reverse() : candidates.slice(index + 1, candidates.length);
597
+ if (focusFirst(nextCandidates)) {
598
+ event.preventDefault();
599
+ } else {
600
+ focusProxyRef.current?.focus();
601
+ }
602
+ }
603
+ }),
604
+ onEscapeKeyDown: composeEventHandlers(props.onEscapeKeyDown, (_event)=>{
605
+ wasEscapeCloseRef.current = true;
606
+ })
607
+ })
608
+ });
609
+ });
610
+ var VIEWPORT_NAME = "NavigationMenuViewport";
611
+ var NavigationMenuViewport$1 = React.forwardRef((props, forwardedRef)=>{
612
+ const { forceMount, ...viewportProps } = props;
613
+ const context = useNavigationMenuContext(VIEWPORT_NAME, props.__scopeNavigationMenu);
614
+ const open = Boolean(context.value);
615
+ return /* @__PURE__ */ jsx(Presence, {
616
+ present: forceMount || open,
617
+ children: /* @__PURE__ */ jsx(NavigationMenuViewportImpl, {
618
+ ...viewportProps,
619
+ ref: forwardedRef
620
+ })
621
+ });
622
+ });
623
+ NavigationMenuViewport$1.displayName = VIEWPORT_NAME;
624
+ var NavigationMenuViewportImpl = React.forwardRef((props, forwardedRef)=>{
625
+ const { __scopeNavigationMenu, children, ...viewportImplProps } = props;
626
+ const context = useNavigationMenuContext(VIEWPORT_NAME, __scopeNavigationMenu);
627
+ const composedRefs = useComposedRefs(forwardedRef, context.onViewportChange);
628
+ const viewportContentContext = useViewportContentContext(CONTENT_NAME, props.__scopeNavigationMenu);
629
+ const [size, setSize] = React.useState(null);
630
+ const [content, setContent] = React.useState(null);
631
+ const viewportWidth = size ? size?.width + "px" : void 0;
632
+ const viewportHeight = size ? size?.height + "px" : void 0;
633
+ const open = Boolean(context.value);
634
+ const activeContentValue = open ? context.value : context.previousValue;
635
+ const handleSizeChange = ()=>{
636
+ if (content) setSize({
637
+ width: content.offsetWidth,
638
+ height: content.offsetHeight
639
+ });
640
+ };
641
+ useResizeObserver(content, handleSizeChange);
642
+ return /* @__PURE__ */ jsx(Primitive.div, {
643
+ "data-state": getOpenState(open),
644
+ "data-orientation": context.orientation,
645
+ ...viewportImplProps,
646
+ ref: composedRefs,
647
+ style: {
648
+ // Prevent interaction when animating out
649
+ pointerEvents: !open && context.isRootMenu ? "none" : void 0,
650
+ ["--radix-navigation-menu-viewport-width"]: viewportWidth,
651
+ ["--radix-navigation-menu-viewport-height"]: viewportHeight,
652
+ ...viewportImplProps.style
653
+ },
654
+ onPointerEnter: composeEventHandlers(props.onPointerEnter, context.onContentEnter),
655
+ onPointerLeave: composeEventHandlers(props.onPointerLeave, whenMouse(context.onContentLeave)),
656
+ children: Array.from(viewportContentContext.items).map(([value, { ref, forceMount, ...props2 }])=>{
657
+ const isActive = activeContentValue === value;
658
+ return /* @__PURE__ */ jsx(Presence, {
659
+ present: forceMount || isActive,
660
+ children: /* @__PURE__ */ jsx(NavigationMenuContentImpl, {
661
+ ...props2,
662
+ ref: composeRefs(ref, (node)=>{
663
+ if (isActive && node) setContent(node);
664
+ })
665
+ })
666
+ }, value);
667
+ })
668
+ });
669
+ });
670
+ var FOCUS_GROUP_NAME = "FocusGroup";
671
+ var FocusGroup = React.forwardRef((props, forwardedRef)=>{
672
+ const { __scopeNavigationMenu, ...groupProps } = props;
673
+ const context = useNavigationMenuContext(FOCUS_GROUP_NAME, __scopeNavigationMenu);
674
+ return /* @__PURE__ */ jsx(FocusGroupCollection.Provider, {
675
+ scope: __scopeNavigationMenu,
676
+ children: /* @__PURE__ */ jsx(FocusGroupCollection.Slot, {
677
+ scope: __scopeNavigationMenu,
678
+ children: /* @__PURE__ */ jsx(Primitive.div, {
679
+ dir: context.dir,
680
+ ...groupProps,
681
+ ref: forwardedRef
682
+ })
683
+ })
684
+ });
685
+ });
686
+ var ARROW_KEYS = [
687
+ "ArrowRight",
688
+ "ArrowLeft",
689
+ "ArrowUp",
690
+ "ArrowDown"
691
+ ];
692
+ var FOCUS_GROUP_ITEM_NAME = "FocusGroupItem";
693
+ var FocusGroupItem = React.forwardRef((props, forwardedRef)=>{
694
+ const { __scopeNavigationMenu, ...groupProps } = props;
695
+ const getItems = useFocusGroupCollection(__scopeNavigationMenu);
696
+ const context = useNavigationMenuContext(FOCUS_GROUP_ITEM_NAME, __scopeNavigationMenu);
697
+ return /* @__PURE__ */ jsx(FocusGroupCollection.ItemSlot, {
698
+ scope: __scopeNavigationMenu,
699
+ children: /* @__PURE__ */ jsx(Primitive.button, {
700
+ ...groupProps,
701
+ ref: forwardedRef,
702
+ onKeyDown: composeEventHandlers(props.onKeyDown, (event)=>{
703
+ const isFocusNavigationKey = [
704
+ "Home",
705
+ "End",
706
+ ...ARROW_KEYS
707
+ ].includes(event.key);
708
+ if (isFocusNavigationKey) {
709
+ let candidateNodes = getItems().map((item)=>item.ref.current);
710
+ const prevItemKey = context.dir === "rtl" ? "ArrowRight" : "ArrowLeft";
711
+ const prevKeys = [
712
+ prevItemKey,
713
+ "ArrowUp",
714
+ "End"
715
+ ];
716
+ if (prevKeys.includes(event.key)) candidateNodes.reverse();
717
+ if (ARROW_KEYS.includes(event.key)) {
718
+ const currentIndex = candidateNodes.indexOf(event.currentTarget);
719
+ candidateNodes = candidateNodes.slice(currentIndex + 1);
720
+ }
721
+ setTimeout(()=>focusFirst(candidateNodes));
722
+ event.preventDefault();
723
+ }
724
+ })
725
+ })
726
+ });
727
+ });
728
+ function getTabbableCandidates(container) {
729
+ const nodes = [];
730
+ const walker = document.createTreeWalker(container, NodeFilter.SHOW_ELEMENT, {
731
+ acceptNode: (node)=>{
732
+ const isHiddenInput = node.tagName === "INPUT" && node.type === "hidden";
733
+ if (node.disabled || node.hidden || isHiddenInput) return NodeFilter.FILTER_SKIP;
734
+ return node.tabIndex >= 0 ? NodeFilter.FILTER_ACCEPT : NodeFilter.FILTER_SKIP;
735
+ }
736
+ });
737
+ while(walker.nextNode())nodes.push(walker.currentNode);
738
+ return nodes;
739
+ }
740
+ function focusFirst(candidates) {
741
+ const previouslyFocusedElement = document.activeElement;
742
+ return candidates.some((candidate)=>{
743
+ if (candidate === previouslyFocusedElement) return true;
744
+ candidate.focus();
745
+ return document.activeElement !== previouslyFocusedElement;
746
+ });
747
+ }
748
+ function removeFromTabOrder(candidates) {
749
+ candidates.forEach((candidate)=>{
750
+ candidate.dataset.tabindex = candidate.getAttribute("tabindex") || "";
751
+ candidate.setAttribute("tabindex", "-1");
752
+ });
753
+ return ()=>{
754
+ candidates.forEach((candidate)=>{
755
+ const prevTabIndex = candidate.dataset.tabindex;
756
+ candidate.setAttribute("tabindex", prevTabIndex);
757
+ });
758
+ };
759
+ }
760
+ function useResizeObserver(element, onResize) {
761
+ const handleResize = useCallbackRef(onResize);
762
+ useLayoutEffect2(()=>{
763
+ let rAF = 0;
764
+ if (element) {
765
+ const resizeObserver = new ResizeObserver(()=>{
766
+ cancelAnimationFrame(rAF);
767
+ rAF = window.requestAnimationFrame(handleResize);
768
+ });
769
+ resizeObserver.observe(element);
770
+ return ()=>{
771
+ window.cancelAnimationFrame(rAF);
772
+ resizeObserver.unobserve(element);
773
+ };
774
+ }
775
+ }, [
776
+ element,
777
+ handleResize
778
+ ]);
779
+ }
780
+ function getOpenState(open) {
781
+ return open ? "open" : "closed";
782
+ }
783
+ function makeTriggerId(baseId, value) {
784
+ return `${baseId}-trigger-${value}`;
785
+ }
786
+ function makeContentId(baseId, value) {
787
+ return `${baseId}-content-${value}`;
788
+ }
789
+ function whenMouse(handler) {
790
+ return (event)=>event.pointerType === "mouse" ? handler(event) : void 0;
791
+ }
792
+ var Root2 = NavigationMenu$1;
793
+ var List = NavigationMenuList$1;
794
+ var Item = NavigationMenuItem$1;
795
+ var Trigger = NavigationMenuTrigger$1;
796
+ var Link = NavigationMenuLink$1;
797
+ var Indicator = NavigationMenuIndicator$1;
798
+ var Content = NavigationMenuContent$1;
799
+ var Viewport = NavigationMenuViewport$1;
800
+
801
+ function NavigationMenu({ className, children, viewport = true, ...props }) {
802
+ return /*#__PURE__*/ React.createElement(Root2, {
803
+ "data-slot": "navigation-menu",
804
+ "data-viewport": viewport,
805
+ className: cn("group/navigation-menu relative flex max-w-max flex-1 items-center justify-center", className),
806
+ ...props
807
+ }, children, viewport && /*#__PURE__*/ React.createElement(NavigationMenuViewport, null));
808
+ }
809
+ function NavigationMenuList({ className, ...props }) {
810
+ return /*#__PURE__*/ React.createElement(List, {
811
+ "data-slot": "navigation-menu-list",
812
+ className: cn("group flex flex-1 list-none items-center justify-center gap-1", className),
813
+ ...props
814
+ });
815
+ }
816
+ function NavigationMenuItem({ className, ...props }) {
817
+ return /*#__PURE__*/ React.createElement(Item, {
818
+ "data-slot": "navigation-menu-item",
819
+ className: cn("relative", className),
820
+ ...props
821
+ });
822
+ }
823
+ const navigationMenuTriggerStyle = cva("group inline-flex h-9 w-max items-center justify-center rounded-md bg-background px-4 py-2 text-sm font-medium hover:bg-accent hover:text-accent-foreground focus:bg-accent focus:text-accent-foreground disabled:pointer-events-none disabled:opacity-50 data-[state=open]:hover:bg-accent data-[state=open]:text-accent-foreground data-[state=open]:focus:bg-accent data-[state=open]:bg-accent/50 focus-visible:ring-ring/50 outline-none transition-[color,box-shadow] focus-visible:ring-[3px] focus-visible:outline-1");
824
+ function NavigationMenuTrigger({ className, children, ...props }) {
825
+ return /*#__PURE__*/ React.createElement(Trigger, {
826
+ "data-slot": "navigation-menu-trigger",
827
+ className: cn(navigationMenuTriggerStyle(), "group", className),
828
+ ...props
829
+ }, children, " ", /*#__PURE__*/ React.createElement(ChevronDown, {
830
+ className: "relative top-[1px] ml-1 size-3 transition duration-300 group-data-[state=open]:rotate-180",
831
+ "aria-hidden": "true"
832
+ }));
833
+ }
834
+ function NavigationMenuContent({ className, ...props }) {
835
+ return /*#__PURE__*/ React.createElement(Content, {
836
+ "data-slot": "navigation-menu-content",
837
+ className: cn("data-[motion^=from-]:animate-in data-[motion^=to-]:animate-out data-[motion^=from-]:fade-in data-[motion^=to-]:fade-out data-[motion=from-end]:slide-in-from-right-52 data-[motion=from-start]:slide-in-from-left-52 data-[motion=to-end]:slide-out-to-right-52 data-[motion=to-start]:slide-out-to-left-52 top-0 left-0 w-full p-2 pr-2.5 md:absolute md:w-auto", "group-data-[viewport=false]/navigation-menu:bg-popover group-data-[viewport=false]/navigation-menu:text-popover-foreground group-data-[viewport=false]/navigation-menu:data-[state=open]:animate-in group-data-[viewport=false]/navigation-menu:data-[state=closed]:animate-out group-data-[viewport=false]/navigation-menu:data-[state=closed]:zoom-out-95 group-data-[viewport=false]/navigation-menu:data-[state=open]:zoom-in-95 group-data-[viewport=false]/navigation-menu:data-[state=open]:fade-in-0 group-data-[viewport=false]/navigation-menu:data-[state=closed]:fade-out-0 group-data-[viewport=false]/navigation-menu:top-full group-data-[viewport=false]/navigation-menu:mt-1.5 group-data-[viewport=false]/navigation-menu:overflow-hidden group-data-[viewport=false]/navigation-menu:rounded-md group-data-[viewport=false]/navigation-menu:border group-data-[viewport=false]/navigation-menu:shadow group-data-[viewport=false]/navigation-menu:duration-200 **:data-[slot=navigation-menu-link]:focus:ring-0 **:data-[slot=navigation-menu-link]:focus:outline-none", className),
838
+ ...props
839
+ });
840
+ }
841
+ function NavigationMenuViewport({ className, ...props }) {
842
+ return /*#__PURE__*/ React.createElement("div", {
843
+ className: cn("absolute top-full left-0 isolate z-50 flex justify-center")
844
+ }, /*#__PURE__*/ React.createElement(Viewport, {
845
+ "data-slot": "navigation-menu-viewport",
846
+ className: cn("origin-top-center bg-popover text-popover-foreground data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-90 relative mt-1.5 h-[var(--radix-navigation-menu-viewport-height)] w-full overflow-hidden rounded-md border shadow md:w-[var(--radix-navigation-menu-viewport-width)]", className),
847
+ ...props
848
+ }));
849
+ }
850
+ function NavigationMenuLink({ className, ...props }) {
851
+ return /*#__PURE__*/ React.createElement(Link, {
852
+ "data-slot": "navigation-menu-link",
853
+ className: cn("data-[active=true]:focus:bg-accent data-[active=true]:hover:bg-accent data-[active=true]:bg-accent/50 data-[active=true]:text-accent-foreground hover:bg-accent hover:text-accent-foreground focus:bg-accent focus:text-accent-foreground focus-visible:ring-ring/50 [&_svg:not([class*='text-'])]:text-muted-foreground flex flex-col gap-1 rounded-sm p-2 text-sm transition-all outline-none focus-visible:ring-[3px] focus-visible:outline-1 [&_svg:not([class*='size-'])]:size-4", className),
854
+ ...props
855
+ });
856
+ }
857
+ function NavigationMenuIndicator({ className, ...props }) {
858
+ return /*#__PURE__*/ React.createElement(Indicator, {
859
+ "data-slot": "navigation-menu-indicator",
860
+ className: cn("data-[state=visible]:animate-in data-[state=hidden]:animate-out data-[state=hidden]:fade-out data-[state=visible]:fade-in top-full z-[1] flex h-1.5 items-end justify-center overflow-hidden", className),
861
+ ...props
862
+ }, /*#__PURE__*/ React.createElement("div", {
863
+ className: "bg-border relative top-[60%] h-2 w-2 rotate-45 rounded-tl-sm shadow-md"
864
+ }));
865
+ }
866
+
867
+ export { NavigationMenu, NavigationMenuContent, NavigationMenuIndicator, NavigationMenuItem, NavigationMenuLink, NavigationMenuList, NavigationMenuTrigger, NavigationMenuViewport, navigationMenuTriggerStyle };
868
+ //# sourceMappingURL=index.mjs.map