@ark-ui/react 4.0.0 → 4.1.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 (77) hide show
  1. package/dist/components/color-picker/color-picker-content.cjs +3 -2
  2. package/dist/components/color-picker/color-picker-content.js +3 -2
  3. package/dist/components/combobox/combobox-content.cjs +3 -2
  4. package/dist/components/combobox/combobox-content.js +3 -2
  5. package/dist/components/date-picker/date-picker-content.cjs +3 -6
  6. package/dist/components/date-picker/date-picker-content.js +3 -6
  7. package/dist/components/dialog/dialog-backdrop.cjs +3 -2
  8. package/dist/components/dialog/dialog-backdrop.js +3 -2
  9. package/dist/components/dialog/dialog-content.cjs +3 -2
  10. package/dist/components/dialog/dialog-content.js +3 -2
  11. package/dist/components/factory.cjs +12 -4
  12. package/dist/components/factory.js +12 -4
  13. package/dist/components/field/field-textarea.cjs +2 -2
  14. package/dist/components/field/field-textarea.js +1 -1
  15. package/dist/components/file-upload/file-upload-item-preview-image.cjs +1 -1
  16. package/dist/components/file-upload/file-upload-item-preview-image.js +1 -1
  17. package/dist/components/hover-card/hover-card-content.cjs +3 -2
  18. package/dist/components/hover-card/hover-card-content.js +3 -2
  19. package/dist/components/index.cjs +14 -0
  20. package/dist/components/index.d.cts +1 -0
  21. package/dist/components/index.d.ts +1 -0
  22. package/dist/components/index.js +8 -0
  23. package/dist/components/menu/menu-content.cjs +3 -2
  24. package/dist/components/menu/menu-content.js +3 -2
  25. package/dist/components/popover/popover-content.cjs +3 -2
  26. package/dist/components/popover/popover-content.js +3 -2
  27. package/dist/components/presence/presence.cjs +4 -2
  28. package/dist/components/presence/presence.js +4 -2
  29. package/dist/components/presence/use-presence.cjs +2 -3
  30. package/dist/components/presence/use-presence.d.cts +2 -3
  31. package/dist/components/presence/use-presence.d.ts +2 -3
  32. package/dist/components/presence/use-presence.js +2 -3
  33. package/dist/components/select/select-content.cjs +3 -2
  34. package/dist/components/select/select-content.js +3 -2
  35. package/dist/components/tabs/tab-content.cjs +3 -2
  36. package/dist/components/tabs/tab-content.js +3 -2
  37. package/dist/components/time-picker/time-picker-content.cjs +3 -6
  38. package/dist/components/time-picker/time-picker-content.js +3 -6
  39. package/dist/components/toggle/index.cjs +21 -0
  40. package/dist/components/toggle/index.d.cts +7 -0
  41. package/dist/components/toggle/index.d.ts +7 -0
  42. package/dist/components/toggle/index.js +8 -0
  43. package/dist/components/toggle/toggle-context.cjs +10 -0
  44. package/dist/components/toggle/toggle-context.d.cts +6 -0
  45. package/dist/components/toggle/toggle-context.d.ts +6 -0
  46. package/dist/components/toggle/toggle-context.js +6 -0
  47. package/dist/components/toggle/toggle-indicator.cjs +20 -0
  48. package/dist/components/toggle/toggle-indicator.d.cts +11 -0
  49. package/dist/components/toggle/toggle-indicator.d.ts +11 -0
  50. package/dist/components/toggle/toggle-indicator.js +16 -0
  51. package/dist/components/toggle/toggle-root.cjs +27 -0
  52. package/dist/components/toggle/toggle-root.d.cts +8 -0
  53. package/dist/components/toggle/toggle-root.d.ts +8 -0
  54. package/dist/components/toggle/toggle-root.js +23 -0
  55. package/dist/components/toggle/toggle.anatomy.cjs +12 -0
  56. package/dist/components/toggle/toggle.anatomy.d.cts +3 -0
  57. package/dist/components/toggle/toggle.anatomy.d.ts +3 -0
  58. package/dist/components/toggle/toggle.anatomy.js +7 -0
  59. package/dist/components/toggle/toggle.cjs +15 -0
  60. package/dist/components/toggle/toggle.d.cts +4 -0
  61. package/dist/components/toggle/toggle.d.ts +4 -0
  62. package/dist/components/toggle/toggle.js +4 -0
  63. package/dist/components/toggle/use-toggle-context.cjs +15 -0
  64. package/dist/components/toggle/use-toggle-context.d.cts +5 -0
  65. package/dist/components/toggle/use-toggle-context.d.ts +5 -0
  66. package/dist/components/toggle/use-toggle-context.js +10 -0
  67. package/dist/components/toggle/use-toggle.cjs +48 -0
  68. package/dist/components/toggle/use-toggle.d.cts +35 -0
  69. package/dist/components/toggle/use-toggle.d.ts +35 -0
  70. package/dist/components/toggle/use-toggle.js +44 -0
  71. package/dist/components/tooltip/tooltip-content.cjs +3 -2
  72. package/dist/components/tooltip/tooltip-content.js +3 -2
  73. package/dist/index.cjs +14 -0
  74. package/dist/index.js +8 -0
  75. package/dist/utils/compose-refs.d.cts +2 -2
  76. package/dist/utils/compose-refs.d.ts +2 -2
  77. package/package.json +58 -58
@@ -6,6 +6,7 @@ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
6
6
  const jsxRuntime = require('react/jsx-runtime');
7
7
  const react$1 = require('@zag-js/react');
8
8
  const react = require('react');
9
+ const composeRefs = require('../../utils/compose-refs.cjs');
9
10
  const factory = require('../factory.cjs');
10
11
  const usePresenceContext = require('../presence/use-presence-context.cjs');
11
12
  const useColorPickerContext = require('./use-color-picker-context.cjs');
@@ -16,13 +17,13 @@ const ColorPickerContent = react.forwardRef(
16
17
  const presence = usePresenceContext.usePresenceContext();
17
18
  const mergedProps = react$1.mergeProps(
18
19
  colorPicker.getContentProps(),
19
- presence.getPresenceProps(ref),
20
+ presence.getPresenceProps(),
20
21
  props
21
22
  );
22
23
  if (presence.unmounted) {
23
24
  return null;
24
25
  }
25
- return /* @__PURE__ */ jsxRuntime.jsx(factory.ark.div, { ...mergedProps });
26
+ return /* @__PURE__ */ jsxRuntime.jsx(factory.ark.div, { ...mergedProps, ref: composeRefs.composeRefs(presence.ref, ref) });
26
27
  }
27
28
  );
28
29
  ColorPickerContent.displayName = "ColorPickerContent";
@@ -2,6 +2,7 @@
2
2
  import { jsx } from 'react/jsx-runtime';
3
3
  import { mergeProps } from '@zag-js/react';
4
4
  import { forwardRef } from 'react';
5
+ import { composeRefs } from '../../utils/compose-refs.js';
5
6
  import { ark } from '../factory.js';
6
7
  import { usePresenceContext } from '../presence/use-presence-context.js';
7
8
  import { useColorPickerContext } from './use-color-picker-context.js';
@@ -12,13 +13,13 @@ const ColorPickerContent = forwardRef(
12
13
  const presence = usePresenceContext();
13
14
  const mergedProps = mergeProps(
14
15
  colorPicker.getContentProps(),
15
- presence.getPresenceProps(ref),
16
+ presence.getPresenceProps(),
16
17
  props
17
18
  );
18
19
  if (presence.unmounted) {
19
20
  return null;
20
21
  }
21
- return /* @__PURE__ */ jsx(ark.div, { ...mergedProps });
22
+ return /* @__PURE__ */ jsx(ark.div, { ...mergedProps, ref: composeRefs(presence.ref, ref) });
22
23
  }
23
24
  );
24
25
  ColorPickerContent.displayName = "ColorPickerContent";
@@ -6,6 +6,7 @@ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
6
6
  const jsxRuntime = require('react/jsx-runtime');
7
7
  const react$1 = require('@zag-js/react');
8
8
  const react = require('react');
9
+ const composeRefs = require('../../utils/compose-refs.cjs');
9
10
  const factory = require('../factory.cjs');
10
11
  const usePresenceContext = require('../presence/use-presence-context.cjs');
11
12
  const useComboboxContext = require('./use-combobox-context.cjs');
@@ -13,11 +14,11 @@ const useComboboxContext = require('./use-combobox-context.cjs');
13
14
  const ComboboxContent = react.forwardRef((props, ref) => {
14
15
  const combobox = useComboboxContext.useComboboxContext();
15
16
  const presence = usePresenceContext.usePresenceContext();
16
- const mergedProps = react$1.mergeProps(combobox.getContentProps(), presence.getPresenceProps(ref), props);
17
+ const mergedProps = react$1.mergeProps(combobox.getContentProps(), presence.getPresenceProps(), props);
17
18
  if (presence.unmounted) {
18
19
  return null;
19
20
  }
20
- return /* @__PURE__ */ jsxRuntime.jsx(factory.ark.div, { ...mergedProps });
21
+ return /* @__PURE__ */ jsxRuntime.jsx(factory.ark.div, { ...mergedProps, ref: composeRefs.composeRefs(presence.ref, ref) });
21
22
  });
22
23
  ComboboxContent.displayName = "ComboboxContent";
23
24
 
@@ -2,6 +2,7 @@
2
2
  import { jsx } from 'react/jsx-runtime';
3
3
  import { mergeProps } from '@zag-js/react';
4
4
  import { forwardRef } from 'react';
5
+ import { composeRefs } from '../../utils/compose-refs.js';
5
6
  import { ark } from '../factory.js';
6
7
  import { usePresenceContext } from '../presence/use-presence-context.js';
7
8
  import { useComboboxContext } from './use-combobox-context.js';
@@ -9,11 +10,11 @@ import { useComboboxContext } from './use-combobox-context.js';
9
10
  const ComboboxContent = forwardRef((props, ref) => {
10
11
  const combobox = useComboboxContext();
11
12
  const presence = usePresenceContext();
12
- const mergedProps = mergeProps(combobox.getContentProps(), presence.getPresenceProps(ref), props);
13
+ const mergedProps = mergeProps(combobox.getContentProps(), presence.getPresenceProps(), props);
13
14
  if (presence.unmounted) {
14
15
  return null;
15
16
  }
16
- return /* @__PURE__ */ jsx(ark.div, { ...mergedProps });
17
+ return /* @__PURE__ */ jsx(ark.div, { ...mergedProps, ref: composeRefs(presence.ref, ref) });
17
18
  });
18
19
  ComboboxContent.displayName = "ComboboxContent";
19
20
 
@@ -6,6 +6,7 @@ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
6
6
  const jsxRuntime = require('react/jsx-runtime');
7
7
  const react$1 = require('@zag-js/react');
8
8
  const react = require('react');
9
+ const composeRefs = require('../../utils/compose-refs.cjs');
9
10
  const factory = require('../factory.cjs');
10
11
  const usePresenceContext = require('../presence/use-presence-context.cjs');
11
12
  const useDatePickerContext = require('./use-date-picker-context.cjs');
@@ -14,15 +15,11 @@ const DatePickerContent = react.forwardRef(
14
15
  (props, ref) => {
15
16
  const datePicker = useDatePickerContext.useDatePickerContext();
16
17
  const presence = usePresenceContext.usePresenceContext();
17
- const mergedProps = react$1.mergeProps(
18
- datePicker.getContentProps(),
19
- presence.getPresenceProps(ref),
20
- props
21
- );
18
+ const mergedProps = react$1.mergeProps(datePicker.getContentProps(), presence.getPresenceProps(), props);
22
19
  if (presence.unmounted) {
23
20
  return null;
24
21
  }
25
- return /* @__PURE__ */ jsxRuntime.jsx(factory.ark.div, { ...mergedProps });
22
+ return /* @__PURE__ */ jsxRuntime.jsx(factory.ark.div, { ...mergedProps, ref: composeRefs.composeRefs(presence.ref, ref) });
26
23
  }
27
24
  );
28
25
  DatePickerContent.displayName = "DatePickerContent";
@@ -2,6 +2,7 @@
2
2
  import { jsx } from 'react/jsx-runtime';
3
3
  import { mergeProps } from '@zag-js/react';
4
4
  import { forwardRef } from 'react';
5
+ import { composeRefs } from '../../utils/compose-refs.js';
5
6
  import { ark } from '../factory.js';
6
7
  import { usePresenceContext } from '../presence/use-presence-context.js';
7
8
  import { useDatePickerContext } from './use-date-picker-context.js';
@@ -10,15 +11,11 @@ const DatePickerContent = forwardRef(
10
11
  (props, ref) => {
11
12
  const datePicker = useDatePickerContext();
12
13
  const presence = usePresenceContext();
13
- const mergedProps = mergeProps(
14
- datePicker.getContentProps(),
15
- presence.getPresenceProps(ref),
16
- props
17
- );
14
+ const mergedProps = mergeProps(datePicker.getContentProps(), presence.getPresenceProps(), props);
18
15
  if (presence.unmounted) {
19
16
  return null;
20
17
  }
21
- return /* @__PURE__ */ jsx(ark.div, { ...mergedProps });
18
+ return /* @__PURE__ */ jsx(ark.div, { ...mergedProps, ref: composeRefs(presence.ref, ref) });
22
19
  }
23
20
  );
24
21
  DatePickerContent.displayName = "DatePickerContent";
@@ -6,6 +6,7 @@ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
6
6
  const jsxRuntime = require('react/jsx-runtime');
7
7
  const react$1 = require('@zag-js/react');
8
8
  const react = require('react');
9
+ const composeRefs = require('../../utils/compose-refs.cjs');
9
10
  const renderStrategy = require('../../utils/render-strategy.cjs');
10
11
  const factory = require('../factory.cjs');
11
12
  const usePresence = require('../presence/use-presence.cjs');
@@ -15,11 +16,11 @@ const DialogBackdrop = react.forwardRef((props, ref) => {
15
16
  const dialog = useDialogContext.useDialogContext();
16
17
  const renderStrategyProps = renderStrategy.useRenderStrategyPropsContext();
17
18
  const presence = usePresence.usePresence({ ...renderStrategyProps, present: dialog.open });
18
- const mergedProps = react$1.mergeProps(dialog.getBackdropProps(), presence.getPresenceProps(ref), props);
19
+ const mergedProps = react$1.mergeProps(dialog.getBackdropProps(), presence.getPresenceProps(), props);
19
20
  if (presence.unmounted) {
20
21
  return null;
21
22
  }
22
- return /* @__PURE__ */ jsxRuntime.jsx(factory.ark.div, { ...mergedProps });
23
+ return /* @__PURE__ */ jsxRuntime.jsx(factory.ark.div, { ...mergedProps, ref: composeRefs.composeRefs(presence.ref, ref) });
23
24
  });
24
25
  DialogBackdrop.displayName = "DialogBackdrop";
25
26
 
@@ -2,6 +2,7 @@
2
2
  import { jsx } from 'react/jsx-runtime';
3
3
  import { mergeProps } from '@zag-js/react';
4
4
  import { forwardRef } from 'react';
5
+ import { composeRefs } from '../../utils/compose-refs.js';
5
6
  import { useRenderStrategyPropsContext } from '../../utils/render-strategy.js';
6
7
  import { ark } from '../factory.js';
7
8
  import { usePresence } from '../presence/use-presence.js';
@@ -11,11 +12,11 @@ const DialogBackdrop = forwardRef((props, ref) => {
11
12
  const dialog = useDialogContext();
12
13
  const renderStrategyProps = useRenderStrategyPropsContext();
13
14
  const presence = usePresence({ ...renderStrategyProps, present: dialog.open });
14
- const mergedProps = mergeProps(dialog.getBackdropProps(), presence.getPresenceProps(ref), props);
15
+ const mergedProps = mergeProps(dialog.getBackdropProps(), presence.getPresenceProps(), props);
15
16
  if (presence.unmounted) {
16
17
  return null;
17
18
  }
18
- return /* @__PURE__ */ jsx(ark.div, { ...mergedProps });
19
+ return /* @__PURE__ */ jsx(ark.div, { ...mergedProps, ref: composeRefs(presence.ref, ref) });
19
20
  });
20
21
  DialogBackdrop.displayName = "DialogBackdrop";
21
22
 
@@ -6,6 +6,7 @@ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
6
6
  const jsxRuntime = require('react/jsx-runtime');
7
7
  const react$1 = require('@zag-js/react');
8
8
  const react = require('react');
9
+ const composeRefs = require('../../utils/compose-refs.cjs');
9
10
  const factory = require('../factory.cjs');
10
11
  const usePresenceContext = require('../presence/use-presence-context.cjs');
11
12
  const useDialogContext = require('./use-dialog-context.cjs');
@@ -13,11 +14,11 @@ const useDialogContext = require('./use-dialog-context.cjs');
13
14
  const DialogContent = react.forwardRef((props, ref) => {
14
15
  const dialog = useDialogContext.useDialogContext();
15
16
  const presence = usePresenceContext.usePresenceContext();
16
- const mergedProps = react$1.mergeProps(dialog.getContentProps(), presence.getPresenceProps(ref), props);
17
+ const mergedProps = react$1.mergeProps(dialog.getContentProps(), presence.getPresenceProps(), props);
17
18
  if (presence.unmounted) {
18
19
  return null;
19
20
  }
20
- return /* @__PURE__ */ jsxRuntime.jsx(factory.ark.div, { ...mergedProps });
21
+ return /* @__PURE__ */ jsxRuntime.jsx(factory.ark.div, { ...mergedProps, ref: composeRefs.composeRefs(presence.ref, ref) });
21
22
  });
22
23
  DialogContent.displayName = "DialogContent";
23
24
 
@@ -2,6 +2,7 @@
2
2
  import { jsx } from 'react/jsx-runtime';
3
3
  import { mergeProps } from '@zag-js/react';
4
4
  import { forwardRef } from 'react';
5
+ import { composeRefs } from '../../utils/compose-refs.js';
5
6
  import { ark } from '../factory.js';
6
7
  import { usePresenceContext } from '../presence/use-presence-context.js';
7
8
  import { useDialogContext } from './use-dialog-context.js';
@@ -9,11 +10,11 @@ import { useDialogContext } from './use-dialog-context.js';
9
10
  const DialogContent = forwardRef((props, ref) => {
10
11
  const dialog = useDialogContext();
11
12
  const presence = usePresenceContext();
12
- const mergedProps = mergeProps(dialog.getContentProps(), presence.getPresenceProps(ref), props);
13
+ const mergedProps = mergeProps(dialog.getContentProps(), presence.getPresenceProps(), props);
13
14
  if (presence.unmounted) {
14
15
  return null;
15
16
  }
16
- return /* @__PURE__ */ jsx(ark.div, { ...mergedProps });
17
+ return /* @__PURE__ */ jsx(ark.div, { ...mergedProps, ref: composeRefs(presence.ref, ref) });
17
18
  });
18
19
  DialogContent.displayName = "DialogContent";
19
20
 
@@ -6,10 +6,18 @@ const core = require('@zag-js/core');
6
6
  const react = require('react');
7
7
  const composeRefs = require('../utils/compose-refs.cjs');
8
8
 
9
- function getRef(child) {
10
- if ("ref" in child.props) return child.props.ref;
11
- if ("ref" in child) return child.ref;
12
- return null;
9
+ function getRef(element) {
10
+ let getter = Object.getOwnPropertyDescriptor(element.props, "ref")?.get;
11
+ let mayWarn = getter && "isReactWarning" in getter && getter.isReactWarning;
12
+ if (mayWarn) {
13
+ return element.ref;
14
+ }
15
+ getter = Object.getOwnPropertyDescriptor(element, "ref")?.get;
16
+ mayWarn = getter && "isReactWarning" in getter && getter.isReactWarning;
17
+ if (mayWarn) {
18
+ return element.props.ref;
19
+ }
20
+ return element.props.ref || element.ref;
13
21
  }
14
22
  const withAsChild = (Component) => {
15
23
  const Comp = react.memo(
@@ -2,10 +2,18 @@ import { mergeProps } from '@zag-js/core';
2
2
  import { memo, forwardRef, createElement, Children, isValidElement, cloneElement } from 'react';
3
3
  import { composeRefs } from '../utils/compose-refs.js';
4
4
 
5
- function getRef(child) {
6
- if ("ref" in child.props) return child.props.ref;
7
- if ("ref" in child) return child.ref;
8
- return null;
5
+ function getRef(element) {
6
+ let getter = Object.getOwnPropertyDescriptor(element.props, "ref")?.get;
7
+ let mayWarn = getter && "isReactWarning" in getter && getter.isReactWarning;
8
+ if (mayWarn) {
9
+ return element.ref;
10
+ }
11
+ getter = Object.getOwnPropertyDescriptor(element, "ref")?.get;
12
+ mayWarn = getter && "isReactWarning" in getter && getter.isReactWarning;
13
+ if (mayWarn) {
14
+ return element.props.ref;
15
+ }
16
+ return element.props.ref || element.ref;
9
17
  }
10
18
  const withAsChild = (Component) => {
11
19
  const Comp = memo(
@@ -4,14 +4,14 @@
4
4
  Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
5
5
 
6
6
  const jsxRuntime = require('react/jsx-runtime');
7
- const core = require('@zag-js/core');
7
+ const react$1 = require('@zag-js/react');
8
8
  const react = require('react');
9
9
  const factory = require('../factory.cjs');
10
10
  const useFieldContext = require('./use-field-context.cjs');
11
11
 
12
12
  const FieldTextarea = react.forwardRef((props, ref) => {
13
13
  const field = useFieldContext.useFieldContext();
14
- const mergedProps = core.mergeProps(field?.getTextareaProps(), props);
14
+ const mergedProps = react$1.mergeProps(field?.getTextareaProps(), props);
15
15
  return /* @__PURE__ */ jsxRuntime.jsx(factory.ark.textarea, { ...mergedProps, ref });
16
16
  });
17
17
  FieldTextarea.displayName = "FieldTextarea";
@@ -1,6 +1,6 @@
1
1
  'use client';
2
2
  import { jsx } from 'react/jsx-runtime';
3
- import { mergeProps } from '@zag-js/core';
3
+ import { mergeProps } from '@zag-js/react';
4
4
  import { forwardRef } from 'react';
5
5
  import { ark } from '../factory.js';
6
6
  import { useFieldContext } from './use-field-context.js';
@@ -16,7 +16,7 @@ const FileUploadItemPreviewImage = react.forwardRef((props, ref) => {
16
16
  const itemProps = useFileUploadItemPropsContext.useFileUploadItemPropsContext();
17
17
  const mergedProps = react$1.mergeProps(fileUpload.getItemPreviewImageProps({ ...itemProps, url }), props);
18
18
  react.useEffect(() => {
19
- fileUpload.createFileUrl(itemProps.file, (url2) => setUrl(url2));
19
+ return fileUpload.createFileUrl(itemProps.file, (url2) => setUrl(url2));
20
20
  }, [itemProps, fileUpload]);
21
21
  return /* @__PURE__ */ jsxRuntime.jsx(factory.ark.img, { ...mergedProps, ref });
22
22
  });
@@ -12,7 +12,7 @@ const FileUploadItemPreviewImage = forwardRef((props, ref) => {
12
12
  const itemProps = useFileUploadItemPropsContext();
13
13
  const mergedProps = mergeProps(fileUpload.getItemPreviewImageProps({ ...itemProps, url }), props);
14
14
  useEffect(() => {
15
- fileUpload.createFileUrl(itemProps.file, (url2) => setUrl(url2));
15
+ return fileUpload.createFileUrl(itemProps.file, (url2) => setUrl(url2));
16
16
  }, [itemProps, fileUpload]);
17
17
  return /* @__PURE__ */ jsx(ark.img, { ...mergedProps, ref });
18
18
  });
@@ -6,6 +6,7 @@ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
6
6
  const jsxRuntime = require('react/jsx-runtime');
7
7
  const react$1 = require('@zag-js/react');
8
8
  const react = require('react');
9
+ const composeRefs = require('../../utils/compose-refs.cjs');
9
10
  const factory = require('../factory.cjs');
10
11
  const usePresenceContext = require('../presence/use-presence-context.cjs');
11
12
  const useHoverCardContext = require('./use-hover-card-context.cjs');
@@ -13,11 +14,11 @@ const useHoverCardContext = require('./use-hover-card-context.cjs');
13
14
  const HoverCardContent = react.forwardRef((props, ref) => {
14
15
  const hoverCard = useHoverCardContext.useHoverCardContext();
15
16
  const presence = usePresenceContext.usePresenceContext();
16
- const mergedProps = react$1.mergeProps(hoverCard.getContentProps(), presence.getPresenceProps(ref), props);
17
+ const mergedProps = react$1.mergeProps(hoverCard.getContentProps(), presence.getPresenceProps(), props);
17
18
  if (presence.unmounted) {
18
19
  return null;
19
20
  }
20
- return /* @__PURE__ */ jsxRuntime.jsx(factory.ark.div, { ...mergedProps });
21
+ return /* @__PURE__ */ jsxRuntime.jsx(factory.ark.div, { ...mergedProps, ref: composeRefs.composeRefs(presence.ref, ref) });
21
22
  });
22
23
  HoverCardContent.displayName = "HoverCardContent";
23
24
 
@@ -2,6 +2,7 @@
2
2
  import { jsx } from 'react/jsx-runtime';
3
3
  import { mergeProps } from '@zag-js/react';
4
4
  import { forwardRef } from 'react';
5
+ import { composeRefs } from '../../utils/compose-refs.js';
5
6
  import { ark } from '../factory.js';
6
7
  import { usePresenceContext } from '../presence/use-presence-context.js';
7
8
  import { useHoverCardContext } from './use-hover-card-context.js';
@@ -9,11 +10,11 @@ import { useHoverCardContext } from './use-hover-card-context.js';
9
10
  const HoverCardContent = forwardRef((props, ref) => {
10
11
  const hoverCard = useHoverCardContext();
11
12
  const presence = usePresenceContext();
12
- const mergedProps = mergeProps(hoverCard.getContentProps(), presence.getPresenceProps(ref), props);
13
+ const mergedProps = mergeProps(hoverCard.getContentProps(), presence.getPresenceProps(), props);
13
14
  if (presence.unmounted) {
14
15
  return null;
15
16
  }
16
- return /* @__PURE__ */ jsx(ark.div, { ...mergedProps });
17
+ return /* @__PURE__ */ jsx(ark.div, { ...mergedProps, ref: composeRefs(presence.ref, ref) });
17
18
  });
18
19
  HoverCardContent.displayName = "HoverCardContent";
19
20
 
@@ -535,6 +535,13 @@ const toastTitle = require('./toast/toast-title.cjs');
535
535
  const toaster = require('./toast/toaster.cjs');
536
536
  const useToastContext = require('./toast/use-toast-context.cjs');
537
537
  const toast$1 = require('./toast/toast.cjs');
538
+ const toggleContext = require('./toggle/toggle-context.cjs');
539
+ const toggleIndicator = require('./toggle/toggle-indicator.cjs');
540
+ const toggleRoot = require('./toggle/toggle-root.cjs');
541
+ const toggle_anatomy = require('./toggle/toggle.anatomy.cjs');
542
+ const useToggle = require('./toggle/use-toggle.cjs');
543
+ const useToggleContext = require('./toggle/use-toggle-context.cjs');
544
+ const toggle = require('./toggle/toggle.cjs');
538
545
  const toggleGroupContext = require('./toggle-group/toggle-group-context.cjs');
539
546
  const toggleGroupItem = require('./toggle-group/toggle-group-item.cjs');
540
547
  const toggleGroupRoot = require('./toggle-group/toggle-group-root.cjs');
@@ -1147,6 +1154,13 @@ exports.ToastTitle = toastTitle.ToastTitle;
1147
1154
  exports.Toaster = toaster.Toaster;
1148
1155
  exports.useToastContext = useToastContext.useToastContext;
1149
1156
  exports.Toast = toast$1;
1157
+ exports.ToggleContext = toggleContext.ToggleContext;
1158
+ exports.ToggleIndicator = toggleIndicator.ToggleIndicator;
1159
+ exports.ToggleRoot = toggleRoot.ToggleRoot;
1160
+ exports.toggleAnatomy = toggle_anatomy.toggleAnatomy;
1161
+ exports.useToggle = useToggle.useToggle;
1162
+ exports.useToggleContext = useToggleContext.useToggleContext;
1163
+ exports.Toggle = toggle;
1150
1164
  exports.ToggleGroupContext = toggleGroupContext.ToggleGroupContext;
1151
1165
  exports.ToggleGroupItem = toggleGroupItem.ToggleGroupItem;
1152
1166
  exports.ToggleGroupRoot = toggleGroupRoot.ToggleGroupRoot;
@@ -40,6 +40,7 @@ export * from './tags-input';
40
40
  export * from './time-picker';
41
41
  export * from './timer';
42
42
  export * from './toast';
43
+ export * from './toggle';
43
44
  export * from './toggle-group';
44
45
  export * from './tooltip';
45
46
  export * from './tree-view';
@@ -40,6 +40,7 @@ export * from './tags-input';
40
40
  export * from './time-picker';
41
41
  export * from './timer';
42
42
  export * from './toast';
43
+ export * from './toggle';
43
44
  export * from './toggle-group';
44
45
  export * from './tooltip';
45
46
  export * from './tree-view';
@@ -568,6 +568,14 @@ export { Toaster } from './toast/toaster.js';
568
568
  export { useToastContext } from './toast/use-toast-context.js';
569
569
  import * as toast from './toast/toast.js';
570
570
  export { toast as Toast };
571
+ export { ToggleContext } from './toggle/toggle-context.js';
572
+ export { ToggleIndicator } from './toggle/toggle-indicator.js';
573
+ export { ToggleRoot } from './toggle/toggle-root.js';
574
+ export { toggleAnatomy } from './toggle/toggle.anatomy.js';
575
+ export { useToggle } from './toggle/use-toggle.js';
576
+ export { useToggleContext } from './toggle/use-toggle-context.js';
577
+ import * as toggle from './toggle/toggle.js';
578
+ export { toggle as Toggle };
571
579
  export { ToggleGroupContext } from './toggle-group/toggle-group-context.js';
572
580
  export { ToggleGroupItem } from './toggle-group/toggle-group-item.js';
573
581
  export { ToggleGroupRoot } from './toggle-group/toggle-group-root.js';
@@ -6,6 +6,7 @@ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
6
6
  const jsxRuntime = require('react/jsx-runtime');
7
7
  const react$1 = require('@zag-js/react');
8
8
  const react = require('react');
9
+ const composeRefs = require('../../utils/compose-refs.cjs');
9
10
  const factory = require('../factory.cjs');
10
11
  const usePresenceContext = require('../presence/use-presence-context.cjs');
11
12
  const useMenuContext = require('./use-menu-context.cjs');
@@ -13,11 +14,11 @@ const useMenuContext = require('./use-menu-context.cjs');
13
14
  const MenuContent = react.forwardRef((props, ref) => {
14
15
  const menu = useMenuContext.useMenuContext();
15
16
  const presence = usePresenceContext.usePresenceContext();
16
- const mergedProps = react$1.mergeProps(menu.getContentProps(), presence.getPresenceProps(ref), props);
17
+ const mergedProps = react$1.mergeProps(menu.getContentProps(), presence.getPresenceProps(), props);
17
18
  if (presence.unmounted) {
18
19
  return null;
19
20
  }
20
- return /* @__PURE__ */ jsxRuntime.jsx(factory.ark.div, { ...mergedProps });
21
+ return /* @__PURE__ */ jsxRuntime.jsx(factory.ark.div, { ...mergedProps, ref: composeRefs.composeRefs(presence.ref, ref) });
21
22
  });
22
23
  MenuContent.displayName = "MenuContent";
23
24
 
@@ -2,6 +2,7 @@
2
2
  import { jsx } from 'react/jsx-runtime';
3
3
  import { mergeProps } from '@zag-js/react';
4
4
  import { forwardRef } from 'react';
5
+ import { composeRefs } from '../../utils/compose-refs.js';
5
6
  import { ark } from '../factory.js';
6
7
  import { usePresenceContext } from '../presence/use-presence-context.js';
7
8
  import { useMenuContext } from './use-menu-context.js';
@@ -9,11 +10,11 @@ import { useMenuContext } from './use-menu-context.js';
9
10
  const MenuContent = forwardRef((props, ref) => {
10
11
  const menu = useMenuContext();
11
12
  const presence = usePresenceContext();
12
- const mergedProps = mergeProps(menu.getContentProps(), presence.getPresenceProps(ref), props);
13
+ const mergedProps = mergeProps(menu.getContentProps(), presence.getPresenceProps(), props);
13
14
  if (presence.unmounted) {
14
15
  return null;
15
16
  }
16
- return /* @__PURE__ */ jsx(ark.div, { ...mergedProps });
17
+ return /* @__PURE__ */ jsx(ark.div, { ...mergedProps, ref: composeRefs(presence.ref, ref) });
17
18
  });
18
19
  MenuContent.displayName = "MenuContent";
19
20
 
@@ -6,6 +6,7 @@ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
6
6
  const jsxRuntime = require('react/jsx-runtime');
7
7
  const react$1 = require('@zag-js/react');
8
8
  const react = require('react');
9
+ const composeRefs = require('../../utils/compose-refs.cjs');
9
10
  const factory = require('../factory.cjs');
10
11
  const usePresenceContext = require('../presence/use-presence-context.cjs');
11
12
  const usePopoverContext = require('./use-popover-context.cjs');
@@ -13,11 +14,11 @@ const usePopoverContext = require('./use-popover-context.cjs');
13
14
  const PopoverContent = react.forwardRef((props, ref) => {
14
15
  const popover = usePopoverContext.usePopoverContext();
15
16
  const presence = usePresenceContext.usePresenceContext();
16
- const mergedProps = react$1.mergeProps(popover.getContentProps(), presence.getPresenceProps(ref), props);
17
+ const mergedProps = react$1.mergeProps(popover.getContentProps(), presence.getPresenceProps(), props);
17
18
  if (presence.unmounted) {
18
19
  return null;
19
20
  }
20
- return /* @__PURE__ */ jsxRuntime.jsx(factory.ark.div, { ...mergedProps });
21
+ return /* @__PURE__ */ jsxRuntime.jsx(factory.ark.div, { ...mergedProps, ref: composeRefs.composeRefs(presence.ref, ref) });
21
22
  });
22
23
  PopoverContent.displayName = "PopoverContent";
23
24
 
@@ -2,6 +2,7 @@
2
2
  import { jsx } from 'react/jsx-runtime';
3
3
  import { mergeProps } from '@zag-js/react';
4
4
  import { forwardRef } from 'react';
5
+ import { composeRefs } from '../../utils/compose-refs.js';
5
6
  import { ark } from '../factory.js';
6
7
  import { usePresenceContext } from '../presence/use-presence-context.js';
7
8
  import { usePopoverContext } from './use-popover-context.js';
@@ -9,11 +10,11 @@ import { usePopoverContext } from './use-popover-context.js';
9
10
  const PopoverContent = forwardRef((props, ref) => {
10
11
  const popover = usePopoverContext();
11
12
  const presence = usePresenceContext();
12
- const mergedProps = mergeProps(popover.getContentProps(), presence.getPresenceProps(ref), props);
13
+ const mergedProps = mergeProps(popover.getContentProps(), presence.getPresenceProps(), props);
13
14
  if (presence.unmounted) {
14
15
  return null;
15
16
  }
16
- return /* @__PURE__ */ jsx(ark.div, { ...mergedProps });
17
+ return /* @__PURE__ */ jsx(ark.div, { ...mergedProps, ref: composeRefs(presence.ref, ref) });
17
18
  });
18
19
  PopoverContent.displayName = "PopoverContent";
19
20
 
@@ -4,6 +4,7 @@ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
4
4
 
5
5
  const jsxRuntime = require('react/jsx-runtime');
6
6
  const react = require('react');
7
+ const composeRefs = require('../../utils/compose-refs.cjs');
7
8
  const factory = require('../factory.cjs');
8
9
  const splitPresenceProps = require('./split-presence-props.cjs');
9
10
  const usePresence = require('./use-presence.cjs');
@@ -18,9 +19,10 @@ const Presence = react.forwardRef((props, ref) => {
18
19
  factory.ark.div,
19
20
  {
20
21
  ...localProps,
21
- ...presence.getPresenceProps(ref),
22
+ ...presence.getPresenceProps(),
22
23
  "data-scope": "presence",
23
- "data-part": "root"
24
+ "data-part": "root",
25
+ ref: composeRefs.composeRefs(presence.ref, ref)
24
26
  }
25
27
  );
26
28
  });
@@ -1,5 +1,6 @@
1
1
  import { jsx } from 'react/jsx-runtime';
2
2
  import { forwardRef } from 'react';
3
+ import { composeRefs } from '../../utils/compose-refs.js';
3
4
  import { ark } from '../factory.js';
4
5
  import { splitPresenceProps } from './split-presence-props.js';
5
6
  import { usePresence } from './use-presence.js';
@@ -14,9 +15,10 @@ const Presence = forwardRef((props, ref) => {
14
15
  ark.div,
15
16
  {
16
17
  ...localProps,
17
- ...presence.getPresenceProps(ref),
18
+ ...presence.getPresenceProps(),
18
19
  "data-scope": "presence",
19
- "data-part": "root"
20
+ "data-part": "root",
21
+ ref: composeRefs(presence.ref, ref)
20
22
  }
21
23
  );
22
24
  });
@@ -6,7 +6,6 @@ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
6
6
  const presence = require('@zag-js/presence');
7
7
  const react$1 = require('@zag-js/react');
8
8
  const react = require('react');
9
- const composeRefs = require('../../utils/compose-refs.cjs');
10
9
  const useEvent = require('../../utils/use-event.cjs');
11
10
 
12
11
  function _interopNamespaceDefault(e) {
@@ -41,12 +40,12 @@ const usePresence = (props) => {
41
40
  wasEverPresent.current = true;
42
41
  }
43
42
  const unmounted = !api.present && !wasEverPresent.current && lazyMount || unmountOnExit && !api.present && wasEverPresent.current;
44
- const getPresenceProps = (ref) => ({
45
- ref: composeRefs.composeRefs(api.setNode, ref),
43
+ const getPresenceProps = () => ({
46
44
  "data-state": props.present ? "open" : "closed",
47
45
  hidden: !api.present
48
46
  });
49
47
  return {
48
+ ref: api.setNode,
50
49
  getPresenceProps,
51
50
  present: api.present,
52
51
  unmounted
@@ -1,4 +1,3 @@
1
- import { ForwardedRef } from 'react';
2
1
  import { Optional } from '../../types';
3
2
  import { RenderStrategyProps } from '../../utils/render-strategy';
4
3
  import * as presence from '@zag-js/presence';
@@ -6,8 +5,8 @@ export interface UsePresenceProps extends Optional<presence.Context, 'present'>,
6
5
  }
7
6
  export type UsePresenceReturn = ReturnType<typeof usePresence>;
8
7
  export declare const usePresence: (props: UsePresenceProps) => {
9
- getPresenceProps: <T extends HTMLElement>(ref: ForwardedRef<T>) => {
10
- ref: ForwardedRef<T>;
8
+ ref: (node: HTMLElement | null) => void;
9
+ getPresenceProps: () => {
11
10
  'data-state': string;
12
11
  hidden: boolean;
13
12
  };
@@ -1,4 +1,3 @@
1
- import { ForwardedRef } from 'react';
2
1
  import { Optional } from '../../types';
3
2
  import { RenderStrategyProps } from '../../utils/render-strategy';
4
3
  import * as presence from '@zag-js/presence';
@@ -6,8 +5,8 @@ export interface UsePresenceProps extends Optional<presence.Context, 'present'>,
6
5
  }
7
6
  export type UsePresenceReturn = ReturnType<typeof usePresence>;
8
7
  export declare const usePresence: (props: UsePresenceProps) => {
9
- getPresenceProps: <T extends HTMLElement>(ref: ForwardedRef<T>) => {
10
- ref: ForwardedRef<T>;
8
+ ref: (node: HTMLElement | null) => void;
9
+ getPresenceProps: () => {
11
10
  'data-state': string;
12
11
  hidden: boolean;
13
12
  };