@ark-ui/react 4.0.0 → 4.1.1
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.
- package/dist/components/accordion/accordion-item.cjs +1 -0
- package/dist/components/accordion/accordion-item.js +1 -0
- package/dist/components/color-picker/color-picker-content.cjs +3 -2
- package/dist/components/color-picker/color-picker-content.js +3 -2
- package/dist/components/combobox/combobox-content.cjs +3 -2
- package/dist/components/combobox/combobox-content.js +3 -2
- package/dist/components/date-picker/date-picker-content.cjs +3 -6
- package/dist/components/date-picker/date-picker-content.js +3 -6
- package/dist/components/dialog/dialog-backdrop.cjs +3 -2
- package/dist/components/dialog/dialog-backdrop.js +3 -2
- package/dist/components/dialog/dialog-content.cjs +3 -2
- package/dist/components/dialog/dialog-content.js +3 -2
- package/dist/components/factory.cjs +12 -4
- package/dist/components/factory.js +12 -4
- package/dist/components/field/field-textarea.cjs +2 -2
- package/dist/components/field/field-textarea.js +1 -1
- package/dist/components/file-upload/file-upload-item-preview-image.cjs +1 -1
- package/dist/components/file-upload/file-upload-item-preview-image.js +1 -1
- package/dist/components/hover-card/hover-card-content.cjs +3 -2
- package/dist/components/hover-card/hover-card-content.js +3 -2
- package/dist/components/index.cjs +19 -0
- package/dist/components/index.d.cts +1 -0
- package/dist/components/index.d.ts +1 -0
- package/dist/components/index.js +9 -0
- package/dist/components/menu/menu-content.cjs +3 -2
- package/dist/components/menu/menu-content.js +3 -2
- package/dist/components/popover/popover-content.cjs +3 -2
- package/dist/components/popover/popover-content.js +3 -2
- package/dist/components/presence/presence.cjs +4 -2
- package/dist/components/presence/presence.js +4 -2
- package/dist/components/presence/use-presence.cjs +2 -3
- package/dist/components/presence/use-presence.d.cts +2 -3
- package/dist/components/presence/use-presence.d.ts +2 -3
- package/dist/components/presence/use-presence.js +2 -3
- package/dist/components/select/select-content.cjs +3 -2
- package/dist/components/select/select-content.js +3 -2
- package/dist/components/tabs/tab-content.cjs +3 -2
- package/dist/components/tabs/tab-content.js +3 -2
- package/dist/components/time-picker/index.cjs +5 -0
- package/dist/components/time-picker/index.d.cts +1 -0
- package/dist/components/time-picker/index.d.ts +1 -0
- package/dist/components/time-picker/index.js +1 -0
- package/dist/components/time-picker/time-picker-content.cjs +3 -6
- package/dist/components/time-picker/time-picker-content.js +3 -6
- package/dist/components/time-picker/use-time-picker.cjs +3 -8
- package/dist/components/time-picker/use-time-picker.d.cts +2 -14
- package/dist/components/time-picker/use-time-picker.d.ts +2 -14
- package/dist/components/time-picker/use-time-picker.js +3 -8
- package/dist/components/toggle/index.cjs +21 -0
- package/dist/components/toggle/index.d.cts +7 -0
- package/dist/components/toggle/index.d.ts +7 -0
- package/dist/components/toggle/index.js +8 -0
- package/dist/components/toggle/toggle-context.cjs +10 -0
- package/dist/components/toggle/toggle-context.d.cts +6 -0
- package/dist/components/toggle/toggle-context.d.ts +6 -0
- package/dist/components/toggle/toggle-context.js +6 -0
- package/dist/components/toggle/toggle-indicator.cjs +20 -0
- package/dist/components/toggle/toggle-indicator.d.cts +11 -0
- package/dist/components/toggle/toggle-indicator.d.ts +11 -0
- package/dist/components/toggle/toggle-indicator.js +16 -0
- package/dist/components/toggle/toggle-root.cjs +27 -0
- package/dist/components/toggle/toggle-root.d.cts +8 -0
- package/dist/components/toggle/toggle-root.d.ts +8 -0
- package/dist/components/toggle/toggle-root.js +23 -0
- package/dist/components/toggle/toggle.anatomy.cjs +12 -0
- package/dist/components/toggle/toggle.anatomy.d.cts +3 -0
- package/dist/components/toggle/toggle.anatomy.d.ts +3 -0
- package/dist/components/toggle/toggle.anatomy.js +7 -0
- package/dist/components/toggle/toggle.cjs +15 -0
- package/dist/components/toggle/toggle.d.cts +4 -0
- package/dist/components/toggle/toggle.d.ts +4 -0
- package/dist/components/toggle/toggle.js +4 -0
- package/dist/components/toggle/use-toggle-context.cjs +15 -0
- package/dist/components/toggle/use-toggle-context.d.cts +5 -0
- package/dist/components/toggle/use-toggle-context.d.ts +5 -0
- package/dist/components/toggle/use-toggle-context.js +10 -0
- package/dist/components/toggle/use-toggle.cjs +48 -0
- package/dist/components/toggle/use-toggle.d.cts +35 -0
- package/dist/components/toggle/use-toggle.d.ts +35 -0
- package/dist/components/toggle/use-toggle.js +44 -0
- package/dist/components/tooltip/tooltip-content.cjs +3 -2
- package/dist/components/tooltip/tooltip-content.js +3 -2
- package/dist/index.cjs +19 -0
- package/dist/index.js +9 -0
- package/dist/utils/compose-refs.d.cts +2 -2
- package/dist/utils/compose-refs.d.ts +2 -2
- package/package.json +78 -71
|
@@ -12,6 +12,7 @@ const useAccordionItemContext = require('./use-accordion-item-context.cjs');
|
|
|
12
12
|
const collapsibleRoot = require('../collapsible/collapsible-root.cjs');
|
|
13
13
|
require('@zag-js/color-picker');
|
|
14
14
|
require('@zag-js/date-picker');
|
|
15
|
+
require('@internationalized/date');
|
|
15
16
|
const renderStrategy = require('../../utils/render-strategy.cjs');
|
|
16
17
|
const useAccordionItemPropsContext = require('./use-accordion-item-props-context.cjs');
|
|
17
18
|
|
|
@@ -8,6 +8,7 @@ import { AccordionItemProvider } from './use-accordion-item-context.js';
|
|
|
8
8
|
import { CollapsibleRoot } from '../collapsible/collapsible-root.js';
|
|
9
9
|
import '@zag-js/color-picker';
|
|
10
10
|
import '@zag-js/date-picker';
|
|
11
|
+
import '@internationalized/date';
|
|
11
12
|
import { useRenderStrategyPropsContext } from '../../utils/render-strategy.js';
|
|
12
13
|
import { AccordionItemPropsProvider } from './use-accordion-item-props-context.js';
|
|
13
14
|
|
|
@@ -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(
|
|
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(
|
|
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(
|
|
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(
|
|
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(
|
|
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(
|
|
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(
|
|
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(
|
|
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(
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
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(
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
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
|
|
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 =
|
|
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/
|
|
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(
|
|
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(
|
|
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
|
|
|
@@ -498,6 +498,7 @@ const useTagsInput = require('./tags-input/use-tags-input.cjs');
|
|
|
498
498
|
const useTagsInputContext = require('./tags-input/use-tags-input-context.cjs');
|
|
499
499
|
const useTagsInputItemContext = require('./tags-input/use-tags-input-item-context.cjs');
|
|
500
500
|
const tagsInput$1 = require('./tags-input/tags-input.cjs');
|
|
501
|
+
const date = require('@internationalized/date');
|
|
501
502
|
const timePickerCell = require('./time-picker/time-picker-cell.cjs');
|
|
502
503
|
const timePickerClearTrigger = require('./time-picker/time-picker-clear-trigger.cjs');
|
|
503
504
|
const timePickerColumn = require('./time-picker/time-picker-column.cjs');
|
|
@@ -535,6 +536,13 @@ const toastTitle = require('./toast/toast-title.cjs');
|
|
|
535
536
|
const toaster = require('./toast/toaster.cjs');
|
|
536
537
|
const useToastContext = require('./toast/use-toast-context.cjs');
|
|
537
538
|
const toast$1 = require('./toast/toast.cjs');
|
|
539
|
+
const toggleContext = require('./toggle/toggle-context.cjs');
|
|
540
|
+
const toggleIndicator = require('./toggle/toggle-indicator.cjs');
|
|
541
|
+
const toggleRoot = require('./toggle/toggle-root.cjs');
|
|
542
|
+
const toggle_anatomy = require('./toggle/toggle.anatomy.cjs');
|
|
543
|
+
const useToggle = require('./toggle/use-toggle.cjs');
|
|
544
|
+
const useToggleContext = require('./toggle/use-toggle-context.cjs');
|
|
545
|
+
const toggle = require('./toggle/toggle.cjs');
|
|
538
546
|
const toggleGroupContext = require('./toggle-group/toggle-group-context.cjs');
|
|
539
547
|
const toggleGroupItem = require('./toggle-group/toggle-group-item.cjs');
|
|
540
548
|
const toggleGroupRoot = require('./toggle-group/toggle-group-root.cjs');
|
|
@@ -1110,6 +1118,10 @@ exports.useTagsInput = useTagsInput.useTagsInput;
|
|
|
1110
1118
|
exports.useTagsInputContext = useTagsInputContext.useTagsInputContext;
|
|
1111
1119
|
exports.useTagsInputItemContext = useTagsInputItemContext.useTagsInputItemContext;
|
|
1112
1120
|
exports.TagsInput = tagsInput$1;
|
|
1121
|
+
Object.defineProperty(exports, "parseTime", {
|
|
1122
|
+
enumerable: true,
|
|
1123
|
+
get: () => date.parseTime
|
|
1124
|
+
});
|
|
1113
1125
|
exports.TimePickerCell = timePickerCell.TimePickerCell;
|
|
1114
1126
|
exports.TimePickerClearTrigger = timePickerClearTrigger.TimePickerClearTrigger;
|
|
1115
1127
|
exports.TimePickerColumn = timePickerColumn.TimePickerColumn;
|
|
@@ -1147,6 +1159,13 @@ exports.ToastTitle = toastTitle.ToastTitle;
|
|
|
1147
1159
|
exports.Toaster = toaster.Toaster;
|
|
1148
1160
|
exports.useToastContext = useToastContext.useToastContext;
|
|
1149
1161
|
exports.Toast = toast$1;
|
|
1162
|
+
exports.ToggleContext = toggleContext.ToggleContext;
|
|
1163
|
+
exports.ToggleIndicator = toggleIndicator.ToggleIndicator;
|
|
1164
|
+
exports.ToggleRoot = toggleRoot.ToggleRoot;
|
|
1165
|
+
exports.toggleAnatomy = toggle_anatomy.toggleAnatomy;
|
|
1166
|
+
exports.useToggle = useToggle.useToggle;
|
|
1167
|
+
exports.useToggleContext = useToggleContext.useToggleContext;
|
|
1168
|
+
exports.Toggle = toggle;
|
|
1150
1169
|
exports.ToggleGroupContext = toggleGroupContext.ToggleGroupContext;
|
|
1151
1170
|
exports.ToggleGroupItem = toggleGroupItem.ToggleGroupItem;
|
|
1152
1171
|
exports.ToggleGroupRoot = toggleGroupRoot.ToggleGroupRoot;
|
package/dist/components/index.js
CHANGED
|
@@ -528,6 +528,7 @@ export { useTagsInputContext } from './tags-input/use-tags-input-context.js';
|
|
|
528
528
|
export { useTagsInputItemContext } from './tags-input/use-tags-input-item-context.js';
|
|
529
529
|
import * as tagsInput from './tags-input/tags-input.js';
|
|
530
530
|
export { tagsInput as TagsInput };
|
|
531
|
+
export { parseTime } from '@internationalized/date';
|
|
531
532
|
export { TimePickerCell } from './time-picker/time-picker-cell.js';
|
|
532
533
|
export { TimePickerClearTrigger } from './time-picker/time-picker-clear-trigger.js';
|
|
533
534
|
export { TimePickerColumn } from './time-picker/time-picker-column.js';
|
|
@@ -568,6 +569,14 @@ export { Toaster } from './toast/toaster.js';
|
|
|
568
569
|
export { useToastContext } from './toast/use-toast-context.js';
|
|
569
570
|
import * as toast from './toast/toast.js';
|
|
570
571
|
export { toast as Toast };
|
|
572
|
+
export { ToggleContext } from './toggle/toggle-context.js';
|
|
573
|
+
export { ToggleIndicator } from './toggle/toggle-indicator.js';
|
|
574
|
+
export { ToggleRoot } from './toggle/toggle-root.js';
|
|
575
|
+
export { toggleAnatomy } from './toggle/toggle.anatomy.js';
|
|
576
|
+
export { useToggle } from './toggle/use-toggle.js';
|
|
577
|
+
export { useToggleContext } from './toggle/use-toggle-context.js';
|
|
578
|
+
import * as toggle from './toggle/toggle.js';
|
|
579
|
+
export { toggle as Toggle };
|
|
571
580
|
export { ToggleGroupContext } from './toggle-group/toggle-group-context.js';
|
|
572
581
|
export { ToggleGroupItem } from './toggle-group/toggle-group-item.js';
|
|
573
582
|
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(
|
|
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(
|
|
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(
|
|
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(
|
|
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(
|
|
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(
|
|
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
|
});
|