@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
@@ -0,0 +1,44 @@
1
+ 'use client';
2
+ import { dataAttr } from '@zag-js/dom-query';
3
+ import { useControllableState } from '../../utils/use-controllable-state.js';
4
+ import { parts } from './toggle.anatomy.js';
5
+
6
+ function useToggle(props) {
7
+ const { defaultPressed, pressed, onPressedChange, disabled } = props;
8
+ const [pressedState, setPressedState] = useControllableState({
9
+ defaultValue: !!defaultPressed,
10
+ value: pressed,
11
+ onChange: onPressedChange
12
+ });
13
+ return {
14
+ pressed: pressedState,
15
+ disabled: !!disabled,
16
+ setPressed: setPressedState,
17
+ getRootProps() {
18
+ return {
19
+ ...parts.root.attrs,
20
+ type: "button",
21
+ disabled,
22
+ "aria-pressed": pressedState,
23
+ "data-state": pressedState ? "on" : "off",
24
+ "data-pressed": dataAttr(pressedState),
25
+ "data-disabled": dataAttr(disabled),
26
+ onClick(event) {
27
+ if (event.defaultPrevented) return;
28
+ if (disabled) return;
29
+ setPressedState(!pressedState);
30
+ }
31
+ };
32
+ },
33
+ getIndicatorProps() {
34
+ return {
35
+ ...parts.indicator.attrs,
36
+ "data-disabled": dataAttr(disabled),
37
+ "data-pressed": dataAttr(pressedState),
38
+ "data-state": pressedState ? "on" : "off"
39
+ };
40
+ }
41
+ };
42
+ }
43
+
44
+ export { useToggle };
@@ -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 useTooltipContext = require('./use-tooltip-context.cjs');
@@ -13,11 +14,11 @@ const useTooltipContext = require('./use-tooltip-context.cjs');
13
14
  const TooltipContent = react.forwardRef((props, ref) => {
14
15
  const tooltip = useTooltipContext.useTooltipContext();
15
16
  const presence = usePresenceContext.usePresenceContext();
16
- const mergedProps = react$1.mergeProps(tooltip.getContentProps(), presence.getPresenceProps(ref), props);
17
+ const mergedProps = react$1.mergeProps(tooltip.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
  TooltipContent.displayName = "TooltipContent";
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 { useTooltipContext } from './use-tooltip-context.js';
@@ -9,11 +10,11 @@ import { useTooltipContext } from './use-tooltip-context.js';
9
10
  const TooltipContent = forwardRef((props, ref) => {
10
11
  const tooltip = useTooltipContext();
11
12
  const presence = usePresenceContext();
12
- const mergedProps = mergeProps(tooltip.getContentProps(), presence.getPresenceProps(ref), props);
13
+ const mergedProps = mergeProps(tooltip.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
  TooltipContent.displayName = "TooltipContent";
19
20
 
package/dist/index.cjs CHANGED
@@ -535,6 +535,13 @@ const toastTitle = require('./components/toast/toast-title.cjs');
535
535
  const toaster = require('./components/toast/toaster.cjs');
536
536
  const useToastContext = require('./components/toast/use-toast-context.cjs');
537
537
  const toast$1 = require('./components/toast/toast.cjs');
538
+ const toggleContext = require('./components/toggle/toggle-context.cjs');
539
+ const toggleIndicator = require('./components/toggle/toggle-indicator.cjs');
540
+ const toggleRoot = require('./components/toggle/toggle-root.cjs');
541
+ const toggle_anatomy = require('./components/toggle/toggle.anatomy.cjs');
542
+ const useToggle = require('./components/toggle/use-toggle.cjs');
543
+ const useToggleContext = require('./components/toggle/use-toggle-context.cjs');
544
+ const toggle = require('./components/toggle/toggle.cjs');
538
545
  const toggleGroupContext = require('./components/toggle-group/toggle-group-context.cjs');
539
546
  const toggleGroupItem = require('./components/toggle-group/toggle-group-item.cjs');
540
547
  const toggleGroupRoot = require('./components/toggle-group/toggle-group-root.cjs');
@@ -1151,6 +1158,13 @@ exports.ToastTitle = toastTitle.ToastTitle;
1151
1158
  exports.Toaster = toaster.Toaster;
1152
1159
  exports.useToastContext = useToastContext.useToastContext;
1153
1160
  exports.Toast = toast$1;
1161
+ exports.ToggleContext = toggleContext.ToggleContext;
1162
+ exports.ToggleIndicator = toggleIndicator.ToggleIndicator;
1163
+ exports.ToggleRoot = toggleRoot.ToggleRoot;
1164
+ exports.toggleAnatomy = toggle_anatomy.toggleAnatomy;
1165
+ exports.useToggle = useToggle.useToggle;
1166
+ exports.useToggleContext = useToggleContext.useToggleContext;
1167
+ exports.Toggle = toggle;
1154
1168
  exports.ToggleGroupContext = toggleGroupContext.ToggleGroupContext;
1155
1169
  exports.ToggleGroupItem = toggleGroupItem.ToggleGroupItem;
1156
1170
  exports.ToggleGroupRoot = toggleGroupRoot.ToggleGroupRoot;
package/dist/index.js CHANGED
@@ -568,6 +568,14 @@ export { Toaster } from './components/toast/toaster.js';
568
568
  export { useToastContext } from './components/toast/use-toast-context.js';
569
569
  import * as toast from './components/toast/toast.js';
570
570
  export { toast as Toast };
571
+ export { ToggleContext } from './components/toggle/toggle-context.js';
572
+ export { ToggleIndicator } from './components/toggle/toggle-indicator.js';
573
+ export { ToggleRoot } from './components/toggle/toggle-root.js';
574
+ export { toggleAnatomy } from './components/toggle/toggle.anatomy.js';
575
+ export { useToggle } from './components/toggle/use-toggle.js';
576
+ export { useToggleContext } from './components/toggle/use-toggle-context.js';
577
+ import * as toggle from './components/toggle/toggle.js';
578
+ export { toggle as Toggle };
571
579
  export { ToggleGroupContext } from './components/toggle-group/toggle-group-context.js';
572
580
  export { ToggleGroupItem } from './components/toggle-group/toggle-group-item.js';
573
581
  export { ToggleGroupRoot } from './components/toggle-group/toggle-group-root.js';
@@ -1,3 +1,3 @@
1
- type PossibleRef<T> = React.Ref<T> | undefined;
2
- export declare function composeRefs<T>(...refs: PossibleRef<T>[]): (node: T) => void;
1
+ type PossibleRef<T> = React.Ref<T | null> | undefined;
2
+ export declare function composeRefs<T>(...refs: PossibleRef<T>[]): (node: T | null) => void;
3
3
  export {};
@@ -1,3 +1,3 @@
1
- type PossibleRef<T> = React.Ref<T> | undefined;
2
- export declare function composeRefs<T>(...refs: PossibleRef<T>[]): (node: T) => void;
1
+ type PossibleRef<T> = React.Ref<T | null> | undefined;
2
+ export declare function composeRefs<T>(...refs: PossibleRef<T>[]): (node: T | null) => void;
3
3
  export {};
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@ark-ui/react",
3
- "version": "4.0.0",
3
+ "version": "4.1.0",
4
4
  "description": "A collection of unstyled, accessible UI components for React, utilizing state machines for seamless interaction.",
5
5
  "keywords": [
6
6
  "accordion",
@@ -143,71 +143,71 @@
143
143
  "sideEffects": false,
144
144
  "dependencies": {
145
145
  "@internationalized/date": "3.5.5",
146
- "@zag-js/accordion": "0.71.0",
147
- "@zag-js/anatomy": "0.71.0",
148
- "@zag-js/avatar": "0.71.0",
149
- "@zag-js/carousel": "0.71.0",
150
- "@zag-js/checkbox": "0.71.0",
151
- "@zag-js/clipboard": "0.71.0",
152
- "@zag-js/collapsible": "0.71.0",
153
- "@zag-js/collection": "0.71.0",
154
- "@zag-js/color-picker": "0.71.0",
155
- "@zag-js/color-utils": "0.71.0",
156
- "@zag-js/combobox": "0.71.0",
157
- "@zag-js/core": "0.71.0",
158
- "@zag-js/date-picker": "0.71.0",
159
- "@zag-js/date-utils": "0.71.0",
160
- "@zag-js/dialog": "0.71.0",
161
- "@zag-js/dom-query": "0.71.0",
162
- "@zag-js/editable": "0.71.0",
163
- "@zag-js/file-upload": "0.71.0",
164
- "@zag-js/file-utils": "0.71.0",
165
- "@zag-js/highlight-word": "0.71.0",
166
- "@zag-js/hover-card": "0.71.0",
167
- "@zag-js/i18n-utils": "0.71.0",
168
- "@zag-js/menu": "0.71.0",
169
- "@zag-js/number-input": "0.71.0",
170
- "@zag-js/pagination": "0.71.0",
171
- "@zag-js/pin-input": "0.71.0",
172
- "@zag-js/popover": "0.71.0",
173
- "@zag-js/presence": "0.71.0",
174
- "@zag-js/progress": "0.71.0",
175
- "@zag-js/qr-code": "0.71.0",
176
- "@zag-js/radio-group": "0.71.0",
177
- "@zag-js/rating-group": "0.71.0",
178
- "@zag-js/react": "0.71.0",
179
- "@zag-js/select": "0.71.0",
180
- "@zag-js/signature-pad": "0.71.0",
181
- "@zag-js/slider": "0.71.0",
182
- "@zag-js/splitter": "0.71.0",
183
- "@zag-js/steps": "0.71.0",
184
- "@zag-js/switch": "0.71.0",
185
- "@zag-js/tabs": "0.71.0",
186
- "@zag-js/tags-input": "0.71.0",
187
- "@zag-js/time-picker": "0.71.0",
188
- "@zag-js/timer": "0.71.0",
189
- "@zag-js/toast": "0.71.0",
190
- "@zag-js/toggle-group": "0.71.0",
191
- "@zag-js/tooltip": "0.71.0",
192
- "@zag-js/tree-view": "0.71.0",
193
- "@zag-js/types": "0.71.0"
146
+ "@zag-js/accordion": "0.73.0",
147
+ "@zag-js/anatomy": "0.73.0",
148
+ "@zag-js/avatar": "0.73.0",
149
+ "@zag-js/carousel": "0.73.0",
150
+ "@zag-js/checkbox": "0.73.0",
151
+ "@zag-js/clipboard": "0.73.0",
152
+ "@zag-js/collapsible": "0.73.0",
153
+ "@zag-js/collection": "0.73.0",
154
+ "@zag-js/color-picker": "0.73.0",
155
+ "@zag-js/color-utils": "0.73.0",
156
+ "@zag-js/combobox": "0.73.0",
157
+ "@zag-js/core": "0.73.0",
158
+ "@zag-js/date-picker": "0.73.0",
159
+ "@zag-js/date-utils": "0.73.0",
160
+ "@zag-js/dialog": "0.73.0",
161
+ "@zag-js/dom-query": "0.73.0",
162
+ "@zag-js/editable": "0.73.0",
163
+ "@zag-js/file-upload": "0.73.0",
164
+ "@zag-js/file-utils": "0.73.0",
165
+ "@zag-js/highlight-word": "0.73.0",
166
+ "@zag-js/hover-card": "0.73.0",
167
+ "@zag-js/i18n-utils": "0.73.0",
168
+ "@zag-js/menu": "0.73.0",
169
+ "@zag-js/number-input": "0.73.0",
170
+ "@zag-js/pagination": "0.73.0",
171
+ "@zag-js/pin-input": "0.73.0",
172
+ "@zag-js/popover": "0.73.0",
173
+ "@zag-js/presence": "0.73.0",
174
+ "@zag-js/progress": "0.73.0",
175
+ "@zag-js/qr-code": "0.73.0",
176
+ "@zag-js/radio-group": "0.73.0",
177
+ "@zag-js/rating-group": "0.73.0",
178
+ "@zag-js/react": "0.73.0",
179
+ "@zag-js/select": "0.73.0",
180
+ "@zag-js/signature-pad": "0.73.0",
181
+ "@zag-js/slider": "0.73.0",
182
+ "@zag-js/splitter": "0.73.0",
183
+ "@zag-js/steps": "0.73.0",
184
+ "@zag-js/switch": "0.73.0",
185
+ "@zag-js/tabs": "0.73.0",
186
+ "@zag-js/tags-input": "0.73.0",
187
+ "@zag-js/time-picker": "0.73.0",
188
+ "@zag-js/timer": "0.73.0",
189
+ "@zag-js/toast": "0.73.0",
190
+ "@zag-js/toggle-group": "0.73.0",
191
+ "@zag-js/tooltip": "0.73.0",
192
+ "@zag-js/tree-view": "0.73.0",
193
+ "@zag-js/types": "0.73.0"
194
194
  },
195
195
  "devDependencies": {
196
196
  "@biomejs/biome": "1.9.2",
197
197
  "@release-it/keep-a-changelog": "5.0.0",
198
- "@storybook/addon-a11y": "8.3.3",
199
- "@storybook/addon-essentials": "8.3.3",
200
- "@storybook/react-vite": "8.3.3",
201
- "@storybook/react": "8.3.3",
198
+ "@storybook/addon-a11y": "8.3.4",
199
+ "@storybook/addon-essentials": "8.3.4",
200
+ "@storybook/react-vite": "8.3.4",
201
+ "@storybook/react": "8.3.4",
202
202
  "@testing-library/dom": "10.4.0",
203
203
  "@testing-library/jest-dom": "6.5.0",
204
204
  "@testing-library/react": "16.0.1",
205
205
  "@testing-library/user-event": "14.5.2",
206
206
  "@types/jsdom": "21.1.7",
207
- "@types/react": "18.3.9",
207
+ "@types/react": "18.3.10",
208
208
  "@types/react-dom": "18.3.0",
209
- "@vitejs/plugin-react": "4.3.1",
210
- "@zag-js/stringify-state": "0.71.0",
209
+ "@vitejs/plugin-react": "4.3.2",
210
+ "@zag-js/stringify-state": "0.73.0",
211
211
  "globby": "14.0.2",
212
212
  "jsdom": "25.0.1",
213
213
  "lucide-react": "0.446.0",
@@ -217,10 +217,10 @@
217
217
  "react-hook-form": "7.53.0",
218
218
  "release-it": "17.6.0",
219
219
  "resize-observer-polyfill": "1.5.1",
220
- "storybook": "8.3.3",
220
+ "storybook": "8.3.4",
221
221
  "typescript": "5.6.2",
222
222
  "vite": "5.4.8",
223
- "vite-plugin-dts": "4.2.2",
223
+ "vite-plugin-dts": "4.2.3",
224
224
  "vitest": "2.1.1",
225
225
  "vitest-axe": "1.0.0-pre.3"
226
226
  },