@optiaxiom/react 0.4.2 → 0.5.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.
Files changed (219) hide show
  1. package/dist/{Link-DSt1ACyC.d.ts → Link-kkRSxd5_.d.ts} +97 -70
  2. package/dist/assets/src/alert-dialog-content/{AlertDialogContent.css.ts.vanilla-smGvjG2W.css → AlertDialogContent.css.ts.vanilla-DfOEzQyP.css} +11 -11
  3. package/dist/assets/src/alert-dialog-footer/AlertDialogFooter.css.ts.vanilla-DTviko8V.css +6 -0
  4. package/dist/assets/src/autocomplete-content/{AutocompleteContent.css.ts.vanilla-BWEuLmul.css → AutocompleteContent.css.ts.vanilla-yr5VObxv.css} +4 -4
  5. package/dist/assets/src/avatar/Avatar.css.ts.vanilla-7Pz1ShaS.css +28 -0
  6. package/dist/assets/src/badge/Badge.css.ts.vanilla-CsqUU2-u.css +46 -0
  7. package/dist/assets/src/box/{Box.css.ts.vanilla-DXsrXznr.css → Box.css.ts.vanilla-CFbu6ERG.css} +23 -23
  8. package/dist/assets/src/button-base/ButtonBase.css.ts.vanilla-lSreN2s2.css +140 -0
  9. package/dist/assets/src/button-loadable/ButtonLoadable.css.ts.vanilla-DdBJS1WF.css +9 -0
  10. package/dist/assets/src/checkbox/Checkbox.css.ts.vanilla-Kaqr1iOD.css +18 -0
  11. package/dist/assets/src/code/Code.css.ts.vanilla-DXWRlz04.css +7 -0
  12. package/dist/assets/src/data-table/DataTable.css.ts.vanilla-LAGWwD9Q.css +24 -0
  13. package/dist/assets/src/data-table-header/DataTableHeader.css.ts.vanilla-BuEWXyCq.css +12 -0
  14. package/dist/assets/src/dialog-content/{DialogContent.css.ts.vanilla-DQSg_hJt.css → DialogContent.css.ts.vanilla-BkW2dfv7.css} +12 -11
  15. package/dist/assets/src/disclosure-content/DisclosureContent.css.ts.vanilla-a3MAJnGX.css +25 -0
  16. package/dist/assets/src/disclosure-trigger/{DisclosureTrigger.css.ts.vanilla-ubqGTRET.css → DisclosureTrigger.css.ts.vanilla-CcLwBaNn.css} +7 -7
  17. package/dist/assets/src/drawer/{Drawer.css.ts.vanilla-Bc73PiWx.css → Drawer.css.ts.vanilla-CzFuJJPj.css} +8 -8
  18. package/dist/assets/src/highlight/Highlight.css.ts.vanilla-RmkcqM-d.css +7 -0
  19. package/dist/assets/src/hover-card-content/{HoverCardContent.css.ts.vanilla-D36Wbt06.css → HoverCardContent.css.ts.vanilla-ClL_Dtju.css} +3 -3
  20. package/dist/assets/src/indicator/Indicator.css.ts.vanilla-vU_zHe1m.css +35 -0
  21. package/dist/assets/src/input-base/InputBase.css.ts.vanilla-BEcIPkFX.css +90 -0
  22. package/dist/assets/src/kbd/Kbd.css.ts.vanilla-BxwsDOi2.css +9 -0
  23. package/dist/assets/src/layers/layers.css.ts.vanilla-D3upUtFn.css +1 -0
  24. package/dist/assets/src/link/{Link.css.ts.vanilla-DZR3tQvl.css → Link.css.ts.vanilla-DXE3v5di.css} +12 -12
  25. package/dist/assets/src/listbox-base/ListboxBase.css.ts.vanilla-BE3RtL_1.css +21 -0
  26. package/dist/assets/src/listbox-item-base/ListboxItemBase.css.ts.vanilla-Boisr2im.css +38 -0
  27. package/dist/assets/src/pagination/Pagination.css.ts.vanilla-DWprrOvv.css +6 -0
  28. package/dist/assets/src/pill/{Pill.css.ts.vanilla-CRxFu2K1.css → Pill.css.ts.vanilla-DOcl2MuH.css} +4 -4
  29. package/dist/assets/src/radio/Radio.css.ts.vanilla-BPP2aWY8.css +13 -0
  30. package/dist/assets/src/search-input/SearchInput.css.ts.vanilla-DeV6_qAF.css +6 -0
  31. package/dist/assets/src/select-content/SelectContent.css.ts.vanilla-CoRlhWeX.css +7 -0
  32. package/dist/assets/src/separator/{Separator.css.ts.vanilla-BxkwM7qo.css → Separator.css.ts.vanilla-CJz0Fua4.css} +10 -10
  33. package/dist/assets/src/sidenav-item/SidenavItem.css.ts.vanilla-CJTL2biw.css +6 -0
  34. package/dist/assets/src/skeleton/Skeleton.css.ts.vanilla-B0tq9DGQ.css +6 -0
  35. package/dist/assets/src/spotlight-input/SpotlightInput.css.ts.vanilla-DZ9q_EkM.css +6 -0
  36. package/dist/assets/src/spotlight-item/SpotlightItem.css.ts.vanilla-ZQcORnru.css +16 -0
  37. package/dist/assets/src/sprinkles/{properties.css.ts.vanilla-DOIoDpaY.css → properties.css.ts.vanilla-BZCTfveD.css} +2093 -2069
  38. package/dist/assets/src/switch/Switch.css.ts.vanilla-D5JoF6ME.css +26 -0
  39. package/dist/assets/src/table/{Table.css.ts.vanilla-94W1cxLN.css → Table.css.ts.vanilla-BRz2D7_P.css} +4 -4
  40. package/dist/assets/src/table-body/TableBody.css.ts.vanilla-BADc-26Z.css +6 -0
  41. package/dist/assets/src/table-cell/{TableCell.css.ts.vanilla-Zz530aGT.css → TableCell.css.ts.vanilla-BQ545diF.css} +4 -4
  42. package/dist/assets/src/table-header-cell/TableHeaderCell.css.ts.vanilla-DboxB76f.css +6 -0
  43. package/dist/assets/src/table-row/TableRow.css.ts.vanilla-COI_-mI5.css +4 -0
  44. package/dist/assets/src/tabs/Tabs.css.ts.vanilla-D7c9aAFv.css +9 -0
  45. package/dist/assets/src/tabs-list/TabsList.css.ts.vanilla-hJFJS54O.css +23 -0
  46. package/dist/assets/src/tabs-trigger/{TabsTrigger.css.ts.vanilla-CVssx0q-.css → TabsTrigger.css.ts.vanilla-Crjg7nwP.css} +10 -10
  47. package/dist/assets/src/text/{Text.css.ts.vanilla-B4gZFG-2.css → Text.css.ts.vanilla-xxaGuRxa.css} +8 -8
  48. package/dist/assets/src/textarea-autosize/TextareaAutosize.css.ts.vanilla-DIlxSuuv.css +34 -0
  49. package/dist/assets/src/toast/Toast.css.ts.vanilla-B8N3Ss56.css +92 -0
  50. package/dist/assets/src/toast-provider/{ToastProvider.css.ts.vanilla-B7r1EWKp.css → ToastProvider.css.ts.vanilla-hbD7r5bf.css} +9 -9
  51. package/dist/assets/src/toggle-input/ToggleInput.css.ts.vanilla-llCUpF4m.css +23 -0
  52. package/dist/assets/src/toggle-input-control/ToggleInputControl.css.ts.vanilla-DYEoiGw8.css +10 -0
  53. package/dist/assets/src/transition/{Transition.css.ts.vanilla-CVuwRXvD.css → Transition.css.ts.vanilla-CAw7P9Kw.css} +16 -16
  54. package/dist/index.d.ts +98 -89
  55. package/dist/index.js +3 -0
  56. package/dist/package.json.js +1 -1
  57. package/dist/src/alert/Alert-css.js +3 -3
  58. package/dist/src/alert/Alert.js +4 -4
  59. package/dist/src/alert-dialog-action/AlertDialogAction.js +2 -6
  60. package/dist/src/alert-dialog-cancel/AlertDialogCancel.js +2 -6
  61. package/dist/src/alert-dialog-content/AlertDialogContent-css.js +6 -5
  62. package/dist/src/alert-dialog-content/AlertDialogContent.js +8 -2
  63. package/dist/src/alert-dialog-description/AlertDialogDescription-css.js +1 -1
  64. package/dist/src/alert-dialog-footer/AlertDialogFooter-css.js +3 -3
  65. package/dist/src/alert-dialog-trigger/AlertDialogTrigger.js +1 -5
  66. package/dist/src/autocomplete-content/AutocompleteContent-css.js +3 -3
  67. package/dist/src/autocomplete-empty/AutocompleteEmpty.js +5 -8
  68. package/dist/src/autocomplete-trigger/AutocompleteTrigger.js +1 -1
  69. package/dist/src/avatar/Avatar-css.js +4 -4
  70. package/dist/src/avatar-group/AvatarGroup-css.js +3 -3
  71. package/dist/src/badge/Badge-css.js +3 -3
  72. package/dist/src/badge/Badge.js +2 -2
  73. package/dist/src/banner/Banner-css.js +3 -3
  74. package/dist/src/banner/Banner.js +4 -4
  75. package/dist/src/box/Box-css.js +3 -3
  76. package/dist/src/button/Button.js +8 -3
  77. package/dist/src/button-addon/ButtonAddon.js +13 -0
  78. package/dist/src/button-base/ButtonBase-css.js +5 -5
  79. package/dist/src/button-base/ButtonBase.js +11 -13
  80. package/dist/src/button-group/ButtonGroup-css.js +3 -3
  81. package/dist/src/button-loadable/ButtonLoadable-css.js +5 -5
  82. package/dist/src/checkbox/Checkbox-css.js +8 -8
  83. package/dist/src/code/Code-css.js +3 -3
  84. package/dist/src/combobox/Combobox.js +43 -3
  85. package/dist/src/combobox-content/ComboboxContent.js +13 -6
  86. package/dist/src/combobox-input/ComboboxInput.js +22 -1
  87. package/dist/src/combobox-trigger/ComboboxTrigger.js +2 -3
  88. package/dist/src/combobox-value/ComboboxValue.js +29 -6
  89. package/dist/src/command/Command.js +12 -14
  90. package/dist/src/command-checkbox-item/CommandCheckboxItem.js +5 -2
  91. package/dist/src/command-empty/CommandEmpty.js +1 -1
  92. package/dist/src/command-footer/CommandFooter.js +15 -3
  93. package/dist/src/command-input/CommandInput.js +3 -8
  94. package/dist/src/command-item/CommandItem.js +23 -17
  95. package/dist/src/command-separator/CommandSeparator.js +1 -1
  96. package/dist/src/data-table/DataTable-css.js +7 -7
  97. package/dist/src/data-table-header/DataTableHeader-css.js +4 -4
  98. package/dist/src/dialog-body/DialogBody-css.js +1 -1
  99. package/dist/src/dialog-close/DialogClose.js +1 -5
  100. package/dist/src/dialog-content/DialogContent-css.js +5 -5
  101. package/dist/src/dialog-content/DialogContent.js +9 -2
  102. package/dist/src/dialog-footer/DialogFooter-css.js +1 -1
  103. package/dist/src/dialog-trigger/DialogTrigger.js +1 -5
  104. package/dist/src/disclosure-content/DisclosureContent-css.js +3 -3
  105. package/dist/src/disclosure-trigger/DisclosureTrigger-css.js +4 -4
  106. package/dist/src/drawer/Drawer-css.js +5 -5
  107. package/dist/src/filtered-slot/FilteredSlot.js +13 -0
  108. package/dist/src/highlight/Highlight-css.js +7 -0
  109. package/dist/src/highlight/Highlight.js +20 -0
  110. package/dist/src/highlight/useHighlightedChunks.js +23 -0
  111. package/dist/src/hover-card-content/HoverCardContent-css.js +3 -3
  112. package/dist/src/hover-card-trigger/HoverCardTrigger.js +3 -7
  113. package/dist/src/indicator/Indicator-css.js +5 -5
  114. package/dist/src/indicator/Indicator.js +3 -3
  115. package/dist/src/input/Input-css.js +5 -5
  116. package/dist/src/input/Input.js +6 -4
  117. package/dist/src/input-base/InputBase-css.js +5 -5
  118. package/dist/src/input-base/InputBase.js +6 -4
  119. package/dist/src/kbd/Kbd-css.js +3 -3
  120. package/dist/src/layers/layers-css.js +3 -3
  121. package/dist/src/link/Link-css.js +4 -4
  122. package/dist/src/link/Link.js +5 -2
  123. package/dist/src/listbox-base/ListboxBase-css.js +3 -3
  124. package/dist/src/listbox-item-base/ListboxItemBase-css.js +6 -4
  125. package/dist/src/listbox-item-base/ListboxItemBase.js +8 -8
  126. package/dist/src/pagination/Pagination-css.js +3 -3
  127. package/dist/src/pagination/Pagination.js +41 -27
  128. package/dist/src/pill/Pill-css.js +3 -3
  129. package/dist/src/radio/Radio-css.js +8 -8
  130. package/dist/src/search-input/SearchInput-css.js +4 -4
  131. package/dist/src/select-content/SelectContent-css.js +3 -3
  132. package/dist/src/select-group/SelectGroup.js +15 -0
  133. package/dist/src/select-group-context/SelectGroupContext.js +5 -0
  134. package/dist/src/select-label/SelectLabel.js +5 -3
  135. package/dist/src/select-separator/SelectSeparator.js +11 -1
  136. package/dist/src/separator/Separator-css.js +3 -3
  137. package/dist/src/sidenav/Sidenav.js +2 -21
  138. package/dist/src/sidenav-content/SidenavContent.js +30 -0
  139. package/dist/src/sidenav-footer/SidenavFooter.js +27 -0
  140. package/dist/src/sidenav-header/SidenavHeader.js +16 -0
  141. package/dist/src/sidenav-item/SidenavItem-css.js +5 -5
  142. package/dist/src/skeleton/Skeleton-css.js +3 -3
  143. package/dist/src/spinner/Spinner.js +5 -5
  144. package/dist/src/spotlight/Spotlight.js +53 -0
  145. package/dist/src/spotlight-content/SpotlightContent.js +48 -0
  146. package/dist/src/spotlight-context/SpotlightContext.js +5 -0
  147. package/dist/src/spotlight-empty/SpotlightEmpty.js +12 -0
  148. package/dist/src/spotlight-input/SpotlightInput-css.js +7 -0
  149. package/dist/src/spotlight-input/SpotlightInput.js +25 -0
  150. package/dist/src/spotlight-item/SpotlightItem-css.js +8 -0
  151. package/dist/src/spotlight-item/SpotlightItem.js +24 -0
  152. package/dist/src/spotlight-label/SpotlightLabel.js +29 -0
  153. package/dist/src/spotlight-list/SpotlightList.js +12 -0
  154. package/dist/src/spotlight-trigger/SpotlightTrigger.js +39 -0
  155. package/dist/src/sprinkles/properties-css.js +4 -4
  156. package/dist/src/switch/Switch-css.js +8 -8
  157. package/dist/src/table/Table-css.js +4 -4
  158. package/dist/src/table-body/TableBody-css.js +3 -3
  159. package/dist/src/table-cell/TableCell-css.js +4 -4
  160. package/dist/src/table-header-cell/TableHeaderCell-css.js +3 -3
  161. package/dist/src/table-row/TableRow-css.js +3 -3
  162. package/dist/src/tabs/Tabs-css.js +3 -3
  163. package/dist/src/tabs-list/TabsList-css.js +3 -3
  164. package/dist/src/tabs-trigger/TabsTrigger-css.js +4 -4
  165. package/dist/src/text/Text-css.js +3 -3
  166. package/dist/src/textarea/Textarea.js +2 -1
  167. package/dist/src/textarea-autosize/TextareaAutosize-css.js +5 -5
  168. package/dist/src/textarea-autosize/TextareaAutosize.js +6 -4
  169. package/dist/src/toast/Toast-css.js +5 -5
  170. package/dist/src/toast/Toast.js +5 -5
  171. package/dist/src/toast-provider/ToastProvider-css.js +3 -3
  172. package/dist/src/toast-provider/ToastProvider.js +1 -1
  173. package/dist/src/toggle-input/ToggleInput-css.js +4 -4
  174. package/dist/src/toggle-input-control/ToggleInputControl-css.js +5 -5
  175. package/dist/src/toggle-input-hidden-input/ToggleInputHiddenInput-css.js +3 -3
  176. package/dist/src/tooltip-content/TooltipContent-css.js +1 -1
  177. package/dist/src/tooltip-trigger/TooltipTrigger.js +2 -5
  178. package/dist/src/transition/Transition-css.js +3 -3
  179. package/dist/src/use-responsive-matches/useResponsiveMatches.js +22 -0
  180. package/dist/src/utils/conditions.js +4 -2
  181. package/dist/unstable.d.ts +186 -54
  182. package/dist/unstable.js +10 -0
  183. package/package.json +1 -1
  184. package/dist/assets/src/alert-dialog-footer/AlertDialogFooter.css.ts.vanilla-EDbgAUpH.css +0 -6
  185. package/dist/assets/src/avatar/Avatar.css.ts.vanilla-DFwfPXh5.css +0 -28
  186. package/dist/assets/src/badge/Badge.css.ts.vanilla-DkeeO3hp.css +0 -46
  187. package/dist/assets/src/button-base/ButtonBase.css.ts.vanilla-CbhXWBhY.css +0 -140
  188. package/dist/assets/src/button-loadable/ButtonLoadable.css.ts.vanilla-C4Loni8x.css +0 -9
  189. package/dist/assets/src/checkbox/Checkbox.css.ts.vanilla-atE0BHRf.css +0 -18
  190. package/dist/assets/src/code/Code.css.ts.vanilla-BokaFw0b.css +0 -7
  191. package/dist/assets/src/data-table/DataTable.css.ts.vanilla-Dl7V0kqj.css +0 -24
  192. package/dist/assets/src/data-table-header/DataTableHeader.css.ts.vanilla-BqcsCuQU.css +0 -12
  193. package/dist/assets/src/disclosure-content/DisclosureContent.css.ts.vanilla-DZGY_b0f.css +0 -25
  194. package/dist/assets/src/indicator/Indicator.css.ts.vanilla-D3ExxWPL.css +0 -35
  195. package/dist/assets/src/input/Input.css.ts.vanilla-qUnBToWI.css +0 -15
  196. package/dist/assets/src/input-base/InputBase.css.ts.vanilla-Qg9a2v5X.css +0 -87
  197. package/dist/assets/src/kbd/Kbd.css.ts.vanilla-CJhUGxYX.css +0 -9
  198. package/dist/assets/src/layers/layers.css.ts.vanilla-C0SoXsdY.css +0 -1
  199. package/dist/assets/src/listbox-base/ListboxBase.css.ts.vanilla-DKxtbiF8.css +0 -21
  200. package/dist/assets/src/listbox-item-base/ListboxItemBase.css.ts.vanilla-BVQ-U1yL.css +0 -30
  201. package/dist/assets/src/pagination/Pagination.css.ts.vanilla-BIEvtX5-.css +0 -6
  202. package/dist/assets/src/radio/Radio.css.ts.vanilla-DWN9BvL_.css +0 -13
  203. package/dist/assets/src/search-input/SearchInput.css.ts.vanilla-DyfBXRnr.css +0 -6
  204. package/dist/assets/src/select-content/SelectContent.css.ts.vanilla-DzQIYsrh.css +0 -7
  205. package/dist/assets/src/sidenav-item/SidenavItem.css.ts.vanilla-za4fE3C2.css +0 -6
  206. package/dist/assets/src/skeleton/Skeleton.css.ts.vanilla-BzoSQC9k.css +0 -6
  207. package/dist/assets/src/switch/Switch.css.ts.vanilla-B3UIwExm.css +0 -26
  208. package/dist/assets/src/table-body/TableBody.css.ts.vanilla-ByuslKwG.css +0 -6
  209. package/dist/assets/src/table-header-cell/TableHeaderCell.css.ts.vanilla-CVy9FZZS.css +0 -6
  210. package/dist/assets/src/table-row/TableRow.css.ts.vanilla-C8nEvBep.css +0 -4
  211. package/dist/assets/src/tabs/Tabs.css.ts.vanilla-AqkJqHOu.css +0 -9
  212. package/dist/assets/src/tabs-list/TabsList.css.ts.vanilla-8Bg2hQwp.css +0 -23
  213. package/dist/assets/src/textarea-autosize/TextareaAutosize.css.ts.vanilla-DbiBLo-Y.css +0 -34
  214. package/dist/assets/src/toast/Toast.css.ts.vanilla-CZhgjlMn.css +0 -92
  215. package/dist/assets/src/toggle-input/ToggleInput.css.ts.vanilla-B5zW77Q6.css +0 -23
  216. package/dist/assets/src/toggle-input-control/ToggleInputControl.css.ts.vanilla-B8-6yg8T.css +0 -10
  217. package/dist/src/combobox-multiple-value/ComboboxMultipleValue.js +0 -31
  218. package/dist/src/combobox-single-value/ComboboxSingleValue.js +0 -12
  219. package/dist/src/command-footer/CommandFooter-css.js +0 -6
@@ -4,25 +4,31 @@ import { useComboboxContext } from '../combobox-context/ComboboxContext.js';
4
4
  import { Command } from '../command/Command.js';
5
5
  import '../field-context/FieldContext.js';
6
6
  import { useFieldContext } from '../field-context/useFieldContext.js';
7
- import { PopoverContent } from '../popover-content/PopoverContent.js';
7
+ import { useResponsiveMatches } from '../use-responsive-matches/useResponsiveMatches.js';
8
8
 
9
9
  const ComboboxContent = forwardRef(
10
- ({ children, ...props }, ref) => {
10
+ ({ children, size: _size, ...props }, ref) => {
11
+ const p = useResponsiveMatches({
12
+ base: "8",
13
+ sm: "4"
14
+ });
11
15
  const { labelId } = useFieldContext();
12
16
  const {
17
+ components,
13
18
  isItemDisabled,
14
19
  items,
15
20
  itemToKey,
16
21
  itemToString,
17
22
  onInputValueChange,
18
- onSelect
23
+ onItemSelect,
24
+ value
19
25
  } = useComboboxContext("ComboboxContent");
20
26
  return /* @__PURE__ */ jsx(
21
- PopoverContent,
27
+ components.Content,
22
28
  {
23
29
  "aria-labelledby": labelId,
24
30
  overflow: "hidden",
25
- p: "4",
31
+ p,
26
32
  ref,
27
33
  ...props,
28
34
  children: /* @__PURE__ */ jsx(
@@ -33,7 +39,8 @@ const ComboboxContent = forwardRef(
33
39
  itemToKey,
34
40
  itemToString,
35
41
  onInputValueChange,
36
- onSelect,
42
+ onItemSelect,
43
+ value,
37
44
  children
38
45
  }
39
46
  )
@@ -1,6 +1,27 @@
1
+ import { jsx } from 'react/jsx-runtime';
2
+ import { forwardRef } from 'react';
3
+ import { useCommandContext } from '../command-context/CommandContext.js';
1
4
  import { CommandInput } from '../command-input/CommandInput.js';
2
5
 
3
- const ComboboxInput = CommandInput;
6
+ const ComboboxInput = forwardRef(
7
+ (props, ref) => {
8
+ const { downshift, highlightedItem } = useCommandContext("ComboboxInput");
9
+ return /* @__PURE__ */ jsx(
10
+ CommandInput,
11
+ {
12
+ m: "4",
13
+ onKeyDown: (event) => {
14
+ if (event.key === " " && highlightedItem) {
15
+ event.preventDefault();
16
+ downshift.selectItem(highlightedItem);
17
+ }
18
+ },
19
+ ref,
20
+ ...props
21
+ }
22
+ );
23
+ }
24
+ );
4
25
  ComboboxInput.displayName = "@optiaxiom/react/ComboboxInput";
5
26
 
6
27
  export { ComboboxInput };
@@ -5,10 +5,9 @@ import { useComboboxContext } from '../combobox-context/ComboboxContext.js';
5
5
  import '../field-context/FieldContext.js';
6
6
  import { useFieldContext } from '../field-context/useFieldContext.js';
7
7
  import { MenuButton } from '../menu-button/MenuButton.js';
8
- import { PopoverTrigger } from '../popover-trigger/PopoverTrigger.js';
9
8
 
10
9
  const ComboboxTrigger = forwardRef(({ asChild, children, ...props }, outerRef) => {
11
- const { setOpen } = useComboboxContext("ComboboxTrigger");
10
+ const { components, setOpen } = useComboboxContext("ComboboxTrigger");
12
11
  const buttonRef = useRef(null);
13
12
  const ref = useComposedRefs(outerRef, buttonRef);
14
13
  const { labelId } = useFieldContext();
@@ -26,7 +25,7 @@ const ComboboxTrigger = forwardRef(({ asChild, children, ...props }, outerRef) =
26
25
  return () => label.removeEventListener("click", onLabelClick);
27
26
  }, [labelId]);
28
27
  return /* @__PURE__ */ jsx(
29
- PopoverTrigger,
28
+ components.Trigger,
30
29
  {
31
30
  "aria-labelledby": labelId,
32
31
  asChild: true,
@@ -1,11 +1,34 @@
1
- import { jsx } from 'react/jsx-runtime';
2
- import { forwardRef } from 'react';
3
- import { ComboboxMultipleValue } from '../combobox-multiple-value/ComboboxMultipleValue.js';
4
- import { ComboboxSingleValue } from '../combobox-single-value/ComboboxSingleValue.js';
1
+ import { jsx, Fragment, jsxs } from 'react/jsx-runtime';
2
+ import { forwardRef, useMemo } from 'react';
3
+ import { Badge } from '../badge/Badge.js';
4
+ import { useComboboxContext } from '../combobox-context/ComboboxContext.js';
5
+ import { Flex } from '../flex/Flex.js';
5
6
 
7
+ const maxDisplayedItems = 2;
6
8
  const ComboboxValue = forwardRef(
7
- (props, ref) => {
8
- return props.type === "multiple" ? /* @__PURE__ */ jsx(ComboboxMultipleValue, { ref, ...props }) : /* @__PURE__ */ jsx(ComboboxSingleValue, { ref, ...props });
9
+ ({ children, placeholder, ...props }, ref) => {
10
+ const {
11
+ itemToKey,
12
+ itemToString,
13
+ value: valueContext
14
+ } = useComboboxContext("ComboboxValue");
15
+ const value = useMemo(
16
+ () => valueContext instanceof Set ? [...valueContext] : valueContext,
17
+ [valueContext]
18
+ );
19
+ return /* @__PURE__ */ jsx(Flex, { flexDirection: "row", flexWrap: "wrap", gap: "2", ref, ...props, children: Array.isArray(value) && value.length > 0 ? children ?? /* @__PURE__ */ jsx(Fragment, { children: value.length > maxDisplayedItems ? /* @__PURE__ */ jsxs(Badge, { children: [
20
+ value.length,
21
+ " selected"
22
+ ] }) : value.slice(0, maxDisplayedItems).map((item) => /* @__PURE__ */ jsx(
23
+ Badge,
24
+ {
25
+ display: "inline-block",
26
+ flex: "1",
27
+ truncate: true,
28
+ children: itemToString(item)
29
+ },
30
+ itemToKey(item)
31
+ )) }) : placeholder });
9
32
  }
10
33
  );
11
34
  ComboboxValue.displayName = "@optiaxiom/react/ComboboxValue";
@@ -1,28 +1,29 @@
1
1
  import { jsx } from 'react/jsx-runtime';
2
2
  import { useControllableState } from '@radix-ui/react-use-controllable-state';
3
3
  import { useCombobox } from 'downshift';
4
- import { useEffect } from 'react';
4
+ import { useMemo } from 'react';
5
5
  import { CommandContextProvider } from '../command-context/CommandContext.js';
6
6
 
7
7
  function Command({
8
8
  children,
9
+ inputValue: inputValueProp,
9
10
  isItemDisabled = () => false,
10
11
  items,
11
12
  itemToKey = (value) => value,
12
13
  itemToString = (value) => value ? String(value) : "",
13
14
  onInputValueChange,
14
- onOpenChange,
15
- onSelect
15
+ onItemSelect,
16
+ value: valueProp
16
17
  }) {
18
+ const value = useMemo(
19
+ () => Array.isArray(valueProp) ? new Set(valueProp) : valueProp,
20
+ [valueProp]
21
+ );
17
22
  const [inputValue, setInputValue] = useControllableState({
18
23
  defaultProp: "",
19
- onChange: onInputValueChange
24
+ onChange: onInputValueChange,
25
+ prop: inputValueProp
20
26
  });
21
- useEffect(() => {
22
- return () => {
23
- setInputValue("");
24
- };
25
- }, [setInputValue]);
26
27
  const downshift = useCombobox({
27
28
  inputValue,
28
29
  isItemDisabled,
@@ -32,7 +33,7 @@ function Command({
32
33
  itemToString,
33
34
  onSelectedItemChange({ selectedItem, type }) {
34
35
  if (type !== useCombobox.stateChangeTypes.InputBlur) {
35
- onSelect?.(selectedItem);
36
+ onItemSelect?.(selectedItem);
36
37
  }
37
38
  },
38
39
  selectedItem: null,
@@ -60,11 +61,8 @@ function Command({
60
61
  highlightedItem: items[downshift.highlightedIndex],
61
62
  isItemDisabled,
62
63
  items,
63
- itemToKey,
64
- itemToString,
65
64
  setInputValue,
66
- setOpen: onOpenChange,
67
- setValue: onSelect,
65
+ value,
68
66
  children
69
67
  }
70
68
  );
@@ -6,7 +6,9 @@ import { CommandItem } from '../command-item/CommandItem.js';
6
6
  import { Flex } from '../flex/Flex.js';
7
7
 
8
8
  const CommandCheckboxItem = forwardRef(({ addonBefore, ...props }, ref) => {
9
- const { isItemDisabled, items } = useCommandContext("CommandCheckboxItem");
9
+ const { isItemDisabled, items, value } = useCommandContext(
10
+ "CommandCheckboxItem"
11
+ );
10
12
  return /* @__PURE__ */ jsx(
11
13
  CommandItem,
12
14
  {
@@ -14,8 +16,9 @@ const CommandCheckboxItem = forwardRef(({ addonBefore, ...props }, ref) => {
14
16
  /* @__PURE__ */ jsx(
15
17
  Checkbox,
16
18
  {
17
- checked: props.active,
19
+ checked: props.active ?? value?.has(props.item),
18
20
  disabled: isItemDisabled(props.item, items.indexOf(props.item)),
21
+ pointerEvents: "none",
19
22
  tabIndex: -1
20
23
  }
21
24
  ),
@@ -15,8 +15,8 @@ const CommandEmpty = forwardRef(
15
15
  alignItems: "center",
16
16
  color: "fg.disabled",
17
17
  display: "flex",
18
+ flexDirection: "column",
18
19
  fontSize: "md",
19
- justifyContent: "center",
20
20
  p: "md",
21
21
  ref,
22
22
  ...props,
@@ -1,11 +1,23 @@
1
1
  import { jsx } from 'react/jsx-runtime';
2
2
  import { forwardRef } from 'react';
3
3
  import { Flex } from '../flex/Flex.js';
4
- import { footer } from './CommandFooter-css.js';
5
4
 
6
5
  const CommandFooter = forwardRef(
7
- ({ children, className, ...props }, ref) => {
8
- return /* @__PURE__ */ jsx(Flex, { asChild: true, ref, ...footer({}, className), ...props, children: /* @__PURE__ */ jsx("li", { children }) });
6
+ ({ children, ...props }, ref) => {
7
+ return /* @__PURE__ */ jsx(
8
+ Flex,
9
+ {
10
+ borderColor: "border.secondary",
11
+ borderT: "1",
12
+ flexDirection: "row",
13
+ gap: "md",
14
+ justifyContent: "space-between",
15
+ p: "sm",
16
+ ref,
17
+ ...props,
18
+ children
19
+ }
20
+ );
9
21
  }
10
22
  );
11
23
  CommandFooter.displayName = "@optiaxiom/react/CommandFooter";
@@ -1,6 +1,7 @@
1
1
  import { jsx } from 'react/jsx-runtime';
2
2
  import { forwardRef } from 'react';
3
3
  import { useCommandContext } from '../command-context/CommandContext.js';
4
+ import { IconMagnifyingGlass } from '../icons/IconMagnifyingGlass.js';
4
5
  import { Input } from '../input/Input.js';
5
6
  import { extractSprinkles } from '../sprinkles/extractSprinkles.js';
6
7
  import '../sprinkles/sprinkles.js';
@@ -9,23 +10,17 @@ import '../sprinkles/sprinklesMerge.js';
9
10
  const CommandInput = forwardRef(
10
11
  (props, ref) => {
11
12
  const { restProps, sprinkleProps } = extractSprinkles(props);
12
- const { downshift, highlightedItem, setInputValue } = useCommandContext("CommandInput");
13
+ const { downshift, setInputValue } = useCommandContext("CommandInput");
13
14
  return /* @__PURE__ */ jsx(
14
15
  Input,
15
16
  {
16
- m: "4",
17
+ addonBefore: /* @__PURE__ */ jsx(IconMagnifyingGlass, {}),
17
18
  ...sprinkleProps,
18
19
  ...downshift.getInputProps({
19
20
  ...restProps,
20
21
  onChange: (event) => {
21
22
  setInputValue("value" in event.target ? event.target.value : "");
22
23
  },
23
- onKeyDown: (event) => {
24
- if (event.key === " " && highlightedItem) {
25
- event.preventDefault();
26
- downshift.selectItem(highlightedItem);
27
- }
28
- },
29
24
  ref
30
25
  })
31
26
  }
@@ -19,30 +19,36 @@ const CommandItem = forwardRef(
19
19
  ...props
20
20
  }, ref) => {
21
21
  const { restProps, sprinkleProps } = extractSprinkles(props);
22
- const { downshift, highlightedItem } = useCommandContext("CommandItem");
22
+ const { downshift, highlightedItem, value } = useCommandContext("CommandItem");
23
23
  const itemProps = downshift.getItemProps({ item });
24
- return /* @__PURE__ */ jsx(CommandItemContextProvider, { active, item, children: /* @__PURE__ */ jsx(
25
- ListboxItemBase,
24
+ return /* @__PURE__ */ jsx(
25
+ CommandItemContextProvider,
26
26
  {
27
- addonAfter,
28
- addonBefore,
29
- description,
30
- icon,
31
- ...sprinkleProps,
27
+ active: active ?? value?.has(item),
28
+ item,
32
29
  children: /* @__PURE__ */ jsx(
33
- "li",
30
+ ListboxItemBase,
34
31
  {
35
- "data-disabled": itemProps["aria-disabled"] ? "" : void 0,
36
- "data-highlighted": highlightedItem === item ? "" : void 0,
37
- "data-selected": downshift.selectedItem === item ? "" : void 0,
38
- ref,
39
- ...restProps,
40
- ...itemProps,
41
- children
32
+ addonAfter,
33
+ addonBefore,
34
+ description,
35
+ icon,
36
+ ...sprinkleProps,
37
+ children: /* @__PURE__ */ jsx(
38
+ "li",
39
+ {
40
+ "data-disabled": itemProps["aria-disabled"] ? "" : void 0,
41
+ "data-highlighted": highlightedItem === item ? "" : void 0,
42
+ ref,
43
+ ...restProps,
44
+ ...itemProps,
45
+ children
46
+ }
47
+ )
42
48
  }
43
49
  )
44
50
  }
45
- ) });
51
+ );
46
52
  }
47
53
  );
48
54
  CommandItem.displayName = "@optiaxiom/react/CommandItem";
@@ -3,7 +3,7 @@ import { forwardRef } from 'react';
3
3
  import { Box } from '../box/Box.js';
4
4
  import { Separator } from '../separator/Separator.js';
5
5
 
6
- const CommandSeparator = forwardRef((props, ref) => /* @__PURE__ */ jsx(Box, { asChild: true, children: /* @__PURE__ */ jsx("li", { ref, children: /* @__PURE__ */ jsx(Separator, { asChild: true, bg: "border.secondary", mx: "-4", my: "2", ...props }) }) }));
6
+ const CommandSeparator = forwardRef((props, ref) => /* @__PURE__ */ jsx(Box, { asChild: true, children: /* @__PURE__ */ jsx("li", { ref, children: /* @__PURE__ */ jsx(Separator, { asChild: true, bg: "border.secondary", mx: "8", my: "4", ...props }) }) }));
7
7
  CommandSeparator.displayName = "@optiaxiom/react/CommandSeparator";
8
8
 
9
9
  export { CommandSeparator };
@@ -1,11 +1,11 @@
1
- import './../../assets/src/layers/layers.css.ts.vanilla-C0SoXsdY.css';
2
- import './../../assets/src/data-table/DataTable.css.ts.vanilla-Dl7V0kqj.css';
1
+ import './../../assets/src/layers/layers.css.ts.vanilla-D3upUtFn.css';
2
+ import './../../assets/src/data-table/DataTable.css.ts.vanilla-LAGWwD9Q.css';
3
3
  import { recipeRuntime } from '../vanilla-extract/recipeRuntime.js';
4
4
 
5
- var cellOffsetVar = 'var(--ka4x4e)';
6
- var columnWidthVar = 'var(--_1mxez1b)';
7
- var tableCell = recipeRuntime({base:[{bg:'bg.default'},'ptg7g1'],variants:{pinned:{false:{},left:'_1n3ls3z',right:{}}}});
8
- var tableHead = recipeRuntime({base:[{bg:'bg.default'},'_1x5px21'],variants:{pinned:{false:{},left:'_18j6gq8',right:{}}}});
9
- var tableHeader = recipeRuntime({base:[{bg:'bg.default'},'_1pp786x']});
5
+ var cellOffsetVar = 'var(--_6bb585)';
6
+ var columnWidthVar = 'var(--_110mhe6)';
7
+ var tableCell = recipeRuntime({base:[{bg:'bg.default'},'_1ekd9c3'],variants:{pinned:{false:{},left:'_1dfdde9',right:{}}}});
8
+ var tableHead = recipeRuntime({base:[{bg:'bg.default'},'z0vt9'],variants:{pinned:{false:{},left:'_1rvdnhz',right:{}}}});
9
+ var tableHeader = recipeRuntime({base:[{bg:'bg.default'},'_1odoan6']});
10
10
 
11
11
  export { cellOffsetVar, columnWidthVar, tableCell, tableHead, tableHeader };
@@ -1,8 +1,8 @@
1
- import './../../assets/src/layers/layers.css.ts.vanilla-C0SoXsdY.css';
2
- import './../../assets/src/data-table-header/DataTableHeader.css.ts.vanilla-BqcsCuQU.css';
1
+ import './../../assets/src/layers/layers.css.ts.vanilla-D3upUtFn.css';
2
+ import './../../assets/src/data-table-header/DataTableHeader.css.ts.vanilla-BuEWXyCq.css';
3
3
  import { recipeRuntime } from '../vanilla-extract/recipeRuntime.js';
4
4
 
5
- var header = recipeRuntime({base:[{gap:'4'},'lwps0o'],variants:{sortable:{false:'bwycvz',true:'_1a5f7ds'},variant:{number:{flexDirection:'row-reverse',justifyContent:'end'},text:{flexDirection:'row'}}}});
6
- var icon = recipeRuntime({base:[{border:'0',color:'fg.tertiary'}],variants:{sorted:{false:'_1e54nrz',true:{}}}});
5
+ var header = recipeRuntime({base:[{gap:'4'},'_1ooamw6'],variants:{sortable:{false:'_1i5coyv',true:'cpep53'},variant:{number:{flexDirection:'row-reverse',justifyContent:'end'},text:{flexDirection:'row'}}}});
6
+ var icon = recipeRuntime({base:[{border:'0',color:'fg.tertiary'}],variants:{sorted:{false:'frrvp9',true:{}}}});
7
7
 
8
8
  export { header, icon };
@@ -1,4 +1,4 @@
1
- import './../../assets/src/layers/layers.css.ts.vanilla-C0SoXsdY.css';
1
+ import './../../assets/src/layers/layers.css.ts.vanilla-D3upUtFn.css';
2
2
  import { recipeRuntime } from '../vanilla-extract/recipeRuntime.js';
3
3
 
4
4
  var body = recipeRuntime({base:[{flex:'1',fontSize:'md',overflow:'auto',pb:'md',pt:'lg',px:'lg'}]});
@@ -2,14 +2,10 @@ import { jsx } from 'react/jsx-runtime';
2
2
  import * as RadixDialog from '@radix-ui/react-dialog';
3
3
  import { forwardRef } from 'react';
4
4
  import { Button } from '../button/Button.js';
5
- import { extractSprinkles } from '../sprinkles/extractSprinkles.js';
6
- import '../sprinkles/sprinkles.js';
7
- import '../sprinkles/sprinklesMerge.js';
8
5
 
9
6
  const DialogClose = forwardRef(
10
7
  ({ asChild, children, ...props }, ref) => {
11
- const { restProps, sprinkleProps } = extractSprinkles(props);
12
- return /* @__PURE__ */ jsx(RadixDialog.Close, { asChild: true, ref, ...sprinkleProps, children: asChild ? children : /* @__PURE__ */ jsx(Button, { ...restProps, children }) });
8
+ return /* @__PURE__ */ jsx(RadixDialog.Close, { asChild: true, ref, ...props, children: asChild ? children : /* @__PURE__ */ jsx(Button, { children }) });
13
9
  }
14
10
  );
15
11
  DialogClose.displayName = "@optiaxiom/react/DialogClose";
@@ -1,9 +1,9 @@
1
- import './../../assets/src/layers/layers.css.ts.vanilla-C0SoXsdY.css';
2
- import './../../assets/src/dialog-content/DialogContent.css.ts.vanilla-DQSg_hJt.css';
1
+ import './../../assets/src/layers/layers.css.ts.vanilla-D3upUtFn.css';
2
+ import './../../assets/src/dialog-content/DialogContent.css.ts.vanilla-BkW2dfv7.css';
3
3
  import { recipeRuntime } from '../vanilla-extract/recipeRuntime.js';
4
4
 
5
- var close = recipeRuntime({base:[{rounded:'full'},'_11kctjz']});
6
- var content = recipeRuntime({base:[{bg:'bg.default',display:'flex',flexDirection:'column',shadow:'md',z:'popover'},'t2s4cp'],variants:{size:{sm:'_1vvwapg',md:'_1op8820',lg:'_1o4h3bl',fullscreen:'_1ovmnbz'}}});
7
- var overlay = recipeRuntime({base:[{bg:'bg.overlay',z:'popover'},'_1os8fh6']});
5
+ var close = recipeRuntime({base:[{rounded:'full'},'a935ko']});
6
+ var content = recipeRuntime({base:[{bg:'bg.default',display:'flex',flexDirection:'column',shadow:'md',z:'popover'},'_5k038e'],variants:{size:{sm:'_8rg9kj',md:'_1oz9csn',lg:'l4u3vf',fullscreen:'_1rpdam6'}}});
7
+ var overlay = recipeRuntime({base:[{bg:'bg.overlay',z:'popover'},'_53pymh']});
8
8
 
9
9
  export { close, content, overlay };
@@ -10,11 +10,18 @@ import { Transition } from '../transition/Transition.js';
10
10
  import { overlay, content, close } from './DialogContent-css.js';
11
11
 
12
12
  const DialogContent = forwardRef(
13
- ({ children, size = "md", withCloseButton = false, ...props }, ref) => {
13
+ ({
14
+ children,
15
+ className,
16
+ size = "md",
17
+ transitionType = "fade",
18
+ withCloseButton = false,
19
+ ...props
20
+ }, ref) => {
14
21
  const { open } = useDialogContext("DialogContent");
15
22
  return /* @__PURE__ */ jsx(AnimatePresence, { children: open && /* @__PURE__ */ jsxs(RadixDialog.Portal, { forceMount: true, children: [
16
23
  /* @__PURE__ */ jsx(Transition, { children: /* @__PURE__ */ jsx(Box, { asChild: true, ...overlay(), children: /* @__PURE__ */ jsx(RadixDialog.Overlay, {}) }) }),
17
- /* @__PURE__ */ jsx(Transition, { "data-side": "bottom", type: "fade", children: /* @__PURE__ */ jsx(Box, { asChild: true, ...content({ size }), children: /* @__PURE__ */ jsxs(RadixDialog.Content, { ref, ...props, children: [
24
+ /* @__PURE__ */ jsx(Transition, { "data-side": "bottom", type: transitionType, children: /* @__PURE__ */ jsx(Box, { asChild: true, ...content({ size }, className), ...props, children: /* @__PURE__ */ jsxs(RadixDialog.Content, { ref, children: [
18
25
  children,
19
26
  withCloseButton && /* @__PURE__ */ jsx(
20
27
  Button,
@@ -1,4 +1,4 @@
1
- import './../../assets/src/layers/layers.css.ts.vanilla-C0SoXsdY.css';
1
+ import './../../assets/src/layers/layers.css.ts.vanilla-D3upUtFn.css';
2
2
  import { recipeRuntime } from '../vanilla-extract/recipeRuntime.js';
3
3
 
4
4
  var footer = recipeRuntime({base:[{borderColor:'border.secondary',borderT:'1',flexDirection:'row',gap:'md',justifyContent:'end',px:'lg',py:'20'}]});
@@ -2,14 +2,10 @@ import { jsx } from 'react/jsx-runtime';
2
2
  import * as RadixDialog from '@radix-ui/react-dialog';
3
3
  import { forwardRef } from 'react';
4
4
  import { Button } from '../button/Button.js';
5
- import { extractSprinkles } from '../sprinkles/extractSprinkles.js';
6
- import '../sprinkles/sprinkles.js';
7
- import '../sprinkles/sprinklesMerge.js';
8
5
 
9
6
  const DialogTrigger = forwardRef(
10
7
  ({ asChild, children, ...props }, ref) => {
11
- const { restProps, sprinkleProps } = extractSprinkles(props);
12
- return /* @__PURE__ */ jsx(RadixDialog.Trigger, { asChild: true, ref, ...sprinkleProps, children: asChild ? children : /* @__PURE__ */ jsx(Button, { ...restProps, children }) });
8
+ return /* @__PURE__ */ jsx(RadixDialog.Trigger, { asChild: true, ref, ...props, children: asChild ? children : /* @__PURE__ */ jsx(Button, { children }) });
13
9
  }
14
10
  );
15
11
  DialogTrigger.displayName = "@optiaxiom/react/DialogTrigger";
@@ -1,7 +1,7 @@
1
- import './../../assets/src/layers/layers.css.ts.vanilla-C0SoXsdY.css';
2
- import './../../assets/src/disclosure-content/DisclosureContent.css.ts.vanilla-DZGY_b0f.css';
1
+ import './../../assets/src/layers/layers.css.ts.vanilla-D3upUtFn.css';
2
+ import './../../assets/src/disclosure-content/DisclosureContent.css.ts.vanilla-a3MAJnGX.css';
3
3
  import { recipeRuntime } from '../vanilla-extract/recipeRuntime.js';
4
4
 
5
- var content = recipeRuntime({base:[{overflow:'hidden'},'_1tcuhdc']});
5
+ var content = recipeRuntime({base:[{overflow:'hidden'},'w9lpdy']});
6
6
 
7
7
  export { content };
@@ -1,8 +1,8 @@
1
- import './../../assets/src/layers/layers.css.ts.vanilla-C0SoXsdY.css';
2
- import './../../assets/src/disclosure-trigger/DisclosureTrigger.css.ts.vanilla-ubqGTRET.css';
1
+ import './../../assets/src/layers/layers.css.ts.vanilla-D3upUtFn.css';
2
+ import './../../assets/src/disclosure-trigger/DisclosureTrigger.css.ts.vanilla-CcLwBaNn.css';
3
3
  import { recipeRuntime } from '../vanilla-extract/recipeRuntime.js';
4
4
 
5
- var icon = recipeRuntime({base:[{transition:'transform'}],variants:{chevronPosition:{end:'_17e1qtm',start:'_2rp2cb'}}});
6
- var trigger = recipeRuntime({base:[{flexDirection:'row',fontSize:'md',fontWeight:'500',gap:'4',p:'xs',px:'4',rounded:'md',textAlign:'start',w:'full'},'_1jk1yid']});
5
+ var icon = recipeRuntime({base:[{transition:'transform'}],variants:{chevronPosition:{end:'r3du9s',start:'_1p9y4b3'}}});
6
+ var trigger = recipeRuntime({base:[{flexDirection:'row',fontSize:'md',fontWeight:'500',gap:'4',p:'xs',px:'4',rounded:'md',textAlign:'start',w:'full'},'_18ltbil']});
7
7
 
8
8
  export { icon, trigger };
@@ -1,9 +1,9 @@
1
- import './../../assets/src/layers/layers.css.ts.vanilla-C0SoXsdY.css';
2
- import './../../assets/src/drawer/Drawer.css.ts.vanilla-Bc73PiWx.css';
1
+ import './../../assets/src/layers/layers.css.ts.vanilla-D3upUtFn.css';
2
+ import './../../assets/src/drawer/Drawer.css.ts.vanilla-CzFuJJPj.css';
3
3
  import { recipeRuntime } from '../vanilla-extract/recipeRuntime.js';
4
4
 
5
- var close = recipeRuntime({base:[{rounded:'full'},'_19w3mws']});
6
- var content = recipeRuntime({base:[{bg:'bg.default',display:'flex',flexDirection:'column',shadow:'md',z:'popover'},'_12td224'],variants:{position:{bottom:[{borderT:'1'},'_1xtn1xo'],left:[{borderR:'1',h:'full',maxW:['full','lg'],w:['full','3/4']},'_3y5zf1'],right:[{borderL:'1',h:'full',maxW:['full','lg'],w:['full','3/4']},'lpk9qi']}}});
7
- var overlay = recipeRuntime({base:[{bg:'bg.overlay',z:'popover'},'_1mg2xvx']});
5
+ var close = recipeRuntime({base:[{rounded:'full'},'h0n686']});
6
+ var content = recipeRuntime({base:[{bg:'bg.default',display:'flex',flexDirection:'column',shadow:'md',z:'popover'},'_1qk8vbu'],variants:{position:{bottom:[{borderT:'1'},'_1dn3jb9'],left:[{borderR:'1',h:'full',maxW:['full','lg'],w:['full','3/4']},'_1u76iqg'],right:[{borderL:'1',h:'full',maxW:['full','lg'],w:['full','3/4']},'_1ro0axs']}}});
7
+ var overlay = recipeRuntime({base:[{bg:'bg.overlay',z:'popover'},'q2o83']});
8
8
 
9
9
  export { close, content, overlay };
@@ -0,0 +1,13 @@
1
+ import { jsx } from 'react/jsx-runtime';
2
+ import { Slot } from '@radix-ui/react-slot';
3
+ import { forwardRef } from 'react';
4
+
5
+ const FilteredSlot = forwardRef(
6
+ ({ exclude, ...props }, ref) => {
7
+ delete props[exclude];
8
+ return /* @__PURE__ */ jsx(Slot, { ref, ...props });
9
+ }
10
+ );
11
+ FilteredSlot.displayName = "@optiaxiom/react/FilteredSlot";
12
+
13
+ export { FilteredSlot };
@@ -0,0 +1,7 @@
1
+ import './../../assets/src/layers/layers.css.ts.vanilla-D3upUtFn.css';
2
+ import './../../assets/src/highlight/Highlight.css.ts.vanilla-RmkcqM-d.css';
3
+ import { recipeRuntime } from '../vanilla-extract/recipeRuntime.js';
4
+
5
+ var mark = recipeRuntime({base:'_1if42hh'});
6
+
7
+ export { mark };
@@ -0,0 +1,20 @@
1
+ import { jsx } from 'react/jsx-runtime';
2
+ import { Fragment } from 'react';
3
+ import { Box } from '../box/Box.js';
4
+ import { mark } from './Highlight-css.js';
5
+ import { useHighlightedChunks } from './useHighlightedChunks.js';
6
+
7
+ function Highlight({
8
+ children = (chunk) => chunk,
9
+ content,
10
+ query,
11
+ ...props
12
+ }) {
13
+ const chunks = useHighlightedChunks(content || "", query);
14
+ return /* @__PURE__ */ jsx(Box, { ...props, children: chunks.map(({ chunk, highlighted }, index) => /* @__PURE__ */ jsx(Fragment, { children: highlighted ? children(
15
+ /* @__PURE__ */ jsx(Box, { asChild: true, ...mark(), children: /* @__PURE__ */ jsx("mark", { children: chunk }) })
16
+ ) : chunk }, index)) });
17
+ }
18
+ Highlight.displayName = "@optiaxiom/react/Highlight";
19
+
20
+ export { Highlight };
@@ -0,0 +1,23 @@
1
+ import { useMemo } from 'react';
2
+
3
+ const useHighlightedChunks = (content, query) => {
4
+ const terms = useMemo(
5
+ () => (Array.isArray(query) ? query : query ? [query] : []).map((q) => typeof q === "string" ? q.trim() : q).filter(Boolean),
6
+ [query]
7
+ );
8
+ if (terms.length === 0) {
9
+ return [{ chunk: content, highlighted: false }];
10
+ }
11
+ const pattern = new RegExp(
12
+ "(" + terms.map(
13
+ (term) => term instanceof RegExp ? term.source : `(?![^<>]*>)(^|\\b)(?=[^/.])${escapeRegExp(term)}`
14
+ ).join("|") + ")",
15
+ "gi"
16
+ );
17
+ return content.split(pattern).map((chunk) => ({ chunk, highlighted: pattern.test(chunk) }));
18
+ };
19
+ function escapeRegExp(string) {
20
+ return string.replace(/[/\-\\^$*+?.()|[\]{}]/g, "\\$&");
21
+ }
22
+
23
+ export { useHighlightedChunks };
@@ -1,7 +1,7 @@
1
- import './../../assets/src/layers/layers.css.ts.vanilla-C0SoXsdY.css';
2
- import './../../assets/src/hover-card-content/HoverCardContent.css.ts.vanilla-D36Wbt06.css';
1
+ import './../../assets/src/layers/layers.css.ts.vanilla-D3upUtFn.css';
2
+ import './../../assets/src/hover-card-content/HoverCardContent.css.ts.vanilla-ClL_Dtju.css';
3
3
  import { recipeRuntime } from '../vanilla-extract/recipeRuntime.js';
4
4
 
5
- var content = recipeRuntime({base:[{bg:'bg.default',border:'1',borderColor:'border.secondary',display:'flex',flexDirection:'column',fontSize:'md',gap:'2',p:'sm',rounded:'lg',shadow:'md',z:'popover'},'cxpjzg']});
5
+ var content = recipeRuntime({base:[{bg:'bg.default',border:'1',borderColor:'border.secondary',display:'flex',flexDirection:'column',fontSize:'md',gap:'2',p:'sm',rounded:'lg',shadow:'md',z:'popover'},'lnwceg']});
6
6
 
7
7
  export { content };