@ark-ui/react 5.6.0 → 5.8.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 (101) hide show
  1. package/dist/components/collection.d.cts +1 -1
  2. package/dist/components/collection.d.ts +1 -1
  3. package/dist/components/date-picker/date-picker-root.cjs +2 -2
  4. package/dist/components/date-picker/date-picker-root.js +2 -2
  5. package/dist/components/floating-panel/floating-panel-body.cjs +5 -7
  6. package/dist/components/floating-panel/floating-panel-body.js +5 -7
  7. package/dist/components/floating-panel/floating-panel-content.cjs +8 -14
  8. package/dist/components/floating-panel/floating-panel-content.js +8 -14
  9. package/dist/components/floating-panel/floating-panel-drag-trigger.cjs +5 -7
  10. package/dist/components/floating-panel/floating-panel-drag-trigger.js +5 -7
  11. package/dist/components/floating-panel/floating-panel-header.cjs +5 -7
  12. package/dist/components/floating-panel/floating-panel-header.js +5 -7
  13. package/dist/components/floating-panel/floating-panel-positioner.cjs +8 -10
  14. package/dist/components/floating-panel/floating-panel-positioner.js +8 -10
  15. package/dist/components/index.cjs +35 -0
  16. package/dist/components/index.d.cts +1 -0
  17. package/dist/components/index.d.ts +1 -0
  18. package/dist/components/index.js +17 -0
  19. package/dist/components/listbox/index.cjs +44 -0
  20. package/dist/components/listbox/index.d.cts +18 -0
  21. package/dist/components/listbox/index.d.ts +18 -0
  22. package/dist/components/listbox/index.js +18 -0
  23. package/dist/components/listbox/listbox-content.cjs +19 -0
  24. package/dist/components/listbox/listbox-content.d.cts +7 -0
  25. package/dist/components/listbox/listbox-content.d.ts +7 -0
  26. package/dist/components/listbox/listbox-content.js +15 -0
  27. package/dist/components/listbox/listbox-context.d.cts +7 -0
  28. package/dist/components/listbox/listbox-context.d.ts +7 -0
  29. package/dist/components/listbox/listbox-input.cjs +21 -0
  30. package/dist/components/listbox/listbox-input.d.cts +8 -0
  31. package/dist/components/listbox/listbox-input.d.ts +8 -0
  32. package/dist/components/listbox/listbox-input.js +17 -0
  33. package/dist/components/listbox/listbox-item-group-label.cjs +21 -0
  34. package/dist/components/listbox/listbox-item-group-label.d.cts +7 -0
  35. package/dist/components/listbox/listbox-item-group-label.d.ts +7 -0
  36. package/dist/components/listbox/listbox-item-group-label.js +17 -0
  37. package/dist/components/listbox/listbox-item-group.cjs +24 -0
  38. package/dist/components/listbox/listbox-item-group.d.cts +7 -0
  39. package/dist/components/listbox/listbox-item-group.d.ts +7 -0
  40. package/dist/components/listbox/listbox-item-group.js +20 -0
  41. package/dist/components/listbox/listbox-item-indicator.cjs +21 -0
  42. package/dist/components/listbox/listbox-item-indicator.d.cts +7 -0
  43. package/dist/components/listbox/listbox-item-indicator.d.ts +7 -0
  44. package/dist/components/listbox/listbox-item-indicator.js +17 -0
  45. package/dist/components/listbox/listbox-item-text.cjs +21 -0
  46. package/dist/components/listbox/listbox-item-text.d.cts +7 -0
  47. package/dist/components/listbox/listbox-item-text.d.ts +7 -0
  48. package/dist/components/listbox/listbox-item-text.js +17 -0
  49. package/dist/components/listbox/listbox-item.cjs +24 -0
  50. package/dist/components/listbox/listbox-item.d.cts +8 -0
  51. package/dist/components/listbox/listbox-item.d.ts +8 -0
  52. package/dist/components/listbox/listbox-item.js +20 -0
  53. package/dist/components/listbox/listbox-label.cjs +19 -0
  54. package/dist/components/listbox/listbox-label.d.cts +7 -0
  55. package/dist/components/listbox/listbox-label.d.ts +7 -0
  56. package/dist/components/listbox/listbox-label.js +15 -0
  57. package/dist/components/listbox/listbox-root-provider.cjs +20 -0
  58. package/dist/components/listbox/listbox-root-provider.d.cts +14 -0
  59. package/dist/components/listbox/listbox-root-provider.d.ts +14 -0
  60. package/dist/components/listbox/listbox-root-provider.js +16 -0
  61. package/dist/components/listbox/listbox-root.cjs +42 -0
  62. package/dist/components/listbox/listbox-root.d.cts +11 -0
  63. package/dist/components/listbox/listbox-root.d.ts +11 -0
  64. package/dist/components/listbox/listbox-root.js +38 -0
  65. package/dist/components/listbox/listbox-value-text.cjs +20 -0
  66. package/dist/components/listbox/listbox-value-text.d.cts +11 -0
  67. package/dist/components/listbox/listbox-value-text.d.ts +11 -0
  68. package/dist/components/listbox/listbox-value-text.js +16 -0
  69. package/dist/components/listbox/listbox.anatomy.d.cts +1 -0
  70. package/dist/components/listbox/listbox.anatomy.d.ts +1 -0
  71. package/dist/components/listbox/listbox.cjs +29 -0
  72. package/dist/components/listbox/listbox.d.cts +12 -0
  73. package/dist/components/listbox/listbox.d.ts +12 -0
  74. package/dist/components/listbox/listbox.js +11 -0
  75. package/dist/components/listbox/use-listbox-context.cjs +15 -0
  76. package/dist/components/listbox/use-listbox-context.d.cts +6 -0
  77. package/dist/components/listbox/use-listbox-context.d.ts +6 -0
  78. package/dist/components/listbox/use-listbox-context.js +10 -0
  79. package/dist/components/listbox/use-listbox-item-context.cjs +15 -0
  80. package/dist/components/listbox/use-listbox-item-context.d.cts +5 -0
  81. package/dist/components/listbox/use-listbox-item-context.d.ts +5 -0
  82. package/dist/components/listbox/use-listbox-item-context.js +10 -0
  83. package/dist/components/listbox/use-listbox-item-group-props.cjs +15 -0
  84. package/dist/components/listbox/use-listbox-item-group-props.d.cts +5 -0
  85. package/dist/components/listbox/use-listbox-item-group-props.d.ts +5 -0
  86. package/dist/components/listbox/use-listbox-item-group-props.js +10 -0
  87. package/dist/components/listbox/use-listbox-item-props-context.cjs +15 -0
  88. package/dist/components/listbox/use-listbox-item-props-context.d.cts +3 -0
  89. package/dist/components/listbox/use-listbox-item-props-context.d.ts +3 -0
  90. package/dist/components/listbox/use-listbox-item-props-context.js +10 -0
  91. package/dist/components/listbox/use-listbox.cjs +45 -0
  92. package/dist/components/listbox/use-listbox.d.cts +13 -0
  93. package/dist/components/listbox/use-listbox.d.ts +13 -0
  94. package/dist/components/listbox/use-listbox.js +22 -0
  95. package/dist/components/toast/toaster.cjs +3 -1
  96. package/dist/components/toast/toaster.js +3 -1
  97. package/dist/components/toggle-group/toggle-group-root.cjs +1 -0
  98. package/dist/components/toggle-group/toggle-group-root.js +1 -0
  99. package/dist/index.cjs +35 -0
  100. package/dist/index.js +17 -0
  101. package/package.json +70 -68
@@ -0,0 +1,16 @@
1
+ 'use client';
2
+ import { jsx } from 'react/jsx-runtime';
3
+ import { mergeProps } from '@zag-js/react';
4
+ import { forwardRef } from 'react';
5
+ import { ark } from '../factory.js';
6
+ import { useListboxContext } from './use-listbox-context.js';
7
+
8
+ const ListboxValueText = forwardRef((props, ref) => {
9
+ const { children, placeholder, ...localprops } = props;
10
+ const listbox = useListboxContext();
11
+ const mergedProps = mergeProps(listbox.getValueTextProps(), localprops);
12
+ return /* @__PURE__ */ jsx(ark.span, { ...mergedProps, ref, children: children || listbox.valueAsString || placeholder });
13
+ });
14
+ ListboxValueText.displayName = "ListboxValueText";
15
+
16
+ export { ListboxValueText };
@@ -0,0 +1 @@
1
+ export { anatomy as listboxAnatomy } from '@zag-js/listbox';
@@ -0,0 +1 @@
1
+ export { anatomy as listboxAnatomy } from '@zag-js/listbox';
@@ -0,0 +1,29 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
4
+
5
+ const listboxContent = require('./listbox-content.cjs');
6
+ const listboxInput = require('./listbox-input.cjs');
7
+ const listboxItem = require('./listbox-item.cjs');
8
+ const listboxItemGroup = require('./listbox-item-group.cjs');
9
+ const listboxItemGroupLabel = require('./listbox-item-group-label.cjs');
10
+ const listboxItemIndicator = require('./listbox-item-indicator.cjs');
11
+ const listboxItemText = require('./listbox-item-text.cjs');
12
+ const listboxLabel = require('./listbox-label.cjs');
13
+ const listboxRoot = require('./listbox-root.cjs');
14
+ const listboxRootProvider = require('./listbox-root-provider.cjs');
15
+ const listboxValueText = require('./listbox-value-text.cjs');
16
+
17
+
18
+
19
+ exports.Content = listboxContent.ListboxContent;
20
+ exports.Input = listboxInput.ListboxInput;
21
+ exports.Item = listboxItem.ListboxItem;
22
+ exports.ItemGroup = listboxItemGroup.ListboxItemGroup;
23
+ exports.ItemGroupLabel = listboxItemGroupLabel.ListboxItemGroupLabel;
24
+ exports.ItemIndicator = listboxItemIndicator.ListboxItemIndicator;
25
+ exports.ItemText = listboxItemText.ListboxItemText;
26
+ exports.Label = listboxLabel.ListboxLabel;
27
+ exports.Root = listboxRoot.ListboxRoot;
28
+ exports.RootProvider = listboxRootProvider.ListboxRootProvider;
29
+ exports.ValueText = listboxValueText.ListboxValueText;
@@ -0,0 +1,12 @@
1
+ export type { HighlightChangeDetails, ScrollToIndexDetails, SelectionDetails, SelectionMode, ValueChangeDetails, } from '@zag-js/listbox';
2
+ export { ListboxContent as Content, type ListboxContentBaseProps as ContentBaseProps, type ListboxContentProps as ContentProps, } from './listbox-content';
3
+ export { ListboxInput as Input, type ListboxInputBaseProps as InputBaseProps, type ListboxInputProps as InputProps, } from './listbox-input';
4
+ export { ListboxItem as Item, type ListboxItemBaseProps as ItemBaseProps, type ListboxItemProps as ItemProps, } from './listbox-item';
5
+ export { ListboxItemGroup as ItemGroup, type ListboxItemGroupBaseProps as ItemGroupBaseProps, type ListboxItemGroupProps as ItemGroupProps, } from './listbox-item-group';
6
+ export { ListboxItemGroupLabel as ItemGroupLabel, type ListboxItemGroupLabelBaseProps as ItemGroupLabelBaseProps, type ListboxItemGroupLabelProps as ItemGroupLabelProps, } from './listbox-item-group-label';
7
+ export { ListboxItemIndicator as ItemIndicator, type ListboxItemIndicatorBaseProps as ItemIndicatorBaseProps, type ListboxItemIndicatorProps as ItemIndicatorProps, } from './listbox-item-indicator';
8
+ export { ListboxItemText as ItemText, type ListboxItemTextBaseProps as ItemTextBaseProps, type ListboxItemTextProps as ItemTextProps, } from './listbox-item-text';
9
+ export { ListboxLabel as Label, type ListboxLabelBaseProps as LabelBaseProps, type ListboxLabelProps as LabelProps, } from './listbox-label';
10
+ export { ListboxRoot as Root, type ListboxRootBaseProps as RootBaseProps, type ListboxRootProps as RootProps, } from './listbox-root';
11
+ export { ListboxRootProvider as RootProvider, type ListboxRootProviderBaseProps as RootProviderBaseProps, type ListboxRootProviderProps as RootProviderProps, } from './listbox-root-provider';
12
+ export { ListboxValueText as ValueText, type ListboxValueTextBaseProps as ValueTextBaseProps, type ListboxValueTextProps as ValueTextProps, } from './listbox-value-text';
@@ -0,0 +1,12 @@
1
+ export type { HighlightChangeDetails, ScrollToIndexDetails, SelectionDetails, SelectionMode, ValueChangeDetails, } from '@zag-js/listbox';
2
+ export { ListboxContent as Content, type ListboxContentBaseProps as ContentBaseProps, type ListboxContentProps as ContentProps, } from './listbox-content';
3
+ export { ListboxInput as Input, type ListboxInputBaseProps as InputBaseProps, type ListboxInputProps as InputProps, } from './listbox-input';
4
+ export { ListboxItem as Item, type ListboxItemBaseProps as ItemBaseProps, type ListboxItemProps as ItemProps, } from './listbox-item';
5
+ export { ListboxItemGroup as ItemGroup, type ListboxItemGroupBaseProps as ItemGroupBaseProps, type ListboxItemGroupProps as ItemGroupProps, } from './listbox-item-group';
6
+ export { ListboxItemGroupLabel as ItemGroupLabel, type ListboxItemGroupLabelBaseProps as ItemGroupLabelBaseProps, type ListboxItemGroupLabelProps as ItemGroupLabelProps, } from './listbox-item-group-label';
7
+ export { ListboxItemIndicator as ItemIndicator, type ListboxItemIndicatorBaseProps as ItemIndicatorBaseProps, type ListboxItemIndicatorProps as ItemIndicatorProps, } from './listbox-item-indicator';
8
+ export { ListboxItemText as ItemText, type ListboxItemTextBaseProps as ItemTextBaseProps, type ListboxItemTextProps as ItemTextProps, } from './listbox-item-text';
9
+ export { ListboxLabel as Label, type ListboxLabelBaseProps as LabelBaseProps, type ListboxLabelProps as LabelProps, } from './listbox-label';
10
+ export { ListboxRoot as Root, type ListboxRootBaseProps as RootBaseProps, type ListboxRootProps as RootProps, } from './listbox-root';
11
+ export { ListboxRootProvider as RootProvider, type ListboxRootProviderBaseProps as RootProviderBaseProps, type ListboxRootProviderProps as RootProviderProps, } from './listbox-root-provider';
12
+ export { ListboxValueText as ValueText, type ListboxValueTextBaseProps as ValueTextBaseProps, type ListboxValueTextProps as ValueTextProps, } from './listbox-value-text';
@@ -0,0 +1,11 @@
1
+ export { ListboxContent as Content } from './listbox-content.js';
2
+ export { ListboxInput as Input } from './listbox-input.js';
3
+ export { ListboxItem as Item } from './listbox-item.js';
4
+ export { ListboxItemGroup as ItemGroup } from './listbox-item-group.js';
5
+ export { ListboxItemGroupLabel as ItemGroupLabel } from './listbox-item-group-label.js';
6
+ export { ListboxItemIndicator as ItemIndicator } from './listbox-item-indicator.js';
7
+ export { ListboxItemText as ItemText } from './listbox-item-text.js';
8
+ export { ListboxLabel as Label } from './listbox-label.js';
9
+ export { ListboxRoot as Root } from './listbox-root.js';
10
+ export { ListboxRootProvider as RootProvider } from './listbox-root-provider.js';
11
+ export { ListboxValueText as ValueText } from './listbox-value-text.js';
@@ -0,0 +1,15 @@
1
+ 'use client';
2
+ 'use strict';
3
+
4
+ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
5
+
6
+ const createContext = require('../../utils/create-context.cjs');
7
+
8
+ const [ListboxProvider, useListboxContext] = createContext.createContext({
9
+ name: "ListboxContext",
10
+ hookName: "useListboxContext",
11
+ providerName: "<ListboxProvider />"
12
+ });
13
+
14
+ exports.ListboxProvider = ListboxProvider;
15
+ exports.useListboxContext = useListboxContext;
@@ -0,0 +1,6 @@
1
+ import { CollectionItem } from '../collection';
2
+ import { UseListboxReturn } from './use-listbox';
3
+ import { Provider } from 'react';
4
+ export interface UseListboxContext<T extends CollectionItem> extends UseListboxReturn<T> {
5
+ }
6
+ export declare const ListboxProvider: Provider<UseListboxContext<any>>, useListboxContext: () => UseListboxContext<any>;
@@ -0,0 +1,6 @@
1
+ import { CollectionItem } from '../collection';
2
+ import { UseListboxReturn } from './use-listbox';
3
+ import { Provider } from 'react';
4
+ export interface UseListboxContext<T extends CollectionItem> extends UseListboxReturn<T> {
5
+ }
6
+ export declare const ListboxProvider: Provider<UseListboxContext<any>>, useListboxContext: () => UseListboxContext<any>;
@@ -0,0 +1,10 @@
1
+ 'use client';
2
+ import { createContext } from '../../utils/create-context.js';
3
+
4
+ const [ListboxProvider, useListboxContext] = createContext({
5
+ name: "ListboxContext",
6
+ hookName: "useListboxContext",
7
+ providerName: "<ListboxProvider />"
8
+ });
9
+
10
+ export { ListboxProvider, useListboxContext };
@@ -0,0 +1,15 @@
1
+ 'use client';
2
+ 'use strict';
3
+
4
+ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
5
+
6
+ const createContext = require('../../utils/create-context.cjs');
7
+
8
+ const [ListboxItemProvider, useListboxItemContext] = createContext.createContext({
9
+ name: "ListboxItemContext",
10
+ hookName: "useListboxItemContext",
11
+ providerName: "<ListboxItemProvider />"
12
+ });
13
+
14
+ exports.ListboxItemProvider = ListboxItemProvider;
15
+ exports.useListboxItemContext = useListboxItemContext;
@@ -0,0 +1,5 @@
1
+ import { ItemState } from '@zag-js/listbox';
2
+ import { Provider } from 'react';
3
+ export interface UseListboxItemContext extends ItemState {
4
+ }
5
+ export declare const ListboxItemProvider: Provider<UseListboxItemContext>, useListboxItemContext: () => UseListboxItemContext;
@@ -0,0 +1,5 @@
1
+ import { ItemState } from '@zag-js/listbox';
2
+ import { Provider } from 'react';
3
+ export interface UseListboxItemContext extends ItemState {
4
+ }
5
+ export declare const ListboxItemProvider: Provider<UseListboxItemContext>, useListboxItemContext: () => UseListboxItemContext;
@@ -0,0 +1,10 @@
1
+ 'use client';
2
+ import { createContext } from '../../utils/create-context.js';
3
+
4
+ const [ListboxItemProvider, useListboxItemContext] = createContext({
5
+ name: "ListboxItemContext",
6
+ hookName: "useListboxItemContext",
7
+ providerName: "<ListboxItemProvider />"
8
+ });
9
+
10
+ export { ListboxItemProvider, useListboxItemContext };
@@ -0,0 +1,15 @@
1
+ 'use client';
2
+ 'use strict';
3
+
4
+ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
5
+
6
+ const createContext = require('../../utils/create-context.cjs');
7
+
8
+ const [ListboxItemGroupPropsProvider, useListboxItemGroupPropsContext] = createContext.createContext({
9
+ name: "ListboxItemGroupPropsContext",
10
+ hookName: "useListboxItemGroupPropsContext",
11
+ providerName: "<ListboxItemGroupPropsProvider />"
12
+ });
13
+
14
+ exports.ListboxItemGroupPropsProvider = ListboxItemGroupPropsProvider;
15
+ exports.useListboxItemGroupPropsContext = useListboxItemGroupPropsContext;
@@ -0,0 +1,5 @@
1
+ import { ItemGroupProps } from '@zag-js/listbox';
2
+ import { Provider } from 'react';
3
+ export interface UseListboxItemGroupPropsContext extends ItemGroupProps {
4
+ }
5
+ export declare const ListboxItemGroupPropsProvider: Provider<ItemGroupProps>, useListboxItemGroupPropsContext: () => ItemGroupProps;
@@ -0,0 +1,5 @@
1
+ import { ItemGroupProps } from '@zag-js/listbox';
2
+ import { Provider } from 'react';
3
+ export interface UseListboxItemGroupPropsContext extends ItemGroupProps {
4
+ }
5
+ export declare const ListboxItemGroupPropsProvider: Provider<ItemGroupProps>, useListboxItemGroupPropsContext: () => ItemGroupProps;
@@ -0,0 +1,10 @@
1
+ 'use client';
2
+ import { createContext } from '../../utils/create-context.js';
3
+
4
+ const [ListboxItemGroupPropsProvider, useListboxItemGroupPropsContext] = createContext({
5
+ name: "ListboxItemGroupPropsContext",
6
+ hookName: "useListboxItemGroupPropsContext",
7
+ providerName: "<ListboxItemGroupPropsProvider />"
8
+ });
9
+
10
+ export { ListboxItemGroupPropsProvider, useListboxItemGroupPropsContext };
@@ -0,0 +1,15 @@
1
+ 'use client';
2
+ 'use strict';
3
+
4
+ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
5
+
6
+ const createContext = require('../../utils/create-context.cjs');
7
+
8
+ const [ListboxItemPropsProvider, useListboxItemPropsContext] = createContext.createContext({
9
+ name: "ListboxItemPropsContext",
10
+ hookName: "useListboxItemPropsContext",
11
+ providerName: "<ListboxItemPropsProvider />"
12
+ });
13
+
14
+ exports.ListboxItemPropsProvider = ListboxItemPropsProvider;
15
+ exports.useListboxItemPropsContext = useListboxItemPropsContext;
@@ -0,0 +1,3 @@
1
+ import { ItemProps } from '@zag-js/listbox';
2
+ import { Provider } from 'react';
3
+ export declare const ListboxItemPropsProvider: Provider<ItemProps<any>>, useListboxItemPropsContext: () => ItemProps<any>;
@@ -0,0 +1,3 @@
1
+ import { ItemProps } from '@zag-js/listbox';
2
+ import { Provider } from 'react';
3
+ export declare const ListboxItemPropsProvider: Provider<ItemProps<any>>, useListboxItemPropsContext: () => ItemProps<any>;
@@ -0,0 +1,10 @@
1
+ 'use client';
2
+ import { createContext } from '../../utils/create-context.js';
3
+
4
+ const [ListboxItemPropsProvider, useListboxItemPropsContext] = createContext({
5
+ name: "ListboxItemPropsContext",
6
+ hookName: "useListboxItemPropsContext",
7
+ providerName: "<ListboxItemPropsProvider />"
8
+ });
9
+
10
+ export { ListboxItemPropsProvider, useListboxItemPropsContext };
@@ -0,0 +1,45 @@
1
+ 'use client';
2
+ 'use strict';
3
+
4
+ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
5
+
6
+ const listbox = require('@zag-js/listbox');
7
+ const react$1 = require('@zag-js/react');
8
+ const react = require('react');
9
+ const useEnvironmentContext = require('../../providers/environment/use-environment-context.cjs');
10
+ const useLocaleContext = require('../../providers/locale/use-locale-context.cjs');
11
+
12
+ function _interopNamespaceDefault(e) {
13
+ const n = Object.create(null, { [Symbol.toStringTag]: { value: 'Module' } });
14
+ if (e) {
15
+ for (const k in e) {
16
+ if (k !== 'default') {
17
+ const d = Object.getOwnPropertyDescriptor(e, k);
18
+ Object.defineProperty(n, k, d.get ? d : {
19
+ enumerable: true,
20
+ get: () => e[k]
21
+ });
22
+ }
23
+ }
24
+ }
25
+ n.default = e;
26
+ return Object.freeze(n);
27
+ }
28
+
29
+ const listbox__namespace = /*#__PURE__*/_interopNamespaceDefault(listbox);
30
+
31
+ const useListbox = (props) => {
32
+ const id = react.useId();
33
+ const { dir } = useLocaleContext.useLocaleContext();
34
+ const { getRootNode } = useEnvironmentContext.useEnvironmentContext();
35
+ const machineProps = {
36
+ id,
37
+ dir,
38
+ getRootNode,
39
+ ...props
40
+ };
41
+ const service = react$1.useMachine(listbox__namespace.machine, machineProps);
42
+ return listbox__namespace.connect(service, react$1.normalizeProps);
43
+ };
44
+
45
+ exports.useListbox = useListbox;
@@ -0,0 +1,13 @@
1
+ import { PropTypes } from '@zag-js/react';
2
+ import { Optional } from '../../types';
3
+ import { CollectionItem, ListCollection } from '../collection';
4
+ import * as listbox from '@zag-js/listbox';
5
+ export interface UseListboxProps<T extends CollectionItem> extends Optional<Omit<listbox.Props<T>, 'dir' | 'getRootNode' | 'collection'>, 'id'> {
6
+ /**
7
+ * The collection of items
8
+ */
9
+ collection: ListCollection<T>;
10
+ }
11
+ export interface UseListboxReturn<T extends CollectionItem> extends listbox.Api<PropTypes, T> {
12
+ }
13
+ export declare const useListbox: <T extends CollectionItem>(props: UseListboxProps<T>) => UseListboxReturn<T>;
@@ -0,0 +1,13 @@
1
+ import { PropTypes } from '@zag-js/react';
2
+ import { Optional } from '../../types';
3
+ import { CollectionItem, ListCollection } from '../collection';
4
+ import * as listbox from '@zag-js/listbox';
5
+ export interface UseListboxProps<T extends CollectionItem> extends Optional<Omit<listbox.Props<T>, 'dir' | 'getRootNode' | 'collection'>, 'id'> {
6
+ /**
7
+ * The collection of items
8
+ */
9
+ collection: ListCollection<T>;
10
+ }
11
+ export interface UseListboxReturn<T extends CollectionItem> extends listbox.Api<PropTypes, T> {
12
+ }
13
+ export declare const useListbox: <T extends CollectionItem>(props: UseListboxProps<T>) => UseListboxReturn<T>;
@@ -0,0 +1,22 @@
1
+ 'use client';
2
+ import * as listbox from '@zag-js/listbox';
3
+ import { useMachine, normalizeProps } from '@zag-js/react';
4
+ import { useId } from 'react';
5
+ import { useEnvironmentContext } from '../../providers/environment/use-environment-context.js';
6
+ import { useLocaleContext } from '../../providers/locale/use-locale-context.js';
7
+
8
+ const useListbox = (props) => {
9
+ const id = useId();
10
+ const { dir } = useLocaleContext();
11
+ const { getRootNode } = useEnvironmentContext();
12
+ const machineProps = {
13
+ id,
14
+ dir,
15
+ getRootNode,
16
+ ...props
17
+ };
18
+ const service = useMachine(listbox.machine, machineProps);
19
+ return listbox.connect(service, normalizeProps);
20
+ };
21
+
22
+ export { useListbox };
@@ -47,10 +47,12 @@ const Toaster = react.forwardRef((props, ref) => {
47
47
  });
48
48
  Toaster.displayName = "Toaster";
49
49
  const ToastActor = (props) => {
50
+ const env = useEnvironmentContext.useEnvironmentContext();
50
51
  const localProps = {
51
52
  ...props.value,
52
53
  parent: props.parent,
53
- index: props.index
54
+ index: props.index,
55
+ getRootNode: env.getRootNode
54
56
  };
55
57
  const service = react$1.useMachine(toast__namespace.machine, { ...localProps });
56
58
  const api = toast__namespace.connect(service, react$1.normalizeProps);
@@ -24,10 +24,12 @@ const Toaster = forwardRef((props, ref) => {
24
24
  });
25
25
  Toaster.displayName = "Toaster";
26
26
  const ToastActor = (props) => {
27
+ const env = useEnvironmentContext();
27
28
  const localProps = {
28
29
  ...props.value,
29
30
  parent: props.parent,
30
- index: props.index
31
+ index: props.index,
32
+ getRootNode: env.getRootNode
31
33
  };
32
34
  const service = useMachine(toast.machine, { ...localProps });
33
35
  const api = toast.connect(service, normalizeProps);
@@ -14,6 +14,7 @@ const useToggleGroupContext = require('./use-toggle-group-context.cjs');
14
14
  const ToggleGroupRoot = react.forwardRef((props, ref) => {
15
15
  const [useToggleGroupProps, localProps] = createSplitProps.createSplitProps()(props, [
16
16
  "defaultValue",
17
+ "deselectable",
17
18
  "disabled",
18
19
  "id",
19
20
  "ids",
@@ -10,6 +10,7 @@ import { ToggleGroupProvider } from './use-toggle-group-context.js';
10
10
  const ToggleGroupRoot = forwardRef((props, ref) => {
11
11
  const [useToggleGroupProps, localProps] = createSplitProps()(props, [
12
12
  "defaultValue",
13
+ "deselectable",
13
14
  "disabled",
14
15
  "id",
15
16
  "ids",
package/dist/index.cjs CHANGED
@@ -277,6 +277,21 @@ const hoverCardTrigger = require('./components/hover-card/hover-card-trigger.cjs
277
277
  const useHoverCard = require('./components/hover-card/use-hover-card.cjs');
278
278
  const useHoverCardContext = require('./components/hover-card/use-hover-card-context.cjs');
279
279
  const hoverCard$1 = require('./components/hover-card/hover-card.cjs');
280
+ const listboxContent = require('./components/listbox/listbox-content.cjs');
281
+ const listboxInput = require('./components/listbox/listbox-input.cjs');
282
+ const listboxItem = require('./components/listbox/listbox-item.cjs');
283
+ const listboxItemGroup = require('./components/listbox/listbox-item-group.cjs');
284
+ const listboxItemGroupLabel = require('./components/listbox/listbox-item-group-label.cjs');
285
+ const listboxItemIndicator = require('./components/listbox/listbox-item-indicator.cjs');
286
+ const listboxItemText = require('./components/listbox/listbox-item-text.cjs');
287
+ const listboxLabel = require('./components/listbox/listbox-label.cjs');
288
+ const listboxRoot = require('./components/listbox/listbox-root.cjs');
289
+ const listboxRootProvider = require('./components/listbox/listbox-root-provider.cjs');
290
+ const listboxValueText = require('./components/listbox/listbox-value-text.cjs');
291
+ const useListbox = require('./components/listbox/use-listbox.cjs');
292
+ const useListboxContext = require('./components/listbox/use-listbox-context.cjs');
293
+ const useListboxItemContext = require('./components/listbox/use-listbox-item-context.cjs');
294
+ const listbox$1 = require('./components/listbox/listbox.cjs');
280
295
  const menuArrow = require('./components/menu/menu-arrow.cjs');
281
296
  const menuArrowTip = require('./components/menu/menu-arrow-tip.cjs');
282
297
  const menuCheckboxItem = require('./components/menu/menu-checkbox-item.cjs');
@@ -653,6 +668,7 @@ const editable = require('@zag-js/editable');
653
668
  const fileUpload = require('@zag-js/file-upload');
654
669
  const floatingPanel = require('@zag-js/floating-panel');
655
670
  const hoverCard = require('@zag-js/hover-card');
671
+ const listbox = require('@zag-js/listbox');
656
672
  const menu = require('@zag-js/menu');
657
673
  const numberInput = require('@zag-js/number-input');
658
674
  const pagination = require('@zag-js/pagination');
@@ -963,6 +979,21 @@ exports.HoverCardTrigger = hoverCardTrigger.HoverCardTrigger;
963
979
  exports.useHoverCard = useHoverCard.useHoverCard;
964
980
  exports.useHoverCardContext = useHoverCardContext.useHoverCardContext;
965
981
  exports.HoverCard = hoverCard$1;
982
+ exports.ListboxContent = listboxContent.ListboxContent;
983
+ exports.ListboxInput = listboxInput.ListboxInput;
984
+ exports.ListboxItem = listboxItem.ListboxItem;
985
+ exports.ListboxItemGroup = listboxItemGroup.ListboxItemGroup;
986
+ exports.ListboxItemGroupLabel = listboxItemGroupLabel.ListboxItemGroupLabel;
987
+ exports.ListboxItemIndicator = listboxItemIndicator.ListboxItemIndicator;
988
+ exports.ListboxItemText = listboxItemText.ListboxItemText;
989
+ exports.ListboxLabel = listboxLabel.ListboxLabel;
990
+ exports.ListboxRoot = listboxRoot.ListboxRoot;
991
+ exports.ListboxRootProvider = listboxRootProvider.ListboxRootProvider;
992
+ exports.ListboxValueText = listboxValueText.ListboxValueText;
993
+ exports.useListbox = useListbox.useListbox;
994
+ exports.useListboxContext = useListboxContext.useListboxContext;
995
+ exports.useListboxItemContext = useListboxItemContext.useListboxItemContext;
996
+ exports.Listbox = listbox$1;
966
997
  exports.MenuArrow = menuArrow.MenuArrow;
967
998
  exports.MenuArrowTip = menuArrowTip.MenuArrowTip;
968
999
  exports.MenuCheckboxItem = menuCheckboxItem.MenuCheckboxItem;
@@ -1379,6 +1410,10 @@ Object.defineProperty(exports, "hoverCardAnatomy", {
1379
1410
  enumerable: true,
1380
1411
  get: () => hoverCard.anatomy
1381
1412
  });
1413
+ Object.defineProperty(exports, "listboxAnatomy", {
1414
+ enumerable: true,
1415
+ get: () => listbox.anatomy
1416
+ });
1382
1417
  Object.defineProperty(exports, "menuAnatomy", {
1383
1418
  enumerable: true,
1384
1419
  get: () => menu.anatomy
package/dist/index.js CHANGED
@@ -291,6 +291,22 @@ export { useHoverCard } from './components/hover-card/use-hover-card.js';
291
291
  export { useHoverCardContext } from './components/hover-card/use-hover-card-context.js';
292
292
  import * as hoverCard from './components/hover-card/hover-card.js';
293
293
  export { hoverCard as HoverCard };
294
+ export { ListboxContent } from './components/listbox/listbox-content.js';
295
+ export { ListboxInput } from './components/listbox/listbox-input.js';
296
+ export { ListboxItem } from './components/listbox/listbox-item.js';
297
+ export { ListboxItemGroup } from './components/listbox/listbox-item-group.js';
298
+ export { ListboxItemGroupLabel } from './components/listbox/listbox-item-group-label.js';
299
+ export { ListboxItemIndicator } from './components/listbox/listbox-item-indicator.js';
300
+ export { ListboxItemText } from './components/listbox/listbox-item-text.js';
301
+ export { ListboxLabel } from './components/listbox/listbox-label.js';
302
+ export { ListboxRoot } from './components/listbox/listbox-root.js';
303
+ export { ListboxRootProvider } from './components/listbox/listbox-root-provider.js';
304
+ export { ListboxValueText } from './components/listbox/listbox-value-text.js';
305
+ export { useListbox } from './components/listbox/use-listbox.js';
306
+ export { useListboxContext } from './components/listbox/use-listbox-context.js';
307
+ export { useListboxItemContext } from './components/listbox/use-listbox-item-context.js';
308
+ import * as listbox from './components/listbox/listbox.js';
309
+ export { listbox as Listbox };
294
310
  export { MenuArrow } from './components/menu/menu-arrow.js';
295
311
  export { MenuArrowTip } from './components/menu/menu-arrow-tip.js';
296
312
  export { MenuCheckboxItem } from './components/menu/menu-checkbox-item.js';
@@ -693,6 +709,7 @@ export { anatomy as editableAnatomy } from '@zag-js/editable';
693
709
  export { anatomy as fileUploadAnatomy } from '@zag-js/file-upload';
694
710
  export { anatomy as floatingPanelAnatomy } from '@zag-js/floating-panel';
695
711
  export { anatomy as hoverCardAnatomy } from '@zag-js/hover-card';
712
+ export { anatomy as listboxAnatomy } from '@zag-js/listbox';
696
713
  export { anatomy as menuAnatomy } from '@zag-js/menu';
697
714
  export { anatomy as numberInputAnatomy } from '@zag-js/number-input';
698
715
  export { anatomy as paginationAnatomy } from '@zag-js/pagination';