@ark-ui/react 5.29.0 → 5.30.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 (123) hide show
  1. package/dist/components/anatomy.cjs +5 -0
  2. package/dist/components/anatomy.d.cts +1 -0
  3. package/dist/components/anatomy.d.ts +1 -0
  4. package/dist/components/anatomy.js +1 -0
  5. package/dist/components/checkbox/use-checkbox-group.cjs +11 -1
  6. package/dist/components/checkbox/use-checkbox-group.d.cts +2 -2
  7. package/dist/components/checkbox/use-checkbox-group.d.ts +2 -2
  8. package/dist/components/checkbox/use-checkbox-group.js +11 -1
  9. package/dist/components/date-picker/date-picker-root.cjs +4 -2
  10. package/dist/components/date-picker/date-picker-root.js +4 -2
  11. package/dist/components/fieldset/use-fieldset.cjs +37 -46
  12. package/dist/components/fieldset/use-fieldset.d.cts +5 -0
  13. package/dist/components/fieldset/use-fieldset.d.ts +5 -0
  14. package/dist/components/fieldset/use-fieldset.js +38 -47
  15. package/dist/components/index.cjs +41 -0
  16. package/dist/components/index.d.cts +1 -0
  17. package/dist/components/index.d.ts +1 -0
  18. package/dist/components/index.js +20 -0
  19. package/dist/components/navigation-menu/index.cjs +44 -0
  20. package/dist/components/navigation-menu/index.d.cts +18 -0
  21. package/dist/components/navigation-menu/index.d.ts +18 -0
  22. package/dist/components/navigation-menu/index.js +18 -0
  23. package/dist/components/navigation-menu/navigation-menu-arrow.cjs +19 -0
  24. package/dist/components/navigation-menu/navigation-menu-arrow.d.cts +7 -0
  25. package/dist/components/navigation-menu/navigation-menu-arrow.d.ts +7 -0
  26. package/dist/components/navigation-menu/navigation-menu-arrow.js +15 -0
  27. package/dist/components/navigation-menu/navigation-menu-content.cjs +41 -0
  28. package/dist/components/navigation-menu/navigation-menu-content.d.cts +9 -0
  29. package/dist/components/navigation-menu/navigation-menu-content.d.ts +9 -0
  30. package/dist/components/navigation-menu/navigation-menu-content.js +37 -0
  31. package/dist/components/navigation-menu/navigation-menu-context.cjs +10 -0
  32. package/dist/components/navigation-menu/navigation-menu-context.d.cts +6 -0
  33. package/dist/components/navigation-menu/navigation-menu-context.d.ts +6 -0
  34. package/dist/components/navigation-menu/navigation-menu-context.js +6 -0
  35. package/dist/components/navigation-menu/navigation-menu-indicator.cjs +25 -0
  36. package/dist/components/navigation-menu/navigation-menu-indicator.d.cts +7 -0
  37. package/dist/components/navigation-menu/navigation-menu-indicator.d.ts +7 -0
  38. package/dist/components/navigation-menu/navigation-menu-indicator.js +21 -0
  39. package/dist/components/navigation-menu/navigation-menu-item-indicator.cjs +23 -0
  40. package/dist/components/navigation-menu/navigation-menu-item-indicator.d.cts +7 -0
  41. package/dist/components/navigation-menu/navigation-menu-item-indicator.d.ts +7 -0
  42. package/dist/components/navigation-menu/navigation-menu-item-indicator.js +19 -0
  43. package/dist/components/navigation-menu/navigation-menu-item.cjs +23 -0
  44. package/dist/components/navigation-menu/navigation-menu-item.d.cts +8 -0
  45. package/dist/components/navigation-menu/navigation-menu-item.d.ts +8 -0
  46. package/dist/components/navigation-menu/navigation-menu-item.js +19 -0
  47. package/dist/components/navigation-menu/navigation-menu-link.cjs +25 -0
  48. package/dist/components/navigation-menu/navigation-menu-link.d.cts +9 -0
  49. package/dist/components/navigation-menu/navigation-menu-link.d.ts +9 -0
  50. package/dist/components/navigation-menu/navigation-menu-link.js +21 -0
  51. package/dist/components/navigation-menu/navigation-menu-list.cjs +19 -0
  52. package/dist/components/navigation-menu/navigation-menu-list.d.cts +7 -0
  53. package/dist/components/navigation-menu/navigation-menu-list.d.ts +7 -0
  54. package/dist/components/navigation-menu/navigation-menu-list.js +15 -0
  55. package/dist/components/navigation-menu/navigation-menu-root-provider.cjs +23 -0
  56. package/dist/components/navigation-menu/navigation-menu-root-provider.d.cts +13 -0
  57. package/dist/components/navigation-menu/navigation-menu-root-provider.d.ts +13 -0
  58. package/dist/components/navigation-menu/navigation-menu-root-provider.js +19 -0
  59. package/dist/components/navigation-menu/navigation-menu-root.cjs +37 -0
  60. package/dist/components/navigation-menu/navigation-menu-root.d.cts +10 -0
  61. package/dist/components/navigation-menu/navigation-menu-root.d.ts +10 -0
  62. package/dist/components/navigation-menu/navigation-menu-root.js +33 -0
  63. package/dist/components/navigation-menu/navigation-menu-trigger.cjs +28 -0
  64. package/dist/components/navigation-menu/navigation-menu-trigger.d.cts +9 -0
  65. package/dist/components/navigation-menu/navigation-menu-trigger.d.ts +9 -0
  66. package/dist/components/navigation-menu/navigation-menu-trigger.js +24 -0
  67. package/dist/components/navigation-menu/navigation-menu-viewport-positioner.cjs +24 -0
  68. package/dist/components/navigation-menu/navigation-menu-viewport-positioner.d.cts +8 -0
  69. package/dist/components/navigation-menu/navigation-menu-viewport-positioner.d.ts +8 -0
  70. package/dist/components/navigation-menu/navigation-menu-viewport-positioner.js +20 -0
  71. package/dist/components/navigation-menu/navigation-menu-viewport.cjs +32 -0
  72. package/dist/components/navigation-menu/navigation-menu-viewport.d.cts +8 -0
  73. package/dist/components/navigation-menu/navigation-menu-viewport.d.ts +8 -0
  74. package/dist/components/navigation-menu/navigation-menu-viewport.js +28 -0
  75. package/dist/components/navigation-menu/navigation-menu.anatomy.d.cts +1 -0
  76. package/dist/components/navigation-menu/navigation-menu.anatomy.d.ts +1 -0
  77. package/dist/components/navigation-menu/navigation-menu.cjs +33 -0
  78. package/dist/components/navigation-menu/navigation-menu.d.cts +14 -0
  79. package/dist/components/navigation-menu/navigation-menu.d.ts +14 -0
  80. package/dist/components/navigation-menu/navigation-menu.js +13 -0
  81. package/dist/components/navigation-menu/use-navigation-menu-context.cjs +15 -0
  82. package/dist/components/navigation-menu/use-navigation-menu-context.d.cts +5 -0
  83. package/dist/components/navigation-menu/use-navigation-menu-context.d.ts +5 -0
  84. package/dist/components/navigation-menu/use-navigation-menu-context.js +10 -0
  85. package/dist/components/navigation-menu/use-navigation-menu-item-props-context.cjs +16 -0
  86. package/dist/components/navigation-menu/use-navigation-menu-item-props-context.d.cts +3 -0
  87. package/dist/components/navigation-menu/use-navigation-menu-item-props-context.d.ts +3 -0
  88. package/dist/components/navigation-menu/use-navigation-menu-item-props-context.js +11 -0
  89. package/dist/components/navigation-menu/use-navigation-menu.cjs +45 -0
  90. package/dist/components/navigation-menu/use-navigation-menu.d.cts +8 -0
  91. package/dist/components/navigation-menu/use-navigation-menu.d.ts +8 -0
  92. package/dist/components/navigation-menu/use-navigation-menu.js +22 -0
  93. package/dist/components/number-input/number-input-root.cjs +1 -0
  94. package/dist/components/number-input/number-input-root.js +1 -0
  95. package/dist/components/pagination/index.cjs +4 -0
  96. package/dist/components/pagination/index.d.cts +2 -0
  97. package/dist/components/pagination/index.d.ts +2 -0
  98. package/dist/components/pagination/index.js +2 -0
  99. package/dist/components/pagination/pagination-first-trigger.cjs +19 -0
  100. package/dist/components/pagination/pagination-first-trigger.d.cts +7 -0
  101. package/dist/components/pagination/pagination-first-trigger.d.ts +7 -0
  102. package/dist/components/pagination/pagination-first-trigger.js +15 -0
  103. package/dist/components/pagination/pagination-last-trigger.cjs +19 -0
  104. package/dist/components/pagination/pagination-last-trigger.d.cts +7 -0
  105. package/dist/components/pagination/pagination-last-trigger.d.ts +7 -0
  106. package/dist/components/pagination/pagination-last-trigger.js +15 -0
  107. package/dist/components/pagination/pagination-root.cjs +1 -0
  108. package/dist/components/pagination/pagination-root.js +1 -0
  109. package/dist/components/pagination/pagination.cjs +4 -0
  110. package/dist/components/pagination/pagination.d.cts +2 -0
  111. package/dist/components/pagination/pagination.d.ts +2 -0
  112. package/dist/components/pagination/pagination.js +2 -0
  113. package/dist/components/radio-group/radio-group-root.cjs +2 -0
  114. package/dist/components/radio-group/radio-group-root.js +2 -0
  115. package/dist/components/radio-group/use-radio-group.cjs +7 -0
  116. package/dist/components/radio-group/use-radio-group.js +7 -0
  117. package/dist/components/segment-group/segment-group-root.cjs +2 -0
  118. package/dist/components/segment-group/segment-group-root.js +2 -0
  119. package/dist/components/tree-view/tree-view-root.cjs +1 -0
  120. package/dist/components/tree-view/tree-view-root.js +1 -0
  121. package/dist/index.cjs +41 -0
  122. package/dist/index.js +20 -0
  123. package/package.json +72 -71
@@ -0,0 +1,18 @@
1
+ export type { ValueChangeDetails as NavigationMenuValueChangeDetails } from '@zag-js/navigation-menu';
2
+ export { NavigationMenuArrow, type NavigationMenuArrowBaseProps, type NavigationMenuArrowProps, } from './navigation-menu-arrow';
3
+ export { NavigationMenuContent, type NavigationMenuContentBaseProps, type NavigationMenuContentProps, } from './navigation-menu-content';
4
+ export { NavigationMenuContext, type NavigationMenuContextProps } from './navigation-menu-context';
5
+ export { NavigationMenuIndicator, type NavigationMenuIndicatorBaseProps, type NavigationMenuIndicatorProps, } from './navigation-menu-indicator';
6
+ export { NavigationMenuItem, type NavigationMenuItemBaseProps, type NavigationMenuItemProps, } from './navigation-menu-item';
7
+ export { NavigationMenuItemIndicator, type NavigationMenuItemIndicatorBaseProps, type NavigationMenuItemIndicatorProps, } from './navigation-menu-item-indicator';
8
+ export { NavigationMenuLink, type NavigationMenuLinkBaseProps, type NavigationMenuLinkProps, } from './navigation-menu-link';
9
+ export { NavigationMenuList, type NavigationMenuListBaseProps, type NavigationMenuListProps, } from './navigation-menu-list';
10
+ export { NavigationMenuRoot, type NavigationMenuRootBaseProps, type NavigationMenuRootProps, } from './navigation-menu-root';
11
+ export { NavigationMenuRootProvider, type NavigationMenuRootProviderBaseProps, type NavigationMenuRootProviderProps, } from './navigation-menu-root-provider';
12
+ export { NavigationMenuTrigger, type NavigationMenuTriggerBaseProps, type NavigationMenuTriggerProps, } from './navigation-menu-trigger';
13
+ export { NavigationMenuViewport, type NavigationMenuViewportBaseProps, type NavigationMenuViewportProps, } from './navigation-menu-viewport';
14
+ export { NavigationMenuViewportPositioner, type NavigationMenuViewportPositionerBaseProps, type NavigationMenuViewportPositionerProps, } from './navigation-menu-viewport-positioner';
15
+ export { navigationMenuAnatomy } from './navigation-menu.anatomy';
16
+ export { useNavigationMenu, type UseNavigationMenuProps, type UseNavigationMenuReturn } from './use-navigation-menu';
17
+ export { useNavigationMenuContext, type UseNavigationMenuContext } from './use-navigation-menu-context';
18
+ export * as NavigationMenu from './navigation-menu';
@@ -0,0 +1,18 @@
1
+ export { NavigationMenuArrow } from './navigation-menu-arrow.js';
2
+ export { NavigationMenuContent } from './navigation-menu-content.js';
3
+ export { NavigationMenuContext } from './navigation-menu-context.js';
4
+ export { NavigationMenuIndicator } from './navigation-menu-indicator.js';
5
+ export { NavigationMenuItem } from './navigation-menu-item.js';
6
+ export { NavigationMenuItemIndicator } from './navigation-menu-item-indicator.js';
7
+ export { NavigationMenuLink } from './navigation-menu-link.js';
8
+ export { NavigationMenuList } from './navigation-menu-list.js';
9
+ export { NavigationMenuRoot } from './navigation-menu-root.js';
10
+ export { NavigationMenuRootProvider } from './navigation-menu-root-provider.js';
11
+ export { NavigationMenuTrigger } from './navigation-menu-trigger.js';
12
+ export { NavigationMenuViewport } from './navigation-menu-viewport.js';
13
+ export { NavigationMenuViewportPositioner } from './navigation-menu-viewport-positioner.js';
14
+ export { useNavigationMenu } from './use-navigation-menu.js';
15
+ export { useNavigationMenuContext } from './use-navigation-menu-context.js';
16
+ import * as navigationMenu from './navigation-menu.js';
17
+ export { navigationMenu as NavigationMenu };
18
+ export { anatomy as navigationMenuAnatomy } from '@zag-js/navigation-menu';
@@ -0,0 +1,19 @@
1
+ 'use client';
2
+ 'use strict';
3
+
4
+ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
5
+
6
+ const jsxRuntime = require('react/jsx-runtime');
7
+ const react$1 = require('@zag-js/react');
8
+ const react = require('react');
9
+ const factory = require('../factory.cjs');
10
+ const useNavigationMenuContext = require('./use-navigation-menu-context.cjs');
11
+
12
+ const NavigationMenuArrow = react.forwardRef((props, ref) => {
13
+ const navigationMenu = useNavigationMenuContext.useNavigationMenuContext();
14
+ const mergedProps = react$1.mergeProps(navigationMenu.getArrowProps(), props);
15
+ return /* @__PURE__ */ jsxRuntime.jsx(factory.ark.div, { ...mergedProps, ref });
16
+ });
17
+ NavigationMenuArrow.displayName = "NavigationMenuArrow";
18
+
19
+ exports.NavigationMenuArrow = NavigationMenuArrow;
@@ -0,0 +1,7 @@
1
+ import { HTMLProps, PolymorphicProps } from '../factory';
2
+ import { ForwardRefExoticComponent, RefAttributes } from 'react';
3
+ export interface NavigationMenuArrowBaseProps extends PolymorphicProps {
4
+ }
5
+ export interface NavigationMenuArrowProps extends HTMLProps<'div'>, NavigationMenuArrowBaseProps {
6
+ }
7
+ export declare const NavigationMenuArrow: ForwardRefExoticComponent<NavigationMenuArrowProps & RefAttributes<HTMLDivElement>>;
@@ -0,0 +1,7 @@
1
+ import { HTMLProps, PolymorphicProps } from '../factory';
2
+ import { ForwardRefExoticComponent, RefAttributes } from 'react';
3
+ export interface NavigationMenuArrowBaseProps extends PolymorphicProps {
4
+ }
5
+ export interface NavigationMenuArrowProps extends HTMLProps<'div'>, NavigationMenuArrowBaseProps {
6
+ }
7
+ export declare const NavigationMenuArrow: ForwardRefExoticComponent<NavigationMenuArrowProps & RefAttributes<HTMLDivElement>>;
@@ -0,0 +1,15 @@
1
+ 'use client';
2
+ import { jsx } from 'react/jsx-runtime';
3
+ import { mergeProps } from '@zag-js/react';
4
+ import { forwardRef } from 'react';
5
+ import { ark } from '../factory.js';
6
+ import { useNavigationMenuContext } from './use-navigation-menu-context.js';
7
+
8
+ const NavigationMenuArrow = forwardRef((props, ref) => {
9
+ const navigationMenu = useNavigationMenuContext();
10
+ const mergedProps = mergeProps(navigationMenu.getArrowProps(), props);
11
+ return /* @__PURE__ */ jsx(ark.div, { ...mergedProps, ref });
12
+ });
13
+ NavigationMenuArrow.displayName = "NavigationMenuArrow";
14
+
15
+ export { NavigationMenuArrow };
@@ -0,0 +1,41 @@
1
+ 'use client';
2
+ 'use strict';
3
+
4
+ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
5
+
6
+ const jsxRuntime = require('react/jsx-runtime');
7
+ const react$1 = require('@zag-js/react');
8
+ const react = require('react');
9
+ const composeRefs = require('../../utils/compose-refs.cjs');
10
+ const createSplitProps = require('../../utils/create-split-props.cjs');
11
+ const renderStrategy = require('../../utils/render-strategy.cjs');
12
+ const factory = require('../factory.cjs');
13
+ const portal = require('../portal/portal.cjs');
14
+ const usePresence = require('../presence/use-presence.cjs');
15
+ const usePresenceContext = require('../presence/use-presence-context.cjs');
16
+ const useNavigationMenuContext = require('./use-navigation-menu-context.cjs');
17
+ const useNavigationMenuItemPropsContext = require('./use-navigation-menu-item-props-context.cjs');
18
+
19
+ const splitContentProps = createSplitProps.createSplitProps();
20
+ const NavigationMenuContent = react.forwardRef((props, ref) => {
21
+ const api = useNavigationMenuContext.useNavigationMenuContext();
22
+ const itemContext = useNavigationMenuItemPropsContext.useNavigationMenuItemPropsContext();
23
+ const value = props.value ?? itemContext?.value;
24
+ const [contentProps, localProps] = splitContentProps({ ...props, value }, ["value"]);
25
+ const renderStrategyProps = renderStrategy.useRenderStrategyPropsContext();
26
+ const presence = usePresence.usePresence({ ...renderStrategyProps, present: api.value === value });
27
+ const mergedProps = react$1.mergeProps(api.getContentProps(contentProps), presence.getPresenceProps(), localProps);
28
+ const content = /* @__PURE__ */ jsxRuntime.jsx(usePresenceContext.PresenceProvider, { value: presence, children: presence.unmounted ? null : /* @__PURE__ */ jsxRuntime.jsx(factory.ark.div, { ...mergedProps, ref: composeRefs.composeRefs(presence.ref, ref) }) });
29
+ const viewportNode = api.getViewportNode();
30
+ if (api.isViewportRendered && viewportNode) {
31
+ return /* @__PURE__ */ jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [
32
+ /* @__PURE__ */ jsxRuntime.jsx("div", { ...api.getViewportProxyProps(contentProps) }),
33
+ /* @__PURE__ */ jsxRuntime.jsx("div", { ...api.getTriggerProxyProps(contentProps) }),
34
+ /* @__PURE__ */ jsxRuntime.jsx(portal.Portal, { container: { current: viewportNode }, children: content })
35
+ ] });
36
+ }
37
+ return content;
38
+ });
39
+ NavigationMenuContent.displayName = "NavigationMenuContent";
40
+
41
+ exports.NavigationMenuContent = NavigationMenuContent;
@@ -0,0 +1,9 @@
1
+ import { ContentProps } from '@zag-js/navigation-menu';
2
+ import { Assign } from '../../types';
3
+ import { HTMLProps, PolymorphicProps } from '../factory';
4
+ import { ForwardRefExoticComponent, RefAttributes } from 'react';
5
+ export interface NavigationMenuContentBaseProps extends Partial<ContentProps>, PolymorphicProps {
6
+ }
7
+ export interface NavigationMenuContentProps extends Assign<HTMLProps<'div'>, NavigationMenuContentBaseProps> {
8
+ }
9
+ export declare const NavigationMenuContent: ForwardRefExoticComponent<NavigationMenuContentProps & RefAttributes<HTMLDivElement>>;
@@ -0,0 +1,9 @@
1
+ import { ContentProps } from '@zag-js/navigation-menu';
2
+ import { Assign } from '../../types';
3
+ import { HTMLProps, PolymorphicProps } from '../factory';
4
+ import { ForwardRefExoticComponent, RefAttributes } from 'react';
5
+ export interface NavigationMenuContentBaseProps extends Partial<ContentProps>, PolymorphicProps {
6
+ }
7
+ export interface NavigationMenuContentProps extends Assign<HTMLProps<'div'>, NavigationMenuContentBaseProps> {
8
+ }
9
+ export declare const NavigationMenuContent: ForwardRefExoticComponent<NavigationMenuContentProps & RefAttributes<HTMLDivElement>>;
@@ -0,0 +1,37 @@
1
+ 'use client';
2
+ import { jsx, jsxs, Fragment } from 'react/jsx-runtime';
3
+ import { mergeProps } from '@zag-js/react';
4
+ import { forwardRef } from 'react';
5
+ import { composeRefs } from '../../utils/compose-refs.js';
6
+ import { createSplitProps } from '../../utils/create-split-props.js';
7
+ import { useRenderStrategyPropsContext } from '../../utils/render-strategy.js';
8
+ import { ark } from '../factory.js';
9
+ import { Portal } from '../portal/portal.js';
10
+ import { usePresence } from '../presence/use-presence.js';
11
+ import { PresenceProvider } from '../presence/use-presence-context.js';
12
+ import { useNavigationMenuContext } from './use-navigation-menu-context.js';
13
+ import { useNavigationMenuItemPropsContext } from './use-navigation-menu-item-props-context.js';
14
+
15
+ const splitContentProps = createSplitProps();
16
+ const NavigationMenuContent = forwardRef((props, ref) => {
17
+ const api = useNavigationMenuContext();
18
+ const itemContext = useNavigationMenuItemPropsContext();
19
+ const value = props.value ?? itemContext?.value;
20
+ const [contentProps, localProps] = splitContentProps({ ...props, value }, ["value"]);
21
+ const renderStrategyProps = useRenderStrategyPropsContext();
22
+ const presence = usePresence({ ...renderStrategyProps, present: api.value === value });
23
+ const mergedProps = mergeProps(api.getContentProps(contentProps), presence.getPresenceProps(), localProps);
24
+ const content = /* @__PURE__ */ jsx(PresenceProvider, { value: presence, children: presence.unmounted ? null : /* @__PURE__ */ jsx(ark.div, { ...mergedProps, ref: composeRefs(presence.ref, ref) }) });
25
+ const viewportNode = api.getViewportNode();
26
+ if (api.isViewportRendered && viewportNode) {
27
+ return /* @__PURE__ */ jsxs(Fragment, { children: [
28
+ /* @__PURE__ */ jsx("div", { ...api.getViewportProxyProps(contentProps) }),
29
+ /* @__PURE__ */ jsx("div", { ...api.getTriggerProxyProps(contentProps) }),
30
+ /* @__PURE__ */ jsx(Portal, { container: { current: viewportNode }, children: content })
31
+ ] });
32
+ }
33
+ return content;
34
+ });
35
+ NavigationMenuContent.displayName = "NavigationMenuContent";
36
+
37
+ export { NavigationMenuContent };
@@ -0,0 +1,10 @@
1
+ 'use client';
2
+ 'use strict';
3
+
4
+ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
5
+
6
+ const useNavigationMenuContext = require('./use-navigation-menu-context.cjs');
7
+
8
+ const NavigationMenuContext = (props) => props.children(useNavigationMenuContext.useNavigationMenuContext());
9
+
10
+ exports.NavigationMenuContext = NavigationMenuContext;
@@ -0,0 +1,6 @@
1
+ import { ReactNode } from 'react';
2
+ import { UseNavigationMenuContext } from './use-navigation-menu-context';
3
+ export interface NavigationMenuContextProps {
4
+ children: (context: UseNavigationMenuContext) => ReactNode;
5
+ }
6
+ export declare const NavigationMenuContext: (props: NavigationMenuContextProps) => ReactNode;
@@ -0,0 +1,6 @@
1
+ import { ReactNode } from 'react';
2
+ import { UseNavigationMenuContext } from './use-navigation-menu-context';
3
+ export interface NavigationMenuContextProps {
4
+ children: (context: UseNavigationMenuContext) => ReactNode;
5
+ }
6
+ export declare const NavigationMenuContext: (props: NavigationMenuContextProps) => ReactNode;
@@ -0,0 +1,6 @@
1
+ 'use client';
2
+ import { useNavigationMenuContext } from './use-navigation-menu-context.js';
3
+
4
+ const NavigationMenuContext = (props) => props.children(useNavigationMenuContext());
5
+
6
+ export { NavigationMenuContext };
@@ -0,0 +1,25 @@
1
+ 'use client';
2
+ 'use strict';
3
+
4
+ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
5
+
6
+ const jsxRuntime = require('react/jsx-runtime');
7
+ const react$1 = require('@zag-js/react');
8
+ const react = require('react');
9
+ const composeRefs = require('../../utils/compose-refs.cjs');
10
+ const renderStrategy = require('../../utils/render-strategy.cjs');
11
+ const factory = require('../factory.cjs');
12
+ const usePresence = require('../presence/use-presence.cjs');
13
+ const usePresenceContext = require('../presence/use-presence-context.cjs');
14
+ const useNavigationMenuContext = require('./use-navigation-menu-context.cjs');
15
+
16
+ const NavigationMenuIndicator = react.forwardRef((props, ref) => {
17
+ const navigationMenu = useNavigationMenuContext.useNavigationMenuContext();
18
+ const renderStrategyProps = renderStrategy.useRenderStrategyPropsContext();
19
+ const presence = usePresence.usePresence({ ...renderStrategyProps, present: navigationMenu.open });
20
+ const mergedProps = react$1.mergeProps(navigationMenu.getIndicatorProps(), presence.getPresenceProps(), props);
21
+ return /* @__PURE__ */ jsxRuntime.jsx(usePresenceContext.PresenceProvider, { value: presence, children: presence.unmounted ? null : /* @__PURE__ */ jsxRuntime.jsx(factory.ark.div, { ...mergedProps, ref: composeRefs.composeRefs(presence.ref, ref) }) });
22
+ });
23
+ NavigationMenuIndicator.displayName = "NavigationMenuIndicator";
24
+
25
+ exports.NavigationMenuIndicator = NavigationMenuIndicator;
@@ -0,0 +1,7 @@
1
+ import { HTMLProps, PolymorphicProps } from '../factory';
2
+ import { ForwardRefExoticComponent, RefAttributes } from 'react';
3
+ export interface NavigationMenuIndicatorBaseProps extends PolymorphicProps {
4
+ }
5
+ export interface NavigationMenuIndicatorProps extends HTMLProps<'div'>, NavigationMenuIndicatorBaseProps {
6
+ }
7
+ export declare const NavigationMenuIndicator: ForwardRefExoticComponent<NavigationMenuIndicatorProps & RefAttributes<HTMLDivElement>>;
@@ -0,0 +1,7 @@
1
+ import { HTMLProps, PolymorphicProps } from '../factory';
2
+ import { ForwardRefExoticComponent, RefAttributes } from 'react';
3
+ export interface NavigationMenuIndicatorBaseProps extends PolymorphicProps {
4
+ }
5
+ export interface NavigationMenuIndicatorProps extends HTMLProps<'div'>, NavigationMenuIndicatorBaseProps {
6
+ }
7
+ export declare const NavigationMenuIndicator: ForwardRefExoticComponent<NavigationMenuIndicatorProps & RefAttributes<HTMLDivElement>>;
@@ -0,0 +1,21 @@
1
+ 'use client';
2
+ import { jsx } from 'react/jsx-runtime';
3
+ import { mergeProps } from '@zag-js/react';
4
+ import { forwardRef } from 'react';
5
+ import { composeRefs } from '../../utils/compose-refs.js';
6
+ import { useRenderStrategyPropsContext } from '../../utils/render-strategy.js';
7
+ import { ark } from '../factory.js';
8
+ import { usePresence } from '../presence/use-presence.js';
9
+ import { PresenceProvider } from '../presence/use-presence-context.js';
10
+ import { useNavigationMenuContext } from './use-navigation-menu-context.js';
11
+
12
+ const NavigationMenuIndicator = forwardRef((props, ref) => {
13
+ const navigationMenu = useNavigationMenuContext();
14
+ const renderStrategyProps = useRenderStrategyPropsContext();
15
+ const presence = usePresence({ ...renderStrategyProps, present: navigationMenu.open });
16
+ const mergedProps = mergeProps(navigationMenu.getIndicatorProps(), presence.getPresenceProps(), props);
17
+ return /* @__PURE__ */ jsx(PresenceProvider, { value: presence, children: presence.unmounted ? null : /* @__PURE__ */ jsx(ark.div, { ...mergedProps, ref: composeRefs(presence.ref, ref) }) });
18
+ });
19
+ NavigationMenuIndicator.displayName = "NavigationMenuIndicator";
20
+
21
+ export { NavigationMenuIndicator };
@@ -0,0 +1,23 @@
1
+ 'use client';
2
+ 'use strict';
3
+
4
+ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
5
+
6
+ const jsxRuntime = require('react/jsx-runtime');
7
+ const react$1 = require('@zag-js/react');
8
+ const react = require('react');
9
+ const factory = require('../factory.cjs');
10
+ const useNavigationMenuContext = require('./use-navigation-menu-context.cjs');
11
+ const useNavigationMenuItemPropsContext = require('./use-navigation-menu-item-props-context.cjs');
12
+
13
+ const NavigationMenuItemIndicator = react.forwardRef(
14
+ (props, ref) => {
15
+ const navigationMenu = useNavigationMenuContext.useNavigationMenuContext();
16
+ const itemProps = useNavigationMenuItemPropsContext.useNavigationMenuItemPropsContext();
17
+ const mergedProps = react$1.mergeProps(navigationMenu.getItemIndicatorProps(itemProps), props);
18
+ return /* @__PURE__ */ jsxRuntime.jsx(factory.ark.div, { ...mergedProps, ref });
19
+ }
20
+ );
21
+ NavigationMenuItemIndicator.displayName = "NavigationMenuItemIndicator";
22
+
23
+ exports.NavigationMenuItemIndicator = NavigationMenuItemIndicator;
@@ -0,0 +1,7 @@
1
+ import { HTMLProps, PolymorphicProps } from '../factory';
2
+ import { ForwardRefExoticComponent, RefAttributes } from 'react';
3
+ export interface NavigationMenuItemIndicatorBaseProps extends PolymorphicProps {
4
+ }
5
+ export interface NavigationMenuItemIndicatorProps extends HTMLProps<'div'>, NavigationMenuItemIndicatorBaseProps {
6
+ }
7
+ export declare const NavigationMenuItemIndicator: ForwardRefExoticComponent<NavigationMenuItemIndicatorProps & RefAttributes<HTMLDivElement>>;
@@ -0,0 +1,7 @@
1
+ import { HTMLProps, PolymorphicProps } from '../factory';
2
+ import { ForwardRefExoticComponent, RefAttributes } from 'react';
3
+ export interface NavigationMenuItemIndicatorBaseProps extends PolymorphicProps {
4
+ }
5
+ export interface NavigationMenuItemIndicatorProps extends HTMLProps<'div'>, NavigationMenuItemIndicatorBaseProps {
6
+ }
7
+ export declare const NavigationMenuItemIndicator: ForwardRefExoticComponent<NavigationMenuItemIndicatorProps & RefAttributes<HTMLDivElement>>;
@@ -0,0 +1,19 @@
1
+ 'use client';
2
+ import { jsx } from 'react/jsx-runtime';
3
+ import { mergeProps } from '@zag-js/react';
4
+ import { forwardRef } from 'react';
5
+ import { ark } from '../factory.js';
6
+ import { useNavigationMenuContext } from './use-navigation-menu-context.js';
7
+ import { useNavigationMenuItemPropsContext } from './use-navigation-menu-item-props-context.js';
8
+
9
+ const NavigationMenuItemIndicator = forwardRef(
10
+ (props, ref) => {
11
+ const navigationMenu = useNavigationMenuContext();
12
+ const itemProps = useNavigationMenuItemPropsContext();
13
+ const mergedProps = mergeProps(navigationMenu.getItemIndicatorProps(itemProps), props);
14
+ return /* @__PURE__ */ jsx(ark.div, { ...mergedProps, ref });
15
+ }
16
+ );
17
+ NavigationMenuItemIndicator.displayName = "NavigationMenuItemIndicator";
18
+
19
+ export { NavigationMenuItemIndicator };
@@ -0,0 +1,23 @@
1
+ 'use client';
2
+ 'use strict';
3
+
4
+ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
5
+
6
+ const jsxRuntime = require('react/jsx-runtime');
7
+ const react$1 = require('@zag-js/react');
8
+ const react = require('react');
9
+ const createSplitProps = require('../../utils/create-split-props.cjs');
10
+ const factory = require('../factory.cjs');
11
+ const useNavigationMenuContext = require('./use-navigation-menu-context.cjs');
12
+ const useNavigationMenuItemPropsContext = require('./use-navigation-menu-item-props-context.cjs');
13
+
14
+ const splitItemProps = createSplitProps.createSplitProps();
15
+ const NavigationMenuItem = react.forwardRef((props, ref) => {
16
+ const [itemProps, localProps] = splitItemProps(props, ["disabled", "value"]);
17
+ const navigationMenu = useNavigationMenuContext.useNavigationMenuContext();
18
+ const mergedProps = react$1.mergeProps(navigationMenu.getItemProps(itemProps), localProps);
19
+ return /* @__PURE__ */ jsxRuntime.jsx(useNavigationMenuItemPropsContext.NavigationMenuItemPropsProvider, { value: itemProps, children: /* @__PURE__ */ jsxRuntime.jsx(factory.ark.div, { ...mergedProps, ref }) });
20
+ });
21
+ NavigationMenuItem.displayName = "NavigationMenuItem";
22
+
23
+ exports.NavigationMenuItem = NavigationMenuItem;
@@ -0,0 +1,8 @@
1
+ import { ItemProps } from '@zag-js/navigation-menu';
2
+ import { HTMLProps, PolymorphicProps } from '../factory';
3
+ import { ForwardRefExoticComponent, RefAttributes } from 'react';
4
+ export interface NavigationMenuItemBaseProps extends ItemProps, PolymorphicProps {
5
+ }
6
+ export interface NavigationMenuItemProps extends HTMLProps<'div'>, NavigationMenuItemBaseProps {
7
+ }
8
+ export declare const NavigationMenuItem: ForwardRefExoticComponent<NavigationMenuItemProps & RefAttributes<HTMLDivElement>>;
@@ -0,0 +1,8 @@
1
+ import { ItemProps } from '@zag-js/navigation-menu';
2
+ import { HTMLProps, PolymorphicProps } from '../factory';
3
+ import { ForwardRefExoticComponent, RefAttributes } from 'react';
4
+ export interface NavigationMenuItemBaseProps extends ItemProps, PolymorphicProps {
5
+ }
6
+ export interface NavigationMenuItemProps extends HTMLProps<'div'>, NavigationMenuItemBaseProps {
7
+ }
8
+ export declare const NavigationMenuItem: ForwardRefExoticComponent<NavigationMenuItemProps & RefAttributes<HTMLDivElement>>;
@@ -0,0 +1,19 @@
1
+ 'use client';
2
+ import { jsx } from 'react/jsx-runtime';
3
+ import { mergeProps } from '@zag-js/react';
4
+ import { forwardRef } from 'react';
5
+ import { createSplitProps } from '../../utils/create-split-props.js';
6
+ import { ark } from '../factory.js';
7
+ import { useNavigationMenuContext } from './use-navigation-menu-context.js';
8
+ import { NavigationMenuItemPropsProvider } from './use-navigation-menu-item-props-context.js';
9
+
10
+ const splitItemProps = createSplitProps();
11
+ const NavigationMenuItem = forwardRef((props, ref) => {
12
+ const [itemProps, localProps] = splitItemProps(props, ["disabled", "value"]);
13
+ const navigationMenu = useNavigationMenuContext();
14
+ const mergedProps = mergeProps(navigationMenu.getItemProps(itemProps), localProps);
15
+ return /* @__PURE__ */ jsx(NavigationMenuItemPropsProvider, { value: itemProps, children: /* @__PURE__ */ jsx(ark.div, { ...mergedProps, ref }) });
16
+ });
17
+ NavigationMenuItem.displayName = "NavigationMenuItem";
18
+
19
+ export { NavigationMenuItem };
@@ -0,0 +1,25 @@
1
+ 'use client';
2
+ 'use strict';
3
+
4
+ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
5
+
6
+ const jsxRuntime = require('react/jsx-runtime');
7
+ const react$1 = require('@zag-js/react');
8
+ const react = require('react');
9
+ const createSplitProps = require('../../utils/create-split-props.cjs');
10
+ const factory = require('../factory.cjs');
11
+ const useNavigationMenuContext = require('./use-navigation-menu-context.cjs');
12
+ const useNavigationMenuItemPropsContext = require('./use-navigation-menu-item-props-context.cjs');
13
+
14
+ const splitLinkProps = createSplitProps.createSplitProps();
15
+ const NavigationMenuLink = react.forwardRef((props, ref) => {
16
+ const itemContext = useNavigationMenuItemPropsContext.useNavigationMenuItemPropsContext();
17
+ const value = props.value ?? itemContext?.value;
18
+ const [linkProps, localProps] = splitLinkProps({ ...props, value }, ["current", "onSelect", "value", "closeOnClick"]);
19
+ const navigationMenu = useNavigationMenuContext.useNavigationMenuContext();
20
+ const mergedProps = react$1.mergeProps(navigationMenu.getLinkProps(linkProps), localProps);
21
+ return /* @__PURE__ */ jsxRuntime.jsx(factory.ark.a, { ...mergedProps, ref });
22
+ });
23
+ NavigationMenuLink.displayName = "NavigationMenuLink";
24
+
25
+ exports.NavigationMenuLink = NavigationMenuLink;
@@ -0,0 +1,9 @@
1
+ import { LinkProps } from '@zag-js/navigation-menu';
2
+ import { Assign } from '../../types';
3
+ import { HTMLProps, PolymorphicProps } from '../factory';
4
+ import { ForwardRefExoticComponent, RefAttributes } from 'react';
5
+ export interface NavigationMenuLinkBaseProps extends Partial<LinkProps>, PolymorphicProps {
6
+ }
7
+ export interface NavigationMenuLinkProps extends Assign<HTMLProps<'a'>, NavigationMenuLinkBaseProps> {
8
+ }
9
+ export declare const NavigationMenuLink: ForwardRefExoticComponent<NavigationMenuLinkProps & RefAttributes<HTMLAnchorElement>>;
@@ -0,0 +1,9 @@
1
+ import { LinkProps } from '@zag-js/navigation-menu';
2
+ import { Assign } from '../../types';
3
+ import { HTMLProps, PolymorphicProps } from '../factory';
4
+ import { ForwardRefExoticComponent, RefAttributes } from 'react';
5
+ export interface NavigationMenuLinkBaseProps extends Partial<LinkProps>, PolymorphicProps {
6
+ }
7
+ export interface NavigationMenuLinkProps extends Assign<HTMLProps<'a'>, NavigationMenuLinkBaseProps> {
8
+ }
9
+ export declare const NavigationMenuLink: ForwardRefExoticComponent<NavigationMenuLinkProps & RefAttributes<HTMLAnchorElement>>;
@@ -0,0 +1,21 @@
1
+ 'use client';
2
+ import { jsx } from 'react/jsx-runtime';
3
+ import { mergeProps } from '@zag-js/react';
4
+ import { forwardRef } from 'react';
5
+ import { createSplitProps } from '../../utils/create-split-props.js';
6
+ import { ark } from '../factory.js';
7
+ import { useNavigationMenuContext } from './use-navigation-menu-context.js';
8
+ import { useNavigationMenuItemPropsContext } from './use-navigation-menu-item-props-context.js';
9
+
10
+ const splitLinkProps = createSplitProps();
11
+ const NavigationMenuLink = forwardRef((props, ref) => {
12
+ const itemContext = useNavigationMenuItemPropsContext();
13
+ const value = props.value ?? itemContext?.value;
14
+ const [linkProps, localProps] = splitLinkProps({ ...props, value }, ["current", "onSelect", "value", "closeOnClick"]);
15
+ const navigationMenu = useNavigationMenuContext();
16
+ const mergedProps = mergeProps(navigationMenu.getLinkProps(linkProps), localProps);
17
+ return /* @__PURE__ */ jsx(ark.a, { ...mergedProps, ref });
18
+ });
19
+ NavigationMenuLink.displayName = "NavigationMenuLink";
20
+
21
+ export { NavigationMenuLink };
@@ -0,0 +1,19 @@
1
+ 'use client';
2
+ 'use strict';
3
+
4
+ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
5
+
6
+ const jsxRuntime = require('react/jsx-runtime');
7
+ const react$1 = require('@zag-js/react');
8
+ const react = require('react');
9
+ const factory = require('../factory.cjs');
10
+ const useNavigationMenuContext = require('./use-navigation-menu-context.cjs');
11
+
12
+ const NavigationMenuList = react.forwardRef((props, ref) => {
13
+ const navigationMenu = useNavigationMenuContext.useNavigationMenuContext();
14
+ const mergedProps = react$1.mergeProps(navigationMenu.getListProps(), props);
15
+ return /* @__PURE__ */ jsxRuntime.jsx(factory.ark.div, { ...mergedProps, ref });
16
+ });
17
+ NavigationMenuList.displayName = "NavigationMenuList";
18
+
19
+ exports.NavigationMenuList = NavigationMenuList;
@@ -0,0 +1,7 @@
1
+ import { HTMLProps, PolymorphicProps } from '../factory';
2
+ import { ForwardRefExoticComponent, RefAttributes } from 'react';
3
+ export interface NavigationMenuListBaseProps extends PolymorphicProps {
4
+ }
5
+ export interface NavigationMenuListProps extends HTMLProps<'div'>, NavigationMenuListBaseProps {
6
+ }
7
+ export declare const NavigationMenuList: ForwardRefExoticComponent<NavigationMenuListProps & RefAttributes<HTMLDivElement>>;
@@ -0,0 +1,7 @@
1
+ import { HTMLProps, PolymorphicProps } from '../factory';
2
+ import { ForwardRefExoticComponent, RefAttributes } from 'react';
3
+ export interface NavigationMenuListBaseProps extends PolymorphicProps {
4
+ }
5
+ export interface NavigationMenuListProps extends HTMLProps<'div'>, NavigationMenuListBaseProps {
6
+ }
7
+ export declare const NavigationMenuList: ForwardRefExoticComponent<NavigationMenuListProps & RefAttributes<HTMLDivElement>>;
@@ -0,0 +1,15 @@
1
+ 'use client';
2
+ import { jsx } from 'react/jsx-runtime';
3
+ import { mergeProps } from '@zag-js/react';
4
+ import { forwardRef } from 'react';
5
+ import { ark } from '../factory.js';
6
+ import { useNavigationMenuContext } from './use-navigation-menu-context.js';
7
+
8
+ const NavigationMenuList = forwardRef((props, ref) => {
9
+ const navigationMenu = useNavigationMenuContext();
10
+ const mergedProps = mergeProps(navigationMenu.getListProps(), props);
11
+ return /* @__PURE__ */ jsx(ark.div, { ...mergedProps, ref });
12
+ });
13
+ NavigationMenuList.displayName = "NavigationMenuList";
14
+
15
+ export { NavigationMenuList };
@@ -0,0 +1,23 @@
1
+ 'use client';
2
+ 'use strict';
3
+
4
+ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
5
+
6
+ const jsxRuntime = require('react/jsx-runtime');
7
+ const react$1 = require('@zag-js/react');
8
+ const react = require('react');
9
+ const createSplitProps = require('../../utils/create-split-props.cjs');
10
+ const renderStrategy = require('../../utils/render-strategy.cjs');
11
+ const factory = require('../factory.cjs');
12
+ const useNavigationMenuContext = require('./use-navigation-menu-context.cjs');
13
+
14
+ const splitRootProviderProps = createSplitProps.createSplitProps();
15
+ const NavigationMenuRootProvider = react.forwardRef((props, ref) => {
16
+ const [renderStrategyProps, navigationMenuProps] = renderStrategy.splitRenderStrategyProps(props);
17
+ const [{ value: navigationMenu }, localProps] = splitRootProviderProps(navigationMenuProps, ["value"]);
18
+ const mergedProps = react$1.mergeProps(navigationMenu.getRootProps(), localProps);
19
+ return /* @__PURE__ */ jsxRuntime.jsx(useNavigationMenuContext.NavigationMenuProvider, { value: navigationMenu, children: /* @__PURE__ */ jsxRuntime.jsx(renderStrategy.RenderStrategyPropsProvider, { value: renderStrategyProps, children: /* @__PURE__ */ jsxRuntime.jsx(factory.ark.nav, { ...mergedProps, ref }) }) });
20
+ });
21
+ NavigationMenuRootProvider.displayName = "NavigationMenuRootProvider";
22
+
23
+ exports.NavigationMenuRootProvider = NavigationMenuRootProvider;
@@ -0,0 +1,13 @@
1
+ import { RenderStrategyProps } from '../../utils/render-strategy';
2
+ import { HTMLProps, PolymorphicProps } from '../factory';
3
+ import { UseNavigationMenuReturn } from './use-navigation-menu';
4
+ import { ForwardRefExoticComponent, RefAttributes } from 'react';
5
+ interface RootProviderProps {
6
+ value: UseNavigationMenuReturn;
7
+ }
8
+ export interface NavigationMenuRootProviderBaseProps extends RootProviderProps, RenderStrategyProps, PolymorphicProps {
9
+ }
10
+ export interface NavigationMenuRootProviderProps extends HTMLProps<'nav'>, NavigationMenuRootProviderBaseProps {
11
+ }
12
+ export declare const NavigationMenuRootProvider: ForwardRefExoticComponent<NavigationMenuRootProviderProps & RefAttributes<HTMLElement>>;
13
+ export {};
@@ -0,0 +1,13 @@
1
+ import { RenderStrategyProps } from '../../utils/render-strategy';
2
+ import { HTMLProps, PolymorphicProps } from '../factory';
3
+ import { UseNavigationMenuReturn } from './use-navigation-menu';
4
+ import { ForwardRefExoticComponent, RefAttributes } from 'react';
5
+ interface RootProviderProps {
6
+ value: UseNavigationMenuReturn;
7
+ }
8
+ export interface NavigationMenuRootProviderBaseProps extends RootProviderProps, RenderStrategyProps, PolymorphicProps {
9
+ }
10
+ export interface NavigationMenuRootProviderProps extends HTMLProps<'nav'>, NavigationMenuRootProviderBaseProps {
11
+ }
12
+ export declare const NavigationMenuRootProvider: ForwardRefExoticComponent<NavigationMenuRootProviderProps & RefAttributes<HTMLElement>>;
13
+ export {};